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
461b5e56
Commit
461b5e56
authored
Nov 05, 2019
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kernel32: Move support for running wineboot to ntdll.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
326df4c1
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
96 additions
and
18 deletions
+96
-18
process.c
dlls/kernel32/process.c
+0
-0
env.c
dlls/ntdll/env.c
+88
-12
wineboot.c
programs/wineboot/wineboot.c
+8
-6
No files found.
dlls/kernel32/process.c
View file @
461b5e56
This diff is collapsed.
Click to expand it.
dlls/ntdll/env.c
View file @
461b5e56
...
@@ -51,6 +51,8 @@ static const BOOL is_win64 = (sizeof(void *) > sizeof(int));
...
@@ -51,6 +51,8 @@ static const BOOL is_win64 = (sizeof(void *) > sizeof(int));
static
const
WCHAR
windows_dir
[]
=
{
'C'
,
':'
,
'\\'
,
'w'
,
'i'
,
'n'
,
'd'
,
'o'
,
'w'
,
's'
,
0
};
static
const
WCHAR
windows_dir
[]
=
{
'C'
,
':'
,
'\\'
,
'w'
,
'i'
,
'n'
,
'd'
,
'o'
,
'w'
,
's'
,
0
};
static
BOOL
first_prefix_start
;
/* first ever process start in this prefix? */
static
inline
SIZE_T
get_env_length
(
const
WCHAR
*
env
)
static
inline
SIZE_T
get_env_length
(
const
WCHAR
*
env
)
{
{
const
WCHAR
*
end
=
env
;
const
WCHAR
*
end
=
env
;
...
@@ -153,7 +155,7 @@ static void set_registry_variables( WCHAR **env, HANDLE hkey, ULONG type )
...
@@ -153,7 +155,7 @@ static void set_registry_variables( WCHAR **env, HANDLE hkey, ULONG type )
* %SystemRoot% which are predefined. But Wine defines these in the
* %SystemRoot% which are predefined. But Wine defines these in the
* registry, so we need two passes.
* registry, so we need two passes.
*/
*/
static
void
set_registry_environment
(
WCHAR
**
env
)
static
BOOL
set_registry_environment
(
WCHAR
**
env
,
BOOL
first_time
)
{
{
static
const
WCHAR
env_keyW
[]
=
{
'\\'
,
'R'
,
'e'
,
'g'
,
'i'
,
's'
,
't'
,
'r'
,
'y'
,
'\\'
,
static
const
WCHAR
env_keyW
[]
=
{
'\\'
,
'R'
,
'e'
,
'g'
,
'i'
,
's'
,
't'
,
'r'
,
'y'
,
'\\'
,
'M'
,
'a'
,
'c'
,
'h'
,
'i'
,
'n'
,
'e'
,
'\\'
,
'M'
,
'a'
,
'c'
,
'h'
,
'i'
,
'n'
,
'e'
,
'\\'
,
...
@@ -168,27 +170,23 @@ static void set_registry_environment( WCHAR **env )
...
@@ -168,27 +170,23 @@ static void set_registry_environment( WCHAR **env )
OBJECT_ATTRIBUTES
attr
;
OBJECT_ATTRIBUTES
attr
;
UNICODE_STRING
nameW
;
UNICODE_STRING
nameW
;
HANDLE
hkey
;
HANDLE
hkey
;
BOOL
ret
=
FALSE
;
attr
.
Length
=
sizeof
(
attr
);
attr
.
RootDirectory
=
0
;
attr
.
ObjectName
=
&
nameW
;
attr
.
Attributes
=
0
;
attr
.
SecurityDescriptor
=
NULL
;
attr
.
SecurityQualityOfService
=
NULL
;
/* first the system environment variables */
/* first the system environment variables */
InitializeObjectAttributes
(
&
attr
,
&
nameW
,
0
,
0
,
NULL
);
RtlInitUnicodeString
(
&
nameW
,
env_keyW
);
RtlInitUnicodeString
(
&
nameW
,
env_keyW
);
if
(
!
NtOpenKey
(
&
hkey
,
KEY_READ
,
&
attr
))
if
(
first_time
&&
!
NtOpenKey
(
&
hkey
,
KEY_READ
,
&
attr
))
{
{
set_registry_variables
(
env
,
hkey
,
REG_SZ
);
set_registry_variables
(
env
,
hkey
,
REG_SZ
);
set_registry_variables
(
env
,
hkey
,
REG_EXPAND_SZ
);
set_registry_variables
(
env
,
hkey
,
REG_EXPAND_SZ
);
NtClose
(
hkey
);
NtClose
(
hkey
);
}
}
else
ret
=
TRUE
;
/* then the ones for the current user */
/* then the ones for the current user */
if
(
RtlOpenCurrentUser
(
KEY_READ
,
&
attr
.
RootDirectory
)
!=
STATUS_SUCCESS
)
return
;
if
(
RtlOpenCurrentUser
(
KEY_READ
,
&
attr
.
RootDirectory
)
!=
STATUS_SUCCESS
)
return
ret
;
RtlInitUnicodeString
(
&
nameW
,
envW
);
RtlInitUnicodeString
(
&
nameW
,
envW
);
if
(
!
NtOpenKey
(
&
hkey
,
KEY_READ
,
&
attr
))
if
(
first_time
&&
!
NtOpenKey
(
&
hkey
,
KEY_READ
,
&
attr
))
{
{
set_registry_variables
(
env
,
hkey
,
REG_SZ
);
set_registry_variables
(
env
,
hkey
,
REG_SZ
);
set_registry_variables
(
env
,
hkey
,
REG_EXPAND_SZ
);
set_registry_variables
(
env
,
hkey
,
REG_EXPAND_SZ
);
...
@@ -204,6 +202,7 @@ static void set_registry_environment( WCHAR **env )
...
@@ -204,6 +202,7 @@ static void set_registry_environment( WCHAR **env )
}
}
NtClose
(
attr
.
RootDirectory
);
NtClose
(
attr
.
RootDirectory
);
return
ret
;
}
}
...
@@ -365,7 +364,7 @@ static WCHAR *build_initial_environment( char **env )
...
@@ -365,7 +364,7 @@ static WCHAR *build_initial_environment( char **env )
p
+=
strlenW
(
p
)
+
1
;
p
+=
strlenW
(
p
)
+
1
;
}
}
*
p
=
0
;
*
p
=
0
;
set_registry_environment
(
&
ptr
);
first_prefix_start
=
set_registry_environment
(
&
ptr
,
TRUE
);
set_additional_environment
(
&
ptr
);
set_additional_environment
(
&
ptr
);
return
ptr
;
return
ptr
;
}
}
...
@@ -1133,6 +1132,81 @@ static inline void get_unicode_string( UNICODE_STRING *str, WCHAR **src, UINT le
...
@@ -1133,6 +1132,81 @@ static inline void get_unicode_string( UNICODE_STRING *str, WCHAR **src, UINT le
*
src
+=
len
/
sizeof
(
WCHAR
);
*
src
+=
len
/
sizeof
(
WCHAR
);
}
}
/***********************************************************************
* run_wineboot
*/
static
void
run_wineboot
(
WCHAR
**
env
)
{
static
const
WCHAR
wineboot_eventW
[]
=
{
'\\'
,
'K'
,
'e'
,
'r'
,
'n'
,
'e'
,
'l'
,
'O'
,
'b'
,
'j'
,
'e'
,
'c'
,
't'
,
's'
,
'\\'
,
'_'
,
'_'
,
'w'
,
'i'
,
'n'
,
'e'
,
'b'
,
'o'
,
'o'
,
't'
,
'_'
,
'e'
,
'v'
,
'e'
,
'n'
,
't'
,
0
};
static
const
WCHAR
wineboot
[]
=
{
'\\'
,
'?'
,
'?'
,
'\\'
,
'C'
,
':'
,
'\\'
,
'w'
,
'i'
,
'n'
,
'd'
,
'o'
,
'w'
,
's'
,
'\\'
,
's'
,
'y'
,
's'
,
't'
,
'e'
,
'm'
,
'3'
,
'2'
,
'\\'
,
'w'
,
'i'
,
'n'
,
'e'
,
'b'
,
'o'
,
'o'
,
't'
,
'.'
,
'e'
,
'x'
,
'e'
,
0
};
static
const
WCHAR
cmdline
[]
=
{
'C'
,
':'
,
'\\'
,
'w'
,
'i'
,
'n'
,
'd'
,
'o'
,
'w'
,
's'
,
'\\'
,
's'
,
'y'
,
's'
,
't'
,
'e'
,
'm'
,
'3'
,
'2'
,
'\\'
,
'w'
,
'i'
,
'n'
,
'e'
,
'b'
,
'o'
,
'o'
,
't'
,
'.'
,
'e'
,
'x'
,
'e'
,
' '
,
'-'
,
'-'
,
'i'
,
'n'
,
'i'
,
't'
,
0
};
UNICODE_STRING
nameW
,
cmdlineW
,
dllpathW
;
RTL_USER_PROCESS_PARAMETERS
*
params
;
RTL_USER_PROCESS_INFORMATION
info
;
WCHAR
*
load_path
,
*
dummy
;
OBJECT_ATTRIBUTES
attr
;
LARGE_INTEGER
timeout
;
HANDLE
handles
[
2
];
NTSTATUS
status
;
ULONG
redir
=
0
;
int
count
=
1
;
RtlInitUnicodeString
(
&
nameW
,
wineboot_eventW
);
InitializeObjectAttributes
(
&
attr
,
&
nameW
,
OBJ_OPENIF
,
0
,
NULL
);
status
=
NtCreateEvent
(
&
handles
[
0
],
EVENT_ALL_ACCESS
,
&
attr
,
NotificationEvent
,
0
);
if
(
status
==
STATUS_OBJECT_NAME_EXISTS
)
goto
wait
;
if
(
status
)
{
ERR
(
"failed to create wineboot event, expect trouble
\n
"
);
return
;
}
LdrGetDllPath
(
wineboot
+
4
,
LOAD_WITH_ALTERED_SEARCH_PATH
,
&
load_path
,
&
dummy
);
RtlInitUnicodeString
(
&
nameW
,
wineboot
+
4
);
RtlInitUnicodeString
(
&
dllpathW
,
load_path
);
RtlInitUnicodeString
(
&
cmdlineW
,
cmdline
);
RtlCreateProcessParametersEx
(
&
params
,
&
nameW
,
&
dllpathW
,
NULL
,
&
cmdlineW
,
*
env
,
NULL
,
NULL
,
NULL
,
NULL
,
PROCESS_PARAMS_FLAG_NORMALIZED
);
params
->
hStdInput
=
0
;
params
->
hStdOutput
=
0
;
params
->
hStdError
=
NtCurrentTeb
()
->
Peb
->
ProcessParameters
->
hStdError
;
RtlInitUnicodeString
(
&
nameW
,
wineboot
);
RtlWow64EnableFsRedirectionEx
(
TRUE
,
&
redir
);
status
=
RtlCreateUserProcess
(
&
nameW
,
OBJ_CASE_INSENSITIVE
,
params
,
NULL
,
NULL
,
0
,
FALSE
,
0
,
0
,
&
info
);
RtlWow64EnableFsRedirection
(
!
redir
);
RtlReleasePath
(
load_path
);
RtlDestroyProcessParameters
(
params
);
if
(
status
)
{
ERR
(
"failed to start wineboot %x
\n
"
,
status
);
NtClose
(
handles
[
0
]
);
return
;
}
NtResumeThread
(
info
.
Thread
,
NULL
);
NtClose
(
info
.
Thread
);
handles
[
count
++
]
=
info
.
Process
;
wait:
timeout
.
QuadPart
=
(
ULONGLONG
)(
first_prefix_start
?
5
:
2
)
*
60
*
1000
*
-
10000
;
if
(
NtWaitForMultipleObjects
(
count
,
handles
,
TRUE
,
FALSE
,
&
timeout
)
==
WAIT_TIMEOUT
)
ERR
(
"boot event wait timed out
\n
"
);
while
(
count
)
NtClose
(
handles
[
--
count
]
);
/* reload environment now that wineboot has run */
set_registry_environment
(
env
,
first_prefix_start
);
set_additional_environment
(
env
);
}
/***********************************************************************
/***********************************************************************
* init_user_process_params
* init_user_process_params
*
*
...
@@ -1173,6 +1247,8 @@ void init_user_process_params( SIZE_T data_size )
...
@@ -1173,6 +1247,8 @@ void init_user_process_params( SIZE_T data_size )
if
(
!
isatty
(
2
))
if
(
!
isatty
(
2
))
wine_server_fd_to_handle
(
2
,
GENERIC_WRITE
|
SYNCHRONIZE
,
OBJ_INHERIT
,
&
params
->
hStdError
);
wine_server_fd_to_handle
(
2
,
GENERIC_WRITE
|
SYNCHRONIZE
,
OBJ_INHERIT
,
&
params
->
hStdError
);
params
->
wShowWindow
=
1
;
/* SW_SHOWNORMAL */
params
->
wShowWindow
=
1
;
/* SW_SHOWNORMAL */
run_wineboot
(
&
params
->
Environment
);
goto
done
;
goto
done
;
}
}
...
...
programs/wineboot/wineboot.c
View file @
461b5e56
...
@@ -1278,13 +1278,15 @@ int __cdecl main( int argc, char *argv[] )
...
@@ -1278,13 +1278,15 @@ int __cdecl main( int argc, char *argv[] )
static
const
WCHAR
RunOnceW
[]
=
{
'R'
,
'u'
,
'n'
,
'O'
,
'n'
,
'c'
,
'e'
,
0
};
static
const
WCHAR
RunOnceW
[]
=
{
'R'
,
'u'
,
'n'
,
'O'
,
'n'
,
'c'
,
'e'
,
0
};
static
const
WCHAR
RunServicesW
[]
=
{
'R'
,
'u'
,
'n'
,
'S'
,
'e'
,
'r'
,
'v'
,
'i'
,
'c'
,
'e'
,
's'
,
0
};
static
const
WCHAR
RunServicesW
[]
=
{
'R'
,
'u'
,
'n'
,
'S'
,
'e'
,
'r'
,
'v'
,
'i'
,
'c'
,
'e'
,
's'
,
0
};
static
const
WCHAR
RunServicesOnceW
[]
=
{
'R'
,
'u'
,
'n'
,
'S'
,
'e'
,
'r'
,
'v'
,
'i'
,
'c'
,
'e'
,
's'
,
'O'
,
'n'
,
'c'
,
'e'
,
0
};
static
const
WCHAR
RunServicesOnceW
[]
=
{
'R'
,
'u'
,
'n'
,
'S'
,
'e'
,
'r'
,
'v'
,
'i'
,
'c'
,
'e'
,
's'
,
'O'
,
'n'
,
'c'
,
'e'
,
0
};
static
const
WCHAR
wineboot_eventW
[]
=
{
'_'
,
'_'
,
'w'
,
'i'
,
'n'
,
'e'
,
'b'
,
'o'
,
'o'
,
't'
,
'_'
,
'e'
,
'v'
,
'e'
,
'n'
,
't'
,
0
};
static
const
WCHAR
wineboot_eventW
[]
=
{
'\\'
,
'K'
,
'e'
,
'r'
,
'n'
,
'e'
,
'l'
,
'O'
,
'b'
,
'j'
,
'e'
,
'c'
,
't'
,
's'
,
'\\'
,
'_'
,
'_'
,
'w'
,
'i'
,
'n'
,
'e'
,
'b'
,
'o'
,
'o'
,
't'
,
'_'
,
'e'
,
'v'
,
'e'
,
'n'
,
't'
,
0
};
/* First, set the current directory to SystemRoot */
/* First, set the current directory to SystemRoot */
int
i
,
j
;
int
i
,
j
;
BOOL
end_session
,
force
,
init
,
kill
,
restart
,
shutdown
,
update
;
BOOL
end_session
,
force
,
init
,
kill
,
restart
,
shutdown
,
update
;
HANDLE
event
;
HANDLE
event
;
SECURITY_ATTRIBUTES
sa
;
OBJECT_ATTRIBUTES
attr
;
UNICODE_STRING
nameW
;
BOOL
is_wow64
;
BOOL
is_wow64
;
end_session
=
force
=
init
=
kill
=
restart
=
shutdown
=
update
=
FALSE
;
end_session
=
force
=
init
=
kill
=
restart
=
shutdown
=
update
=
FALSE
;
...
@@ -1362,10 +1364,10 @@ int __cdecl main( int argc, char *argv[] )
...
@@ -1362,10 +1364,10 @@ int __cdecl main( int argc, char *argv[] )
if
(
shutdown
)
return
0
;
if
(
shutdown
)
return
0
;
sa
.
nLength
=
sizeof
(
sa
);
/* create event to be inherited by services.exe */
sa
.
lpSecurityDescriptor
=
NULL
;
InitializeObjectAttributes
(
&
attr
,
&
nameW
,
OBJ_OPENIF
|
OBJ_INHERIT
,
0
,
NULL
)
;
sa
.
bInheritHandle
=
TRUE
;
/* so that services.exe inherits it */
RtlInitUnicodeString
(
&
nameW
,
wineboot_eventW
);
event
=
CreateEventW
(
&
sa
,
TRUE
,
FALSE
,
wineboot_eventW
);
NtCreateEvent
(
&
event
,
EVENT_ALL_ACCESS
,
&
attr
,
NotificationEvent
,
0
);
ResetEvent
(
event
);
/* in case this is a restart */
ResetEvent
(
event
);
/* in case this is a restart */
...
...
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