Commit b9657463 authored by Will Deacon's avatar Will Deacon

rseq/selftests: Add support for arm64

Hook up arm64 support to the rseq selftests.
Acked-by: default avatarMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
parent 09ffcb0d
...@@ -114,6 +114,26 @@ unsigned int yield_mod_cnt, nr_abort; ...@@ -114,6 +114,26 @@ unsigned int yield_mod_cnt, nr_abort;
"bne 222b\n\t" \ "bne 222b\n\t" \
"333:\n\t" "333:\n\t"
#elif defined(__AARCH64EL__)
#define RSEQ_INJECT_INPUT \
, [loop_cnt_1] "Qo" (loop_cnt[1]) \
, [loop_cnt_2] "Qo" (loop_cnt[2]) \
, [loop_cnt_3] "Qo" (loop_cnt[3]) \
, [loop_cnt_4] "Qo" (loop_cnt[4]) \
, [loop_cnt_5] "Qo" (loop_cnt[5]) \
, [loop_cnt_6] "Qo" (loop_cnt[6])
#define INJECT_ASM_REG RSEQ_ASM_TMP_REG32
#define RSEQ_INJECT_ASM(n) \
" ldr " INJECT_ASM_REG ", %[loop_cnt_" #n "]\n" \
" cbz " INJECT_ASM_REG ", 333f\n" \
"222:\n" \
" sub " INJECT_ASM_REG ", " INJECT_ASM_REG ", #1\n" \
" cbnz " INJECT_ASM_REG ", 222b\n" \
"333:\n"
#elif __PPC__ #elif __PPC__
#define RSEQ_INJECT_INPUT \ #define RSEQ_INJECT_INPUT \
......
This diff is collapsed.
...@@ -71,6 +71,8 @@ extern __thread volatile struct rseq __rseq_abi; ...@@ -71,6 +71,8 @@ extern __thread volatile struct rseq __rseq_abi;
#include <rseq-x86.h> #include <rseq-x86.h>
#elif defined(__ARMEL__) #elif defined(__ARMEL__)
#include <rseq-arm.h> #include <rseq-arm.h>
#elif defined (__AARCH64EL__)
#include <rseq-arm64.h>
#elif defined(__PPC__) #elif defined(__PPC__)
#include <rseq-ppc.h> #include <rseq-ppc.h>
#elif defined(__mips__) #elif defined(__mips__)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment