drm_vblank_work.h 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /* SPDX-License-Identifier: MIT */
  2. #ifndef _DRM_VBLANK_WORK_H_
  3. #define _DRM_VBLANK_WORK_H_
  4. #include <linux/kthread.h>
  5. struct drm_crtc;
  6. /**
  7. * struct drm_vblank_work - A delayed work item which delays until a target
  8. * vblank passes, and then executes at realtime priority outside of IRQ
  9. * context.
  10. *
  11. * See also:
  12. * drm_vblank_work_schedule()
  13. * drm_vblank_work_init()
  14. * drm_vblank_work_cancel_sync()
  15. * drm_vblank_work_flush()
  16. * drm_vblank_work_flush_all()
  17. */
  18. struct drm_vblank_work {
  19. /**
  20. * @base: The base &kthread_work item which will be executed by
  21. * &drm_vblank_crtc.worker. Drivers should not interact with this
  22. * directly, and instead rely on drm_vblank_work_init() to initialize
  23. * this.
  24. */
  25. struct kthread_work base;
  26. /**
  27. * @vblank: A pointer to &drm_vblank_crtc this work item belongs to.
  28. */
  29. struct drm_vblank_crtc *vblank;
  30. /**
  31. * @count: The target vblank this work will execute on. Drivers should
  32. * not modify this value directly, and instead use
  33. * drm_vblank_work_schedule()
  34. */
  35. u64 count;
  36. /**
  37. * @cancelling: The number of drm_vblank_work_cancel_sync() calls that
  38. * are currently running. A work item cannot be rescheduled until all
  39. * calls have finished.
  40. */
  41. int cancelling;
  42. /**
  43. * @node: The position of this work item in
  44. * &drm_vblank_crtc.pending_work.
  45. */
  46. struct list_head node;
  47. };
  48. /**
  49. * to_drm_vblank_work - Retrieve the respective &drm_vblank_work item from a
  50. * &kthread_work
  51. * @_work: The &kthread_work embedded inside a &drm_vblank_work
  52. */
  53. #define to_drm_vblank_work(_work) \
  54. container_of((_work), struct drm_vblank_work, base)
  55. int drm_vblank_work_schedule(struct drm_vblank_work *work,
  56. u64 count, bool nextonmiss);
  57. void drm_vblank_work_init(struct drm_vblank_work *work, struct drm_crtc *crtc,
  58. void (*func)(struct kthread_work *work));
  59. bool drm_vblank_work_cancel_sync(struct drm_vblank_work *work);
  60. void drm_vblank_work_flush(struct drm_vblank_work *work);
  61. void drm_vblank_work_flush_all(struct drm_crtc *crtc);
  62. #endif /* !_DRM_VBLANK_WORK_H_ */