linux内核分析之系统调用

来源:互联网 发布:淘宝banner全屏代码 编辑:程序博客网 时间:2024/05/20 07:52

在内核入口函数start_kernel中调用trap_init实现系统调用的初始化工作

void __init trap_init(void){...set_system_trap_gate(SYSCALL_VECTOR, &system_call);....}
也就是IDT中0x80用来实现系统调用,实现系统调用的函数为system_call,为汇编实现

ENTRY(system_call)RING0_INT_FRAME# can't unwind into user space anywaypushl %eax# save orig_eaxCFI_ADJUST_CFA_OFFSET 4SAVE_ALLGET_THREAD_INFO(%ebp)# system call tracing in operation / emulationtestl $_TIF_WORK_SYSCALL_ENTRY,TI_flags(%ebp)jnz syscall_trace_entrycmpl $(nr_syscalls), %eaxjae syscall_badsyssyscall_call:call *sys_call_table(,%eax,4)/*跳转到具体的系统调用函数*/movl %eax,PT_EAX(%esp)# store the return valuesyscall_exit:LOCKDEP_SYS_EXITDISABLE_INTERRUPTS(CLBR_ANY)# make sure we don't miss an interrupt# setting need_resched or sigpending# between sampling and the iretTRACE_IRQS_OFFmovl TI_flags(%ebp), %ecxtestl $_TIF_ALLWORK_MASK, %ecx# current->workjne syscall_exit_work
........

具体的系统调用函数存放在sys_call_table表中,在调用system_call具体的系统调用号存放在eax寄存器中

原创粉丝点击