aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon/radeon_cp.c
diff options
context:
space:
mode:
authorJiri Slaby <jslaby@suse.cz>2010-01-06 17:39:31 +0100
committerDave Airlie <airlied@redhat.com>2010-01-07 13:38:59 +1000
commit5eb226132f53d5ec36ce4e7ff9d6b49cceb50f3d (patch)
tree585e5208417c896a87c8ad8febb51b45acfe4c11 /drivers/gpu/drm/radeon/radeon_cp.c
parentdrm/radeon/kms: add missing breaks in i2c and ss lookups (diff)
downloadlinux-dev-5eb226132f53d5ec36ce4e7ff9d6b49cceb50f3d.tar.xz
linux-dev-5eb226132f53d5ec36ce4e7ff9d6b49cceb50f3d.zip
drm/radeon/kms: fix memory leak
Stanse found a memory leak in radeon_master_create. master_priv is not freed/assigned on all paths. Fix that. Signed-off-by: Jiri Slaby <jslaby@suse.cz> Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/radeon_cp.c')
-rw-r--r--drivers/gpu/drm/radeon/radeon_cp.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_cp.c b/drivers/gpu/drm/radeon/radeon_cp.c
index 0b2f9c2ad2c1..06123ba31d31 100644
--- a/drivers/gpu/drm/radeon/radeon_cp.c
+++ b/drivers/gpu/drm/radeon/radeon_cp.c
@@ -2145,6 +2145,7 @@ int radeon_master_create(struct drm_device *dev, struct drm_master *master)
&master_priv->sarea);
if (ret) {
DRM_ERROR("SAREA setup failed\n");
+ kfree(master_priv);
return ret;
}
master_priv->sarea_priv = master_priv->sarea->handle + sizeof(struct drm_sarea);