mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-14 11:11:22 -04:00
iio: adc: qcom-pm8xxx-xoadc: use scoped device_for_each_child_node()
Switch to device_for_each_child_node_scoped() to simplify the code by removing the need for calls to fwnode_handle_put() in the error path. This prevents possible memory leaks if new error paths are added without the required call to fwnode_handle_put(). Signed-off-by: Javier Carrasco <javier.carrasco.cruz@gmail.com> Link: https://patch.msgid.link/20240926-iio_device_for_each_child_node_scoped-v1-1-64ca8a424578@gmail.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
committed by
Jonathan Cameron
parent
ee3bf0c148
commit
db44b37a20
@@ -821,7 +821,6 @@ static int pm8xxx_xoadc_parse_channel(struct device *dev,
|
||||
|
||||
static int pm8xxx_xoadc_parse_channels(struct pm8xxx_xoadc *adc)
|
||||
{
|
||||
struct fwnode_handle *child;
|
||||
struct pm8xxx_chan_info *ch;
|
||||
int ret;
|
||||
int i;
|
||||
@@ -844,16 +843,15 @@ static int pm8xxx_xoadc_parse_channels(struct pm8xxx_xoadc *adc)
|
||||
return -ENOMEM;
|
||||
|
||||
i = 0;
|
||||
device_for_each_child_node(adc->dev, child) {
|
||||
device_for_each_child_node_scoped(adc->dev, child) {
|
||||
ch = &adc->chans[i];
|
||||
ret = pm8xxx_xoadc_parse_channel(adc->dev, child,
|
||||
adc->variant->channels,
|
||||
&adc->iio_chans[i],
|
||||
ch);
|
||||
if (ret) {
|
||||
fwnode_handle_put(child);
|
||||
if (ret)
|
||||
return ret;
|
||||
}
|
||||
|
||||
i++;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user