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