免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1225 | 回复: 1
打印 上一主题 下一主题

linux内核分析之系统调用 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-26 21:44 |只看该作者 |倒序浏览

linux内核分析之系统调用









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




view plaincopy to clipboard
  1. 01.void __init trap_init(void)  
  2. 02.{  
  3. 03.    ...  
  4. 04.    set_system_trap_gate(SYSCALL_VECTOR, &system_call);  
  5. 05.    ....  
  6. 06.}  
复制代码
也就是IDT中0x80用来实现系统调用,实现系统调用的函数为system_call,为汇编实现




view plaincopy to clipboard
  1. 01.<pre name="code" class="html">ENTRY(system_call)  
  2. 02.    RING0_INT_FRAME         # can't unwind into user space anyway  
  3. 03.    pushl %eax          # save orig_eax  
  4. 04.    CFI_ADJUST_CFA_OFFSET 4  
  5. 05.    SAVE_ALL  
  6. 06.    GET_THREAD_INFO(%ebp)  
  7. 07.                    # system call tracing in operation / emulation  
  8. 08.    testl $_TIF_WORK_SYSCALL_ENTRY,TI_flags(%ebp)  
  9. 09.    jnz syscall_trace_entry  
  10. 10.    cmpl $(nr_syscalls), %eax  
  11. 11.    jae syscall_badsys  
  12. 12.syscall_call:  
  13. 13.    call *sys_call_table(,%eax,4)/*跳转到具体的系统调用函数*/  
  14. 14.    movl %eax,PT_EAX(%esp)      # store the return value  
  15. 15.syscall_exit:  
  16. 16.    LOCKDEP_SYS_EXIT  
  17. 17.    DISABLE_INTERRUPTS(CLBR_ANY)    # make sure we don't miss an interrupt  
  18. 18.                    # setting need_resched or sigpending  
  19. 19.                    # between sampling and the iret  
  20. 20.    TRACE_IRQS_OFF  
  21. 21.    movl TI_flags(%ebp), %ecx  
  22. 22.    testl $_TIF_ALLWORK_MASK, %ecx  # current->work  
  23. 23.    jne syscall_exit_work  
复制代码
........


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

论坛徽章:
0
2 [报告]
发表于 2011-12-26 21:44 |只看该作者
谢谢分享  
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP