xref: /DragonOS/kernel/src/syscall/syscall.c (revision 406099704eb939ae23b18f0cfb3ed36c534c1c84)
1 #include "syscall.h"
2 #include <common/errno.h>
3 #include <common/fcntl.h>
4 #include <common/string.h>
5 #include <exception/gate.h>
6 #include <exception/irq.h>
7 #include <filesystem/vfs/VFS.h>
8 #include <mm/slab.h>
9 #include <process/process.h>
10 #include <time/sleep.h>
11 #include <arch/arch.h>
12 
13 #if ARCH(I386) || ARCH(X86_64)
14 // 导出系统调用入口函数,定义在entry.S
15 extern void syscall_int(void);
16 
17 /**
18  * @brief 通过中断进入系统调用
19  *
20  * @param syscall_id
21  * @param arg0
22  * @param arg1
23  * @param arg2
24  * @param arg3
25  * @param arg4
26  * @param arg5
27  * @param arg6
28  * @param arg7
29  * @return long
30  */
31 
32 long enter_syscall_int(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, ul arg4, ul arg5, ul arg6, ul arg7)
33 {
34     long err_code;
35     __asm__ __volatile__("movq %2, %%r8 \n\t"
36                          "movq %3, %%r9 \n\t"
37                          "movq %4, %%r10 \n\t"
38                          "movq %5, %%r11 \n\t"
39                          "movq %6, %%r12 \n\t"
40                          "movq %7, %%r13 \n\t"
41                          "movq %8, %%r14 \n\t"
42                          "movq %9, %%r15 \n\t"
43                          "int $0x80   \n\t"
44                          : "=a"(err_code)
45                          : "a"(syscall_id), "m"(arg0), "m"(arg1), "m"(arg2), "m"(arg3), "m"(arg4), "m"(arg5), "m"(arg6),
46                            "m"(arg7)
47                          : "memory", "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15", "rcx", "rdx");
48 
49     return err_code;
50 }
51 
52 #else
53 long enter_syscall_int(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, ul arg4, ul arg5, ul arg6, ul arg7){
54   while (1)
55   {
56     /* code */
57   }
58 
59 }
60 
61 #endif
62 
63 /**
64  * @brief 打印字符串的系统调用
65  *
66  * 当arg1和arg2均为0时,打印黑底白字,否则按照指定的前景色和背景色来打印
67  *
68  * @param regs 寄存器
69  * @param arg0 要打印的字符串
70  * @param arg1 前景色
71  * @param arg2 背景色
72  * @return ul 返回值
73  */
74 ul do_put_string(char *s, uint32_t front_color, uint32_t background_color)
75 {
76 
77     printk_color(front_color, background_color, s);
78     return 0;
79 }
80 
81 
82