diff options
Diffstat (limited to 'drivers/net/macvtap.c')
| -rw-r--r-- | drivers/net/macvtap.c | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c index 919f4fccc322..27ecc5c4fa26 100644 --- a/drivers/net/macvtap.c +++ b/drivers/net/macvtap.c @@ -642,7 +642,7 @@ static void macvtap_skb_to_vnet_hdr(struct macvtap_queue *q,  	if (skb->ip_summed == CHECKSUM_PARTIAL) {  		vnet_hdr->flags = VIRTIO_NET_HDR_F_NEEDS_CSUM; -		if (vlan_tx_tag_present(skb)) +		if (skb_vlan_tag_present(skb))  			vnet_hdr->csum_start = cpu_to_macvtap16(q,  				skb_checksum_start_offset(skb) + VLAN_HLEN);  		else @@ -654,11 +654,14 @@ static void macvtap_skb_to_vnet_hdr(struct macvtap_queue *q,  	} /* else everything is zero */  } +/* Neighbour code has some assumptions on HH_DATA_MOD alignment */ +#define MACVTAP_RESERVE HH_DATA_OFF(ETH_HLEN) +  /* Get packet from user space buffer */  static ssize_t macvtap_get_user(struct macvtap_queue *q, struct msghdr *m,  				struct iov_iter *from, int noblock)  { -	int good_linear = SKB_MAX_HEAD(NET_IP_ALIGN); +	int good_linear = SKB_MAX_HEAD(MACVTAP_RESERVE);  	struct sk_buff *skb;  	struct macvlan_dev *vlan;  	unsigned long total_len = iov_iter_count(from); @@ -722,7 +725,7 @@ static ssize_t macvtap_get_user(struct macvtap_queue *q, struct msghdr *m,  			linear = macvtap16_to_cpu(q, vnet_hdr.hdr_len);  	} -	skb = macvtap_alloc_skb(&q->sk, NET_IP_ALIGN, copylen, +	skb = macvtap_alloc_skb(&q->sk, MACVTAP_RESERVE, copylen,  				linear, noblock, &err);  	if (!skb)  		goto err; @@ -818,13 +821,13 @@ static ssize_t macvtap_put_user(struct macvtap_queue *q,  	total = vnet_hdr_len;  	total += skb->len; -	if (vlan_tx_tag_present(skb)) { +	if (skb_vlan_tag_present(skb)) {  		struct {  			__be16 h_vlan_proto;  			__be16 h_vlan_TCI;  		} veth;  		veth.h_vlan_proto = skb->vlan_proto; -		veth.h_vlan_TCI = htons(vlan_tx_tag_get(skb)); +		veth.h_vlan_TCI = htons(skb_vlan_tag_get(skb));  		vlan_offset = offsetof(struct vlan_ethhdr, h_vlan_proto);  		total += VLAN_HLEN; | 
