#include <linux/net.h>
#include <linux/netdevice.h>
#include <linux/rculist.h>
+#include <linux/uio.h>
#include <linux/vmalloc.h>
#include <net/netdev_queues.h>
};
static int xsk_getsockopt(struct socket *sock, int level, int optname,
- char __user *optval, int __user *optlen)
+ sockopt_t *opt)
{
struct sock *sk = sock->sk;
struct xdp_sock *xs = xdp_sk(sk);
if (level != SOL_XDP)
return -ENOPROTOOPT;
- if (get_user(len, optlen))
- return -EFAULT;
+ len = opt->optlen;
if (len < 0)
return -EINVAL;
stats.tx_invalid_descs = xskq_nb_invalid_descs(xs->tx);
mutex_unlock(&xs->mutex);
- if (copy_to_user(optval, &stats, stats_size))
- return -EFAULT;
- if (put_user(stats_size, optlen))
+ if (copy_to_iter(&stats, stats_size, &opt->iter_out) !=
+ stats_size)
return -EFAULT;
+ opt->optlen = stats_size;
return 0;
}
to_copy = &off_v1;
}
- if (copy_to_user(optval, to_copy, len))
- return -EFAULT;
- if (put_user(len, optlen))
+ if (copy_to_iter(to_copy, len, &opt->iter_out) != len)
return -EFAULT;
+ opt->optlen = len;
return 0;
}
mutex_unlock(&xs->mutex);
len = sizeof(opts);
- if (copy_to_user(optval, &opts, len))
- return -EFAULT;
- if (put_user(len, optlen))
+ if (copy_to_iter(&opts, len, &opt->iter_out) != len)
return -EFAULT;
+ opt->optlen = len;
return 0;
}
.listen = sock_no_listen,
.shutdown = sock_no_shutdown,
.setsockopt = xsk_setsockopt,
- .getsockopt = xsk_getsockopt,
+ .getsockopt_iter = xsk_getsockopt,
.sendmsg = xsk_sendmsg,
.recvmsg = xsk_recvmsg,
.mmap = xsk_mmap,