Commit | Line | Data |
---|---|---|
898a2b32 BS |
1 | #ifndef __NVKM_SW_CHAN_H__ |
2 | #define __NVKM_SW_CHAN_H__ | |
07b9e6cc | 3 | #define nvkm_sw_chan(p) container_of((p), struct nvkm_sw_chan, object) |
898a2b32 | 4 | #include "priv.h" |
898a2b32 BS |
5 | #include <core/event.h> |
6 | ||
7 | struct nvkm_sw_chan { | |
61570911 | 8 | const struct nvkm_sw_chan_func *func; |
07b9e6cc BS |
9 | struct nvkm_object object; |
10 | struct nvkm_sw *sw; | |
61570911 BS |
11 | struct nvkm_fifo_chan *fifo; |
12 | struct list_head head; | |
07b9e6cc | 13 | |
898a2b32 BS |
14 | struct nvkm_event event; |
15 | }; | |
16 | ||
61570911 | 17 | struct nvkm_sw_chan_func { |
07b9e6cc | 18 | void *(*dtor)(struct nvkm_sw_chan *); |
61570911 BS |
19 | bool (*mthd)(struct nvkm_sw_chan *, int subc, u32 mthd, u32 data); |
20 | }; | |
21 | ||
07b9e6cc BS |
22 | int nvkm_sw_chan_ctor(const struct nvkm_sw_chan_func *, struct nvkm_sw *, |
23 | struct nvkm_fifo_chan *, const struct nvkm_oclass *, | |
24 | struct nvkm_sw_chan *); | |
61570911 | 25 | bool nvkm_sw_chan_mthd(struct nvkm_sw_chan *, int subc, u32 mthd, u32 data); |
898a2b32 | 26 | #endif |