第五周
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第五周相关的知识,希望对你有一定的参考价值。
潘恒 + 原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
一、使用gdb跟踪分析一个系统调用内核函数
1.增加系统调用
1).先执行rm menu -rf,强制删除原有的menu文件夹,使用git命令更新menu代码至最新版
2).test.c中main函数里,增加MenuConfig()
3).增加对应的两个函数,Getpid和GetpidAsm
4).make rootfs
输入help,可以看到当前的系统调用:
5).
成功。
2.使用 gdb调试
c运行之后,在MenuOs里使用time,可以看到它停了下来
list可以查看内部的函数,直到sys_time返回后进入汇编代码处理,gdb无法继续进行追踪
二、分析从system_call开始到iret结束之间的整个过程
- SAVE_ALL:保存现场
- syscall_call:调用了系统调用处理函数
- restore all:恢复现场(因为系统调用处理函数也算是一种特殊的“中断”)
- syscallexitwork:同上一条i
- INTERRUPT RETURN:也就是iret,系统调用到此结束
三、对系统调用处理过程的理解
1.用户态到内核态需要int 0x80进行中断,只有生成了中断向量后才可以切换状态;
2.中断处理让CPU停止当前工作转为执行系统内核中预设的一些任务,因此必须要对当前CPU执行的任务进行执行现场的保护工作,并对一些其他杂七杂八的工作进行检查,完成调用后,再进行检查,才能执行iret返回。
以上是关于第五周的主要内容,如果未能解决你的问题,请参考以下文章