From fdff5c3a3a9e7c90c2ac65b39e2a2fb47628c0c5 Mon Sep 17 00:00:00 2001 From: Bang Jun-Young Date: Mon, 29 Jan 2007 22:55:02 +0900 Subject: [PATCH] ntdll: Fix NtUnloadKey to match the DDK. --- dlls/advapi32/registry.c | 6 +++++- dlls/ntdll/reg.c | 6 +++--- include/winternl.h | 2 +- 3 files changed, 9 insertions(+), 5 deletions(-) diff --git a/dlls/advapi32/registry.c b/dlls/advapi32/registry.c index 54b0bfb6d36..6589a2351a1 100644 --- a/dlls/advapi32/registry.c +++ b/dlls/advapi32/registry.c @@ -2089,6 +2089,8 @@ LONG WINAPI RegUnLoadKeyW( HKEY hkey, LPCWSTR lpSubKey ) { DWORD ret; HKEY shkey; + OBJECT_ATTRIBUTES attr; + UNICODE_STRING subkey; TRACE("(%p,%s)\n",hkey, debugstr_w(lpSubKey)); @@ -2096,7 +2098,9 @@ LONG WINAPI RegUnLoadKeyW( HKEY hkey, LPCWSTR lpSubKey ) if( ret ) return ERROR_INVALID_PARAMETER; - ret = RtlNtStatusToDosError(NtUnloadKey(shkey)); + RtlInitUnicodeString(&subkey, lpSubKey); + InitializeObjectAttributes(&attr, &subkey, OBJ_CASE_INSENSITIVE, shkey, NULL); + ret = RtlNtStatusToDosError(NtUnloadKey(&attr)); RegCloseKey(shkey); diff --git a/dlls/ntdll/reg.c b/dlls/ntdll/reg.c index be9a34ac8ea..99a46c018d7 100644 --- a/dlls/ntdll/reg.c +++ b/dlls/ntdll/reg.c @@ -775,15 +775,15 @@ NTSTATUS WINAPI RtlpNtSetValueKey( HANDLE hkey, ULONG type, const void *data, * NtUnloadKey [NTDLL.@] * ZwUnloadKey [NTDLL.@] */ -NTSTATUS WINAPI NtUnloadKey(IN HANDLE KeyHandle) +NTSTATUS WINAPI NtUnloadKey(IN POBJECT_ATTRIBUTES attr) { NTSTATUS ret; - TRACE("(%p)\n", KeyHandle); + TRACE("(%p)\n", attr); SERVER_START_REQ( unload_registry ) { - req->hkey = KeyHandle; + req->hkey = attr->RootDirectory; ret = wine_server_call(req); } SERVER_END_REQ; diff --git a/include/winternl.h b/include/winternl.h index 19b2ac94327..e128268dbc7 100644 --- a/include/winternl.h +++ b/include/winternl.h @@ -1935,7 +1935,7 @@ NTSTATUS WINAPI NtTerminateProcess(HANDLE,LONG); NTSTATUS WINAPI NtTerminateThread(HANDLE,LONG); NTSTATUS WINAPI NtTestAlert(VOID); NTSTATUS WINAPI NtUnloadDriver(const UNICODE_STRING *); -NTSTATUS WINAPI NtUnloadKey(HANDLE); +NTSTATUS WINAPI NtUnloadKey(POBJECT_ATTRIBUTES); NTSTATUS WINAPI NtUnloadKeyEx(POBJECT_ATTRIBUTES,HANDLE); NTSTATUS WINAPI NtUnlockFile(HANDLE,PIO_STATUS_BLOCK,PLARGE_INTEGER,PLARGE_INTEGER,PULONG); NTSTATUS WINAPI NtUnlockVirtualMemory(HANDLE,PVOID*,SIZE_T*,ULONG);