diff options
author | Jesper Juhl <jj@chaosbits.net> | 2012-03-08 11:00:58 -0500 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2012-03-10 08:05:37 -0500 |
commit | aa7c62af10b6ba7f0496ee3a1a760ad216426720 (patch) | |
tree | 25f67514f2fcfb7ed7f1859053d83b2f09f469b9 /drivers/gpu/drm/gma500/psb_intel_lvds.c | |
parent | 05442e5e1ff1e75868e4f83822775f41e18c63b4 (diff) |
intel, gma500, lvds: Fix use after free and mem leak in psb_intel_lvds_init()
In psb_intel_lvds_init(), if we fail to allocate memory for
'psb_intel_connector' we free the memory we previously allocated for
'psb_intel_encoder', but we then proceed to use that free'd pointer
when we do 'psb_intel_encoder->dev_priv = lvds_priv;'.
We may also leak the memory we allocated for 'psb_intel_encoder' if we
'goto failed_connector;' and the variable goes out of scope.
While I was there anyway, I also removed the pointless 'if
(psb_intel_connector)' before freeing it at the 'failed_connector:'
label - kfree() deals gracefully with NULL pointers, so it is not
needed.
Signed-off-by: Jesper Juhl <jj@chaosbits.net>
Signed-off-by: Alan Cox <alan@linux.intel.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/gma500/psb_intel_lvds.c')
-rw-r--r-- | drivers/gpu/drm/gma500/psb_intel_lvds.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/drivers/gpu/drm/gma500/psb_intel_lvds.c b/drivers/gpu/drm/gma500/psb_intel_lvds.c index 69a96513752f..c83f5b5d1057 100644 --- a/drivers/gpu/drm/gma500/psb_intel_lvds.c +++ b/drivers/gpu/drm/gma500/psb_intel_lvds.c | |||
@@ -713,7 +713,6 @@ void psb_intel_lvds_init(struct drm_device *dev, | |||
713 | 713 | ||
714 | psb_intel_encoder = | 714 | psb_intel_encoder = |
715 | kzalloc(sizeof(struct psb_intel_encoder), GFP_KERNEL); | 715 | kzalloc(sizeof(struct psb_intel_encoder), GFP_KERNEL); |
716 | |||
717 | if (!psb_intel_encoder) { | 716 | if (!psb_intel_encoder) { |
718 | dev_err(dev->dev, "psb_intel_encoder allocation error\n"); | 717 | dev_err(dev->dev, "psb_intel_encoder allocation error\n"); |
719 | return; | 718 | return; |
@@ -721,10 +720,9 @@ void psb_intel_lvds_init(struct drm_device *dev, | |||
721 | 720 | ||
722 | psb_intel_connector = | 721 | psb_intel_connector = |
723 | kzalloc(sizeof(struct psb_intel_connector), GFP_KERNEL); | 722 | kzalloc(sizeof(struct psb_intel_connector), GFP_KERNEL); |
724 | |||
725 | if (!psb_intel_connector) { | 723 | if (!psb_intel_connector) { |
726 | kfree(psb_intel_encoder); | ||
727 | dev_err(dev->dev, "psb_intel_connector allocation error\n"); | 724 | dev_err(dev->dev, "psb_intel_connector allocation error\n"); |
725 | goto failed_encoder; | ||
728 | } | 726 | } |
729 | 727 | ||
730 | lvds_priv = kzalloc(sizeof(struct psb_intel_lvds_priv), GFP_KERNEL); | 728 | lvds_priv = kzalloc(sizeof(struct psb_intel_lvds_priv), GFP_KERNEL); |
@@ -862,7 +860,8 @@ failed_blc_i2c: | |||
862 | drm_encoder_cleanup(encoder); | 860 | drm_encoder_cleanup(encoder); |
863 | drm_connector_cleanup(connector); | 861 | drm_connector_cleanup(connector); |
864 | failed_connector: | 862 | failed_connector: |
865 | if (psb_intel_connector) | 863 | kfree(psb_intel_connector); |
866 | kfree(psb_intel_connector); | 864 | failed_encoder: |
865 | kfree(psb_intel_encoder); | ||
867 | } | 866 | } |
868 | 867 | ||