Message ID | 20210806093938.1950990-1-u.kleine-koenig@pengutronix.de (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | parisc: Make struct parisc_driver::remove() return void | expand |
Context | Check | Description |
---|---|---|
netdev/tree_selection | success | Not a local patch |
On Fri, Aug 06, 2021 at 11:39:38AM +0200, Uwe Kleine-König wrote: > The caller of this function (parisc_driver_remove() in > arch/parisc/kernel/drivers.c) ignores the return value, so better don't > return any value at all to not wake wrong expectations in driver authors. > > The only function that could return a non-zero value before was > ipmi_parisc_remove() which returns the return value of > ipmi_si_remove_by_dev(). Make this function return void, too, as for all > other callers the value is ignored, too. > > Also fold in a small checkpatch fix for: > > WARNING: Unnecessary space before function pointer arguments > + void (*remove) (struct parisc_device *dev); > > Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> > --- > arch/parisc/include/asm/parisc-device.h | 4 ++-- > drivers/char/ipmi/ipmi_si_intf.c | 6 +----- > drivers/char/ipmi/ipmi_si_parisc.c | 4 ++-- > drivers/char/ipmi/ipmi_si_platform.c | 4 +++- > drivers/input/keyboard/hilkbd.c | 4 +--- > drivers/input/serio/gscps2.c | 3 +-- > drivers/net/ethernet/i825xx/lasi_82596.c | 3 +-- > drivers/parport/parport_gsc.c | 3 +-- > drivers/scsi/lasi700.c | 4 +--- > drivers/scsi/zalon.c | 4 +--- > drivers/tty/serial/mux.c | 3 +-- > sound/parisc/harmony.c | 3 +-- > 12 files changed, 16 insertions(+), 29 deletions(-) > > diff --git a/arch/parisc/include/asm/parisc-device.h b/arch/parisc/include/asm/parisc-device.h > index d02d144c6012..4de3b391d812 100644 > --- a/arch/parisc/include/asm/parisc-device.h > +++ b/arch/parisc/include/asm/parisc-device.h > @@ -34,8 +34,8 @@ struct parisc_driver { > struct parisc_driver *next; > char *name; > const struct parisc_device_id *id_table; > - int (*probe) (struct parisc_device *dev); /* New device discovered */ > - int (*remove) (struct parisc_device *dev); > + int (*probe)(struct parisc_device *dev); /* New device discovered */ > + void (*remove)(struct parisc_device *dev); > struct device_driver drv; > }; > > diff --git a/drivers/char/ipmi/ipmi_si_intf.c b/drivers/char/ipmi/ipmi_si_intf.c > index 62929a3e397e..bb466981dc1b 100644 > --- a/drivers/char/ipmi/ipmi_si_intf.c > +++ b/drivers/char/ipmi/ipmi_si_intf.c > @@ -2228,22 +2228,18 @@ static void cleanup_one_si(struct smi_info *smi_info) > kfree(smi_info); > } > > -int ipmi_si_remove_by_dev(struct device *dev) > +void ipmi_si_remove_by_dev(struct device *dev) This function is also used by ipmi_si_platform.c, so you can't change this. -corey > { > struct smi_info *e; > - int rv = -ENOENT; > > mutex_lock(&smi_infos_lock); > list_for_each_entry(e, &smi_infos, link) { > if (e->io.dev == dev) { > cleanup_one_si(e); > - rv = 0; > break; > } > } > mutex_unlock(&smi_infos_lock); > - > - return rv; > } > > struct device *ipmi_si_remove_by_data(int addr_space, enum si_type si_type, > diff --git a/drivers/char/ipmi/ipmi_si_parisc.c b/drivers/char/ipmi/ipmi_si_parisc.c > index 11c9160275df..2be2967f6b5f 100644 > --- a/drivers/char/ipmi/ipmi_si_parisc.c > +++ b/drivers/char/ipmi/ipmi_si_parisc.c > @@ -29,9 +29,9 @@ static int __init ipmi_parisc_probe(struct parisc_device *dev) > return ipmi_si_add_smi(&io); > } > > -static int __exit ipmi_parisc_remove(struct parisc_device *dev) > +static void __exit ipmi_parisc_remove(struct parisc_device *dev) > { > - return ipmi_si_remove_by_dev(&dev->dev); > + ipmi_si_remove_by_dev(&dev->dev); > } > > static const struct parisc_device_id ipmi_parisc_tbl[] __initconst = { > diff --git a/drivers/char/ipmi/ipmi_si_platform.c b/drivers/char/ipmi/ipmi_si_platform.c > index 380a6a542890..505cc978c97a 100644 > --- a/drivers/char/ipmi/ipmi_si_platform.c > +++ b/drivers/char/ipmi/ipmi_si_platform.c > @@ -411,7 +411,9 @@ static int ipmi_probe(struct platform_device *pdev) > > static int ipmi_remove(struct platform_device *pdev) > { > - return ipmi_si_remove_by_dev(&pdev->dev); > + ipmi_si_remove_by_dev(&pdev->dev); > + > + return 0; > } > > static int pdev_match_name(struct device *dev, const void *data) > diff --git a/drivers/input/keyboard/hilkbd.c b/drivers/input/keyboard/hilkbd.c > index 62ccfebf2f60..c1a4d5055de6 100644 > --- a/drivers/input/keyboard/hilkbd.c > +++ b/drivers/input/keyboard/hilkbd.c > @@ -316,11 +316,9 @@ static int __init hil_probe_chip(struct parisc_device *dev) > return hil_keyb_init(); > } > > -static int __exit hil_remove_chip(struct parisc_device *dev) > +static void __exit hil_remove_chip(struct parisc_device *dev) > { > hil_keyb_exit(); > - > - return 0; > } > > static const struct parisc_device_id hil_tbl[] __initconst = { > diff --git a/drivers/input/serio/gscps2.c b/drivers/input/serio/gscps2.c > index 2f9775de3c5b..a9065c6ab550 100644 > --- a/drivers/input/serio/gscps2.c > +++ b/drivers/input/serio/gscps2.c > @@ -411,7 +411,7 @@ static int __init gscps2_probe(struct parisc_device *dev) > * @return: success/error report > */ > > -static int __exit gscps2_remove(struct parisc_device *dev) > +static void __exit gscps2_remove(struct parisc_device *dev) > { > struct gscps2port *ps2port = dev_get_drvdata(&dev->dev); > > @@ -425,7 +425,6 @@ static int __exit gscps2_remove(struct parisc_device *dev) > #endif > dev_set_drvdata(&dev->dev, NULL); > kfree(ps2port); > - return 0; > } > > > diff --git a/drivers/net/ethernet/i825xx/lasi_82596.c b/drivers/net/ethernet/i825xx/lasi_82596.c > index 96c6f4f36904..48e001881c75 100644 > --- a/drivers/net/ethernet/i825xx/lasi_82596.c > +++ b/drivers/net/ethernet/i825xx/lasi_82596.c > @@ -196,7 +196,7 @@ lan_init_chip(struct parisc_device *dev) > return retval; > } > > -static int __exit lan_remove_chip(struct parisc_device *pdev) > +static void __exit lan_remove_chip(struct parisc_device *pdev) > { > struct net_device *dev = parisc_get_drvdata(pdev); > struct i596_private *lp = netdev_priv(dev); > @@ -205,7 +205,6 @@ static int __exit lan_remove_chip(struct parisc_device *pdev) > dma_free_noncoherent(&pdev->dev, sizeof(struct i596_private), lp->dma, > lp->dma_addr, DMA_BIDIRECTIONAL); > free_netdev (dev); > - return 0; > } > > static const struct parisc_device_id lan_tbl[] __initconst = { > diff --git a/drivers/parport/parport_gsc.c b/drivers/parport/parport_gsc.c > index 1e43b3f399a8..4332692ca4b8 100644 > --- a/drivers/parport/parport_gsc.c > +++ b/drivers/parport/parport_gsc.c > @@ -378,7 +378,7 @@ static int __init parport_init_chip(struct parisc_device *dev) > return 0; > } > > -static int __exit parport_remove_chip(struct parisc_device *dev) > +static void __exit parport_remove_chip(struct parisc_device *dev) > { > struct parport *p = dev_get_drvdata(&dev->dev); > if (p) { > @@ -397,7 +397,6 @@ static int __exit parport_remove_chip(struct parisc_device *dev) > parport_put_port(p); > kfree (ops); /* hope no-one cached it */ > } > - return 0; > } > > static const struct parisc_device_id parport_tbl[] __initconst = { > diff --git a/drivers/scsi/lasi700.c b/drivers/scsi/lasi700.c > index 6d14a7a94d0b..86fe19e0468d 100644 > --- a/drivers/scsi/lasi700.c > +++ b/drivers/scsi/lasi700.c > @@ -134,7 +134,7 @@ lasi700_probe(struct parisc_device *dev) > return -ENODEV; > } > > -static int __exit > +static void __exit > lasi700_driver_remove(struct parisc_device *dev) > { > struct Scsi_Host *host = dev_get_drvdata(&dev->dev); > @@ -146,8 +146,6 @@ lasi700_driver_remove(struct parisc_device *dev) > free_irq(host->irq, host); > iounmap(hostdata->base); > kfree(hostdata); > - > - return 0; > } > > static struct parisc_driver lasi700_driver __refdata = { > diff --git a/drivers/scsi/zalon.c b/drivers/scsi/zalon.c > index 7eac76cccc4c..f1e5cf8a17d9 100644 > --- a/drivers/scsi/zalon.c > +++ b/drivers/scsi/zalon.c > @@ -168,15 +168,13 @@ static const struct parisc_device_id zalon_tbl[] __initconst = { > > MODULE_DEVICE_TABLE(parisc, zalon_tbl); > > -static int __exit zalon_remove(struct parisc_device *dev) > +static void __exit zalon_remove(struct parisc_device *dev) > { > struct Scsi_Host *host = dev_get_drvdata(&dev->dev); > > scsi_remove_host(host); > ncr53c8xx_release(host); > free_irq(dev->irq, host); > - > - return 0; > } > > static struct parisc_driver zalon_driver __refdata = { > diff --git a/drivers/tty/serial/mux.c b/drivers/tty/serial/mux.c > index be640d9863cd..643dfbcc43f9 100644 > --- a/drivers/tty/serial/mux.c > +++ b/drivers/tty/serial/mux.c > @@ -496,7 +496,7 @@ static int __init mux_probe(struct parisc_device *dev) > return 0; > } > > -static int __exit mux_remove(struct parisc_device *dev) > +static void __exit mux_remove(struct parisc_device *dev) > { > int i, j; > int port_count = (long)dev_get_drvdata(&dev->dev); > @@ -518,7 +518,6 @@ static int __exit mux_remove(struct parisc_device *dev) > } > > release_mem_region(dev->hpa.start + MUX_OFFSET, port_count * MUX_LINE_OFFSET); > - return 0; > } > > /* Hack. This idea was taken from the 8250_gsc.c on how to properly order > diff --git a/sound/parisc/harmony.c b/sound/parisc/harmony.c > index 1440db8b4177..2e3e5aa47682 100644 > --- a/sound/parisc/harmony.c > +++ b/sound/parisc/harmony.c > @@ -968,11 +968,10 @@ snd_harmony_probe(struct parisc_device *padev) > return err; > } > > -static int __exit > +static void __exit > snd_harmony_remove(struct parisc_device *padev) > { > snd_card_free(parisc_get_drvdata(padev)); > - return 0; > } > > static struct parisc_driver snd_harmony_driver __refdata = { > -- > 2.30.2 >
On Fri, Aug 06, 2021 at 11:39:38AM +0200, Uwe Kleine-König wrote: > The caller of this function (parisc_driver_remove() in > arch/parisc/kernel/drivers.c) ignores the return value, so better don't > return any value at all to not wake wrong expectations in driver authors. > > The only function that could return a non-zero value before was > ipmi_parisc_remove() which returns the return value of > ipmi_si_remove_by_dev(). Make this function return void, too, as for all > other callers the value is ignored, too. > > Also fold in a small checkpatch fix for: > > WARNING: Unnecessary space before function pointer arguments > + void (*remove) (struct parisc_device *dev); > > Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> > --- ... > drivers/input/keyboard/hilkbd.c | 4 +--- > drivers/input/serio/gscps2.c | 3 +-- Acked-by: Dmitry Torokhov <dmitry.torokhov@gmail.com> Thanks.
Hello, On Fri, Aug 06, 2021 at 12:49:27PM -0500, Corey Minyard wrote: > On Fri, Aug 06, 2021 at 11:39:38AM +0200, Uwe Kleine-König wrote: > > -int ipmi_si_remove_by_dev(struct device *dev) > > +void ipmi_si_remove_by_dev(struct device *dev) > > This function is also used by ipmi_si_platform.c, so you can't change > this. Did you see that I adapted ipmi_si_platform.c below? That is an instance of "Make [ipmi_si_remove_by_dev] return void, too, as for all other callers the value is ignored, too." (In ipmi_si_platform.c the return value is used in a struct platform_driver::remove function. The value returned there is ignored, see commit e5e1c209788138f33ca6558bf9f572f6904f486d.) Best regards Uwe
diff --git a/arch/parisc/include/asm/parisc-device.h b/arch/parisc/include/asm/parisc-device.h index d02d144c6012..4de3b391d812 100644 --- a/arch/parisc/include/asm/parisc-device.h +++ b/arch/parisc/include/asm/parisc-device.h @@ -34,8 +34,8 @@ struct parisc_driver { struct parisc_driver *next; char *name; const struct parisc_device_id *id_table; - int (*probe) (struct parisc_device *dev); /* New device discovered */ - int (*remove) (struct parisc_device *dev); + int (*probe)(struct parisc_device *dev); /* New device discovered */ + void (*remove)(struct parisc_device *dev); struct device_driver drv; }; diff --git a/drivers/char/ipmi/ipmi_si_intf.c b/drivers/char/ipmi/ipmi_si_intf.c index 62929a3e397e..bb466981dc1b 100644 --- a/drivers/char/ipmi/ipmi_si_intf.c +++ b/drivers/char/ipmi/ipmi_si_intf.c @@ -2228,22 +2228,18 @@ static void cleanup_one_si(struct smi_info *smi_info) kfree(smi_info); } -int ipmi_si_remove_by_dev(struct device *dev) +void ipmi_si_remove_by_dev(struct device *dev) { struct smi_info *e; - int rv = -ENOENT; mutex_lock(&smi_infos_lock); list_for_each_entry(e, &smi_infos, link) { if (e->io.dev == dev) { cleanup_one_si(e); - rv = 0; break; } } mutex_unlock(&smi_infos_lock); - - return rv; } struct device *ipmi_si_remove_by_data(int addr_space, enum si_type si_type, diff --git a/drivers/char/ipmi/ipmi_si_parisc.c b/drivers/char/ipmi/ipmi_si_parisc.c index 11c9160275df..2be2967f6b5f 100644 --- a/drivers/char/ipmi/ipmi_si_parisc.c +++ b/drivers/char/ipmi/ipmi_si_parisc.c @@ -29,9 +29,9 @@ static int __init ipmi_parisc_probe(struct parisc_device *dev) return ipmi_si_add_smi(&io); } -static int __exit ipmi_parisc_remove(struct parisc_device *dev) +static void __exit ipmi_parisc_remove(struct parisc_device *dev) { - return ipmi_si_remove_by_dev(&dev->dev); + ipmi_si_remove_by_dev(&dev->dev); } static const struct parisc_device_id ipmi_parisc_tbl[] __initconst = { diff --git a/drivers/char/ipmi/ipmi_si_platform.c b/drivers/char/ipmi/ipmi_si_platform.c index 380a6a542890..505cc978c97a 100644 --- a/drivers/char/ipmi/ipmi_si_platform.c +++ b/drivers/char/ipmi/ipmi_si_platform.c @@ -411,7 +411,9 @@ static int ipmi_probe(struct platform_device *pdev) static int ipmi_remove(struct platform_device *pdev) { - return ipmi_si_remove_by_dev(&pdev->dev); + ipmi_si_remove_by_dev(&pdev->dev); + + return 0; } static int pdev_match_name(struct device *dev, const void *data) diff --git a/drivers/input/keyboard/hilkbd.c b/drivers/input/keyboard/hilkbd.c index 62ccfebf2f60..c1a4d5055de6 100644 --- a/drivers/input/keyboard/hilkbd.c +++ b/drivers/input/keyboard/hilkbd.c @@ -316,11 +316,9 @@ static int __init hil_probe_chip(struct parisc_device *dev) return hil_keyb_init(); } -static int __exit hil_remove_chip(struct parisc_device *dev) +static void __exit hil_remove_chip(struct parisc_device *dev) { hil_keyb_exit(); - - return 0; } static const struct parisc_device_id hil_tbl[] __initconst = { diff --git a/drivers/input/serio/gscps2.c b/drivers/input/serio/gscps2.c index 2f9775de3c5b..a9065c6ab550 100644 --- a/drivers/input/serio/gscps2.c +++ b/drivers/input/serio/gscps2.c @@ -411,7 +411,7 @@ static int __init gscps2_probe(struct parisc_device *dev) * @return: success/error report */ -static int __exit gscps2_remove(struct parisc_device *dev) +static void __exit gscps2_remove(struct parisc_device *dev) { struct gscps2port *ps2port = dev_get_drvdata(&dev->dev); @@ -425,7 +425,6 @@ static int __exit gscps2_remove(struct parisc_device *dev) #endif dev_set_drvdata(&dev->dev, NULL); kfree(ps2port); - return 0; } diff --git a/drivers/net/ethernet/i825xx/lasi_82596.c b/drivers/net/ethernet/i825xx/lasi_82596.c index 96c6f4f36904..48e001881c75 100644 --- a/drivers/net/ethernet/i825xx/lasi_82596.c +++ b/drivers/net/ethernet/i825xx/lasi_82596.c @@ -196,7 +196,7 @@ lan_init_chip(struct parisc_device *dev) return retval; } -static int __exit lan_remove_chip(struct parisc_device *pdev) +static void __exit lan_remove_chip(struct parisc_device *pdev) { struct net_device *dev = parisc_get_drvdata(pdev); struct i596_private *lp = netdev_priv(dev); @@ -205,7 +205,6 @@ static int __exit lan_remove_chip(struct parisc_device *pdev) dma_free_noncoherent(&pdev->dev, sizeof(struct i596_private), lp->dma, lp->dma_addr, DMA_BIDIRECTIONAL); free_netdev (dev); - return 0; } static const struct parisc_device_id lan_tbl[] __initconst = { diff --git a/drivers/parport/parport_gsc.c b/drivers/parport/parport_gsc.c index 1e43b3f399a8..4332692ca4b8 100644 --- a/drivers/parport/parport_gsc.c +++ b/drivers/parport/parport_gsc.c @@ -378,7 +378,7 @@ static int __init parport_init_chip(struct parisc_device *dev) return 0; } -static int __exit parport_remove_chip(struct parisc_device *dev) +static void __exit parport_remove_chip(struct parisc_device *dev) { struct parport *p = dev_get_drvdata(&dev->dev); if (p) { @@ -397,7 +397,6 @@ static int __exit parport_remove_chip(struct parisc_device *dev) parport_put_port(p); kfree (ops); /* hope no-one cached it */ } - return 0; } static const struct parisc_device_id parport_tbl[] __initconst = { diff --git a/drivers/scsi/lasi700.c b/drivers/scsi/lasi700.c index 6d14a7a94d0b..86fe19e0468d 100644 --- a/drivers/scsi/lasi700.c +++ b/drivers/scsi/lasi700.c @@ -134,7 +134,7 @@ lasi700_probe(struct parisc_device *dev) return -ENODEV; } -static int __exit +static void __exit lasi700_driver_remove(struct parisc_device *dev) { struct Scsi_Host *host = dev_get_drvdata(&dev->dev); @@ -146,8 +146,6 @@ lasi700_driver_remove(struct parisc_device *dev) free_irq(host->irq, host); iounmap(hostdata->base); kfree(hostdata); - - return 0; } static struct parisc_driver lasi700_driver __refdata = { diff --git a/drivers/scsi/zalon.c b/drivers/scsi/zalon.c index 7eac76cccc4c..f1e5cf8a17d9 100644 --- a/drivers/scsi/zalon.c +++ b/drivers/scsi/zalon.c @@ -168,15 +168,13 @@ static const struct parisc_device_id zalon_tbl[] __initconst = { MODULE_DEVICE_TABLE(parisc, zalon_tbl); -static int __exit zalon_remove(struct parisc_device *dev) +static void __exit zalon_remove(struct parisc_device *dev) { struct Scsi_Host *host = dev_get_drvdata(&dev->dev); scsi_remove_host(host); ncr53c8xx_release(host); free_irq(dev->irq, host); - - return 0; } static struct parisc_driver zalon_driver __refdata = { diff --git a/drivers/tty/serial/mux.c b/drivers/tty/serial/mux.c index be640d9863cd..643dfbcc43f9 100644 --- a/drivers/tty/serial/mux.c +++ b/drivers/tty/serial/mux.c @@ -496,7 +496,7 @@ static int __init mux_probe(struct parisc_device *dev) return 0; } -static int __exit mux_remove(struct parisc_device *dev) +static void __exit mux_remove(struct parisc_device *dev) { int i, j; int port_count = (long)dev_get_drvdata(&dev->dev); @@ -518,7 +518,6 @@ static int __exit mux_remove(struct parisc_device *dev) } release_mem_region(dev->hpa.start + MUX_OFFSET, port_count * MUX_LINE_OFFSET); - return 0; } /* Hack. This idea was taken from the 8250_gsc.c on how to properly order diff --git a/sound/parisc/harmony.c b/sound/parisc/harmony.c index 1440db8b4177..2e3e5aa47682 100644 --- a/sound/parisc/harmony.c +++ b/sound/parisc/harmony.c @@ -968,11 +968,10 @@ snd_harmony_probe(struct parisc_device *padev) return err; } -static int __exit +static void __exit snd_harmony_remove(struct parisc_device *padev) { snd_card_free(parisc_get_drvdata(padev)); - return 0; } static struct parisc_driver snd_harmony_driver __refdata = {
The caller of this function (parisc_driver_remove() in arch/parisc/kernel/drivers.c) ignores the return value, so better don't return any value at all to not wake wrong expectations in driver authors. The only function that could return a non-zero value before was ipmi_parisc_remove() which returns the return value of ipmi_si_remove_by_dev(). Make this function return void, too, as for all other callers the value is ignored, too. Also fold in a small checkpatch fix for: WARNING: Unnecessary space before function pointer arguments + void (*remove) (struct parisc_device *dev); Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de> --- arch/parisc/include/asm/parisc-device.h | 4 ++-- drivers/char/ipmi/ipmi_si_intf.c | 6 +----- drivers/char/ipmi/ipmi_si_parisc.c | 4 ++-- drivers/char/ipmi/ipmi_si_platform.c | 4 +++- drivers/input/keyboard/hilkbd.c | 4 +--- drivers/input/serio/gscps2.c | 3 +-- drivers/net/ethernet/i825xx/lasi_82596.c | 3 +-- drivers/parport/parport_gsc.c | 3 +-- drivers/scsi/lasi700.c | 4 +--- drivers/scsi/zalon.c | 4 +--- drivers/tty/serial/mux.c | 3 +-- sound/parisc/harmony.c | 3 +-- 12 files changed, 16 insertions(+), 29 deletions(-)