Debug的基本使用()
Debug是一个通过操作系统(os)对cpu寄存器进行访问用于学习汇编的程序,但是如今的win10(64位)已经不支持cmd打开debug,但是我们可以通过DOSBOX模拟器对其进行访问。
安装方法:先在https://www.dosbox.com中下载dosbox(默认路径在C:\Program Files (x86)),接下来在网上下载debug.exe,为了方便可以直接在D盘下创一个Debug文件夹放到里边即可。接下来修改一下DOSBox 0.74-3 Options.bat里的路径,把最后的路径挂到
MOUNT C D:\DebugC:debug
中即可打开Dosbox。
debug 的基本用法
debug 基本指令 | 指令全称 | 用法 | 用途 |
---|---|---|---|
? | ---------- | ? | 显示debug的命令列表 |
A | assemble | A [ address ] | 将输入源程序的指令汇编成目标代码并从指定的地址单元开始存放。若省缺起始地址,则从当前CS:100地址开始存放。A命令按行汇编,主要用于小段程序的汇编或对目标程序的修改 |
C | compare | C range address | 比较内存的两个部分 |
D | dump | D [ range ] | 显示部分内存的内容 |
E | enter | E address [ list ] | 从指定地址开始,将数据输入 |
F | fill | F range list | 使用指定值填充一段内存 |
G | go | G [ = address ] [ addresses ] | 运行在内存中的可执行文件 |
H | hex | H value1 value2 | 执行十六进制运算 |
I | input | I port | 显示来自特定端口的 1 字节值 |
L | load | L [ address ] [driver ] [ firstsector ] [ number ] | 将文件或磁盘扇区内容加载到内存 |
M | move | M range address | 复制内存块中的内容 |
N | name | N [ pathname ] [ arglist ] | 指定 Debug l(加载)或 w(写入)命令的可执行文件的名称,或者指定正在调试的可执行文件的参数 |
O | output | O port byte | 向输出端口发送 1 个字节的值 |
P | proceed | P [ =address ] [ number ] | 执行循环、重复的字符串指令、软件中断或子例程;或通过任何其他指令跟踪 |
Q | quit | Q | 退出 debug会话,不保存当前测试文件 |
R | register | R [ register ] | 若给出寄存器名,则显示该寄存器的内存并可进行修改。缺省寄存器名,则显示所有寄存器的内容及当前值( 不能修改 ) |
S | search | S range list | 在部分内存中搜索一个或多个字节值的模式 |
T | trace | T [ =address] [ value ] | 执行一条指令,然后显示所有寄存器的内容、所有标志的状态和Debug下一步要执行的指令的解码形式 |
U | unassemble | U [ range ] | 反汇编字节并显示相应的原语句 |
W | write | W [address ] [ drive ] [ firstsector ] [ number ] | 将测试文件写入磁盘 |
XA | allocate expanded memory | XA [ # pages ] | 分配扩展内存 |
XD | deallocate expanded memory | XD [ handle ] | 释放扩展内存 |
XM | map expanded memory pages | XM [ Lpage ] [ Ppage ] [ handle ] | 映射扩展内存页 |
XS | display expanded memory status | XS | 显示扩展内存的状态 |
以上便是debug的简介。
学习汇编语言并且调用debug调试的时候,主要使用到 -L -U -D -G -T -P 指令
-L 装入 -G 运行 -U 反汇编 -T 单步(可以进入子程序) -P 单步(不进入子程序)-D 查询内存
汇编语言程序建立步骤:
- edit 建立源文件 格式:edit xxx.asm ( 必须以 asm 为扩展文件名,否则不能使用 masm 调用 ),生成 obj 文件。
- masm 生成链接文件 格式:masm xxx.asm 然后生成 obj 文件,obj 文件是可连接文件,接下来需要使用link链接文件生成exe
- link 生成 exe 文件 格式:link xxx.obj 生成 exe 可执行文件
接下来我们进行一些基本的操作
-r 命令查看,改变cpu寄存器内容
-d 查看内存中的内容
-e 命令改写内存中的内容
-u 将机器指令翻译为汇编指令
-t 执行下一条指令
-a 以汇编指令方式写入一条机器指令
首先介绍一下基本内容,看下初始配置:
看这些寄存器的名称应该都是8086的寄存器名称2333
在电脑(CISC)的cpu指令由pc(cs段地址和ip偏移地址往地址总线传输地址)控制,因此我们可以修改cs和ip值对pc进行操作。
CS:代码段寄存器i ES:额外的寄存器
DS:数据段寄存器 (A-D)X:普通寄存器
SS:堆栈段寄存器 SP:堆栈寄存器
BP:基址寄存器 DI:变址寄存器
SI:源址寄存器
修改cs,ip地址(-r cs||ip),dosbox里默认是2个字节16位,即4个十六进制表示:
执行下一条指令(-t),可发现ip+=3,占了三个字节,在-d查看一下内存:
下面我们随意用-a来操作一下(输入命令):
然后修改cs:ip往下执行......:
按quit即可退出,以上就是debug的基本汇编操作用法,观看愉快!!!
相关文章
Windows10下利用DOSBOX和MASM32搭建汇编语言开发环境
这篇文章主要介绍了Windows10下利用DOSBOX和MASM32搭建汇编语言开发环境,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2020-01-01
最新评论