It is possible that the size of the BOs currently queued for the GPU exceed our available memory for dumping a device core dump. If this occures, try generating a core dump without containing the contents of the BOs. Signed-off-by: Russell King <rmk+kernel@xxxxxxxxxxxxxxx> --- drivers/gpu/drm/etnaviv/etnaviv_dump.c | 30 ++++++++++++++++++++++-------- 1 file changed, 22 insertions(+), 8 deletions(-) diff --git a/drivers/gpu/drm/etnaviv/etnaviv_dump.c b/drivers/gpu/drm/etnaviv/etnaviv_dump.c index 9146e30e24a6..ed53a88eaea4 100644 --- a/drivers/gpu/drm/etnaviv/etnaviv_dump.c +++ b/drivers/gpu/drm/etnaviv/etnaviv_dump.c @@ -118,6 +118,7 @@ void etnaviv_core_dump(struct etnaviv_gpu *gpu) unsigned int n_obj, n_bomap_pages; size_t file_size, mmu_size; __le64 *bomap, *bomap_start; + bool bos = true; /* Only catch the first event, or when manually re-armed */ if (!etnaviv_dump_core) @@ -126,6 +127,7 @@ void etnaviv_core_dump(struct etnaviv_gpu *gpu) mmu_size = etnaviv_iommu_dump_size(gpu->mmu); +again: /* We always dump registers, mmu, ring and end marker */ n_obj = 4; n_bomap_pages = 0; @@ -148,9 +150,12 @@ void etnaviv_core_dump(struct etnaviv_gpu *gpu) continue; obj = vram->object; - file_size += obj->base.size; n_bomap_pages += obj->base.size >> PAGE_SHIFT; - n_obj++; + + if (bos) { + file_size += obj->base.size; + n_obj++; + } } /* If we have any buffer objects, add a bomap object */ @@ -166,6 +171,11 @@ void etnaviv_core_dump(struct etnaviv_gpu *gpu) iter.start = __vmalloc(file_size, GFP_KERNEL | __GFP_NOWARN | __GFP_NORETRY, PAGE_KERNEL); if (!iter.start) { + if (bos) { + dev_warn(gpu->dev, "devcoredump too big, trying without bos\n"); + bos = false; + goto again; + } dev_warn(gpu->dev, "failed to allocate devcoredump file\n"); return; } @@ -223,14 +233,18 @@ void etnaviv_core_dump(struct etnaviv_gpu *gpu) *bomap++ = cpu_to_le64(page_to_phys(*pages++)); } - iter.hdr->iova = cpu_to_le64(vram->iova); + if (bos) { + iter.hdr->iova = cpu_to_le64(vram->iova); - vaddr = etnaviv_gem_vmap(&obj->base); - if (vaddr) - memcpy(iter.data, vaddr, obj->base.size); + vaddr = etnaviv_gem_vmap(&obj->base); + dev_crit(gpu->dev, "Copying object %p ops %pS vaddr %p to %p size %zu\n", + obj, obj->ops, vaddr, iter.data, obj->base.size); + if (vaddr) + memcpy(iter.data, vaddr, obj->base.size); - etnaviv_core_dump_header(&iter, ETDUMP_BUF_BO, iter.data + - obj->base.size); + etnaviv_core_dump_header(&iter, ETDUMP_BUF_BO, iter.data + + obj->base.size); + } } etnaviv_core_dump_header(&iter, ETDUMP_BUF_END, iter.data); -- 2.7.4 _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel