首页 > 系统服务 > 详细

20135327郭皓--Linux内核分析第五周 扒开系统调用的三层皮(下)

时间:2016-03-27 19:22:47      阅读:424      评论:0      收藏:0      [点我收藏+]

Linux内核分析第五周 扒开系统调用的三层皮(下)

实验:分析system_call中断处理过程

  1.给MenuOS增加time和time-asm命令

技术分享

1 rm menu -rf //强制删除原menu文件
2 git clone http://github.com/mengning/menu.git //从github中克隆
3 cd menu //在menu文件夹下才能正确编译
4 make rootfs //运行自动编译脚本,生成根文件系统,启动MenuOS

技术分享

原来的菜单列表

进入test.c加入上周的getpid

技术分享

运行结果:

技术分享

2.使用gdb跟踪系统调用内核函数sys_time

PS:我在虚拟机里没有弄出来,没有找到vmlinux,于是在实验楼里完成!

 

准备进行gdb跟踪

技术分享

设置断点跟踪

技术分享

c:继续执行,停在断点处
n/s:单步运行,s进入函数,n不进入

从system_call开始到iret结束的流程图:

技术分享

 

系统调用在内核代码中的处理过程 

  • main.c中start_kernel函数:trap_init()
  • trap_gate函数中,涉及到了系统调用的中断向量和system_call的汇编代码入口
    • SYSCALL_VECTOR:系统调用的中断向量
    • &system_call:汇编代码入口
  • 执行int 0x80,系统直接跳转到system_call

system_call到iret之间的主要代码:

SAVE_ALL //保存现场
call *sys_call_table(,%eax,4) //调用了系统调度处理函数,eax存的是系统调用号,是实际的系统调度程序。
sys_call_table //系统调用分派表
syscall_after_all//保存返回值
sys_exit_work  //详见解释
restore all //恢复现场(因为系统调用也是一种特殊的“中断”)
INTERRUPT RETURN //也就是iret,系统调用到此结束    

对sys_exit_work的解释:

  • 若有sys_exit_work,则进入sys_exit_work:会有一个进程调度时机。
    • work_pending -> work_notifysig,用来处理信号
      • 可能call schedule:进程调度代码
      • 可能跳转到restore_all,恢复现场。
  • 若无sys_exit_work,就执行restore_all恢复,返回用户态。

 

 

总结:

  本周通过一个实验来分析系统调用“中断”机制,通过int 0x80触发一个系统调用 ,马上执行系统调用处理函数system_call,最后返回到用户态。而我们主要研究了内核在系统调用过程的代码来分析系统调用,通过gdb单步追踪也可以看出系统调用的过程,方便我们理解。

20135327郭皓--Linux内核分析第五周 扒开系统调用的三层皮(下)

原文:http://www.cnblogs.com/20135327leme/p/5326363.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!