1b7019ac5SIlia Mirkin /* SPDX-License-Identifier: MIT */
25025407bSBen Skeggs #ifndef __NVKM_SUBDEV_H__
35025407bSBen Skeggs #define __NVKM_SUBDEV_H__
468f3f702SBen Skeggs #include <core/device.h>
5c39f472eSBen Skeggs 
65025407bSBen Skeggs struct nvkm_subdev {
7f0290215SBen Skeggs 	const struct nvkm_subdev_func *func;
8d351b856SBen Skeggs 	struct nvkm_device *device;
968f3f702SBen Skeggs 	enum nvkm_devidx index;
10c39f472eSBen Skeggs 	u32 debug;
11*54d10db1SBen Skeggs 	struct list_head head;
12c39f472eSBen Skeggs 
1368f3f702SBen Skeggs 	bool oneinit;
14c39f472eSBen Skeggs };
15c39f472eSBen Skeggs 
16f0290215SBen Skeggs struct nvkm_subdev_func {
17f0290215SBen Skeggs 	void *(*dtor)(struct nvkm_subdev *);
18f0290215SBen Skeggs 	int (*preinit)(struct nvkm_subdev *);
19f0290215SBen Skeggs 	int (*oneinit)(struct nvkm_subdev *);
20c5c9127bSBen Skeggs 	int (*info)(struct nvkm_subdev *, u64 mthd, u64 *data);
21f0290215SBen Skeggs 	int (*init)(struct nvkm_subdev *);
22f0290215SBen Skeggs 	int (*fini)(struct nvkm_subdev *, bool suspend);
23f0290215SBen Skeggs 	void (*intr)(struct nvkm_subdev *);
24f0290215SBen Skeggs };
25f0290215SBen Skeggs 
2668f3f702SBen Skeggs extern const char *nvkm_subdev_name[NVKM_SUBDEV_NR];
27f02ca842SBen Skeggs int nvkm_subdev_new_(const struct nvkm_subdev_func *, struct nvkm_device *,
28f02ca842SBen Skeggs 		     int index, struct nvkm_subdev **);
29f0290215SBen Skeggs void nvkm_subdev_ctor(const struct nvkm_subdev_func *, struct nvkm_device *,
3056d06fa2SBen Skeggs 		      int index, struct nvkm_subdev *);
31f0290215SBen Skeggs void nvkm_subdev_del(struct nvkm_subdev **);
32f0290215SBen Skeggs int  nvkm_subdev_preinit(struct nvkm_subdev *);
33f0290215SBen Skeggs int  nvkm_subdev_init(struct nvkm_subdev *);
34f0290215SBen Skeggs int  nvkm_subdev_fini(struct nvkm_subdev *, bool suspend);
35c5c9127bSBen Skeggs int  nvkm_subdev_info(struct nvkm_subdev *, u64, u64 *);
36f0290215SBen Skeggs void nvkm_subdev_intr(struct nvkm_subdev *);
37f0290215SBen Skeggs 
386594363bSBen Skeggs /* subdev logging */
396594363bSBen Skeggs #define nvkm_printk_(s,l,p,f,a...) do {                                        \
40c1fcb148SAlexandre Courbot 	const struct nvkm_subdev *_subdev = (s);                               \
4182be74eeSBen Skeggs 	if (CONFIG_NOUVEAU_DEBUG >= (l) && _subdev->debug >= (l)) {            \
42f0290215SBen Skeggs 		dev_##p(_subdev->device->dev, "%s: "f,                         \
43f0290215SBen Skeggs 			nvkm_subdev_name[_subdev->index], ##a);                \
44f0290215SBen Skeggs 	}                                                                      \
45c39f472eSBen Skeggs } while(0)
466594363bSBen Skeggs #define nvkm_printk(s,l,p,f,a...) nvkm_printk_((s), NV_DBG_##l, p, f, ##a)
476594363bSBen Skeggs #define nvkm_fatal(s,f,a...) nvkm_printk((s), FATAL,   crit, f, ##a)
486594363bSBen Skeggs #define nvkm_error(s,f,a...) nvkm_printk((s), ERROR,    err, f, ##a)
496594363bSBen Skeggs #define nvkm_warn(s,f,a...)  nvkm_printk((s),  WARN, notice, f, ##a)
506594363bSBen Skeggs #define nvkm_info(s,f,a...)  nvkm_printk((s),  INFO,   info, f, ##a)
516594363bSBen Skeggs #define nvkm_debug(s,f,a...) nvkm_printk((s), DEBUG,   info, f, ##a)
526594363bSBen Skeggs #define nvkm_trace(s,f,a...) nvkm_printk((s), TRACE,   info, f, ##a)
536594363bSBen Skeggs #define nvkm_spam(s,f,a...)  nvkm_printk((s),  SPAM,    dbg, f, ##a)
54c39f472eSBen Skeggs #endif
55