diff options
| author | David S. Miller <davem@davemloft.net> | 2015-04-13 18:18:05 -0400 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2015-04-13 18:18:05 -0400 | 
| commit | 6e8a9d9148b6dc2305fcaaf60550b81cbb6319c6 (patch) | |
| tree | 60a235b136b1a3b2d0d7f3eef903fa13c319e1e9 /net/compat.c | |
| parent | 789f558cfb3680aeb52de137418637f6b04b7d22 (diff) | |
| parent | 01e97e6517053d7c0b9af5248e944a9209909cf5 (diff) | |
Merge branch 'for-davem' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Al Viro says:
====================
netdev-related stuff in vfs.git
There are several commits sitting in vfs.git that probably ought to go in
via net-next.git.  First of all, there's merge with vfs.git#iocb - that's
Christoph's aio rework, which has triggered conflicts with the ->sendmsg()
and ->recvmsg() patches a while ago.  It's not so much Christoph's stuff
that ought to be in net-next, as (pretty simple) conflict resolution on merge.
The next chunk is switch to {compat_,}import_iovec/import_single_range - new
safer primitives for initializing iov_iter.  The primitives themselves come
from vfs/git#iov_iter (and they are used quite a lot in vfs part of queue),
conversion of net/socket.c syscalls belongs in net-next, IMO.  Next there's
afs and rxrpc stuff from dhowells.  And then there's sanitizing kernel_sendmsg
et.al.  + missing inlined helper for "how much data is left in msg->msg_iter" -
this stuff is used in e.g.  cifs stuff, but it belongs in net-next.
That pile is pullable from
git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs.git for-davem
I'll post the individual patches in there in followups; could you take a look
and tell if everything in there is OK with you?
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/compat.c')
| -rw-r--r-- | net/compat.c | 18 | 
1 files changed, 7 insertions, 11 deletions
| diff --git a/net/compat.c b/net/compat.c index c4b6b0f43d5d..5cfd26a0006f 100644 --- a/net/compat.c +++ b/net/compat.c @@ -31,10 +31,10 @@  #include <asm/uaccess.h>  #include <net/compat.h> -ssize_t get_compat_msghdr(struct msghdr *kmsg, -			  struct compat_msghdr __user *umsg, -			  struct sockaddr __user **save_addr, -			  struct iovec **iov) +int get_compat_msghdr(struct msghdr *kmsg, +		      struct compat_msghdr __user *umsg, +		      struct sockaddr __user **save_addr, +		      struct iovec **iov)  {  	compat_uptr_t uaddr, uiov, tmp3;  	compat_size_t nr_segs; @@ -81,13 +81,9 @@ ssize_t get_compat_msghdr(struct msghdr *kmsg,  	kmsg->msg_iocb = NULL; -	err = compat_rw_copy_check_uvector(save_addr ? READ : WRITE, -					   compat_ptr(uiov), nr_segs, -					   UIO_FASTIOV, *iov, iov); -	if (err >= 0) -		iov_iter_init(&kmsg->msg_iter, save_addr ? READ : WRITE, -			      *iov, nr_segs, err); -	return err; +	return compat_import_iovec(save_addr ? READ : WRITE, +				   compat_ptr(uiov), nr_segs, +				   UIO_FASTIOV, iov, &kmsg->msg_iter);  }  /* Bleech... */ | 
