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 struct mutex mutex; 11c39f472eSBen Skeggs u32 debug; 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