汇编指令与机器码的相互转换【转】

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

1. 机器语言指令有操做码(OP)和地址码两部分组成
机器语言咱们只要重点理解一下几个概念:

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

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

在多数操做码中,常使用某些位来指示某些信息:


如图上结构里的: w=1 时 对字来操做
w=0 时 对字节来操做


d值在双操做数指令中才有效

d=1 时 有且只有一个寄存器用于目的操做数
d=0 时 有且只有一个寄存器用于源操做数
s=1 时 当即数为8位,但要求扩展成16位数
s=0 时 当指令做字节操做/有16位当即数


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


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


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

mod字段与r/m(register/memory)字段结合在一块儿肯定另外一个操做数的寻址方式

如今熟悉简单的:
______________________________________________________________________________
表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汇编语言书籍的机器语言部分,应该有解释的。