Commit 1a18f3b9 authored by Daniel Lehman's avatar Daniel Lehman Committed by Alexandre Julliard

ntdll: Return success for magic handles.

parent 18f46e5a
...@@ -1223,7 +1223,6 @@ static void test_debugger(DWORD cont_status) ...@@ -1223,7 +1223,6 @@ static void test_debugger(DWORD cont_status)
} }
else if (stage == 13) else if (stage == 13)
{ {
todo_wine
ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n"); ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n");
continuestatus = DBG_EXCEPTION_NOT_HANDLED; continuestatus = DBG_EXCEPTION_NOT_HANDLED;
} }
...@@ -3923,7 +3922,6 @@ static void test_debugger(DWORD cont_status) ...@@ -3923,7 +3922,6 @@ static void test_debugger(DWORD cont_status)
} }
else if (stage == 13) else if (stage == 13)
{ {
todo_wine
ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n"); ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n");
continuestatus = DBG_EXCEPTION_NOT_HANDLED; continuestatus = DBG_EXCEPTION_NOT_HANDLED;
} }
...@@ -6627,7 +6625,6 @@ static void test_debugger(DWORD cont_status) ...@@ -6627,7 +6625,6 @@ static void test_debugger(DWORD cont_status)
} }
else if (stage == 13) else if (stage == 13)
{ {
todo_wine
ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n"); ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n");
continuestatus = DBG_EXCEPTION_NOT_HANDLED; continuestatus = DBG_EXCEPTION_NOT_HANDLED;
} }
...@@ -7881,7 +7878,6 @@ static void test_debugger(DWORD cont_status) ...@@ -7881,7 +7878,6 @@ static void test_debugger(DWORD cont_status)
} }
else if (stage == 13) else if (stage == 13)
{ {
todo_wine
ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n"); ok(FALSE || broken(TRUE) /* < Win10 */, "should not throw exception\n");
continuestatus = DBG_EXCEPTION_NOT_HANDLED; continuestatus = DBG_EXCEPTION_NOT_HANDLED;
} }
...@@ -8624,24 +8620,20 @@ static void test_closehandle(DWORD numexc, HANDLE handle) ...@@ -8624,24 +8620,20 @@ static void test_closehandle(DWORD numexc, HANDLE handle)
ret = CloseHandle(handle); ret = CloseHandle(handle);
ok(expectret || (GetLastError() == ERROR_INVALID_HANDLE), ok(expectret || (GetLastError() == ERROR_INVALID_HANDLE),
"CloseHandle had wrong GetLastError(), got %lu for %p\n", GetLastError(), handle); "CloseHandle had wrong GetLastError(), got %lu for %p\n", GetLastError(), handle);
todo_wine_if(is_magic_handle(handle)) {
ok(ret == expectret || broken(HandleToLong(handle) < 0) /* < Win10 */, ok(ret == expectret || broken(HandleToLong(handle) < 0) /* < Win10 */,
"CloseHandle expected %d, got %d for %p\n", expectret, ret, handle); "CloseHandle expected %d, got %d for %p\n", expectret, ret, handle);
ok(invalid_handle_exceptions == numexc || broken(!numexc && is_magic_handle(handle)), /* < Win10 */ ok(invalid_handle_exceptions == numexc || broken(!numexc && is_magic_handle(handle)), /* < Win10 */
"CloseHandle generated %ld exceptions, expected %ld for %p\n", "CloseHandle generated %ld exceptions, expected %ld for %p\n",
invalid_handle_exceptions, numexc, handle); invalid_handle_exceptions, numexc, handle);
}
invalid_handle_exceptions = 0; invalid_handle_exceptions = 0;
expect = expectret ? STATUS_SUCCESS : STATUS_INVALID_HANDLE; expect = expectret ? STATUS_SUCCESS : STATUS_INVALID_HANDLE;
status = pNtClose(handle); status = pNtClose(handle);
todo_wine_if(is_magic_handle(handle)) {
ok(status == expect || broken(HandleToLong(handle) < 0), /* < Win10 */ ok(status == expect || broken(HandleToLong(handle) < 0), /* < Win10 */
"NtClose returned unexpected status %#lx, expected %#lx for %p\n", status, expect, handle); "NtClose returned unexpected status %#lx, expected %#lx for %p\n", status, expect, handle);
ok(invalid_handle_exceptions == numexc || broken(!numexc && is_magic_handle(handle)), /* < Win10 */ ok(invalid_handle_exceptions == numexc || broken(!numexc && is_magic_handle(handle)), /* < Win10 */
"CloseHandle generated %ld exceptions, expected %ld for %p\n", "CloseHandle generated %ld exceptions, expected %ld for %p\n",
invalid_handle_exceptions, numexc, handle); invalid_handle_exceptions, numexc, handle);
}
pRtlRemoveVectoredExceptionHandler(vectored_handler); pRtlRemoveVectoredExceptionHandler(vectored_handler);
} }
......
...@@ -1704,6 +1704,9 @@ NTSTATUS WINAPI NtClose( HANDLE handle ) ...@@ -1704,6 +1704,9 @@ NTSTATUS WINAPI NtClose( HANDLE handle )
NTSTATUS ret; NTSTATUS ret;
int fd; int fd;
if (HandleToLong( handle ) >= ~5 && HandleToLong( handle ) <= ~0)
return STATUS_SUCCESS;
server_enter_uninterrupted_section( &fd_cache_mutex, &sigset ); server_enter_uninterrupted_section( &fd_cache_mutex, &sigset );
/* always remove the cached fd; if the server request fails we'll just /* always remove the cached fd; if the server request fails we'll just
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment