syscall.h 2.6 KB

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