Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4629211ybl; Wed, 22 Jan 2020 01:35:25 -0800 (PST) X-Google-Smtp-Source: APXvYqzGvny4eX7MoQGVIh9CszuRo040wEMOup/QSC6E0K+KZXJlHDry5KaWk4+e4gx/gKa3uf0f X-Received: by 2002:a05:6830:1d59:: with SMTP id p25mr6815882oth.308.1579685725497; Wed, 22 Jan 2020 01:35:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579685725; cv=none; d=google.com; s=arc-20160816; b=dBZuo1oFFUCYzr6AxVKmHmv2zojLtrU632fH66jWqFaSKKtMixU/qJoQ6Ew4+NBQq/ yM2Sjp7hiFCIrk7Tgz5cJSVgh+QdMfv6YglufuFKHZ29KcUhXznp3fOkNP6bZwpTjk7X EOmG68SCVhET4BqlOziwYiM95MrPjM+hUQIJsml+ZXUqeJ6PwrQP/KJHF7mgX92b9Hb7 XvAQbN14fWmGKqDQvvXfd5i+kWwR7oiC0yj1786dCE0tQt4+/KzST1ms1R1ea5IpcrW8 9DaUIaU+54P+IAUxMvXpv3+qgjDfPM7bstK0IubZoP657+KszAY9it1AbmhillgPe6vS arng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=7LRpmN+BIuHyHwSrH4UDh5A11urunRQz1+Y0GkxNRs0=; b=gMDWIrejq1p/BPYfZDlJtNeZeUhHEobLU+lqYPFoybF0j8/WsKsIdRCMNGnchSWzlH d0lY2dUPy/WeeWNvlz6Rg0APLe4OX9+J3lvdlJ7lgiEoBxGlyIOrwqftCmNju1/WOSna qDOumkYkEhWKwCE4f2iJovtbEuXCe48Sn9hxAtfwHAUy7xHE6KlBLR3Nafy/9YuslK+n CAOGeEtENu6dYOjacQIofFHYAKFVgdEmOGXzBwIgg/od5C5T86G27ouDifjfWmKo/N1f DDDhznqHgLgHuF+yLZN7n1IPczXkVaMoEzYIWT5iDthOyXnqQxSPSm3jl9tPhp7Tb46e WWvg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=av8Lh31p; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w7si23391097otq.250.2020.01.22.01.35.14; Wed, 22 Jan 2020 01:35:25 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=av8Lh31p; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730224AbgAVJct (ORCPT + 99 others); Wed, 22 Jan 2020 04:32:49 -0500 Received: from mail.kernel.org ([198.145.29.99]:45970 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729247AbgAVJcs (ORCPT ); Wed, 22 Jan 2020 04:32:48 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id AE61824672; Wed, 22 Jan 2020 09:32:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579685567; bh=MJ9fE1EUKx/z8Nw9yIwKG7TAB3DTDh8CO5gV/glkYsc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=av8Lh31pY9xVjo3xH1tUWhZvge8yur9PIsHA+H+PCLki4HbuoRFNset19Egq9owqr l6/Xb2uJo1DD4wLmVleSGAdGQpeBsiMpaR85xaBcaTcSbSwJxqxRx6VxUPTzoCF5D1 xIXCFez4JMGcwSs6e4kk9B4VIx0gOrwvHusxofTY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Pengcheng Yang , Neal Cardwell , "David S. Miller" Subject: [PATCH 4.4 65/76] tcp: fix marked lost packets not being retransmitted Date: Wed, 22 Jan 2020 10:29:21 +0100 Message-Id: <20200122092801.225054629@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200122092751.587775548@linuxfoundation.org> References: <20200122092751.587775548@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Pengcheng Yang [ Upstream commit e176b1ba476cf36f723cfcc7a9e57f3cb47dec70 ] When the packet pointed to by retransmit_skb_hint is unlinked by ACK, retransmit_skb_hint will be set to NULL in tcp_clean_rtx_queue(). If packet loss is detected at this time, retransmit_skb_hint will be set to point to the current packet loss in tcp_verify_retransmit_hint(), then the packets that were previously marked lost but not retransmitted due to the restriction of cwnd will be skipped and cannot be retransmitted. To fix this, when retransmit_skb_hint is NULL, retransmit_skb_hint can be reset only after all marked lost packets are retransmitted (retrans_out >= lost_out), otherwise we need to traverse from tcp_rtx_queue_head in tcp_xmit_retransmit_queue(). Packetdrill to demonstrate: // Disable RACK and set max_reordering to keep things simple 0 `sysctl -q net.ipv4.tcp_recovery=0` +0 `sysctl -q net.ipv4.tcp_max_reordering=3` // Establish a connection +0 socket(..., SOCK_STREAM, IPPROTO_TCP) = 3 +0 setsockopt(3, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0 +0 bind(3, ..., ...) = 0 +0 listen(3, 1) = 0 +.1 < S 0:0(0) win 32792 +0 > S. 0:0(0) ack 1 <...> +.01 < . 1:1(0) ack 1 win 257 +0 accept(3, ..., ...) = 4 // Send 8 data segments +0 write(4, ..., 8000) = 8000 +0 > P. 1:8001(8000) ack 1 // Enter recovery and 1:3001 is marked lost +.01 < . 1:1(0) ack 1 win 257 +0 < . 1:1(0) ack 1 win 257 +0 < . 1:1(0) ack 1 win 257 // Retransmit 1:1001, now retransmit_skb_hint points to 1001:2001 +0 > . 1:1001(1000) ack 1 // 1001:2001 was ACKed causing retransmit_skb_hint to be set to NULL +.01 < . 1:1(0) ack 2001 win 257 // Now retransmit_skb_hint points to 4001:5001 which is now marked lost // BUG: 2001:3001 was not retransmitted +0 > . 2001:3001(1000) ack 1 Signed-off-by: Pengcheng Yang Acked-by: Neal Cardwell Tested-by: Neal Cardwell Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/ipv4/tcp_input.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -895,9 +895,10 @@ static void tcp_update_reordering(struct /* This must be called before lost_out is incremented */ static void tcp_verify_retransmit_hint(struct tcp_sock *tp, struct sk_buff *skb) { - if (!tp->retransmit_skb_hint || - before(TCP_SKB_CB(skb)->seq, - TCP_SKB_CB(tp->retransmit_skb_hint)->seq)) + if ((!tp->retransmit_skb_hint && tp->retrans_out >= tp->lost_out) || + (tp->retransmit_skb_hint && + before(TCP_SKB_CB(skb)->seq, + TCP_SKB_CB(tp->retransmit_skb_hint)->seq))) tp->retransmit_skb_hint = skb; if (!tp->lost_out ||