On Tue, Dec 12, 2023 at 06:53:13PM +0100, Christophe JAILLET wrote: > Le 12/12/2023 à 10:20, Dan Carpenter a écrit : > > We added locking to this function but these two error paths were > > accidentally overlooked. > > > > Fixes: f0af81683466 ("cdx: Introduce lock to protect controller ops") > > Signed-off-by: Dan Carpenter <dan.carpenter@xxxxxxxxxx> > > --- > > drivers/cdx/cdx.c | 14 +++++++++----- > > 1 file changed, 9 insertions(+), 5 deletions(-) > > > > diff --git a/drivers/cdx/cdx.c b/drivers/cdx/cdx.c > > index d84d153078d7..f4f9f0c88c09 100644 > > --- a/drivers/cdx/cdx.c > > +++ b/drivers/cdx/cdx.c > > @@ -572,12 +572,16 @@ static ssize_t rescan_store(const struct bus_type *bus, > > /* Rescan all the devices */ > > for_each_compatible_node(np, NULL, compat_node_name) { > > - if (!np) > > - return -EINVAL; > > + if (!np) { > > + count = -EINVAL; > > + goto unlock; > > + } > > pd = of_find_device_by_node(np); > > - if (!pd) > > - return -EINVAL; > > + if (!pd) { > > + count = -EINVAL; > > + goto unlock; > > Unrelated to your patch, but should we have a of_node_put(np); here, on > early exit? > Let me resend this along with a patch 2/2 which adds the of_node_put(). regards, dan carpenter