From: Andrzej Turko <andrzej.turko@xxxxxxxxxxxxxxx> Converted the test gem_exec_basic to use the memory region uapi. Signed-off-by: Andrzej Turko <andrzej.turko@xxxxxxxxxxxxxxx> Cc: Zbigniew Kempczynski <zbigniew.kempczynski@xxxxxxxxx> Cc: Dominik Grzegorzek <dominik.grzegorzek@xxxxxxxxx> Cc: Petri Latvala <petri.latvala@xxxxxxxxx> --- tests/i915/gem_exec_basic.c | 50 +++++++++++++++++++++++++------------ 1 file changed, 34 insertions(+), 16 deletions(-) diff --git a/tests/i915/gem_exec_basic.c b/tests/i915/gem_exec_basic.c index 5021852f..d1569781 100644 --- a/tests/i915/gem_exec_basic.c +++ b/tests/i915/gem_exec_basic.c @@ -22,17 +22,18 @@ */ #include "igt.h" +#include "igt_collection.h" #include "i915/gem_create.h" IGT_TEST_DESCRIPTION("Basic sanity check of execbuf-ioctl rings."); -static uint32_t batch_create(int fd) +static uint32_t batch_create(int fd, uint32_t batch_size, uint32_t region) { const uint32_t bbe = MI_BATCH_BUFFER_END; uint32_t handle; - handle = gem_create(fd, 4096); + handle = gem_create_in_memory_regions(fd, batch_size, region); gem_write(fd, handle, 0, &bbe, sizeof(bbe)); return handle; @@ -41,36 +42,53 @@ static uint32_t batch_create(int fd) igt_main { const struct intel_execution_engine2 *e; + struct local_drm_i915_query_memory_regions *query_info; + struct igt_collection *regions, *set; + uint32_t batch_size; int fd = -1; igt_fixture { fd = drm_open_driver(DRIVER_INTEL); /* igt_require_gem(fd); // test is mandatory */ igt_fork_hang_detector(fd); + + query_info = gem_get_query_memory_regions(fd); + igt_assert(query_info); + + set = get_memory_region_set(query_info, + I915_SYSTEM_MEMORY); } igt_subtest_with_dynamic("basic") { - struct drm_i915_gem_exec_object2 exec = { - .handle = batch_create(fd), - }; + for_each_combination(regions, 1, set) { + char *sub_name = memregion_dynamic_subtest_name(regions); + struct drm_i915_gem_exec_object2 exec; + uint32_t region = igt_collection_get_value(regions, 0); - __for_each_physical_engine(fd, e) { - igt_dynamic_f("%s", e->name) { - struct drm_i915_gem_execbuffer2 execbuf = { - .buffers_ptr = to_user_pointer(&exec), - .buffer_count = 1, - .flags = e->flags, - }; + batch_size = gem_get_batch_size(fd, MEMORY_TYPE_FROM_REGION(region)); + memset(&exec, 0, sizeof(exec)); + exec.handle = batch_create(fd, batch_size, region); - gem_execbuf(fd, &execbuf); + __for_each_physical_engine(fd, e) { + igt_dynamic_f("%s-%s", e->name, sub_name) { + struct drm_i915_gem_execbuffer2 execbuf = { + .buffers_ptr = to_user_pointer(&exec), + .buffer_count = 1, + .flags = e->flags, + }; + + gem_execbuf(fd, &execbuf); + } } + gem_sync(fd, exec.handle); /* catch any GPU hang */ + gem_close(fd, exec.handle); + free(sub_name); } - - gem_sync(fd, exec.handle); /* catch any GPU hang */ - gem_close(fd, exec.handle); } igt_fixture { + free(query_info); + igt_collection_destroy(set); igt_stop_hang_detector(); close(fd); } -- 2.26.3 _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx