Put the mdiodev after lynx_pcs_create() so that the Lynx PCS driver
can manage the lifetime of the mdiodev its using.
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
        }
 
        mac->pcs = lynx_pcs_create(mdiodev);
+       mdio_device_put(mdiodev);
        if (!mac->pcs) {
                netdev_err(mac->net_dev, "lynx_pcs_create() failed\n");
-               mdio_device_free(mdiodev);
                return -ENOMEM;
        }
 
        struct phylink_pcs *phylink_pcs = mac->pcs;
 
        if (phylink_pcs) {
-               struct mdio_device *mdio = lynx_get_mdio_device(phylink_pcs);
-
                lynx_pcs_destroy(phylink_pcs);
-               mdio_device_free(mdio);
                mac->pcs = NULL;
        }
 }