diff options
author | Eric Dumazet <edumazet@google.com> | 2015-03-17 21:32:26 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-03-17 22:01:55 -0400 |
commit | 407640de2152e33341ce1131dac269672c3d50f7 (patch) | |
tree | dec463be332bf8e0360d495d355e90cd9b80bd26 /net/ipv4 | |
parent | 9f2dbdd9b11d40f5fe0749eb91cd1cfc86fde575 (diff) |
inet: add sk_listener argument to inet_reqsk_alloc()
listener socket can be used to set net pointer, and will
be later used to hold a reference on listener.
Add a const qualifier to first argument (struct request_sock_ops *),
and factorize all write_pnet(&ireq->ireq_net, sock_net(sk));
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/syncookies.c | 3 | ||||
-rw-r--r-- | net/ipv4/tcp_input.c | 3 |
2 files changed, 2 insertions, 4 deletions
diff --git a/net/ipv4/syncookies.c b/net/ipv4/syncookies.c index 5ae0c49f5e2e..eb940750bb1b 100644 --- a/net/ipv4/syncookies.c +++ b/net/ipv4/syncookies.c | |||
@@ -325,7 +325,7 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb) | |||
325 | goto out; | 325 | goto out; |
326 | 326 | ||
327 | ret = NULL; | 327 | ret = NULL; |
328 | req = inet_reqsk_alloc(&tcp_request_sock_ops); /* for safety */ | 328 | req = inet_reqsk_alloc(&tcp_request_sock_ops, sk); /* for safety */ |
329 | if (!req) | 329 | if (!req) |
330 | goto out; | 330 | goto out; |
331 | 331 | ||
@@ -346,7 +346,6 @@ struct sock *cookie_v4_check(struct sock *sk, struct sk_buff *skb) | |||
346 | req->ts_recent = tcp_opt.saw_tstamp ? tcp_opt.rcv_tsval : 0; | 346 | req->ts_recent = tcp_opt.saw_tstamp ? tcp_opt.rcv_tsval : 0; |
347 | treq->snt_synack = tcp_opt.saw_tstamp ? tcp_opt.rcv_tsecr : 0; | 347 | treq->snt_synack = tcp_opt.saw_tstamp ? tcp_opt.rcv_tsecr : 0; |
348 | treq->listener = NULL; | 348 | treq->listener = NULL; |
349 | write_pnet(&ireq->ireq_net, sock_net(sk)); | ||
350 | ireq->ireq_family = AF_INET; | 349 | ireq->ireq_family = AF_INET; |
351 | 350 | ||
352 | ireq->ir_iif = sk->sk_bound_dev_if; | 351 | ireq->ir_iif = sk->sk_bound_dev_if; |
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index 7257eb206c07..2a480f6811ea 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c | |||
@@ -6004,7 +6004,7 @@ int tcp_conn_request(struct request_sock_ops *rsk_ops, | |||
6004 | goto drop; | 6004 | goto drop; |
6005 | } | 6005 | } |
6006 | 6006 | ||
6007 | req = inet_reqsk_alloc(rsk_ops); | 6007 | req = inet_reqsk_alloc(rsk_ops, sk); |
6008 | if (!req) | 6008 | if (!req) |
6009 | goto drop; | 6009 | goto drop; |
6010 | 6010 | ||
@@ -6020,7 +6020,6 @@ int tcp_conn_request(struct request_sock_ops *rsk_ops, | |||
6020 | 6020 | ||
6021 | tmp_opt.tstamp_ok = tmp_opt.saw_tstamp; | 6021 | tmp_opt.tstamp_ok = tmp_opt.saw_tstamp; |
6022 | tcp_openreq_init(req, &tmp_opt, skb, sk); | 6022 | tcp_openreq_init(req, &tmp_opt, skb, sk); |
6023 | write_pnet(&inet_rsk(req)->ireq_net, sock_net(sk)); | ||
6024 | 6023 | ||
6025 | /* Note: tcp_v6_init_req() might override ir_iif for link locals */ | 6024 | /* Note: tcp_v6_init_req() might override ir_iif for link locals */ |
6026 | inet_rsk(req)->ir_iif = sk->sk_bound_dev_if; | 6025 | inet_rsk(req)->ir_iif = sk->sk_bound_dev_if; |