第1关:进程创建前后页目录和页表的变化
本关任务:
1.在 0 号进程执行 fork 系统调用之前,线性地址空间到物理地址空间的映射关系是怎样的? 2.在 0 号进程刚执行完 fork 系统调用时,线性地址空间到物理地址空间的映射关系是怎样的?
3.在 0 号进程执行 fork 系统调用前后,页目录发生了怎样的变化?
一般而言,可以在该系统调用处设置断点,跟踪到该断点,然后使用 si 命令单步执行到陷入指令。但是,对于 main 函数里的 fork 系统调用,不能这样操作(因为 gdb 有时断点设置不够准),可以先跟踪到前一行的 move_to_user_mode 语句,然后使用 n 单步执行,即可到达 fork 系统调用的开始,此时再反汇编,找到陷入指令:
可以看到陷入指令的地址是0x6908,等会在bochsdbg模式将断点打在这个地址
查看0号进程控制块的地址和对应值,以便于在bochsdbg模式下判断进程号
在dbg模式下将断点打到陷入指令地址,并查看当前进程是否为0号进程
查看线性地址空间和物理地址空间映射关系