20233808《Linux内核原理分析与设计》第四周作业

1.学习第四章并与chatgpt的对话

https://chat.openai.com/share/f811934c-053e-4146-aac6-986618ee1511

2.实验楼

打开shell

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

冻结CPU

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

# 关于-s和-S选项的说明:
#1. -S
#-S 在启动时冻结CPU(使用'c'开始执行)
#2. -s
#-s 是'-gdb tcp::1234'的简写形式
# 若不想使用1234端口,则可以使用-gdb tcp:xxxx来取代-s选项

跟踪调试

# 打开 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

3.分析

start_kernel函数是内核的入口点,它的执行过程可以分为以下步骤:

1. 设置堆栈和初始化处理器:在这个阶段,内核还会禁用中断,以确保在初始化完成之前不会发生中断。

2. 初始化内核调度器;

3. 启动初始化进程的创建:start_kernel通过调用kernel_init函数创建初始化进程。这是通过在内核线程中创建一个用户态进程来完成的;

5. 启动内核初始化代码:kernel_init函数进一步初始化系统;

6. 初始化 1 号进程:1号进程是用户空间的第一个进程,通常是`/sbin/init`或`systemd`。1号进程的创建是由`kernel_init`或`init`函数负责的;

这些步骤最终将系统从内核态切换到用户态,使得用户应用程序能够在系统上运行。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值