]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blob - drivers/gpu/drm/nouveau/core/subdev/devinit/priv.h
drm/nv50-/devinit: prevent use of engines marked as disabled by hw/vbios
[mirror_ubuntu-artful-kernel.git] / drivers / gpu / drm / nouveau / core / subdev / devinit / priv.h
1 #ifndef __NVKM_DEVINIT_PRIV_H__
2 #define __NVKM_DEVINIT_PRIV_H__
3
4 #include <subdev/bios.h>
5 #include <subdev/bios/pll.h>
6 #include <subdev/clock/pll.h>
7 #include <subdev/devinit.h>
8
9 struct nouveau_devinit_impl {
10 struct nouveau_oclass base;
11 void (*meminit)(struct nouveau_devinit *);
12 int (*pll_set)(struct nouveau_devinit *, u32 type, u32 freq);
13 u64 (*disable)(struct nouveau_devinit *);
14 };
15
16 #define nouveau_devinit_create(p,e,o,d) \
17 nouveau_devinit_create_((p), (e), (o), sizeof(**d), (void **)d)
18 #define nouveau_devinit_destroy(p) \
19 nouveau_subdev_destroy(&(p)->base)
20 #define nouveau_devinit_init(p) ({ \
21 struct nouveau_devinit *d = (p); \
22 _nouveau_devinit_init(nv_object(d)); \
23 })
24 #define nouveau_devinit_fini(p,s) ({ \
25 struct nouveau_devinit *d = (p); \
26 _nouveau_devinit_fini(nv_object(d), (s)); \
27 })
28
29 int nouveau_devinit_create_(struct nouveau_object *, struct nouveau_object *,
30 struct nouveau_oclass *, int, void **);
31 #define _nouveau_devinit_dtor _nouveau_subdev_dtor
32 int _nouveau_devinit_init(struct nouveau_object *);
33 int _nouveau_devinit_fini(struct nouveau_object *, bool suspend);
34
35 #endif