Board logo

标题: 转贴:dr-debug使用详解(简体)[作者: wolfwood ] [打印本页]

作者: lydong     时间: 2003-2-16 00:00    标题: 转贴:dr-debug使用详解(简体)[作者: wolfwood ]


[作者: wolfwood ]dr-debug使用详解
debug使用详解

首先,向大家推荐使用DR-DOS7所带的DR-DEBUG,指令支持到Pemtium pro,功能强大,且支持宏。最方便的是可以用回车代替上一条u/d/p/t指令,方便察看和调试。
下面把其帮助翻译如下:

汇编,把输入的汇编语言转成机器码
A [address]                                (example: Acs:100)

设置中断点以调试
B [address] [count] [condition]       (example: B100 2 al=80)

比较两段内存内容
Compare     C range address                       (example: C200 20d 500)

显示指定内存数据
Dump        D [range]                             (example: Dcs:500 L 10)

编辑内存数据
Enter       E [address] [data]                (example: Eds:500 "Hello "

填充内存
Fill        F range data                      (example: F100 13f "Test "

运行程序从指定点
Go          G [=address] [breakpoints]                (example: Gcs:4bb0)

计算
Hex         H [value1] [value2]                        (example: H10e 01)

从I/O埠输入
Input       I port                                        (example: I3f2)

载入文件或指定逻辑扇区内容
Load        L [address] [drive] [firstsec] [number]   (ex: L0Cff 3 09 10)

移动(复制)内存内容
Move        M range address                 (example: Mcs:200 220 cs:400)

指定操作文件名
Name        N [drive:] [path] filename               (example: Ntest.com)

向I/O埠输出
Output      O port value                               (example: O3ff 10)

单步执行(跳过int/rep/call等)
Proceed     P [=address] [number]                    (example: P=ds:3fff)

退出debug
Quit        Q

更改或显示寄存器
Register    R [register_name]                         (example: Rax 1000)

搜索数据于指定内存
Search      S range data                        (example: Sds:200 500 32)

单步执行(进入int/rep/call等)
Trace       T [=address] [number]               (example: T=3cff:0100 10)

反汇编指定内存中机器码
Unassemble  U [range]                           (example: U3cff:0200 400)

显示屏幕内容(相当于)
Viewswap    V                                           (any key returns)

写入文件或指定逻辑扇区内容
Write       W [address] [drive] [firstsec] [number] (ex: Wds:200 0 16 0f)
(range 可以是: 开始[段:]偏移 结束偏移  或  开始地址 L 长度)

以下是详细使用说明:
                   --- 术语表 ---
pathname  - 文件名(路径可选)
testparms - 参数
address   - 内存地址[段:]偏移
            如果省略段地址,以CS用作汇编\反汇编;DS用于其他功能
range     - 可以是: 开始[段:]偏移 结束偏移  
                    开始地址 L 长度
                    开始地址, +长度
reg       - 寄存器名
list      - 由空格或逗号分开的一些数值(给定类型的)

drive     - 0 = A:, 1 = B:, ...
firstsec  - 逻辑扇区号(以0开始)

                   --- 运算符号 ---
数可以是16进制(默认的), #十进制, \八进制, %二进制, '字符串'("chars",
寄存器, [绝对地址], ^堆栈。
可以使用运算符(+ - * /) 及 (括号) 。
例:Rax=(^[ss:sp] + (bl * %1001) + 'a').

-代表基本debug命令
+代表dr-debug特有命令
x代表只能在dr-debug扩展模式下执行的指令,用/s进入默认模式,用/x进入扩展模式

                   --- Dump commands ---
-D[number]           x 设置/查询默认显示长度(按字节)
-DB[number]          x 设置/查询默认显示长度,并返回按字节模式
D=[hexdigit|?|-]     x 设置/查询 察看开始点(0-f)
D [range]            - 显示指定内存内容(/S 模式) / 重复上一次D? 命令(/X 模式)
DB[range]            - 显示指定内存内容(按字节)
DW[range]            x 显示指定内存内容(按字)
DD[range]            x 显示指定内存内容(按双字)
DP[range]            x 显示指定内存的指针(远间指针-段:偏移)
DI[range]            x 显示中断向量表(range=中断号)

                   --- Enter commands ---
                       (省略list时,回车后输入数据,"."退出)
E [address