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 | a85aaf1 | 2014-01-02 16:23:24 -0800 | [diff] [blame] | 13 | #include <private/bionic_asm.h> |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 14 | |
Elliott Hughes | bdff26d | 2013-02-11 17:08:16 -0800 | [diff] [blame] | 15 | ENTRY(syscall) |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 16 | # Push the callee save registers. |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 17 | push %ebx |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 18 | .cfi_adjust_cfa_offset 4 |
| 19 | .cfi_rel_offset ebx, 0 |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 20 | push %esi |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 21 | .cfi_adjust_cfa_offset 4 |
| 22 | .cfi_rel_offset esi, 0 |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 23 | push %edi |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 24 | .cfi_adjust_cfa_offset 4 |
| 25 | .cfi_rel_offset edi, 0 |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 26 | push %ebp |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 27 | .cfi_adjust_cfa_offset 4 |
| 28 | .cfi_rel_offset ebp, 0 |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 29 | |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 30 | # Load all the arguments from the calling frame. |
| 31 | # (Not all will be valid, depending on the syscall.) |
| 32 | mov 20(%esp),%eax |
| 33 | mov 24(%esp),%ebx |
| 34 | mov 28(%esp),%ecx |
| 35 | mov 32(%esp),%edx |
| 36 | mov 36(%esp),%esi |
| 37 | mov 40(%esp),%edi |
| 38 | mov 44(%esp),%ebp |
| 39 | |
| 40 | # Make the system call. |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 41 | int $0x80 |
| 42 | |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 43 | # Error? |
Elliott Hughes | a85aaf1 | 2014-01-02 16:23:24 -0800 | [diff] [blame] | 44 | cmpl $-MAX_ERRNO, %eax |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 45 | jb 1f |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 46 | # Yes, so set errno. |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 47 | negl %eax |
| 48 | pushl %eax |
Elliott Hughes | 011e111 | 2014-09-08 15:25:01 -0700 | [diff] [blame] | 49 | call __set_errno_internal |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 50 | addl $4, %esp |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 51 | 1: |
Jin Wei | c164f2a | 2012-04-12 16:50:42 +0800 | [diff] [blame] | 52 | # Restore the callee save registers. |
| 53 | pop %ebp |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 54 | .cfi_adjust_cfa_offset -4 |
Christopher Ferris | 940d312 | 2015-04-14 17:02:31 -0700 | [diff] [blame] | 55 | .cfi_restore ebp |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 56 | pop %edi |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 57 | .cfi_adjust_cfa_offset -4 |
Christopher Ferris | 940d312 | 2015-04-14 17:02:31 -0700 | [diff] [blame] | 58 | .cfi_restore edi |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 59 | pop %esi |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 60 | .cfi_adjust_cfa_offset -4 |
Christopher Ferris | 940d312 | 2015-04-14 17:02:31 -0700 | [diff] [blame] | 61 | .cfi_restore esi |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 62 | pop %ebx |
Christopher Ferris | 605ee81 | 2015-04-13 14:20:11 -0700 | [diff] [blame] | 63 | .cfi_adjust_cfa_offset -4 |
Christopher Ferris | 940d312 | 2015-04-14 17:02:31 -0700 | [diff] [blame] | 64 | .cfi_restore ebx |
Bruce Beare | 3c543e1 | 2010-03-04 10:29:38 -0800 | [diff] [blame] | 65 | ret |
Elliott Hughes | bdff26d | 2013-02-11 17:08:16 -0800 | [diff] [blame] | 66 | END(syscall) |