Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / drivers / gpu / drm / nouveau / nvkm / subdev / pmu / priv.h
1 #ifndef __NVKM_PMU_PRIV_H__
2 #define __NVKM_PMU_PRIV_H__
3 #include <subdev/pmu.h>
4 #include <subdev/pmu/fuc/os.h>
5
6 #define nvkm_pmu_create(p, e, o, d)                                         \
7         nvkm_pmu_create_((p), (e), (o), sizeof(**d), (void **)d)
8 #define nvkm_pmu_destroy(p)                                                 \
9         nvkm_subdev_destroy(&(p)->base)
10 #define nvkm_pmu_init(p) ({                                                 \
11         struct nvkm_pmu *_pmu = (p);                                       \
12         _nvkm_pmu_init(nv_object(_pmu));                                   \
13 })
14 #define nvkm_pmu_fini(p,s) ({                                               \
15         struct nvkm_pmu *_pmu = (p);                                       \
16         _nvkm_pmu_fini(nv_object(_pmu), (s));                              \
17 })
18
19 int nvkm_pmu_create_(struct nvkm_object *, struct nvkm_object *,
20                         struct nvkm_oclass *, int, void **);
21
22 int _nvkm_pmu_ctor(struct nvkm_object *, struct nvkm_object *,
23                       struct nvkm_oclass *, void *, u32,
24                       struct nvkm_object **);
25 #define _nvkm_pmu_dtor _nvkm_subdev_dtor
26 int _nvkm_pmu_init(struct nvkm_object *);
27 int _nvkm_pmu_fini(struct nvkm_object *, bool);
28 void nvkm_pmu_pgob(struct nvkm_pmu *pmu, bool enable);
29
30 struct nvkm_pmu_impl {
31         struct nvkm_oclass base;
32         struct {
33                 u32 *data;
34                 u32  size;
35         } code;
36         struct {
37                 u32 *data;
38                 u32  size;
39         } data;
40
41         void (*pgob)(struct nvkm_pmu *, bool);
42 };
43
44 void gk110_pmu_pgob(struct nvkm_pmu *, bool);
45 #endif