#include "arm/asm.h"
-#define SYS_BASE 0x00900000
+// OABI
+//#define SYS_BASE 0x00900000
+
+// EABI
+#define SYS_BASE 0x0
+
#define SYS_exit (SYS_BASE + 1)
#define SYS_write (SYS_BASE + 4)
#define SYS_clone (SYS_BASE + 120)
MOVW 0(FP), R0
MOVW 4(FP), R1
MOVW 8(FP), R2
- SWI $SYS_write
+ MOVW $SYS_write, R7
+ SWI $0
RET
TEXT exit(SB),7,$-4
MOVW 0(FP), R0
- SWI $SYS_exit_group
+ MOVW $SYS_exit_group, R7
+ SWI $0
MOVW $1234, R0
MOVW $1002, R1
MOVW R0, (R1) // fail hard
TEXT exit1(SB),7,$-4
MOVW 0(FP), R0
- SWI $SYS_exit
+ MOVW $SYS_exit, R7
+ SWI $0
MOVW $1234, R0
MOVW $1003, R1
MOVW R0, (R1) // fail hard
MOVW 12(FP), R3
MOVW 16(FP), R4
MOVW 20(FP), R5
- SWI $SYS_mmap2
+ MOVW $SYS_mmap2, R7
+ SWI $0
RET
// int32 futex(int32 *uaddr, int32 op, int32 val,
MOVW 16(SP), R3
MOVW 20(SP), R4
MOVW 24(SP), R5
- SWI $SYS_futex
+ MOVW $SYS_futex, R7
+ SWI $0
RET
MOVW $1234, R6
MOVW R6, 12(R1)
- SWI $SYS_clone
+ MOVW $SYS_clone, R7
+ SWI $0
// In parent, return.
CMP $0, R0
BL emptyfunc(SB) // fault if stack check is wrong
// Initialize m->procid to Linux tid
- SWI $SYS_gettid
+ MOVW $SYS_gettid, R7
+ SWI $0
MOVW R0, m_procid(m)
// Call fn
;;
Xarm)
export A=5
- export E="qemu-arm -cpu cortex-a8 "
+ export E=${EMU_arm:-qemu-arm -cpu cortex-a8}
;;
*)
echo 1>&2 run: unsupported '$GOARCH'