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
45a63e5b
Commit
45a63e5b
authored
May 17, 2020
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Store main() arguments in the Unix library.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
50134cce
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
50 additions
and
24 deletions
+50
-24
env.c
dlls/ntdll/env.c
+8
-13
loader.c
dlls/ntdll/loader.c
+6
-4
loader.c
dlls/ntdll/unix/loader.c
+34
-6
unixlib.h
dlls/ntdll/unixlib.h
+2
-1
No files found.
dlls/ntdll/env.c
View file @
45a63e5b
...
@@ -61,13 +61,6 @@ static inline SIZE_T get_env_length( const WCHAR *env )
...
@@ -61,13 +61,6 @@ static inline SIZE_T get_env_length( const WCHAR *env )
return
end
+
1
-
env
;
return
end
+
1
-
env
;
}
}
#ifdef __APPLE__
extern
char
**
__wine_get_main_environment
(
void
);
#else
extern
char
**
__wine_main_environ
;
static
char
**
__wine_get_main_environment
(
void
)
{
return
__wine_main_environ
;
}
#endif
/***********************************************************************
/***********************************************************************
* is_special_env_var
* is_special_env_var
...
@@ -779,8 +772,6 @@ static void set_library_wargv( char **argv, const UNICODE_STRING *image )
...
@@ -779,8 +772,6 @@ static void set_library_wargv( char **argv, const UNICODE_STRING *image )
total
-=
reslen
;
total
-=
reslen
;
}
}
wargv
[
argc
]
=
NULL
;
wargv
[
argc
]
=
NULL
;
__wine_main_argc
=
argc
;
__wine_main_wargv
=
wargv
;
__wine_main_wargv
=
wargv
;
}
}
...
@@ -1465,6 +1456,10 @@ void init_user_process_params( SIZE_T data_size )
...
@@ -1465,6 +1456,10 @@ void init_user_process_params( SIZE_T data_size )
startup_info_t
*
info
=
NULL
;
startup_info_t
*
info
=
NULL
;
RTL_USER_PROCESS_PARAMETERS
*
params
=
NULL
;
RTL_USER_PROCESS_PARAMETERS
*
params
=
NULL
;
UNICODE_STRING
curdir
,
dllpath
,
imagepath
,
cmdline
,
title
,
desktop
,
shellinfo
,
runtime
;
UNICODE_STRING
curdir
,
dllpath
,
imagepath
,
cmdline
,
title
,
desktop
,
shellinfo
,
runtime
;
int
argc
;
char
**
argv
,
**
envp
;
unix_funcs
->
get_main_args
(
&
argc
,
&
argv
,
&
envp
);
if
(
!
data_size
)
if
(
!
data_size
)
{
{
...
@@ -1472,13 +1467,13 @@ void init_user_process_params( SIZE_T data_size )
...
@@ -1472,13 +1467,13 @@ void init_user_process_params( SIZE_T data_size )
WCHAR
*
env
,
curdir_buffer
[
MAX_PATH
];
WCHAR
*
env
,
curdir_buffer
[
MAX_PATH
];
NtCurrentTeb
()
->
Peb
->
ProcessParameters
=
&
initial_params
;
NtCurrentTeb
()
->
Peb
->
ProcessParameters
=
&
initial_params
;
initial_params
.
Environment
=
build_initial_environment
(
__wine_get_main_environment
()
);
initial_params
.
Environment
=
build_initial_environment
(
envp
);
curdir
.
Buffer
=
curdir_buffer
;
curdir
.
Buffer
=
curdir_buffer
;
curdir
.
MaximumLength
=
sizeof
(
curdir_buffer
);
curdir
.
MaximumLength
=
sizeof
(
curdir_buffer
);
get_current_directory
(
&
curdir
);
get_current_directory
(
&
curdir
);
initial_params
.
CurrentDirectory
.
DosPath
=
curdir
;
initial_params
.
CurrentDirectory
.
DosPath
=
curdir
;
get_image_path
(
__wine_main_
argv
[
0
],
&
initial_params
.
ImagePathName
);
get_image_path
(
argv
[
0
],
&
initial_params
.
ImagePathName
);
set_library_wargv
(
__wine_main_
argv
,
&
initial_params
.
ImagePathName
);
set_library_wargv
(
argv
,
&
initial_params
.
ImagePathName
);
build_command_line
(
__wine_main_wargv
,
&
cmdline
);
build_command_line
(
__wine_main_wargv
,
&
cmdline
);
LdrGetDllPath
(
initial_params
.
ImagePathName
.
Buffer
,
0
,
&
load_path
,
&
dummy
);
LdrGetDllPath
(
initial_params
.
ImagePathName
.
Buffer
,
0
,
&
load_path
,
&
dummy
);
RtlInitUnicodeString
(
&
dllpath
,
load_path
);
RtlInitUnicodeString
(
&
dllpath
,
load_path
);
...
@@ -1566,7 +1561,7 @@ void init_user_process_params( SIZE_T data_size )
...
@@ -1566,7 +1561,7 @@ void init_user_process_params( SIZE_T data_size )
else
params
->
Environment
[
0
]
=
0
;
else
params
->
Environment
[
0
]
=
0
;
}
}
set_library_wargv
(
__wine_main_
argv
,
NULL
);
set_library_wargv
(
argv
,
NULL
);
done:
done:
RtlFreeHeap
(
GetProcessHeap
(),
0
,
info
);
RtlFreeHeap
(
GetProcessHeap
(),
0
,
info
);
...
...
dlls/ntdll/loader.c
View file @
45a63e5b
...
@@ -1324,11 +1324,12 @@ static void call_tls_callbacks( HMODULE module, UINT reason )
...
@@ -1324,11 +1324,12 @@ static void call_tls_callbacks( HMODULE module, UINT reason )
static
void
call_constructors
(
WINE_MODREF
*
wm
)
static
void
call_constructors
(
WINE_MODREF
*
wm
)
{
{
#ifdef HAVE_DLINFO
#ifdef HAVE_DLINFO
extern
char
**
__wine_main_environ
;
struct
link_map
*
map
;
struct
link_map
*
map
;
void
(
*
init_func
)(
int
,
char
**
,
char
**
)
=
NULL
;
void
(
*
init_func
)(
int
,
char
**
,
char
**
)
=
NULL
;
void
(
**
init_array
)(
int
,
char
**
,
char
**
)
=
NULL
;
void
(
**
init_array
)(
int
,
char
**
,
char
**
)
=
NULL
;
ULONG_PTR
i
,
init_arraysz
=
0
;
ULONG_PTR
i
,
init_arraysz
=
0
;
int
argc
;
char
**
argv
,
**
envp
;
#ifdef _WIN64
#ifdef _WIN64
const
Elf64_Dyn
*
dyn
;
const
Elf64_Dyn
*
dyn
;
#else
#else
...
@@ -1351,11 +1352,12 @@ static void call_constructors( WINE_MODREF *wm )
...
@@ -1351,11 +1352,12 @@ static void call_constructors( WINE_MODREF *wm )
TRACE
(
"%s: got init_func %p init_array %p %lu
\n
"
,
debugstr_us
(
&
wm
->
ldr
.
BaseDllName
),
TRACE
(
"%s: got init_func %p init_array %p %lu
\n
"
,
debugstr_us
(
&
wm
->
ldr
.
BaseDllName
),
init_func
,
init_array
,
init_arraysz
);
init_func
,
init_array
,
init_arraysz
);
if
(
init_func
)
init_func
(
__wine_main_argc
,
__wine_main_argv
,
__wine_main_environ
);
unix_funcs
->
get_main_args
(
&
argc
,
&
argv
,
&
envp
);
if
(
init_func
)
init_func
(
argc
,
argv
,
envp
);
if
(
init_array
)
if
(
init_array
)
for
(
i
=
0
;
i
<
init_arraysz
/
sizeof
(
*
init_array
);
i
++
)
for
(
i
=
0
;
i
<
init_arraysz
/
sizeof
(
*
init_array
);
i
++
)
init_array
[
i
](
argc
,
argv
,
envp
);
init_array
[
i
](
__wine_main_argc
,
__wine_main_argv
,
__wine_main_environ
);
#endif
#endif
}
}
...
...
dlls/ntdll/unix/loader.c
View file @
45a63e5b
...
@@ -65,6 +65,14 @@ WINE_DEFAULT_DEBUG_CHANNEL(ntdll);
...
@@ -65,6 +65,14 @@ WINE_DEFAULT_DEBUG_CHANNEL(ntdll);
extern
IMAGE_NT_HEADERS
__wine_spec_nt_header
;
extern
IMAGE_NT_HEADERS
__wine_spec_nt_header
;
extern
void
CDECL
__wine_set_unix_funcs
(
int
version
,
const
struct
unix_funcs
*
funcs
);
extern
void
CDECL
__wine_set_unix_funcs
(
int
version
,
const
struct
unix_funcs
*
funcs
);
extern
int
__wine_main_argc
;
extern
char
**
__wine_main_argv
;
extern
char
**
__wine_main_environ
;
static
int
main_argc
;
static
char
**
main_argv
;
static
char
**
main_envp
;
static
inline
void
*
get_rva
(
const
IMAGE_NT_HEADERS
*
nt
,
ULONG_PTR
addr
)
static
inline
void
*
get_rva
(
const
IMAGE_NT_HEADERS
*
nt
,
ULONG_PTR
addr
)
{
{
return
(
BYTE
*
)
nt
+
addr
;
return
(
BYTE
*
)
nt
+
addr
;
...
@@ -151,6 +159,19 @@ void CDECL get_host_version( const char **sysname, const char **release )
...
@@ -151,6 +159,19 @@ void CDECL get_host_version( const char **sysname, const char **release )
/*************************************************************************
/*************************************************************************
* get_main_args
*
* Return the initial arguments.
*/
static
void
CDECL
get_main_args
(
int
*
argc
,
char
**
argv
[],
char
**
envp
[]
)
{
*
argc
=
main_argc
;
*
argv
=
main_argv
;
*
envp
=
main_envp
;
}
/*************************************************************************
* map_so_dll
* map_so_dll
*
*
* Map a builtin dll in memory and fixup RVAs.
* Map a builtin dll in memory and fixup RVAs.
...
@@ -428,6 +449,7 @@ static HMODULE load_ntdll(void)
...
@@ -428,6 +449,7 @@ static HMODULE load_ntdll(void)
*/
*/
static
struct
unix_funcs
unix_funcs
=
static
struct
unix_funcs
unix_funcs
=
{
{
get_main_args
,
get_version
,
get_version
,
get_build_id
,
get_build_id
,
get_host_version
,
get_host_version
,
...
@@ -684,9 +706,6 @@ static void check_command_line( int argc, char *argv[] )
...
@@ -684,9 +706,6 @@ static void check_command_line( int argc, char *argv[] )
*/
*/
void
__wine_main
(
int
argc
,
char
*
argv
[],
char
*
envp
[]
)
void
__wine_main
(
int
argc
,
char
*
argv
[],
char
*
envp
[]
)
{
{
extern
int
__wine_main_argc
;
extern
char
**
__wine_main_argv
;
extern
char
**
__wine_main_environ
;
HMODULE
module
;
HMODULE
module
;
wine_init_argv0_path
(
argv
[
0
]
);
wine_init_argv0_path
(
argv
[
0
]
);
...
@@ -705,9 +724,9 @@ void __wine_main( int argc, char *argv[], char *envp[] )
...
@@ -705,9 +724,9 @@ void __wine_main( int argc, char *argv[], char *envp[] )
}
}
}
}
__wine_main_argc
=
argc
;
__wine_main_argc
=
main_argc
=
argc
;
__wine_main_argv
=
argv
;
__wine_main_argv
=
main_argv
=
argv
;
__wine_main_environ
=
envp
;
__wine_main_environ
=
main_envp
=
envp
;
virtual_init
();
virtual_init
();
module
=
load_ntdll
();
module
=
load_ntdll
();
...
@@ -734,6 +753,15 @@ NTSTATUS __cdecl __wine_init_unix_lib( HMODULE module, const void *ptr_in, void
...
@@ -734,6 +753,15 @@ NTSTATUS __cdecl __wine_init_unix_lib( HMODULE module, const void *ptr_in, void
{
{
const
IMAGE_NT_HEADERS
*
nt
=
ptr_in
;
const
IMAGE_NT_HEADERS
*
nt
=
ptr_in
;
#ifdef __APPLE__
extern
char
**
__wine_get_main_environment
(
void
);
main_envp
=
__wine_get_main_environment
();
#else
main_envp
=
__wine_main_environ
;
#endif
main_argc
=
__wine_main_argc
;
main_argv
=
__wine_main_argv
;
map_so_dll
(
nt
,
module
);
map_so_dll
(
nt
,
module
);
fixup_ntdll_imports
(
&
__wine_spec_nt_header
,
module
);
fixup_ntdll_imports
(
&
__wine_spec_nt_header
,
module
);
*
(
struct
unix_funcs
**
)
ptr_out
=
&
unix_funcs
;
*
(
struct
unix_funcs
**
)
ptr_out
=
&
unix_funcs
;
...
...
dlls/ntdll/unixlib.h
View file @
45a63e5b
...
@@ -24,11 +24,12 @@
...
@@ -24,11 +24,12 @@
#include "wine/debug.h"
#include "wine/debug.h"
/* increment this when you change the function table */
/* increment this when you change the function table */
#define NTDLL_UNIXLIB_VERSION
3
#define NTDLL_UNIXLIB_VERSION
4
struct
unix_funcs
struct
unix_funcs
{
{
/* environment functions */
/* environment functions */
void
(
CDECL
*
get_main_args
)(
int
*
argc
,
char
**
argv
[],
char
**
envp
[]
);
const
char
*
(
CDECL
*
get_version
)(
void
);
const
char
*
(
CDECL
*
get_version
)(
void
);
const
char
*
(
CDECL
*
get_build_id
)(
void
);
const
char
*
(
CDECL
*
get_build_id
)(
void
);
void
(
CDECL
*
get_host_version
)(
const
char
**
sysname
,
const
char
**
release
);
void
(
CDECL
*
get_host_version
)(
const
char
**
sysname
,
const
char
**
release
);
...
...
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