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