0001
0002 #ifndef __NVKM_SW_H__
0003 #define __NVKM_SW_H__
0004 #include <core/engine.h>
0005
0006 struct nvkm_sw {
0007 const struct nvkm_sw_func *func;
0008 struct nvkm_engine engine;
0009
0010 struct list_head chan;
0011 };
0012
0013 bool nvkm_sw_mthd(struct nvkm_sw *sw, int chid, int subc, u32 mthd, u32 data);
0014
0015 int nv04_sw_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_sw **);
0016 int nv10_sw_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_sw **);
0017 int nv50_sw_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_sw **);
0018 int gf100_sw_new(struct nvkm_device *, enum nvkm_subdev_type, int inst, struct nvkm_sw **);
0019 #endif