ehea: Fix a checksum issue on the receive path
Currently we set all skbs with CHECKSUM_UNNECESSARY, even those whose protocol we don't know. This patch just add the CHECKSUM_COMPLETE tag for non TCP/UDP packets. Reported-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: Breno Leitao <leitao@linux.vnet.ibm.com> Signed-off-by: Jay Vosburgh <fubar@us.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
这个提交包含在:
@@ -533,8 +533,15 @@ static inline void ehea_fill_skb(struct net_device *dev,
|
||||
int length = cqe->num_bytes_transfered - 4; /*remove CRC */
|
||||
|
||||
skb_put(skb, length);
|
||||
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
||||
skb->protocol = eth_type_trans(skb, dev);
|
||||
|
||||
/* The packet was not an IPV4 packet so a complemented checksum was
|
||||
calculated. The value is found in the Internet Checksum field. */
|
||||
if (cqe->status & EHEA_CQE_BLIND_CKSUM) {
|
||||
skb->ip_summed = CHECKSUM_COMPLETE;
|
||||
skb->csum = csum_unfold(~cqe->inet_checksum_value);
|
||||
} else
|
||||
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
||||
}
|
||||
|
||||
static inline struct sk_buff *get_skb_by_index(struct sk_buff **skb_array,
|
||||
|
在新工单中引用
屏蔽一个用户