diff options
Diffstat (limited to 'net/compat.c')
| -rw-r--r-- | net/compat.c | 34 | 
1 files changed, 12 insertions, 22 deletions
| diff --git a/net/compat.c b/net/compat.c index 47a614b370cd..f7084780a8f8 100644 --- a/net/compat.c +++ b/net/compat.c @@ -810,34 +810,23 @@ COMPAT_SYSCALL_DEFINE6(recvfrom, int, fd, void __user *, buf, compat_size_t, len  	return __compat_sys_recvfrom(fd, buf, len, flags, addr, addrlen);  } -static int __compat_sys_recvmmsg(int fd, struct compat_mmsghdr __user *mmsg, -				 unsigned int vlen, unsigned int flags, -				 struct old_timespec32 __user *timeout) +COMPAT_SYSCALL_DEFINE5(recvmmsg_time64, int, fd, struct compat_mmsghdr __user *, mmsg, +		       unsigned int, vlen, unsigned int, flags, +		       struct __kernel_timespec __user *, timeout)  { -	int datagrams; -	struct timespec64 ktspec; - -	if (timeout == NULL) -		return __sys_recvmmsg(fd, (struct mmsghdr __user *)mmsg, vlen, -				      flags | MSG_CMSG_COMPAT, NULL); - -	if (compat_get_timespec64(&ktspec, timeout)) -		return -EFAULT; - -	datagrams = __sys_recvmmsg(fd, (struct mmsghdr __user *)mmsg, vlen, -				   flags | MSG_CMSG_COMPAT, &ktspec); -	if (datagrams > 0 && compat_put_timespec64(&ktspec, timeout)) -		datagrams = -EFAULT; - -	return datagrams; +	return __sys_recvmmsg(fd, (struct mmsghdr __user *)mmsg, vlen, +			      flags | MSG_CMSG_COMPAT, timeout, NULL);  } +#ifdef CONFIG_COMPAT_32BIT_TIME  COMPAT_SYSCALL_DEFINE5(recvmmsg, int, fd, struct compat_mmsghdr __user *, mmsg,  		       unsigned int, vlen, unsigned int, flags,  		       struct old_timespec32 __user *, timeout)  { -	return __compat_sys_recvmmsg(fd, mmsg, vlen, flags, timeout); +	return __sys_recvmmsg(fd, (struct mmsghdr __user *)mmsg, vlen, +			      flags | MSG_CMSG_COMPAT, NULL, timeout);  } +#endif  COMPAT_SYSCALL_DEFINE2(socketcall, int, call, u32 __user *, args)  { @@ -925,8 +914,9 @@ COMPAT_SYSCALL_DEFINE2(socketcall, int, call, u32 __user *, args)  		ret = __compat_sys_recvmsg(a0, compat_ptr(a1), a[2]);  		break;  	case SYS_RECVMMSG: -		ret = __compat_sys_recvmmsg(a0, compat_ptr(a1), a[2], a[3], -					    compat_ptr(a[4])); +		ret = __sys_recvmmsg(a0, compat_ptr(a1), a[2], +				     a[3] | MSG_CMSG_COMPAT, NULL, +				     compat_ptr(a[4]));  		break;  	case SYS_ACCEPT4:  		ret = __sys_accept4(a0, compat_ptr(a1), compat_ptr(a[2]), a[3]); | 
