gallium/ddebug: new pipe for hang detection and driver state dumping (v2)
authorMarek Olšák <marek.olsak@amd.com>
Sat, 4 Jul 2015 12:10:21 +0000 (14:10 +0200)
committerMarek Olšák <marek.olsak@amd.com>
Wed, 26 Aug 2015 17:25:18 +0000 (19:25 +0200)
commit525921ed51176255474c73adacfc6801a7bf2783
tree2695524d4f9d915a8c5bce90590a2086aebc3d74
parent0fc21ecfc0891d239f20bf7724e51bc75503570c
gallium/ddebug: new pipe for hang detection and driver state dumping (v2)

v2: lots of improvements

This is like identity or trace, but simpler. It doesn't wrap most states.

Run with:
  GALLIUM_DDEBUG=1000 [executable]
where "executable" is the app and "1000" is in miliseconds, meaning that
the context will be considered hung if a fence fails to signal in 1000 ms.

If that happens, all shaders, context states, bound resources, draw
parameters, and driver debug information (if any) will be dumped into:
  /home/$username/dd_dumps/$processname_$pid_$index.

Note that the context is flushed after every draw/clear/copy/blit operation
and then waited for to find the exact call that hangs.

You can also do:
  GALLIUM_DDEBUG=always
to do the dumping after every draw/clear/copy/blit operation without
flushing and waiting.

Examples of driver states that can be dumped are:
- Hardware status registers saying which hw block is busy (hung).
- Disassembled shaders in a human-readable form.
- The last submitted command buffer in a human-readable form.

v2: drop pipe-loader changes, drop SConscript
    rename dd.h -> dd_pipe.h

Acked-by: Christian König <christian.koenig@amd.com>
Acked-by: Alex Deucher <alexander.deucher@amd.com>
configure.ac
src/gallium/Makefile.am
src/gallium/auxiliary/target-helpers/inline_debug_helper.h
src/gallium/drivers/ddebug/Makefile.am [new file with mode: 0644]
src/gallium/drivers/ddebug/Makefile.sources [new file with mode: 0644]
src/gallium/drivers/ddebug/dd_context.c [new file with mode: 0644]
src/gallium/drivers/ddebug/dd_draw.c [new file with mode: 0644]
src/gallium/drivers/ddebug/dd_pipe.h [new file with mode: 0644]
src/gallium/drivers/ddebug/dd_public.h [new file with mode: 0644]
src/gallium/drivers/ddebug/dd_screen.c [new file with mode: 0644]
src/gallium/targets/dri/Makefile.am