[PATCH v3 10/19] lib/amdgpu: add macro for adding cmds in user queue
Sunil Khatri
sunil.khatri at amd.com
Fri Mar 28 08:24:07 UTC 2025
Add macros which enable adding cmds in user queue
for size more than ring size. Ring is treate as
a circular buffer and ovewrite from beginning
when write ptr reaches the end of queue.
Signed-off-by: Sunil Khatri <sunil.khatri at amd.com>
---
lib/amdgpu/amd_user_queue.h | 17 ++++++++++++++++-
1 file changed, 16 insertions(+), 1 deletion(-)
diff --git a/lib/amdgpu/amd_user_queue.h b/lib/amdgpu/amd_user_queue.h
index 355f16f19..539a78819 100644
--- a/lib/amdgpu/amd_user_queue.h
+++ b/lib/amdgpu/amd_user_queue.h
@@ -15,9 +15,24 @@
#define PAGE_SIZE 4096
#endif
-#define USERMODE_QUEUE_SIZE (PAGE_SIZE * 256) //In bytes
+#define USERMODE_QUEUE_SIZE (PAGE_SIZE * 256) //In bytes with total size as 1 Mbyte
#define ALIGNMENT 4096
#define DOORBELL_INDEX 4
+#define USERMODE_QUEUE_SIZE_DW (USERMODE_QUEUE_SIZE >> 2)
+#define USERMODE_QUEUE_SIZE_DW_MASK (USERMODE_QUEUE_SIZE_DW - 1)
+
+#define amdgpu_pkt_begin() uint32_t __num_dw_written = 0; \
+ uint32_t __ring_start = *ring_context->wptr_cpu & USERMODE_QUEUE_SIZE_DW_MASK;
+
+#define amdgpu_pkt_add_dw(value) do { \
+ *(ring_context->queue_cpu + \
+ ((__ring_start + __num_dw_written) & USERMODE_QUEUE_SIZE_DW_MASK)) \
+ = value; \
+ __num_dw_written++;\
+} while (0)
+
+#define amdgpu_pkt_end() \
+ *ring_context->wptr_cpu += __num_dw_written
void amdgpu_alloc_doorbell(amdgpu_device_handle device_handle, struct amdgpu_userq_bo *doorbell_bo,
unsigned int size, unsigned int domain);
--
2.43.0
More information about the igt-dev
mailing list