Commit 67d78e7f authored by Leon Romanovsky's avatar Leon Romanovsky Committed by David S. Miller

net: mscc: ocelot: delay devlink registration to the end

Open access to the devlink interface when the driver fully initialized.
Signed-off-by: default avatarLeon Romanovsky <leonro@nvidia.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent b2ab483f
...@@ -1134,7 +1134,6 @@ static int mscc_ocelot_probe(struct platform_device *pdev) ...@@ -1134,7 +1134,6 @@ static int mscc_ocelot_probe(struct platform_device *pdev)
if (err) if (err)
goto out_put_ports; goto out_put_ports;
devlink_register(devlink);
err = mscc_ocelot_init_ports(pdev, ports); err = mscc_ocelot_init_ports(pdev, ports);
if (err) if (err)
goto out_ocelot_devlink_unregister; goto out_ocelot_devlink_unregister;
...@@ -1157,6 +1156,7 @@ static int mscc_ocelot_probe(struct platform_device *pdev) ...@@ -1157,6 +1156,7 @@ static int mscc_ocelot_probe(struct platform_device *pdev)
register_switchdev_blocking_notifier(&ocelot_switchdev_blocking_nb); register_switchdev_blocking_notifier(&ocelot_switchdev_blocking_nb);
of_node_put(ports); of_node_put(ports);
devlink_register(devlink);
dev_info(&pdev->dev, "Ocelot switch probed\n"); dev_info(&pdev->dev, "Ocelot switch probed\n");
...@@ -1166,7 +1166,6 @@ static int mscc_ocelot_probe(struct platform_device *pdev) ...@@ -1166,7 +1166,6 @@ static int mscc_ocelot_probe(struct platform_device *pdev)
mscc_ocelot_release_ports(ocelot); mscc_ocelot_release_ports(ocelot);
mscc_ocelot_teardown_devlink_ports(ocelot); mscc_ocelot_teardown_devlink_ports(ocelot);
out_ocelot_devlink_unregister: out_ocelot_devlink_unregister:
devlink_unregister(devlink);
ocelot_deinit(ocelot); ocelot_deinit(ocelot);
out_put_ports: out_put_ports:
of_node_put(ports); of_node_put(ports);
...@@ -1179,11 +1178,11 @@ static int mscc_ocelot_remove(struct platform_device *pdev) ...@@ -1179,11 +1178,11 @@ static int mscc_ocelot_remove(struct platform_device *pdev)
{ {
struct ocelot *ocelot = platform_get_drvdata(pdev); struct ocelot *ocelot = platform_get_drvdata(pdev);
devlink_unregister(ocelot->devlink);
ocelot_deinit_timestamp(ocelot); ocelot_deinit_timestamp(ocelot);
ocelot_devlink_sb_unregister(ocelot); ocelot_devlink_sb_unregister(ocelot);
mscc_ocelot_release_ports(ocelot); mscc_ocelot_release_ports(ocelot);
mscc_ocelot_teardown_devlink_ports(ocelot); mscc_ocelot_teardown_devlink_ports(ocelot);
devlink_unregister(ocelot->devlink);
ocelot_deinit(ocelot); ocelot_deinit(ocelot);
unregister_switchdev_blocking_notifier(&ocelot_switchdev_blocking_nb); unregister_switchdev_blocking_notifier(&ocelot_switchdev_blocking_nb);
unregister_switchdev_notifier(&ocelot_switchdev_nb); unregister_switchdev_notifier(&ocelot_switchdev_nb);
......
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