summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSamuel Pitoiset <samuel.pitoiset@gmail.com>2018-03-14 12:02:13 +0100
committerSamuel Pitoiset <samuel.pitoiset@gmail.com>2018-03-15 17:19:54 +0100
commit14c27c251127628b7264ee630f9854762962279b (patch)
tree9ef1ae3bed62d39a19c282ca67a969caa2a5f470
parent5be2757c3506004d9913ad2ea3ad4fbe6af70dce (diff)
radv: print some information when RADV_TRACE_FILE is set
Just to be sure all options are enabled when trying to generate a hang report. Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
-rw-r--r--src/amd/vulkan/radv_debug.c2
-rw-r--r--src/amd/vulkan/radv_debug.h3
-rw-r--r--src/amd/vulkan/radv_device.c5
3 files changed, 9 insertions, 1 deletions
diff --git a/src/amd/vulkan/radv_debug.c b/src/amd/vulkan/radv_debug.c
index f3b79004f6..ce582312c5 100644
--- a/src/amd/vulkan/radv_debug.c
+++ b/src/amd/vulkan/radv_debug.c
@@ -593,7 +593,7 @@ radv_dump_dmesg(FILE *f)
pclose(p);
}
-static void
+void
radv_dump_enabled_options(struct radv_device *device, FILE *f)
{
uint64_t mask;
diff --git a/src/amd/vulkan/radv_debug.h b/src/amd/vulkan/radv_debug.h
index 804f620690..08877676b5 100644
--- a/src/amd/vulkan/radv_debug.h
+++ b/src/amd/vulkan/radv_debug.h
@@ -61,4 +61,7 @@ radv_check_gpu_hangs(struct radv_queue *queue, struct radeon_winsys_cs *cs);
void
radv_print_spirv(uint32_t *data, uint32_t size, FILE *fp);
+void
+radv_dump_enabled_options(struct radv_device *device, FILE *f);
+
#endif
diff --git a/src/amd/vulkan/radv_device.c b/src/amd/vulkan/radv_device.c
index 13b2da584e..36ba0c3833 100644
--- a/src/amd/vulkan/radv_device.c
+++ b/src/amd/vulkan/radv_device.c
@@ -1322,10 +1322,15 @@ VkResult radv_CreateDevice(
device->physical_device->rad_info.max_se >= 2;
if (getenv("RADV_TRACE_FILE")) {
+ const char *filename = getenv("RADV_TRACE_FILE");
+
keep_shader_info = true;
if (!radv_init_trace(device))
goto fail;
+
+ fprintf(stderr, "Trace file will be dumped to %s\n", filename);
+ radv_dump_enabled_options(device, stderr);
}
device->keep_shader_info = keep_shader_info;