mirror of https://github.com/acidanthera/audk.git
Fix the non-blocking behavior for connect. The behavior was correct if the code polled the connect routine but was not correct when using select to complete the asynchronous request. This change fixes the select case by moving where some of the operations performed upon the connection completion.
Signed-off-by: lpleahy leroy.p.leahy@intel.com Reviewed-by: Daniel Moura oxesoft@gmail.com git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@14984 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
daf705847f
commit
ceecdc62ab
|
@ -1825,15 +1825,7 @@ EslSocketConnect (
|
||||||
// Set the next state if connected
|
// Set the next state if connected
|
||||||
//
|
//
|
||||||
if ( EFI_NOT_READY != Status ) {
|
if ( EFI_NOT_READY != Status ) {
|
||||||
if ( !EFI_ERROR ( Status )) {
|
if ( EFI_ERROR ( Status )) {
|
||||||
pSocket->State = SOCKET_STATE_CONNECTED;
|
|
||||||
|
|
||||||
//
|
|
||||||
// Start the receive operations
|
|
||||||
//
|
|
||||||
EslSocketRxStart ( pSocket->pPortList );
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
pSocket->State = SOCKET_STATE_BOUND;
|
pSocket->State = SOCKET_STATE_BOUND;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5141,7 +5133,7 @@ EslSocketRxPoll (
|
||||||
<ul>
|
<ul>
|
||||||
<li>::EslIp4Receive to restart the receive engine to release flow control.</li>
|
<li>::EslIp4Receive to restart the receive engine to release flow control.</li>
|
||||||
<li>::EslIp4RxComplete to continue the operation of the receive engine if flow control is not being applied.</li>
|
<li>::EslIp4RxComplete to continue the operation of the receive engine if flow control is not being applied.</li>
|
||||||
<li>::EslIp4SocketIsConfigured to start the recevie engine for the new socket.</li>
|
<li>::EslIp4SocketIsConfigured to start the receive engine for the new socket.</li>
|
||||||
<li>::EslTcp4ListenComplete to start the recevie engine for the new socket.</li>
|
<li>::EslTcp4ListenComplete to start the recevie engine for the new socket.</li>
|
||||||
<li>::EslTcp4Receive to restart the receive engine to release flow control.</li>
|
<li>::EslTcp4Receive to restart the receive engine to release flow control.</li>
|
||||||
<li>::EslTcp4RxComplete to continue the operation of the receive engine if flow control is not being applied.</li>
|
<li>::EslTcp4RxComplete to continue the operation of the receive engine if flow control is not being applied.</li>
|
||||||
|
|
|
@ -232,6 +232,13 @@ EslTcp4ConnectComplete (
|
||||||
pTcp4->ConfigData.AccessPoint.RemoteAddress.Addr[3],
|
pTcp4->ConfigData.AccessPoint.RemoteAddress.Addr[3],
|
||||||
pTcp4->ConfigData.AccessPoint.RemotePort ));
|
pTcp4->ConfigData.AccessPoint.RemotePort ));
|
||||||
|
|
||||||
|
//
|
||||||
|
// Start the receive operations
|
||||||
|
//
|
||||||
|
pSocket->bConfigured = TRUE;
|
||||||
|
pSocket->State = SOCKET_STATE_CONNECTED;
|
||||||
|
EslSocketRxStart ( pPort );
|
||||||
|
|
||||||
//
|
//
|
||||||
// Remove the rest of the ports
|
// Remove the rest of the ports
|
||||||
//
|
//
|
||||||
|
@ -416,7 +423,6 @@ EslTcp4ConnectPoll (
|
||||||
|
|
||||||
case EFI_SUCCESS:
|
case EFI_SUCCESS:
|
||||||
pSocket->errno = 0;
|
pSocket->errno = 0;
|
||||||
pSocket->bConfigured = TRUE;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EFI_TIMEOUT:
|
case EFI_TIMEOUT:
|
||||||
|
|
|
@ -238,6 +238,13 @@ EslTcp6ConnectComplete (
|
||||||
pTcp6->ConfigData.AccessPoint.RemoteAddress.Addr[15],
|
pTcp6->ConfigData.AccessPoint.RemoteAddress.Addr[15],
|
||||||
pTcp6->ConfigData.AccessPoint.RemotePort ));
|
pTcp6->ConfigData.AccessPoint.RemotePort ));
|
||||||
|
|
||||||
|
//
|
||||||
|
// Start the receive operations
|
||||||
|
//
|
||||||
|
pSocket->bConfigured = TRUE;
|
||||||
|
pSocket->State = SOCKET_STATE_CONNECTED;
|
||||||
|
EslSocketRxStart ( pPort );
|
||||||
|
|
||||||
//
|
//
|
||||||
// Remove the rest of the ports
|
// Remove the rest of the ports
|
||||||
//
|
//
|
||||||
|
@ -434,7 +441,6 @@ EslTcp6ConnectPoll (
|
||||||
|
|
||||||
case EFI_SUCCESS:
|
case EFI_SUCCESS:
|
||||||
pSocket->errno = 0;
|
pSocket->errno = 0;
|
||||||
pSocket->bConfigured = TRUE;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EFI_TIMEOUT:
|
case EFI_TIMEOUT:
|
||||||
|
|
Loading…
Reference in New Issue