[Nouveau] [PATCH] drm/nouveau: fix nouveau_mm/nouveau_mm_node leak
Marcin Slusarz
marcin.slusarz at gmail.com
Sun Oct 21 15:19:35 PDT 2012
On Fri, Oct 19, 2012 at 04:05:14PM +1000, Ben Skeggs wrote:
> On Thu, Oct 11, 2012 at 11:53:09PM +0200, Marcin Slusarz wrote:
> > Signed-off-by: Marcin Slusarz <marcin.slusarz at gmail.com>
> > ---
> > drivers/gpu/drm/nouveau/core/core/gpuobj.c | 6 +++++-
> > drivers/gpu/drm/nouveau/core/include/core/gpuobj.h | 3 +++
> > 2 files changed, 8 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/gpu/drm/nouveau/core/core/gpuobj.c b/drivers/gpu/drm/nouveau/core/core/gpuobj.c
> > index c2a7608..48121d2 100644
> > --- a/drivers/gpu/drm/nouveau/core/core/gpuobj.c
> > +++ b/drivers/gpu/drm/nouveau/core/core/gpuobj.c
> > @@ -39,8 +39,11 @@ nouveau_gpuobj_destroy(struct nouveau_gpuobj *gpuobj)
> > nv_wo32(gpuobj, i, 0x00000000);
> > }
> >
> > + if (gpuobj->node)
> > + nouveau_mm_free(gpuobj->node_heap, &gpuobj->node);
> > +
> if (gpuobj->node) {
> nouveau_mm_free(&nv_gpuobj(gpuobj->parent)->heap,
> &gpuobj->node);
> }
>
> Or something to that effect, instead of having to store the heap
> pointer again.
Oh, right.
(Somehow I assumed pargpu to be different object than parent when
I first read it.)
> > if (gpuobj->heap.block_size)
> > - nouveau_mm_fini(&gpuobj->heap);
> > + WARN_ON(nouveau_mm_fini(&gpuobj->heap));
> Alright, I get this. However, perhaps we should go the full hog here
> and make nouveau_mm_fini() directly do the WARN_ON() in this situation?
>
> There was, once upon a time, reasons for it not doing this, I don't
> believe they're valid anymore though.
OK.
Marcin
More information about the Nouveau
mailing list