net: switch copy_bpf_fprog_from_user to sockptr_t
Pass a sockptr_t to prepare for set_fs-less handling of the kernel pointer from bpf-cgroup. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
ba423fdaa5
commit
b1ea9ff6af
@@ -77,14 +77,14 @@
|
||||
#include <net/transp_v6.h>
|
||||
#include <linux/btf_ids.h>
|
||||
|
||||
int copy_bpf_fprog_from_user(struct sock_fprog *dst, void __user *src, int len)
|
||||
int copy_bpf_fprog_from_user(struct sock_fprog *dst, sockptr_t src, int len)
|
||||
{
|
||||
if (in_compat_syscall()) {
|
||||
struct compat_sock_fprog f32;
|
||||
|
||||
if (len != sizeof(f32))
|
||||
return -EINVAL;
|
||||
if (copy_from_user(&f32, src, sizeof(f32)))
|
||||
if (copy_from_sockptr(&f32, src, sizeof(f32)))
|
||||
return -EFAULT;
|
||||
memset(dst, 0, sizeof(*dst));
|
||||
dst->len = f32.len;
|
||||
@@ -92,7 +92,7 @@ int copy_bpf_fprog_from_user(struct sock_fprog *dst, void __user *src, int len)
|
||||
} else {
|
||||
if (len != sizeof(*dst))
|
||||
return -EINVAL;
|
||||
if (copy_from_user(dst, src, sizeof(*dst)))
|
||||
if (copy_from_sockptr(dst, src, sizeof(*dst)))
|
||||
return -EFAULT;
|
||||
}
|
||||
|
||||
|
@@ -1063,7 +1063,8 @@ set_sndbuf:
|
||||
case SO_ATTACH_FILTER: {
|
||||
struct sock_fprog fprog;
|
||||
|
||||
ret = copy_bpf_fprog_from_user(&fprog, optval, optlen);
|
||||
ret = copy_bpf_fprog_from_user(&fprog, USER_SOCKPTR(optval),
|
||||
optlen);
|
||||
if (!ret)
|
||||
ret = sk_attach_filter(&fprog, sk);
|
||||
break;
|
||||
@@ -1084,7 +1085,8 @@ set_sndbuf:
|
||||
case SO_ATTACH_REUSEPORT_CBPF: {
|
||||
struct sock_fprog fprog;
|
||||
|
||||
ret = copy_bpf_fprog_from_user(&fprog, optval, optlen);
|
||||
ret = copy_bpf_fprog_from_user(&fprog, USER_SOCKPTR(optval),
|
||||
optlen);
|
||||
if (!ret)
|
||||
ret = sk_reuseport_attach_filter(&fprog, sk);
|
||||
break;
|
||||
|
Reference in New Issue
Block a user