From: Simon Horman <simon.horman@corigine.com>
To: Vladimir Oltean <vladimir.oltean@nxp.com>
Cc: netdev@vger.kernel.org, Andrew Lunn <andrew@lunn.ch>,
Florian Fainelli <f.fainelli@gmail.com>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH net 2/2] net: dsa: tag_sja1105: always prefer source port information from INCL_SRCPT
Date: Mon, 26 Jun 2023 20:11:53 +0200 [thread overview]
Message-ID: <ZJnU6WntVQW2AgvZ@corigine.com> (raw)
In-Reply-To: <20230626155112.3155993-3-vladimir.oltean@nxp.com>
On Mon, Jun 26, 2023 at 06:51:12PM +0300, Vladimir Oltean wrote:
> Currently the sja1105 tagging protocol prefers using the source port
> information from the VLAN header if that is available, falling back to
> the INCL_SRCPT option if it isn't. The VLAN header is available for all
> frames except for META frames initiated by the switch (containing RX
> timestamps), and thus, the "if (is_link_local)" branch is practically
> dead.
>
> The tag_8021q source port identification has become more loose
> ("imprecise") and will report a plausible rather than exact bridge port,
> when under a bridge (be it VLAN-aware or VLAN-unaware). But link-local
> traffic always needs to know the precise source port. With incorrect
> source port reporting, for example PTP traffic over 2 bridged ports will
> all be seen on sockets opened on the first such port, which is incorrect.
>
> Now that the tagging protocol has been changed to make link-local frames
> always contain source port information, we can reverse the order of the
> checks so that we always give precedence to that information (which is
> always precise) in lieu of the tag_8021q VID which is only precise for a
> standalone port.
>
> Fixes: d7f9787a763f ("net: dsa: tag_8021q: add support for imprecise RX based on the VBID")
> Fixes: 91495f21fcec ("net: dsa: tag_8021q: replace the SVL bridging with VLAN-unaware IVL bridging")
> Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com>
> ---
> net/dsa/tag_sja1105.c | 35 +++++++++++++++++++++++++----------
> 1 file changed, 25 insertions(+), 10 deletions(-)
>
> diff --git a/net/dsa/tag_sja1105.c b/net/dsa/tag_sja1105.c
> index a5f3b73da417..0e62eab8f251 100644
> --- a/net/dsa/tag_sja1105.c
> +++ b/net/dsa/tag_sja1105.c
> @@ -545,10 +545,7 @@ static struct sk_buff *sja1105_rcv(struct sk_buff *skb,
> is_link_local = sja1105_is_link_local(skb);
> is_meta = sja1105_is_meta_frame(skb);
>
> - if (sja1105_skb_has_tag_8021q(skb)) {
> - /* Normal traffic path. */
> - sja1105_vlan_rcv(skb, &source_port, &switch_id, &vbid, &vid);
> - } else if (is_link_local) {
> + if (is_link_local) {
> /* Management traffic path. Switch embeds the switch ID and
> * port ID into bytes of the destination MAC, courtesy of
> * the incl_srcpt options.
> @@ -562,16 +559,34 @@ static struct sk_buff *sja1105_rcv(struct sk_buff *skb,
> sja1105_meta_unpack(skb, &meta);
> source_port = meta.source_port;
> switch_id = meta.switch_id;
> - } else {
> - return NULL;
> }
>
> - if (vbid >= 1)
> + /* Normal data plane traffic and link-local frames are tagged with
> + * a tag_8021q VLAN which we have to strip
> + */
> + if (sja1105_skb_has_tag_8021q(skb)) {
> + int tmp_source_port = -1, tmp_switch_id = -1;
> +
> + sja1105_vlan_rcv(skb, &tmp_source_port, &tmp_switch_id, &vbid,
> + &vid);
> + /* Preserve the source information from the INCL_SRCPT option,
> + * if available. This allows us to not overwrite a valid source
> + * port and switch ID with zeroes when receiving link-local
> + * frames from a VLAN-unaware bridged port (non-zero vbid) or a
> + * VLAN-aware bridged port (non-zero vid).
> + */
> + if (source_port == -1)
> + source_port = tmp_source_port;
> + if (switch_id == -1)
> + switch_id = tmp_switch_id;
> + }
> +
> + if (source_port != -1 && switch_id != -1)
> + skb->dev = dsa_master_find_slave(netdev, switch_id, source_port);
> + else if (vbid >= 1)
> skb->dev = dsa_tag_8021q_find_port_by_vbid(netdev, vbid);
> - else if (source_port == -1 || switch_id == -1)
> - skb->dev = dsa_find_designated_bridge_port_by_vid(netdev, vid);
> else
> - skb->dev = dsa_master_find_slave(netdev, switch_id, source_port);
> + skb->dev = dsa_find_designated_bridge_port_by_vid(netdev, vid);
Hi Vladimir,
A similar comment to that made for [1], though the code is somewhat
different to that case: are you sure vid is initialised here?
GCC 12 and Smatch seem unsure about it.
[1] Re: [PATCH net-next v2 4/7] net: dsa: vsc73xx: Add dsa tagging based on 8021q
https://lore.kernel.org/all/ZJg2M+Qvg3Fv73CH@corigine.com/
> if (!skb->dev) {
> netdev_warn(netdev, "Couldn't decode source port\n");
> return NULL;
> --
> 2.34.1
>
>
next prev parent reply other threads:[~2023-06-26 18:12 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-06-26 15:51 [PATCH net 0/2] Fix PTP received on wrong port with bridged SJA1105 DSA Vladimir Oltean
2023-06-26 15:51 ` [PATCH net 1/2] net: dsa: sja1105: always enable the INCL_SRCPT option Vladimir Oltean
2023-06-26 15:51 ` [PATCH net 2/2] net: dsa: tag_sja1105: always prefer source port information from INCL_SRCPT Vladimir Oltean
2023-06-26 18:11 ` Simon Horman [this message]
2023-06-26 22:18 ` Vladimir Oltean
2023-06-27 11:15 ` Simon Horman
2023-06-27 11:41 ` Vladimir Oltean
2023-06-27 11:59 ` Simon Horman
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ZJnU6WntVQW2AgvZ@corigine.com \
--to=simon.horman@corigine.com \
--cc=andrew@lunn.ch \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=f.fainelli@gmail.com \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=vladimir.oltean@nxp.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.