Bochs几条基本指令:

通过物理地址查看内存时,可以不加参数'/nuf':

其中n指定显示的单元数,默认是1;

u 指定每个显示单元的大小(b表示字节、h表示字(2字节)、w表示双字(4字节)),默认是w;

f 指定显示格式(x 十六进制、d 有符号十进制、u 无符号十进制、o 八进制、t 二进制、c 字符),默认是x

1、指令断点

1.1、设置断点

1.1.1、设置在物理地址

b/break addr

1.1.2、设置在线性地址

lb/lbreak addr

1.1.3、设置在虚拟地址

vb/vbreak seg:off  seg是段选择子,off是段内偏移。

1.2、禁用/启用断点

bpd|bpe bn  禁用/启用断点,相当于WinDBG的“be”和“bd”。bn是断点号,可以用blist命令查询。

1.3、删除断点

d/del bn  bn是断点号,可以用blist命令查询。

1.4、显示现有断点(断点号和地址)

blist/info b/info break

2、读写断点

2.1、设置读写断点

watch read addr

watch write addr

2.2、删除读写断点

unwatch read addr

unwatch write addr

unwatch  删除所有现有的读写断点

2.3、显示现有读写断点

watch

3、执行控制

3.1、单步执行(遇到call和int进入函数、中断内)

s/step [count]  单步执行count条指令,count 默认为 1。相当于WinDBG的“t”。

3.2、单步执行(遇到call和int不进入函数、中断内)

p/n/next  相当于WinDBG的“p”。

3.3、继续执行,直到遇到断点

c/cont  相当于WinDBG的“g”。

4、查看寄存器

4.1、查看通用寄存器

r/info r/info reg

4.2、查看段寄存器和段描述符寄存器

sreg

info gdt  查看全局描述符表的信息

info idt  查看中断描述符表的信息

info ldt  查看局部描述符表的信息

info tss  查看任务状态段的信息

4.3、查看控制寄存器

creg

5、查看内存

5.1、通过物理地址查看

xp [/nuf] addr

其中n指定显示的单元数,默认是1;

u 指定每个显示单元的大小(b表示字节、h表示字(2字节)、w表示双字(4字节)),默认是w;

f 指定显示格式(x 十六进制、d 有符号十进制、u 无符号十进制、o 八进制、t 二进制、c 字符),默认是x

5.2、通过线性地址查看

x [/nuf] addr  nuf的意义同上

5.3、查看堆栈

print-stack

5.4、反编译

u/disas/disassemble [/n] [start] [end]

n是反编译的指令的数目,默认是1;start是开始反汇编的地址,默认是当前指令指针所指的地址;end是结束反汇编的地址

6、停止调试并退出

q/quit/exit

可以通过输入命令help查看相关命令参数信息

例:help x

help b

bochs调试命令的更多相关文章

  1. 用bochs调试自己写的系统引导代码

    1 安装和配置bochs 首先从bochs.sourceforge.net里面把BOCHS给download下来,鉴于Windows的普及,仅仅谈BOCHS在win下的使用方法,其实在其它的OS中方法 ...

  2. 利用bochs调试Linux 0.11内核

    引导程序调试软件bochs,跟配套的linux0.11内核img下载地址分别是: http://sourceforge.net/projects/bochs/http://www.oldlinux.o ...

  3. Bochs调试加载符号文件的问题

    1. Bochs中的调试命令ldsym没有触发的情况. 参考:http://www.ibm.com/developerworks/cn/linux/sdk/lex/ Lex 代表 Lexical An ...

  4. bochs 调试 com 文件 magicbreak

    参考 https://blog.csdn.net/housansan/article/details/41833581 在网上看到2中解决此问题的方法:1.使用dos下的debug32工具单步跟踪pm ...

  5. 使用bochs调试汇编程序

    使用bochs调试汇编程序 前面我们已经搭建好了bochs的环境,并且将我们的汇编程序写入了硬盘里面,现在我们来看看如何通过bochs来调试我们的程序. 前文:https://www.cnblogs. ...

  6. GDB调试命令小结

    1.启动调试 前置条件:编译生成执行码时带上 -g,如果使用Makefile,通过给CFLAGS指定-g选项,否则调试时没有符号信息.gdb program //最常用的用gdb启动程序,开始调试的方 ...

  7. Windbg调试命令详解

    作者:张佩][原文:http://www.yiiyee.cn/Blog] 1. 概述 用户成功安装微软Windows调试工具集后,能够在安装目录下发现四个调试器程序,分别是:cdb.exe.ntsd. ...

  8. jdb调试命令

    常用调试命令: run GeoHashTest #带参数运行 stop at GeoHashTest:22 #断点GeoHashTest文件的22行 stop in GeoHashEncode.Enc ...

  9. 基础调试命令 - .dump/.dumpcap/.writemem/!runaway

    Windbg是windows平台上强大的调试器,它相对于其他常见的IDE集成的调试器有几个重要的优势, Windbg可以做内核态调试 Windbg可以脱离源代码进行调试 Windbg可以用来分析dum ...

随机推荐

  1. Angular 学习笔记 ( 我追的 feature 和 bug )

    Angular 有许多功能还不齐全,也有不少 bug 让人很头疼,所以这里做一些记入 Angular Bug 1.input type="number", valueChanges ...

  2. C# 泛型集合排序

    Student sModel = new Student(); List<Student > list = new List<Student >(); list= list.O ...

  3. Arc Engine二次开发——弹窗进行属性查询

    在Arcmap中使用Sapefile格式的矢量数据时,经常会用到其属性查询的功能,弹出窗体然后用户鼠标点击或手动输入查询条件,进而查询到感兴趣的要素.在AE二次开发中也经常需要这个功能,于是在此记录整 ...

  4. Innodb学习

    一.并发控制 为什么要进行并发控制? 因为并发的任务会对同一个临界资源进行操作,如果不进行并发控制,可能导致不一致,故必须进行并发控制. 如何进行并发控制? 1.锁. 2.数据多版本. 施工ing.. ...

  5. Django 启动报错 UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc7

    pycharm 报错 cmd 报错 解决办法 首先 是计算机 编码问题  是 django 读取你的  用户host名 但是 windos 用户名 如果是中文 就会报这个错  要改成 英文

  6. unittest管理测试用例

    #coding=utf-8 from selenium import webdriver from time import sleep import unittest #导入unittest库 imp ...

  7. jade注释

    在jade里面注释是有多种方式的 单行注释,加两个//,跟js里面一样 //h1.title#title imoock jade study => <!--h1.title#title i ...

  8. Entity Framework 在MySQL中执行SQL语句,关于参数问题

    在Entity Framework中添加MySQL模型,在写代码的过程中需要直接执行SQL语句. 在SQL语句中用到了@curRank := 0 这样在SQL语句中定义参数,同时还会有传入参数:ai. ...

  9. XSLT格式

    XSL 指扩展样式表语言(EXtensible Stylesheet Language). XSL - 不仅仅是样式表语言,包括三部分: XSLT :一种用于转换 XML 文档的语言. XPath : ...

  10. vue 组件高级用法(递归组件,内联模板,动态组件,异步组件)