* pbuf.h, tcp.c, tcp_in.c: fixed bug #33871: rejecting TCP_EVENT_RECV() for
the last packet including FIN can lose data
- 2011-09-22: Simon Goldschmidt
- * tcp.c: fixed bug #34360 tcp_shutdown: RST on unacked is not send when
- shutting down both rx AND tx
-
2011-09-22: Simon Goldschmidt
* tcp_impl.h: fixed bug #34355: nagle does not take snd_buf/snd_queuelen into
account
return ERR_CONN;
}
if (shut_rx) {
- /* shut down the receive side: set a flag not to receive any more data */
+ /* shut down the receive side: free buffered data... */
+ if (pcb->refused_data != NULL) {
+ pbuf_free(pcb->refused_data);
+ pcb->refused_data = NULL;
+ }
+ /* ... and set a flag not to receive any more data */
pcb->flags |= TF_RXCLOSED;
}
if (shut_tx) {
case SYN_RCVD:
case ESTABLISHED:
case CLOSE_WAIT:
- /* if shut_tx AND shut_rx, send RST if we have unacked data */
- return tcp_close_shutdown(pcb, (u8_t)shut_rx);
+ return tcp_close_shutdown(pcb, 0);
default:
/* don't shut down other states */
break;
}
}
- if (shut_rx && (pcb->refused_data != NULL)) {
- /* shut down the receive side: free buffered data if we come here */
- pbuf_free(pcb->refused_data);
- pcb->refused_data = NULL;
- }
/* @todo: return another err_t if not in correct state or already shut? */
return ERR_OK;
}