Commit 18f1296f authored by Ioana Ciornei's avatar Ioana Ciornei Committed by Greg Kroah-Hartman

staging: fsl-dpaa2/ethsw: register_netdev only when ready

The register_netdev() call should be made only when ready to process any
user request on the interface. Move the call to be the last one issued
in the probe sequence.
Reported-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarIoana Ciornei <ioana.ciornei@nxp.com>
Link: https://lore.kernel.org/r/1565700187-16048-10-git-send-email-ioana.ciornei@nxp.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 38fc2136
...@@ -1588,23 +1588,21 @@ static int ethsw_probe_port(struct ethsw_core *ethsw, u16 port_idx) ...@@ -1588,23 +1588,21 @@ static int ethsw_probe_port(struct ethsw_core *ethsw, u16 port_idx)
port_netdev->min_mtu = ETH_MIN_MTU; port_netdev->min_mtu = ETH_MIN_MTU;
port_netdev->max_mtu = ETHSW_MAX_FRAME_LENGTH; port_netdev->max_mtu = ETHSW_MAX_FRAME_LENGTH;
err = ethsw_port_init(port_priv, port_idx);
if (err)
goto err_port_probe;
err = register_netdev(port_netdev); err = register_netdev(port_netdev);
if (err < 0) { if (err < 0) {
dev_err(dev, "register_netdev error %d\n", err); dev_err(dev, "register_netdev error %d\n", err);
goto err_register_netdev; goto err_port_probe;
} }
ethsw->ports[port_idx] = port_priv; ethsw->ports[port_idx] = port_priv;
err = ethsw_port_init(port_priv, port_idx);
if (err)
goto err_ethsw_port_init;
return 0; return 0;
err_ethsw_port_init: err_port_probe:
unregister_netdev(port_netdev);
err_register_netdev:
free_netdev(port_netdev); free_netdev(port_netdev);
return err; return err;
......
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