linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [net v3 0/1] net: ethernet: adi: adin1110: Fix notifiers
@ 2022-10-25  7:52 Alexandru Tachici
  2022-10-25  7:52 ` [net v3 1/1] " Alexandru Tachici
  0 siblings, 1 reply; 3+ messages in thread
From: Alexandru Tachici @ 2022-10-25  7:52 UTC (permalink / raw)
  To: linux-kernel
  Cc: andrew, linux, davem, edumazet, kuba, pabeni, netdev, lennart

ADIN1110 was registering netdev_notifiers on each device probe.
This leads to warnings/probe failures because of double registration
of the same notifier when to adin1110/2111 devices are connected to
the same system.

Move the registration of netdev_notifiers in module init call,
in this way multiple driver instances can use the same notifiers.


Alexandru Tachici (1):
  net: ethernet: adi: adin1110: Fix notifiers

Changelog v2 -> v3:
  - moved spi_driver registration after nofiers registration in order to avoid
  a small window where events could be lost

 drivers/net/ethernet/adi/adin1110.c | 32 +++++++++++++++++++++--------
 1 file changed, 23 insertions(+), 9 deletions(-)

-- 
2.34.1


^ permalink raw reply	[flat|nested] 3+ messages in thread

* [net v3 1/1] net: ethernet: adi: adin1110: Fix notifiers
  2022-10-25  7:52 [net v3 0/1] net: ethernet: adi: adin1110: Fix notifiers Alexandru Tachici
@ 2022-10-25  7:52 ` Alexandru Tachici
  2022-10-27  3:40   ` Jakub Kicinski
  0 siblings, 1 reply; 3+ messages in thread
From: Alexandru Tachici @ 2022-10-25  7:52 UTC (permalink / raw)
  To: linux-kernel
  Cc: andrew, linux, davem, edumazet, kuba, pabeni, netdev, lennart

ADIN1110 was registering netdev_notifiers on each device probe.
This leads to warnings/probe failures because of double registration
of the same notifier when to adin1110/2111 devices are connected to
the same system.

Move the registration of netdev_notifiers in module init call,
in this way multiple driver instances can use the same notifiers.

Fixes: bc93e19d088b ("net: ethernet: adi: Add ADIN1110 support")
Signed-off-by: Alexandru Tachici <alexandru.tachici@analog.com>
---
 drivers/net/ethernet/adi/adin1110.c | 32 +++++++++++++++++++++--------
 1 file changed, 23 insertions(+), 9 deletions(-)

diff --git a/drivers/net/ethernet/adi/adin1110.c b/drivers/net/ethernet/adi/adin1110.c
index 086aa9c96b31..73c08a523780 100644
--- a/drivers/net/ethernet/adi/adin1110.c
+++ b/drivers/net/ethernet/adi/adin1110.c
@@ -1507,16 +1507,15 @@ static struct notifier_block adin1110_switchdev_notifier = {
 	.notifier_call = adin1110_switchdev_event,
 };
 
-static void adin1110_unregister_notifiers(void *data)
+static void adin1110_unregister_notifiers(void)
 {
 	unregister_switchdev_blocking_notifier(&adin1110_switchdev_blocking_notifier);
 	unregister_switchdev_notifier(&adin1110_switchdev_notifier);
 	unregister_netdevice_notifier(&adin1110_netdevice_nb);
 }
 
-static int adin1110_setup_notifiers(struct adin1110_priv *priv)
+static int adin1110_setup_notifiers(void)
 {
-	struct device *dev = &priv->spidev->dev;
 	int ret;
 
 	ret = register_netdevice_notifier(&adin1110_netdevice_nb);
@@ -1531,13 +1530,14 @@ static int adin1110_setup_notifiers(struct adin1110_priv *priv)
 	if (ret < 0)
 		goto err_sdev;
 
-	return devm_add_action_or_reset(dev, adin1110_unregister_notifiers, NULL);
+	return 0;
 
 err_sdev:
 	unregister_switchdev_notifier(&adin1110_switchdev_notifier);
 
 err_netdev:
 	unregister_netdevice_notifier(&adin1110_netdevice_nb);
+
 	return ret;
 }
 
@@ -1608,10 +1608,6 @@ static int adin1110_probe_netdevs(struct adin1110_priv *priv)
 	if (ret < 0)
 		return ret;
 
-	ret = adin1110_setup_notifiers(priv);
-	if (ret < 0)
-		return ret;
-
 	for (i = 0; i < priv->cfg->ports_nr; i++) {
 		ret = devm_register_netdev(dev, priv->ports[i]->netdev);
 		if (ret < 0) {
@@ -1688,7 +1684,25 @@ static struct spi_driver adin1110_driver = {
 	.probe = adin1110_probe,
 	.id_table = adin1110_spi_id,
 };
-module_spi_driver(adin1110_driver);
+
+static int __init adin1110_driver_init(void)
+{
+	int err;
+
+	err = adin1110_setup_notifiers();
+	if (err)
+		return err;
+
+	return spi_register_driver(&adin1110_driver);
+}
+
+static void __exit adin1110_exit(void)
+{
+	adin1110_unregister_notifiers();
+	spi_unregister_driver(&adin1110_driver);
+}
+module_init(adin1110_driver_init);
+module_exit(adin1110_exit);
 
 MODULE_DESCRIPTION("ADIN1110 Network driver");
 MODULE_AUTHOR("Alexandru Tachici <alexandru.tachici@analog.com>");
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [net v3 1/1] net: ethernet: adi: adin1110: Fix notifiers
  2022-10-25  7:52 ` [net v3 1/1] " Alexandru Tachici
@ 2022-10-27  3:40   ` Jakub Kicinski
  0 siblings, 0 replies; 3+ messages in thread
From: Jakub Kicinski @ 2022-10-27  3:40 UTC (permalink / raw)
  To: Alexandru Tachici
  Cc: linux-kernel, andrew, linux, davem, edumazet, pabeni, netdev, lennart

On Tue, 25 Oct 2022 10:52:27 +0300 Alexandru Tachici wrote:
> +	int err;
> +
> +	err = adin1110_setup_notifiers();
> +	if (err)
> +		return err;
> +
> +	return spi_register_driver(&adin1110_driver);

What unregisters the notifies if spi_register_driver()
fails, now?

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2022-10-27  3:40 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-10-25  7:52 [net v3 0/1] net: ethernet: adi: adin1110: Fix notifiers Alexandru Tachici
2022-10-25  7:52 ` [net v3 1/1] " Alexandru Tachici
2022-10-27  3:40   ` Jakub Kicinski

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).