|
@@ -227,7 +227,7 @@ static void set_skb_frag(struct sk_buff *skb, struct page *page,
|
|
|
skb->len += size;
|
|
|
skb->truesize += PAGE_SIZE;
|
|
|
skb_shinfo(skb)->nr_frags++;
|
|
|
- skb_shinfo(skb)->gso_type |= SKB_GSO_SHARED_FRAG;
|
|
|
+ skb_shinfo(skb)->tx_flags |= SKBTX_SHARED_FRAG;
|
|
|
*len -= size;
|
|
|
}
|
|
|
|
|
@@ -387,18 +387,16 @@ static void receive_buf(struct receive_queue *rq, void *buf, unsigned int len)
|
|
|
ntohs(skb->protocol), skb->len, skb->pkt_type);
|
|
|
|
|
|
if (hdr->hdr.gso_type != VIRTIO_NET_HDR_GSO_NONE) {
|
|
|
- unsigned short gso_type = 0;
|
|
|
-
|
|
|
pr_debug("GSO!\n");
|
|
|
switch (hdr->hdr.gso_type & ~VIRTIO_NET_HDR_GSO_ECN) {
|
|
|
case VIRTIO_NET_HDR_GSO_TCPV4:
|
|
|
- gso_type = SKB_GSO_TCPV4;
|
|
|
+ skb_shinfo(skb)->gso_type = SKB_GSO_TCPV4;
|
|
|
break;
|
|
|
case VIRTIO_NET_HDR_GSO_UDP:
|
|
|
- gso_type = SKB_GSO_UDP;
|
|
|
+ skb_shinfo(skb)->gso_type = SKB_GSO_UDP;
|
|
|
break;
|
|
|
case VIRTIO_NET_HDR_GSO_TCPV6:
|
|
|
- gso_type = SKB_GSO_TCPV6;
|
|
|
+ skb_shinfo(skb)->gso_type = SKB_GSO_TCPV6;
|
|
|
break;
|
|
|
default:
|
|
|
net_warn_ratelimited("%s: bad gso type %u.\n",
|
|
@@ -407,7 +405,7 @@ static void receive_buf(struct receive_queue *rq, void *buf, unsigned int len)
|
|
|
}
|
|
|
|
|
|
if (hdr->hdr.gso_type & VIRTIO_NET_HDR_GSO_ECN)
|
|
|
- gso_type |= SKB_GSO_TCP_ECN;
|
|
|
+ skb_shinfo(skb)->gso_type |= SKB_GSO_TCP_ECN;
|
|
|
|
|
|
skb_shinfo(skb)->gso_size = hdr->hdr.gso_size;
|
|
|
if (skb_shinfo(skb)->gso_size == 0) {
|
|
@@ -415,7 +413,6 @@ static void receive_buf(struct receive_queue *rq, void *buf, unsigned int len)
|
|
|
goto frame_err;
|
|
|
}
|
|
|
|
|
|
- skb_shinfo(skb)->gso_type |= gso_type;
|
|
|
/* Header must be checked, and gso_segs computed. */
|
|
|
skb_shinfo(skb)->gso_type |= SKB_GSO_DODGY;
|
|
|
skb_shinfo(skb)->gso_segs = 0;
|