nvk: Track and dump device-generated commands if possible
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/31394>
This commit is contained in:
committed by
Marge Bot
parent
7b6b2f9501
commit
e1404ffd11
@@ -236,8 +236,14 @@ nvk_bind_buffer_memory(struct nvk_device *dev,
|
||||
{
|
||||
VK_FROM_HANDLE(nvk_device_memory, mem, info->memory);
|
||||
VK_FROM_HANDLE(nvk_buffer, buffer, info->buffer);
|
||||
struct nvk_physical_device *pdev = nvk_device_physical(dev);
|
||||
VkResult result = VK_SUCCESS;
|
||||
|
||||
if ((pdev->debug_flags & NVK_DEBUG_PUSH_DUMP) &&
|
||||
(buffer->vk.usage & (VK_BUFFER_USAGE_2_INDIRECT_BUFFER_BIT_KHR |
|
||||
VK_BUFFER_USAGE_2_PREPROCESS_BUFFER_BIT_EXT)))
|
||||
nvkmd_dev_track_mem(dev->nvkmd, mem->mem);
|
||||
|
||||
if (buffer->va != NULL) {
|
||||
result = nvkmd_va_bind_mem(buffer->va, &buffer->vk.base,
|
||||
0 /* va_offset */,
|
||||
|
||||
@@ -1095,6 +1095,26 @@ nvk_cmd_buffer_dump(struct nvk_cmd_buffer *cmd, FILE *fp)
|
||||
const uint64_t addr = p->addr;
|
||||
fprintf(fp, "<%u B of INDIRECT DATA at 0x%" PRIx64 ">\n",
|
||||
p->range, addr);
|
||||
|
||||
uint64_t mem_offset = 0;
|
||||
struct nvkmd_mem *mem =
|
||||
nvkmd_dev_lookup_mem_by_va(dev->nvkmd, addr, &mem_offset);
|
||||
if (mem != NULL) {
|
||||
void *map;
|
||||
VkResult map_result = nvkmd_mem_map(mem, &dev->vk.base,
|
||||
NVKMD_MEM_MAP_RD, NULL,
|
||||
&map);
|
||||
if (map_result == VK_SUCCESS) {
|
||||
struct nv_push push = {
|
||||
.start = mem->map + mem_offset,
|
||||
.end = mem->map + mem_offset + p->range,
|
||||
};
|
||||
vk_push_print(fp, &push, &pdev->info);
|
||||
nvkmd_mem_unmap(mem, 0);
|
||||
}
|
||||
|
||||
nvkmd_mem_unref(mem);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user