summaryrefslogtreecommitdiff
path: root/tests/checkasm/aarch64
diff options
context:
space:
mode:
authorJames Almer <jamrial@gmail.com>2017-03-23 17:36:53 -0300
committerJames Almer <jamrial@gmail.com>2017-03-23 17:36:53 -0300
commita2d34cc51ba1e3c19928f1c5aedd7a2990593c47 (patch)
tree41405f986c9ce565f6ab48a226e3bdb417ea7ffd /tests/checkasm/aarch64
parentcab4c7fa199fe98db2b298d64eb6cfa386dae939 (diff)
parentf1b3e131385176c3c9d9783b25047856a0dcebf6 (diff)
Merge commit 'f1b3e131385176c3c9d9783b25047856a0dcebf6'
* commit 'f1b3e131385176c3c9d9783b25047856a0dcebf6': checkasm: aarch64: Clobber the stack before calling functions Merged-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'tests/checkasm/aarch64')
-rw-r--r--tests/checkasm/aarch64/checkasm.S13
1 files changed, 13 insertions, 0 deletions
diff --git a/tests/checkasm/aarch64/checkasm.S b/tests/checkasm/aarch64/checkasm.S
index f0a671e58d..8e4f8c35e4 100644
--- a/tests/checkasm/aarch64/checkasm.S
+++ b/tests/checkasm/aarch64/checkasm.S
@@ -52,6 +52,19 @@ endconst
// max number of args used by any asm function.
#define MAX_ARGS 15
+#define CLOBBER_STACK ((8*MAX_ARGS + 15) & ~15)
+
+function checkasm_stack_clobber, export=1
+ mov x29, sp
+ mov x2, #CLOBBER_STACK
+1:
+ stp x0, x1, [sp, #-16]!
+ subs x2, x2, #16
+ b.gt 1b
+ mov sp, x29
+ ret
+endfunc
+
#define ARG_STACK ((8*(MAX_ARGS - 8) + 15) & ~15)
function checkasm_checked_call, export=1