1 #pragma once
2 
3 #include <common/glib.h>
4 #include <common/kprint.h>
5 #include <common/unistd.h>
6 #include <process/ptrace.h>
7 
8 // 定义最大系统调用数量
9 #define MAX_SYSTEM_CALL_NUM 256
10 
11 #define ESYSCALL_NOT_EXISTS 1
12 
13 typedef unsigned long (*system_call_t)(struct pt_regs *regs);
14 
15 extern void ret_from_system_call(void); // 导出从系统调用返回的函数(定义在entry.S
16 
17 extern system_call_t system_call_table[MAX_SYSTEM_CALL_NUM];
18 
19 // 判断系统调用是否来自用户态
20 #define SYSCALL_FROM_USER(regs) (user_mode(regs))
21 // 判断系统调用是否来自内核态
22 #define SYSCALL_FROM_KERNEL(regs) (!SYSCALL_FROM_USER(regs))
23 
24 /**
25  * @brief 初始化系统调用模块
26  *
27  */
28 void syscall_init();
29 
30 /**
31  * @brief 用户态系统调用入口函数
32  * 从用户态进入系统调用
33  * @param syscall_id 系统调用id
34  * @return long 错误码
35  */
36 long enter_syscall(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, ul arg4, ul arg5, ul arg6, ul arg7);
37 long enter_syscall_int(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, ul arg4, ul arg5, ul arg6, ul arg7);
38 
39 /**
40  * @brief 系统调用不存在时的处理函数
41  *
42  * @param regs 进程3特权级下的寄存器
43  * @return ul
44  */
45 ul system_call_not_exists(struct pt_regs *regs);
46 
47 /**
48  * @brief 打印字符串的系统调用
49  *
50  * 当arg1和arg2均为0时,打印黑底白字,否则按照指定的前景色和背景色来打印
51  *
52  * @param regs 寄存器
53  * @param arg0 要打印的字符串
54  * @param arg1 前景色
55  * @param arg2 背景色
56  * @return ul 返回值
57  */
58 ul sys_printf(struct pt_regs *regs);
59 
60 /**
61  * @brief 将堆内存调整为arg0
62  *
63  * @param arg0 新的堆区域的结束地址
64  * arg0=0  ===> 返回堆区域的起始地址
65  * arg0=-1  ===> 返回堆区域的结束地址
66  * @return uint64_t 错误码
67  *
68  */
69 uint64_t sys_brk(struct pt_regs *regs);
70 
71 /**
72  * @brief 将堆内存空间加上offset(注意,该系统调用只应在普通进程中调用,而不能是内核线程)
73  *
74  * @param arg0 offset偏移量
75  * @return uint64_t the previous program break
76  */
77 uint64_t sys_sbrk(struct pt_regs *regs);
78 
79 /**
80  * @brief 创建文件夹
81  * 在VFS.c中实现
82  * @param path(r8) 路径
83  * @param mode(r9) 模式
84  * @return uint64_t
85  */
86 uint64_t sys_mkdir(struct pt_regs *regs);
87 
88 /**
89  * @brief 创建管道
90  * 在pipe.c中实现
91  * @param fd(r8) 文件句柄指针
92  * @param num(r9) 文件句柄个数
93  * @return uint64_t
94  */
95 uint64_t sys_pipe(struct pt_regs *regs);
96 
97 ul sys_ahci_end_req(struct pt_regs *regs);
98 
99 // 系统调用的内核入口程序
100 void do_syscall_int(struct pt_regs *regs, unsigned long error_code);
101