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

本文介绍了一个简单的内核调试实验过程,通过使用QEMU和GDB实现了内核的启动与跟踪调试,并详细分析了内核启动流程,包括0号进程、init进程及关键内核线程的创建与调度。

一、实验过程

1.使用一下命令启动内核,

cd ~/LinuxKernel/

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

结果如图

2. 使用 gdb 跟踪调试内核。

$ qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S 

结果如下图,内核运行被冻结

打开 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()(入口)处对init_task(0号进程)进行初始化,0号进程创建了init进程后,调用cpu_idle()转变为idle进程,执行最后一次调度后,init进程运行。1号内核线程kernel_init()负责执行内核的部分初始化工作及系统配置,最后调用do_execve加载init程序,演变成init进程(用户态1号进程),init进程时内核启动的第一个用户态进程;2号内核线程kthreadd()由0号进程创建,始终运行在内核空间,负责所有内核线程的调度和管理。在start_kernel处设置断点,因为内核的主要模块的初始化工作都是在start——kernel函数里调用的。main.c中没有main函数,start_kernel()就相当于C语言中的main函数,start_kernel是一切的起点,所以首先在start_kernel()设置断点进行分析。
 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值