构建调试Linux内核网络代码的环境MenuOS系统

1.下载Linux内核源代码

https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.0.1.tar.xz
xz -d linux-5.0.1.tar.xz
tar -xvf linux-5.0.1.tar
cd linux-5.0.1

2. 安装内核编译工具

sudo apt install build-essential flex bison libssl-dev libelf-dev libncurses-dev

3.配置编译内核

make x86_64_defconfig #生成64位配置文件
make menuconfig #开启文本菜单选项,对窗口有限制,尽量调大窗口
#Kernel hacking -> Compile-time checks and compiler options -> [*] Compile the kernel with debug info#配置内核使之携带调试信息,保存并退出
make #编译,时间较长

4.升级当前系统内核

sudo make modules_install #安装前通过系统快照备份,以防出现故障前功尽弃
sudo make install
sudo update-grub
reboot
uname -a #检查当前内核版本,确认升级成功

5. 通过QEMU虚拟机加载内核,构造MenuOS

sudo apt install qemu
git clone https://github.com/mengning/menu.git
cd menu
sudo apt-get install libc6-dev-i386 #在64位环境下编译32位程序需安装
vim Makefile #将Makefile中"qemu..."那一行进行对应修改
qemu -kernel ../linux-5.0.1/arch/x86/boot/bzImage -initrd ../rootfs.img #打开qemu
make rootfs

 

构建调试Linux内核网络代码的环境MenuOS系统_第1张图片

 

 

6 构建Linux内核的gdb调试环境

qemu -kernel ../linux-5.0.1/arch/x86/boot/bzImage -initrd ../rootfs.img -append  nokaslr -s -S #在qemu中启动gdb server#可以看到新打开的qemu虚拟机显示黑屏,此时它正在等待gdb的链接#关于-s和-S选项的说明:#-S freeze CPU at startup (use ‘c‘ to start execution)#-s shorthand for -gdb tcp::1234#nokaslr KASLR是kernel address space layout randomization的缩写gdb #在另外一个终端运行gdbfile linux-5.0.1/vmlinux #加载符号表break start_kernel #在start_kernel处设置断点target remote:1234 #建立gdb与gdbserver之间的连接clist #显示断点处相关源代码

  构建调试Linux内核网络代码的环境MenuOS系统_第2张图片

你可能感兴趣的:(构建调试Linux内核网络代码的环境MenuOS系统)