xref: /DragonOS/kernel/src/syscall/syscall.c (revision b8ed38251dc255b0c525801b5dbf37d3b0d0d61e)
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