diff options
Diffstat (limited to 'drivers/net/ethernet/emulex')
-rw-r--r-- | drivers/net/ethernet/emulex/benet/be_main.c | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/drivers/net/ethernet/emulex/benet/be_main.c b/drivers/net/ethernet/emulex/benet/be_main.c index 2886c9b63f90..a254942ed5a6 100644 --- a/drivers/net/ethernet/emulex/benet/be_main.c +++ b/drivers/net/ethernet/emulex/benet/be_main.c | |||
@@ -626,11 +626,6 @@ static inline u16 be_get_tx_vlan_tag(struct be_adapter *adapter, | |||
626 | return vlan_tag; | 626 | return vlan_tag; |
627 | } | 627 | } |
628 | 628 | ||
629 | static int be_vlan_tag_chk(struct be_adapter *adapter, struct sk_buff *skb) | ||
630 | { | ||
631 | return vlan_tx_tag_present(skb) || adapter->pvid; | ||
632 | } | ||
633 | |||
634 | static void wrb_fill_hdr(struct be_adapter *adapter, struct be_eth_hdr_wrb *hdr, | 629 | static void wrb_fill_hdr(struct be_adapter *adapter, struct be_eth_hdr_wrb *hdr, |
635 | struct sk_buff *skb, u32 wrb_cnt, u32 len) | 630 | struct sk_buff *skb, u32 wrb_cnt, u32 len) |
636 | { | 631 | { |
@@ -781,11 +776,10 @@ static netdev_tx_t be_xmit(struct sk_buff *skb, | |||
781 | eth_hdr_len = ntohs(skb->protocol) == ETH_P_8021Q ? | 776 | eth_hdr_len = ntohs(skb->protocol) == ETH_P_8021Q ? |
782 | VLAN_ETH_HLEN : ETH_HLEN; | 777 | VLAN_ETH_HLEN : ETH_HLEN; |
783 | 778 | ||
784 | /* HW has a bug which considers padding bytes as legal | 779 | /* For padded packets, BE HW modifies tot_len field in IP header |
785 | * and modifies the IPv4 hdr's 'tot_len' field | 780 | * incorrecly when VLAN tag is inserted by HW. |
786 | */ | 781 | */ |
787 | if (skb->len <= 60 && be_vlan_tag_chk(adapter, skb) && | 782 | if (skb->len <= 60 && vlan_tx_tag_present(skb) && is_ipv4_pkt(skb)) { |
788 | is_ipv4_pkt(skb)) { | ||
789 | ip = (struct iphdr *)ip_hdr(skb); | 783 | ip = (struct iphdr *)ip_hdr(skb); |
790 | pskb_trim(skb, eth_hdr_len + ntohs(ip->tot_len)); | 784 | pskb_trim(skb, eth_hdr_len + ntohs(ip->tot_len)); |
791 | } | 785 | } |
@@ -795,7 +789,7 @@ static netdev_tx_t be_xmit(struct sk_buff *skb, | |||
795 | * Manually insert VLAN in pkt. | 789 | * Manually insert VLAN in pkt. |
796 | */ | 790 | */ |
797 | if (skb->ip_summed != CHECKSUM_PARTIAL && | 791 | if (skb->ip_summed != CHECKSUM_PARTIAL && |
798 | be_vlan_tag_chk(adapter, skb)) { | 792 | vlan_tx_tag_present(skb)) { |
799 | skb = be_insert_vlan_in_pkt(adapter, skb); | 793 | skb = be_insert_vlan_in_pkt(adapter, skb); |
800 | if (unlikely(!skb)) | 794 | if (unlikely(!skb)) |
801 | goto tx_drop; | 795 | goto tx_drop; |