Skip to content

Commit 894cfbc

Browse files
Christoph Hellwigdavem330
authored andcommitted
net/ipv6: switch do_ipv6_setsockopt 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 <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent b84d2b7 commit 894cfbc

File tree

1 file changed

+33
-33
lines changed

1 file changed

+33
-33
lines changed

net/ipv6/ipv6_sockglue.c

Lines changed: 33 additions & 33 deletions
Original file line numberDiff line numberDiff line change
@@ -136,37 +136,37 @@ static bool setsockopt_needs_rtnl(int optname)
136136
return false;
137137
}
138138

139-
static int copy_group_source_from_user(struct group_source_req *greqs,
140-
void __user *optval, int optlen)
139+
static int copy_group_source_from_sockptr(struct group_source_req *greqs,
140+
sockptr_t optval, int optlen)
141141
{
142142
if (in_compat_syscall()) {
143143
struct compat_group_source_req gr32;
144144

145145
if (optlen < sizeof(gr32))
146146
return -EINVAL;
147-
if (copy_from_user(&gr32, optval, sizeof(gr32)))
147+
if (copy_from_sockptr(&gr32, optval, sizeof(gr32)))
148148
return -EFAULT;
149149
greqs->gsr_interface = gr32.gsr_interface;
150150
greqs->gsr_group = gr32.gsr_group;
151151
greqs->gsr_source = gr32.gsr_source;
152152
} else {
153153
if (optlen < sizeof(*greqs))
154154
return -EINVAL;
155-
if (copy_from_user(greqs, optval, sizeof(*greqs)))
155+
if (copy_from_sockptr(greqs, optval, sizeof(*greqs)))
156156
return -EFAULT;
157157
}
158158

159159
return 0;
160160
}
161161

162162
static int do_ipv6_mcast_group_source(struct sock *sk, int optname,
163-
void __user *optval, int optlen)
163+
sockptr_t optval, int optlen)
164164
{
165165
struct group_source_req greqs;
166166
int omode, add;
167167
int ret;
168168

169-
ret = copy_group_source_from_user(&greqs, optval, optlen);
169+
ret = copy_group_source_from_sockptr(&greqs, optval, optlen);
170170
if (ret)
171171
return ret;
172172

@@ -200,7 +200,7 @@ static int do_ipv6_mcast_group_source(struct sock *sk, int optname,
200200
return ip6_mc_source(add, omode, sk, &greqs);
201201
}
202202

203-
static int ipv6_set_mcast_msfilter(struct sock *sk, void __user *optval,
203+
static int ipv6_set_mcast_msfilter(struct sock *sk, sockptr_t optval,
204204
int optlen)
205205
{
206206
struct group_filter *gsf;
@@ -211,7 +211,7 @@ static int ipv6_set_mcast_msfilter(struct sock *sk, void __user *optval,
211211
if (optlen > sysctl_optmem_max)
212212
return -ENOBUFS;
213213

214-
gsf = memdup_user(optval, optlen);
214+
gsf = memdup_sockptr(optval, optlen);
215215
if (IS_ERR(gsf))
216216
return PTR_ERR(gsf);
217217

@@ -231,7 +231,7 @@ static int ipv6_set_mcast_msfilter(struct sock *sk, void __user *optval,
231231
return ret;
232232
}
233233

234-
static int compat_ipv6_set_mcast_msfilter(struct sock *sk, void __user *optval,
234+
static int compat_ipv6_set_mcast_msfilter(struct sock *sk, sockptr_t optval,
235235
int optlen)
236236
{
237237
const int size0 = offsetof(struct compat_group_filter, gf_slist);
@@ -251,7 +251,7 @@ static int compat_ipv6_set_mcast_msfilter(struct sock *sk, void __user *optval,
251251

252252
gf32 = p + 4; /* we want ->gf_group and ->gf_slist aligned */
253253
ret = -EFAULT;
254-
if (copy_from_user(gf32, optval, optlen))
254+
if (copy_from_sockptr(gf32, optval, optlen))
255255
goto out_free_p;
256256

257257
/* numsrc >= (4G-140)/128 overflow in 32 bits */
@@ -276,14 +276,14 @@ static int compat_ipv6_set_mcast_msfilter(struct sock *sk, void __user *optval,
276276
}
277277

278278
static int ipv6_mcast_join_leave(struct sock *sk, int optname,
279-
void __user *optval, int optlen)
279+
sockptr_t optval, int optlen)
280280
{
281281
struct sockaddr_in6 *psin6;
282282
struct group_req greq;
283283

284284
if (optlen < sizeof(greq))
285285
return -EINVAL;
286-
if (copy_from_user(&greq, optval, sizeof(greq)))
286+
if (copy_from_sockptr(&greq, optval, sizeof(greq)))
287287
return -EFAULT;
288288

289289
if (greq.gr_group.ss_family != AF_INET6)
@@ -296,14 +296,14 @@ static int ipv6_mcast_join_leave(struct sock *sk, int optname,
296296
}
297297

298298
static int compat_ipv6_mcast_join_leave(struct sock *sk, int optname,
299-
void __user *optval, int optlen)
299+
sockptr_t optval, int optlen)
300300
{
301301
struct compat_group_req gr32;
302302
struct sockaddr_in6 *psin6;
303303

304304
if (optlen < sizeof(gr32))
305305
return -EINVAL;
306-
if (copy_from_user(&gr32, optval, sizeof(gr32)))
306+
if (copy_from_sockptr(&gr32, optval, sizeof(gr32)))
307307
return -EFAULT;
308308

309309
if (gr32.gr_group.ss_family != AF_INET6)
@@ -315,7 +315,7 @@ static int compat_ipv6_mcast_join_leave(struct sock *sk, int optname,
315315
return ipv6_sock_mc_drop(sk, gr32.gr_interface, &psin6->sin6_addr);
316316
}
317317

318-
static int ipv6_set_opt_hdr(struct sock *sk, int optname, void __user *optval,
318+
static int ipv6_set_opt_hdr(struct sock *sk, int optname, sockptr_t optval,
319319
int optlen)
320320
{
321321
struct ipv6_pinfo *np = inet6_sk(sk);
@@ -332,14 +332,14 @@ static int ipv6_set_opt_hdr(struct sock *sk, int optname, void __user *optval,
332332
* length, per RFC3542.
333333
*/
334334
if (optlen > 0) {
335-
if (!optval)
335+
if (sockptr_is_null(optval))
336336
return -EINVAL;
337337
if (optlen < sizeof(struct ipv6_opt_hdr) ||
338338
optlen & 0x7 ||
339339
optlen > 8 * 255)
340340
return -EINVAL;
341341

342-
new = memdup_user(optval, optlen);
342+
new = memdup_sockptr(optval, optlen);
343343
if (IS_ERR(new))
344344
return PTR_ERR(new);
345345
if (unlikely(ipv6_optlen(new) > optlen)) {
@@ -390,19 +390,19 @@ static int ipv6_set_opt_hdr(struct sock *sk, int optname, void __user *optval,
390390
}
391391

392392
static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
393-
char __user *optval, unsigned int optlen)
393+
sockptr_t optval, unsigned int optlen)
394394
{
395395
struct ipv6_pinfo *np = inet6_sk(sk);
396396
struct net *net = sock_net(sk);
397397
int val, valbool;
398398
int retv = -ENOPROTOOPT;
399399
bool needs_rtnl = setsockopt_needs_rtnl(optname);
400400

401-
if (!optval)
401+
if (sockptr_is_null(optval))
402402
val = 0;
403403
else {
404404
if (optlen >= sizeof(int)) {
405-
if (get_user(val, (int __user *) optval))
405+
if (copy_from_sockptr(&val, optval, sizeof(val)))
406406
return -EFAULT;
407407
} else
408408
val = 0;
@@ -411,8 +411,7 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
411411
valbool = (val != 0);
412412

413413
if (ip6_mroute_opt(optname))
414-
return ip6_mroute_setsockopt(sk, optname, USER_SOCKPTR(optval),
415-
optlen);
414+
return ip6_mroute_setsockopt(sk, optname, optval, optlen);
416415

417416
if (needs_rtnl)
418417
rtnl_lock();
@@ -663,12 +662,13 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
663662

664663
if (optlen == 0)
665664
goto e_inval;
666-
else if (optlen < sizeof(struct in6_pktinfo) || !optval)
665+
else if (optlen < sizeof(struct in6_pktinfo) ||
666+
sockptr_is_null(optval))
667667
goto e_inval;
668668

669-
if (copy_from_user(&pkt, optval, sizeof(struct in6_pktinfo))) {
670-
retv = -EFAULT;
671-
break;
669+
if (copy_from_sockptr(&pkt, optval, sizeof(pkt))) {
670+
retv = -EFAULT;
671+
break;
672672
}
673673
if (!sk_dev_equal_l3scope(sk, pkt.ipi6_ifindex))
674674
goto e_inval;
@@ -709,7 +709,7 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
709709
refcount_set(&opt->refcnt, 1);
710710
opt->tot_len = sizeof(*opt) + optlen;
711711
retv = -EFAULT;
712-
if (copy_from_user(opt+1, optval, optlen))
712+
if (copy_from_sockptr(opt + 1, optval, optlen))
713713
goto done;
714714

715715
msg.msg_controllen = optlen;
@@ -831,7 +831,7 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
831831
break;
832832

833833
retv = -EFAULT;
834-
if (copy_from_user(&mreq, optval, sizeof(struct ipv6_mreq)))
834+
if (copy_from_sockptr(&mreq, optval, sizeof(struct ipv6_mreq)))
835835
break;
836836

837837
if (optname == IPV6_ADD_MEMBERSHIP)
@@ -849,7 +849,7 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
849849
goto e_inval;
850850

851851
retv = -EFAULT;
852-
if (copy_from_user(&mreq, optval, sizeof(struct ipv6_mreq)))
852+
if (copy_from_sockptr(&mreq, optval, sizeof(struct ipv6_mreq)))
853853
break;
854854

855855
if (optname == IPV6_JOIN_ANYCAST)
@@ -929,15 +929,14 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
929929
retv = 0;
930930
break;
931931
case IPV6_FLOWLABEL_MGR:
932-
retv = ipv6_flowlabel_opt(sk, USER_SOCKPTR(optval), optlen);
932+
retv = ipv6_flowlabel_opt(sk, optval, optlen);
933933
break;
934934
case IPV6_IPSEC_POLICY:
935935
case IPV6_XFRM_POLICY:
936936
retv = -EPERM;
937937
if (!ns_capable(net->user_ns, CAP_NET_ADMIN))
938938
break;
939-
retv = xfrm_user_policy(sk, optname, USER_SOCKPTR(optval),
940-
optlen);
939+
retv = xfrm_user_policy(sk, optname, optval, optlen);
941940
break;
942941

943942
case IPV6_ADDR_PREFERENCES:
@@ -992,7 +991,8 @@ int ipv6_setsockopt(struct sock *sk, int level, int optname,
992991
if (level != SOL_IPV6)
993992
return -ENOPROTOOPT;
994993

995-
err = do_ipv6_setsockopt(sk, level, optname, optval, optlen);
994+
err = do_ipv6_setsockopt(sk, level, optname, USER_SOCKPTR(optval),
995+
optlen);
996996
#ifdef CONFIG_NETFILTER
997997
/* we need to exclude all possible ENOPROTOOPTs except default case */
998998
if (err == -ENOPROTOOPT && optname != IPV6_IPSEC_POLICY &&

0 commit comments

Comments
 (0)