diff options
author | Tom Herbert <tom@herbertland.com> | 2016-03-07 17:11:05 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-03-09 16:36:14 -0500 |
commit | 473bd239b808a8af5241ce9996a16d283d88ddff (patch) | |
tree | 1a02155265887fa8e2893ddc144a656c240349ee /net/ipv4/tcp.c | |
parent | fa9835e52e3ea946916c2ce6c625c86421131740 (diff) |
tcp: Add tcp_inq to get available receive bytes on socket
Create a common kernel function to get the number of bytes available
on a TCP socket. This is based on code in INQ getsockopt and we now call
the function for that getsockopt.
Signed-off-by: Tom Herbert <tom@herbertland.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/tcp.c')
-rw-r--r-- | net/ipv4/tcp.c | 15 |
1 files changed, 1 insertions, 14 deletions
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index f9faadb42485..a265f00b9df9 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c | |||
@@ -556,20 +556,7 @@ int tcp_ioctl(struct sock *sk, int cmd, unsigned long arg) | |||
556 | return -EINVAL; | 556 | return -EINVAL; |
557 | 557 | ||
558 | slow = lock_sock_fast(sk); | 558 | slow = lock_sock_fast(sk); |
559 | if ((1 << sk->sk_state) & (TCPF_SYN_SENT | TCPF_SYN_RECV)) | 559 | answ = tcp_inq(sk); |
560 | answ = 0; | ||
561 | else if (sock_flag(sk, SOCK_URGINLINE) || | ||
562 | !tp->urg_data || | ||
563 | before(tp->urg_seq, tp->copied_seq) || | ||
564 | !before(tp->urg_seq, tp->rcv_nxt)) { | ||
565 | |||
566 | answ = tp->rcv_nxt - tp->copied_seq; | ||
567 | |||
568 | /* Subtract 1, if FIN was received */ | ||
569 | if (answ && sock_flag(sk, SOCK_DONE)) | ||
570 | answ--; | ||
571 | } else | ||
572 | answ = tp->urg_seq - tp->copied_seq; | ||
573 | unlock_sock_fast(sk, slow); | 560 | unlock_sock_fast(sk, slow); |
574 | break; | 561 | break; |
575 | case SIOCATMARK: | 562 | case SIOCATMARK: |