在应用层,系统调用在C库中有相应的函数,在那里会期通过中断指令INT 0x80,
使cpu由用户态转变成内核态,会执行到system_call()(arch/i386/kernel/entry.S),每个系统调用都有自
己的系统调用号,在内核中有一个系统调用表sys_call_table[],以系统调用号为下标的相应元素是一个函数指针,即系统调用在内核中对应函数
的入中地址.system_call()中,会通过call指令调用到该函数.这样就完成了从shell中输入mkdir
调用到内核的sys_mkdir了.
首先把系统调用号装入EAX,然后把调用参数放在ebx、ecx、edx、esi、edi,然后触发0x80中断。这是x86上的做法,其他体系结构类似(Robert Love《LKD》)。
阅读(1042) | 评论(0) | 转发(0) |