From: Christoph Paasch Date: Sat, 6 Jul 2019 23:13:07 +0000 (-0700) Subject: tcp: Reset bytes_acked and bytes_received when disconnecting X-Git-Tag: v5.1.21~39 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=2527ea8f115cdd0b1e8fc5cb161ff7d1a7a99351;p=thirdparty%2Fkernel%2Fstable.git tcp: Reset bytes_acked and bytes_received when disconnecting [ Upstream commit e858faf556d4e14c750ba1e8852783c6f9520a0e ] If an app is playing tricks to reuse a socket via tcp_disconnect(), bytes_acked/received needs to be reset to 0. Otherwise tcp_info will report the sum of the current and the old connection.. Cc: Eric Dumazet Fixes: 0df48c26d841 ("tcp: add tcpi_bytes_acked to tcp_info") Fixes: bdd1f9edacb5 ("tcp: add tcpi_bytes_received to tcp_info") Signed-off-by: Christoph Paasch Signed-off-by: Eric Dumazet Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 05fa7b7aee1ed..caac580e1f1d9 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c @@ -2630,6 +2630,8 @@ int tcp_disconnect(struct sock *sk, int flags) tcp_saved_syn_free(tp); tp->compressed_ack = 0; tp->bytes_sent = 0; + tp->bytes_acked = 0; + tp->bytes_received = 0; tp->bytes_retrans = 0; tp->duplicate_sack[0].start_seq = 0; tp->duplicate_sack[0].end_seq = 0;