mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-04 04:02:26 +00:00
ASoC: codecs: audio-iio-aux: Simplify audio_iio_aux_probe() with cleanup.h
Allocate the memory with scoped/cleanup.h in audio_iio_aux_probe() to reduce error handling (less error paths) and make the code a bit simpler. Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://patch.msgid.link/20240703-asoc-cleanup-h-v1-2-71219dfd0aef@linaro.org Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
408e493817
commit
f9cbfb6612
@ -230,8 +230,6 @@ static int audio_iio_aux_probe(struct platform_device *pdev)
|
||||
struct audio_iio_aux_chan *iio_aux_chan;
|
||||
struct device *dev = &pdev->dev;
|
||||
struct audio_iio_aux *iio_aux;
|
||||
const char **names;
|
||||
u32 *invert_ranges;
|
||||
int count;
|
||||
int ret;
|
||||
int i;
|
||||
@ -248,22 +246,22 @@ static int audio_iio_aux_probe(struct platform_device *pdev)
|
||||
|
||||
iio_aux->num_chans = count;
|
||||
|
||||
names = kcalloc(iio_aux->num_chans, sizeof(*names), GFP_KERNEL);
|
||||
const char **names __free(kfree) = kcalloc(iio_aux->num_chans,
|
||||
sizeof(*names),
|
||||
GFP_KERNEL);
|
||||
if (!names)
|
||||
return -ENOMEM;
|
||||
|
||||
invert_ranges = kcalloc(iio_aux->num_chans, sizeof(*invert_ranges), GFP_KERNEL);
|
||||
if (!invert_ranges) {
|
||||
ret = -ENOMEM;
|
||||
goto out_free_names;
|
||||
}
|
||||
u32 *invert_ranges __free(kfree) = kcalloc(iio_aux->num_chans,
|
||||
sizeof(*invert_ranges),
|
||||
GFP_KERNEL);
|
||||
if (!invert_ranges)
|
||||
return -ENOMEM;
|
||||
|
||||
ret = device_property_read_string_array(dev, "io-channel-names",
|
||||
names, iio_aux->num_chans);
|
||||
if (ret < 0) {
|
||||
dev_err_probe(dev, ret, "failed to read io-channel-names\n");
|
||||
goto out_free_invert_ranges;
|
||||
}
|
||||
if (ret < 0)
|
||||
return dev_err_probe(dev, ret, "failed to read io-channel-names\n");
|
||||
|
||||
/*
|
||||
* snd-control-invert-range is optional and can contain fewer items
|
||||
@ -274,10 +272,8 @@ static int audio_iio_aux_probe(struct platform_device *pdev)
|
||||
count = min_t(unsigned int, count, iio_aux->num_chans);
|
||||
ret = device_property_read_u32_array(dev, "snd-control-invert-range",
|
||||
invert_ranges, count);
|
||||
if (ret < 0) {
|
||||
dev_err_probe(dev, ret, "failed to read snd-control-invert-range\n");
|
||||
goto out_free_invert_ranges;
|
||||
}
|
||||
if (ret < 0)
|
||||
return dev_err_probe(dev, ret, "failed to read snd-control-invert-range\n");
|
||||
}
|
||||
|
||||
for (i = 0; i < iio_aux->num_chans; i++) {
|
||||
@ -286,23 +282,16 @@ static int audio_iio_aux_probe(struct platform_device *pdev)
|
||||
iio_aux_chan->is_invert_range = invert_ranges[i];
|
||||
|
||||
iio_aux_chan->iio_chan = devm_iio_channel_get(dev, iio_aux_chan->name);
|
||||
if (IS_ERR(iio_aux_chan->iio_chan)) {
|
||||
ret = PTR_ERR(iio_aux_chan->iio_chan);
|
||||
dev_err_probe(dev, ret, "get IIO channel '%s' failed\n",
|
||||
iio_aux_chan->name);
|
||||
goto out_free_invert_ranges;
|
||||
}
|
||||
if (IS_ERR(iio_aux_chan->iio_chan))
|
||||
return dev_err_probe(dev, PTR_ERR(iio_aux_chan->iio_chan),
|
||||
"get IIO channel '%s' failed\n",
|
||||
iio_aux_chan->name);
|
||||
}
|
||||
|
||||
platform_set_drvdata(pdev, iio_aux);
|
||||
|
||||
ret = devm_snd_soc_register_component(dev, &audio_iio_aux_component_driver,
|
||||
NULL, 0);
|
||||
out_free_invert_ranges:
|
||||
kfree(invert_ranges);
|
||||
out_free_names:
|
||||
kfree(names);
|
||||
return ret;
|
||||
return devm_snd_soc_register_component(dev, &audio_iio_aux_component_driver,
|
||||
NULL, 0);
|
||||
}
|
||||
|
||||
static const struct of_device_id audio_iio_aux_ids[] = {
|
||||
|
Loading…
Reference in New Issue
Block a user