[Intel-gfx] [PATCH igt 3/9] igt/drv_hangman: Inject a true hang
Daniel Vetter
daniel at ffwll.ch
Wed Dec 16 01:02:27 PST 2015
On Sat, Dec 12, 2015 at 08:02:49PM +0000, Chris Wilson wrote:
> Wean drv_hangman off the atrocious stop_rings and use a real GPU hang
> instead.
>
> Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk>
Doesn't this kill pre-gen6? Or at least anything where we don't have
proper hang recovery ... Lack of that is why I've done the original
stop_rings fun.
-Daniel
> ---
> tests/drv_hangman.c | 66 ++++++++++++-----------------------------------------
> 1 file changed, 14 insertions(+), 52 deletions(-)
>
> diff --git a/tests/drv_hangman.c b/tests/drv_hangman.c
> index cd63b97..866d9dc 100644
> --- a/tests/drv_hangman.c
> +++ b/tests/drv_hangman.c
> @@ -147,59 +147,21 @@ static void assert_error_state_collected(void)
> assert_dfs_entry_not("i915_error_state", "no error state collected");
> }
>
> -#define MAGIC_NUMBER 0x10001
> -const uint32_t batch[] = { MI_NOOP,
> - MI_BATCH_BUFFER_END,
> - MAGIC_NUMBER,
> - MAGIC_NUMBER };
> +const uint32_t *batch;
>
> -static uint64_t submit_batch(int fd, unsigned ring_id, bool stop_ring)
> +static uint64_t submit_hang(int fd, unsigned ring_id)
> {
> - struct drm_i915_gem_execbuffer2 execbuf;
> - struct drm_i915_gem_exec_object2 exec;
> - uint64_t presumed_offset;
> -
> - gem_require_ring(fd, ring_id);
> -
> - exec.handle = gem_create(fd, 4096);
> - gem_write(fd, exec.handle, 0, batch, sizeof(batch));
> - exec.relocation_count = 0;
> - exec.relocs_ptr = 0;
> - exec.alignment = 0;
> - exec.offset = 0;
> - exec.flags = 0;
> - exec.rsvd1 = 0;
> - exec.rsvd2 = 0;
> -
> - execbuf.buffers_ptr = (uintptr_t)&exec;
> - execbuf.buffer_count = 1;
> - execbuf.batch_start_offset = 0;
> - execbuf.batch_len = sizeof(batch);
> - execbuf.cliprects_ptr = 0;
> - execbuf.num_cliprects = 0;
> - execbuf.DR1 = 0;
> - execbuf.DR4 = 0;
> - execbuf.flags = ring_id;
> - i915_execbuffer2_set_context_id(execbuf, 0);
> - execbuf.rsvd2 = 0;
> -
> - gem_execbuf(fd, &execbuf);
> - gem_sync(fd, exec.handle);
> - presumed_offset = exec.offset;
> -
> - if (stop_ring) {
> - igt_set_stop_rings(igt_to_stop_ring_flag(ring_id));
> -
> - gem_execbuf(fd, &execbuf);
> - gem_sync(fd, exec.handle);
> -
> - igt_assert(igt_get_stop_rings() == STOP_RING_NONE);
> - igt_assert(presumed_offset == exec.offset);
> - }
> + uint64_t offset;
> + igt_hang_ring_t hang;
> +
> + hang = igt_hang_ctx(fd, 0, ring_id, HANG_ALLOW_CAPTURE, &offset);
> +
> + batch = gem_mmap__cpu(fd, hang.handle, 0, 4096, PROT_READ);
> + gem_set_domain(fd, hang.handle, I915_GEM_DOMAIN_CPU, 0);
>
> - gem_close(fd, exec.handle);
> + igt_post_hang_ring(fd, hang);
>
> - return exec.offset;
> + return offset;
> }
>
> static void clear_error_state(void)
> @@ -222,7 +184,7 @@ static void test_error_state_basic(void)
> clear_error_state();
> assert_error_state_clear();
>
> - submit_batch(fd, I915_EXEC_RENDER, true);
> + submit_hang(fd, I915_EXEC_RENDER);
> close(fd);
>
> assert_error_state_collected();
> @@ -276,7 +238,7 @@ static void check_error_state(const int gen,
> if (!uses_cmd_parser)
> igt_assert(gtt_offset == expected_offset);
>
> - for (i = 0; i < sizeof(batch) / 4; i++) {
> + for (i = 0; i < 1024; i++) {
> igt_assert(getline(&line, &line_size, file) > 0);
> snprintf(expected_line, sizeof(expected_line), "%08x : %08x",
> 4*i, batch[i]);
> @@ -381,7 +343,7 @@ static void test_error_state_capture(unsigned ring_id,
> gen = intel_gen(intel_get_drm_devid(fd));
> cmd_parser = uses_cmd_parser(fd, gen);
>
> - offset = submit_batch(fd, ring_id, true);
> + offset = submit_hang(fd, ring_id);
> close(fd);
>
> check_error_state(gen, cmd_parser, ring_name, offset);
> --
> 2.6.3
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
--
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
More information about the Intel-gfx
mailing list