出于对用虚拟机 调试 内核代码,看是否能对学习内核有比较大的帮助。。 进行了下验证 。
中间 的命令仅作为参考, 是使用过程中的一些记录, 文件命名 路径名 使用时 作出对应调整 需。
1, 下载linux内核源码。
https://mirrors.edge.kernel.org/pub/linux/kernel/v3.x/
$ wget https://cdn.kernel.org/pub/linux/kernel/v3.x/linux-3.10.104.tar.xz # 解压 $ tar xvf linux-3.10.104.tar.xz
$ cd linux-3.10.104
进行配置
$ make menuconfig
编译。
$ make -j8 #
$ cp linux-3.10.104/arch/x86_64/boot/bzImage
安装虚拟机
$ sudo apt-get install qemu
2. 制作rootfs
vi hello.c
gcc -static -o helloworld hello.cecho helloworld | cpio -o --format=newc > rootfs
制作根文件系统。
emu-system-x86_64 -kernel linux_3.10/linux-3.10.92/arch/x86_64/boot/bzImage -initrd ./rootfs/rootfs -append "root=/dev/ram rdinit=/helloworld"
3, 启动 启动linux内核。
cd LinuxKernel
qemu-system-i386 -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S # 关于-s和-S选项的说明:
# -S freeze CPU at startup (use ’c’ to start execution)
# -s shorthand for -gdb tcp::1234 若不想使用1234端口,则可以使用-gdb tcp:xxxx来取代-s选项
qemu-system-x86_64 -kernel linux_3.10/linux-3.10.92/arch/x86_64/boot/bzImage -initrd ./rootfs/rootfs -append "root=/dev/ram rdinit=/helloworld" -s -S
4 启动gdb调试
gdb
(gdb)file linux-3.18.6/vmlinux # 在gdb界面中targe remote之前加载符号表
(gdb)target remote:1234 # 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行
(gdb)break start_kernel # 断点的设置可以在target remote之前,也可以在之后