summaryrefslogtreecommitdiff
path: root/drivers/net/ethernet/cisco
diff options
context:
space:
mode:
authorSiva Reddy Kallam <siva.kallam@broadcom.com>2016-02-03 11:39:38 +0300
committerDavid S. Miller <davem@davemloft.net>2016-02-09 12:39:14 +0300
commitb7d987295c74500b733a0ba07f9a9bcc4074fa83 (patch)
tree95aae805073fc667290d60c6877414ad73946052 /drivers/net/ethernet/cisco
parent5f74f82ea34c0da80ea0b49192bb5ea06e063593 (diff)
downloadlinux-b7d987295c74500b733a0ba07f9a9bcc4074fa83.tar.xz
tg3: Fix for tg3 transmit queue 0 timed out when too many gso_segs
tg3_tso_bug() can hit a condition where the entire tx ring is not big enough to segment the GSO packet. For example, if MSS is very small, gso_segs can exceed the tx ring size. When we hit the condition, it will cause tx timeout. tg3_tso_bug() is called to handle TSO and DMA hardware bugs. For TSO bugs, if tg3_tso_bug() cannot succeed, we have to drop the packet. For DMA bugs, we can still fall back to linearize the SKB and let the hardware transmit the TSO packet. This patch adds a function tg3_tso_bug_gso_check() to check if there are enough tx descriptors for GSO before calling tg3_tso_bug(). The caller will then handle the error appropriately - drop or lineraize the SKB. v2: Corrected patch description to avoid confusion. Signed-off-by: Siva Reddy Kallam <siva.kallam@broadcom.com> Signed-off-by: Michael Chan <mchan@broadcom.com> Acked-by: Prashant Sreedharan <prashant@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/cisco')
0 files changed, 0 insertions, 0 deletions