Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ba67b510 authored by Ivan Vecera's avatar Ivan Vecera Committed by David S. Miller
Browse files

tg3: update rx_jumbo_pending ring param only when jumbo frames are enabled



The patch fixes a problem with dropped jumbo frames after usage of
'ethtool -G ... rx'.

Scenario:
1. ip link set eth0 up
2. ethtool -G eth0 rx N # <- This zeroes rx-jumbo
3. ip link set mtu 9000 dev eth0

The ethtool command set rx_jumbo_pending to zero so any received jumbo
packets are dropped and you need to use 'ethtool -G eth0 rx-jumbo N'
to workaround the issue.
The patch changes the logic so rx_jumbo_pending value is changed only if
jumbo frames are enabled (MTU > 1500).

Signed-off-by: default avatarIvan Vecera <ivecera@redhat.com>
Acked-by: default avatarMichael Chan <mchan@broadcom.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent dc8eaaa0
Loading
Loading
Loading
Loading
+3 −1
Original line number Diff line number Diff line
@@ -12286,6 +12286,8 @@ static int tg3_set_ringparam(struct net_device *dev, struct ethtool_ringparam *e
	if (tg3_flag(tp, MAX_RXPEND_64) &&
	    tp->rx_pending > 63)
		tp->rx_pending = 63;

	if (tg3_flag(tp, JUMBO_RING_ENABLE))
		tp->rx_jumbo_pending = ering->rx_jumbo_pending;

	for (i = 0; i < tp->irq_max; i++)