2022-2023-1 20222814 《Linux内核原理与分析》第七周作业
实验六-分析Linux内核创建一个新进程的过程
1、删除原有的menu,在github上下载新版本menu
2、MenuOS中增加fork命令,并覆盖掉test.c文件
在MenuOS输入help查询系统调用函数,测试新加入的fork命令,并执行fork:
3、跟踪分析进程创建的过程
(1)在shell1中启动内核
cd LinuxKernel //返回LinuxKernel目录
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S //启动内核
(2)在shell2中进行gdb调试
(gdb)file linux-3.18.6/vmlinux
(gdb)target remote:1234
在sys_clone、do_fork、dup_task_struct、copy_process、copy_thread、ret_from_fork处设置断点:
(gdb)b sys_clone
(gdb)b do_fork
(gdb)b dup_task_struct
(gdb)b copy_process
(gdb)b copy_thread
(gdb)b ret_from_fork
gdb中continue执行到断点do_fork处:
继续调试,会停留在第3个断点,停在dup_task_struct函数,最终进入dup_task_struct内部,停留在copy_thread和ret_from_fork上: