1ebb58dc2SBen Skeggs #ifndef __NVKM_PMU_PRIV_H__ 2ebb58dc2SBen Skeggs #define __NVKM_PMU_PRIV_H__ 3ebb58dc2SBen Skeggs #include <subdev/pmu.h> 4ebb58dc2SBen Skeggs #include <subdev/pmu/fuc/os.h> 5ebb58dc2SBen Skeggs 621b13791SBen Skeggs #define nvkm_pmu_create(p, e, o, d) \ 721b13791SBen Skeggs nvkm_pmu_create_((p), (e), (o), sizeof(**d), (void **)d) 821b13791SBen Skeggs #define nvkm_pmu_destroy(p) \ 921b13791SBen Skeggs nvkm_subdev_destroy(&(p)->base) 1021b13791SBen Skeggs #define nvkm_pmu_init(p) ({ \ 1121b13791SBen Skeggs struct nvkm_pmu *_pmu = (p); \ 1221b13791SBen Skeggs _nvkm_pmu_init(nv_object(_pmu)); \ 13ebb58dc2SBen Skeggs }) 1421b13791SBen Skeggs #define nvkm_pmu_fini(p,s) ({ \ 1521b13791SBen Skeggs struct nvkm_pmu *_pmu = (p); \ 1621b13791SBen Skeggs _nvkm_pmu_fini(nv_object(_pmu), (s)); \ 17ebb58dc2SBen Skeggs }) 18ebb58dc2SBen Skeggs 1921b13791SBen Skeggs int nvkm_pmu_create_(struct nvkm_object *, struct nvkm_object *, 2021b13791SBen Skeggs struct nvkm_oclass *, int, void **); 21ebb58dc2SBen Skeggs 2221b13791SBen Skeggs int _nvkm_pmu_ctor(struct nvkm_object *, struct nvkm_object *, 2321b13791SBen Skeggs struct nvkm_oclass *, void *, u32, 2421b13791SBen Skeggs struct nvkm_object **); 2521b13791SBen Skeggs #define _nvkm_pmu_dtor _nvkm_subdev_dtor 2621b13791SBen Skeggs int _nvkm_pmu_init(struct nvkm_object *); 2721b13791SBen Skeggs int _nvkm_pmu_fini(struct nvkm_object *, bool); 2821b13791SBen Skeggs void nvkm_pmu_pgob(struct nvkm_pmu *pmu, bool enable); 29ebb58dc2SBen Skeggs 30ebb58dc2SBen Skeggs struct nvkm_pmu_impl { 3121b13791SBen Skeggs struct nvkm_oclass base; 32ebb58dc2SBen Skeggs struct { 33ebb58dc2SBen Skeggs u32 *data; 34ebb58dc2SBen Skeggs u32 size; 35ebb58dc2SBen Skeggs } code; 36ebb58dc2SBen Skeggs struct { 37ebb58dc2SBen Skeggs u32 *data; 38ebb58dc2SBen Skeggs u32 size; 39ebb58dc2SBen Skeggs } data; 40ebb58dc2SBen Skeggs 4121b13791SBen Skeggs void (*pgob)(struct nvkm_pmu *, bool); 42ebb58dc2SBen Skeggs }; 43f02a0e84SBen Skeggs 44f02a0e84SBen Skeggs void gk110_pmu_pgob(struct nvkm_pmu *, bool); 45ebb58dc2SBen Skeggs #endif 46