[next 1/5] net: ftgmac100: Add DM_MDIO support

Ramon Fried rfried.dev at gmail.com
Sat Dec 11 00:08:50 CET 2021


On Thu, Dec 9, 2021 at 4:12 AM Dylan Hung <dylan_hung at aspeedtech.com> wrote:
>
> Add support for DM_MDIO to connect to PHY.  For the systems that have a
> stand-alone MDIO hardware block, enable CONFIG_DM_MDIO to use driver
> model for MDIO devices.
>
> Signed-off-by: Dylan Hung <dylan_hung at aspeedtech.com>
> ---
>  drivers/net/ftgmac100.c | 20 +++++++++++++++-----
>  1 file changed, 15 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/net/ftgmac100.c b/drivers/net/ftgmac100.c
> index 0687230b4bb4..b6e9526c3b9f 100644
> --- a/drivers/net/ftgmac100.c
> +++ b/drivers/net/ftgmac100.c
> @@ -220,7 +220,11 @@ static int ftgmac100_phy_init(struct udevice *dev)
>         struct phy_device *phydev;
>         int ret;
>
> -       phydev = phy_connect(priv->bus, priv->phy_addr, dev, priv->phy_mode);
> +       if (IS_ENABLED(CONFIG_DM_MDIO))
> +               phydev = dm_eth_phy_connect(dev);
> +       else
> +               phydev = phy_connect(priv->bus, priv->phy_addr, dev, priv->phy_mode);
> +
>         if (!phydev)
>                 return -ENODEV;
>
> @@ -589,10 +593,16 @@ static int ftgmac100_probe(struct udevice *dev)
>         if (ret)
>                 goto out;
>
> -       ret = ftgmac100_mdio_init(dev);
> -       if (ret) {
> -               dev_err(dev, "Failed to initialize mdiobus: %d\n", ret);
> -               goto out;
> +       /*
> +        * If DM MDIO is enabled, the MDIO bus will be initialized later in
> +        * dm_eth_phy_connect
> +        */
> +       if (!IS_ENABLED(CONFIG_DM_MDIO)) {
> +               ret = ftgmac100_mdio_init(dev);
> +               if (ret) {
> +                       dev_err(dev, "Failed to initialize mdiobus: %d\n", ret);
> +                       goto out;
> +               }
>         }
>
>         ret = ftgmac100_phy_init(dev);
> --
> 2.25.1
>
Reviewed-by: Ramon Fried <rfried.dev at gmail.com>


More information about the U-Boot mailing list