git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'interrupt-rework' into prog-loader
[lunaix-os.git]
/
lunaix-os
/
kernel
/
asm
/
x86
/
syscall.S
diff --git
a/lunaix-os/kernel/asm/x86/syscall.S
b/lunaix-os/kernel/asm/x86/syscall.S
index b8d021973cbec4eda95d8daf7c78d6c53a86ad36..62e07212264d300aed2a80d7aaee2c0d0267d635 100644
(file)
--- a/
lunaix-os/kernel/asm/x86/syscall.S
+++ b/
lunaix-os/kernel/asm/x86/syscall.S
@@
-30,7
+30,7
@@
.long __lxsys_close /* 20 */
.long __lxsys_read
.long __lxsys_write
.long __lxsys_close /* 20 */
.long __lxsys_read
.long __lxsys_write
- .long __lxsys_readdir
+ .long __lxsys_
sys_
readdir
.long __lxsys_mkdir
.long __lxsys_lseek /* 25 */
.long __lxsys_geterrno
.long __lxsys_mkdir
.long __lxsys_lseek /* 25 */
.long __lxsys_geterrno
@@
-55,6
+55,13
@@
.long __lxsys_setxattr /* 45 */
.long __lxsys_fgetxattr
.long __lxsys_fsetxattr
.long __lxsys_setxattr /* 45 */
.long __lxsys_fgetxattr
.long __lxsys_fsetxattr
+ .long __lxsys_ioctl
+ .long __lxsys_getpgid
+ .long __lxsys_setpgid /* 50 */
+ .long __lxsys_syslog
+ .long __lxsys_sys_mmap
+ .long __lxsys_munmap
+ .long __lxsys_execve
2:
.rept __SYSCALL_MAX - (2b - 1b)/4
.long 0
2:
.rept __SYSCALL_MAX - (2b - 1b)/4
.long 0
@@
-65,10
+72,11
@@
.section .text
syscall_hndlr:
pushl %ebp
.section .text
syscall_hndlr:
pushl %ebp
- movl 8(%esp), %ebp
+ movl 8(%esp), %ebp
// isr_param*
- movl (%ebp), %eax /* eax: call code as well as the return value from syscall */
- cmpl $__SYSCALL_MAX, %eax
+ addl $4, %ebp
+ movl (%ebp), %eax /* eax: call code as well as the return value from syscall */
+ cmpl $__SYSCALL_MAX, %eax
jae 2f
shll $2, %eax
jae 2f
shll $2, %eax
@@
-80,8
+88,7
@@
popl %ebp
ret
1:
popl %ebp
ret
1:
- pushl 24(%ebp) /* esi - #6 arg */
- pushl 20(%ebp) /* ebp - #5 arg */
+ pushl 24(%ebp) /* esi - #5 arg */
pushl 16(%ebp) /* edi - #4 arg */
pushl 12(%ebp) /* edx - #3 arg */
pushl 8(%ebp) /* ecx - #2 arg */
pushl 16(%ebp) /* edi - #4 arg */
pushl 12(%ebp) /* edx - #3 arg */
pushl 8(%ebp) /* ecx - #2 arg */
@@
-91,7
+98,7
@@
movl %eax, (%ebp) /* save the return value */
movl %eax, (%ebp) /* save the return value */
- addl $2
4
, %esp /* remove the parameters from stack */
+ addl $2
0
, %esp /* remove the parameters from stack */
popl %ebp
popl %ebp