kernel32: Return success from ReadFileEx/WriteFileEx when I/O is pending.

This commit is contained in:
Vincent Povirk 2012-06-14 14:42:47 -05:00 committed by Alexandre Julliard
parent 982153605a
commit 14404713de
2 changed files with 9 additions and 5 deletions

View File

@ -352,7 +352,7 @@ BOOL WINAPI ReadFileEx(HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
status = NtReadFile(hFile, NULL, FILE_ReadWriteApc, lpCompletionRoutine, status = NtReadFile(hFile, NULL, FILE_ReadWriteApc, lpCompletionRoutine,
io_status, buffer, bytesToRead, &offset, NULL); io_status, buffer, bytesToRead, &offset, NULL);
if (status) if (status && status != STATUS_PENDING)
{ {
SetLastError( RtlNtStatusToDosError(status) ); SetLastError( RtlNtStatusToDosError(status) );
return FALSE; return FALSE;
@ -484,8 +484,12 @@ BOOL WINAPI WriteFileEx(HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
status = NtWriteFile(hFile, NULL, FILE_ReadWriteApc, lpCompletionRoutine, status = NtWriteFile(hFile, NULL, FILE_ReadWriteApc, lpCompletionRoutine,
io_status, buffer, bytesToWrite, &offset, NULL); io_status, buffer, bytesToWrite, &offset, NULL);
if (status) SetLastError( RtlNtStatusToDosError(status) ); if (status && status != STATUS_PENDING)
return !status; {
SetLastError( RtlNtStatusToDosError(status) );
return FALSE;
}
return TRUE;
} }

View File

@ -1795,7 +1795,7 @@ static void test_readfileex_pending(void)
completion_called = 0; completion_called = 0;
ResetEvent(event); ResetEvent(event);
ret = ReadFileEx(server, read_buf, sizeof(read_buf), &overlapped, completion_routine); ret = ReadFileEx(server, read_buf, sizeof(read_buf), &overlapped, completion_routine);
todo_wine ok(ret == TRUE, "ReadFileEx failed, err=%i\n", GetLastError()); ok(ret == TRUE, "ReadFileEx failed, err=%i\n", GetLastError());
ok(completion_called == 0, "completion routine called before ReadFileEx returned\n"); ok(completion_called == 0, "completion routine called before ReadFileEx returned\n");
ret = WriteFile(client, test_string, sizeof(test_string), &num_bytes, NULL); ret = WriteFile(client, test_string, sizeof(test_string), &num_bytes, NULL);
@ -1837,7 +1837,7 @@ static void test_readfileex_pending(void)
ok(completion_lpoverlapped == &overlapped, "completion called with wrong overlapped pointer\n"); ok(completion_lpoverlapped == &overlapped, "completion called with wrong overlapped pointer\n");
} }
todo_wine ok(ret == TRUE, "WriteFileEx failed, err=%i\n", err); ok(ret == TRUE, "WriteFileEx failed, err=%i\n", err);
ok(completion_called == 0, "completion routine called but wait timed out\n"); ok(completion_called == 0, "completion routine called but wait timed out\n");
ok(completion_errorcode == 0, "completion called with error %x\n", completion_errorcode); ok(completion_errorcode == 0, "completion called with error %x\n", completion_errorcode);
ok(completion_lpoverlapped == &overlapped, "completion called with wrong overlapped pointer\n"); ok(completion_lpoverlapped == &overlapped, "completion called with wrong overlapped pointer\n");