Commit bce49343 authored by Jakub Kicinski's avatar Jakub Kicinski

Merge branch 'net-convert-to-platform-remove-callback-returning-void'

Uwe Kleine-König says:

====================
net*: Convert to platform remove callback returning void

(implicit) v1 of this series can be found at
https://lore.kernel.org/netdev/20231117095922.876489-1-u.kleine-koenig@pengutronix.de.

Changes since then:

 - Dropped patch #1 as Alex objected. Patch #1 (was #2 before) now
   converts ipa to remove_new() and introduces an error message in the
   error path that failed before.
====================

Link: https://lore.kernel.org/r/cover.1701713943.git.u.kleine-koenig@pengutronix.deSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parents 2ff46b9e a06041e2
...@@ -1438,7 +1438,7 @@ static int fjes_probe(struct platform_device *plat_dev) ...@@ -1438,7 +1438,7 @@ static int fjes_probe(struct platform_device *plat_dev)
} }
/* fjes_remove - Device Removal Routine */ /* fjes_remove - Device Removal Routine */
static int fjes_remove(struct platform_device *plat_dev) static void fjes_remove(struct platform_device *plat_dev)
{ {
struct net_device *netdev = dev_get_drvdata(&plat_dev->dev); struct net_device *netdev = dev_get_drvdata(&plat_dev->dev);
struct fjes_adapter *adapter = netdev_priv(netdev); struct fjes_adapter *adapter = netdev_priv(netdev);
...@@ -1462,8 +1462,6 @@ static int fjes_remove(struct platform_device *plat_dev) ...@@ -1462,8 +1462,6 @@ static int fjes_remove(struct platform_device *plat_dev)
netif_napi_del(&adapter->napi); netif_napi_del(&adapter->napi);
free_netdev(netdev); free_netdev(netdev);
return 0;
} }
static struct platform_driver fjes_driver = { static struct platform_driver fjes_driver = {
...@@ -1471,7 +1469,7 @@ static struct platform_driver fjes_driver = { ...@@ -1471,7 +1469,7 @@ static struct platform_driver fjes_driver = {
.name = DRV_NAME, .name = DRV_NAME,
}, },
.probe = fjes_probe, .probe = fjes_probe,
.remove = fjes_remove, .remove_new = fjes_remove,
}; };
static acpi_status static acpi_status
......
...@@ -943,7 +943,7 @@ static int ipa_probe(struct platform_device *pdev) ...@@ -943,7 +943,7 @@ static int ipa_probe(struct platform_device *pdev)
return ret; return ret;
} }
static int ipa_remove(struct platform_device *pdev) static void ipa_remove(struct platform_device *pdev)
{ {
struct ipa *ipa = dev_get_drvdata(&pdev->dev); struct ipa *ipa = dev_get_drvdata(&pdev->dev);
struct ipa_power *power = ipa->power; struct ipa_power *power = ipa->power;
...@@ -966,8 +966,16 @@ static int ipa_remove(struct platform_device *pdev) ...@@ -966,8 +966,16 @@ static int ipa_remove(struct platform_device *pdev)
usleep_range(USEC_PER_MSEC, 2 * USEC_PER_MSEC); usleep_range(USEC_PER_MSEC, 2 * USEC_PER_MSEC);
ret = ipa_modem_stop(ipa); ret = ipa_modem_stop(ipa);
} }
if (ret) if (ret) {
return ret; /*
* Not cleaning up here properly might also yield a
* crash later on. As the device is still unregistered
* in this case, this might even yield a crash later on.
*/
dev_err(dev, "Failed to stop modem (%pe), leaking resources\n",
ERR_PTR(ret));
return;
}
ipa_teardown(ipa); ipa_teardown(ipa);
} }
...@@ -985,17 +993,6 @@ static int ipa_remove(struct platform_device *pdev) ...@@ -985,17 +993,6 @@ static int ipa_remove(struct platform_device *pdev)
ipa_power_exit(power); ipa_power_exit(power);
dev_info(dev, "IPA driver removed"); dev_info(dev, "IPA driver removed");
return 0;
}
static void ipa_shutdown(struct platform_device *pdev)
{
int ret;
ret = ipa_remove(pdev);
if (ret)
dev_err(&pdev->dev, "shutdown: remove returned %d\n", ret);
} }
static const struct attribute_group *ipa_attribute_groups[] = { static const struct attribute_group *ipa_attribute_groups[] = {
...@@ -1008,8 +1005,8 @@ static const struct attribute_group *ipa_attribute_groups[] = { ...@@ -1008,8 +1005,8 @@ static const struct attribute_group *ipa_attribute_groups[] = {
static struct platform_driver ipa_driver = { static struct platform_driver ipa_driver = {
.probe = ipa_probe, .probe = ipa_probe,
.remove = ipa_remove, .remove_new = ipa_remove,
.shutdown = ipa_shutdown, .shutdown = ipa_remove,
.driver = { .driver = {
.name = "ipa", .name = "ipa",
.pm = &ipa_pm_ops, .pm = &ipa_pm_ops,
......
...@@ -505,11 +505,9 @@ static int miic_probe(struct platform_device *pdev) ...@@ -505,11 +505,9 @@ static int miic_probe(struct platform_device *pdev)
return ret; return ret;
} }
static int miic_remove(struct platform_device *pdev) static void miic_remove(struct platform_device *pdev)
{ {
pm_runtime_put(&pdev->dev); pm_runtime_put(&pdev->dev);
return 0;
} }
static const struct of_device_id miic_of_mtable[] = { static const struct of_device_id miic_of_mtable[] = {
...@@ -525,7 +523,7 @@ static struct platform_driver miic_driver = { ...@@ -525,7 +523,7 @@ static struct platform_driver miic_driver = {
.of_match_table = miic_of_mtable, .of_match_table = miic_of_mtable,
}, },
.probe = miic_probe, .probe = miic_probe,
.remove = miic_remove, .remove_new = miic_remove,
}; };
module_platform_driver(miic_driver); module_platform_driver(miic_driver);
......
...@@ -3097,7 +3097,7 @@ static int sfp_probe(struct platform_device *pdev) ...@@ -3097,7 +3097,7 @@ static int sfp_probe(struct platform_device *pdev)
return 0; return 0;
} }
static int sfp_remove(struct platform_device *pdev) static void sfp_remove(struct platform_device *pdev)
{ {
struct sfp *sfp = platform_get_drvdata(pdev); struct sfp *sfp = platform_get_drvdata(pdev);
...@@ -3107,8 +3107,6 @@ static int sfp_remove(struct platform_device *pdev) ...@@ -3107,8 +3107,6 @@ static int sfp_remove(struct platform_device *pdev)
rtnl_lock(); rtnl_lock();
sfp_sm_event(sfp, SFP_E_REMOVE); sfp_sm_event(sfp, SFP_E_REMOVE);
rtnl_unlock(); rtnl_unlock();
return 0;
} }
static void sfp_shutdown(struct platform_device *pdev) static void sfp_shutdown(struct platform_device *pdev)
...@@ -3129,7 +3127,7 @@ static void sfp_shutdown(struct platform_device *pdev) ...@@ -3129,7 +3127,7 @@ static void sfp_shutdown(struct platform_device *pdev)
static struct platform_driver sfp_driver = { static struct platform_driver sfp_driver = {
.probe = sfp_probe, .probe = sfp_probe,
.remove = sfp_remove, .remove_new = sfp_remove,
.shutdown = sfp_shutdown, .shutdown = sfp_shutdown,
.driver = { .driver = {
.name = "sfp", .name = "sfp",
......
...@@ -1259,7 +1259,7 @@ static int ucc_hdlc_probe(struct platform_device *pdev) ...@@ -1259,7 +1259,7 @@ static int ucc_hdlc_probe(struct platform_device *pdev)
return ret; return ret;
} }
static int ucc_hdlc_remove(struct platform_device *pdev) static void ucc_hdlc_remove(struct platform_device *pdev)
{ {
struct ucc_hdlc_private *priv = dev_get_drvdata(&pdev->dev); struct ucc_hdlc_private *priv = dev_get_drvdata(&pdev->dev);
...@@ -1277,8 +1277,6 @@ static int ucc_hdlc_remove(struct platform_device *pdev) ...@@ -1277,8 +1277,6 @@ static int ucc_hdlc_remove(struct platform_device *pdev)
kfree(priv); kfree(priv);
dev_info(&pdev->dev, "UCC based hdlc module removed\n"); dev_info(&pdev->dev, "UCC based hdlc module removed\n");
return 0;
} }
static const struct of_device_id fsl_ucc_hdlc_of_match[] = { static const struct of_device_id fsl_ucc_hdlc_of_match[] = {
...@@ -1292,7 +1290,7 @@ MODULE_DEVICE_TABLE(of, fsl_ucc_hdlc_of_match); ...@@ -1292,7 +1290,7 @@ MODULE_DEVICE_TABLE(of, fsl_ucc_hdlc_of_match);
static struct platform_driver ucc_hdlc_driver = { static struct platform_driver ucc_hdlc_driver = {
.probe = ucc_hdlc_probe, .probe = ucc_hdlc_probe,
.remove = ucc_hdlc_remove, .remove_new = ucc_hdlc_remove,
.driver = { .driver = {
.name = DRV_NAME, .name = DRV_NAME,
.pm = HDLC_PM_OPS, .pm = HDLC_PM_OPS,
......
...@@ -1522,20 +1522,19 @@ static int ixp4xx_hss_probe(struct platform_device *pdev) ...@@ -1522,20 +1522,19 @@ static int ixp4xx_hss_probe(struct platform_device *pdev)
return err; return err;
} }
static int ixp4xx_hss_remove(struct platform_device *pdev) static void ixp4xx_hss_remove(struct platform_device *pdev)
{ {
struct port *port = platform_get_drvdata(pdev); struct port *port = platform_get_drvdata(pdev);
unregister_hdlc_device(port->netdev); unregister_hdlc_device(port->netdev);
free_netdev(port->netdev); free_netdev(port->netdev);
npe_release(port->npe); npe_release(port->npe);
return 0;
} }
static struct platform_driver ixp4xx_hss_driver = { static struct platform_driver ixp4xx_hss_driver = {
.driver.name = DRV_NAME, .driver.name = DRV_NAME,
.probe = ixp4xx_hss_probe, .probe = ixp4xx_hss_probe,
.remove = ixp4xx_hss_remove, .remove_new = ixp4xx_hss_remove,
}; };
module_platform_driver(ixp4xx_hss_driver); module_platform_driver(ixp4xx_hss_driver);
......
...@@ -846,7 +846,7 @@ static int bam_dmux_probe(struct platform_device *pdev) ...@@ -846,7 +846,7 @@ static int bam_dmux_probe(struct platform_device *pdev)
return 0; return 0;
} }
static int bam_dmux_remove(struct platform_device *pdev) static void bam_dmux_remove(struct platform_device *pdev)
{ {
struct bam_dmux *dmux = platform_get_drvdata(pdev); struct bam_dmux *dmux = platform_get_drvdata(pdev);
struct device *dev = dmux->dev; struct device *dev = dmux->dev;
...@@ -877,8 +877,6 @@ static int bam_dmux_remove(struct platform_device *pdev) ...@@ -877,8 +877,6 @@ static int bam_dmux_remove(struct platform_device *pdev)
disable_irq(dmux->pc_irq); disable_irq(dmux->pc_irq);
bam_dmux_power_off(dmux); bam_dmux_power_off(dmux);
bam_dmux_free_skbs(dmux->tx_skbs, DMA_TO_DEVICE); bam_dmux_free_skbs(dmux->tx_skbs, DMA_TO_DEVICE);
return 0;
} }
static const struct dev_pm_ops bam_dmux_pm_ops = { static const struct dev_pm_ops bam_dmux_pm_ops = {
...@@ -893,7 +891,7 @@ MODULE_DEVICE_TABLE(of, bam_dmux_of_match); ...@@ -893,7 +891,7 @@ MODULE_DEVICE_TABLE(of, bam_dmux_of_match);
static struct platform_driver bam_dmux_driver = { static struct platform_driver bam_dmux_driver = {
.probe = bam_dmux_probe, .probe = bam_dmux_probe,
.remove = bam_dmux_remove, .remove_new = bam_dmux_remove,
.driver = { .driver = {
.name = "bam-dmux", .name = "bam-dmux",
.pm = &bam_dmux_pm_ops, .pm = &bam_dmux_pm_ops,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment