注:
1.C和C++编译器使用逆序,即第一个参数放在堆栈顶部
2.库过程是由汇编语言写成的。因为引发系统调用的实际机制是非常依赖于机器的,一些诸如保存寄存器值和设置堆栈指针之类的操作是无法用C语言这一高级语言描述,所以这些操作通过一个短小的汇编语言例程来完成,使得C语言(或其他语言)能够通过调用该例程来使用系统调用。
3.陷入内核(TRAP)和普通的过程调用有什么不同?
1)执行普通的过程调用,不会改变模式
执行TRAP,运行模式从用户态切换到内核态
2)过程调用给定过程所在的相对地址或绝对地址
TRAP指令不能跳转到任意地址,只能跳转到一个固定地址上,或者指令中有一个8位长的字段,它给定了内存中一张表的索引,这张表中含有跳转地址