net: remove compat_sys_{get,set}sockopt
Now that the ->compat_{get,set}sockopt proto_ops methods are gone there is no good reason left to keep the compat syscalls separate. This fixes the odd use of unsigned int for the compat_setsockopt optlen and the missing sock_use_custom_sol_socket. It would also easily allow running the eBPF hooks for the compat syscalls, but such a large change in behavior does not belong into a consolidation patch like this one. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
8c918ffbba
commit
55db9c0e85
@ -599,9 +599,9 @@ __SYSCALL(__NR_recvfrom, compat_sys_recvfrom)
|
|||||||
#define __NR_shutdown 293
|
#define __NR_shutdown 293
|
||||||
__SYSCALL(__NR_shutdown, sys_shutdown)
|
__SYSCALL(__NR_shutdown, sys_shutdown)
|
||||||
#define __NR_setsockopt 294
|
#define __NR_setsockopt 294
|
||||||
__SYSCALL(__NR_setsockopt, compat_sys_setsockopt)
|
__SYSCALL(__NR_setsockopt, sys_setsockopt)
|
||||||
#define __NR_getsockopt 295
|
#define __NR_getsockopt 295
|
||||||
__SYSCALL(__NR_getsockopt, compat_sys_getsockopt)
|
__SYSCALL(__NR_getsockopt, sys_getsockopt)
|
||||||
#define __NR_sendmsg 296
|
#define __NR_sendmsg 296
|
||||||
__SYSCALL(__NR_sendmsg, compat_sys_sendmsg)
|
__SYSCALL(__NR_sendmsg, compat_sys_sendmsg)
|
||||||
#define __NR_recvmsg 297
|
#define __NR_recvmsg 297
|
||||||
|
@ -60,8 +60,8 @@
|
|||||||
50 n32 getsockname sys_getsockname
|
50 n32 getsockname sys_getsockname
|
||||||
51 n32 getpeername sys_getpeername
|
51 n32 getpeername sys_getpeername
|
||||||
52 n32 socketpair sys_socketpair
|
52 n32 socketpair sys_socketpair
|
||||||
53 n32 setsockopt compat_sys_setsockopt
|
53 n32 setsockopt sys_setsockopt
|
||||||
54 n32 getsockopt compat_sys_getsockopt
|
54 n32 getsockopt sys_getsockopt
|
||||||
55 n32 clone __sys_clone
|
55 n32 clone __sys_clone
|
||||||
56 n32 fork __sys_fork
|
56 n32 fork __sys_fork
|
||||||
57 n32 execve compat_sys_execve
|
57 n32 execve compat_sys_execve
|
||||||
|
@ -184,7 +184,7 @@
|
|||||||
170 o32 connect sys_connect
|
170 o32 connect sys_connect
|
||||||
171 o32 getpeername sys_getpeername
|
171 o32 getpeername sys_getpeername
|
||||||
172 o32 getsockname sys_getsockname
|
172 o32 getsockname sys_getsockname
|
||||||
173 o32 getsockopt sys_getsockopt compat_sys_getsockopt
|
173 o32 getsockopt sys_getsockopt sys_getsockopt
|
||||||
174 o32 listen sys_listen
|
174 o32 listen sys_listen
|
||||||
175 o32 recv sys_recv compat_sys_recv
|
175 o32 recv sys_recv compat_sys_recv
|
||||||
176 o32 recvfrom sys_recvfrom compat_sys_recvfrom
|
176 o32 recvfrom sys_recvfrom compat_sys_recvfrom
|
||||||
@ -192,7 +192,7 @@
|
|||||||
178 o32 send sys_send
|
178 o32 send sys_send
|
||||||
179 o32 sendmsg sys_sendmsg compat_sys_sendmsg
|
179 o32 sendmsg sys_sendmsg compat_sys_sendmsg
|
||||||
180 o32 sendto sys_sendto
|
180 o32 sendto sys_sendto
|
||||||
181 o32 setsockopt sys_setsockopt compat_sys_setsockopt
|
181 o32 setsockopt sys_setsockopt sys_setsockopt
|
||||||
182 o32 shutdown sys_shutdown
|
182 o32 shutdown sys_shutdown
|
||||||
183 o32 socket sys_socket
|
183 o32 socket sys_socket
|
||||||
184 o32 socketpair sys_socketpair
|
184 o32 socketpair sys_socketpair
|
||||||
|
@ -198,8 +198,8 @@
|
|||||||
178 common rt_sigqueueinfo sys_rt_sigqueueinfo compat_sys_rt_sigqueueinfo
|
178 common rt_sigqueueinfo sys_rt_sigqueueinfo compat_sys_rt_sigqueueinfo
|
||||||
179 common rt_sigsuspend sys_rt_sigsuspend compat_sys_rt_sigsuspend
|
179 common rt_sigsuspend sys_rt_sigsuspend compat_sys_rt_sigsuspend
|
||||||
180 common chown sys_chown
|
180 common chown sys_chown
|
||||||
181 common setsockopt sys_setsockopt compat_sys_setsockopt
|
181 common setsockopt sys_setsockopt sys_setsockopt
|
||||||
182 common getsockopt sys_getsockopt compat_sys_getsockopt
|
182 common getsockopt sys_getsockopt sys_getsockopt
|
||||||
183 common sendmsg sys_sendmsg compat_sys_sendmsg
|
183 common sendmsg sys_sendmsg compat_sys_sendmsg
|
||||||
184 common recvmsg sys_recvmsg compat_sys_recvmsg
|
184 common recvmsg sys_recvmsg compat_sys_recvmsg
|
||||||
185 common semop sys_semop
|
185 common semop sys_semop
|
||||||
|
@ -433,8 +433,8 @@
|
|||||||
336 common recv sys_recv compat_sys_recv
|
336 common recv sys_recv compat_sys_recv
|
||||||
337 common recvfrom sys_recvfrom compat_sys_recvfrom
|
337 common recvfrom sys_recvfrom compat_sys_recvfrom
|
||||||
338 common shutdown sys_shutdown
|
338 common shutdown sys_shutdown
|
||||||
339 common setsockopt sys_setsockopt compat_sys_setsockopt
|
339 common setsockopt sys_setsockopt sys_setsockopt
|
||||||
340 common getsockopt sys_getsockopt compat_sys_getsockopt
|
340 common getsockopt sys_getsockopt sys_getsockopt
|
||||||
341 common sendmsg sys_sendmsg compat_sys_sendmsg
|
341 common sendmsg sys_sendmsg compat_sys_sendmsg
|
||||||
342 common recvmsg sys_recvmsg compat_sys_recvmsg
|
342 common recvmsg sys_recvmsg compat_sys_recvmsg
|
||||||
343 32 recvmmsg sys_recvmmsg_time32 compat_sys_recvmmsg_time32
|
343 32 recvmmsg sys_recvmmsg_time32 compat_sys_recvmmsg_time32
|
||||||
|
@ -372,8 +372,8 @@
|
|||||||
362 common connect sys_connect sys_connect
|
362 common connect sys_connect sys_connect
|
||||||
363 common listen sys_listen sys_listen
|
363 common listen sys_listen sys_listen
|
||||||
364 common accept4 sys_accept4 sys_accept4
|
364 common accept4 sys_accept4 sys_accept4
|
||||||
365 common getsockopt sys_getsockopt compat_sys_getsockopt
|
365 common getsockopt sys_getsockopt sys_getsockopt
|
||||||
366 common setsockopt sys_setsockopt compat_sys_setsockopt
|
366 common setsockopt sys_setsockopt sys_setsockopt
|
||||||
367 common getsockname sys_getsockname sys_getsockname
|
367 common getsockname sys_getsockname sys_getsockname
|
||||||
368 common getpeername sys_getpeername sys_getpeername
|
368 common getpeername sys_getpeername sys_getpeername
|
||||||
369 common sendto sys_sendto sys_sendto
|
369 common sendto sys_sendto sys_sendto
|
||||||
|
@ -157,22 +157,22 @@ do_sys_shutdown: /* sys_shutdown(int, int) */
|
|||||||
nop
|
nop
|
||||||
nop
|
nop
|
||||||
nop
|
nop
|
||||||
do_sys_setsockopt: /* compat_sys_setsockopt(int, int, int, char *, int) */
|
do_sys_setsockopt: /* sys_setsockopt(int, int, int, char *, int) */
|
||||||
47: ldswa [%o1 + 0x0] %asi, %o0
|
47: ldswa [%o1 + 0x0] %asi, %o0
|
||||||
sethi %hi(compat_sys_setsockopt), %g1
|
sethi %hi(sys_setsockopt), %g1
|
||||||
48: ldswa [%o1 + 0x8] %asi, %o2
|
48: ldswa [%o1 + 0x8] %asi, %o2
|
||||||
49: lduwa [%o1 + 0xc] %asi, %o3
|
49: lduwa [%o1 + 0xc] %asi, %o3
|
||||||
50: ldswa [%o1 + 0x10] %asi, %o4
|
50: ldswa [%o1 + 0x10] %asi, %o4
|
||||||
jmpl %g1 + %lo(compat_sys_setsockopt), %g0
|
jmpl %g1 + %lo(sys_setsockopt), %g0
|
||||||
51: ldswa [%o1 + 0x4] %asi, %o1
|
51: ldswa [%o1 + 0x4] %asi, %o1
|
||||||
nop
|
nop
|
||||||
do_sys_getsockopt: /* compat_sys_getsockopt(int, int, int, u32, u32) */
|
do_sys_getsockopt: /* sys_getsockopt(int, int, int, u32, u32) */
|
||||||
52: ldswa [%o1 + 0x0] %asi, %o0
|
52: ldswa [%o1 + 0x0] %asi, %o0
|
||||||
sethi %hi(compat_sys_getsockopt), %g1
|
sethi %hi(sys_getsockopt), %g1
|
||||||
53: ldswa [%o1 + 0x8] %asi, %o2
|
53: ldswa [%o1 + 0x8] %asi, %o2
|
||||||
54: lduwa [%o1 + 0xc] %asi, %o3
|
54: lduwa [%o1 + 0xc] %asi, %o3
|
||||||
55: lduwa [%o1 + 0x10] %asi, %o4
|
55: lduwa [%o1 + 0x10] %asi, %o4
|
||||||
jmpl %g1 + %lo(compat_sys_getsockopt), %g0
|
jmpl %g1 + %lo(sys_getsockopt), %g0
|
||||||
56: ldswa [%o1 + 0x4] %asi, %o1
|
56: ldswa [%o1 + 0x4] %asi, %o1
|
||||||
nop
|
nop
|
||||||
do_sys_sendmsg: /* compat_sys_sendmsg(int, struct compat_msghdr *, unsigned int) */
|
do_sys_sendmsg: /* compat_sys_sendmsg(int, struct compat_msghdr *, unsigned int) */
|
||||||
|
@ -147,7 +147,7 @@
|
|||||||
115 32 getgroups32 sys_getgroups
|
115 32 getgroups32 sys_getgroups
|
||||||
116 common gettimeofday sys_gettimeofday compat_sys_gettimeofday
|
116 common gettimeofday sys_gettimeofday compat_sys_gettimeofday
|
||||||
117 common getrusage sys_getrusage compat_sys_getrusage
|
117 common getrusage sys_getrusage compat_sys_getrusage
|
||||||
118 common getsockopt sys_getsockopt compat_sys_getsockopt
|
118 common getsockopt sys_getsockopt sys_getsockopt
|
||||||
119 common getcwd sys_getcwd
|
119 common getcwd sys_getcwd
|
||||||
120 common readv sys_readv compat_sys_readv
|
120 common readv sys_readv compat_sys_readv
|
||||||
121 common writev sys_writev compat_sys_writev
|
121 common writev sys_writev compat_sys_writev
|
||||||
@ -425,7 +425,7 @@
|
|||||||
352 common userfaultfd sys_userfaultfd
|
352 common userfaultfd sys_userfaultfd
|
||||||
353 common bind sys_bind
|
353 common bind sys_bind
|
||||||
354 common listen sys_listen
|
354 common listen sys_listen
|
||||||
355 common setsockopt sys_setsockopt compat_sys_setsockopt
|
355 common setsockopt sys_setsockopt sys_setsockopt
|
||||||
356 common mlock2 sys_mlock2
|
356 common mlock2 sys_mlock2
|
||||||
357 common copy_file_range sys_copy_file_range
|
357 common copy_file_range sys_copy_file_range
|
||||||
358 common preadv2 sys_preadv2 compat_sys_preadv2
|
358 common preadv2 sys_preadv2 compat_sys_preadv2
|
||||||
|
@ -8,6 +8,13 @@
|
|||||||
#include <asm/unistd.h>
|
#include <asm/unistd.h>
|
||||||
#include <asm/syscall.h>
|
#include <asm/syscall.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Reuse the 64-bit entry points for the x32 versions that occupy different
|
||||||
|
* slots in the syscall table.
|
||||||
|
*/
|
||||||
|
#define __x32_sys_getsockopt __x64_sys_getsockopt
|
||||||
|
#define __x32_sys_setsockopt __x64_sys_setsockopt
|
||||||
|
|
||||||
#define __SYSCALL_64(nr, sym)
|
#define __SYSCALL_64(nr, sym)
|
||||||
|
|
||||||
#define __SYSCALL_X32(nr, sym) extern long __x32_##sym(const struct pt_regs *);
|
#define __SYSCALL_X32(nr, sym) extern long __x32_##sym(const struct pt_regs *);
|
||||||
|
@ -376,8 +376,8 @@
|
|||||||
362 i386 connect sys_connect
|
362 i386 connect sys_connect
|
||||||
363 i386 listen sys_listen
|
363 i386 listen sys_listen
|
||||||
364 i386 accept4 sys_accept4
|
364 i386 accept4 sys_accept4
|
||||||
365 i386 getsockopt sys_getsockopt compat_sys_getsockopt
|
365 i386 getsockopt sys_getsockopt sys_getsockopt
|
||||||
366 i386 setsockopt sys_setsockopt compat_sys_setsockopt
|
366 i386 setsockopt sys_setsockopt sys_setsockopt
|
||||||
367 i386 getsockname sys_getsockname
|
367 i386 getsockname sys_getsockname
|
||||||
368 i386 getpeername sys_getpeername
|
368 i386 getpeername sys_getpeername
|
||||||
369 i386 sendto sys_sendto
|
369 i386 sendto sys_sendto
|
||||||
|
@ -396,8 +396,8 @@
|
|||||||
538 x32 sendmmsg compat_sys_sendmmsg
|
538 x32 sendmmsg compat_sys_sendmmsg
|
||||||
539 x32 process_vm_readv compat_sys_process_vm_readv
|
539 x32 process_vm_readv compat_sys_process_vm_readv
|
||||||
540 x32 process_vm_writev compat_sys_process_vm_writev
|
540 x32 process_vm_writev compat_sys_process_vm_writev
|
||||||
541 x32 setsockopt compat_sys_setsockopt
|
541 x32 setsockopt sys_setsockopt
|
||||||
542 x32 getsockopt compat_sys_getsockopt
|
542 x32 getsockopt sys_getsockopt
|
||||||
543 x32 io_setup compat_sys_io_setup
|
543 x32 io_setup compat_sys_io_setup
|
||||||
544 x32 io_submit compat_sys_io_submit
|
544 x32 io_submit compat_sys_io_submit
|
||||||
545 x32 execveat compat_sys_execveat
|
545 x32 execveat compat_sys_execveat
|
||||||
|
@ -737,10 +737,6 @@ asmlinkage long compat_sys_shmat(int shmid, compat_uptr_t shmaddr, int shmflg);
|
|||||||
asmlinkage long compat_sys_recvfrom(int fd, void __user *buf, compat_size_t len,
|
asmlinkage long compat_sys_recvfrom(int fd, void __user *buf, compat_size_t len,
|
||||||
unsigned flags, struct sockaddr __user *addr,
|
unsigned flags, struct sockaddr __user *addr,
|
||||||
int __user *addrlen);
|
int __user *addrlen);
|
||||||
asmlinkage long compat_sys_setsockopt(int fd, int level, int optname,
|
|
||||||
char __user *optval, unsigned int optlen);
|
|
||||||
asmlinkage long compat_sys_getsockopt(int fd, int level, int optname,
|
|
||||||
char __user *optval, int __user *optlen);
|
|
||||||
asmlinkage long compat_sys_sendmsg(int fd, struct compat_msghdr __user *msg,
|
asmlinkage long compat_sys_sendmsg(int fd, struct compat_msghdr __user *msg,
|
||||||
unsigned flags);
|
unsigned flags);
|
||||||
asmlinkage long compat_sys_recvmsg(int fd, struct compat_msghdr __user *msg,
|
asmlinkage long compat_sys_recvmsg(int fd, struct compat_msghdr __user *msg,
|
||||||
|
@ -1424,4 +1424,8 @@ long compat_ksys_semtimedop(int semid, struct sembuf __user *tsems,
|
|||||||
unsigned int nsops,
|
unsigned int nsops,
|
||||||
const struct old_timespec32 __user *timeout);
|
const struct old_timespec32 __user *timeout);
|
||||||
|
|
||||||
|
int __sys_getsockopt(int fd, int level, int optname, char __user *optval,
|
||||||
|
int __user *optlen);
|
||||||
|
int __sys_setsockopt(int fd, int level, int optname, char __user *optval,
|
||||||
|
int optlen);
|
||||||
#endif
|
#endif
|
||||||
|
@ -606,9 +606,9 @@ __SYSCALL(__NR_sendto, sys_sendto)
|
|||||||
#define __NR_recvfrom 207
|
#define __NR_recvfrom 207
|
||||||
__SC_COMP(__NR_recvfrom, sys_recvfrom, compat_sys_recvfrom)
|
__SC_COMP(__NR_recvfrom, sys_recvfrom, compat_sys_recvfrom)
|
||||||
#define __NR_setsockopt 208
|
#define __NR_setsockopt 208
|
||||||
__SC_COMP(__NR_setsockopt, sys_setsockopt, compat_sys_setsockopt)
|
__SC_COMP(__NR_setsockopt, sys_setsockopt, sys_setsockopt)
|
||||||
#define __NR_getsockopt 209
|
#define __NR_getsockopt 209
|
||||||
__SC_COMP(__NR_getsockopt, sys_getsockopt, compat_sys_getsockopt)
|
__SC_COMP(__NR_getsockopt, sys_getsockopt, sys_getsockopt)
|
||||||
#define __NR_shutdown 210
|
#define __NR_shutdown 210
|
||||||
__SYSCALL(__NR_shutdown, sys_shutdown)
|
__SYSCALL(__NR_shutdown, sys_shutdown)
|
||||||
#define __NR_sendmsg 211
|
#define __NR_sendmsg 211
|
||||||
|
79
net/compat.c
79
net/compat.c
@ -335,77 +335,6 @@ void scm_detach_fds_compat(struct msghdr *kmsg, struct scm_cookie *scm)
|
|||||||
__scm_destroy(scm);
|
__scm_destroy(scm);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __compat_sys_setsockopt(int fd, int level, int optname,
|
|
||||||
char __user *optval, unsigned int optlen)
|
|
||||||
{
|
|
||||||
int err;
|
|
||||||
struct socket *sock;
|
|
||||||
|
|
||||||
if (optlen > INT_MAX)
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
sock = sockfd_lookup(fd, &err);
|
|
||||||
if (sock) {
|
|
||||||
err = security_socket_setsockopt(sock, level, optname);
|
|
||||||
if (err) {
|
|
||||||
sockfd_put(sock);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (level == SOL_SOCKET)
|
|
||||||
err = sock_setsockopt(sock, level,
|
|
||||||
optname, optval, optlen);
|
|
||||||
else if (sock->ops->compat_setsockopt)
|
|
||||||
err = sock->ops->compat_setsockopt(sock, level,
|
|
||||||
optname, optval, optlen);
|
|
||||||
else
|
|
||||||
err = sock->ops->setsockopt(sock, level,
|
|
||||||
optname, optval, optlen);
|
|
||||||
sockfd_put(sock);
|
|
||||||
}
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
COMPAT_SYSCALL_DEFINE5(setsockopt, int, fd, int, level, int, optname,
|
|
||||||
char __user *, optval, unsigned int, optlen)
|
|
||||||
{
|
|
||||||
return __compat_sys_setsockopt(fd, level, optname, optval, optlen);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int __compat_sys_getsockopt(int fd, int level, int optname,
|
|
||||||
char __user *optval,
|
|
||||||
int __user *optlen)
|
|
||||||
{
|
|
||||||
int err;
|
|
||||||
struct socket *sock = sockfd_lookup(fd, &err);
|
|
||||||
|
|
||||||
if (sock) {
|
|
||||||
err = security_socket_getsockopt(sock, level, optname);
|
|
||||||
if (err) {
|
|
||||||
sockfd_put(sock);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (level == SOL_SOCKET)
|
|
||||||
err = sock_getsockopt(sock, level,
|
|
||||||
optname, optval, optlen);
|
|
||||||
else if (sock->ops->compat_getsockopt)
|
|
||||||
err = sock->ops->compat_getsockopt(sock, level,
|
|
||||||
optname, optval, optlen);
|
|
||||||
else
|
|
||||||
err = sock->ops->getsockopt(sock, level,
|
|
||||||
optname, optval, optlen);
|
|
||||||
sockfd_put(sock);
|
|
||||||
}
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
COMPAT_SYSCALL_DEFINE5(getsockopt, int, fd, int, level, int, optname,
|
|
||||||
char __user *, optval, int __user *, optlen)
|
|
||||||
{
|
|
||||||
return __compat_sys_getsockopt(fd, level, optname, optval, optlen);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Argument list sizes for compat_sys_socketcall */
|
/* Argument list sizes for compat_sys_socketcall */
|
||||||
#define AL(x) ((x) * sizeof(u32))
|
#define AL(x) ((x) * sizeof(u32))
|
||||||
static unsigned char nas[21] = {
|
static unsigned char nas[21] = {
|
||||||
@ -565,13 +494,11 @@ COMPAT_SYSCALL_DEFINE2(socketcall, int, call, u32 __user *, args)
|
|||||||
ret = __sys_shutdown(a0, a1);
|
ret = __sys_shutdown(a0, a1);
|
||||||
break;
|
break;
|
||||||
case SYS_SETSOCKOPT:
|
case SYS_SETSOCKOPT:
|
||||||
ret = __compat_sys_setsockopt(a0, a1, a[2],
|
ret = __sys_setsockopt(a0, a1, a[2], compat_ptr(a[3]), a[4]);
|
||||||
compat_ptr(a[3]), a[4]);
|
|
||||||
break;
|
break;
|
||||||
case SYS_GETSOCKOPT:
|
case SYS_GETSOCKOPT:
|
||||||
ret = __compat_sys_getsockopt(a0, a1, a[2],
|
ret = __sys_getsockopt(a0, a1, a[2], compat_ptr(a[3]),
|
||||||
compat_ptr(a[3]),
|
compat_ptr(a[4]));
|
||||||
compat_ptr(a[4]));
|
|
||||||
break;
|
break;
|
||||||
case SYS_SENDMSG:
|
case SYS_SENDMSG:
|
||||||
ret = __compat_sys_sendmsg(a0, compat_ptr(a1), a[2]);
|
ret = __compat_sys_sendmsg(a0, compat_ptr(a1), a[2]);
|
||||||
|
25
net/socket.c
25
net/socket.c
@ -2094,9 +2094,8 @@ static bool sock_use_custom_sol_socket(const struct socket *sock)
|
|||||||
* Set a socket option. Because we don't know the option lengths we have
|
* Set a socket option. Because we don't know the option lengths we have
|
||||||
* to pass the user mode parameter for the protocols to sort out.
|
* to pass the user mode parameter for the protocols to sort out.
|
||||||
*/
|
*/
|
||||||
|
int __sys_setsockopt(int fd, int level, int optname, char __user *optval,
|
||||||
static int __sys_setsockopt(int fd, int level, int optname,
|
int optlen)
|
||||||
char __user *optval, int optlen)
|
|
||||||
{
|
{
|
||||||
mm_segment_t oldfs = get_fs();
|
mm_segment_t oldfs = get_fs();
|
||||||
char *kernel_optval = NULL;
|
char *kernel_optval = NULL;
|
||||||
@ -2114,8 +2113,10 @@ static int __sys_setsockopt(int fd, int level, int optname,
|
|||||||
if (err)
|
if (err)
|
||||||
goto out_put;
|
goto out_put;
|
||||||
|
|
||||||
err = BPF_CGROUP_RUN_PROG_SETSOCKOPT(sock->sk, &level, &optname,
|
if (!in_compat_syscall())
|
||||||
optval, &optlen, &kernel_optval);
|
err = BPF_CGROUP_RUN_PROG_SETSOCKOPT(sock->sk, &level, &optname,
|
||||||
|
optval, &optlen,
|
||||||
|
&kernel_optval);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto out_put;
|
goto out_put;
|
||||||
if (err > 0) {
|
if (err > 0) {
|
||||||
@ -2154,9 +2155,8 @@ SYSCALL_DEFINE5(setsockopt, int, fd, int, level, int, optname,
|
|||||||
* Get a socket option. Because we don't know the option lengths we have
|
* Get a socket option. Because we don't know the option lengths we have
|
||||||
* to pass a user mode parameter for the protocols to sort out.
|
* to pass a user mode parameter for the protocols to sort out.
|
||||||
*/
|
*/
|
||||||
|
int __sys_getsockopt(int fd, int level, int optname, char __user *optval,
|
||||||
static int __sys_getsockopt(int fd, int level, int optname,
|
int __user *optlen)
|
||||||
char __user *optval, int __user *optlen)
|
|
||||||
{
|
{
|
||||||
int err, fput_needed;
|
int err, fput_needed;
|
||||||
struct socket *sock;
|
struct socket *sock;
|
||||||
@ -2170,7 +2170,8 @@ static int __sys_getsockopt(int fd, int level, int optname,
|
|||||||
if (err)
|
if (err)
|
||||||
goto out_put;
|
goto out_put;
|
||||||
|
|
||||||
max_optlen = BPF_CGROUP_GETSOCKOPT_MAX_OPTLEN(optlen);
|
if (!in_compat_syscall())
|
||||||
|
max_optlen = BPF_CGROUP_GETSOCKOPT_MAX_OPTLEN(optlen);
|
||||||
|
|
||||||
if (level == SOL_SOCKET)
|
if (level == SOL_SOCKET)
|
||||||
err = sock_getsockopt(sock, level, optname, optval, optlen);
|
err = sock_getsockopt(sock, level, optname, optval, optlen);
|
||||||
@ -2178,8 +2179,10 @@ static int __sys_getsockopt(int fd, int level, int optname,
|
|||||||
err = sock->ops->getsockopt(sock, level, optname, optval,
|
err = sock->ops->getsockopt(sock, level, optname, optval,
|
||||||
optlen);
|
optlen);
|
||||||
|
|
||||||
err = BPF_CGROUP_RUN_PROG_GETSOCKOPT(sock->sk, level, optname, optval,
|
if (!in_compat_syscall())
|
||||||
optlen, max_optlen, err);
|
err = BPF_CGROUP_RUN_PROG_GETSOCKOPT(sock->sk, level, optname,
|
||||||
|
optval, optlen, max_optlen,
|
||||||
|
err);
|
||||||
out_put:
|
out_put:
|
||||||
fput_light(sock->file, fput_needed);
|
fput_light(sock->file, fput_needed);
|
||||||
return err;
|
return err;
|
||||||
|
@ -606,9 +606,9 @@ __SYSCALL(__NR_sendto, sys_sendto)
|
|||||||
#define __NR_recvfrom 207
|
#define __NR_recvfrom 207
|
||||||
__SC_COMP(__NR_recvfrom, sys_recvfrom, compat_sys_recvfrom)
|
__SC_COMP(__NR_recvfrom, sys_recvfrom, compat_sys_recvfrom)
|
||||||
#define __NR_setsockopt 208
|
#define __NR_setsockopt 208
|
||||||
__SC_COMP(__NR_setsockopt, sys_setsockopt, compat_sys_setsockopt)
|
__SC_COMP(__NR_setsockopt, sys_setsockopt, sys_setsockopt)
|
||||||
#define __NR_getsockopt 209
|
#define __NR_getsockopt 209
|
||||||
__SC_COMP(__NR_getsockopt, sys_getsockopt, compat_sys_getsockopt)
|
__SC_COMP(__NR_getsockopt, sys_getsockopt, sys_getsockopt)
|
||||||
#define __NR_shutdown 210
|
#define __NR_shutdown 210
|
||||||
__SYSCALL(__NR_shutdown, sys_shutdown)
|
__SYSCALL(__NR_shutdown, sys_shutdown)
|
||||||
#define __NR_sendmsg 211
|
#define __NR_sendmsg 211
|
||||||
|
@ -427,8 +427,8 @@
|
|||||||
336 common recv sys_recv compat_sys_recv
|
336 common recv sys_recv compat_sys_recv
|
||||||
337 common recvfrom sys_recvfrom compat_sys_recvfrom
|
337 common recvfrom sys_recvfrom compat_sys_recvfrom
|
||||||
338 common shutdown sys_shutdown
|
338 common shutdown sys_shutdown
|
||||||
339 common setsockopt sys_setsockopt compat_sys_setsockopt
|
339 common setsockopt sys_setsockopt sys_setsockopt
|
||||||
340 common getsockopt sys_getsockopt compat_sys_getsockopt
|
340 common getsockopt sys_getsockopt sys_getsockopt
|
||||||
341 common sendmsg sys_sendmsg compat_sys_sendmsg
|
341 common sendmsg sys_sendmsg compat_sys_sendmsg
|
||||||
342 common recvmsg sys_recvmsg compat_sys_recvmsg
|
342 common recvmsg sys_recvmsg compat_sys_recvmsg
|
||||||
343 32 recvmmsg sys_recvmmsg_time32 compat_sys_recvmmsg_time32
|
343 32 recvmmsg sys_recvmmsg_time32 compat_sys_recvmmsg_time32
|
||||||
|
@ -372,8 +372,8 @@
|
|||||||
362 common connect sys_connect compat_sys_connect
|
362 common connect sys_connect compat_sys_connect
|
||||||
363 common listen sys_listen sys_listen
|
363 common listen sys_listen sys_listen
|
||||||
364 common accept4 sys_accept4 compat_sys_accept4
|
364 common accept4 sys_accept4 compat_sys_accept4
|
||||||
365 common getsockopt sys_getsockopt compat_sys_getsockopt
|
365 common getsockopt sys_getsockopt sys_getsockopt
|
||||||
366 common setsockopt sys_setsockopt compat_sys_setsockopt
|
366 common setsockopt sys_setsockopt sys_setsockopt
|
||||||
367 common getsockname sys_getsockname compat_sys_getsockname
|
367 common getsockname sys_getsockname compat_sys_getsockname
|
||||||
368 common getpeername sys_getpeername compat_sys_getpeername
|
368 common getpeername sys_getpeername compat_sys_getpeername
|
||||||
369 common sendto sys_sendto compat_sys_sendto
|
369 common sendto sys_sendto compat_sys_sendto
|
||||||
|
@ -396,8 +396,8 @@
|
|||||||
538 x32 sendmmsg compat_sys_sendmmsg
|
538 x32 sendmmsg compat_sys_sendmmsg
|
||||||
539 x32 process_vm_readv compat_sys_process_vm_readv
|
539 x32 process_vm_readv compat_sys_process_vm_readv
|
||||||
540 x32 process_vm_writev compat_sys_process_vm_writev
|
540 x32 process_vm_writev compat_sys_process_vm_writev
|
||||||
541 x32 setsockopt compat_sys_setsockopt
|
541 x32 setsockopt sys_setsockopt
|
||||||
542 x32 getsockopt compat_sys_getsockopt
|
542 x32 getsockopt sys_getsockopt
|
||||||
543 x32 io_setup compat_sys_io_setup
|
543 x32 io_setup compat_sys_io_setup
|
||||||
544 x32 io_submit compat_sys_io_submit
|
544 x32 io_submit compat_sys_io_submit
|
||||||
545 x32 execveat compat_sys_execveat
|
545 x32 execveat compat_sys_execveat
|
||||||
|
Loading…
x
Reference in New Issue
Block a user