aboutsummaryrefslogtreecommitdiff
path: root/winsup/cygwin/dcrt0.cc
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2022-07-14 20:08:58 +0200
committerCorinna Vinschen <corinna@vinschen.de>2022-07-14 20:08:58 +0200
commit5192d5ea51dee786ba1cb97b216bd40115dbbf20 (patch)
treeef47a237a9320ef54f3b5369c1a687d7918e6c4e /winsup/cygwin/dcrt0.cc
parente46f15c2d168abea34b4d880b4eba38d750c7066 (diff)
downloadnewlib-5192d5ea51dee786ba1cb97b216bd40115dbbf20.zip
newlib-5192d5ea51dee786ba1cb97b216bd40115dbbf20.tar.gz
newlib-5192d5ea51dee786ba1cb97b216bd40115dbbf20.tar.bz2
Cygwin: _dll_crt0: minimize target-specific conditional code
Only the assembler snippet is really x86_64-specific, so minimize the conditional code block to this snippet. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
Diffstat (limited to 'winsup/cygwin/dcrt0.cc')
-rw-r--r--winsup/cygwin/dcrt0.cc8
1 files changed, 4 insertions, 4 deletions
diff --git a/winsup/cygwin/dcrt0.cc b/winsup/cygwin/dcrt0.cc
index 897a2fb..97eefa1 100644
--- a/winsup/cygwin/dcrt0.cc
+++ b/winsup/cygwin/dcrt0.cc
@@ -1016,7 +1016,6 @@ __cygwin_exit_return: \n\
extern "C" void __stdcall
_dll_crt0 ()
{
-#ifdef __x86_64__
/* Starting with Windows 10 rel 1511, the main stack of an application is
not reproducible if a 64 bit process has been started from a 32 bit
process. Given that we have enough virtual address space on 64 bit
@@ -1033,6 +1032,7 @@ _dll_crt0 ()
PVOID stackaddr = create_new_main_thread_stack (allocationbase);
if (stackaddr)
{
+#ifdef __x86_64__
/* Set stack pointer to new address. Set frame pointer to
stack pointer and subtract 32 bytes for shadow space. */
__asm__ ("\n\
@@ -1040,6 +1040,9 @@ _dll_crt0 ()
movq %%rsp, %%rbp \n\
subq $32,%%rsp \n"
: : [ADDR] "r" (stackaddr));
+#else
+#error unimplemented for this target
+#endif
/* We're on the new stack now. Free up space taken by the former
main thread stack and set DeallocationStack correctly. */
VirtualFree (NtCurrentTeb ()->DeallocationStack, 0, MEM_RELEASE);
@@ -1049,9 +1052,6 @@ _dll_crt0 ()
else
fork_info->alloc_stack ();
}
-#else
-#error unimplemented for this target
-#endif
fesetenv (FE_DFL_ENV);
_main_tls = &_my_tls;