* [PATCH net 0/2] net: stmmac: Minor fixes for stmmac EST implementation
@ 2025-09-11 8:22 Rohan G Thomas via B4 Relay
2025-09-11 8:22 ` [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks Rohan G Thomas via B4 Relay
2025-09-11 8:23 ` [PATCH net 2/2] net: stmmac: Consider Tx VLAN offload tag length for maxSDU Rohan G Thomas via B4 Relay
0 siblings, 2 replies; 7+ messages in thread
From: Rohan G Thomas via B4 Relay @ 2025-09-11 8:22 UTC (permalink / raw)
To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski,
Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu,
Rohan G Thomas
Cc: netdev, linux-stm32, linux-arm-kernel, linux-kernel,
Rohan G Thomas, Matthew Gerlach
This patchset includes following minor fixes for stmmac EST
implementation:
1. Fix GCL bounds checks
2. Consider Tx VLAN offload tag length for maxSDU
Signed-off-by: Rohan G Thomas <rohan.g.thomas@altera.com>
---
Rohan G Thomas (2):
net: stmmac: est: Fix GCL bounds checks
net: stmmac: Consider Tx VLAN offload tag length for maxSDU
drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 25 ++++++++++++++++-------
drivers/net/ethernet/stmicro/stmmac/stmmac_tc.c | 4 ++--
2 files changed, 20 insertions(+), 9 deletions(-)
---
base-commit: 1f24a240974589ce42f70502ccb3ff3f5189d69a
change-id: 20250911-qbv-fixes-4ae64de86ee7
Best regards,
--
Rohan G Thomas <rohan.g.thomas@altera.com>
^ permalink raw reply [flat|nested] 7+ messages in thread* [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks 2025-09-11 8:22 [PATCH net 0/2] net: stmmac: Minor fixes for stmmac EST implementation Rohan G Thomas via B4 Relay @ 2025-09-11 8:22 ` Rohan G Thomas via B4 Relay 2025-09-11 11:24 ` Russell King (Oracle) 2025-09-11 8:23 ` [PATCH net 2/2] net: stmmac: Consider Tx VLAN offload tag length for maxSDU Rohan G Thomas via B4 Relay 1 sibling, 1 reply; 7+ messages in thread From: Rohan G Thomas via B4 Relay @ 2025-09-11 8:22 UTC (permalink / raw) To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski, Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu, Rohan G Thomas Cc: netdev, linux-stm32, linux-arm-kernel, linux-kernel, Rohan G Thomas, Matthew Gerlach From: Rohan G Thomas <rohan.g.thomas@intel.com> Fix the bounds checks for the hw supported maximum GCL entry count and gate interval time. Fixes: b60189e0392f ("net: stmmac: Integrate EST with TAPRIO scheduler API") Signed-off-by: Rohan G Thomas <rohan.g.thomas@intel.com> Reviewed-by: Matthew Gerlach <matthew.gerlach@altera.com> --- drivers/net/ethernet/stmicro/stmmac/stmmac_tc.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_tc.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_tc.c index 694d6ee1438197bd4434af6e9b78f022e94ff98f..89d094abb6be5c993c81901e3f79a6b03f310511 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_tc.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_tc.c @@ -981,7 +981,7 @@ static int tc_taprio_configure(struct stmmac_priv *priv, if (qopt->cmd == TAPRIO_CMD_DESTROY) goto disable; - if (qopt->num_entries >= dep) + if (qopt->num_entries > dep) return -EINVAL; if (!qopt->cycle_time) return -ERANGE; @@ -1012,7 +1012,7 @@ static int tc_taprio_configure(struct stmmac_priv *priv, s64 delta_ns = qopt->entries[i].interval; u32 gates = qopt->entries[i].gate_mask; - if (delta_ns > GENMASK(wid, 0)) + if (delta_ns >= BIT(wid)) return -ERANGE; if (gates > GENMASK(31 - wid, 0)) return -ERANGE; -- 2.25.1 ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks 2025-09-11 8:22 ` [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks Rohan G Thomas via B4 Relay @ 2025-09-11 11:24 ` Russell King (Oracle) 2025-09-11 12:42 ` G Thomas, Rohan 0 siblings, 1 reply; 7+ messages in thread From: Russell King (Oracle) @ 2025-09-11 11:24 UTC (permalink / raw) To: rohan.g.thomas Cc: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski, Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu, Rohan G Thomas, netdev, linux-stm32, linux-arm-kernel, linux-kernel, Matthew Gerlach On Thu, Sep 11, 2025 at 04:22:59PM +0800, Rohan G Thomas via B4 Relay wrote: > @@ -1012,7 +1012,7 @@ static int tc_taprio_configure(struct stmmac_priv *priv, > s64 delta_ns = qopt->entries[i].interval; > u32 gates = qopt->entries[i].gate_mask; > > - if (delta_ns > GENMASK(wid, 0)) > + if (delta_ns >= BIT(wid)) While I agree this makes it look better, you don't change the version below, which makes the code inconsistent. I also don't see anything wrong with the original comparison. -- RMK's Patch system: https://www.armlinux.org.uk/developer/patches/ FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last! ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks 2025-09-11 11:24 ` Russell King (Oracle) @ 2025-09-11 12:42 ` G Thomas, Rohan 2025-09-12 0:01 ` Jakub Kicinski 0 siblings, 1 reply; 7+ messages in thread From: G Thomas, Rohan @ 2025-09-11 12:42 UTC (permalink / raw) To: Russell King (Oracle) Cc: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski, Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu, Rohan G Thomas, netdev, linux-stm32, linux-arm-kernel, linux-kernel, Matthew Gerlach Hi Russell, Thanks for reviewing the patch. On 9/11/2025 4:54 PM, Russell King (Oracle) wrote: > On Thu, Sep 11, 2025 at 04:22:59PM +0800, Rohan G Thomas via B4 Relay wrote: >> @@ -1012,7 +1012,7 @@ static int tc_taprio_configure(struct stmmac_priv *priv, >> s64 delta_ns = qopt->entries[i].interval; >> u32 gates = qopt->entries[i].gate_mask; >> >> - if (delta_ns > GENMASK(wid, 0)) >> + if (delta_ns >= BIT(wid)) > > While I agree this makes it look better, you don't change the version > below, which makes the code inconsistent. I also don't see anything > wrong with the original comparison. Just to clarify the intent behind this change: For example, if wid = 3, then GENMASK(3, 0) = 0b1111 = 15. But the maximum supported gate interval in this case is actually 7, since only 3 bits are available to represent the value. So in the patch, the condition delta_ns >= BIT(wid) effectively checks if delta_ns is 8 or more, which correctly returns an error for values that exceed the 3-bit limit. > Best Regards, Rohan ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks 2025-09-11 12:42 ` G Thomas, Rohan @ 2025-09-12 0:01 ` Jakub Kicinski 2025-09-12 5:04 ` G Thomas, Rohan 0 siblings, 1 reply; 7+ messages in thread From: Jakub Kicinski @ 2025-09-12 0:01 UTC (permalink / raw) To: G Thomas, Rohan Cc: Russell King (Oracle), Andrew Lunn, David S. Miller, Eric Dumazet, Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu, Rohan G Thomas, netdev, linux-stm32, linux-arm-kernel, linux-kernel, Matthew Gerlach On Thu, 11 Sep 2025 18:12:16 +0530 G Thomas, Rohan wrote: > On 9/11/2025 4:54 PM, Russell King (Oracle) wrote: > > On Thu, Sep 11, 2025 at 04:22:59PM +0800, Rohan G Thomas via B4 Relay wrote: > >> @@ -1012,7 +1012,7 @@ static int tc_taprio_configure(struct stmmac_priv *priv, > >> s64 delta_ns = qopt->entries[i].interval; > >> u32 gates = qopt->entries[i].gate_mask; > >> > >> - if (delta_ns > GENMASK(wid, 0)) > >> + if (delta_ns >= BIT(wid)) > > > > While I agree this makes it look better, you don't change the version > > below, which makes the code inconsistent. I also don't see anything > > wrong with the original comparison. > > Just to clarify the intent behind this change: > For example, if wid = 3, then GENMASK(3, 0) = 0b1111 = 15. But the > maximum supported gate interval in this case is actually 7, since only 3 > bits are available to represent the value. So in the patch, the > condition delta_ns >= BIT(wid) effectively checks if delta_ns is 8 or > more, which correctly returns an error for values that exceed the 3-bit > limit. Comparison to BIT() looks rather odd, I think it's better to correct the GENMASK() bound? ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks 2025-09-12 0:01 ` Jakub Kicinski @ 2025-09-12 5:04 ` G Thomas, Rohan 0 siblings, 0 replies; 7+ messages in thread From: G Thomas, Rohan @ 2025-09-12 5:04 UTC (permalink / raw) To: Jakub Kicinski Cc: Russell King (Oracle), Andrew Lunn, David S. Miller, Eric Dumazet, Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu, Rohan G Thomas, netdev, linux-stm32, linux-arm-kernel, linux-kernel, Matthew Gerlach Hi Jakub, Thanks for reviewing the patch. On 9/12/2025 5:31 AM, Jakub Kicinski wrote: > On Thu, 11 Sep 2025 18:12:16 +0530 G Thomas, Rohan wrote: >> On 9/11/2025 4:54 PM, Russell King (Oracle) wrote: >>> On Thu, Sep 11, 2025 at 04:22:59PM +0800, Rohan G Thomas via B4 Relay wrote: >>>> @@ -1012,7 +1012,7 @@ static int tc_taprio_configure(struct stmmac_priv *priv, >>>> s64 delta_ns = qopt->entries[i].interval; >>>> u32 gates = qopt->entries[i].gate_mask; >>>> >>>> - if (delta_ns > GENMASK(wid, 0)) >>>> + if (delta_ns >= BIT(wid)) >>> >>> While I agree this makes it look better, you don't change the version >>> below, which makes the code inconsistent. I also don't see anything >>> wrong with the original comparison. >> >> Just to clarify the intent behind this change: >> For example, if wid = 3, then GENMASK(3, 0) = 0b1111 = 15. But the >> maximum supported gate interval in this case is actually 7, since only 3 >> bits are available to represent the value. So in the patch, the >> condition delta_ns >= BIT(wid) effectively checks if delta_ns is 8 or >> more, which correctly returns an error for values that exceed the 3-bit >> limit. > > Comparison to BIT() looks rather odd, I think it's better to correct > the GENMASK() bound? Sure I'll update the condition to use GENMASK(wid - 1, 0) in the next version. That should make the logic consistent with the checks below. Best Regards, Rohan ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH net 2/2] net: stmmac: Consider Tx VLAN offload tag length for maxSDU 2025-09-11 8:22 [PATCH net 0/2] net: stmmac: Minor fixes for stmmac EST implementation Rohan G Thomas via B4 Relay 2025-09-11 8:22 ` [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks Rohan G Thomas via B4 Relay @ 2025-09-11 8:23 ` Rohan G Thomas via B4 Relay 1 sibling, 0 replies; 7+ messages in thread From: Rohan G Thomas via B4 Relay @ 2025-09-11 8:23 UTC (permalink / raw) To: Andrew Lunn, David S. Miller, Eric Dumazet, Jakub Kicinski, Paolo Abeni, Maxime Coquelin, Alexandre Torgue, Jose Abreu, Rohan G Thomas Cc: netdev, linux-stm32, linux-arm-kernel, linux-kernel, Rohan G Thomas, Matthew Gerlach From: Rohan G Thomas <rohan.g.thomas@intel.com> On hardware with Tx VLAN offload enabled, add the VLAN tag length to the skb length before checking the Qbv maxSDU. Add 4 bytes for 802.1Q an add 8 bytes for 802.1AD tagging. Fixes: c5c3e1bfc9e0 ("net: stmmac: Offload queueMaxSDU from tc-taprio") Signed-off-by: Rohan G Thomas <rohan.g.thomas@intel.com> Reviewed-by: Matthew Gerlach <matthew.gerlach@altera.com> --- drivers/net/ethernet/stmicro/stmmac/stmmac_main.c | 25 ++++++++++++++++------- 1 file changed, 18 insertions(+), 7 deletions(-) diff --git a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c index 419cb49ee5a25519a60a84bae6bcdb0be655384e..c487ce95436c2a1f502f96d00afab6270d77c0bb 100644 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c @@ -4531,6 +4531,7 @@ static netdev_tx_t stmmac_xmit(struct sk_buff *skb, struct net_device *dev) bool has_vlan, set_ic; int entry, first_tx; dma_addr_t des; + u32 sdu_len; tx_q = &priv->dma_conf.tx_queue[queue]; txq_stats = &priv->xstats.txq_stats[queue]; @@ -4547,13 +4548,6 @@ static netdev_tx_t stmmac_xmit(struct sk_buff *skb, struct net_device *dev) return stmmac_tso_xmit(skb, dev); } - if (priv->est && priv->est->enable && - priv->est->max_sdu[queue] && - skb->len > priv->est->max_sdu[queue]){ - priv->xstats.max_sdu_txq_drop[queue]++; - goto max_sdu_err; - } - if (unlikely(stmmac_tx_avail(priv, queue) < nfrags + 1)) { if (!netif_tx_queue_stopped(netdev_get_tx_queue(dev, queue))) { netif_tx_stop_queue(netdev_get_tx_queue(priv->dev, @@ -4569,6 +4563,23 @@ static netdev_tx_t stmmac_xmit(struct sk_buff *skb, struct net_device *dev) /* Check if VLAN can be inserted by HW */ has_vlan = stmmac_vlan_insert(priv, skb, tx_q); + sdu_len = skb->len; + if (has_vlan) { + /* Add VLAN tag length to sdu length in case of txvlan offload */ + if (priv->dev->features & NETIF_F_HW_VLAN_CTAG_TX) + sdu_len += VLAN_HLEN; + if (skb->vlan_proto == htons(ETH_P_8021AD) && + priv->dev->features & NETIF_F_HW_VLAN_STAG_TX) + sdu_len += VLAN_HLEN; + } + + if (priv->est && priv->est->enable && + priv->est->max_sdu[queue] && + sdu_len > priv->est->max_sdu[queue]) { + priv->xstats.max_sdu_txq_drop[queue]++; + goto max_sdu_err; + } + entry = tx_q->cur_tx; first_entry = entry; WARN_ON(tx_q->tx_skbuff[first_entry]); -- 2.25.1 ^ permalink raw reply related [flat|nested] 7+ messages in thread
end of thread, other threads:[~2025-09-12 5:04 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2025-09-11 8:22 [PATCH net 0/2] net: stmmac: Minor fixes for stmmac EST implementation Rohan G Thomas via B4 Relay 2025-09-11 8:22 ` [PATCH net 1/2] net: stmmac: est: Fix GCL bounds checks Rohan G Thomas via B4 Relay 2025-09-11 11:24 ` Russell King (Oracle) 2025-09-11 12:42 ` G Thomas, Rohan 2025-09-12 0:01 ` Jakub Kicinski 2025-09-12 5:04 ` G Thomas, Rohan 2025-09-11 8:23 ` [PATCH net 2/2] net: stmmac: Consider Tx VLAN offload tag length for maxSDU Rohan G Thomas via B4 Relay
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).