diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/internal/arm/syscall.s | 15 | ||||
| -rw-r--r-- | src/setjmp/arm/longjmp.s | 15 | ||||
| -rw-r--r-- | src/setjmp/arm/setjmp.s | 17 | ||||
| -rw-r--r-- | src/signal/arm/restore.s | 11 | ||||
| -rw-r--r-- | src/thread/arm/__set_thread_area.s | 12 | ||||
| -rw-r--r-- | src/thread/arm/__unmapself.s | 8 | ||||
| -rw-r--r-- | src/thread/arm/clone.s | 35 | ||||
| -rw-r--r-- | src/thread/arm/syscall_cp.s | 23 | 
8 files changed, 136 insertions, 0 deletions
| diff --git a/src/internal/arm/syscall.s b/src/internal/arm/syscall.s new file mode 100644 index 00000000..c5ae25c3 --- /dev/null +++ b/src/internal/arm/syscall.s @@ -0,0 +1,15 @@ +.global __syscall +.type __syscall,%function +__syscall: +	mov ip,sp +	stmfd sp!,{r4,r5,r6,r7} +	mov r7,r0 +	mov r0,r1 +	mov r1,r2 +	mov r2,r3 +	ldmfd ip,{r3,r4,r5,r6} +	svc 0 +	ldmfd sp!,{r4,r5,r6,r7} +	tst lr,#1 +	moveq pc,lr +	bx lr diff --git a/src/setjmp/arm/longjmp.s b/src/setjmp/arm/longjmp.s new file mode 100644 index 00000000..037cb3d3 --- /dev/null +++ b/src/setjmp/arm/longjmp.s @@ -0,0 +1,15 @@ +.global _longjmp +.global longjmp +.type _longjmp,%function +.type longjmp,%function +_longjmp: +longjmp: +	mov ip,r0 +	movs r0,r1 +	moveq r0,#1 +	ldmia ip!, {v1,v2,v3,v4,v5,v6,sl,fp} +	ldr sp,[ip],#4 +	ldr lr,[ip],#4 +	tst lr,#1 +	moveq pc,lr +	bx lr diff --git a/src/setjmp/arm/setjmp.s b/src/setjmp/arm/setjmp.s new file mode 100644 index 00000000..41e02d82 --- /dev/null +++ b/src/setjmp/arm/setjmp.s @@ -0,0 +1,17 @@ +.global __setjmp +.global _setjmp +.global setjmp +.type __setjmp,%function +.type _setjmp,%function +.type setjmp,%function +__setjmp: +_setjmp: +setjmp: +	mov ip,r0 +	stmia ip!,{v1,v2,v3,v4,v5,v6,sl,fp} +	mov r2,sp +	stmia ip!,{r2,lr} +	mov r0,#0 +	tst lr,#1 +	moveq pc,lr +	bx lr diff --git a/src/signal/arm/restore.s b/src/signal/arm/restore.s new file mode 100644 index 00000000..18f7216b --- /dev/null +++ b/src/signal/arm/restore.s @@ -0,0 +1,11 @@ +.global __restore +.type __restore,%function +__restore: +	mov r7,#119 +	swi 0x0 + +.global __restore_rt +.type __restore_rt,%function +__restore_rt: +	mov r7,#173 +	swi 0x0 diff --git a/src/thread/arm/__set_thread_area.s b/src/thread/arm/__set_thread_area.s new file mode 100644 index 00000000..63d8884f --- /dev/null +++ b/src/thread/arm/__set_thread_area.s @@ -0,0 +1,12 @@ +.text +.global __set_thread_area +.type   __set_thread_area,%function +__set_thread_area: +	mov r1,r7 +	mov r7,#0x0f0000 +	add r7,r7,#5 +	svc 0 +	mov r7,r1 +	tst lr,#1 +	moveq pc,lr +	bx lr diff --git a/src/thread/arm/__unmapself.s b/src/thread/arm/__unmapself.s new file mode 100644 index 00000000..62ebb7c1 --- /dev/null +++ b/src/thread/arm/__unmapself.s @@ -0,0 +1,8 @@ +.text +.global __unmapself +.type   __unmapself,%function +__unmapself: +	mov r7,#91 +	svc 0 +	mov r7,#1 +	svc 0 diff --git a/src/thread/arm/clone.s b/src/thread/arm/clone.s new file mode 100644 index 00000000..65cd3f5a --- /dev/null +++ b/src/thread/arm/clone.s @@ -0,0 +1,35 @@ +.text +.global __clone +.weak clone +.type   __clone,%function +.type   clone,%function +__clone: +clone: +	stmfd sp!,{r4,r5,r6,r7} +	mov r7,#120 +	mov r6,r3 +	mov r5,r0 +	mov r0,r2 +	and r1,r1,#-16 +	ldr r2,[sp,#16] +	ldr r3,[sp,#20] +	ldr r4,[sp,#24] +	svc 0 +	tst r0,r0 +	beq 1f +	ldmfd sp!,{r4,r5,r6,r7} +	tst lr,#1 +	moveq pc,lr +	bx lr + +1:	mov r0,r6 +	tst r5,#1 +	bne 1f +	mov lr,pc +	mov pc,r5 +2:	mov r1,r0 +	mov r0,#1 +	svc + +1:	blx r5 +	b 2b diff --git a/src/thread/arm/syscall_cp.s b/src/thread/arm/syscall_cp.s new file mode 100644 index 00000000..59924fc5 --- /dev/null +++ b/src/thread/arm/syscall_cp.s @@ -0,0 +1,23 @@ +.global __syscall_cp_asm +.type __syscall_cp_asm,%function +__syscall_cp_asm: +	mov ip,sp +	stmfd sp!,{r4,r5,r6,r7,lr} +	stmfd sp!,{r0} +	bl 1f +1:	mov r4,#(1f-.) +	add r4,r4,lr +	str r4,[r0,#4] +	str sp,[r0] +	mov r7,r1 +	mov r0,r2 +	mov r1,r3 +	ldmfd ip,{r2,r3,r4,r5,r6} +1:	svc 0 +	ldmfd sp!,{r1} +	mov r2,#0 +	str r2,[r1] +	ldmfd sp!,{r4,r5,r6,r7,lr} +	tst lr,#1 +	moveq pc,lr +	bx lr | 
