标题1.分析 system_call 中断处理过程
删除menu后重新clone该菜单,将上周的代码添加到test.c中,同时添加新的main函数,结果如下:
经过重新编译后得到如下结果:
使用qumu命令重新启动内核并使用-s和-S参数“冻结”系统执行。
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
打开gdb调试,代码如下:
$ gdb
(gdb) file linux-3.18.6/vmlinux
Reading symbols from linux-3.18.6/vmlinux...done.
(gdb) target remote:1234
Remote debugging using :1234
0x0000fff0 in ?? ()
同时在sys_creat处设置断点,然后按c执行,在系统界面中输入新增的Create命令,中断被执行,结果如下:
标题2.结果分析和总结
系统调用命令的具体格式因系统而异,但由用户程序进入系统调用的步骤及执行过程大体相同。其执行过程如下:
1 .保护用户程序的现场信息,同时把系统调用命令的编号等参数放入指定的存储单元;
2 .根据系统调用命令的编号查找系统调用入口表,找到相应系统功能调用子程序的入口地址;
3 .转到该子程序执行,当系统调用命令执行完毕,相应的结果通常返回给参数,这些参数放在指定的存储单元里;
4 .系统调用命令执行完毕后恢复用户程序执行的现场信息,同时把系统调用命令的返回参数或参数区首址放入指定的寄存器中,供用户程序使用。
nt 0x80——>system call:通过中断向量匹配;
system call——>sys_xyz():通过系统调用号匹配;