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

一、实验要求:

  1、使用gdb跟踪分析一个系统调用内核函数

  2、根据本周所学知识分析系统调用的过程,从system_call开始到iret结束之间的整个过程,并画出简要准确的流程图

二、实验步骤:

  1、实验环境是使用本课程配置的实验楼虚拟机环境

      2、打开命令行客户端,cd LinuxKernel目录,使用命令rm -rf menu删除原来的代码,使用git clone https://github.com/mengning/menu.git获取menu的最新代码,

      3、cd menu进入menu子文件夹,使用vi test.c打开文件,将上周实验的代码拷贝入test.c中,构造成两个函数,成为menu的两个菜单项。

      4启动系统,看到如下结果

实验截图如下:

2、分析system_call处理流程

 

 

代码如下:

  1. .macro INTERRUPT_RETURN  ; 中断返回  
  2.     iret  
  3. .endm  
  4. .macro SAVE_ALL          ; 保护现场  
  5.     ...  
  6. .macro RESTORE_INT_REGS  
  7.     ...  
  8. .endm  
  9.    
  10. ENTRY(system_call)  
  11.     SAVE_ALL  
  12. syscall_call:  
  13.     call *sys_call_table(,%eax,4)  
  14.     movl %eax, PT_EAX(%esp)  ; store the return value  
  15. syscall exit:  
  16.     testl $_TIF_ALLWORK_MASK, %ecx # current->work  
  17.     jne syscall_exit_work  
  18. restore_all:  
  19.     RESTORE_INT_REGS  
  20. irq_return:  
  21.     INTERRUPT_RETURN      ; 到这里就算执行完了  
  22. ENDPROC(system_call)  
  23.    
  24. syscall_exit_work:  
  25.     testl  $_TIF_WORK_SYSCALL_EXIT, %ecx  
  26.     jz work_pending  
  27. END(syscall_exit_work)  
  28.    
  29. work_pending:  
  30.     testb $_TIF_NEED_RESCHED, %cl  
  31.     jz work_notifysig  
  32. work_resched:  
  33.     call schedule  
  34.     jz restore_all  
  35. work_notifysig:  
  36.     ...                  ; deal with pending signals  
  37. END(work_pending)  

流程图:

三、总结

系统调用是很多种不同的中断处理过程组成,也就是中断,在中断里头可能还会有进程上下文的转换或者中断上下文的转换。

posted @ 2016-03-27 14:21  20135226黄坤  阅读(277)  评论(0编辑  收藏  举报