日期:2014-05-16  浏览次数:20841 次

linux内核调试环境搭建
@PC: ubuntu 11.10, gcc 4.5, g++ 4.5
@virtual machine: bochs

@install:
1.直接安装
1.可以直接利用apt直接下载安装:
         $sudoapt-get install vgabios bochs bochs -x bximage

2.准备工作
1.      $sudoapt-get install build-essential
2.      $sudoapt-get install xorg-dev
3.      $sudoapt-get install bison
4.      $sudoapt-get install libgtk2.0-dev
5.      $sudoapt-get install g++

3.开始安装
1).bochs的官方网站为http://bochs.sourceforge.net/
2).可以通过页面上的链接到sourceforge下载源代码:
下载页面为http://sourceforge.net/projects/bochs/files/bochs/2.4.6/下载 bochs-2.4.6.tar.gz即可。
3).解压:
         $tarvxzf bochs-2.4.6.tar.gz
4).config: 进入到解压出的目录中,执行:
         $./configure–enable-debugger –enable-disasm
5).make:
         $make
6).安装:
$sudomake install

@startup:

1.制作虚拟软驱:

         $bximage

有提示,一步步操作就可以。

2.制作虚拟然盘映像:

         $ddif=boot.bin of=a.img bs=512 count=1 conv=notrunc

这里boot.bin是我们编译好的程序文件;a.img是我们要生成的软盘映像文件。

3.配置文件:
在a.img文件的所在目录下面,新建一个.bochsrc文件,并添加如下代码:
# how much memory the enulated machine will have
megs:32

# filename of ROM images
romimage:file=/usr/local/share/bochs/BIOS-bochs-latest
vgaromimage:file=/usr/local/share/bochs/VGABIOS-lgpl-latest

# what disk images will be used
floppya:1_44=a.img, status=inserted

# choose the boot disk
boot:floppy

# where do we send log messages?
log:bochsout.log

# disable the mouse
mouse: enabled=0

# enable key mapping, using US layout as default
keyboard_mapping: enabled=1, map=/usr/local/share/bochs/keymaps/x11-pc-us.map

NOTE!!! 这里romimage:file=的路经,vgaromimge:file=的路径,以及keyboard_mapping:enabled=1,map=的路径,需要设置为bochs安装的路径。
把这个.bochsrc文件与a.img文件保存在同一个目录下。

4.运行虚拟机:

         $bochs-f bochsrc

或者

         $bochs

然后选择6, 然后就根据bochs调试命令进行调试

@debug:

1.在某物理地址设置断点 b addr b 0x30400
2.显示当前所有断点信息 info break info break
3.继续执行,直到遇上断点 c c
4.单步执行 s s
5.单步执行(遇到函数则跳过) n n
6.查看寄存器信息:
info cpu info cpu
r r
fp fp
sreg sreg
creg creg
7.查看堆栈 print-stack print-stack
8.查看内存物理地址内容 xp /nuf addr xp /40bx 0x9013e
9.查看线性地址内容 x /nuf addr x /40bx 0x13e
10.反汇编一段内存 u start end u 0x30400 0x3040D | u/10
11.反汇编执行的每一条指令 trace-on trace-on
12.每执行一条指令就打印 CPU 信息 trace-reg trace-reg on 查看寄存器信息