系统调用实验
1.给MenuOS增加命令
利用以下代码添加两个命令:一个是time,功能是显示系统时间;一个是time-asm,功能是使用汇编方式来显示时间。
rm -rf menu //强制删除当前的menu目录
git clone https://github.com/mengning/menu.git //重新克隆一个新版本的menu
make rootfs //可以自动编译并自动生成根文件系统
可以在test.c文件中找到time和timeasm函数:
使用make roof打开menu镜像,操作完成后可以看到MenuOS菜单中新增了两条命令:
2.使用gdb跟踪系统调用内核函数sys_time
通过list命令列出了sys_time对应的代码:
3.system_call流程示意图
读者从系统调用处理过程的入口开始,可以看到SAVE_ALL保存现场,然后找到syscall_call和sys_call_table。call *sys_call_table(,%eax,4)就是调用了系统调用的内核处理函数,之后restore_all和最后有一个INTERRUPT_RETURN(iret)用于恢复现场并返回系统调用到用户态结束。在这个过程当中可能会执行system_exit_work,里面有work_pending,其中的work_notifysig是处理信号的。work_pending里还有可能调用schedule,这是一个非常关键的部分,他是进程切换的代码。
4.小结
(1)system_call是一段汇编代码的起点。只能调试系统调用的内核函数和其他内核函数的处理过程,但gdb不能完成跟踪执行过程的任务。
(2)system_call代码就是系统调用的处理过程,系统调用是一个特殊一点的中断(或称之为软中断),所有其他中断处理过程和这个system_call类似。比如中断过程中都有保护现场和恢复现场,system_call代码中保存现场SAVE_ALL和恢复现场restore_all。