fifo.h 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #ifndef __NVKM_FIFO_H__
  2. #define __NVKM_FIFO_H__
  3. #include <core/engine.h>
  4. #include <core/event.h>
  5. #define NVKM_FIFO_CHID_NR 4096
  6. struct nvkm_fifo_engn {
  7. struct nvkm_object *object;
  8. int refcount;
  9. int usecount;
  10. };
  11. struct nvkm_fifo_chan {
  12. const struct nvkm_fifo_chan_func *func;
  13. struct nvkm_fifo *fifo;
  14. u64 engines;
  15. struct nvkm_object object;
  16. struct list_head head;
  17. u16 chid;
  18. struct nvkm_gpuobj *inst;
  19. struct nvkm_gpuobj *push;
  20. struct nvkm_vm *vm;
  21. void __iomem *user;
  22. u64 addr;
  23. u32 size;
  24. struct nvkm_fifo_engn engn[NVKM_SUBDEV_NR];
  25. };
  26. struct nvkm_fifo {
  27. const struct nvkm_fifo_func *func;
  28. struct nvkm_engine engine;
  29. DECLARE_BITMAP(mask, NVKM_FIFO_CHID_NR);
  30. int nr;
  31. struct list_head chan;
  32. spinlock_t lock;
  33. struct nvkm_event uevent; /* async user trigger */
  34. struct nvkm_event cevent; /* channel creation event */
  35. struct nvkm_event kevent; /* channel killed */
  36. };
  37. void nvkm_fifo_pause(struct nvkm_fifo *, unsigned long *);
  38. void nvkm_fifo_start(struct nvkm_fifo *, unsigned long *);
  39. void nvkm_fifo_chan_put(struct nvkm_fifo *, unsigned long flags,
  40. struct nvkm_fifo_chan **);
  41. struct nvkm_fifo_chan *
  42. nvkm_fifo_chan_inst(struct nvkm_fifo *, u64 inst, unsigned long *flags);
  43. struct nvkm_fifo_chan *
  44. nvkm_fifo_chan_chid(struct nvkm_fifo *, int chid, unsigned long *flags);
  45. int nv04_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  46. int nv10_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  47. int nv17_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  48. int nv40_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  49. int nv50_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  50. int g84_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  51. int gf100_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  52. int gk104_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  53. int gk110_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  54. int gk208_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  55. int gk20a_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  56. int gm107_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  57. int gm200_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  58. int gm20b_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  59. int gp100_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  60. int gp10b_fifo_new(struct nvkm_device *, int, struct nvkm_fifo **);
  61. #endif