sparc/vio: make remove callback return void
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Wed, 5 May 2021 20:14:49 +0000 (22:14 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 14 May 2021 11:45:58 +0000 (13:45 +0200)
The driver core ignores the return value of struct bus_type::remove()
because there is only little that can be done. To simplify the quest to
make this function return void, let struct vio_driver::remove() return
void, too. All users already unconditionally return 0, this commit makes
it obvious that returning an error code is a bad idea and should prevent
that future driver authors consider returning an error code.

Note there are two nominally different implementations for a vio bus:
one in arch/sparc/kernel/vio.c and the other in
arch/powerpc/platforms/pseries/vio.c. This patch only addresses the
former.

Acked-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Link: https://lore.kernel.org/r/20210505201449.195627-1-u.kleine-koenig@pengutronix.de
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/sparc/include/asm/vio.h
arch/sparc/kernel/ds.c
arch/sparc/kernel/vio.c
drivers/block/sunvdc.c
drivers/net/ethernet/sun/ldmvsw.c
drivers/net/ethernet/sun/sunvnet.c
drivers/tty/vcc.c

index 059f0eb..8a1a83b 100644 (file)
@@ -362,7 +362,7 @@ struct vio_driver {
        struct list_head                node;
        const struct vio_device_id      *id_table;
        int (*probe)(struct vio_dev *dev, const struct vio_device_id *id);
-       int (*remove)(struct vio_dev *dev);
+       void (*remove)(struct vio_dev *dev);
        void (*shutdown)(struct vio_dev *dev);
        unsigned long                   driver_data;
        struct device_driver            driver;
index 522e5b5..4a5bdb0 100644 (file)
@@ -1236,11 +1236,6 @@ out_err:
        return err;
 }
 
-static int ds_remove(struct vio_dev *vdev)
-{
-       return 0;
-}
-
 static const struct vio_device_id ds_match[] = {
        {
                .type = "domain-services-port",
@@ -1251,7 +1246,6 @@ static const struct vio_device_id ds_match[] = {
 static struct vio_driver ds_driver = {
        .id_table       = ds_match,
        .probe          = ds_probe,
-       .remove         = ds_remove,
        .name           = "ds",
 };
 
index 4f57056..348a886 100644 (file)
@@ -105,10 +105,10 @@ static int vio_device_remove(struct device *dev)
                 * routines to do so at the moment. TBD
                 */
 
-               return drv->remove(vdev);
+               drv->remove(vdev);
        }
 
-       return 1;
+       return 0;
 }
 
 static ssize_t devspec_show(struct device *dev,
index 39aeebc..1547d43 100644 (file)
@@ -1071,7 +1071,7 @@ err_out_release_mdesc:
        return err;
 }
 
-static int vdc_port_remove(struct vio_dev *vdev)
+static void vdc_port_remove(struct vio_dev *vdev)
 {
        struct vdc_port *port = dev_get_drvdata(&vdev->dev);
 
@@ -1094,7 +1094,6 @@ static int vdc_port_remove(struct vio_dev *vdev)
 
                kfree(port);
        }
-       return 0;
 }
 
 static void vdc_requeue_inflight(struct vdc_port *port)
index 01ea0d6..50bd4e3 100644 (file)
@@ -404,7 +404,7 @@ err_out_free_dev:
        return err;
 }
 
-static int vsw_port_remove(struct vio_dev *vdev)
+static void vsw_port_remove(struct vio_dev *vdev)
 {
        struct vnet_port *port = dev_get_drvdata(&vdev->dev);
        unsigned long flags;
@@ -430,8 +430,6 @@ static int vsw_port_remove(struct vio_dev *vdev)
 
                free_netdev(port->dev);
        }
-
-       return 0;
 }
 
 static void vsw_cleanup(void)
index 96b883f..58ee892 100644 (file)
@@ -510,7 +510,7 @@ err_out_put_mdesc:
        return err;
 }
 
-static int vnet_port_remove(struct vio_dev *vdev)
+static void vnet_port_remove(struct vio_dev *vdev)
 {
        struct vnet_port *port = dev_get_drvdata(&vdev->dev);
 
@@ -533,7 +533,6 @@ static int vnet_port_remove(struct vio_dev *vdev)
 
                kfree(port);
        }
-       return 0;
 }
 
 static const struct vio_device_id vnet_port_match[] = {
index 0a3a71e..0c9b291 100644 (file)
@@ -668,7 +668,7 @@ free_port:
  *
  * Return: status of removal
  */
-static int vcc_remove(struct vio_dev *vdev)
+static void vcc_remove(struct vio_dev *vdev)
 {
        struct vcc_port *port = dev_get_drvdata(&vdev->dev);
 
@@ -703,8 +703,6 @@ static int vcc_remove(struct vio_dev *vdev)
                kfree(port->domain);
                kfree(port);
        }
-
-       return 0;
 }
 
 static const struct vio_device_id vcc_match[] = {