tcp: allow multiple rxt rescues during recovery 07/40007/2
authorFlorin Coras <fcoras@cisco.com>
Sat, 25 Nov 2023 17:00:44 +0000 (09:00 -0800)
committerDave Barach <vpp@barachs.net>
Mon, 27 Nov 2023 18:50:34 +0000 (18:50 +0000)
Type: improvement

Change-Id: Ia8d7cd6ff9b1449d986d514d9556cbf803deb670
Signed-off-by: Florin Coras <fcoras@cisco.com>
src/vnet/tcp/tcp_output.c

index aad69df..c994845 100644 (file)
@@ -1279,6 +1279,7 @@ tcp_cc_init_rxt_timeout (tcp_connection_t * tc)
   tc->cwnd_acc_bytes = 0;
   tc->tr_occurences += 1;
   tc->sack_sb.reorder = TCP_DUPACK_THRESHOLD;
+  tc->sack_sb.rescue_rxt = tc->snd_una - 1;
   tcp_recovery_on (tc);
 }
 
@@ -1783,8 +1784,7 @@ tcp_retransmit_sack (tcp_worker_ctx_t * wrk, tcp_connection_t * tc,
              goto done;
            }
 
-         if (tcp_in_recovery (tc) || !can_rescue
-             || scoreboard_rescue_rxt_valid (sb, tc))
+         if (!can_rescue || scoreboard_rescue_rxt_valid (sb, tc))
            break;
 
          /* If rescue rxt undefined or less than snd_una then one segment of