实验步骤:
1.安装内核
下载linux-5.0.1.tar.xz,地址为 https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.0.1.tar.xz。国外源比较慢,建议自行更改为国内源。
创建一个目录叫做MenuOS,把下载好的文件包放进去,进行解压缩。
xz -d linux-5.0.1.tar.xz
tar -xvf linux-5.0.1.tar
得到一个目录,叫做linux-5.0.1,内容如下:
make x86_64_defconfig#生成32位x86的配置文件
make menuconfig#进入图形界面
随后进行编译make,等待时间30分钟左右。
sudo apt install qemu # 安装qemu命令
sudo ln -s /usr/bin/qemu-system-i386 /usr/bin/qemu #建立一个软链接 之后才可以使用qem
2.安装qemu模拟器
git clone https://github.com/mengning/menu.git mkdir rootfs cd menu sudo apt-get install libc6-dev-i386 #安装libc6-dev-i386
vim Makefile #修改一下Makefile文件 qemu -kernel ../linux-5.0.1/arch/x86/boot/bzImage -initrd ../rootfs.img #创建的根文件系统 make rootfs #初始化根目录
3.构建gdb调试环境
qemu -kernel ../linux-5.0.1/arch/x86/boot/bzImage -initrd ../rootfs.img -append nokaslr -s -S
//在新打开的qemu虚拟机上,出现的是一个黑屏,此时的qemu在等待gdb的连接
gdb file ~/LinuxKernel/linux-5.0.1/vmlinux # # 在gdb界面中targe remote之前加载符号表
break start_kernel # 断点的设置可以在target remote之前,也可以在之后
target remote:1234 # 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行 c #按c 让qemu上的Linux继续运行 list #输入list指令可以查看断点处的代码。
4.构建调试Linux内核网络代码的环境MenuOS
cd ~/LinuxKernel git clone https://github.com/mengning/linuxnet.git cd linuxnet/lab2 make cd ../../menu/ make rootfs
cd ~/LinuxKernel cd linuxnet/lab3 make rootfs