该
int80h调用本身不会破坏任何东西,除了把返回值
eax。因此,您拥有的代码片段很好。(但是,如果您的代码片段是一个更大的例程的一部分,而该例程预期会被通常的Linux
x86 ABI之后的其他代码调用,则您需要
ebx在进入例程时保留,可能还有其他寄存器,并在退出时进行恢复。 )
内核中的相关代码可以在中找到
arch/x86/kernel/entry_32.S。由于宏的广泛使用和各种详细信息(支持syscall跟踪,DWARF调试注释等),因此很难遵循;但是:
int80h处理程序是
system_call(我链接到的版本的493行);寄存器通过
SAVE_ALL宏保存(第497行);并
RESTORE_REGS在返回之前再次通过(第534行)将其恢复。



