Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Generic syscall call. |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 3 | * Upon entry: |
| 4 | * %eax: system call number - caller save |
| 5 | * %ebx: arg0 to system call - callee save |
| 6 | * %ecx: arg1 - caller save |
| 7 | * %edx: arg2 - caller save |
| 8 | * %esi: arg3 - callee save |
| 9 | * %edi: arg4 - callee save |
| 10 | * %ebp: arg5 - callee save |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 11 | */ |
| 12 | |
Elliott Hughes | bdff26d | 2013-02-11 17:08:16 -0800 | [diff] [blame] | 13 | #include <machine/asm.h> |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 14 | #include <sys/linux-syscalls.h> |
| 15 | |
Elliott Hughes | bdff26d | 2013-02-11 17:08:16 -0800 | [diff] [blame] | 16 | ENTRY(syscall) |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 17 | # Push the callee save registers. |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 18 | push %ebx |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 19 | push %esi |
| 20 | push %edi |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 21 | push %ebp |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 22 | |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 23 | # Load all the arguments from the calling frame. |
| 24 | # (Not all will be valid, depending on the syscall.) |
| 25 | mov 20(%esp),%eax |
| 26 | mov 24(%esp),%ebx |
| 27 | mov 28(%esp),%ecx |
| 28 | mov 32(%esp),%edx |
| 29 | mov 36(%esp),%esi |
| 30 | mov 40(%esp),%edi |
| 31 | mov 44(%esp),%ebp |
| 32 | |
| 33 | # Make the system call. |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 34 | int $0x80 |
| 35 | |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 36 | # Error? |
Jun Nakajima | 5288fee | 2011-06-17 14:37:50 -0700 | [diff] [blame] | 37 | cmpl $-4095, %eax |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 38 | jb 1f |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 39 | # Yes, so set errno. |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 40 | negl %eax |
| 41 | pushl %eax |
| 42 | call __set_errno |
| 43 | addl $4, %esp |
| 44 | orl $-1, %eax |
| 45 | 1: |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 46 | # Restore the callee save registers. |
| 47 | pop %ebp |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 48 | pop %edi |
| 49 | pop %esi |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 50 | pop %ebx |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 51 | ret |
Elliott Hughes | bdff26d | 2013-02-11 17:08:16 -0800 | [diff] [blame] | 52 | END(syscall) |