-
Notifications
You must be signed in to change notification settings - Fork 13.3k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Fix TCP race condition, remove fixed delay in CC #5167
Conversation
ClientContext::_wait_for_sent9) could dereference a TCP's _pcb after the connection was dropped by the OS, resulting in a crash. Move the connection dropped check to catch this case, and replace a fixed millisecond delay() with a yield and timeout value to minimize wasted time when transmission completes.
@@ -308,37 +308,37 @@ class ClientContext | |||
if (!_pcb) | |||
return true; | |||
|
|||
int loop = -1; | |||
int prevsndbuf = -1; | |||
max_wait_ms++; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
max_wait_ms++;
no more necessary
|
||
// force lwIP to send what can be sent | ||
tcp_output(_pcb); | ||
|
||
int sndbuf = tcp_sndbuf(_pcb); | ||
if (sndbuf != prevsndbuf) { | ||
// send buffer has changed (or first iteration) | ||
// we received an ack: restart the loop counter | ||
// we received an ack: restart the timeout |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
just remove this comment, your new one is better
// wait until sent: timeout | ||
DEBUGV(":wustmo\n"); | ||
#endif | ||
break; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this break
would be return false;
} | ||
#endif | ||
|
||
return max_wait_ms > 0; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
return true;
here
ClientContext::_wait_for_sent() could dereference a TCP's _pcb after
the connection was dropped by the OS, resulting in a crash.
Move the connection dropped check to catch this case, and replace
a fixed millisecond delay() with a yield and timeout value to minimize
wasted time when transmission completes.