|
@@ -434,6 +434,7 @@ efx_rx_packet_gro(struct efx_channel *channel, struct efx_rx_buffer *rx_buf,
|
|
PKT_HASH_TYPE_L3);
|
|
PKT_HASH_TYPE_L3);
|
|
skb->ip_summed = ((rx_buf->flags & EFX_RX_PKT_CSUMMED) ?
|
|
skb->ip_summed = ((rx_buf->flags & EFX_RX_PKT_CSUMMED) ?
|
|
CHECKSUM_UNNECESSARY : CHECKSUM_NONE);
|
|
CHECKSUM_UNNECESSARY : CHECKSUM_NONE);
|
|
|
|
+ skb->csum_level = !!(rx_buf->flags & EFX_RX_PKT_CSUM_LEVEL);
|
|
|
|
|
|
for (;;) {
|
|
for (;;) {
|
|
skb_fill_page_desc(skb, skb_shinfo(skb)->nr_frags,
|
|
skb_fill_page_desc(skb, skb_shinfo(skb)->nr_frags,
|
|
@@ -621,8 +622,10 @@ static void efx_rx_deliver(struct efx_channel *channel, u8 *eh,
|
|
|
|
|
|
/* Set the SKB flags */
|
|
/* Set the SKB flags */
|
|
skb_checksum_none_assert(skb);
|
|
skb_checksum_none_assert(skb);
|
|
- if (likely(rx_buf->flags & EFX_RX_PKT_CSUMMED))
|
|
|
|
|
|
+ if (likely(rx_buf->flags & EFX_RX_PKT_CSUMMED)) {
|
|
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
|
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
|
|
|
+ skb->csum_level = !!(rx_buf->flags & EFX_RX_PKT_CSUM_LEVEL);
|
|
|
|
+ }
|
|
|
|
|
|
efx_rx_skb_attach_timestamp(channel, skb);
|
|
efx_rx_skb_attach_timestamp(channel, skb);
|
|
|
|
|