Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
1cf1a3f2
Commit
1cf1a3f2
authored
Sep 22, 2009
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Only create the CPU registry keys on first run.
parent
e1e9f599
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
7 deletions
+14
-7
nt.c
dlls/ntdll/nt.c
+14
-7
No files found.
dlls/ntdll/nt.c
View file @
1cf1a3f2
...
...
@@ -857,7 +857,7 @@ static inline void get_cpuinfo(SYSTEM_CPU_INFORMATION* info)
}
}
static
void
create_system_registry_keys
(
void
)
static
BOOL
create_system_registry_keys
(
void
)
{
static
const
WCHAR
SystemW
[]
=
{
'M'
,
'a'
,
'c'
,
'h'
,
'i'
,
'n'
,
'e'
,
'\\'
,
'H'
,
'a'
,
'r'
,
'd'
,
'w'
,
'a'
,
'r'
,
'e'
,
'\\'
,
...
...
@@ -878,6 +878,7 @@ static void create_system_registry_keys( void )
HANDLE
hkey
,
system_key
,
cpu_key
;
OBJECT_ATTRIBUTES
attr
;
UNICODE_STRING
nameW
,
valueW
;
ULONG
dispos
;
attr
.
Length
=
sizeof
(
attr
);
attr
.
RootDirectory
=
0
;
...
...
@@ -887,17 +888,23 @@ static void create_system_registry_keys( void )
attr
.
SecurityQualityOfService
=
NULL
;
RtlInitUnicodeString
(
&
nameW
,
SystemW
);
if
(
NtCreateKey
(
&
system_key
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
0
,
NULL
))
return
;
if
(
NtCreateKey
(
&
system_key
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
&
dispos
))
return
FALSE
;
if
(
dispos
==
REG_OPENED_EXISTING_KEY
)
{
NtClose
(
system_key
);
return
FALSE
;
}
RtlInitUnicodeString
(
&
valueW
,
IdentifierW
);
NtSetValueKey
(
system_key
,
&
valueW
,
0
,
REG_SZ
,
SysidW
,
sizeof
(
SysidW
)
);
attr
.
RootDirectory
=
system_key
;
RtlInitUnicodeString
(
&
nameW
,
fpuW
);
if
(
!
NtCreateKey
(
&
hkey
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
0
,
NULL
))
NtClose
(
hkey
);
if
(
!
NtCreateKey
(
&
hkey
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
NULL
))
NtClose
(
hkey
);
RtlInitUnicodeString
(
&
nameW
,
cpuW
);
if
(
!
NtCreateKey
(
&
cpu_key
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
0
,
NULL
))
if
(
!
NtCreateKey
(
&
cpu_key
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
NULL
))
{
for
(
i
=
0
;
i
<
NtCurrentTeb
()
->
Peb
->
NumberOfProcessors
;
i
++
)
{
...
...
@@ -906,7 +913,7 @@ static void create_system_registry_keys( void )
attr
.
RootDirectory
=
cpu_key
;
sprintfW
(
numW
,
PercentDW
,
i
);
RtlInitUnicodeString
(
&
nameW
,
numW
);
if
(
!
NtCreateKey
(
&
hkey
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
0
,
NULL
))
if
(
!
NtCreateKey
(
&
hkey
,
KEY_ALL_ACCESS
,
&
attr
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
NULL
))
{
PROCESSOR_POWER_INFORMATION
power_info
;
DWORD
cpuMHz
;
...
...
@@ -935,6 +942,7 @@ static void create_system_registry_keys( void )
NtClose
(
cpu_key
);
}
NtClose
(
system_key
);
return
TRUE
;
}
static
void
create_env_registry_keys
(
void
)
...
...
@@ -1377,8 +1385,7 @@ void fill_cpu_info(void)
TRACE
(
"<- CPU arch %d, level %d, rev %d, features 0x%x
\n
"
,
cached_sci
.
Architecture
,
cached_sci
.
Level
,
cached_sci
.
Revision
,
cached_sci
.
FeatureSet
);
create_env_registry_keys
();
create_system_registry_keys
();
if
(
create_system_registry_keys
())
create_env_registry_keys
();
}
/******************************************************************************
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment