From: Zheng Yan Date: Mon, 19 Sep 2011 02:37:34 +0000 (-0400) Subject: tcp: fix validation of D-SACK X-Git-Tag: firefly_0821_release~3680^2~4450^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=f779b2d60ab95c17f1e025778ed0df3ec2f05d75;p=firefly-linux-kernel-4.4.55.git tcp: fix validation of D-SACK D-SACK is allowed to reside below snd_una. But the corresponding check in tcp_is_sackblock_valid() is the exact opposite. It looks like a typo. Signed-off-by: Zheng Yan Acked-by: Eric Dumazet Signed-off-by: David S. Miller --- diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index ea0d2183df4b..21fab3edb92c 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -1124,7 +1124,7 @@ static int tcp_is_sackblock_valid(struct tcp_sock *tp, int is_dsack, return 0; /* ...Then it's D-SACK, and must reside below snd_una completely */ - if (!after(end_seq, tp->snd_una)) + if (after(end_seq, tp->snd_una)) return 0; if (!before(start_seq, tp->undo_marker))