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 查看寄存器信息