On Sat, Jul 06, 2019 at 06:51:30PM +0530, Nishka Dasgupta wrote: > Each iteration of for_each_child_of_node puts the previous > node, but in the case of a return from the middle of the loop, there is > no put, thus causing a memory leak. Hence add an of_node_put before the > return. > Issue found with Coccinelle. > > Signed-off-by: Nishka Dasgupta <nishkadg.linux@xxxxxxxxx> Applied. For future patches, please don't put source file extensions into the subject line. Thanks, Guenter > --- > drivers/hwmon/ina3221.c | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/drivers/hwmon/ina3221.c b/drivers/hwmon/ina3221.c > index 55943b4dcc7b..0037e2bdacd6 100644 > --- a/drivers/hwmon/ina3221.c > +++ b/drivers/hwmon/ina3221.c > @@ -713,8 +713,10 @@ static int ina3221_probe_from_dt(struct device *dev, struct ina3221_data *ina) > > for_each_child_of_node(np, child) { > ret = ina3221_probe_child_from_dt(dev, child, ina); > - if (ret) > + if (ret) { > + of_node_put(child); > return ret; > + } > } > > return 0;