53 lines
948 B
ArmAsm
53 lines
948 B
ArmAsm
/*
|
|
* Generic syscall call.
|
|
* Upon entry
|
|
* %eax: system call number
|
|
* %ebx: arg0 to system call
|
|
* %ecx: arg..
|
|
* %edx: arg..
|
|
* %esi: arg..
|
|
* %edi: arg..
|
|
* We push these (to save them) load them up with the
|
|
* values from the calling frame (not all will actually be valid)
|
|
* and make the syscall.
|
|
*/
|
|
|
|
#include <sys/linux-syscalls.h>
|
|
|
|
.text
|
|
.type syscall, @function
|
|
.globl syscall
|
|
.align 4
|
|
|
|
syscall:
|
|
push %eax
|
|
push %ebx
|
|
push %ecx
|
|
push %edx
|
|
push %esi
|
|
push %edi
|
|
mov 28(%esp),%eax
|
|
mov 32(%esp),%ebx
|
|
mov 36(%esp),%ecx
|
|
mov 40(%esp),%edx
|
|
mov 44(%esp),%esi
|
|
mov 48(%esp),%edi
|
|
|
|
int $0x80
|
|
|
|
cmpl $-129, %eax
|
|
jb 1f
|
|
negl %eax
|
|
pushl %eax
|
|
call __set_errno
|
|
addl $4, %esp
|
|
orl $-1, %eax
|
|
1:
|
|
pop %edi
|
|
pop %esi
|
|
pop %edx
|
|
pop %ecx
|
|
pop %ebx
|
|
pop %eax
|
|
ret
|