summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSudip Mukherjee <sudipm.mukherjee@gmail.com>2015-09-11 15:00:56 +0530
committerBen Skeggs <bskeggs@redhat.com>2015-10-12 13:08:20 +1000
commitfdc5d93347be4b2dd4c9b62668cea4cfa7aa72ef (patch)
tree7d568ec3a007199cf64b989d5682f2d0d28639a2
parentc60cd4ec9e07e5da5e914a465b6bc3d660beb614 (diff)
downloadnouveau-fdc5d93347be4b2dd4c9b62668cea4cfa7aa72ef.tar.gz
drm: fix memory leak
If pm_runtime_get_sync() we were going to "out" but we missed freeing vma. Signed-off-by: Sudip Mukherjee <sudip@vectorindia.org> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
-rw-r--r--drm/nouveau/nouveau_gem.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drm/nouveau/nouveau_gem.c b/drm/nouveau/nouveau_gem.c
index 1497a1462..ce74ab12e 100644
--- a/drm/nouveau/nouveau_gem.c
+++ b/drm/nouveau/nouveau_gem.c
@@ -84,8 +84,10 @@ nouveau_gem_object_open(struct drm_gem_object *gem, struct drm_file *file_priv)
}
ret = pm_runtime_get_sync(dev);
- if (ret < 0 && ret != -EACCES)
+ if (ret < 0 && ret != -EACCES) {
+ kfree(vma);
goto out;
+ }
ret = nouveau_bo_vma_add(nvbo, cli->vm, vma);
if (ret)