bochs: bochs
ubuntu安装Bochs
sudo apt-get install bochs bochs-x
进入工程目录
输入 bochs命令运行
进入选择命令行,输入6启动模拟器
$ vim bochsrc.me
cpu: model=core2_penryn_t9600, count=1, ips=50000000, reset_on_triple_fault=1, ignore_bad_msrs=1, msrs="msrs.def"
cpu: cpuid_limit_winnt=0
memory: guest=512, host=256
## vgaromimage: file=$BXSHARE/VGABIOS-lgpl-latest
vgaromimage: file=/usr/share/bochs/VGABIOS-lgpl-latest
mouse: enabled=0
pci: enabled=1, chipset=i440fx
private_colormap: enabled=0
floppya: 1_44=/dev/fd0, status=inserted
ata0: enabled=1, ioaddr1=0x1f0, ioaddr2=0x3f0, irq=14
ata1: enabled=1, ioaddr1=0x170, ioaddr2=0x370, irq=15
ata2: enabled=0, ioaddr1=0x1e8, ioaddr2=0x3e0, irq=11
ata3: enabled=0, ioaddr1=0x168, ioaddr2=0x360, irq=9
ata0-master: type=disk, mode=flat,path="build/ratsos.img"
boot: disk
floppy_bootsig_check: disabled=0
log: bochsout.txt
panic: action=ask
error: action=report
info: action=report
debug: action=ignore, pci=report # report BX_DEBUG from module ‘pci‘
debugger_log: -
parport1: enabled=1, file="parport.out"
#sound: driver=default, waveout=/dev/dsp. wavein=, midiout=
#speaker: enabled=1, mode=sound
创建硬盘镜像
bximage -mode=create -hd=128M -imgmode=flat -q icyos.img
根据配置文件运行
命令如下:
bochs -f bochsrc.me
调试
| 命令 | 说明 |
|---|---|
| blist | 显示所有断点信息 |
| pb [物理地址] | 设置断点,以物理地址方式 |
| vb [虚拟地址] | 设置断点,以虚拟地址方式 |
| lb [线性地址] | 设置断点,以线性地址方式 |
| d [断点号] | 删除断点 ,断点号根据blist查询 |
| c | 继续执行,跳到下一个断点/ |
| s [N] | 单步执行 |
| n | 单步执行(跳过call函数内部 ) |
| q | 退出 |
显示信息
| 命令 | 说明 |
|---|---|
| show mode | 显示模式切换 |
| show int | 显示中断 |
| show call | 显示call调用 |
| trace on | 显示指令反编译 |
| info ivt | 显示ivt(中断向量表)信息 |
| info idt | 显示idt(中断描述符表)信息 |
| info gdt | 显示gdt信息 |
| info ldt | 显示ldt信息 |
| info tss | 显示tss信息 |
| info tab | 页表映射 |
| reg | 通用寄存器信息 + 标志寄存器 + eip寄存器信息 |
| sreg | 段寄存器信息 |
| creg | 控制寄存器信息 |
| dreg | 调试寄存器信息 |
| print-stack N | 堆栈信息 |
内存信息
| 命令 | 说明 |
|---|---|
| xp /nuf [物理地址] | 显示物理地址处内容,例如:xp /16 0xa0000 |
| x /nuf [线性地址] | 显示线性地址处内容 |
| setpmem | |
| page | |
原文:https://www.cnblogs.com/mlzrq/p/10223048.html