mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2024-11-16 14:11:02 +00:00
fixed bug #34636: FIN_WAIT_2 - Incorrect shutdown of TCP pcb: don't let PCBs time out from FIN_WAIT_2 if the RX side wasn't close (by either calling tcp_close or tcp_shutdown(RDWR))
This commit is contained in:
parent
bec8cf9f38
commit
593f75fc3b
@ -62,6 +62,9 @@ HISTORY
|
||||
|
||||
++ Bugfixes:
|
||||
|
||||
2012-01-21: Simon Goldschmidt
|
||||
* tcp.c: fixed bug #34636: FIN_WAIT_2 - Incorrect shutdown of TCP pcb
|
||||
|
||||
2012-01-20: Simon Goldschmidt
|
||||
* dhcp.c: fixed bug #35151: DHCP asserts on incoming option lengths
|
||||
|
||||
|
@ -872,12 +872,17 @@ tcp_slowtmr_start:
|
||||
}
|
||||
/* Check if this PCB has stayed too long in FIN-WAIT-2 */
|
||||
if (pcb->state == FIN_WAIT_2) {
|
||||
/* If this PCB is in FIN_WAIT_2 because of SHUT_WR don't let it time out. */
|
||||
if (pcb->flags & TF_RXCLOSED) {
|
||||
/* PCB was fully closed (either through close() or SHUT_RDWR):
|
||||
normal FIN-WAIT timeout handling. */
|
||||
if ((u32_t)(tcp_ticks - pcb->tmr) >
|
||||
TCP_FIN_WAIT_TIMEOUT / TCP_SLOW_INTERVAL) {
|
||||
++pcb_remove;
|
||||
LWIP_DEBUGF(TCP_DEBUG, ("tcp_slowtmr: removing pcb stuck in FIN-WAIT-2\n"));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* Check if KEEPALIVE should be sent */
|
||||
if(ip_get_option(pcb, SOF_KEEPALIVE) &&
|
||||
|
Loading…
Reference in New Issue
Block a user