diff options
| author | Chris Wilson <chris@chris-wilson.co.uk> | 2020-04-30 22:14:35 +0100 | 
|---|---|---|
| committer | Chris Wilson <chris@chris-wilson.co.uk> | 2020-05-01 00:15:25 +0100 | 
| commit | 87890a8dbf7e1c5230557a0249175a7543f32d00 (patch) | |
| tree | 8da68c5f669472da4d996d6f1d576ebb3b009402 /tests/i915 | |
| parent | 57ee41f12b7a53283fd812c5f72fcb39e6ad2197 (diff) | |
i915/gem_exec_reloc: Flood the ring with GPU relocs
Try to fill the ring with GPU relocations and cause the execution to
block; only to be resolved by a GPU hang. Whereas in the previous test,
we went deep with many relocations inside the same object, here we go
wide with one relocation inside each of many objects.
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Acked-by: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Diffstat (limited to 'tests/i915')
| -rw-r--r-- | tests/i915/gem_exec_reloc.c | 91 | 
1 files changed, 87 insertions, 4 deletions
| diff --git a/tests/i915/gem_exec_reloc.c b/tests/i915/gem_exec_reloc.c index 5f2f029d..bdb818f4 100644 --- a/tests/i915/gem_exec_reloc.c +++ b/tests/i915/gem_exec_reloc.c @@ -359,8 +359,8 @@ static void __many_active(int i915, unsigned engine, unsigned long count)  	unsigned long reloc_sz;  	struct drm_i915_gem_exec_object2 obj[2] = {{  		.handle = gem_create(i915, count * sizeof(uint64_t)), -			.relocs_ptr = many_relocs(count, &reloc_sz), -			.relocation_count = count, +		.relocs_ptr = many_relocs(count, &reloc_sz), +		.relocation_count = count,  	}};  	struct drm_i915_gem_execbuffer2 execbuf = {  		.buffers_ptr = to_user_pointer(obj), @@ -379,7 +379,7 @@ static void __many_active(int i915, unsigned engine, unsigned long count)  	igt_assert_eq(sync_fence_status(spin->out_fence), 0);  	igt_spin_free(i915, spin); -	for (unsigned long i = 0; i < obj[0].relocation_count; i++) { +	for (unsigned long i = 0; i < count; i++) {  		uint64_t addr;  		gem_read(i915, obj[0].handle, i * sizeof(addr), @@ -394,14 +394,90 @@ static void __many_active(int i915, unsigned engine, unsigned long count)  static void many_active(int i915, unsigned engine)  { +	const uint64_t max = gem_aperture_size(i915) / 2;  	unsigned long count = 256;  	igt_until_timeout(5) { +		uint64_t required, total; + +		if (!__intel_check_memory(1, 8 * count, CHECK_RAM, +					  &required, &total)) +			break; +  		igt_debug("Testing count:%lu\n", count);  		__many_active(i915, engine, count);  		count <<= 2; -		if (!count) +		if (count * 8 >= max) +			break; +	} +} + +static void __wide_active(int i915, unsigned engine, unsigned long count) +{ +	struct drm_i915_gem_relocation_entry *reloc = +		calloc(count, sizeof(*reloc)); +	struct drm_i915_gem_exec_object2 *obj = +		calloc(count + 1, sizeof(*obj)); +	struct drm_i915_gem_execbuffer2 execbuf = { +		.buffers_ptr = to_user_pointer(obj), +		.buffer_count = count + 1, +		.flags = engine | I915_EXEC_HANDLE_LUT, +	}; +	igt_spin_t *spin; + +	for (unsigned long i = 0; i < count; i++) { +		obj[i].handle = gem_create(i915, 4096); +		obj[i].flags = EXEC_OBJECT_WRITE; +	} + +	spin = __igt_spin_new(i915, +			      .engine = engine, +			      .flags = (IGT_SPIN_FENCE_OUT | +					IGT_SPIN_NO_PREEMPTION)); +	obj[count] = spin->obj[1]; +	gem_execbuf(i915, &execbuf); /* mark all the objects as active */ + +	for (unsigned long i = 0; i < count; i++) { +		reloc[i].target_handle = i; +		reloc[i].presumed_offset = ~0ull; +		obj[i].relocs_ptr = to_user_pointer(&reloc[i]); +		obj[i].relocation_count = 1; +	} +	gem_execbuf(i915, &execbuf); /* relocation onto active objects */ + +	igt_assert_eq(sync_fence_status(spin->out_fence), 0); +	igt_spin_free(i915, spin); + +	for (unsigned long i = 0; i < count; i++) { +		uint64_t addr; + +		gem_read(i915, obj[i].handle, 0, &addr, sizeof(addr)); +		igt_assert_eq_u64(addr, obj[i].offset); + +		gem_close(i915, obj[i].handle); +	} +	free(obj); +	free(reloc); +} + +static void wide_active(int i915, unsigned engine) +{ +	const uint64_t max = gem_aperture_size(i915) / 4096 / 2; +	unsigned long count = 256; + +	igt_until_timeout(5) { +		uint64_t required, total; + +		if (!__intel_check_memory(count, 4096, CHECK_RAM, +					  &required, &total)) +			break; + +		igt_debug("Testing count:%lu\n", count); +		__wide_active(i915, engine, count); + +		count <<= 2; +		if (count >= max)  			break;  	}  } @@ -1064,6 +1140,13 @@ igt_main  		}  	} +	igt_subtest_with_dynamic("basic-wide-active") { +		__for_each_physical_engine(fd, e) { +			igt_dynamic_f("%s", e->name) +				wide_active(fd, e->flags); +		} +	} +  	igt_subtest("basic-parallel")  		parallel(fd); | 
