+Karthik/Ashok

On 3/12/21 2:35 PM, Bin Meng wrote:
> Following the same updates that were done to the fixed phy driver,
> use ofnode_ APIs instead of fdt_ APIs so that the Xilinx PHY driver
> can support live DT.
> 
> Signed-off-by: Bin Meng <bmeng...@gmail.com>
> 
> ---
> 
> Changes in v2:
> - move device tree parsing from xilinxgmiitorgmii_probe() to
>   xilinxgmiitorgmii_config() and use OF APIs
> 
>  drivers/net/phy/phy.c               | 23 +++++------
>  drivers/net/phy/xilinx_gmii2rgmii.c | 61 ++++++++++++++---------------
>  2 files changed, 40 insertions(+), 44 deletions(-)
> 
> diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c
> index eae40cc0d6..d464379121 100644
> --- a/drivers/net/phy/phy.c
> +++ b/drivers/net/phy/phy.c
> @@ -953,23 +953,20 @@ static struct phy_device *phy_connect_gmii2rgmii(struct 
> mii_dev *bus,
>  #endif
>  {
>       struct phy_device *phydev = NULL;
> -     int sn = dev_of_offset(dev);
> -     int off;
> -
> -     while (sn > 0) {
> -             off = fdt_node_offset_by_compatible(gd->fdt_blob, sn,
> -                                                 "xlnx,gmii-to-rgmii-1.0");
> -             if (off > 0) {
> -                     phydev = phy_device_create(bus, off,
> +     ofnode node = dev_ofnode(dev);
> +
> +     while (ofnode_valid(node)) {
> +             node = ofnode_by_compatible(node, "xlnx,gmii-to-rgmii-1.0");
> +             if (ofnode_valid(node)) {
> +                     phydev = phy_device_create(bus, 0,
>                                                  PHY_GMII2RGMII_ID, false,
>                                                  interface);
> +                     if (phydev)
> +                             phydev->node = node;
>                       break;
>               }
> -             if (off == -FDT_ERR_NOTFOUND)
> -                     sn = fdt_first_subnode(gd->fdt_blob, sn);
> -             else
> -                     printf("%s: Error finding compat string:%d\n",
> -                            __func__, off);
> +
> +             node = ofnode_first_subnode(node);
>       }
>  
>       return phydev;
> diff --git a/drivers/net/phy/xilinx_gmii2rgmii.c 
> b/drivers/net/phy/xilinx_gmii2rgmii.c
> index 74105c0b7d..635c0570ef 100644
> --- a/drivers/net/phy/xilinx_gmii2rgmii.c
> +++ b/drivers/net/phy/xilinx_gmii2rgmii.c
> @@ -18,9 +18,38 @@ DECLARE_GLOBAL_DATA_PTR;
>  
>  static int xilinxgmiitorgmii_config(struct phy_device *phydev)
>  {
> -     struct phy_device *ext_phydev = phydev->priv;
> +     ofnode node = phy_get_ofnode(phydev);
> +     struct phy_device *ext_phydev;
> +     struct ofnode_phandle_args phandle;
> +     int ext_phyaddr = -1;
> +     int ret;
>  
>       debug("%s\n", __func__);
> +
> +     if (!ofnode_valid(node))
> +             return -EINVAL;
> +
> +     phydev->addr = ofnode_read_u32_default(node, "reg", -1);
> +     ret = ofnode_parse_phandle_with_args(node, "phy-handle",
> +                                          NULL, 0, 0, &phandle);
> +     if (ret)
> +             return ret;
> +
> +     ext_phyaddr = ofnode_read_u32_default(phandle.node, "reg", -1);
> +     ext_phydev = phy_find_by_mask(phydev->bus,
> +                                   1 << ext_phyaddr,
> +                                   PHY_INTERFACE_MODE_RGMII);
> +     if (!ext_phydev) {
> +             printf("%s, No external phy device found\n", __func__);
> +             return -EINVAL;
> +     }
> +
> +     ext_phydev->node = phandle.node;
> +     phydev->priv = ext_phydev;
> +
> +     debug("%s, gmii2rgmmi:0x%x, extphy:0x%x\n", __func__, phydev->addr,
> +           ext_phyaddr);
> +
>       if (ext_phydev->drv->config)
>               ext_phydev->drv->config(ext_phydev);
>  
> @@ -83,11 +112,6 @@ static int xilinxgmiitorgmii_startup(struct phy_device 
> *phydev)
>  
>  static int xilinxgmiitorgmii_probe(struct phy_device *phydev)
>  {
> -     int ofnode = phydev->addr;
> -     u32 phy_of_handle;
> -     int ext_phyaddr = -1;
> -     struct phy_device *ext_phydev;
> -
>       debug("%s\n", __func__);
>  
>       if (phydev->interface != PHY_INTERFACE_MODE_GMII) {
> @@ -95,31 +119,6 @@ static int xilinxgmiitorgmii_probe(struct phy_device 
> *phydev)
>               return -EINVAL;
>       }
>  
> -     /*
> -      * Read the phy address again as the one we read in ethernet driver
> -      * was overwritten for the purpose of storing the ofnode
> -      */
> -     phydev->addr = fdtdec_get_int(gd->fdt_blob, ofnode, "reg", -1);
> -     phy_of_handle = fdtdec_lookup_phandle(gd->fdt_blob, ofnode,
> -                                           "phy-handle");
> -     if (phy_of_handle > 0)
> -             ext_phyaddr = fdtdec_get_int(gd->fdt_blob,
> -                                          phy_of_handle,
> -                                          "reg", -1);
> -     ext_phydev = phy_find_by_mask(phydev->bus,
> -                                   1 << ext_phyaddr,
> -                                   PHY_INTERFACE_MODE_RGMII);
> -     if (!ext_phydev) {
> -             printf("%s, No external phy device found\n", __func__);
> -             return -EINVAL;
> -     }
> -
> -     ext_phydev->node = offset_to_ofnode(phy_of_handle);
> -     phydev->priv = ext_phydev;
> -
> -     debug("%s, gmii2rgmmi:0x%x, extphy:0x%x\n", __func__, phydev->addr,
> -           ext_phyaddr);
> -
>       phydev->flags |= PHY_FLAG_BROKEN_RESET;
>  
>       return 0;
> 

Karthik/Ashok: Please retest it.

Thanks,
Michal

Reply via email to