1 #include "syscall.h" 2 #include <arch/arch.h> 3 #include <common/errno.h> 4 #include <common/fcntl.h> 5 #include <common/string.h> 6 #include <mm/slab.h> 7 #include <process/process.h> 8 #include <time/sleep.h> 9 10 #if ARCH(I386) || ARCH(X86_64) 11 // 导出系统调用入口函数,定义在entry.S中 12 extern void syscall_int(void); 13 14 /** 15 * @brief 通过中断进入系统调用 16 * 17 * @param syscall_id 18 * @param arg0 19 * @param arg1 20 * @param arg2 21 * @param arg3 22 * @param arg4 23 * @param arg5 24 * @param arg6 25 * @param arg7 26 * @return long 27 */ 28 29 long enter_syscall_int(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, 30 ul arg4, ul arg5) { 31 long err_code; 32 __asm__ __volatile__("movq %2, %%rdi \n\t" 33 "movq %3, %%rsi \n\t" 34 "movq %4, %%rdx \n\t" 35 "movq %5, %%r10 \n\t" 36 "movq %6, %%r8 \n\t" 37 "movq %7, %%r9 \n\t" 38 "int $0x80 \n\t" 39 : "=a"(err_code) 40 : "a"(syscall_id), "m"(arg0), "m"(arg1), "m"(arg2), 41 "m"(arg3), "m"(arg4), "m"(arg5) 42 : "memory", "r8", "r9", "r10", "rdi", "rsi", "rdx"); 43 44 return err_code; 45 } 46 47 #else 48 long enter_syscall_int(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, 49 ul arg4, ul arg5) { 50 while (1) { 51 /* code */ 52 } 53 } 54 55 #endif 56