1/*	$NetBSD: nv50.h,v 1.3 2021/12/18 23:45:39 riastradh Exp $	*/
2
3/* SPDX-License-Identifier: MIT */
4#ifndef __NV50_DEVINIT_H__
5#define __NV50_DEVINIT_H__
6#define nv50_devinit(p) container_of((p), struct nv50_devinit, base)
7#include "priv.h"
8
9struct nv50_devinit {
10	struct nvkm_devinit base;
11	u32 r001540;
12};
13
14int nv50_devinit_new_(const struct nvkm_devinit_func *, struct nvkm_device *,
15		      int, struct nvkm_devinit **);
16void nv50_devinit_preinit(struct nvkm_devinit *);
17void nv50_devinit_init(struct nvkm_devinit *);
18int  nv50_devinit_pll_set(struct nvkm_devinit *, u32, u32);
19
20int  gt215_devinit_pll_set(struct nvkm_devinit *, u32, u32);
21
22int  gf100_devinit_ctor(struct nvkm_object *, struct nvkm_object *,
23			struct nvkm_oclass *, void *, u32,
24			struct nvkm_object **);
25int  gf100_devinit_pll_set(struct nvkm_devinit *, u32, u32);
26void gf100_devinit_preinit(struct nvkm_devinit *);
27
28u64  gm107_devinit_disable(struct nvkm_devinit *);
29
30int gm200_devinit_post(struct nvkm_devinit *, bool);
31void gm200_devinit_preos(struct nv50_devinit *, bool);
32#endif
33