bnx2x: allow handling tunnel over udp offload
authorDmitry Kravkov <dmitry@broadcom.com>
Sun, 28 Apr 2013 08:16:02 +0000 (08:16 +0000)
committerDavid S. Miller <davem@davemloft.net>
Mon, 29 Apr 2013 19:27:47 +0000 (15:27 -0400)
CC: Pravin B Shelar <pshelar@nicira.com>
Signed-off-by: Dmitry Kravkov <dmitry@broadcom.com>
Signed-off-by: Eilon Greenstein <eilong@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/broadcom/bnx2x/bnx2x_cmn.c
drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c

index fd20a4ff015054fe875a8f6709bf7c11c884027f..466b512cda4fdc0c9324c0f726f9e208d2dc548b 100644 (file)
@@ -3530,6 +3530,11 @@ static void bnx2x_update_pbds_gso_enc(struct sk_buff *skb,
                        ETH_TX_PARSE_2ND_BD_IP_HDR_LEN_OUTER_W_SHIFT) |
                ((skb->protocol == cpu_to_be16(ETH_P_8021Q)) <<
                        ETH_TX_PARSE_2ND_BD_LLC_SNAP_EN_SHIFT);
+
+       if (ip_hdr(skb)->protocol == IPPROTO_UDP) {
+               SET_FLAG(*global_data, ETH_TX_PARSE_2ND_BD_TUNNEL_UDP_EXIST, 1);
+               pbd2->tunnel_udp_hdr_start_w = skb_transport_offset(skb) >> 1;
+       }
 }
 
 /* called with netif_tx_lock
index 927f83af9d5c59f2cc664f0da8c3679ef48254e9..91a0434ce1bdb5d640af56dc46b89a97aa240f6a 100644 (file)
@@ -12043,11 +12043,11 @@ static int bnx2x_init_dev(struct bnx2x *bp, struct pci_dev *pdev,
                NETIF_F_RXCSUM | NETIF_F_LRO | NETIF_F_GRO |
                NETIF_F_RXHASH | NETIF_F_HW_VLAN_CTAG_TX;
        if (!CHIP_IS_E1x(bp)) {
-               dev->hw_features |= NETIF_F_GSO_GRE;
+               dev->hw_features |= NETIF_F_GSO_GRE | NETIF_F_GSO_UDP_TUNNEL;
                dev->hw_enc_features =
                        NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM | NETIF_F_SG |
                        NETIF_F_TSO | NETIF_F_TSO_ECN | NETIF_F_TSO6 |
-                       NETIF_F_GSO_GRE;
+                       NETIF_F_GSO_GRE | NETIF_F_GSO_UDP_TUNNEL;
        }
 
        dev->vlan_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM |