分析system_call中断处理过程
一、给MenuOS增加命令
首先可以删除实验楼自带的系统,然后再git clone一个新的,这样减少了编译过程,一个make搞定
我们进入menu中的test.c,新增我上一次博客中的两个功能的代码(一个API,一个内嵌汇编)-注意要加头文件**#include<unistd.h>**
然后执行如下命令:
make rootfs
结果为:
二、使用gdb跟踪调用内核函数sys_getpid
gdb调试
首先返回父目录,再启动镜像,但一定要把镜像冻结起来,命令如下:
cd ..
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
这里-s是在1234端口创建一个gdb-server,-S是将其冻结起来,方便gdb调试:
再打开一个窗口,打开gdb,然后输入:
file linux-3.18.6/vmlinux
target remote:1234
然后可以设置两个断点:
b start_kernel
b sys_getpid
结果如下图所示: