drm_suballoc.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /* SPDX-License-Identifier: GPL-2.0 OR MIT */
  2. /*
  3. * Copyright 2011 Red Hat Inc.
  4. * Copyright © 2022 Intel Corporation
  5. */
  6. #ifndef _DRM_SUBALLOC_H_
  7. #define _DRM_SUBALLOC_H_
  8. #include <drm/drm_mm.h>
  9. #include <linux/dma-fence.h>
  10. #include <linux/types.h>
  11. #define DRM_SUBALLOC_MAX_QUEUES 32
  12. /**
  13. * struct drm_suballoc_manager - fenced range allocations
  14. * @wq: Wait queue for sleeping allocations on contention.
  15. * @hole: Pointer to first hole node.
  16. * @olist: List of allocated ranges.
  17. * @flist: Array[fence context hash] of queues of fenced allocated ranges.
  18. * @size: Size of the managed range.
  19. * @align: Default alignment for the managed range.
  20. */
  21. struct drm_suballoc_manager {
  22. wait_queue_head_t wq;
  23. struct list_head *hole;
  24. struct list_head olist;
  25. struct list_head flist[DRM_SUBALLOC_MAX_QUEUES];
  26. size_t size;
  27. size_t align;
  28. };
  29. /**
  30. * struct drm_suballoc - Sub-allocated range
  31. * @olist: List link for list of allocated ranges.
  32. * @flist: List linkk for the manager fenced allocated ranges queues.
  33. * @manager: The drm_suballoc_manager.
  34. * @soffset: Start offset.
  35. * @eoffset: End offset + 1 so that @eoffset - @soffset = size.
  36. * @fence: The fence protecting the allocation.
  37. */
  38. struct drm_suballoc {
  39. struct list_head olist;
  40. struct list_head flist;
  41. struct drm_suballoc_manager *manager;
  42. size_t soffset;
  43. size_t eoffset;
  44. struct dma_fence *fence;
  45. };
  46. void drm_suballoc_manager_init(struct drm_suballoc_manager *sa_manager,
  47. size_t size, size_t align);
  48. void drm_suballoc_manager_fini(struct drm_suballoc_manager *sa_manager);
  49. struct drm_suballoc *
  50. drm_suballoc_new(struct drm_suballoc_manager *sa_manager, size_t size,
  51. gfp_t gfp, bool intr, size_t align);
  52. void drm_suballoc_free(struct drm_suballoc *sa, struct dma_fence *fence);
  53. /**
  54. * drm_suballoc_soffset - Range start.
  55. * @sa: The struct drm_suballoc.
  56. *
  57. * Return: The start of the allocated range.
  58. */
  59. static inline size_t drm_suballoc_soffset(struct drm_suballoc *sa)
  60. {
  61. return sa->soffset;
  62. }
  63. /**
  64. * drm_suballoc_eoffset - Range end.
  65. * @sa: The struct drm_suballoc.
  66. *
  67. * Return: The end of the allocated range + 1.
  68. */
  69. static inline size_t drm_suballoc_eoffset(struct drm_suballoc *sa)
  70. {
  71. return sa->eoffset;
  72. }
  73. /**
  74. * drm_suballoc_size - Range size.
  75. * @sa: The struct drm_suballoc.
  76. *
  77. * Return: The size of the allocated range.
  78. */
  79. static inline size_t drm_suballoc_size(struct drm_suballoc *sa)
  80. {
  81. return sa->eoffset - sa->soffset;
  82. }
  83. #ifdef CONFIG_DEBUG_FS
  84. void drm_suballoc_dump_debug_info(struct drm_suballoc_manager *sa_manager,
  85. struct drm_printer *p,
  86. unsigned long long suballoc_base);
  87. #else
  88. static inline void
  89. drm_suballoc_dump_debug_info(struct drm_suballoc_manager *sa_manager,
  90. struct drm_printer *p,
  91. unsigned long long suballoc_base)
  92. { }
  93. #endif
  94. #endif /* _DRM_SUBALLOC_H_ */