linux-系统调用如何知道包装函数将参数放入何处?
作者:互联网
我正在尝试在Linux(RedHat Enterprise 8)中实施syscall,我对其工作方式有些困惑.据我了解,我在用户模式下实现了一个包装器,该包装器将syscall编号放入eax,将参数放在ebx,ecx,edx等中,然后调用int 0x80,后者调用相应的syscall.我的问题是,由于系统调用是像常规C函数一样编写的,因此它如何知道哪些寄存器包含哪些参数?它是一个约定,还是有一个约定的机制?如果存在,它在哪里以及如何执行?
编辑:这是一项家庭作业.我知道有些syscall宏可以为我做这些事情.
解决方法:
从Linux Journal文章开始,在第2页的底部
Since the system call interface is exclusively register-parametered, six parameters at most can be used with a single system call. %eax is the syscall number; %ebx, %ecx, %edx, %esi, %edi and %ebp are the six generic registers used as param0-5; and %esp cannot be used because it’s overwritten by the kernel when it enters ring 0 (i.e., kernel mode).
您的c代码可能看起来像是在进行系统调用,但实际上是在libc中调用一个函数.该函数确保所有参数都在正确的寄存器中,然后执行中断.
标签:system-calls,linux 来源: https://codeday.me/bug/20191106/2000736.html