i915_sw_fence.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /*
  2. * i915_sw_fence.h - library routines for N:M synchronisation points
  3. *
  4. * Copyright (C) 2016 Intel Corporation
  5. *
  6. * This file is released under the GPLv2.
  7. *
  8. */
  9. #ifndef _I915_SW_FENCE_H_
  10. #define _I915_SW_FENCE_H_
  11. #include <linux/gfp.h>
  12. #include <linux/kref.h>
  13. #include <linux/notifier.h> /* for NOTIFY_DONE */
  14. #include <linux/wait.h>
  15. struct completion;
  16. struct dma_fence;
  17. struct dma_fence_ops;
  18. struct reservation_object;
  19. struct i915_sw_fence {
  20. wait_queue_head_t wait;
  21. unsigned long flags;
  22. struct kref kref;
  23. atomic_t pending;
  24. };
  25. #define I915_SW_FENCE_CHECKED_BIT 0 /* used internally for DAG checking */
  26. #define I915_SW_FENCE_PRIVATE_BIT 1 /* available for use by owner */
  27. #define I915_SW_FENCE_MASK (~3)
  28. enum i915_sw_fence_notify {
  29. FENCE_COMPLETE,
  30. FENCE_FREE
  31. };
  32. typedef int (*i915_sw_fence_notify_t)(struct i915_sw_fence *,
  33. enum i915_sw_fence_notify state);
  34. #define __i915_sw_fence_call __aligned(4)
  35. void __i915_sw_fence_init(struct i915_sw_fence *fence,
  36. i915_sw_fence_notify_t fn,
  37. const char *name,
  38. struct lock_class_key *key);
  39. #ifdef CONFIG_LOCKDEP
  40. #define i915_sw_fence_init(fence, fn) \
  41. do { \
  42. static struct lock_class_key __key; \
  43. \
  44. __i915_sw_fence_init((fence), (fn), #fence, &__key); \
  45. } while (0)
  46. #else
  47. #define i915_sw_fence_init(fence, fn) \
  48. __i915_sw_fence_init((fence), (fn), NULL, NULL)
  49. #endif
  50. #ifdef CONFIG_DRM_I915_SW_FENCE_DEBUG_OBJECTS
  51. void i915_sw_fence_fini(struct i915_sw_fence *fence);
  52. #else
  53. static inline void i915_sw_fence_fini(struct i915_sw_fence *fence) {}
  54. #endif
  55. void i915_sw_fence_commit(struct i915_sw_fence *fence);
  56. int i915_sw_fence_await_sw_fence(struct i915_sw_fence *fence,
  57. struct i915_sw_fence *after,
  58. wait_queue_t *wq);
  59. int i915_sw_fence_await_sw_fence_gfp(struct i915_sw_fence *fence,
  60. struct i915_sw_fence *after,
  61. gfp_t gfp);
  62. int i915_sw_fence_await_dma_fence(struct i915_sw_fence *fence,
  63. struct dma_fence *dma,
  64. unsigned long timeout,
  65. gfp_t gfp);
  66. int i915_sw_fence_await_reservation(struct i915_sw_fence *fence,
  67. struct reservation_object *resv,
  68. const struct dma_fence_ops *exclude,
  69. bool write,
  70. unsigned long timeout,
  71. gfp_t gfp);
  72. static inline bool i915_sw_fence_signaled(const struct i915_sw_fence *fence)
  73. {
  74. return atomic_read(&fence->pending) <= 0;
  75. }
  76. static inline bool i915_sw_fence_done(const struct i915_sw_fence *fence)
  77. {
  78. return atomic_read(&fence->pending) < 0;
  79. }
  80. static inline void i915_sw_fence_wait(struct i915_sw_fence *fence)
  81. {
  82. wait_event(fence->wait, i915_sw_fence_done(fence));
  83. }
  84. #endif /* _I915_SW_FENCE_H_ */