`

汇编笔记

阅读更多

 

1.寄存器:

 

AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW

 

通用寄存器AX,BX,CX,DX,存放数据

 

段寄存器CS(段寄存器),IP(段指针),CPU通过CS * 16 + IP 读取指令并执行。

 

执行内容如 B8 01 00

 

执行后IP加3

 

 

2.命令

 

r 查看修改寄存器内容

 

d 查看内存

 

e 机器码编辑内存

 

u 查看汇编指令

 

t 执行指令

 

a 以汇编指令写内存

 

 

3.demo:

-d 1000:0 //see memory at 1000:0

 

-e 1000:0 b80100 //mov ax,0001

 

-u 1000:0 //see the MOV AX,0001

 

-rcs //see cs

 

-rip //see ip

 

-t  //run

 

 

4.为何mov ax,0001 机器指令是 B80100:

 

参考资料:

8086 opcode:

http://www.arl.wustl.edu/~lockwood/class/cse306/resources/opcodes.html

 

 

以下解答内容转载自:http://www.pcstu.com/program/huibianyuyan/jq/20070213/30526.html

 

机器语言我们只要重点理解一下几个概念:

1. 机器语言指令有操作码(OP)和地址码两部分组成


|_____________OP_______________|__d__|__w__|

|_____________OP_______________|__s__|__w__| <--此格式用于立即寻址方式

在多数操作码中,常使用某些位来指示某些信息:
如图上结构里的: w=1 时 对字来操作
w=0 时 对字节来操作

d值在双操作数指令中才有效
当 d=1 时 有且只有一个寄存器用于目的操作数
d=0 时 有且只有一个寄存器用于源操作数

s=1 时 立即数为8位,但要求扩展成16位数
s=0 时 当指令作字节操作/有16位立即数

由于汇编的指令格式很多,这里我只作一些基本情况介绍,必要时读者可以下载/查阅80x86汇编小站http://www.x86asm.com提供的OPCODES手册来查阅。

2. 寻址方式的机器语言表示:

| mod | reg | r/m |
|_____|_____|_____|_____|_____|_____|_____|

reg 表示寄存器方式,在不包括立即数的双操作数指令的情况下,规定必须有一个操作数在寄存器中,该寄存器由reg字段指定,并与操作码字节中的w位相组合确定的寄存器

mod字段与r/m(register/memory)字段结合在一起确定另一个操作数的寻址方式现在你们下载了80x86汇编小站(http://www.x86asm.com)提供的OPCODES 手册了吗?
下载好了,请解压后打开里面的:opcodes.html 文件,然后熟悉里面的表格:

现在熟悉简单的:
______________________________________________________________________________
表1 <PS:部分资料> rrr : W=0 : W=1 : reg32

000 : AL : AX : EAX

001 : CL : CX : ECX

010 : DL : DX : EDX

011 : BL : BX : EBX

100 : AH : SP : ESP

101 : CH : BP : EBP

110 : DH : SI : ESI

111 : BH : DI : EDI
______________________________________________________________________________
表2 <PS:部分资料> rrr : Index Register
000 : EAX

001 : ECX

010 : EDX

011 : EBX

100 : No Index

101 : EBP

110 : ESI

111 : EDI
______________________________________________________________________________
表3 <PS:部分资料> mmm : Function 11
w=1
000 : DS:[BX+SI]

001 : DS:[BX+DI]

010 : SS:[BP+SI]

011 : SS:[BP+DI] BX

100 : DS:[SI]

101 : DS:[DI]

110 : SS:[BP]

111 : DS:[BX]
______________________________________________________________________________
表4 <PS:部分资料>
oo : Function

00 : If mmm = 110, then a displacement follows the operation; otherwise, no displacement is used

01 : An 8-bit signed displacement follows the opcode

10 : A 16-bit signed displacement follows the opcode

11 : mmm specifies a register, instead of an addressing mode
______________________________________________________________________________
上面的表,你都看明白了吗? 现在我就教你们如何利用这样的表格来把汇编指令翻译机器码

3.指令格式简介

8086所用的16位指令格式:

________ _____________ ________ ________
|操作码| + |mod-reg-r/m| + |位移量| + |立即数|
1~2字节 0~1字节 0~2字节 0~2字节

OK!以上就是基本知识,下面我们来实践吧:

———————————————————————————————————————
问题:

MOV AX,1234H 对应的机器码为:B83412

MOV EBX,0 对应的机器码为:66BB00000000

MOV CL,55H 对应的机器码为: B155

MOV AX,BX 对应的机器码为:8BC3

我在问一下,机器码的数据格式是什么? 好像是 机器指令+操作数(高位存放在地址高位,低位存放在地址低位),但是前面MOV AX,怎么就变成了B8,弄不明白,请指教。

PS: 上面的题目是一个网友问的,现在我来实践一遍给你们看。


———————————————————————————————————————

指令1 -> MOV AX,1234H 对应的机器码为:B83412

解法: 判断-> 这个是8086汇编16位汇编指令格式,并且是立即寻址方式
查表-> 打开opcodes.html文件,找到标题为“Main Instructions”,单击“M”字母,然后对应查看 “MOV Reg,Imm”格式的“OpCode”项为:1011wrrr
再判断-> 由于寄存器是AX, 立即数是1234H,明显是“对字操作”,所以w=1
在查看本文章上面的“表1”,对应的查到rrr的值为000
组合结果-> w=1
rrr=000
1011wrrr=1011 1000B ->B8H
根据“ 3.指令格式简介” -> B8H + |立即数(低位在前高位在后)|= B83412H

PS: "+" 符号不为“加号”

好了,已经解完第一题了,机器码为 B83412H

 

———————————————————————————————————————

指令4 -> MOV AX,BX 对应的机器码为:8BC3

 

解法: 判断-> 这个是8086汇编16位汇编指令格式,并且是寄存器寻址方式
查表-> 打开opcodes.html文件,找到标题为“Main Instructions”,单击“M

”字母,然后对应查看 “MOV Reg,Reg”格式的“OpCode”项为:1000101woorrrmmm
再判断-> 由于寄存器是AX, BX 明显是“对字操作”,所以w=1
在查看本文章上面的“表4”,对应查到oo=11 因为是寄存器寻址方式
在查看本文章上面的“表1”,对应查到rrr的值为000 ,因为当两个操

作数都是寄存器,那么一般要以目的操作数为准
在查看本文章上面的“表3”, 对应查到mmm的值为011 ,因为当两个操作数都是寄存器,那么一般要以源操作数为准
组合结果-> w=1
oo=11
rrr=000
mmm=011
1000101woorrrmmm=1000 1011 1100 0011B ->8BC3H

好了,已经解完第二题了,机器码为8BC3H
———————————————————————————————————————

 

呵呵,不错吧,很简单吧,有了80X86 OPCODES 查询表一切都是那么简单,如果还有什么问题,大家都来这里提问!

剩下的:

指令2 -> MOV EBX,0 对应的机器码为:66BB00000000

指令3 -> MOV CL,55H 对应的机器码为: B155

大家来练练手,注意指令2 需要用到32位指令格式,请查阅相关的80x86汇编语言书籍的机器语言部分,应该有解释的。

指令2的解法,请大家等待,或者大家研究一下,把解法贴出来,给大家参考哦!

 

 

 

参考资料:8086微处理器结构

引用自:http://www.ahzk.net/wlzx/%BA%CF%B9%A4%B4%F3/%CE%A2%BB%FA%D4%AD%C0%ED/weiji/chapter211.htm

 

8086微处理器的结构
1.8086/8088的结构特点
  8086/8088CPU是由两个独立的功能部件组成,即总线接口部件(BIU)和执行部件(EU),如图2-1 所示。这正是8086/8088CPU所具有的,不同于8位CPU的全新结构特点。

图2-1 8086/8088结构特点

(1)BIU
  • BIU的组成:由段寄存(CS、DS、ES、SS)、指令指针(IP)、20位物理地址加法器、6字节指令队列(8088为4字节指令队列)及总线控制逻辑组成。
  • BIU的功能:负责从内存中取指令,送入指令队列,实现CPU与存储器和I/O接口之间的数据传送。
  • BIU的工作过程:根据EU提供的偏移地址及相应段寄存器的内容,将二者送入地址加法器中,从而产生20位的物理地址,对相应存储单元进行读、写操作,也可根据EU的请求对I/O接口进行读/写操作。
(2)EU
  • EU的组成:由通用寄存器(AX、BX、CX、DX、BP、SP、SI、DI)、标志寄存器(FR)、运算器(ALU)和EU控制系统组成。
  • EU的功能:分析指令和执行指令。
  • EU的工作构成:从指令队列头中取出指令,对其进行分析、执行。
[注] 将8086/8088 CPU分成二个独立的功能部件使二者能够并行工作,把取指令工作和分析指令、执行指令工作重叠进行,从而提高CPU的工作效力,加快指令的执行速度。指令 队列可以被看成是一个特殊的RAM,它的工作原理是"先进先出",写入的指令只能存放在队列尾,读出的指令是队列头存放的指令。EU和BIU之间就是通过 指令队列联系起来,多数情况下,BIU在不停地向队列写入指令,而EU每执行完一条指令后,就向队列读取下一条指令。二者的动作既独立,又协调。
2.8086/8088中的寄存器
  8086/8088共含有14个16位寄存器,掌握这些寄存器的名称符号、长度、含义和用法是学习指令系统的基础,对考生掌握指令编写汇编语言程序是非常重要的。8086/8088中的寄存器从功能上可划分成4类。如图2-2 所示:

图2-2 8086/8088中的寄存器

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics