Commit 5b3cc856 authored by Krzysztof Kozlowski's avatar Krzysztof Kozlowski Committed by Mark Brown

ASoC: dapm: Simplify dapm_cnew_widget() with cleanup.h

Allocate the memory with scoped/cleanup.h in dapm_cnew_widget() to
reduce error handling (less error paths) and make the code a bit
simpler.
Signed-off-by: default avatarKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Link: https://patch.msgid.link/20240703-asoc-cleanup-h-v1-10-71219dfd0aef@linaro.orgSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 1a7b8468
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/async.h> #include <linux/async.h>
#include <linux/cleanup.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/pm.h> #include <linux/pm.h>
#include <linux/bitops.h> #include <linux/bitops.h>
...@@ -323,9 +324,9 @@ static inline struct snd_soc_dapm_widget *dapm_cnew_widget( ...@@ -323,9 +324,9 @@ static inline struct snd_soc_dapm_widget *dapm_cnew_widget(
const struct snd_soc_dapm_widget *_widget, const struct snd_soc_dapm_widget *_widget,
const char *prefix) const char *prefix)
{ {
struct snd_soc_dapm_widget *w; struct snd_soc_dapm_widget *w __free(kfree) = kmemdup(_widget,
sizeof(*_widget),
w = kmemdup(_widget, sizeof(*_widget), GFP_KERNEL); GFP_KERNEL);
if (!w) if (!w)
return NULL; return NULL;
...@@ -333,20 +334,18 @@ static inline struct snd_soc_dapm_widget *dapm_cnew_widget( ...@@ -333,20 +334,18 @@ static inline struct snd_soc_dapm_widget *dapm_cnew_widget(
w->name = kasprintf(GFP_KERNEL, "%s %s", prefix, _widget->name); w->name = kasprintf(GFP_KERNEL, "%s %s", prefix, _widget->name);
else else
w->name = kstrdup_const(_widget->name, GFP_KERNEL); w->name = kstrdup_const(_widget->name, GFP_KERNEL);
if (!w->name) { if (!w->name)
kfree(w);
return NULL; return NULL;
}
if (_widget->sname) { if (_widget->sname) {
w->sname = kstrdup_const(_widget->sname, GFP_KERNEL); w->sname = kstrdup_const(_widget->sname, GFP_KERNEL);
if (!w->sname) { if (!w->sname) {
kfree_const(w->name); kfree_const(w->name);
kfree(w);
return NULL; return NULL;
} }
} }
return w;
return_ptr(w);
} }
struct dapm_kcontrol_data { struct dapm_kcontrol_data {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment