Message ID | 20210927234825.823582-4-vladimir.oltean@nxp.com |
---|---|
State | Superseded |
Delegated to: | Priyanka Jain |
Headers | show |
Series | Support the SJA1105 DSA switch on the NXP LS1021A-TSN board | expand |
On Tue, Sep 28, 2021 at 2:48 AM Vladimir Oltean <vladimir.oltean@nxp.com> wrote: > > In the current DSA switch driver API, only the udevice of the switch > (belonging to UCLASS_DSA) is exposed, as well as an "int port" argument. > So drivers do not have access to the udevice of individual ports > (belonging to UCLASS_ETH), one of the reasons being that not all ports > have an associated UCLASS_ETH udevice. > > However, all DSA ports have an OF node, and in some cases the driver > needs a handle to it, for all ports including the CPU port. Example: the > following Linux per-port device tree property: > > managed = "in-band-status"; > > states whether a port should operate with clause 37 in-band autoneg > enabled or not. > > This patch exposes a function which can be called by individual drivers > as needed. > > Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com> > --- > include/net/dsa.h | 12 ++++++++++++ > net/dsa-uclass.c | 20 ++++++++++++++++++++ > 2 files changed, 32 insertions(+) > > diff --git a/include/net/dsa.h b/include/net/dsa.h > index ab2a9dfbea2d..d165427fcd4c 100644 > --- a/include/net/dsa.h > +++ b/include/net/dsa.h > @@ -6,6 +6,7 @@ > #ifndef __DSA_H__ > #define __DSA_H__ > > +#include <dm/ofnode.h> > #include <phy.h> > #include <net.h> > > @@ -145,6 +146,17 @@ int dsa_set_tagging(struct udevice *dev, ushort headroom, ushort tailroom); > */ > struct udevice *dsa_get_master(struct udevice *dev); > > +/** > + * dsa_port_get_ofnode() - Return a reference to the given port's OF node > + * > + * Can be called at driver probe time or later. > + * > + * @dev: DSA switch udevice pointer > + * @port: Port index > + * @return OF node reference if OK, NULL on error > + */ > +ofnode dsa_port_get_ofnode(struct udevice *dev, int port); > + > /** > * dsa_port_get_pdata() - Helper that returns the platdata of an active > * (non-CPU) DSA port device. > diff --git a/net/dsa-uclass.c b/net/dsa-uclass.c > index a9b4484d6d24..61bb47d0102d 100644 > --- a/net/dsa-uclass.c > +++ b/net/dsa-uclass.c > @@ -44,6 +44,26 @@ int dsa_set_tagging(struct udevice *dev, ushort headroom, ushort tailroom) > return 0; > } > > +ofnode dsa_port_get_ofnode(struct udevice *dev, int port) > +{ > + struct dsa_pdata *pdata = dev_get_uclass_plat(dev); > + struct dsa_port_pdata *port_pdata; > + struct udevice *pdev; > + > + if (port == pdata->cpu_port) > + return pdata->cpu_port_node; > + > + for (device_find_first_child(dev, &pdev); > + pdev; > + device_find_next_child(&pdev)) { > + port_pdata = dev_get_parent_plat(pdev); > + if (port_pdata->index == port) > + return dev_ofnode(pdev); > + } > + > + return ofnode_null(); > +} > + > /* returns the DSA master Ethernet device */ > struct udevice *dsa_get_master(struct udevice *dev) > { > -- > 2.25.1 > Reviewed-by: Ramon Fried <rfried.dev@gmail.com>
diff --git a/include/net/dsa.h b/include/net/dsa.h index ab2a9dfbea2d..d165427fcd4c 100644 --- a/include/net/dsa.h +++ b/include/net/dsa.h @@ -6,6 +6,7 @@ #ifndef __DSA_H__ #define __DSA_H__ +#include <dm/ofnode.h> #include <phy.h> #include <net.h> @@ -145,6 +146,17 @@ int dsa_set_tagging(struct udevice *dev, ushort headroom, ushort tailroom); */ struct udevice *dsa_get_master(struct udevice *dev); +/** + * dsa_port_get_ofnode() - Return a reference to the given port's OF node + * + * Can be called at driver probe time or later. + * + * @dev: DSA switch udevice pointer + * @port: Port index + * @return OF node reference if OK, NULL on error + */ +ofnode dsa_port_get_ofnode(struct udevice *dev, int port); + /** * dsa_port_get_pdata() - Helper that returns the platdata of an active * (non-CPU) DSA port device. diff --git a/net/dsa-uclass.c b/net/dsa-uclass.c index a9b4484d6d24..61bb47d0102d 100644 --- a/net/dsa-uclass.c +++ b/net/dsa-uclass.c @@ -44,6 +44,26 @@ int dsa_set_tagging(struct udevice *dev, ushort headroom, ushort tailroom) return 0; } +ofnode dsa_port_get_ofnode(struct udevice *dev, int port) +{ + struct dsa_pdata *pdata = dev_get_uclass_plat(dev); + struct dsa_port_pdata *port_pdata; + struct udevice *pdev; + + if (port == pdata->cpu_port) + return pdata->cpu_port_node; + + for (device_find_first_child(dev, &pdev); + pdev; + device_find_next_child(&pdev)) { + port_pdata = dev_get_parent_plat(pdev); + if (port_pdata->index == port) + return dev_ofnode(pdev); + } + + return ofnode_null(); +} + /* returns the DSA master Ethernet device */ struct udevice *dsa_get_master(struct udevice *dev) {
In the current DSA switch driver API, only the udevice of the switch (belonging to UCLASS_DSA) is exposed, as well as an "int port" argument. So drivers do not have access to the udevice of individual ports (belonging to UCLASS_ETH), one of the reasons being that not all ports have an associated UCLASS_ETH udevice. However, all DSA ports have an OF node, and in some cases the driver needs a handle to it, for all ports including the CPU port. Example: the following Linux per-port device tree property: managed = "in-band-status"; states whether a port should operate with clause 37 in-band autoneg enabled or not. This patch exposes a function which can be called by individual drivers as needed. Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com> --- include/net/dsa.h | 12 ++++++++++++ net/dsa-uclass.c | 20 ++++++++++++++++++++ 2 files changed, 32 insertions(+)