[Nouveau] [PATCH] drm/nouveau: unpin pushbuffer bo before destroying it
Marcin Slusarz
marcin.slusarz at gmail.com
Sun Dec 2 03:30:06 PST 2012
On Sun, Nov 25, 2012 at 11:02:28PM +0100, Marcin Slusarz wrote:
> Fixes GART leak (as accounted by nouveau_drm.gem.gart_available).
>
> Signed-off-by: Marcin Slusarz <marcin.slusarz at gmail.com>
> ---
>
> Running glxinfo in a loop is enough to trigger it - after several thousand
> runs (depending on GART size), X server crashes and does not come back in
> a correct state (corruptions and crashes).
>
> With this patch applied, it's possible again to do full piglit run (with
> concurrency disabled) without crashes or lockups.
>
> ---
Please consider applying this patch for 3.7/3.7.x. This bug is easily
reproducible and has fatal consequences (gpu is unusuable after 1st crash).
> drivers/gpu/drm/nouveau/nouveau_chan.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/drivers/gpu/drm/nouveau/nouveau_chan.c b/drivers/gpu/drm/nouveau/nouveau_chan.c
> index 1363578..174300b 100644
> --- a/drivers/gpu/drm/nouveau/nouveau_chan.c
> +++ b/drivers/gpu/drm/nouveau/nouveau_chan.c
> @@ -76,6 +76,8 @@ nouveau_channel_del(struct nouveau_channel **pchan)
> nouveau_object_del(client, NVDRM_DEVICE, chan->push.handle);
> nouveau_bo_vma_del(chan->push.buffer, &chan->push.vma);
> nouveau_bo_unmap(chan->push.buffer);
> + if (chan->push.buffer && chan->push.buffer->pin_refcnt)
> + nouveau_bo_unpin(chan->push.buffer);
> nouveau_bo_ref(NULL, &chan->push.buffer);
> kfree(chan);
> }
> --
> 1.7.12
>
More information about the Nouveau
mailing list