xref: /linux/drivers/gpu/drm/nouveau/include/nvkm/subdev/devinit.h (revision fbc872c38c8fed31948c85683b5326ee5ab9fccc)
1 #ifndef __NVKM_DEVINIT_H__
2 #define __NVKM_DEVINIT_H__
3 #include <core/subdev.h>
4 struct nvkm_devinit;
5 
6 struct nvkm_devinit {
7 	const struct nvkm_devinit_func *func;
8 	struct nvkm_subdev subdev;
9 	bool post;
10 	bool force_post;
11 };
12 
13 u32 nvkm_devinit_mmio(struct nvkm_devinit *, u32 addr);
14 int nvkm_devinit_pll_set(struct nvkm_devinit *, u32 type, u32 khz);
15 void nvkm_devinit_meminit(struct nvkm_devinit *);
16 u64 nvkm_devinit_disable(struct nvkm_devinit *);
17 int nvkm_devinit_post(struct nvkm_devinit *, u64 *disable);
18 
19 int nv04_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
20 int nv05_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
21 int nv10_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
22 int nv1a_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
23 int nv20_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
24 int nv50_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
25 int g84_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
26 int g98_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
27 int gt215_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
28 int mcp89_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
29 int gf100_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
30 int gm107_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
31 int gm200_devinit_new(struct nvkm_device *, int, struct nvkm_devinit **);
32 #endif
33