mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2024-11-18 20:10:53 +00:00
fixed bug #20506 "Initial congestion window is very small" again by implementing the calculation formula from RFC3390
This commit is contained in:
parent
5dd6b1effc
commit
2775fb5a45
@ -6,6 +6,10 @@ HISTORY
|
|||||||
|
|
||||||
++ New features:
|
++ New features:
|
||||||
|
|
||||||
|
2015-01-16: Simon Goldschmidt
|
||||||
|
* tcp_in.c: fixed bug #20506 "Initial congestion window is very small" again
|
||||||
|
by implementing the calculation formula from RFC3390
|
||||||
|
|
||||||
2014-12-10: Simon Goldschmidt
|
2014-12-10: Simon Goldschmidt
|
||||||
* api: added option LWIP_NETCONN_SEM_PER_THREAD to use a semaphore per thread
|
* api: added option LWIP_NETCONN_SEM_PER_THREAD to use a semaphore per thread
|
||||||
instead of using one per netconn and per select call
|
instead of using one per netconn and per select call
|
||||||
|
@ -62,6 +62,8 @@
|
|||||||
#include "lwip/nd6.h"
|
#include "lwip/nd6.h"
|
||||||
#endif /* LWIP_ND6_TCP_REACHABILITY_HINTS */
|
#endif /* LWIP_ND6_TCP_REACHABILITY_HINTS */
|
||||||
|
|
||||||
|
#define LWIP_TCP_CALC_INITIAL_CWND(mss) LWIP_MIN((4U * (mss)), LWIP_MAX((2U * (mss)), 4380U));
|
||||||
|
|
||||||
/* These variables are global to all functions involved in the input
|
/* These variables are global to all functions involved in the input
|
||||||
processing of TCP segments. They are set by the tcp_input()
|
processing of TCP segments. They are set by the tcp_input()
|
||||||
function. */
|
function. */
|
||||||
@ -740,7 +742,10 @@ tcp_process(struct tcp_pcb *pcb)
|
|||||||
* but for the default value of pcb->mss) */
|
* but for the default value of pcb->mss) */
|
||||||
pcb->ssthresh = pcb->mss * 10;
|
pcb->ssthresh = pcb->mss * 10;
|
||||||
|
|
||||||
pcb->cwnd = ((pcb->cwnd == 1) ? (pcb->mss * 2) : pcb->mss);
|
pcb->cwnd = LWIP_TCP_CALC_INITIAL_CWND(pcb->mss);
|
||||||
|
LWIP_DEBUGF(TCP_CWND_DEBUG, ("tcp_process (SENT): cwnd %"TCPWNDSIZE_F
|
||||||
|
" ssthresh %"TCPWNDSIZE_F"\n",
|
||||||
|
pcb->cwnd, pcb->ssthresh));
|
||||||
LWIP_ASSERT("pcb->snd_queuelen > 0", (pcb->snd_queuelen > 0));
|
LWIP_ASSERT("pcb->snd_queuelen > 0", (pcb->snd_queuelen > 0));
|
||||||
--pcb->snd_queuelen;
|
--pcb->snd_queuelen;
|
||||||
LWIP_DEBUGF(TCP_QLEN_DEBUG, ("tcp_process: SYN-SENT --queuelen %"TCPWNDSIZE_F"\n", (tcpwnd_size_t)pcb->snd_queuelen));
|
LWIP_DEBUGF(TCP_QLEN_DEBUG, ("tcp_process: SYN-SENT --queuelen %"TCPWNDSIZE_F"\n", (tcpwnd_size_t)pcb->snd_queuelen));
|
||||||
@ -776,7 +781,6 @@ tcp_process(struct tcp_pcb *pcb)
|
|||||||
if (flags & TCP_ACK) {
|
if (flags & TCP_ACK) {
|
||||||
/* expected ACK number? */
|
/* expected ACK number? */
|
||||||
if (TCP_SEQ_BETWEEN(ackno, pcb->lastack+1, pcb->snd_nxt)) {
|
if (TCP_SEQ_BETWEEN(ackno, pcb->lastack+1, pcb->snd_nxt)) {
|
||||||
tcpwnd_size_t old_cwnd;
|
|
||||||
pcb->state = ESTABLISHED;
|
pcb->state = ESTABLISHED;
|
||||||
LWIP_DEBUGF(TCP_DEBUG, ("TCP connection established %"U16_F" -> %"U16_F".\n", inseg.tcphdr->src, inseg.tcphdr->dest));
|
LWIP_DEBUGF(TCP_DEBUG, ("TCP connection established %"U16_F" -> %"U16_F".\n", inseg.tcphdr->src, inseg.tcphdr->dest));
|
||||||
#if LWIP_CALLBACK_API
|
#if LWIP_CALLBACK_API
|
||||||
@ -793,7 +797,6 @@ tcp_process(struct tcp_pcb *pcb)
|
|||||||
}
|
}
|
||||||
return ERR_ABRT;
|
return ERR_ABRT;
|
||||||
}
|
}
|
||||||
old_cwnd = pcb->cwnd;
|
|
||||||
/* If there was any data contained within this ACK,
|
/* If there was any data contained within this ACK,
|
||||||
* we'd better pass it on to the application as well. */
|
* we'd better pass it on to the application as well. */
|
||||||
tcp_receive(pcb);
|
tcp_receive(pcb);
|
||||||
@ -803,7 +806,10 @@ tcp_process(struct tcp_pcb *pcb)
|
|||||||
pcb->acked--;
|
pcb->acked--;
|
||||||
}
|
}
|
||||||
|
|
||||||
pcb->cwnd = ((old_cwnd == 1) ? (pcb->mss * 2) : pcb->mss);
|
pcb->cwnd = LWIP_TCP_CALC_INITIAL_CWND(pcb->mss);
|
||||||
|
LWIP_DEBUGF(TCP_CWND_DEBUG, ("tcp_process (SYN_RCVD): cwnd %"TCPWNDSIZE_F
|
||||||
|
" ssthresh %"TCPWNDSIZE_F"\n",
|
||||||
|
pcb->cwnd, pcb->ssthresh));
|
||||||
|
|
||||||
if (recv_flags & TF_GOT_FIN) {
|
if (recv_flags & TF_GOT_FIN) {
|
||||||
tcp_ack_now(pcb);
|
tcp_ack_now(pcb);
|
||||||
|
Loading…
Reference in New Issue
Block a user