[igt-dev] [PATCH i-g-t 2/6] tests/api_intel_allocator: Verify gem-pool is working as expected
Zbigniew Kempczyński
zbigniew.kempczynski at intel.com
Fri Mar 11 12:13:14 UTC 2022
Simple check which acquires buffer objects from gem-pool. It verifies:
- object reuse (previously created is completed in execbuf)
- object creation (submitting batches when spinner is executing).
Signed-off-by: Zbigniew Kempczyński <zbigniew.kempczynski at intel.com>
Cc: Kamil Konieczny <kamil.konieczny at linux.intel.com>
Reviewed-by: Kamil Konieczny <kamil.konieczny at linux.intel.com>
---
tests/i915/api_intel_allocator.c | 58 ++++++++++++++++++++++++++++++++
1 file changed, 58 insertions(+)
diff --git a/tests/i915/api_intel_allocator.c b/tests/i915/api_intel_allocator.c
index a652caf4ec..a7929e9b13 100644
--- a/tests/i915/api_intel_allocator.c
+++ b/tests/i915/api_intel_allocator.c
@@ -692,6 +692,60 @@ static void fork_reopen_allocator(int fd, uint8_t type)
intel_allocator_multiprocess_stop();
}
+static uint32_t single_exec_from_pool(int i915, uint64_t ahnd, uint64_t size)
+{
+ struct drm_i915_gem_execbuffer2 execbuf = {};
+ struct drm_i915_gem_exec_object2 obj = {};
+ uint32_t bb = gem_create_from_pool(i915, &size, REGION_SMEM);
+ uint32_t *bbptr;
+
+ bbptr = gem_mmap__device_coherent(i915, bb, 0, size, PROT_WRITE);
+ *bbptr = MI_BATCH_BUFFER_END;
+ gem_munmap(bbptr, size);
+ obj.offset = get_offset(ahnd, bb, size, 0);
+ if (ahnd)
+ obj.flags = EXEC_OBJECT_PINNED;
+ obj.handle = bb;
+ execbuf.buffer_count = 1;
+ execbuf.buffers_ptr = to_user_pointer(&obj);
+ gem_execbuf(i915, &execbuf);
+
+ return bb;
+}
+
+static void gem_pool(int i915)
+{
+ uint32_t bb[4];
+ uint64_t ahnd = get_reloc_ahnd(i915, 0);
+ igt_spin_t *spin;
+
+ bb[0] = single_exec_from_pool(i915, ahnd, 4096);
+ gem_sync(i915, bb[0]);
+ bb[1] = single_exec_from_pool(i915, ahnd, 4096);
+ igt_assert(bb[0] == bb[1]);
+
+ bb[2] = single_exec_from_pool(i915, ahnd, 8192);
+ gem_sync(i915, bb[2]);
+ bb[3] = single_exec_from_pool(i915, ahnd, 8192);
+ igt_assert(bb[2] == bb[3]);
+ igt_assert(bb[0] != bb[2]);
+
+ spin = igt_spin_new(i915,
+ .ahnd = ahnd,
+ .engine = I915_EXEC_DEFAULT);
+ bb[0] = single_exec_from_pool(i915, ahnd, 4096);
+ bb[1] = single_exec_from_pool(i915, ahnd, 4096);
+ bb[2] = single_exec_from_pool(i915, ahnd, 8192);
+ bb[3] = single_exec_from_pool(i915, ahnd, 8192);
+ igt_spin_free(i915, spin);
+ igt_assert(bb[0] != bb[1]);
+ igt_assert(bb[2] != bb[3]);
+
+ put_ahnd(ahnd);
+
+ gem_pool_dump();
+}
+
struct allocators {
const char *name;
uint8_t type;
@@ -790,6 +844,10 @@ igt_main
igt_subtest_f("execbuf-with-allocator")
execbuf_with_allocator(fd);
+ igt_describe("Verifies creating and executing bb from gem pool");
+ igt_subtest_f("gem-pool")
+ gem_pool(fd);
+
igt_fixture
close(fd);
}
--
2.32.0
More information about the igt-dev
mailing list