syscall.h 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #pragma once
  2. #include "../common/glib.h"
  3. #include "../common/kprint.h"
  4. #include "../process/ptrace.h"
  5. // 定义最大系统调用数量
  6. #define MAX_SYSTEM_CALL_NUM 128
  7. #define ESYSCALL_NOT_EXISTS 1
  8. typedef unsigned long (*system_call_t)(struct pt_regs *regs);
  9. extern void ret_from_system_call(void); // 导出从系统调用返回的函数(定义在entry.S)
  10. /**
  11. * @brief 初始化系统调用模块
  12. *
  13. */
  14. void syscall_init();
  15. /**
  16. * @brief 用户态系统调用入口函数
  17. * 从用户态进入系统调用
  18. * @param syscall_id 系统调用id
  19. * @return long 错误码
  20. */
  21. long enter_syscall(ul syscall_id,ul arg0, ul arg1, ul arg2, ul arg3, ul arg4, ul arg5, ul arg6, ul arg7);
  22. /**
  23. * @brief 系统调用不存在时的处理函数
  24. *
  25. * @param regs 进程3特权级下的寄存器
  26. * @return ul
  27. */
  28. ul system_call_not_exists(struct pt_regs *regs)
  29. {
  30. kerror("System call [ ID #%d ] not exists.", regs->rax);
  31. return ESYSCALL_NOT_EXISTS;
  32. }
  33. /**
  34. * @brief 打印字符串的系统调用
  35. *
  36. * 当arg1和arg2均为0时,打印黑底白字,否则按照指定的前景色和背景色来打印
  37. *
  38. * @param regs 寄存器
  39. * @param arg0 要打印的字符串
  40. * @param arg1 前景色
  41. * @param arg2 背景色
  42. * @return ul 返回值
  43. */
  44. ul sys_printf(struct pt_regs *regs);
  45. system_call_t system_call_table[MAX_SYSTEM_CALL_NUM] =
  46. {
  47. [0] = system_call_not_exists,
  48. [1] = sys_printf,
  49. [2 ... MAX_SYSTEM_CALL_NUM - 1] = system_call_not_exists
  50. };