Pengcheng Yang
d9157f6806
tcp: fix F-RTO may not work correctly when receiving DSACK
...
Currently DSACK is regarded as a dupack, which may cause
F-RTO to incorrectly enter "loss was real" when receiving
DSACK.
Packetdrill to demonstrate:
// Enable F-RTO and TLP
0 `sysctl -q net.ipv4.tcp_frto=2`
0 `sysctl -q net.ipv4.tcp_early_retrans=3`
0 `sysctl -q net.ipv4.tcp_congestion_control=cubic`
// 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
// RTT 10ms, RTO 210ms
+.1 < S 0:0(0) win 32792 <mss 1000,sackOK,nop,nop,nop,wscale 7>
+0 > S. 0:0(0) ack 1 <...>
+.01 < . 1:1(0) ack 1 win 257
+0 accept(3, ..., ...) = 4
// Send 2 data segments
+0 write(4, ..., 2000) = 2000
+0 > P. 1:2001(2000) ack 1
// TLP
+.022 > P. 1001:2001(1000) ack 1
// Continue to send 8 data segments
+0 write(4, ..., 10000) = 10000
+0 > P. 2001:10001(8000) ack 1
// RTO
+.188 > . 1:1001(1000) ack 1
// The original data is acked and new data is sent(F-RTO step 2.b)
+0 < . 1:1(0) ack 2001 win 257
+0 > P. 10001:12001(2000) ack 1
// D-SACK caused by TLP is regarded as a dupack, this results in
// the incorrect judgment of "loss was real"(F-RTO step 3.a)
+.022 < . 1:1(0) ack 2001 win 257 <sack 1001:2001,nop,nop>
// Never-retransmitted data(3001:4001) are acked and
// expect to switch to open state(F-RTO step 3.b)
+0 < . 1:1(0) ack 4001 win 257
+0 %{ assert tcpi_ca_state == 0, tcpi_ca_state }%
Fixes: e33099f96d99 ("tcp: implement RFC5682 F-RTO")
Signed-off-by: Pengcheng Yang <yangpc@wangsu.com>
Acked-by: Neal Cardwell <ncardwell@google.com>
Tested-by: Neal Cardwell <ncardwell@google.com>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Link: https://lore.kernel.org/r/1650967419-2150-1-git-send-email-yangpc@wangsu.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
2022-04-28 10:35:38 -07:00
..
2022-04-25 10:37:33 +02:00
2022-02-21 11:41:30 +00:00
2021-06-30 15:51:09 -07:00
2022-02-26 12:53:59 +00:00
2022-01-27 12:03:46 -08:00
2021-09-19 12:43:56 +01:00
2021-09-29 11:39:33 +01:00
2022-02-18 21:20:06 -08:00
2022-03-07 13:14:04 +01:00
2022-04-13 10:16:11 +02:00
2022-03-15 20:20:02 -07:00
2022-02-17 11:44:20 -08:00
2021-09-28 17:32:56 -07:00
2022-02-10 15:33:33 +00:00
2022-04-01 12:09:17 +01:00
2022-03-15 20:20:02 -07:00
2021-11-24 17:21:42 -08:00
2021-05-17 15:29:35 -07:00
2021-11-24 17:21:42 -08:00
2022-01-25 11:25:21 +00:00
2021-11-14 12:20:44 +00:00
2022-02-02 14:45:18 +00:00
2021-12-10 21:14:49 -08:00
2022-03-03 14:38:48 +00:00
2022-02-09 21:28:36 -08:00
2022-01-26 19:00:31 -08:00
2021-03-01 13:32:12 -08:00
2022-03-03 14:38:48 +00:00
2022-03-03 14:38:48 +00:00
2022-04-25 11:40:45 +01:00
2022-03-03 14:38:48 +00:00
2022-01-29 17:53:07 +00:00
2022-03-03 14:38:48 +00:00
2021-11-20 14:11:00 +00:00
2021-01-08 19:25:35 -08:00
2022-04-15 14:27:30 -07:00
2021-10-13 09:41:37 -07:00
2021-06-30 15:51:09 -07:00
2021-10-28 14:36:41 +01:00
2021-10-13 09:41:37 -07:00
2022-02-10 17:29:56 -08:00
2021-02-26 12:28:03 -08:00
2020-11-16 08:08:54 -08:00
2021-04-18 22:04:16 +02:00
2022-02-08 20:41:33 -08:00
2022-02-24 09:18:29 -08:00
2022-01-26 19:00:31 -08:00
2021-05-17 15:29:35 -07:00
2021-07-13 09:28:29 -07:00
2022-01-27 20:58:39 +02:00
2022-03-23 10:53:49 -07:00
2022-04-25 12:10:11 +01:00
2022-03-09 20:05:44 -08:00
2022-01-18 14:26:41 -08:00
2022-03-15 16:43:31 +01:00
2022-03-11 22:51:40 -08:00
2022-01-18 14:26:41 -08:00
2022-01-18 14:26:41 -08:00
2021-09-20 13:09:06 +01:00
2022-04-28 10:35:38 -07:00
2022-03-09 20:05:44 -08:00
2021-03-28 17:31:13 -07:00
2020-12-14 16:40:27 -08:00
2022-04-22 15:05:59 -07:00
2021-09-27 12:47:39 +01:00
2021-11-16 13:16:54 +00:00
2022-04-25 12:07:45 +01:00
2022-04-22 15:20:47 -07:00
2021-07-27 20:07:21 +01:00
2020-08-24 17:31:20 -07:00
2021-06-29 11:28:21 -07:00
2020-10-13 17:11:52 -07:00
2021-06-29 11:54:36 -07:00
2022-03-09 20:05:20 -08:00
2021-05-17 15:29:35 -07:00
2021-10-26 12:29:33 -07:00
2021-07-13 09:28:29 -07:00
2021-11-24 17:21:42 -08:00
2021-09-21 10:17:20 +01:00
2022-02-23 12:35:00 +00:00
2022-02-07 11:18:49 +00:00
2021-05-17 15:29:35 -07:00
2022-03-15 20:20:02 -07:00
2021-05-17 15:29:35 -07:00
2021-09-23 10:10:00 +02:00