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