On 12/06/15 10:18, Andrew Lunn wrote:
> By default, DSA and CPU ports are configured to the maximum speed the
> switch supports. However there can be use cases where the peer device
> port is slower. Allow a fixed-link property to be used with the DSA
> and CPU port in the device tree, and use this information to configure
> the port.
> 
> Signed-off-by: Andrew Lunn <and...@lunn.ch>
> ---
>  include/net/dsa.h |  1 +
>  net/dsa/dsa.c     | 39 +++++++++++++++++++++++++++++++++++++++
>  2 files changed, 40 insertions(+)
> 
> diff --git a/include/net/dsa.h b/include/net/dsa.h
> index fbca63ba8f73..24572f99224c 100644
> --- a/include/net/dsa.h
> +++ b/include/net/dsa.h
> @@ -160,6 +160,7 @@ struct dsa_switch {
>        * Slave mii_bus and devices for the individual ports.
>        */
>       u32                     dsa_port_mask;
> +     u32                     cpu_port_mask;
>       u32                     phys_port_mask;
>       u32                     phys_mii_mask;
>       struct mii_bus          *slave_mii_bus;
> diff --git a/net/dsa/dsa.c b/net/dsa/dsa.c
> index 392e29a0227d..f9c8f4e7ebce 100644
> --- a/net/dsa/dsa.c
> +++ b/net/dsa/dsa.c
> @@ -176,6 +176,36 @@ __ATTRIBUTE_GROUPS(dsa_hwmon);
>  #endif /* CONFIG_NET_DSA_HWMON */
>  
>  /* basic switch operations 
> **************************************************/
> +static int dsa_cpu_dsa_setup(struct dsa_switch *ds, struct net_device 
> *master)
> +{
> +     struct dsa_chip_data *cd = ds->pd;
> +     struct device_node *port_dn;
> +     struct phy_device *phydev;
> +     int ret, port;
> +
> +     for (port = 0; port < DSA_MAX_PORTS; port++) {
> +             if (!((ds->cpu_port_mask | ds->dsa_port_mask) & (1 << port)))
> +                     continue;
> +
> +             port_dn = cd->port_dn[port];
> +             if (of_phy_is_fixed_link(port_dn)) {
> +                     ret = of_phy_register_fixed_link(port_dn);
> +                     if (ret) {
> +                             netdev_err(master,
> +                                        "failed to register fixed PHY\n");
> +                             return ret;
> +                     }
> +                     phydev = of_phy_find_device(port_dn);
> +                     phydev->is_pseudo_fixed_link = true;

I suppose this could be automatically set by the Generic PHY driver once
we bind it to the fixed MDIO bus implementation instead of having driver
have to do this, what do you think?
-- 
Florian
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to