0

os161 ”操作系统包含以下代码。具体来说,定义系统调用的位置:

...

#include <kern/syscall.h>
...

#define SYSCALL(sym, num) \
   .set noreorder       ; \
   .globl sym           ; \
   .type sym,@function      ; \
   .ent sym         ; \
sym:                ; \
   j __syscall                  ; \
   addiu v0, $0, SYS_##sym  ; \
   .end sym         ; \
   .set reorder

...

SYSCALL(fork, 0)
SYSCALL(vfork, 1)
SYSCALL(execv, 2)
SYSCALL(_exit, 3)
SYSCALL(waitpid, 4)
SYSCALL(getpid, 5)
...

在底部,每个系统调用都有一个数字。我似乎无法弄清楚这些数字的用途。

我不是在询问系统调用号的使用,我是在询问使用num宏的参数SYSCALL。我找不到它在哪里使用。

即使将系统调用号移至,也不使用v0该参数。num相反,它移动文件中定义的常量kern/syscall.h

...

#define SYS_fork         0
#define SYS_vfork        1
#define SYS_execv        2
#define SYS__exit        3
#define SYS_waitpid      4
#define SYS_getpid       5
...

这个论点如何num以某种方式有用?

4

1 回答 1

1

它用于其他工具以简化源代码的维护。
以下是来自理解系统调用的引用

syscalls.S:此文件是在编译时从 syscalls-mips.S 创建的,是汇编到 C 库中的实际文件。系统调用的实际名称使用名为 callno-parse.sh 的脚本放置在此文件中,该脚本从内核的头文件中读取它们。这避免了必须制作第二个系统调用列表。在实际系统中,通常每个系统调用存根都放置在其自己的源文件中,以便有选择地链接它们。OS/161 将它们放在一起以简化生成文件。向 callno.h 添加新条目会在您重新构建用户级代码时自动定义新的用户级系统调用过程。此文件中的每个“SYSCALL(name,num)”宏语句都由 C 预处理器扩展为相应系统调用函数的声明。

kern/syscall.h 很可能是由这些工具之一生成的。

于 2020-08-02T06:41:23.410 回答