diff options
author | Sridhar Samudrala <sri@us.ibm.com> | 2010-01-23 11:02:21 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-01-23 11:02:21 +0100 |
commit | 8e1e8a4779cb23c1d9f51e9223795e07ec54d77a (patch) | |
tree | e381b1cacfdc3351574d650dc0dbf77ada2e91a4 /drivers/net/e1000e | |
parent | igb/igbvf: cleanup exception handling in tx_map_adv (diff) | |
download | linux-8e1e8a4779cb23c1d9f51e9223795e07ec54d77a.tar.xz linux-8e1e8a4779cb23c1d9f51e9223795e07ec54d77a.zip |
net: Fix IPv6 GSO type checks in Intel ethernet drivers
Found this problem when testing IPv6 from a KVM guest to a remote
host via e1000e device on the host.
The following patch fixes the check for IPv6 GSO packet in Intel
ethernet drivers to use skb_is_gso_v6(). SKB_GSO_DODGY is also set
when packets are forwarded from a guest.
Signed-off-by: Sridhar Samudrala <sri@us.ibm.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/e1000e')
-rw-r--r-- | drivers/net/e1000e/netdev.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/e1000e/netdev.c b/drivers/net/e1000e/netdev.c index 3d887104a0d8..57f149b75fbe 100644 --- a/drivers/net/e1000e/netdev.c +++ b/drivers/net/e1000e/netdev.c @@ -3786,7 +3786,7 @@ static int e1000_tso(struct e1000_adapter *adapter, 0, IPPROTO_TCP, 0); cmd_length = E1000_TXD_CMD_IP; ipcse = skb_transport_offset(skb) - 1; - } else if (skb_shinfo(skb)->gso_type == SKB_GSO_TCPV6) { + } else if (skb_is_gso_v6(skb)) { ipv6_hdr(skb)->payload_len = 0; tcp_hdr(skb)->check = ~csum_ipv6_magic(&ipv6_hdr(skb)->saddr, &ipv6_hdr(skb)->daddr, |