1b7019ac5SIlia Mirkin /* SPDX-License-Identifier: MIT */
2898a2b32SBen Skeggs #ifndef __NVKM_SW_PRIV_H__
3898a2b32SBen Skeggs #define __NVKM_SW_PRIV_H__
407b9e6ccSBen Skeggs #define nvkm_sw(p) container_of((p), struct nvkm_sw, engine)
5898a2b32SBen Skeggs #include <engine/sw.h>
607b9e6ccSBen Skeggs struct nvkm_sw_chan;
7898a2b32SBen Skeggs 
88d6461d8SBen Skeggs int nvkm_sw_new_(const struct nvkm_sw_func *, struct nvkm_device *, enum nvkm_subdev_type, int,
98d6461d8SBen Skeggs 		 struct nvkm_sw **);
106f41c7c5SBen Skeggs 
1107b9e6ccSBen Skeggs struct nvkm_sw_chan_sclass {
1207b9e6ccSBen Skeggs 	int (*ctor)(struct nvkm_sw_chan *, const struct nvkm_oclass *,
1307b9e6ccSBen Skeggs 		    void *data, u32 size, struct nvkm_object **);
1407b9e6ccSBen Skeggs 	struct nvkm_sclass base;
1507b9e6ccSBen Skeggs };
1607b9e6ccSBen Skeggs 
1707b9e6ccSBen Skeggs struct nvkm_sw_func {
18*c546656fSBen Skeggs 	int (*chan_new)(struct nvkm_sw *, struct nvkm_chan *,
1907b9e6ccSBen Skeggs 			const struct nvkm_oclass *, struct nvkm_object **);
2007b9e6ccSBen Skeggs 	const struct nvkm_sw_chan_sclass sclass[];
2107b9e6ccSBen Skeggs };
22898a2b32SBen Skeggs #endif
23