tcp: avoid sending acks when data available
Type: fix Change-Id: I02e2cb2d349f9ddb2bfed040a08ca448f379d565 Signed-off-by: Florin Coras <fcoras@cisco.com>
This commit is contained in:

committed by
Dave Barach

parent
ec44e26372
commit
cb711a4ec9
@ -786,6 +786,7 @@ void tcp_send_reset (tcp_connection_t * tc);
|
||||
void tcp_send_syn (tcp_connection_t * tc);
|
||||
void tcp_send_synack (tcp_connection_t * tc);
|
||||
void tcp_send_fin (tcp_connection_t * tc);
|
||||
void tcp_send_ack (tcp_connection_t * tc);
|
||||
void tcp_update_burst_snd_vars (tcp_connection_t * tc);
|
||||
void tcp_update_rto (tcp_connection_t * tc);
|
||||
void tcp_flush_frame_to_output (tcp_worker_ctx_t * wrk, u8 is_ip4);
|
||||
|
@ -1681,6 +1681,7 @@ tcp_rcv_fin (tcp_worker_ctx_t * wrk, tcp_connection_t * tc, vlib_buffer_t * b,
|
||||
|
||||
/* Account for the FIN and send ack */
|
||||
tc->rcv_nxt += 1;
|
||||
tc->flags |= TCP_CONN_FINRCVD;
|
||||
tcp_program_ack (tc);
|
||||
/* Enter CLOSE-WAIT and notify session. To avoid lingering
|
||||
* in CLOSE-WAIT, set timer (reuse WAITCLOSE). */
|
||||
@ -2593,7 +2594,9 @@ tcp46_syn_sent_inline (vlib_main_t * vm, vlib_node_runtime_t * node,
|
||||
}
|
||||
else
|
||||
{
|
||||
tcp_program_ack (new_tc0);
|
||||
/* Send ack now instead of programming it because connection was
|
||||
* just established and it's not optional. */
|
||||
tcp_send_ack (new_tc0);
|
||||
}
|
||||
|
||||
drop:
|
||||
|
@ -518,7 +518,6 @@ tcp_compute_checksum (tcp_connection_t * tc, vlib_buffer_t * b)
|
||||
return checksum;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Prepare ACK
|
||||
*/
|
||||
@ -1086,6 +1085,10 @@ tcp_send_fin (tcp_connection_t * tc)
|
||||
return;
|
||||
}
|
||||
|
||||
/* If we have non-dupacks programmed, no need to send them */
|
||||
if ((tc->flags & TCP_CONN_SNDACK) && !tc->pending_dupacks)
|
||||
tc->flags &= ~TCP_CONN_SNDACK;
|
||||
|
||||
tcp_retransmit_timer_force_update (tc);
|
||||
b = vlib_get_buffer (vm, bi);
|
||||
tcp_init_buffer (vm, b);
|
||||
@ -1165,7 +1168,6 @@ tcp_push_hdr_i (tcp_connection_t * tc, vlib_buffer_t * b, u32 snd_nxt,
|
||||
tc->bytes_out += data_len;
|
||||
tc->data_segs_out += 1;
|
||||
|
||||
|
||||
th->checksum = tcp_compute_checksum (tc, b);
|
||||
|
||||
TCP_EVT (TCP_EVT_PKTIZE, tc);
|
||||
@ -1883,6 +1885,13 @@ tcp_retransmit_should_retry_head (tcp_connection_t * tc,
|
||||
return (tx_adv_sack > (tc->snd_una - tc->prr_start) * rr);
|
||||
}
|
||||
|
||||
static inline u8
|
||||
tcp_max_tx_deq (tcp_connection_t * tc)
|
||||
{
|
||||
return (transport_max_tx_dequeue (&tc->connection)
|
||||
- (tc->snd_nxt - tc->snd_una));
|
||||
}
|
||||
|
||||
#define scoreboard_rescue_rxt_valid(_sb, _tc) \
|
||||
(seq_geq (_sb->rescue_rxt, _tc->snd_una) \
|
||||
&& seq_leq (_sb->rescue_rxt, _tc->snd_congestion))
|
||||
@ -2145,8 +2154,13 @@ tcp_send_acks (tcp_connection_t * tc, u32 max_burst_size)
|
||||
|
||||
if (!tc->pending_dupacks)
|
||||
{
|
||||
tcp_send_ack (tc);
|
||||
return 1;
|
||||
if (tcp_in_cong_recovery (tc) || !tcp_max_tx_deq (tc)
|
||||
|| tc->state != TCP_STATE_ESTABLISHED)
|
||||
{
|
||||
tcp_send_ack (tc);
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* If we're supposed to send dupacks but have no ooo data
|
||||
@ -2154,6 +2168,7 @@ tcp_send_acks (tcp_connection_t * tc, u32 max_burst_size)
|
||||
if (!vec_len (tc->snd_sacks))
|
||||
{
|
||||
tcp_send_ack (tc);
|
||||
tc->pending_dupacks = 0;
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user