diff options
Diffstat (limited to 'drivers/net/macvtap.c')
| -rw-r--r-- | drivers/net/macvtap.c | 11 | 
1 files changed, 4 insertions, 7 deletions
diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c index 7869b0651576..5c26653eceb5 100644 --- a/drivers/net/macvtap.c +++ b/drivers/net/macvtap.c @@ -437,7 +437,7 @@ static int macvtap_get_minor(struct macvlan_dev *vlan)  	if (retval >= 0) {  		vlan->minor = retval;  	} else if (retval == -ENOSPC) { -		printk(KERN_ERR "too many macvtap devices\n"); +		netdev_err(vlan->dev, "Too many macvtap devices\n");  		retval = -EINVAL;  	}  	mutex_unlock(&minor_lock); @@ -679,7 +679,6 @@ static ssize_t macvtap_get_user(struct macvtap_queue *q, struct msghdr *m,  	int depth;  	bool zerocopy = false;  	size_t linear; -	ssize_t n;  	if (q->flags & IFF_VNET_HDR) {  		vnet_hdr_len = q->vnet_hdr_sz; @@ -690,8 +689,7 @@ static ssize_t macvtap_get_user(struct macvtap_queue *q, struct msghdr *m,  		len -= vnet_hdr_len;  		err = -EFAULT; -		n = copy_from_iter(&vnet_hdr, sizeof(vnet_hdr), from); -		if (n != sizeof(vnet_hdr)) +		if (!copy_from_iter_full(&vnet_hdr, sizeof(vnet_hdr), from))  			goto err;  		iov_iter_advance(from, vnet_hdr_len - sizeof(vnet_hdr));  		if ((vnet_hdr.flags & VIRTIO_NET_HDR_F_NEEDS_CSUM) && @@ -826,9 +824,8 @@ static ssize_t macvtap_put_user(struct macvtap_queue *q,  		if (iov_iter_count(iter) < vnet_hdr_len)  			return -EINVAL; -		ret = virtio_net_hdr_from_skb(skb, &vnet_hdr, -					      macvtap_is_little_endian(q)); -		if (ret) +		if (virtio_net_hdr_from_skb(skb, &vnet_hdr, +					    macvtap_is_little_endian(q)))  			BUG();  		if (copy_to_iter(&vnet_hdr, sizeof(vnet_hdr), iter) !=  |