Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
4e2827aa
Commit
4e2827aa
authored
Jan 28, 2010
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wineboot: Add a wrapper function for RegSetValueExW.
parent
1da6d263
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
23 deletions
+27
-23
wineboot.c
programs/wineboot/wineboot.c
+27
-23
No files found.
programs/wineboot/wineboot.c
View file @
4e2827aa
...
@@ -158,6 +158,12 @@ done:
...
@@ -158,6 +158,12 @@ done:
return
ret
;
return
ret
;
}
}
/* wrapper for RegSetValueExW */
static
DWORD
set_reg_value
(
HKEY
hkey
,
const
WCHAR
*
name
,
const
WCHAR
*
value
)
{
return
RegSetValueExW
(
hkey
,
name
,
0
,
REG_SZ
,
(
BYTE
*
)
value
,
(
strlenW
(
value
)
+
1
)
*
sizeof
(
WCHAR
)
);
}
/* create the volatile hardware registry keys */
/* create the volatile hardware registry keys */
static
void
create_hardware_registry_keys
(
void
)
static
void
create_hardware_registry_keys
(
void
)
{
{
...
@@ -192,7 +198,7 @@ static void create_hardware_registry_keys(void)
...
@@ -192,7 +198,7 @@ static void create_hardware_registry_keys(void)
KEY_ALL_ACCESS
,
NULL
,
&
system_key
,
NULL
))
KEY_ALL_ACCESS
,
NULL
,
&
system_key
,
NULL
))
return
;
return
;
RegSetValueExW
(
system_key
,
IdentifierW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
SysidW
,
sizeof
(
SysidW
)
);
set_reg_value
(
system_key
,
IdentifierW
,
SysidW
);
if
(
RegCreateKeyExW
(
system_key
,
fpuW
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
if
(
RegCreateKeyExW
(
system_key
,
fpuW
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
KEY_ALL_ACCESS
,
NULL
,
&
fpu_key
,
NULL
))
KEY_ALL_ACCESS
,
NULL
,
&
fpu_key
,
NULL
))
...
@@ -209,19 +215,16 @@ static void create_hardware_registry_keys(void)
...
@@ -209,19 +215,16 @@ static void create_hardware_registry_keys(void)
if
(
!
RegCreateKeyExW
(
cpu_key
,
numW
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
if
(
!
RegCreateKeyExW
(
cpu_key
,
numW
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
KEY_ALL_ACCESS
,
NULL
,
&
hkey
,
NULL
))
KEY_ALL_ACCESS
,
NULL
,
&
hkey
,
NULL
))
{
{
RegSetValueExW
(
hkey
,
IdentifierW
,
0
,
REG_SZ
,
set_reg_value
(
hkey
,
IdentifierW
,
idW
);
(
const
BYTE
*
)
idW
,
(
strlenW
(
idW
)
+
1
)
*
sizeof
(
WCHAR
)
);
/*TODO; report amd's properly*/
/*TODO; report amd's properly*/
RegSetValueExW
(
hkey
,
VendorIdentifierW
,
0
,
REG_SZ
,
set_reg_value
(
hkey
,
VendorIdentifierW
,
VenidIntelW
);
(
const
BYTE
*
)
VenidIntelW
,
sizeof
(
VenidIntelW
)
);
RegSetValueExW
(
hkey
,
mhzKeyW
,
0
,
REG_DWORD
,
(
BYTE
*
)
&
power_info
.
MaxMhz
,
sizeof
(
DWORD
)
);
RegSetValueExW
(
hkey
,
mhzKeyW
,
0
,
REG_DWORD
,
(
BYTE
*
)
&
power_info
.
MaxMhz
,
sizeof
(
DWORD
)
);
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
}
}
if
(
!
RegCreateKeyExW
(
fpu_key
,
numW
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
if
(
!
RegCreateKeyExW
(
fpu_key
,
numW
,
0
,
NULL
,
REG_OPTION_VOLATILE
,
KEY_ALL_ACCESS
,
NULL
,
&
hkey
,
NULL
))
KEY_ALL_ACCESS
,
NULL
,
&
hkey
,
NULL
))
{
{
RegSetValueExW
(
hkey
,
IdentifierW
,
0
,
REG_SZ
,
set_reg_value
(
hkey
,
IdentifierW
,
idW
);
(
const
BYTE
*
)
idW
,
(
strlenW
(
idW
)
+
1
)
*
sizeof
(
WCHAR
)
);
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
}
}
}
}
...
@@ -258,21 +261,21 @@ static void create_environment_registry_keys( void )
...
@@ -258,21 +261,21 @@ static void create_environment_registry_keys( void )
if
(
RegCreateKeyW
(
HKEY_LOCAL_MACHINE
,
EnvironW
,
&
env_key
))
return
;
if
(
RegCreateKeyW
(
HKEY_LOCAL_MACHINE
,
EnvironW
,
&
env_key
))
return
;
sprintfW
(
buffer
,
PercentDW
,
NtCurrentTeb
()
->
Peb
->
NumberOfProcessors
);
sprintfW
(
buffer
,
PercentDW
,
NtCurrentTeb
()
->
Peb
->
NumberOfProcessors
);
RegSetValueExW
(
env_key
,
NumProcW
,
0
,
REG_SZ
,
(
BYTE
*
)
buffer
,
(
strlenW
(
buffer
)
+
1
)
*
sizeof
(
WCHAR
)
);
set_reg_value
(
env_key
,
NumProcW
,
buffer
);
/* TODO: currently hardcoded x86, add different processors */
/* TODO: currently hardcoded x86, add different processors */
RegSetValueExW
(
env_key
,
ProcArchW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
x86W
,
sizeof
(
x86W
)
);
set_reg_value
(
env_key
,
ProcArchW
,
x86W
);
/* TODO: currently hardcoded Intel, add different processors */
/* TODO: currently hardcoded Intel, add different processors */
sprintfW
(
buffer
,
IntelCpuDescrW
,
sci
.
Level
,
HIBYTE
(
sci
.
Revision
),
LOBYTE
(
sci
.
Revision
)
);
sprintfW
(
buffer
,
IntelCpuDescrW
,
sci
.
Level
,
HIBYTE
(
sci
.
Revision
),
LOBYTE
(
sci
.
Revision
)
);
RegSetValueExW
(
env_key
,
ProcIdW
,
0
,
REG_SZ
,
(
BYTE
*
)
buffer
,
(
strlenW
(
buffer
)
+
1
)
*
sizeof
(
WCHAR
)
);
set_reg_value
(
env_key
,
ProcIdW
,
buffer
);
sprintfW
(
buffer
,
PercentDW
,
sci
.
Level
);
sprintfW
(
buffer
,
PercentDW
,
sci
.
Level
);
RegSetValueExW
(
env_key
,
ProcLvlW
,
0
,
REG_SZ
,
(
BYTE
*
)
buffer
,
(
strlenW
(
buffer
)
+
1
)
*
sizeof
(
WCHAR
)
);
set_reg_value
(
env_key
,
ProcLvlW
,
buffer
);
/* Properly report model/stepping */
/* Properly report model/stepping */
sprintfW
(
buffer
,
Percent04XW
,
sci
.
Revision
);
sprintfW
(
buffer
,
Percent04XW
,
sci
.
Revision
);
RegSetValueExW
(
env_key
,
ProcRevW
,
0
,
REG_SZ
,
(
BYTE
*
)
buffer
,
(
strlenW
(
buffer
)
+
1
)
*
sizeof
(
WCHAR
)
);
set_reg_value
(
env_key
,
ProcRevW
,
buffer
);
RegCloseKey
(
env_key
);
RegCloseKey
(
env_key
);
}
}
...
@@ -291,7 +294,7 @@ static void create_volatile_environment_registry_key(void)
...
@@ -291,7 +294,7 @@ static void create_volatile_environment_registry_key(void)
static
const
WCHAR
ConsoleW
[]
=
{
'C'
,
'o'
,
'n'
,
's'
,
'o'
,
'l'
,
'e'
,
0
};
static
const
WCHAR
ConsoleW
[]
=
{
'C'
,
'o'
,
'n'
,
's'
,
'o'
,
'l'
,
'e'
,
0
};
static
const
WCHAR
EmptyW
[]
=
{
0
};
static
const
WCHAR
EmptyW
[]
=
{
0
};
WCHAR
path
[
MAX_PATH
];
WCHAR
path
[
MAX_PATH
];
WCHAR
computername
[
MAX_COMPUTERNAME_LENGTH
+
1
+
2
]
=
{
'\\'
,
'\\'
}
;
WCHAR
computername
[
MAX_COMPUTERNAME_LENGTH
+
1
+
2
];
DWORD
size
=
MAX_COMPUTERNAME_LENGTH
+
1
;
DWORD
size
=
MAX_COMPUTERNAME_LENGTH
+
1
;
HKEY
hkey
;
HKEY
hkey
;
HRESULT
hr
;
HRESULT
hr
;
...
@@ -301,32 +304,33 @@ static void create_volatile_environment_registry_key(void)
...
@@ -301,32 +304,33 @@ static void create_volatile_environment_registry_key(void)
return
;
return
;
hr
=
SHGetFolderPathW
(
NULL
,
CSIDL_APPDATA
,
NULL
,
SHGFP_TYPE_CURRENT
,
path
);
hr
=
SHGetFolderPathW
(
NULL
,
CSIDL_APPDATA
,
NULL
,
SHGFP_TYPE_CURRENT
,
path
);
if
(
SUCCEEDED
(
hr
))
if
(
SUCCEEDED
(
hr
))
set_reg_value
(
hkey
,
AppDataW
,
path
);
RegSetValueExW
(
hkey
,
AppDataW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
path
,
(
strlenW
(
path
)
+
1
)
*
sizeof
(
WCHAR
)
);
RegSetValueExW
(
hkey
,
ClientNameW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
ConsoleW
,
sizeof
(
ConsoleW
)
);
set_reg_value
(
hkey
,
ClientNameW
,
ConsoleW
);
/* Write the profile path's drive letter and directory components into
/* Write the profile path's drive letter and directory components into
* HOMEDRIVE and HOMEPATH respectively. */
* HOMEDRIVE and HOMEPATH respectively. */
hr
=
SHGetFolderPathW
(
NULL
,
CSIDL_PROFILE
,
NULL
,
SHGFP_TYPE_CURRENT
,
path
);
hr
=
SHGetFolderPathW
(
NULL
,
CSIDL_PROFILE
,
NULL
,
SHGFP_TYPE_CURRENT
,
path
);
if
(
SUCCEEDED
(
hr
))
if
(
SUCCEEDED
(
hr
))
{
{
RegSetValueExW
(
hkey
,
HomePathW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
&
path
[
2
],
(
strlenW
(
path
)
+
1
-
2
)
*
sizeof
(
WCHAR
)
);
set_reg_value
(
hkey
,
HomePathW
,
path
+
2
);
path
[
2
]
=
'\0'
;
path
[
2
]
=
'\0'
;
RegSetValueExW
(
hkey
,
HomeDriveW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
path
,
3
*
sizeof
(
WCHAR
)
);
set_reg_value
(
hkey
,
HomeDriveW
,
path
);
}
}
RegSetValueExW
(
hkey
,
HomeShareW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
EmptyW
,
sizeof
(
EmptyW
)
);
set_reg_value
(
hkey
,
HomeShareW
,
EmptyW
);
hr
=
SHGetFolderPathW
(
NULL
,
CSIDL_LOCAL_APPDATA
,
NULL
,
SHGFP_TYPE_CURRENT
,
path
);
hr
=
SHGetFolderPathW
(
NULL
,
CSIDL_LOCAL_APPDATA
,
NULL
,
SHGFP_TYPE_CURRENT
,
path
);
if
(
SUCCEEDED
(
hr
))
if
(
SUCCEEDED
(
hr
))
RegSetValueExW
(
hkey
,
LocalAppDataW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
path
,
(
strlenW
(
path
)
+
1
)
*
sizeof
(
WCHAR
)
);
set_reg_value
(
hkey
,
LocalAppDataW
,
path
);
if
(
GetComputerNameW
(
&
computername
[
2
],
&
size
))
if
(
GetComputerNameW
(
&
computername
[
2
],
&
size
))
RegSetValueExW
(
hkey
,
LogonServerW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
computername
,
(
size
+
1
+
2
)
*
sizeof
(
WCHAR
)
);
{
computername
[
0
]
=
computername
[
1
]
=
'\\'
;
RegSetValueExW
(
hkey
,
SessionNameW
,
0
,
REG_SZ
,
(
const
BYTE
*
)
ConsoleW
,
sizeof
(
ConsoleW
)
);
set_reg_value
(
hkey
,
LogonServerW
,
computername
);
}
set_reg_value
(
hkey
,
SessionNameW
,
ConsoleW
);
RegCloseKey
(
hkey
);
RegCloseKey
(
hkey
);
}
}
...
...
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