* [PATCH net] tg3: Fix race for querying speed/duplex
@ 2026-03-25 11:20 Thomas Bogendoerfer
2026-03-26 9:59 ` Pavan Chebbi
0 siblings, 1 reply; 2+ messages in thread
From: Thomas Bogendoerfer @ 2026-03-25 11:20 UTC (permalink / raw)
To: Pavan Chebbi, Michael Chan, Andrew Lunn, David S. Miller,
Eric Dumazet, Jakub Kicinski, Paolo Abeni, Nithin Sujir, netdev,
linux-kernel
When driver signals carrier up via netif_carrier_on() its internal
link_up state isn't updated immediately. This leads to inconsistent
speed/duplex in /proc/net/bonding/bondX where the speed and duplex
is shown as unknown while ethtool shows correct values. Fix this by
using netif_carrier_ok() for link checking in get_ksettings function.
Fixes: 84421b99cedc ("tg3: Update link_up flag for phylib devices")
Signed-off-by: Thomas Bogendoerfer <tbogendoerfer@suse.de>
---
drivers/net/ethernet/broadcom/tg3.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/net/ethernet/broadcom/tg3.c b/drivers/net/ethernet/broadcom/tg3.c
index 21a5dd342724..73a4b569b03e 100644
--- a/drivers/net/ethernet/broadcom/tg3.c
+++ b/drivers/net/ethernet/broadcom/tg3.c
@@ -12299,7 +12299,7 @@ static int tg3_get_link_ksettings(struct net_device *dev,
ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.advertising,
advertising);
- if (netif_running(dev) && tp->link_up) {
+ if (netif_running(dev) && netif_carrier_ok(dev)) {
cmd->base.speed = tp->link_config.active_speed;
cmd->base.duplex = tp->link_config.active_duplex;
ethtool_convert_legacy_u32_to_link_mode(
--
2.43.0
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH net] tg3: Fix race for querying speed/duplex
2026-03-25 11:20 [PATCH net] tg3: Fix race for querying speed/duplex Thomas Bogendoerfer
@ 2026-03-26 9:59 ` Pavan Chebbi
0 siblings, 0 replies; 2+ messages in thread
From: Pavan Chebbi @ 2026-03-26 9:59 UTC (permalink / raw)
To: Thomas Bogendoerfer
Cc: Michael Chan, Andrew Lunn, David S. Miller, Eric Dumazet,
Jakub Kicinski, Paolo Abeni, Nithin Sujir, netdev, linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1544 bytes --]
On Wed, Mar 25, 2026 at 4:51 PM Thomas Bogendoerfer
<tbogendoerfer@suse.de> wrote:
>
> When driver signals carrier up via netif_carrier_on() its internal
> link_up state isn't updated immediately. This leads to inconsistent
> speed/duplex in /proc/net/bonding/bondX where the speed and duplex
> is shown as unknown while ethtool shows correct values. Fix this by
> using netif_carrier_ok() for link checking in get_ksettings function.
>
> Fixes: 84421b99cedc ("tg3: Update link_up flag for phylib devices")
> Signed-off-by: Thomas Bogendoerfer <tbogendoerfer@suse.de>
> ---
> drivers/net/ethernet/broadcom/tg3.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
Reviewed-by: Pavan Chebbi <pavan.chebbi@broadcom.com>
Thank you.
> diff --git a/drivers/net/ethernet/broadcom/tg3.c b/drivers/net/ethernet/broadcom/tg3.c
> index 21a5dd342724..73a4b569b03e 100644
> --- a/drivers/net/ethernet/broadcom/tg3.c
> +++ b/drivers/net/ethernet/broadcom/tg3.c
> @@ -12299,7 +12299,7 @@ static int tg3_get_link_ksettings(struct net_device *dev,
> ethtool_convert_legacy_u32_to_link_mode(cmd->link_modes.advertising,
> advertising);
>
> - if (netif_running(dev) && tp->link_up) {
> + if (netif_running(dev) && netif_carrier_ok(dev)) {
> cmd->base.speed = tp->link_config.active_speed;
> cmd->base.duplex = tp->link_config.active_duplex;
> ethtool_convert_legacy_u32_to_link_mode(
> --
> 2.43.0
>
[-- Attachment #2: S/MIME Cryptographic Signature --]
[-- Type: application/pkcs7-signature, Size: 5469 bytes --]
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2026-03-26 9:59 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-03-25 11:20 [PATCH net] tg3: Fix race for querying speed/duplex Thomas Bogendoerfer
2026-03-26 9:59 ` Pavan Chebbi
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox