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