[builtins] Implement __chkstk for arm64 windows
authorMartin Storsjo <martin@martin.st>
Wed, 20 Dec 2017 06:52:52 +0000 (06:52 +0000)
committerMartin Storsjo <martin@martin.st>
Wed, 20 Dec 2017 06:52:52 +0000 (06:52 +0000)
Differential Revision: https://reviews.llvm.org/D41134

llvm-svn: 321151

compiler-rt/lib/builtins/CMakeLists.txt
compiler-rt/lib/builtins/aarch64/chkstk.S [new file with mode: 0644]

index 6fa95831912194b56584e4036b90a31ab627ecc4..6a0faf8ebf0ef3f30d15cce58818c0183b106e5d 100644 (file)
@@ -446,6 +446,12 @@ set(aarch64_SOURCES
   ${GENERIC_TF_SOURCES}
   ${GENERIC_SOURCES})
 
+if (MINGW)
+  set(aarch64_SOURCES
+      ${aarch64_SOURCES}
+      aarch64/chkstk.S)
+endif()
+
 set(armhf_SOURCES ${arm_SOURCES})
 set(armv7_SOURCES ${arm_SOURCES})
 set(armv7s_SOURCES ${arm_SOURCES})
diff --git a/compiler-rt/lib/builtins/aarch64/chkstk.S b/compiler-rt/lib/builtins/aarch64/chkstk.S
new file mode 100644 (file)
index 0000000..89ec90b
--- /dev/null
@@ -0,0 +1,34 @@
+// This file is dual licensed under the MIT and the University of Illinois Open
+// Source Licenses. See LICENSE.TXT for details.
+
+#include "../assembly.h"
+
+// __chkstk routine
+// This routine is windows specific.
+// http://msdn.microsoft.com/en-us/library/ms648426.aspx
+
+// This clobbers registers x16 and x17.
+// Does not modify any memory or the stack pointer.
+
+//      mov     x15, #256 // Number of bytes of stack, in units of 16 byte
+//      bl      __chkstk
+//      sub     sp, sp, x15, lsl #4
+
+#ifdef __aarch64__
+
+#define PAGE_SIZE 4096
+
+        .p2align 2
+DEFINE_COMPILERRT_FUNCTION(__chkstk)
+        lsl    x16, x15, #4
+        mov    x17, sp
+1:
+        sub    x17, x17, #PAGE_SIZE
+        subs   x16, x16, #PAGE_SIZE
+        ldr    xzr, [x17]
+        b.gt   1b
+
+        ret
+END_COMPILERRT_FUNCTION(__chkstk)
+
+#endif // __aarch64__