diff options
-rw-r--r-- | include/linux/skbuff.h | 3 | ||||
-rw-r--r-- | include/net/udplite.h | 3 | ||||
-rw-r--r-- | net/ipv4/ip_output.c | 6 | ||||
-rw-r--r-- | net/ipv4/ping.c | 14 | ||||
-rw-r--r-- | net/ipv4/raw.c | 2 | ||||
-rw-r--r-- | net/ipv4/tcp_input.c | 2 | ||||
-rw-r--r-- | net/ipv6/raw.c | 2 |
7 files changed, 14 insertions, 18 deletions
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 9a8bafee1b67..b349c96dc80a 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h | |||
@@ -2692,8 +2692,7 @@ int skb_vlan_push(struct sk_buff *skb, __be16 vlan_proto, u16 vlan_tci); | |||
2692 | 2692 | ||
2693 | static inline int memcpy_from_msg(void *data, struct msghdr *msg, int len) | 2693 | static inline int memcpy_from_msg(void *data, struct msghdr *msg, int len) |
2694 | { | 2694 | { |
2695 | /* XXX: stripping const */ | 2695 | return copy_from_iter(data, len, &msg->msg_iter) == len ? 0 : -EFAULT; |
2696 | return memcpy_fromiovec(data, (struct iovec *)msg->msg_iter.iov, len); | ||
2697 | } | 2696 | } |
2698 | 2697 | ||
2699 | static inline int memcpy_to_msg(struct msghdr *msg, void *data, int len) | 2698 | static inline int memcpy_to_msg(struct msghdr *msg, void *data, int len) |
diff --git a/include/net/udplite.h b/include/net/udplite.h index ae7c8d1fbcad..80761938b9a7 100644 --- a/include/net/udplite.h +++ b/include/net/udplite.h | |||
@@ -20,8 +20,7 @@ static __inline__ int udplite_getfrag(void *from, char *to, int offset, | |||
20 | int len, int odd, struct sk_buff *skb) | 20 | int len, int odd, struct sk_buff *skb) |
21 | { | 21 | { |
22 | struct msghdr *msg = from; | 22 | struct msghdr *msg = from; |
23 | /* XXX: stripping const */ | 23 | return copy_from_iter(to, len, &msg->msg_iter) != len ? -EFAULT : 0; |
24 | return memcpy_fromiovecend(to, (struct iovec *)msg->msg_iter.iov, offset, len); | ||
25 | } | 24 | } |
26 | 25 | ||
27 | /* Designate sk as UDP-Lite socket */ | 26 | /* Designate sk as UDP-Lite socket */ |
diff --git a/net/ipv4/ip_output.c b/net/ipv4/ip_output.c index b50861b22b6b..f998bc87ae38 100644 --- a/net/ipv4/ip_output.c +++ b/net/ipv4/ip_output.c | |||
@@ -755,13 +755,11 @@ ip_generic_getfrag(void *from, char *to, int offset, int len, int odd, struct sk | |||
755 | struct msghdr *msg = from; | 755 | struct msghdr *msg = from; |
756 | 756 | ||
757 | if (skb->ip_summed == CHECKSUM_PARTIAL) { | 757 | if (skb->ip_summed == CHECKSUM_PARTIAL) { |
758 | /* XXX: stripping const */ | 758 | if (copy_from_iter(to, len, &msg->msg_iter) != len) |
759 | if (memcpy_fromiovecend(to, (struct iovec *)msg->msg_iter.iov, offset, len) < 0) | ||
760 | return -EFAULT; | 759 | return -EFAULT; |
761 | } else { | 760 | } else { |
762 | __wsum csum = 0; | 761 | __wsum csum = 0; |
763 | /* XXX: stripping const */ | 762 | if (csum_and_copy_from_iter(to, len, &csum, &msg->msg_iter) != len) |
764 | if (csum_partial_copy_fromiovecend(to, (struct iovec *)msg->msg_iter.iov, offset, len, &csum) < 0) | ||
765 | return -EFAULT; | 763 | return -EFAULT; |
766 | skb->csum = csum_block_add(skb->csum, csum, odd); | 764 | skb->csum = csum_block_add(skb->csum, csum, odd); |
767 | } | 765 | } |
diff --git a/net/ipv4/ping.c b/net/ipv4/ping.c index 9e15ba701401..e9f66e1cda50 100644 --- a/net/ipv4/ping.c +++ b/net/ipv4/ping.c | |||
@@ -599,18 +599,18 @@ int ping_getfrag(void *from, char *to, | |||
599 | struct pingfakehdr *pfh = (struct pingfakehdr *)from; | 599 | struct pingfakehdr *pfh = (struct pingfakehdr *)from; |
600 | 600 | ||
601 | if (offset == 0) { | 601 | if (offset == 0) { |
602 | if (fraglen < sizeof(struct icmphdr)) | 602 | fraglen -= sizeof(struct icmphdr); |
603 | if (fraglen < 0) | ||
603 | BUG(); | 604 | BUG(); |
604 | if (csum_partial_copy_fromiovecend(to + sizeof(struct icmphdr), | 605 | if (csum_and_copy_from_iter(to + sizeof(struct icmphdr), |
605 | pfh->msg->msg_iter.iov, 0, fraglen - sizeof(struct icmphdr), | 606 | fraglen, &pfh->wcheck, |
606 | &pfh->wcheck)) | 607 | &pfh->msg->msg_iter) != fraglen) |
607 | return -EFAULT; | 608 | return -EFAULT; |
608 | } else if (offset < sizeof(struct icmphdr)) { | 609 | } else if (offset < sizeof(struct icmphdr)) { |
609 | BUG(); | 610 | BUG(); |
610 | } else { | 611 | } else { |
611 | if (csum_partial_copy_fromiovecend | 612 | if (csum_and_copy_from_iter(to, fraglen, &pfh->wcheck, |
612 | (to, pfh->msg->msg_iter.iov, offset - sizeof(struct icmphdr), | 613 | &pfh->msg->msg_iter) != fraglen) |
613 | fraglen, &pfh->wcheck)) | ||
614 | return -EFAULT; | 614 | return -EFAULT; |
615 | } | 615 | } |
616 | 616 | ||
diff --git a/net/ipv4/raw.c b/net/ipv4/raw.c index 2c9d252072a2..f027a708b7e0 100644 --- a/net/ipv4/raw.c +++ b/net/ipv4/raw.c | |||
@@ -382,7 +382,7 @@ static int raw_send_hdrinc(struct sock *sk, struct flowi4 *fl4, | |||
382 | 382 | ||
383 | skb->transport_header = skb->network_header; | 383 | skb->transport_header = skb->network_header; |
384 | err = -EFAULT; | 384 | err = -EFAULT; |
385 | if (memcpy_fromiovecend((void *)iph, msg->msg_iter.iov, 0, length)) | 385 | if (memcpy_from_msg(iph, msg, length)) |
386 | goto error_free; | 386 | goto error_free; |
387 | 387 | ||
388 | iphlen = iph->ihl * 4; | 388 | iphlen = iph->ihl * 4; |
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index 93c74829cbce..71fb37c70581 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c | |||
@@ -4368,7 +4368,7 @@ int tcp_send_rcvq(struct sock *sk, struct msghdr *msg, size_t size) | |||
4368 | if (tcp_try_rmem_schedule(sk, skb, skb->truesize)) | 4368 | if (tcp_try_rmem_schedule(sk, skb, skb->truesize)) |
4369 | goto err_free; | 4369 | goto err_free; |
4370 | 4370 | ||
4371 | if (copy_from_iter(skb_put(skb, size), size, &msg->msg_iter) != size) | 4371 | if (memcpy_from_msg(skb_put(skb, size), msg, size)) |
4372 | goto err_free; | 4372 | goto err_free; |
4373 | 4373 | ||
4374 | TCP_SKB_CB(skb)->seq = tcp_sk(sk)->rcv_nxt; | 4374 | TCP_SKB_CB(skb)->seq = tcp_sk(sk)->rcv_nxt; |
diff --git a/net/ipv6/raw.c b/net/ipv6/raw.c index 0dbb328fa688..dae7f1a1e464 100644 --- a/net/ipv6/raw.c +++ b/net/ipv6/raw.c | |||
@@ -648,7 +648,7 @@ static int rawv6_send_hdrinc(struct sock *sk, struct msghdr *msg, int length, | |||
648 | skb->ip_summed = CHECKSUM_NONE; | 648 | skb->ip_summed = CHECKSUM_NONE; |
649 | 649 | ||
650 | skb->transport_header = skb->network_header; | 650 | skb->transport_header = skb->network_header; |
651 | err = memcpy_fromiovecend((void *)iph, msg->msg_iter.iov, 0, length); | 651 | err = memcpy_from_msg(iph, msg, length); |
652 | if (err) | 652 | if (err) |
653 | goto error_fault; | 653 | goto error_fault; |
654 | 654 | ||