Commit 3bbd37d0 authored by Sven Baars's avatar Sven Baars Committed by Alexandre Julliard

kernelbase: Call create_key() from create_subkey().

parent 899b0b82
...@@ -227,44 +227,28 @@ static NTSTATUS open_key( HKEY *retkey, HKEY root, UNICODE_STRING *name, DWORD o ...@@ -227,44 +227,28 @@ static NTSTATUS open_key( HKEY *retkey, HKEY root, UNICODE_STRING *name, DWORD o
return status; return status;
} }
static NTSTATUS create_key( HKEY *retkey, HKEY root, UNICODE_STRING name, ULONG options, ACCESS_MASK access,
const UNICODE_STRING *class, PULONG dispos );
static NTSTATUS create_subkey( HKEY *subkey, HKEY root, UNICODE_STRING *name, DWORD options, ACCESS_MASK access, static NTSTATUS create_subkey( HKEY *subkey, HKEY root, UNICODE_STRING *name, DWORD options, ACCESS_MASK access,
const UNICODE_STRING *class, PULONG dispos ) const UNICODE_STRING *class, PULONG dispos )
{ {
ACCESS_MASK access_64 = access & ~KEY_WOW64_32KEY;
DWORD i = 0, len = name->Length / sizeof(WCHAR); DWORD i = 0, len = name->Length / sizeof(WCHAR);
WCHAR *buffer = name->Buffer; WCHAR *buffer = name->Buffer;
OBJECT_ATTRIBUTES attr;
UNICODE_STRING str; UNICODE_STRING str;
NTSTATUS status; NTSTATUS status;
attr.Length = sizeof(attr);
attr.RootDirectory = root;
attr.ObjectName = &str;
attr.Attributes = 0;
attr.SecurityDescriptor = NULL;
attr.SecurityQualityOfService = NULL;
if (i < len && buffer[i] == '\\') return STATUS_OBJECT_PATH_INVALID; if (i < len && buffer[i] == '\\') return STATUS_OBJECT_PATH_INVALID;
while (i < len && buffer[i] != '\\') i++; while (i < len && buffer[i] != '\\') i++;
str.Buffer = name->Buffer; str.Buffer = name->Buffer;
str.Length = i * sizeof(WCHAR); str.Length = i * sizeof(WCHAR);
if (i == len) if (i < len)
{
if (options & REG_OPTION_OPEN_LINK) attr.Attributes |= OBJ_OPENLINK;
}
else
{
options &= ~REG_OPTION_CREATE_LINK; options &= ~REG_OPTION_CREATE_LINK;
}
status = NtCreateKey( (HANDLE *)subkey, access, &attr, 0, class, options, dispos );
if (status == STATUS_PREDEFINED_HANDLE)
{
*subkey = get_perflib_key( *subkey );
status = STATUS_SUCCESS;
}
status = create_key( subkey, root, str, options, access_64, class, dispos );
if (!status) if (!status)
{ {
while (i < len && buffer[i] == '\\') i++; while (i < len && buffer[i] == '\\') i++;
......
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