一、编译Linux内核
1.下载并解压Linux-5.0.1
mkdir kernel wget https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/linux-5.0.1.tar mv linux-5.0.1.tar ./kernel cd kernel tar -xvf linux-5.0.1.tar.gz
2.安装编译工具
sudo apt install build-essential flex bison libssl-dev libelf-dev libncurses-dev
3.配置内核并编译
make menuconfig
4.编译
make
5.升级内核
sudo make modules_install sudo make install sudo update-grub reboot uname -a
二、安装qemu模拟器
sudo apt-get install qemu
三、构造MenuOS
git clone https://github.com/mengning/menu.git mkdir rootfs cd menu sudo apt-get install libc6-dev-i386 #在64位环境下编译32位需安装
因为我们Ubuntu的Linux内核版本和此次实验版本不同,所以需要在制作根文件系统前先修改makefile,将其kernel路径更改为我们安装的Linux-5.0.1的路径(注意makefile文件的修改权限,使用sudo打开)
make rootfs #初始化根文件系统
qemu-system-x86_64 -kernel linux-5.0.1/arch/x86/boot/bzImage -initrd rootfs.img #启动qemu模拟Menu OS
四、集成tcp服务端测试网络功能
在命令行输入help查看当前提供命令
git clone https://github.com/mengning/linuxnet.git cd linuxnet/lab2 make
完成配置后再次启动
qemu-system-x86_64 -kernel linux-5.0.1/arch/x86/boot/bzImage -initrd rootfs.img
键入help查看提供的命令
已经提供了replyhi和hello的命令
依次键入replyhi和hello
Menu OS系统已成功实现基于TCP的客户端和服务端通信
五、使用GDB跟踪调试内核函数
qemu-system-x86_64 -kernel linux-5.0.1/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已被冻结,重新开启一个终端进入gdb调试
(gdb)file linux-5.0.1/vmlinux # 在gdb界面中targe remote之前加载符号表 (gdb)target remote:1234 # 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行 (gdb)break start_kernel # 断点的设置可以在target remote之前,也可以在之后
继续运行并通过list命令查看断点处代码