Hi,

On 25/02/2025 13:48, Chintan Vankar wrote:
> CPSW driver is defined as UCLASS_MISC driver which needs to be probed
> explicitly. Define bind method for CPSW driver to scan and bind
> ethernet-ports with UCLASS_ETH driver which will eventually probe CPSW
> driver and avoids probing CPSW driver explicitly.

Thank you for doing this. Overall it looks good. Just some cosmetic changes
suggested below.

> 
> Signed-off-by: Chintan Vankar <c-van...@ti.com>
> ---
> 
> Link to v2:
> https://lore.kernel.org/r/20250219104831.2315464-3-c-van...@ti.com/
> 
> Changes from v2 to v3:
> - Removed if condition not required in CPSW driver as suggested by
>   Alexander Sverdlin.
> 
>  drivers/net/ti/am65-cpsw-nuss.c | 120 ++++++++++++++++++--------------
>  1 file changed, 67 insertions(+), 53 deletions(-)
> 
> diff --git a/drivers/net/ti/am65-cpsw-nuss.c b/drivers/net/ti/am65-cpsw-nuss.c
> index c70b42f6bcc..10513cf92f2 100644
> --- a/drivers/net/ti/am65-cpsw-nuss.c
> +++ b/drivers/net/ti/am65-cpsw-nuss.c
> @@ -667,6 +667,59 @@ static int am65_cpsw_ofdata_parse_phy(struct udevice 
> *dev)
>       return 0;
>  }
>  
> +static int am65_cpsw_probe_nuss(struct udevice *dev)
> +{
> +     struct am65_cpsw_common *cpsw_common = dev_get_priv(dev);
> +     int ret, i;
> +
> +     cpsw_common->dev = dev;
> +     cpsw_common->ss_base = dev_read_addr(dev);
> +     if (cpsw_common->ss_base == FDT_ADDR_T_NONE)
> +             return -EINVAL;
> +
> +     ret = power_domain_get_by_index(dev, &cpsw_common->pwrdmn, 0);
> +     if (ret) {
> +             dev_err(dev, "failed to get pwrdmn: %d\n", ret);
> +             return ret;
> +     }
> +
> +     ret = clk_get_by_name(dev, "fck", &cpsw_common->fclk);
> +     if (ret) {
> +             power_domain_free(&cpsw_common->pwrdmn);
> +             dev_err(dev, "failed to get clock %d\n", ret);
> +             return ret;
> +     }
> +
> +     cpsw_common->cpsw_base = cpsw_common->ss_base + AM65_CPSW_CPSW_NU_BASE;
> +     cpsw_common->ale_base = cpsw_common->cpsw_base +
> +                             AM65_CPSW_CPSW_NU_ALE_BASE;
> +
> +     for (i = 0; i < AM65_CPSW_CPSWNU_MAX_PORTS; i++) {
> +             struct am65_cpsw_port *port = &cpsw_common->ports[i];
> +
> +             port->port_base = cpsw_common->cpsw_base +
> +                               AM65_CPSW_CPSW_NU_PORTS_OFFSET +
> +                               (i * AM65_CPSW_CPSW_NU_PORTS_OFFSET);
> +             port->port_sgmii_base = cpsw_common->ss_base +
> +                                     (i * AM65_CPSW_SGMII_BASE);
> +             port->macsl_base = port->port_base +
> +                                AM65_CPSW_CPSW_NU_PORT_MACSL_OFFSET;
> +     }
> +
> +     cpsw_common->bus_freq =
> +                     dev_read_u32_default(dev, "bus_freq",
> +                                          AM65_CPSW_MDIO_BUS_FREQ_DEF);
> +
> +     dev_info(dev, "K3 CPSW: nuss_ver: 0x%08X cpsw_ver: 0x%08X ale_ver: 
> 0x%08X Ports:%u\n",
> +              readl(cpsw_common->ss_base),
> +              readl(cpsw_common->cpsw_base),
> +              readl(cpsw_common->ale_base),
> +              cpsw_common->port_num);
> +
> +     power_domain_free(&cpsw_common->pwrdmn);
> +     return ret;
> +}
> +

Instead of moving the am65_cpsw_probe_nuss() please leave it where it was
and add the new am65_cpsw_nuss_bind() after it.
This way it will show only what really changed in diff and is easier to review.

>  static int am65_cpsw_port_probe(struct udevice *dev)
>  {
>       struct am65_cpsw_priv *priv = dev_get_priv(dev);
> @@ -697,45 +750,30 @@ out:
>       return ret;
>  }
>  
> -static int am65_cpsw_probe_nuss(struct udevice *dev)
> +static int am65_cpsw_nuss_bind(struct udevice *dev)
>  {
>       struct am65_cpsw_common *cpsw_common = dev_get_priv(dev);
> -     ofnode ports_np, node;
> -     int ret, i;
> +     struct uclass_driver *drv;
>       struct udevice *port_dev;
> +     ofnode ports_np, node;
> +     int ret;
>  
> -     cpsw_common->dev = dev;
> -     cpsw_common->ss_base = dev_read_addr(dev);
> -     if (cpsw_common->ss_base == FDT_ADDR_T_NONE)
> -             return -EINVAL;
> -
> -     ret = power_domain_get_by_index(dev, &cpsw_common->pwrdmn, 0);
> -     if (ret) {
> -             dev_err(dev, "failed to get pwrdmn: %d\n", ret);
> -             return ret;
> -     }
> -
> -     ret = clk_get_by_name(dev, "fck", &cpsw_common->fclk);
> -     if (ret) {
> -             power_domain_free(&cpsw_common->pwrdmn);
> -             dev_err(dev, "failed to get clock %d\n", ret);
> -             return ret;
> +     drv = lists_uclass_lookup(UCLASS_ETH);
> +     if (!drv) {
> +             puts("Cannot find eth driver");
> +             return -ENOENT;

I'm not sure why this check is required.
drv is not used anywhere.

>       }
>  
> -     cpsw_common->cpsw_base = cpsw_common->ss_base + AM65_CPSW_CPSW_NU_BASE;
> -     cpsw_common->ale_base = cpsw_common->cpsw_base +
> -                             AM65_CPSW_CPSW_NU_ALE_BASE;
> -
> +     cpsw_common->dev = dev;
>       ports_np = dev_read_subnode(dev, "ethernet-ports");
>       if (!ofnode_valid(ports_np)) {
> -             ret = -ENOENT;
> -             goto out;
> +             return -ENOENT;
>       }
>  
>       ofnode_for_each_subnode(node, ports_np) {
>               const char *node_name;
> -             u32 port_id;
>               bool disabled;
> +             u32 port_id;
>  
>               node_name = ofnode_get_name(node);
>  
> @@ -745,14 +783,13 @@ static int am65_cpsw_probe_nuss(struct udevice *dev)
>               if (ret) {
>                       dev_err(dev, "%s: failed to get port_id (%d)\n",
>                               node_name, ret);
> -                     goto out;
> +                     return ret;
>               }
>  
>               if (port_id >= AM65_CPSW_CPSWNU_MAX_PORTS) {
>                       dev_err(dev, "%s: invalid port_id (%d)\n",
>                               node_name, port_id);
> -                     ret = -EINVAL;
> -                     goto out;
> +                     return -EINVAL;
>               }
>               cpsw_common->port_num++;
>  
> @@ -768,30 +805,6 @@ static int am65_cpsw_probe_nuss(struct udevice *dev)
>                       dev_err(dev, "Failed to bind to %s node\n", 
> ofnode_get_name(node));
>       }
>  
> -     for (i = 0; i < AM65_CPSW_CPSWNU_MAX_PORTS; i++) {
> -             struct am65_cpsw_port *port = &cpsw_common->ports[i];
> -
> -             port->port_base = cpsw_common->cpsw_base +
> -                               AM65_CPSW_CPSW_NU_PORTS_OFFSET +
> -                               (i * AM65_CPSW_CPSW_NU_PORTS_OFFSET);
> -             port->port_sgmii_base = cpsw_common->ss_base +
> -                                     (i * AM65_CPSW_SGMII_BASE);
> -             port->macsl_base = port->port_base +
> -                                AM65_CPSW_CPSW_NU_PORT_MACSL_OFFSET;
> -     }
> -
> -     cpsw_common->bus_freq =
> -                     dev_read_u32_default(dev, "bus_freq",
> -                                          AM65_CPSW_MDIO_BUS_FREQ_DEF);
> -
> -     dev_info(dev, "K3 CPSW: nuss_ver: 0x%08X cpsw_ver: 0x%08X ale_ver: 
> 0x%08X Ports:%u\n",
> -              readl(cpsw_common->ss_base),
> -              readl(cpsw_common->cpsw_base),
> -              readl(cpsw_common->ale_base),
> -              cpsw_common->port_num);
> -
> -out:
> -     power_domain_free(&cpsw_common->pwrdmn);
>       return ret;
>  }
>  
> @@ -806,6 +819,7 @@ U_BOOT_DRIVER(am65_cpsw_nuss) = {
>       .name   = "am65_cpsw_nuss",
>       .id     = UCLASS_MISC,
>       .of_match = am65_cpsw_nuss_ids,
> +     .bind   = am65_cpsw_nuss_bind,
>       .probe  = am65_cpsw_probe_nuss,
>       .priv_auto = sizeof(struct am65_cpsw_common),
>  };

-- 
cheers,
-roger

Reply via email to