From: sashiko-bot@kernel.org
To: "Minghuan Lian" <minghuan.lian@nxp.com>
Cc: robh@kernel.org, conor+dt@kernel.org, devicetree@vger.kernel.org,
krzk+dt@kernel.org
Subject: Re: [PATCH net-next 2/4] net: dsa: tag_hms: Add HMS tag protocol
Date: Sun, 10 May 2026 09:10:56 +0000 [thread overview]
Message-ID: <20260510091056.91967C2BCB8@smtp.kernel.org> (raw)
In-Reply-To: <20260509090632.2959553-3-minghuan.lian@nxp.com>
Thank you for your contribution! Sashiko AI review found 4 potential issue(s) to consider:
- [High] The `buf` pointer in `hms_rcv_meta_cmd()` becomes a dangling pointer if `skb_linearize()` reallocates the SKB.
- [High] Incorrect length calculation in `hms_rcv_meta_cmd()` leads to an integer underflow when invoking the switch driver's meta command handler.
- [High] Returning `NULL` after `__vlan_hwaccel_push_inside()` fails in `hms_imprecise_xmit()` causes a double free in the caller.
- [Medium] The Kconfig symbol NET_DSA_TAG_HMS selects a non-existent symbol NET_DSA_TAG_8021Q.
--
commit 5802d819bc05556c0d9f828794cc67145ff4496a
Author: Minghuan Lian <minghuan.lian@nxp.com>
net: dsa: tag_hms: Add HMS tag protocol
This commit adds a DSA tagger for NXP Heterogeneous Multi-SoC (HMS) switches.
It supports both tag_8021q based transmit and receive handling for regular
data traffic, and an HMS meta frame format for link-local and control traffic.
> diff --git a/net/dsa/Kconfig b/net/dsa/Kconfig
> --- a/net/dsa/Kconfig
> +++ b/net/dsa/Kconfig
> @@ -211,4 +211,13 @@ config NET_DSA_TAG_YT921X
> Say Y or M if you want to enable support for tagging frames for
> Motorcomm YT921x switches.
>
> +config NET_DSA_TAG_HMS
> + tristate "Tag driver for NXP Heterogeneous Multi-SoC switches"
> + select NET_DSA_TAG_8021Q
Does the NET_DSA_TAG_8021Q config symbol exist? Looking through the tree, it
appears tag_8021q.c is compiled unconditionally as part of dsa_core-y rather
than having its own Kconfig symbol. Selecting a non-existent symbol can lead
to unmet dependency warnings or silent build failures.
> + help
> + Say Y or M if you want to enable support for tagging frames for
> + NXP Heterogeneous Multi-SoC switch family. This driver uses a
[ ... ]
> diff --git a/net/dsa/tag_hms.c b/net/dsa/tag_hms.c
> new file mode 100644
> --- /dev/null
> +++ b/net/dsa/tag_hms.c
[ ... ]
> +static struct sk_buff *hms_imprecise_xmit(struct sk_buff *skb,
> + struct net_device *netdev)
> +{
> + struct dsa_port *dp = dsa_user_to_port(netdev);
> + unsigned int bridge_num = dsa_port_bridge_num_get(dp);
> + struct net_device *br = dsa_port_bridge_dev_get(dp);
> + u16 tx_vid;
[ ... ]
> + if (unlikely(skb_vlan_tag_present(skb))) {
> + skb = __vlan_hwaccel_push_inside(skb);
> + if (!skb) {
> + WARN_ONCE(1, "Failed to push VLAN tag to payload!\n");
> + return NULL;
Could returning NULL here lead to a double free?
If __vlan_hwaccel_push_inside() fails, it consumes and frees the original skb.
However, returning NULL back up to the DSA core (dsa_user_xmit) usually
signals that the tagger did not consume the skb, which leads the DSA core to
call kfree_skb() on the original pointer again.
> + }
> + }
> +
> + return dsa_8021q_xmit(skb, netdev, hms_xmit_tpid(dp), tx_vid);
> +}
[ ... ]
> +static struct sk_buff *hms_rcv_meta_cmd(struct sk_buff *skb, u16 rx_header)
> +{
> + u8 *buf = dsa_etype_header_pos_rx(skb) + HMS_HEADER_LEN;
> + int switch_id = HMS_RX_HEADER_SWITCH_ID(rx_header);
> + int source_port = HMS_RX_HEADER_PORT_ID(rx_header);
> + struct hms_tagger_data *tagger_data;
> + struct net_device *master = skb->dev;
> + struct dsa_port *cpu_dp;
> + struct dsa_switch *ds;
> +
> + cpu_dp = master->dsa_ptr;
> + ds = dsa_switch_find(cpu_dp->dst->index, switch_id);
> + if (!ds) {
> + net_err_ratelimited("%s: cannot find switch id %d\n",
> + master->name, switch_id);
> + return NULL;
> + }
> +
> + tagger_data = ds->tagger_data;
> + if (!tagger_data->meta_cmd_handler)
> + return NULL;
> +
> + if (skb_is_nonlinear(skb))
> + if (skb_linearize(skb))
> + return NULL;
If skb_linearize() reallocates the data buffer to make it contiguous, does the
buf pointer become dangling? It was initialized before the linearization and
might now point to freed memory.
> +
> + tagger_data->meta_cmd_handler(ds, source_port, buf,
> + skb->len - HMS_HEADER_LEN - 2 * ETH_ALEN);
Is this length calculation correct for the receive path?
Since the MAC header has usually already been pulled from the skb by the time
we reach the tagger, skb->len should simply be the payload size. Subtracting
an additional 2 * ETH_ALEN might cause an integer underflow if the metadata
payload is small, resulting in a huge size_t value being passed to the driver
callback.
> +
> + /* Discard the meta frame */
> + return NULL;
> +}
--
Sashiko AI review · https://sashiko.dev/#/patchset/20260509090632.2959553-1-minghuan.lian@nxp.com?part=2
next prev parent reply other threads:[~2026-05-10 9:10 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-09 9:06 [PATCH net-next 0/4] net: dsa: Add NXP i.MX RT1180 NETC switch support Minghuan Lian
2026-05-09 9:06 ` [PATCH net-next 1/4] dt-bindings: net: dsa: add NXP i.MX RT1180 NETC switch Minghuan Lian
2026-05-09 9:06 ` [PATCH net-next 2/4] net: dsa: tag_hms: Add HMS tag protocol Minghuan Lian
2026-05-10 9:10 ` sashiko-bot [this message]
2026-05-09 9:06 ` [PATCH net-next 3/4] net: dsa: hms: Add NXP i.MX RT1180 NETC switch driver Minghuan Lian
2026-05-10 9:10 ` sashiko-bot
2026-05-09 9:06 ` [PATCH net-next 4/4] net: dsa: hms: Add ethtool statistics support Minghuan Lian
2026-05-10 9:10 ` sashiko-bot
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=20260510091056.91967C2BCB8@smtp.kernel.org \
--to=sashiko-bot@kernel.org \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=krzk+dt@kernel.org \
--cc=minghuan.lian@nxp.com \
--cc=robh@kernel.org \
--cc=sashiko@lists.linux.dev \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox