diff options
author | Eric Dumazet <edumazet@google.com> | 2015-03-12 19:44:09 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-03-12 22:58:13 -0400 |
commit | d4f06873b636519cedbe8d2eeae77c713c6a121c (patch) | |
tree | 7025fa2ff2b8cf9e701de46ce7c71a1553f1a19a /net/ipv4/tcp_ipv4.c | |
parent | 41b822c59e21414d829bcfd00df0c8f7f13b1b95 (diff) |
inet: get_openreq4() & get_openreq6() do not need listener
ireq->ir_num contains local port, use it.
Also, get_openreq4() dumping listen_sk->refcnt makes litle sense.
inet_diag_fill_req() can also use ireq->ir_num
Signed-off-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/tcp_ipv4.c')
-rw-r--r-- | net/ipv4/tcp_ipv4.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c index f0c6fc32bfa8..70b0f701bbdb 100644 --- a/net/ipv4/tcp_ipv4.c +++ b/net/ipv4/tcp_ipv4.c | |||
@@ -2204,7 +2204,7 @@ void tcp_proc_unregister(struct net *net, struct tcp_seq_afinfo *afinfo) | |||
2204 | } | 2204 | } |
2205 | EXPORT_SYMBOL(tcp_proc_unregister); | 2205 | EXPORT_SYMBOL(tcp_proc_unregister); |
2206 | 2206 | ||
2207 | static void get_openreq4(const struct sock *sk, const struct request_sock *req, | 2207 | static void get_openreq4(const struct request_sock *req, |
2208 | struct seq_file *f, int i, kuid_t uid) | 2208 | struct seq_file *f, int i, kuid_t uid) |
2209 | { | 2209 | { |
2210 | const struct inet_request_sock *ireq = inet_rsk(req); | 2210 | const struct inet_request_sock *ireq = inet_rsk(req); |
@@ -2214,7 +2214,7 @@ static void get_openreq4(const struct sock *sk, const struct request_sock *req, | |||
2214 | " %02X %08X:%08X %02X:%08lX %08X %5u %8d %u %d %pK", | 2214 | " %02X %08X:%08X %02X:%08lX %08X %5u %8d %u %d %pK", |
2215 | i, | 2215 | i, |
2216 | ireq->ir_loc_addr, | 2216 | ireq->ir_loc_addr, |
2217 | ntohs(inet_sk(sk)->inet_sport), | 2217 | ireq->ir_num, |
2218 | ireq->ir_rmt_addr, | 2218 | ireq->ir_rmt_addr, |
2219 | ntohs(ireq->ir_rmt_port), | 2219 | ntohs(ireq->ir_rmt_port), |
2220 | TCP_SYN_RECV, | 2220 | TCP_SYN_RECV, |
@@ -2225,7 +2225,7 @@ static void get_openreq4(const struct sock *sk, const struct request_sock *req, | |||
2225 | from_kuid_munged(seq_user_ns(f), uid), | 2225 | from_kuid_munged(seq_user_ns(f), uid), |
2226 | 0, /* non standard timer */ | 2226 | 0, /* non standard timer */ |
2227 | 0, /* open_requests have no inode */ | 2227 | 0, /* open_requests have no inode */ |
2228 | atomic_read(&sk->sk_refcnt), | 2228 | 0, |
2229 | req); | 2229 | req); |
2230 | } | 2230 | } |
2231 | 2231 | ||
@@ -2332,7 +2332,7 @@ static int tcp4_seq_show(struct seq_file *seq, void *v) | |||
2332 | get_tcp4_sock(v, seq, st->num); | 2332 | get_tcp4_sock(v, seq, st->num); |
2333 | break; | 2333 | break; |
2334 | case TCP_SEQ_STATE_OPENREQ: | 2334 | case TCP_SEQ_STATE_OPENREQ: |
2335 | get_openreq4(st->syn_wait_sk, v, seq, st->num, st->uid); | 2335 | get_openreq4(v, seq, st->num, st->uid); |
2336 | break; | 2336 | break; |
2337 | } | 2337 | } |
2338 | out: | 2338 | out: |