系列文章目录
【Linux内核调试环境搭建01】内核编译
【Linux内核调试环境搭建02】使用qemu运行内核
前言
作为一个学习linux内核的小白,看着庞大地内核源码着实陷入了一种不知道从何开始地茫然。怎么愉快地阅读代码,怎么像debug单片机代码一样去调试内核、去查看它地执行步骤,这些问题困扰了我很久。那有人就说了,大佬有vim就够了!程序怎么运行的,大佬的脑子就是高性能多核CPU,直接在脑子里运行!行行行,我不是大佬。我花了大量时间疯狂地在浏览器进行索引后,终于找到了一个合适地方法。如果你和我一样也是一个小小白,那么这个系列文章将会教你如何愉快地阅读内核代码。
一、qemu是什么?
A generic and open source machine emulator and virtualizer
一个通用的开源机器模拟器和虚拟机。
无论我们想要学习内核,还是驱动相关的代码,我认为使用虚拟机去模拟物理硬件最为合适。使用过SOC的开发板的小伙伴,肯定会遇到过一类问题:程序下载。太麻烦了!又要准备Uboot、内核的执行文件、根文件系统,还需要使用厂家的提供的烧写工具去烧写,尽管很多厂家已经提供了很完善的工具,但我还是嫌繁琐,嫌烧程序等半天。老实说,这一套下来你还有多少精力去看你想看的,做你想做的。所以,听我的使用qemu吧,当然如果你目前还停留在折腾程序下载这个阶段,那就放手去折腾硬件吧^-^
!
二、安装qemu
我是用的是桌面版的Ubuntu22.04,直接apt安装吧
sudo apt update
sudo apt install qemu-system-arm
看看版本:
demo@demo-ubuntu:~/linux$ qemu-system-arm --version
QEMU emulator version 8.2.2
Copyright (c) 2003-2023 Fabrice Bellard and the QEMU Project developers
三、运行内核
【Linux内核调试环境搭建01】内核编译 章节已经编译好了内核,这里直接运行
qemu-system-arm \
-M vexpress-a9 \
-nographic \
-m 512M \
-kernel ~/linux/linux-4.19-build/arch/arm/boot/zImage \
-dtb ~/linux/linux-4.19-build/arch/arm/boot/dts/vexpress-v2p-ca9.dtb \
-append "console=ttyAMA0" \
-smp 4
如果你的qemu已经正常打印输出,且最后一句:
—[ end Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(0,0) ]—
那么你已经成功了^*v*^
总结
好了,没有根文件系统进入panic
,下一章再说。另外你是否发现按下ctrl+c
没办法让qemu
退出,你可以按ctrl+a
再按x
即可。