All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] ASoC: dapm: Fix kcontrol widget name memory management
@ 2015-07-08 19:59 Lars-Peter Clausen
  2015-07-08 21:17 ` Applied "ASoC: dapm: Fix kcontrol widget name memory management" to the asoc tree Mark Brown
  2015-07-09  8:06 ` [PATCH] ASoC: dapm: Fix kcontrol widget name memory management Charles Keepax
  0 siblings, 2 replies; 3+ messages in thread
From: Lars-Peter Clausen @ 2015-07-08 19:59 UTC (permalink / raw)
  To: Mark Brown, Liam Girdwood; +Cc: Charles Keepax, Lars-Peter Clausen, alsa-devel

The name field of the widget template is only used inside
snd_soc_dapm_new_control_unlocked() which allocates a copy for the actual
widget. This means we need to free the name allocated for the template in
dapm_kcontrol_data_alloc() and not the name of the actual widget in
dapm_kcontrol_free(). Otherwise we get a double free on the widget name and
a memory leak on the template name.

Fixes: 773da9b358bf ("ASoC: dapm: Append "Autodisable" to autodisable widget names")
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
---
 sound/soc/soc-dapm.c | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)

diff --git a/sound/soc/soc-dapm.c b/sound/soc/soc-dapm.c
index 6bac491..1628f0c 100644
--- a/sound/soc/soc-dapm.c
+++ b/sound/soc/soc-dapm.c
@@ -358,9 +358,10 @@ static int dapm_kcontrol_data_alloc(struct snd_soc_dapm_widget *widget,
 			data->widget =
 				snd_soc_dapm_new_control_unlocked(widget->dapm,
 				&template);
+			kfree(name);
 			if (!data->widget) {
 				ret = -ENOMEM;
-				goto err_name;
+				goto err_data;
 			}
 		}
 		break;
@@ -391,9 +392,10 @@ static int dapm_kcontrol_data_alloc(struct snd_soc_dapm_widget *widget,
 
 			data->widget = snd_soc_dapm_new_control_unlocked(
 						widget->dapm, &template);
+			kfree(name);
 			if (!data->widget) {
 				ret = -ENOMEM;
-				goto err_name;
+				goto err_data;
 			}
 
 			snd_soc_dapm_add_path(widget->dapm, data->widget,
@@ -408,8 +410,6 @@ static int dapm_kcontrol_data_alloc(struct snd_soc_dapm_widget *widget,
 
 	return 0;
 
-err_name:
-	kfree(name);
 err_data:
 	kfree(data);
 	return ret;
@@ -418,8 +418,6 @@ err_data:
 static void dapm_kcontrol_free(struct snd_kcontrol *kctl)
 {
 	struct dapm_kcontrol_data *data = snd_kcontrol_chip(kctl);
-	if (data->widget)
-		kfree(data->widget->name);
 	kfree(data->wlist);
 	kfree(data);
 }
-- 
2.1.4

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Applied "ASoC: dapm: Fix kcontrol widget name memory management" to the asoc tree
  2015-07-08 19:59 [PATCH] ASoC: dapm: Fix kcontrol widget name memory management Lars-Peter Clausen
@ 2015-07-08 21:17 ` Mark Brown
  2015-07-09  8:06 ` [PATCH] ASoC: dapm: Fix kcontrol widget name memory management Charles Keepax
  1 sibling, 0 replies; 3+ messages in thread
From: Mark Brown @ 2015-07-08 21:17 UTC (permalink / raw)
  To: Lars-Peter Clausen, Mark Brown; +Cc: alsa-devel

The patch

   ASoC: dapm: Fix kcontrol widget name memory management

has been applied to the asoc tree at

   git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git 

All being well this means that it will be integrated into the linux-next
tree (usually sometime in the next 24 hours) and sent to Linus during
the next merge window (or sooner if it is a bug fix), however if
problems are discovered then the patch may be dropped or reverted.  

You may get further e-mails resulting from automated or manual testing
and review of the tree, please engage with people reporting problems and
send followup patches addressing any issues that are reported if needed.

If any updates are required or you are submitting further changes they
should be sent as incremental updates against current git, existing
patches will not be replaced.

Please add any relevant lists and maintainers to the CCs when replying
to this mail.

Thanks,
Mark

>From e18077b6e5dfe26e9fbbdc1fd1085a1701c24bea Mon Sep 17 00:00:00 2001
From: Lars-Peter Clausen <lars@metafoo.de>
Date: Wed, 8 Jul 2015 21:59:59 +0200
Subject: [PATCH] ASoC: dapm: Fix kcontrol widget name memory management

The name field of the widget template is only used inside
snd_soc_dapm_new_control_unlocked() which allocates a copy for the actual
widget. This means we need to free the name allocated for the template in
dapm_kcontrol_data_alloc() and not the name of the actual widget in
dapm_kcontrol_free(). Otherwise we get a double free on the widget name and
a memory leak on the template name.

Fixes: 773da9b358bf ("ASoC: dapm: Append "Autodisable" to autodisable widget names")
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Mark Brown <broonie@kernel.org>
---
 sound/soc/soc-dapm.c | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)

diff --git a/sound/soc/soc-dapm.c b/sound/soc/soc-dapm.c
index 1779430013ea..9f270c0308b7 100644
--- a/sound/soc/soc-dapm.c
+++ b/sound/soc/soc-dapm.c
@@ -358,9 +358,10 @@ static int dapm_kcontrol_data_alloc(struct snd_soc_dapm_widget *widget,
 			data->widget =
 				snd_soc_dapm_new_control_unlocked(widget->dapm,
 				&template);
+			kfree(name);
 			if (!data->widget) {
 				ret = -ENOMEM;
-				goto err_name;
+				goto err_data;
 			}
 		}
 		break;
@@ -391,9 +392,10 @@ static int dapm_kcontrol_data_alloc(struct snd_soc_dapm_widget *widget,
 
 			data->widget = snd_soc_dapm_new_control_unlocked(
 						widget->dapm, &template);
+			kfree(name);
 			if (!data->widget) {
 				ret = -ENOMEM;
-				goto err_name;
+				goto err_data;
 			}
 
 			snd_soc_dapm_add_path(widget->dapm, data->widget,
@@ -408,8 +410,6 @@ static int dapm_kcontrol_data_alloc(struct snd_soc_dapm_widget *widget,
 
 	return 0;
 
-err_name:
-	kfree(name);
 err_data:
 	kfree(data);
 	return ret;
@@ -418,8 +418,6 @@ err_data:
 static void dapm_kcontrol_free(struct snd_kcontrol *kctl)
 {
 	struct dapm_kcontrol_data *data = snd_kcontrol_chip(kctl);
-	if (data->widget)
-		kfree(data->widget->name);
 	kfree(data->wlist);
 	kfree(data);
 }
-- 
2.1.4

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH] ASoC: dapm: Fix kcontrol widget name memory management
  2015-07-08 19:59 [PATCH] ASoC: dapm: Fix kcontrol widget name memory management Lars-Peter Clausen
  2015-07-08 21:17 ` Applied "ASoC: dapm: Fix kcontrol widget name memory management" to the asoc tree Mark Brown
@ 2015-07-09  8:06 ` Charles Keepax
  1 sibling, 0 replies; 3+ messages in thread
From: Charles Keepax @ 2015-07-09  8:06 UTC (permalink / raw)
  To: Lars-Peter Clausen; +Cc: alsa-devel, Mark Brown, Liam Girdwood

On Wed, Jul 08, 2015 at 09:59:59PM +0200, Lars-Peter Clausen wrote:
> The name field of the widget template is only used inside
> snd_soc_dapm_new_control_unlocked() which allocates a copy for the actual
> widget. This means we need to free the name allocated for the template in
> dapm_kcontrol_data_alloc() and not the name of the actual widget in
> dapm_kcontrol_free(). Otherwise we get a double free on the widget name and
> a memory leak on the template name.
> 
> Fixes: 773da9b358bf ("ASoC: dapm: Append "Autodisable" to autodisable widget names")
> Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
> ---

Oops, thanks for fixing that up.

Acked-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com>

Thanks,
Charles

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2015-07-09  8:11 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-07-08 19:59 [PATCH] ASoC: dapm: Fix kcontrol widget name memory management Lars-Peter Clausen
2015-07-08 21:17 ` Applied "ASoC: dapm: Fix kcontrol widget name memory management" to the asoc tree Mark Brown
2015-07-09  8:06 ` [PATCH] ASoC: dapm: Fix kcontrol widget name memory management Charles Keepax

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.