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