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_int(ul syscall_id, ul arg0, ul arg1, ul arg2, ul arg3, ul arg4, ul arg5, ul arg6, ul arg7); 37 38 /** 39 * @brief 系统调用不存在时的处理函数 40 * 41 * @param regs 进程3特权级下的寄存器 42 * @return ul 43 */ 44 ul system_call_not_exists(struct pt_regs *regs); 45 46 /** 47 * @brief 打印字符串的系统调用 48 * 49 * 当arg1和arg2均为0时,打印黑底白字,否则按照指定的前景色和背景色来打印 50 * 51 * @param regs 寄存器 52 * @param arg0 要打印的字符串 53 * @param arg1 前景色 54 * @param arg2 背景色 55 * @return ul 返回值 56 */ 57 ul sys_printf(struct pt_regs *regs); 58 59 /** 60 * @brief 将堆内存调整为arg0 61 * 62 * @param arg0 新的堆区域的结束地址 63 * arg0=0 ===> 返回堆区域的起始地址 64 * arg0=-1 ===> 返回堆区域的结束地址 65 * @return uint64_t 错误码 66 * 67 */ 68 uint64_t sys_brk(struct pt_regs *regs); 69 70 /** 71 * @brief 将堆内存空间加上offset(注意,该系统调用只应在普通进程中调用,而不能是内核线程) 72 * 73 * @param arg0 offset偏移量 74 * @return uint64_t the previous program break 75 */ 76 uint64_t sys_sbrk(struct pt_regs *regs); 77 78 /** 79 * @brief 创建文件夹 80 * 在VFS.c中实现 81 * @param path(r8) 路径 82 * @param mode(r9) 模式 83 * @return uint64_t 84 */ 85 uint64_t sys_mkdir(struct pt_regs *regs); 86 87 /** 88 * @brief 创建管道 89 * 在pipe.c中实现 90 * @param fd(r8) 文件句柄指针 91 * @param num(r9) 文件句柄个数 92 * @return uint64_t 93 */ 94 uint64_t sys_pipe(struct pt_regs *regs); 95 96 ul sys_ahci_end_req(struct pt_regs *regs); 97 98 // 系统调用的内核入口程序 99 void do_syscall_int(struct pt_regs *regs, unsigned long error_code); 100