阅读学习教材「庖丁解牛Linux 分析 」第4章,有问题优先使用chatgpt等AI工具。或者到蓝墨云班课中提问,24小时内回复,鼓励解答别人问题,提问前请阅读「如何提问」。
教材深入学习关注豆列「Linux内核及安全」。
学习蓝墨云班课中第四周视频「构造一个简单的Linux系统MenuOS?」,并完成实验楼上配套实验三。,注意从下往上看。基于树莓派或其他平台完成ARM相关内容。
在本周日晚12:00前发学习博客(标题 学号《Linux内核原理与分析》第四周作业),重点是遇到的问题和解决方案内容涵盖教材学习和视频,格式用Markdown。不按时交作业会扣分。
跟踪分析 Linux 内核的启动过程
cd ~/LinuxKernel/
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img
输入以上命令
跟踪分析 Linux 内核的启动过程
$ qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
# 关于-s和-S选项的说明:
# 1. -S
# -S freeze CPU at startup (use ’c’ to start execution)
# 2. -s
# -s shorthand for -gdb tcp::1234
# 若不想使用1234端口,则可以使用-gdb tcp:xxxx来取代-s选项
完成上述操作后,另开一个 shell 窗口
# 打开 GDB 调试器
$ gdb
# 在 GDB 中输入以下命令:
# 在gdb界面中targe remote之前加载符号表
(gdb)file linux-3.18.6/vmlinux
# 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行
(gdb)target remote:1234
# 断点的设置可以在target remote之前,也可以在之后
(gdb)break start_kernel
可以看到内核代码运行到start_kernel()函数时停止,通过list命名查看断点附近代码
再在rest_init处设置一个断点,按c继续执行
使用list查看断点附近代码
start_kernel 函数是 Linux 内核启动的入口函数,其中包含了 Linux 系统的初始化和启动过程。以下是 start_kernel 函数的执行过程的简要分析:
初始化阶段:start_kernel 函数首先会进行一些初始化操作,如设置内核变量、建立页表等。
启动阶段:在初始化完成后,start_kernel 函数将调用 rest_init 函数,该函数会启动系统的其他核心子系统,如进程管理、内存管理等。
创建 idle 进程:在启动阶段,start_kernel 函数会创建一个特殊的进程,即 idle 进程。idle 进程是系统中唯一一个永远运行在空闲 CPU 上的进程,它没有实际的工作任务,只是在系统空闲时循环执行指令,以防止CPU无事可做。
创建 1 号进程:接下来,start_kernel 函数会创建 1 号进程,也称为 init 进程(或 systemd 进程)。init 进程是用户空间的第一个进程,负责启动用户空间的各种服务和程序。
总结起来,Linux 系统的启动过程主要经历了初始化阶段、启动阶段和进程创建阶段。start_kernel 函数是整个过程的入口函数,它完成了内核的初始化和其他核心子系统的启动。在启动过程中,通过创建 idle 进程和 1 号进程(init 进程),系统能够持续运行并为用户提供服务。
总结:
看了庖丁解牛书上的内容后,对内核原理有了自己的认识和理解,在实验过程中,出现了很多不解之处和很多错误之处,后来通过GPT一步步找出了问题并解决了问题,是一个成长的过程,发现问题,理解问题,最后解决问题这个过程让我印象深刻,这样才是真正的学习和进步!