summaryrefslogtreecommitdiff
path: root/lib/builtins/aarch64/chkstk.S
diff options
context:
space:
mode:
authorMartin Storsjo <martin@martin.st>2017-12-20 06:52:52 +0000
committerMartin Storsjo <martin@martin.st>2017-12-20 06:52:52 +0000
commit1d871d6cd3fed01cd50dd63e743bd2ea6e65eab6 (patch)
tree07e097addf191bf60cd11600b50cdbcff8da3f56 /lib/builtins/aarch64/chkstk.S
parent16be70a660a34d6a7fb8296a54f43926edb688d9 (diff)
[builtins] Implement __chkstk for arm64 windows
Differential Revision: https://reviews.llvm.org/D41134 git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@321151 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/builtins/aarch64/chkstk.S')
-rw-r--r--lib/builtins/aarch64/chkstk.S34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/builtins/aarch64/chkstk.S b/lib/builtins/aarch64/chkstk.S
new file mode 100644
index 000000000..89ec90b08
--- /dev/null
+++ b/lib/builtins/aarch64/chkstk.S
@@ -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__