2021-2022-1 20212821《Linux内核原理与分析》第四周作业

本文详述了如何使用GDB跟踪Linux内核3.18.6的启动过程,从start_kernel函数开始,逐步解析内核初始化、0号进程、kernel_init和kthreadd线程的创建,直至init进程的启动。实验展示了内核如何从停止状态逐步执行到init进程运行的过程。
摘要由CSDN通过智能技术生成

实验三:跟踪分析Linux内核的启动过程

1.实验过程

首先在实验楼shell中执行以下命令:

cd ~/LinuxKernel/
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img

执行结果如下:
在这里插入图片描述
使用gdb跟踪调试内核启动过程
首先执行以下命令启动内核:

$ qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
  • 执行结果如下:

在这里插入图片描述
可以看到使用上述命令启动内核时内核处于[Stopped]状态
接下来再另外打开一个shell窗口,并执行如下命令:

gdb
(gdb)file linux-3.18.6/vmlinux
(gdb)target remote:1234
(gdb)break start_kernel

执行结果如下:
在这里插入图片描述
上述指令在start_kernel处设置了断点,接下来使用c命令来执行
结果如图:
在这里插入图片描述
内核代码运行到start_kernel()函数处遇到断点,暂停执行。
可以通过list命令查看到start_kernel处上下的代码:
在这里插入图片描述
接下来再在rest_init处设置一个断点,并使用c命令执行,结果如下:
在这里插入图片描述
可以看到,内核再一次暂停。
使用list命令:
在这里插入图片描述

2.从start_kernel到init进程启动过程的理解

首先,start_kernel会对几乎所有的内核主要模块进行初始化。start_kernel会率先使用宏初始化0号进程init_task,init_task是唯一一个没有使用kernel_thread()而是使用宏手工进行初始化的进程,kernel_thread()是内核创建线程的一种方式,也称为fork方式。接下来start_kernel就会对各种模块进行初始化。start_kernel函数在最后会调用rest_init函数,该函数用来创建kernel_init和kthreadd内核线程。其中,kernel_init(1号内核线程)和kthreadd(2号内核线程)均是0号进程通过kernel_thread()方式来创建的。0号进程在创建了init用户进程后就会调用cpu_idle()演变为idle进程,执行一次调度后,cpu开始运行init进程,而当系统中没有任何进程可以调度时,进程就绪队列为空,cpu就会再次转到0号进程运行,有新进程时再去执行新进程,如此反复。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值