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:
committed by
lpleahy
parent
daf705847f
commit
ceecdc62ab
@@ -232,6 +232,13 @@ EslTcp4ConnectComplete (
|
||||
pTcp4->ConfigData.AccessPoint.RemoteAddress.Addr[3],
|
||||
pTcp4->ConfigData.AccessPoint.RemotePort ));
|
||||
|
||||
//
|
||||
// Start the receive operations
|
||||
//
|
||||
pSocket->bConfigured = TRUE;
|
||||
pSocket->State = SOCKET_STATE_CONNECTED;
|
||||
EslSocketRxStart ( pPort );
|
||||
|
||||
//
|
||||
// Remove the rest of the ports
|
||||
//
|
||||
@@ -416,7 +423,6 @@ EslTcp4ConnectPoll (
|
||||
|
||||
case EFI_SUCCESS:
|
||||
pSocket->errno = 0;
|
||||
pSocket->bConfigured = TRUE;
|
||||
break;
|
||||
|
||||
case EFI_TIMEOUT:
|
||||
|
Reference in New Issue
Block a user