Improve async i/o compatability. lpOverlapped->Internal should hold

the overlapped transfer status.
This commit is contained in:
Mike McCormack 2000-12-29 19:35:25 +00:00 committed by Alexandre Julliard
parent 775fc630da
commit 1c80bc927e
1 changed files with 11 additions and 4 deletions

View File

@ -2794,7 +2794,9 @@ VOID COMM_WaitCommEventService(void **args)
if(buffer)
*buffer = events;
lpOverlapped->Internal = STATUS_SUCCESS;
SetEvent( lpOverlapped->hEvent);
CloseHandle(lpOverlapped->InternalHigh);
}
/***********************************************************************
@ -2842,8 +2844,10 @@ BOOL WINAPI WaitCommEvent(
return FALSE;
}
lpov->Internal = 0;
lpov->InternalHigh = hFile;
ResetEvent(lpov->hEvent);
lpov->Internal = STATUS_PENDING;
lpov->InternalHigh = 0;
lpov->Offset = 0;
lpov->OffsetHigh = 0;
@ -2861,7 +2865,7 @@ BOOL WINAPI WaitCommEvent(
ret=server_call( REQ_CREATE_ASYNC );
lpov->Internal = req->ov_handle;
lpov->InternalHigh = req->ov_handle;
}
SERVER_END_REQ;
@ -2873,6 +2877,9 @@ BOOL WINAPI WaitCommEvent(
return FALSE;
}
/* activate the overlapped operation */
lpov->Internal = STATUS_PENDING;
/* wait ourselves if the caller didn't give us an overlapped struct */
if(!lpOverlapped)
{