Prev: [1/23] x86: percpu: Avoid warnings of unused variables in per cpu
Next: Removing dead CONFIG_BLK_DEV_IDE
From: Corey Minyard on 10 Jun 2010 14:20 Yes, thanks for this. Acked-by: Corey Minyard <cminyard(a)mvista.com> Matthew Garrett wrote: > The ipmi code will never register a PCI or Open Firmware driver if > a hardcoded device is provided by the user. This can cause us to attempt > to unregister a driver that was never registered, resulting in an oops. > Keep track of registration in order to avoid this. > > Signed-off-by: Matthew Garrett <mjg(a)redhat.com> > --- > drivers/char/ipmi/ipmi_si_intf.c | 21 +++++++++++++++++---- > 1 files changed, 17 insertions(+), 4 deletions(-) > > diff --git a/drivers/char/ipmi/ipmi_si_intf.c b/drivers/char/ipmi/ipmi_si_intf.c > index 35603dd..311f85b 100644 > --- a/drivers/char/ipmi/ipmi_si_intf.c > +++ b/drivers/char/ipmi/ipmi_si_intf.c > @@ -302,6 +302,12 @@ struct smi_info { > > static int force_kipmid[SI_MAX_PARMS]; > static int num_force_kipmid; > +#ifdef CONFIG_PCI > +static int pci_registered; > +#endif > +#ifdef CONFIG_PPC_OF > +static int of_registered; > +#endif > > static unsigned int kipmid_max_busy_us[SI_MAX_PARMS]; > static int num_max_busy_us; > @@ -3314,6 +3320,8 @@ static __devinit int init_ipmi_si(void) > rv = pci_register_driver(&ipmi_pci_driver); > if (rv) > printk(KERN_ERR PFX "Unable to register PCI driver: %d\n", rv); > + else > + pci_registered = 1; > #endif > > #ifdef CONFIG_ACPI > @@ -3330,6 +3338,7 @@ static __devinit int init_ipmi_si(void) > > #ifdef CONFIG_PPC_OF > of_register_platform_driver(&ipmi_of_platform_driver); > + of_registered = 1; > #endif > > /* We prefer devices with interrupts, but in the case of a machine > @@ -3383,11 +3392,13 @@ static __devinit int init_ipmi_si(void) > if (unload_when_empty && list_empty(&smi_infos)) { > mutex_unlock(&smi_infos_lock); > #ifdef CONFIG_PCI > - pci_unregister_driver(&ipmi_pci_driver); > + if (pci_registered) > + pci_unregister_driver(&ipmi_pci_driver); > #endif > > #ifdef CONFIG_PPC_OF > - of_unregister_platform_driver(&ipmi_of_platform_driver); > + if (of_registered) > + of_unregister_platform_driver(&ipmi_of_platform_driver); > #endif > driver_unregister(&ipmi_driver.driver); > printk(KERN_WARNING PFX > @@ -3478,14 +3489,16 @@ static __exit void cleanup_ipmi_si(void) > return; > > #ifdef CONFIG_PCI > - pci_unregister_driver(&ipmi_pci_driver); > + if (pci_registered) > + pci_unregister_driver(&ipmi_pci_driver); > #endif > #ifdef CONFIG_ACPI > pnp_unregister_driver(&ipmi_pnp_driver); > #endif > > #ifdef CONFIG_PPC_OF > - of_unregister_platform_driver(&ipmi_of_platform_driver); > + if (of_registered) > + of_unregister_platform_driver(&ipmi_of_platform_driver); > #endif > > mutex_lock(&smi_infos_lock); > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Andrew Morton on 14 Jun 2010 16:40
On Thu, 10 Jun 2010 13:53:26 -0400 Matthew Garrett <mjg(a)redhat.com> wrote: > The ipmi code will never register a PCI or Open Firmware driver if > a hardcoded device is provided by the user. How does a user "provide a hardcoded device"? > This can cause us to attempt > to unregister a driver that was never registered, resulting in an oops. > Keep track of registration in order to avoid this. > I tried to work out from the above whether we want to backport this fix into -stable and failed. And I reckon that if I can't work this out from a changelog, the changelog is inadequate. > --- a/drivers/char/ipmi/ipmi_si_intf.c > +++ b/drivers/char/ipmi/ipmi_si_intf.c > @@ -302,6 +302,12 @@ struct smi_info { > > static int force_kipmid[SI_MAX_PARMS]; > static int num_force_kipmid; > +#ifdef CONFIG_PCI > +static int pci_registered; > +#endif > +#ifdef CONFIG_PPC_OF > +static int of_registered; > +#endif > > static unsigned int kipmid_max_busy_us[SI_MAX_PARMS]; > static int num_max_busy_us; > @@ -3314,6 +3320,8 @@ static __devinit int init_ipmi_si(void) > rv = pci_register_driver(&ipmi_pci_driver); > if (rv) > printk(KERN_ERR PFX "Unable to register PCI driver: %d\n", rv); > + else > + pci_registered = 1; > #endif > > #ifdef CONFIG_ACPI > @@ -3330,6 +3338,7 @@ static __devinit int init_ipmi_si(void) > > #ifdef CONFIG_PPC_OF > of_register_platform_driver(&ipmi_of_platform_driver); > + of_registered = 1; I assume the code will still oops if of_register_platform_driver() failed. > #endif > > /* We prefer devices with interrupts, but in the case of a machine > @@ -3383,11 +3392,13 @@ static __devinit int init_ipmi_si(void) > if (unload_when_empty && list_empty(&smi_infos)) { > mutex_unlock(&smi_infos_lock); > #ifdef CONFIG_PCI > - pci_unregister_driver(&ipmi_pci_driver); > + if (pci_registered) > + pci_unregister_driver(&ipmi_pci_driver); > #endif > > #ifdef CONFIG_PPC_OF > - of_unregister_platform_driver(&ipmi_of_platform_driver); > + if (of_registered) > + of_unregister_platform_driver(&ipmi_of_platform_driver); > #endif > driver_unregister(&ipmi_driver.driver); > printk(KERN_WARNING PFX > @@ -3478,14 +3489,16 @@ static __exit void cleanup_ipmi_si(void) > return; > > #ifdef CONFIG_PCI > - pci_unregister_driver(&ipmi_pci_driver); > + if (pci_registered) > + pci_unregister_driver(&ipmi_pci_driver); > #endif > #ifdef CONFIG_ACPI > pnp_unregister_driver(&ipmi_pnp_driver); > #endif > > #ifdef CONFIG_PPC_OF > - of_unregister_platform_driver(&ipmi_of_platform_driver); > + if (of_registered) > + of_unregister_platform_driver(&ipmi_of_platform_driver); > #endif > > mutex_lock(&smi_infos_lock); -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |