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

 实验环境

实验楼(实验楼每次实验有时间限制,本次实验并非一次性做完的,所以截图上显示的时间会有一些错乱。)

初识 MenuOS 系统

我们已经在 LinuxKernel 目录构建好了基于 3.18.6 的内核环境,可以使用实验楼的虚拟机打开 Xfce 终端(Terminal), 运行 MenuOS 系统。

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

将网络通信程序的服务端集成到 MenuOS 系统中

接下来我们需要将 C/S 方式的网络通信程序的服务端集成到 MenuOS 系统中,成为 MenuOS 系统的命令 replyhi。

实际上我们已经给大家集成好了,我们 git clone 克隆一个 linuxnet.git,进入 lab2 目录执行 make 可以将我们集成好的代码 copy 到 menu 项目中。

然后进入 menu,我们写了一个脚本 rootfs,运行 make rootfs,脚本就可以帮助我们自动编译、自动生成根文件系统,还会帮我们运行起来 MenuOS 系统。

详细命令如下:

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

其中我们增加了命令 replyhi,功能是回复 hi 的 TCP 服务.

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

 使用跟踪分析 ~/Linux 内核的启动过程的 -s 和 -S 选项启动 MenuOS 系统:

$ qemu -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 选项

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

接下来您就可以参照前面“跟踪分析 Linux 内核的启动过程的具体操作方法”进行跟踪调试了,

只是我们 socket 接口使用的是系统 sys_socketcall,可以将 sys_socketcall 设为断点跟踪看看。

# 打开 GDB 调试器 $ gdb

# 在 GDB 中输入以下命令:

# 在 gdb 界面中 targe remote 之前加载符号表

(gdb)file linux-3.18.6/vmlinux

# 建立 gdb 和 gdbserver 之间的连接

(gdb)target remote:1234

# 断点的设置可以在target remote之前,也可以在之后

(gdb)break start_kernel

# 按 c 让qemu上的Linux继续运行

(gdb)c

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

 

 

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