Hi Russell,

Am Dienstag, den 17.07.2018, 17:02 +0100 schrieb Russell King:
> Try a bit harder to produce a devcoredump when things go wrong.  If we
> fail to allocate the memory for a dump including the actual bo contents,
> omit the bos and try again.  Capturing some information from the GPU is
> better than having no information.

Agreed. One nit below.

> Signed-off-by: Russell King <rmk+ker...@armlinux.org.uk>
> ---
>  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 48aef6cf6a42..c9987bc38acc 100644
> --- a/drivers/gpu/drm/etnaviv/etnaviv_dump.c
> +++ b/drivers/gpu/drm/etnaviv/etnaviv_dump.c
> @@ -129,6 +129,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)
> @@ -137,6 +138,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;
> @@ -159,9 +161,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 */
> @@ -177,6 +182,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;
> >     }
> @@ -234,14 +244,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);

Did you mean to include this output in the patch? I guess it makes the
etnaviv coredump much more noisy in the system logs and doesn't carry
much useful info for the regular user.

Regards,
Lucas

> +                     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);
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to