欢迎来到天天文库
浏览记录
ID:11936744
大小:5.90 MB
页数:100页
时间:2018-07-15
《微机原理与接口技术复习资料》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、微机原理与接口技术——复习资料(第三章,第四章)安庆师范大学物理电气与工程学院电子信息科学与技术2班邹方玉微机原理与接口技术第三章8086的寻址方式和指令系统§3-18086的寻址方式概述l计算机的指令包括:操作码+操作数↓↓操作的性质操作的对象↓存放寄存器、存储器、I/O端口地址、立即数(由寻址方式决定)l寻址方式:指令中说明操作数所在地址的方法。l指令分类:单操作数、双操作数、无操作数。(双操作数指令形式:操作码目的操作数,源操作数)u各种寻址方式指令执行速度不同:l操作数在寄存器中指令执行速度快:在CPU内部立即执行;l操作数在指令队列中(立即数寻址)指令执行速度较快;l
2、操作数在存储器中指令执行速度较慢:通过总线与CPU交换数据。uCPU进行读/写存储器的操作:1把一个偏移量送到BIU,计算出20位物理地址;2执行总线周期存取操作数。寻址方式举例:u8086指令的寻址方式类型一、立即寻址方式(ImmediateAddressing)l含义:操作数是立即数(即8位或16位常数),直接包含在指令中。l特点:翻译成机器码时,立即数是指令的一部分,紧跟在操作码之后存放在代码段内。在取出指令的同时也就取出了操作数,立即有操作数可用,所以称之为立即寻址。16位数:高字节→代码段的高地址单元,低字节→低地址单元;l作用:常用于给寄存器赋初值。例MOVCX,2
3、A50H解:将立即数2A50H送到CX寄存器中。(又例:MOVCL,20H)l注意:①立即数可以送到寄存器、一个存储单元(8位)、两个连续的存储单元(16位)中去;②立即数只能作源操作数,不能作目的操作数;③以A~F打头的数字出现在指令中时,前面必须加数字0。以免与其它符号相混淆(如:0AF22H)。二、寄存器寻址方式(RegisterAddressing)l含义:操作数包含在寄存器中,寄存器的名称由指令指定。l特点:16位操作数:寄存器可以AX、BX、CX、DX、SI、DI、SP和BP等。8位操作数:寄存器AH、AL、BH、BL、CH、CL、DH和DL。l作用:寄存器之间传递
4、数据。例:MOVDX,AX解:(AX)送到DX寄存器中。(AX内容不变)(又例:MOVBL,AL)l注意:源操作数的长度必须与目的操作数一致。(注:以下寻址方式下,指令的操作数在存储器中,要先求物理地址才能获得操作数。)三、直接寻址方式(DirectAddressing)l含义:存储单元的有效地址EA(即:操作数的偏移地址)直接由指令给出。l特点:有效地址存放在代码段中(指令的操作码之后),而该地址单元中的数据总是存放在存储器中。操作数的物理地址=16×DS+EAl作用:实现对存储单元的读/写操作。例MOVAX,[2000H]解:设DS=3000H;(32000H)=1234H
5、由指令得:EA=2000H(16位逻辑地址)物理地址=16×3000H+2000H=32000H(20位,20根地址线)则:AX=1234H指令执行过程如图所示。(注:如用AL替代AX,则AL=34H)l注意:ØDS:默认的段寄存器;Ø指令中有效地址的表示:[立即数],以便与立即数相区别;Ø关于段超越前缀:有效地址前用“:”(称为修改属性运算符)修改运算属性。可对代码段(CS)、堆栈段(SS)或附加段(ES)寄存器直接寻址。例:MOVAX,ES:[3000H];(物理地址=16×ES+3000H)l关于符号地址:用来代替数值地址,即给存储单元起个名字。例:AREA1DW2000
6、H;伪指令定义………MOVAX,AREA1;或:MOVAX,[AREA1]解:如右图所示,DS=3000H时,AX=1234H例:AREA1EQU2000H;伪指令定义………MOVAX,AREA1解:AX=2000H四、寄存器间接寻址方式(RegisterIndirectAddressing)l含义:操作数的有效地址放在寄存器中。l特点:使用寄存器:基址寄存器BX、基址指针寄存器BP,变址寄存器SI、DI。操作数的物理地址=16×DS+BX/SI/DI或=16×SS+BPl作用:有效地址可以存放在寄存器中。例MOVBX,[SI]解:设:DS=1000H,SI=2000H,(12
7、000H)=318BH则:物理地址=16×DS+SI=10000H+2000H=12000H指令执行后,BX=318BH,指令执行过程如图所示。l注意:Ø寄存器名称外必须加方括号,以区别寄存器寻址方式;Ø段超越前缀用来从默认段以外的段中取得数据;例MOVBX,ES:[SI]Ø关于默认段:指定寄存器BX、SI或DI,默认操作数存放在数据段DS中;(DS:BX,SI,DI)指定寄存器BP,默认操作数存放在堆栈段SS中;(SS:BP)五、寄存器相对寻址方式(RegisterRelativeAddr
此文档下载收益归作者所有