> -----Original Message-----
> From: Corey Minyard [mailto:tcminy...@gmail.com]
> Sent: Wednesday, August 22, 2018 11:28 AM
> To: Ernst, Justin <justin.er...@hpe.com>; Corey Minyard
> <miny...@acm.org>
> Cc: Arnd Bergmann <a...@arndb.de>; Greg Kroah-Hartman
> <gre...@linuxfoundation.org>; Jeremy Kerr <j...@ozlabs.org>; openipmi-
> develo...@lists.sourceforge.net; linux-ker...@vger.kernel.org; Anderson,
> Russ <russ.ander...@hpe.com>
> Subject: Re: [PATCH] Remove redundant cleanup in ipmi_register_smi
> 
> On 08/21/2018 10:25 AM, Justin Ernst wrote:
> > When ipmi_register_smi fails, it performs a small cleanup routine
> > before returning its error value. In try_smi_init, on the condition
> > that ipmi_register_smi fails, ipmi_unregister_smi is called.
> > ipmi_unregister_smi performs the same cleanup routine as
> > ipmi_register_smi. This results in a kernel NULL pointer dereference.
> > Removing the cleanup routine in ipmi_register_smi results in proper
> cleanup of a ipmi_register_smi failure.
> 
> This is almost certainly wrong.  If ipmi_register_smi() fails, the calling 
> code
> shouldn't call ipmi_unregister_smi().
> 
> However, I think I know what is going wrong.  ipmi_register_smi() can fail
> after the interface is initialized, if so the registering code will think it 
> is
> registered and call ipmi_unregister_smi() on a failure.  I'll send a patch for
> this.
> 
> -corey

Thanks for the reply Corey. I agree with what you have stated. I'll be watching 
for the patch.
-Justin

> 
> >
> > Cc: Corey Minyard <miny...@acm.org>
> > Cc: Arnd Bergmann <a...@arndb.de>
> > Cc: Greg Kroah-Hartman <gre...@linuxfoundation.org>
> > Cc: Jeremy Kerr <j...@ozlabs.org>
> > Cc: openipmi-developer@lists.sourceforge.net
> > Cc: linux-ker...@vger.kernel.org
> > Cc: Russ Anderson <russ.ander...@hpe.com>
> > Acked-by: Andrew Banman <aban...@hpe.com>
> > Signed-off-by: Justin Ernst <justin.er...@hpe.com>
> > ---
> >   drivers/char/ipmi/ipmi_msghandler.c | 10 +++++-----
> >   1 file changed, 5 insertions(+), 5 deletions(-)
> >
> > diff --git a/drivers/char/ipmi/ipmi_msghandler.c
> > b/drivers/char/ipmi/ipmi_msghandler.c
> > index 51832b8a2c62..3b0b50c4f064 100644
> > --- a/drivers/char/ipmi/ipmi_msghandler.c
> > +++ b/drivers/char/ipmi/ipmi_msghandler.c
> > @@ -3395,12 +3395,12 @@ int ipmi_register_smi(const struct
> > ipmi_smi_handlers *handlers,
> >
> >    out:
> >     if (rv) {
> > -           ipmi_bmc_unregister(intf);
> > -           list_del_rcu(&intf->link);
> > +           /*
> > +            * ipmi_unregister_smi must be called to clean up after
> > +            * failure. We unlock the mutex to allow ipmi_unregister_smi
> > +            * to lock it and perform cleanup.
> > +            */
> >             mutex_unlock(&ipmi_interfaces_mutex);
> > -           synchronize_srcu(&ipmi_interfaces_srcu);
> > -           cleanup_srcu_struct(&intf->users_srcu);
> > -           kref_put(&intf->refcount, intf_free);
> >     } else {
> >             /*
> >              * Keep memory order straight for RCU readers.  Make
> 

------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most
engaging tech sites, Slashdot.org! http://sdm.link/slashdot
_______________________________________________
Openipmi-developer mailing list
Openipmi-developer@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/openipmi-developer

Reply via email to