mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 21:38:43 +00:00
[WINESYNC] msi: Don't assume that WoW64 redirection is enabled in custom_start_server().
As of 3a884c2ef the server is started on the main thread, so this is no longer a valid assumption. In particular, we disable WoW64 redirection while running standard actions, including the top-level INSTALL action. Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=45663 Signed-off-by: Zebediah Figura <z.figura12@gmail.com> Signed-off-by: Hans Leidekker <hans@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org> wine commit id 51ad009bacd297c0607bc6de4d5dae18afe6ea98 by Zebediah Figura <z.figura12@gmail.com>
This commit is contained in:
parent
d79a5e413e
commit
49439bc1b4
1 changed files with 5 additions and 2 deletions
|
@ -616,14 +616,17 @@ static DWORD custom_start_server(MSIPACKAGE *package, DWORD arch)
|
|||
if (pipe == INVALID_HANDLE_VALUE)
|
||||
ERR("Failed to create custom action client pipe: %u\n", GetLastError());
|
||||
|
||||
if (sizeof(void *) == 8 && arch == SCS_32BIT_BINARY)
|
||||
if (!IsWow64Process(GetCurrentProcess(), &wow64))
|
||||
wow64 = FALSE;
|
||||
|
||||
if ((sizeof(void *) == 8 || wow64) && arch == SCS_32BIT_BINARY)
|
||||
GetSystemWow64DirectoryW(path, MAX_PATH - sizeof(msiexecW)/sizeof(WCHAR));
|
||||
else
|
||||
GetSystemDirectoryW(path, MAX_PATH - sizeof(msiexecW)/sizeof(WCHAR));
|
||||
strcatW(path, msiexecW);
|
||||
sprintfW(cmdline, argsW, path, GetCurrentProcessId());
|
||||
|
||||
if (IsWow64Process(GetCurrentProcess(), &wow64) && wow64 && arch == SCS_64BIT_BINARY)
|
||||
if (wow64 && arch == SCS_64BIT_BINARY)
|
||||
{
|
||||
Wow64DisableWow64FsRedirection(&cookie);
|
||||
CreateProcessW(path, cmdline, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi);
|
||||
|
|
Loading…
Reference in a new issue