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; 10*9c28abb7SBen Skeggs char name[16]; 11c39f472eSBen Skeggs u32 debug; 1254d10db1SBen Skeggs struct list_head head; 13c39f472eSBen Skeggs 1468f3f702SBen Skeggs bool oneinit; 15c39f472eSBen Skeggs }; 16c39f472eSBen Skeggs 17f0290215SBen Skeggs struct nvkm_subdev_func { 18f0290215SBen Skeggs void *(*dtor)(struct nvkm_subdev *); 19f0290215SBen Skeggs int (*preinit)(struct nvkm_subdev *); 20f0290215SBen Skeggs int (*oneinit)(struct nvkm_subdev *); 21c5c9127bSBen Skeggs int (*info)(struct nvkm_subdev *, u64 mthd, u64 *data); 22f0290215SBen Skeggs int (*init)(struct nvkm_subdev *); 23f0290215SBen Skeggs int (*fini)(struct nvkm_subdev *, bool suspend); 24f0290215SBen Skeggs void (*intr)(struct nvkm_subdev *); 25f0290215SBen Skeggs }; 26f0290215SBen Skeggs 27*9c28abb7SBen Skeggs extern const char *nvkm_subdev_type[NVKM_SUBDEV_NR]; 28f02ca842SBen Skeggs int nvkm_subdev_new_(const struct nvkm_subdev_func *, struct nvkm_device *, 29f02ca842SBen Skeggs int index, struct nvkm_subdev **); 30f0290215SBen Skeggs void nvkm_subdev_ctor(const struct nvkm_subdev_func *, struct nvkm_device *, 3156d06fa2SBen Skeggs int index, struct nvkm_subdev *); 32f0290215SBen Skeggs void nvkm_subdev_del(struct nvkm_subdev **); 33f0290215SBen Skeggs int nvkm_subdev_preinit(struct nvkm_subdev *); 34f0290215SBen Skeggs int nvkm_subdev_init(struct nvkm_subdev *); 35f0290215SBen Skeggs int nvkm_subdev_fini(struct nvkm_subdev *, bool suspend); 36c5c9127bSBen Skeggs int nvkm_subdev_info(struct nvkm_subdev *, u64, u64 *); 37f0290215SBen Skeggs void nvkm_subdev_intr(struct nvkm_subdev *); 38f0290215SBen Skeggs 396594363bSBen Skeggs /* subdev logging */ 406594363bSBen Skeggs #define nvkm_printk_(s,l,p,f,a...) do { \ 41c1fcb148SAlexandre Courbot const struct nvkm_subdev *_subdev = (s); \ 42*9c28abb7SBen Skeggs if (CONFIG_NOUVEAU_DEBUG >= (l) && _subdev->debug >= (l)) \ 43*9c28abb7SBen Skeggs dev_##p(_subdev->device->dev, "%s: "f, _subdev->name, ##a); \ 44c39f472eSBen Skeggs } while(0) 456594363bSBen Skeggs #define nvkm_printk(s,l,p,f,a...) nvkm_printk_((s), NV_DBG_##l, p, f, ##a) 466594363bSBen Skeggs #define nvkm_fatal(s,f,a...) nvkm_printk((s), FATAL, crit, f, ##a) 476594363bSBen Skeggs #define nvkm_error(s,f,a...) nvkm_printk((s), ERROR, err, f, ##a) 486594363bSBen Skeggs #define nvkm_warn(s,f,a...) nvkm_printk((s), WARN, notice, f, ##a) 496594363bSBen Skeggs #define nvkm_info(s,f,a...) nvkm_printk((s), INFO, info, f, ##a) 506594363bSBen Skeggs #define nvkm_debug(s,f,a...) nvkm_printk((s), DEBUG, info, f, ##a) 516594363bSBen Skeggs #define nvkm_trace(s,f,a...) nvkm_printk((s), TRACE, info, f, ##a) 526594363bSBen Skeggs #define nvkm_spam(s,f,a...) nvkm_printk((s), SPAM, dbg, f, ##a) 53c39f472eSBen Skeggs #endif 54