diff options
| author | Jiri Slaby <jslaby@suse.cz> | 2010-01-06 11:39:31 -0500 |
|---|---|---|
| committer | Dave Airlie <airlied@redhat.com> | 2010-01-06 22:38:59 -0500 |
| commit | 5eb226132f53d5ec36ce4e7ff9d6b49cceb50f3d (patch) | |
| tree | 585e5208417c896a87c8ad8febb51b45acfe4c11 | |
| parent | 1d3d51b6d2d6fb51c6c30a8c7ed0fd939f6100bf (diff) | |
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>
| -rw-r--r-- | drivers/gpu/drm/radeon/radeon_cp.c | 1 |
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) | |||
| 2145 | &master_priv->sarea); | 2145 | &master_priv->sarea); |
| 2146 | if (ret) { | 2146 | if (ret) { |
| 2147 | DRM_ERROR("SAREA setup failed\n"); | 2147 | DRM_ERROR("SAREA setup failed\n"); |
| 2148 | kfree(master_priv); | ||
| 2148 | return ret; | 2149 | return ret; |
| 2149 | } | 2150 | } |
| 2150 | master_priv->sarea_priv = master_priv->sarea->handle + sizeof(struct drm_sarea); | 2151 | master_priv->sarea_priv = master_priv->sarea->handle + sizeof(struct drm_sarea); |
