五章80868088指令系统课件.ppt

上传人(卖家):晟晟文业 文档编号:3614217 上传时间:2022-09-26 格式:PPT 页数:109 大小:251.50KB
下载 相关 举报
五章80868088指令系统课件.ppt_第1页
第1页 / 共109页
五章80868088指令系统课件.ppt_第2页
第2页 / 共109页
五章80868088指令系统课件.ppt_第3页
第3页 / 共109页
五章80868088指令系统课件.ppt_第4页
第4页 / 共109页
五章80868088指令系统课件.ppt_第5页
第5页 / 共109页
点击查看更多>>
资源描述

1、第五章8086/8088 指令系统C第一节指令格式和寻址方式第一节指令格式和寻址方式C第二节数据传送指令第二节数据传送指令C第三节算术运算指令第三节算术运算指令C第四节逻辑运算指令第四节逻辑运算指令C第五节控制转移指令第五节控制转移指令C第六节字符串指令第六节字符串指令第一节指令格式和寻址方式i一、指令格式一、指令格式i二、指令助记符二、指令助记符i三、寻址方式三、寻址方式i(一)指令地址的寻址方式(一)指令地址的寻址方式i(二)操作数地址寻地方式(二)操作数地址寻地方式一、指令格式指令是计算机用以控制各部件协调动作的命令指令是计算机用以控制各部件协调动作的命令指令字是一种二进制代码,它包括两

2、个基本部分:操作指令字是一种二进制代码,它包括两个基本部分:操作码和地址码。操作码提供的是操作控制信息,指明计算机应码和地址码。操作码提供的是操作控制信息,指明计算机应执行什么性质的操作,如进行执行什么性质的操作,如进行+、-、等;地址码提、等;地址码提供参加运算操作数据的存放地址(即操作数地址)。供参加运算操作数据的存放地址(即操作数地址)。只提供一个操作数地址的指令,称为单操作数指令;提只提供一个操作数地址的指令,称为单操作数指令;提供二个操作数地址的指令,称为双操作数指令;不提供操作供二个操作数地址的指令,称为双操作数指令;不提供操作数地址的指令,称为无操作数指令。数地址的指令,称为无操

3、作数指令。无操作数指令只有操作码部分,它的格式为无操作数指令只有操作码部分,它的格式为 其中其中为操作码。为操作码。这种指令表示只进行某种操作,无需操作数,如控制机这种指令表示只进行某种操作,无需操作数,如控制机器的运行状态,暂停(器的运行状态,暂停(HALTHALT)等,就属于无操作数指令。等,就属于无操作数指令。单操作数指令格式为单操作数指令格式为 其中其中为操作码;为操作码;D D为目标操作数地址,简称目标地址。为目标操作数地址,简称目标地址。这种指令表示对目标地址这种指令表示对目标地址D D中的内容,按操作码中的内容,按操作码规定规定进行操作,结果送目标地址。进行操作,结果送目标地址。

4、双操作数指令格式为双操作数指令格式为 其中,其中,为操作码,为操作码,D D为目标地址,为目标地址,S S为源地址(即作数为源地址(即作数地址)。地址)。这种指令表示对源地址和目标地址中的内容,按操作码这种指令表示对源地址和目标地址中的内容,按操作码规定的操作进行操作,结果送目标地址,即规定的操作进行操作,结果送目标地址,即DDSDDS。D D S在微型机中,一般采用可变字长指令。也就是说,不同在微型机中,一般采用可变字长指令。也就是说,不同的指令用不同长度来表示,但都是字节的整倍数。如一字节、的指令用不同长度来表示,但都是字节的整倍数。如一字节、二字节、三字节和四字节指令等。它们在存储器中分

5、别占有二字节、三字节和四字节指令等。它们在存储器中分别占有14个存储单元,其格式如下:个存储单元,其格式如下:单字节指令:单字节指令:操作码操作码 7 6 5 4 3 2 1 0 双字节指令:双字节指令:第一字节:第一字节:操作码操作码 第二字节:第二字节:操作数或地址操作数或地址 三字节指令:三字节指令:第一字节:第一字节:操作码操作码 第二字节:第二字节:操作数或地址低位操作数或地址低位 第三字节:第三字节:操作数或地址高位操作数或地址高位 或:或:第一字节:第一字节:操作码操作码 第二字节:第二字节:操作码操作码 第三字节:第三字节:操作数或地址操作数或地址 四字节指令:四字节指令:第一

6、字节:第一字节:操作码操作码 第二字节:第二字节:操作码操作码 第三字节:第三字节:操作数或地址地位操作数或地址地位 第四字节:第四字节:操作数或地址高位操作数或地址高位 二、指令助记符机器指令是二进制代码,二进制代码不易辨识和记忆。机器指令是二进制代码,二进制代码不易辨识和记忆。因此,在介绍机器指令时,除非必要情况下用二进制代码,因此,在介绍机器指令时,除非必要情况下用二进制代码,一般情况下使用指令助记符。指令助记符由操作码和操作数一般情况下使用指令助记符。指令助记符由操作码和操作数的助记符号表示。通常操作码用英文单词或英文缩写单词来的助记符号表示。通常操作码用英文单词或英文缩写单词来表示如

7、:表示如:ADD,JP(Jump)等。操作数用表示寄存器存储等。操作数用表示寄存器存储器地址的符号来表示。我们首先来学习操作数部分的符号,器地址的符号来表示。我们首先来学习操作数部分的符号,然后结合指令来学习表示操作码的符号。用助记符来表示的然后结合指令来学习表示操作码的符号。用助记符来表示的指令又称为指令的汇编格式。指令又称为指令的汇编格式。指令中要出现的符号介绍如下:指令中要出现的符号介绍如下:AX,BX,CX,DX 16位通用寄位通用寄存器存器AH,BH,CH,DH,AL,BL,CL,DL 8位通用寄位通用寄存器存器CS,DS,ES,SS 段寄存器段寄存器SP,BP,IP 堆栈指针,基址

8、指针,指令指针堆栈指针,基址指针,指令指针DI,SI 目的,源变址寄存器目的,源变址寄存器Flags 标志寄存标志寄存r r=AX、BX、CX、DX r=AL、BL、CL、DLa(acc)a=AX ALSeg seg=CS、DS、ES、SSSrc(source)、)、dst(dest)源操作数、目的操作数源操作数、目的操作数Count 计数器计数器Oprd 操作数操作数Im 立即数立即数 n 8位位 nn 16位位nnnn 32位位EA 有效地址有效地址三、寻址方式数据和程序在存储器数据和程序在存储器中的位置,称为地址。存中的位置,称为地址。存放指令的地址,称为指令放指令的地址,称为指令地址;

9、存放数据的地址,地址;存放数据的地址,称为操作数地址,简称操称为操作数地址,简称操作地址。作地址。寻找指令地址和操作寻找指令地址和操作数地址的方式,统称为寻数地址的方式,统称为寻址方式。形成指令地址和址方式。形成指令地址和操作数地址的过程,称为操作数地址的过程,称为寻址过程。寻址过程。(一)指令地址的寻址方式(一)指令地址的寻址方式(二)操作数地址寻地方式(二)操作数地址寻地方式(一)指令地址的寻址方式在微机中,指令地址的寻址方式比较简单,通常是在在微机中,指令地址的寻址方式比较简单,通常是在CPU中设置程序计数器中设置程序计数器PC,PC中的内容就是指令地址。中的内容就是指令地址。在一般情况

10、下,程序是顺序执行的,程序在存储器中也在一般情况下,程序是顺序执行的,程序在存储器中也是按顺序存放的。这时,只要将程序计数器中的内容自动递是按顺序存放的。这时,只要将程序计数器中的内容自动递增,就可以形成下一条指令地址。增,就可以形成下一条指令地址。当需要改变程序的执行顺序时,要使用转移指令,由转当需要改变程序的执行顺序时,要使用转移指令,由转移指令给出转移后指令字的起始地址。将此地址送到程序计移指令给出转移后指令字的起始地址。将此地址送到程序计数器,就形成了转移后的地址。然后,程序计数器中的内容数器,就形成了转移后的地址。然后,程序计数器中的内容又自动递增,直到再次发生转移为止。又自动递增,

11、直到再次发生转移为止。(二)操作数地址寻地方式微机在工作时,指令地址在程序执行过程中时自动形成微机在工作时,指令地址在程序执行过程中时自动形成的,但指令所需的操作数地址是随机的,要根据指令的规定的,但指令所需的操作数地址是随机的,要根据指令的规定求得,获得操作数地址的方式,称为操作数寻址方式,有时求得,获得操作数地址的方式,称为操作数寻址方式,有时也把它称为寻址方式。也把它称为寻址方式。在操作数寻址方式中,除了涉及在操作数寻址方式中,除了涉及BP的寻址方式外,一般的寻址方式外,一般寻址均在数据段内(段地址由寻址均在数据段内(段地址由DS提供),在涉及提供),在涉及BP时,则时,则使用堆栈段(段

12、地址由使用堆栈段(段地址由SS提供),在执行串操作时,使用提供),在执行串操作时,使用附加段附加段ES。在各种寻址方式中,以立即数和存储器直接寻在各种寻址方式中,以立即数和存储器直接寻址方式,速度最快,因为此时址方式,速度最快,因为此时8086/8088的执行单元的执行单元EU可可以立即从寄存器中或指令队列中取出操作数,而无须再由总以立即从寄存器中或指令队列中取出操作数,而无须再由总线执行单元计算出有效的线执行单元计算出有效的20位地址,然后再去取操作数。位地址,然后再去取操作数。立即数寻址在指令中直接给出一个常数作为操作数,如:在指令中直接给出一个常数作为操作数,如:MOV AX,200表示

13、将常数表示将常数200送到存储器送到存储器AX中,要注意的是在中,要注意的是在16位操位操作中,直接数的取值范围为作中,直接数的取值范围为32767(7FFFH)到到-32768(8000H),),当为无符号数时则为当为无符号数时则为0-65535(0FFFFH),),对对8位数应为位数应为0-255(OFFH),),符号数为符号数为127(7FH)到到-128(80H)。)。2.寄存器直接寻址指令中的寄存器存放了操作数,如:指令中的寄存器存放了操作数,如:ADD CX,BX表示将表示将BX中的值直接相加,然后送到中的值直接相加,然后送到CX中去。中去。3.寄存器间接寻址在指令中,有操作数的地

14、址,将该地址同左移在指令中,有操作数的地址,将该地址同左移4位后的位后的DS值相加,即可得到值相加,即可得到20位物理地址,从该地址中取出操作位物理地址,从该地址中取出操作数进行指令所要求的操作,这种寻址方法称为直接寻址,通数进行指令所要求的操作,这种寻址方法称为直接寻址,通常该类指令中,操作数的地址用标号表示,例如:常该类指令中,操作数的地址用标号表示,例如:ADD AX、TABLE表示将表示将AX中的值和中的值和TABLE表示的地址中的内容相加,和表示的地址中的内容相加,和放在放在AX中。中。8086/8088按字存放内容时,低字节方在低地址中,按字存放内容时,低字节方在低地址中,高字节跟

15、随其后,方在高地址中。高字节跟随其后,方在高地址中。5.变址寻址将指令中指令的变址寄存器的内容加上偏移值,即成为将指令中指令的变址寄存器的内容加上偏移值,即成为操作的地址,例如:操作的地址,例如:MOV DI,4MOV AX,TABLEDI表示偏移值表示偏移值TABLE加加4(DI的内容)作为操作数地址,的内容)作为操作数地址,取出操作数送取出操作数送AX。这种寻址方式通常用于读写表中的元素,如这种寻址方式通常用于读写表中的元素,如TABLE偏移偏移值表示的首址,加值表示的首址,加4表示将表中的第三个量(表示将表中的第三个量(16位)送位)送AX,读写数组元素也采用此法。读写数组元素也采用此法

16、。6.基址寻址同变址类似,不过这种寻址中使用基址寄存器同变址类似,不过这种寻址中使用基址寄存器BX、BP代替变址寄存器代替变址寄存器DI和和SI。它是将基址寄存器的内容加上偏它是将基址寄存器的内容加上偏移量而作为操作数地址的,例如:移量而作为操作数地址的,例如:MOV AX,BX+6表示表示BX作为基址,距其偏移作为基址,距其偏移6字节的地址便是操作数地字节的地址便是操作数地址,在这种寻址中址,在这种寻址中BX基址对应的段地址在当前数据段中,基址对应的段地址在当前数据段中,若基址是若基址是BP,则操做数在堆栈段内。则操做数在堆栈段内。IBM汇编允许用三种形式指定基址寻址,它们的效果是汇编允许用

17、三种形式指定基址寻址,它们的效果是一样的,如:一样的,如:MOV AX,BX+6 ;标准格式标准格式MOV AX,6BX ;先写偏移值先写偏移值MOV AX,BX+6 ;偏移值写在括号内偏移值写在括号内7.基址变址寻址基址变址寻址时,操作数地址是由一个基址寄存器的内基址变址寻址时,操作数地址是由一个基址寄存器的内容,一个变址寄存器的内容及偏移值(是任选项,也可不用)容,一个变址寄存器的内容及偏移值(是任选项,也可不用)相加和,例如:相加和,例如:MOV AX,6BPSI表示距栈顶表示距栈顶6个字节处作为基址,然后以个字节处作为基址,然后以SI内容为相对内容为相对基址的偏移作为操作地址,这种寻址

18、方式在访问堆栈数组时基址的偏移作为操作地址,这种寻址方式在访问堆栈数组时很有用,如基址为栈顶,则变址寄存器中的值表示堆栈中的很有用,如基址为栈顶,则变址寄存器中的值表示堆栈中的相应元素。相应元素。这种寻址方式也多用于对二维数组的访问,如用这种寻址方式也多用于对二维数组的访问,如用BX作为作为数组的首地址,变址寄存器及偏移值作为数组行和列的值,数组的首地址,变址寄存器及偏移值作为数组行和列的值,依次寻址,就可找到某个二维数组元素。依次寻址,就可找到某个二维数组元素。第二节数据传送指令第二节数据传送指令8086/8088有有92条指令,按其功能可分为条指令,按其功能可分为6个功能组:个功能组:1.

19、数据才传送数据才传送2.算术运算算术运算 3.逻辑运算逻辑运算 4.串操作串操作 5.控制传送控制传送 6.处理器控制处理器控制 数据传送指令又可分为以下七种:数据传送指令又可分为以下七种:(1)通用数据传送指令通用数据传送指令MOV(2)堆栈操作指令堆栈操作指令 (3)交换指令交换指令(4)标志寄存器传送指令标志寄存器传送指令(5)输入输出指令输入输出指令(6)地址目的传送指令地址目的传送指令(7)查表转换指令查表转换指令 这类指令用来在寄存器和存储单元或输入这类指令用来在寄存器和存储单元或输入/输出端口输出端口传送数据或地址,表传送数据或地址,表5.2.1列出这列出这7种指令种指令:汇编格

20、式汇编格式 操作操作MOV dest,source 传送一个字节或字传送一个字节或字PUSH source 压一个字进栈压一个字进栈POP dest 弹一个字进栈弹一个字进栈PUSHF 压标志寄存器进栈压标志寄存器进栈POPF 弹标志寄存器出栈弹标志寄存器出栈XCHG op1,op2 交换两个字节或字交换两个字节或字LAHF 将标志寄存器内容装入将标志寄存器内容装入AH中(装右字节)中(装右字节)SAHF 将将AH寄存器内容存到标志寄存器(右字节)寄存器内容存到标志寄存器(右字节)IN acc,port 从端口输入字节或字到累加器从端口输入字节或字到累加器OUT port,acc 从累加器输出

21、一个字节或字到端口从累加器输出一个字节或字到端口LEA dest,source 装入有效地址,即将存储器操作数偏装入有效地址,即将存储器操作数偏 移地址送目的寄存器移地址送目的寄存器LDS dest,source 将段地址装入将段地址装入DS中,偏移地址装入中,偏移地址装入 目的寄存器目的寄存器LES dest,source 将段地址装入将段地址装入ES中,偏移地址装入目中,偏移地址装入目 的寄存器的寄存器 XLAT 查表转换查表转换、MOV指令MOV指令是最基本的通用传送指令,它把一个字节或一指令是最基本的通用传送指令,它把一个字节或一个字从源传送到目的。这条指令可实现下述操作:个字从源传送

22、到目的。这条指令可实现下述操作:MOV nn,a ;(nn)aMOV a,nn ;a(nn)MOV seg,src ;segsrcMOV dst,seg ;dstsegMOV r,src ;rsrcMOV dst,r ;dstrMOV dst,im ;dstimMOV指令可以在寄存器与存储单元之间,寄存器和寄存指令可以在寄存器与存储单元之间,寄存器和寄存器之间传送字节或字,也可以将一个立即数送寄存器或存储器之间传送字节或字,也可以将一个立即数送寄存器或存储单元,例如:单元,例如:MOV AX,TABLE ;TABLE存储地址传送到存储地址传送到AXMOV TABLE,DX ;从从DX传送到存储

23、地址传送到存储地址MOV ES;BX,AX ;指定段寄存器到指定段寄存器到ES,而不而不用用DSMOV DS,AX ;寄存器间寄存器间16位数传送位数传送MOV DL,AL ;8位寄存器间传送位寄存器间传送MOV CL,30 ;常数送寄存器常数送寄存器MOV TABLE,05H ;常数送存储单元常数送存储单元2、堆栈操作指令目前,微计算机一般都是把内存的一个区域作为堆栈。目前,微计算机一般都是把内存的一个区域作为堆栈。这个堆栈按照后进先出的原则组织一段内存区域,由堆栈指这个堆栈按照后进先出的原则组织一段内存区域,由堆栈指针指出它在存储器中的位置。针指出它在存储器中的位置。8086/8088用段

24、寄存器用段寄存器SS和和堆栈指针堆栈指针SP指示堆栈在内存的位置,这个堆栈长度为指示堆栈在内存的位置,这个堆栈长度为64KB,因此因此SP为为16位指针的单元。位指针的单元。8086/8088规定规定SP始终指向堆始终指向堆栈的顶部,即始终指向最后压入堆栈的信息所在的单元。栈的顶部,即始终指向最后压入堆栈的信息所在的单元。8086/8088的堆栈是下推式,即随着压入堆栈的内容的增的堆栈是下推式,即随着压入堆栈的内容的增加,加,SP的值减小。的值减小。SP的初值可由的初值可由MOV SP,im指令来设定。指令来设定。堆栈操作指令包括入栈指令和出栈指令。堆栈操作指令包括入栈指令和出栈指令。(1)入

25、栈指令)入栈指令 PUSH oprd 入栈指令完成将入栈指令完成将16位的数据送入堆栈的操作,具体入栈位的数据送入堆栈的操作,具体入栈指令如下:指令如下:PUSH r ;(SP)r,SPSP-2PUSH seg ;(SP)seg,SPSP-2PUSH src ;(SP)src,SPSP-2(2)出栈指令出栈指令 POP oprd出栈指令完成将出栈指令完成将16位的数据从堆栈弹出的操作,具体出位的数据从堆栈弹出的操作,具体出栈指令如下:栈指令如下:POP r ;r(SP),SPSP+2POP seg ;seg(SP),SPSP+2POP dst ;dst(DP),SPSP+2入栈时,把一个字从上

26、述操作数传送到已由入栈时,把一个字从上述操作数传送到已由SP指向的堆指向的堆栈顶部,同时修改栈顶部,同时修改SP的值,使的值,使SP指向新的栈项单元。指向新的栈项单元。出栈时,把堆栈顶部的一个字,传送到指定的目标操作出栈时,把堆栈顶部的一个字,传送到指定的目标操作数,同时修改数,同时修改SP的值,使的值,使SP指向新的栈顶单元。指向新的栈顶单元。PUSH和和POP指令提供一个先进后出的堆栈结构,它们用指令提供一个先进后出的堆栈结构,它们用SS栈寄存器来指向栈的段地址,用栈寄存器来指向栈的段地址,用SP堆栈指针来指向栈顶堆栈指针来指向栈顶位置,当执行位置,当执行PUSH指令时,指令时,SP减减2

27、后,将源操作数(一个后,将源操作数(一个字)压入栈内,相反字)压入栈内,相反POP指令则将当时指令则将当时SP所指定的堆栈中的所指定的堆栈中的字取出到目的操作数,然后字取出到目的操作数,然后SP加加2。PUSH和和POP指令提供了一种存储的技巧,例如可用于数指令提供了一种存储的技巧,例如可用于数据交换,将据交换,将DS的值传给的值传给ES,使数据段和附加段指向同一个使数据段和附加段指向同一个段地址:段地址:PUSH DSPOP ES又如在程序中要用到某一寄存器,它的值在程序中某一又如在程序中要用到某一寄存器,它的值在程序中某一段将被改变,而后面又要用到它,且需要它的原先值,可采段将被改变,而后

28、面又要用到它,且需要它的原先值,可采用如下方法:用如下方法:PUSH AX ;将将AX值存入堆栈值存入堆栈 ;AX的值被改变的程序段的值被改变的程序段POP AX ;再取回再取回AX的原先值的原先值(3)PUSHF和和POPF指令指令PUSHF和和POPF是将标志寄存器内容入栈和出栈,这两是将标志寄存器内容入栈和出栈,这两种指令在调用子程序,保存标志寄存器内容时常用到,即在种指令在调用子程序,保存标志寄存器内容时常用到,即在调用前标志寄存器入栈,返回主程序时,恢复其值。另外,调用前标志寄存器入栈,返回主程序时,恢复其值。另外,当标志寄存器当标志寄存器TF位为位为1时,时,8086/8088在每

29、执行一条指令在每执行一条指令后,便执行一条后,便执行一条1型中断指令,即指令执行变成单步方式,型中断指令,即指令执行变成单步方式,这在调试程序时可用到,以便跟踪每条指令执行情况。由于这在调试程序时可用到,以便跟踪每条指令执行情况。由于没有任何一条指令能使没有任何一条指令能使TF变成变成1,但这可用下面的方法实现:,但这可用下面的方法实现:PUSHF ;标志进栈标志进栈POP AX ;标志值送标志值送AXOR AX,0100H ;使使TF位置位置1PUSH AX ;AX进栈进栈 POPF ;将将AX值送到标志寄存器值送到标志寄存器若要恢复若要恢复TF=0,则可将则可将OR AX,0100H换成换

30、成AND AX,0FEFFH来清除来清除TF。3、交换指令具体的指令如下:具体的指令如下:XCHG AXXCHG AX,r ;AX rr ;AX r XCHG r,XCHG r,srcsrc ;r ;r src src XCHG XCHG指令用于交换源操作数和目的操作数的内容,源和指令用于交换源操作数和目的操作数的内容,源和目的操作数可以在寄存器或单元中,但不能同为存储单元,目的操作数可以在寄存器或单元中,但不能同为存储单元,段寄存器也不能用作操作数。下面是寄存器交换段寄存器也不能用作操作数。下面是寄存器交换例如:例如:MOV AXMOV AX,50 50 MOV BX MOV BX,1010

31、 XCHG AX XCHG AX,BX BX ;现在现在AX=10AX=10,BX=50BX=504标志寄存器传送指令LAHF和SAHFLAHF指令是将标志寄存其中标志指令是将标志寄存其中标志CF.PF.AF.ZF.和和SF分别送到分别送到AH的的0.2.4.6.7位位,而而SAHF指令却相反,它是将指令却相反,它是将AH的相应位内容送到标志寄存器的的相应位内容送到标志寄存器的CF、PF、AF、ZF和和SF位。位。5.输入输出指令IN和OUTIN和和OUT指令用来读写指令用来读写I/O口口,8086/8088可寻址的口可寻址的口地址可达地址可达64K个个,口地址可用口地址可用DX或立即数表示或

32、立即数表示,如用立即数如用立即数,则仅能寻址则仅能寻址0-FFH,读写的数据必须从读写的数据必须从AX中接收或传送中接收或传送,例例如如:IN AL,2FH ;从从2FH口输入一个字节到口输入一个字节到ALOUT 5,AL ;将将AL中的数送到中的数送到5口中去口中去MOV DX,3FCH ;3FCH口地址送口地址送DXIN AX,DX ;从从3FCH口读一个字到口读一个字到AX中中这类指令在接口技术中使用较多这类指令在接口技术中使用较多,当读写一个字时当读写一个字时,先是先是低字节低字节,然后是高字节然后是高字节(因为数据总线是因为数据总线是8位位,所以必须分两所以必须分两次读写次读写),如

33、从如从3FCH口读一个字时口读一个字时,实际上从实际上从3FCH口读一个口读一个字节到字节到AL中去中去.然后从然后从3FCH口再读一个字节到口再读一个字节到AH中去。中去。6.地址-目标传送指令8086/8088有三条地址有三条地址-目标传送指令目标传送指令:LEA r,src LDS r,src LES r,src LEA指令将一个储储器中数据的偏移地址送到任一个通用指令将一个储储器中数据的偏移地址送到任一个通用寄存器寄存器.指针寄存器或变址寄存器指针寄存器或变址寄存器,例如例如:LEA BX,TABLEDI 将把将把TABLE+DI的偏移地址送到的偏移地址送到BX中中.LDS指令将从指定

34、的存储器地址中取出一个指令将从指定的存储器地址中取出一个32位的双倍位的双倍字字,将其低将其低16位送到指定的字寄存器位送到指定的字寄存器,而将高而将高16位送到位送到DS,例如例如:LDS BX,ARRAY ARRAY假如为一个双倍字长的字假如为一个双倍字长的字,比如是代表一个物理地比如是代表一个物理地址的变量址的变量,执行此指令后将执行此指令后将ARRAY高二字节表示的段地址送高二字节表示的段地址送入入DS中中,而将其低二字节表示的偏移地址送入而将其低二字节表示的偏移地址送入BX中中,这相当这相当执行了三条指令执行了三条指令:MOV BX,ARRAY MOV AX,ARRAY+2 MOV

35、DS,AX LES指令将段地址送入指令将段地址送入ES中中,其别的功能同其别的功能同LDS.7.查表转换指令XLATXLAT指令可进行查表操作此表可达指令可进行查表操作此表可达256个字节个字节.使用该使用该指令时指令时,将表的起始地址送入将表的起始地址送入BX中中,将表的位移值将表的位移值(即要查表即要查表的位置的位置)送入送入AL中中.。然后执行。然后执行XLAT指令指令,则将查到的值存则将查到的值存入入AL中中.第三节算术运算指令8086/8088有加、减、乘、除四种基本的运算指令,有加、减、乘、除四种基本的运算指令,这些指令可用于字节或字运算,可用于带字号数与无符号数这些指令可用于字节

36、或字运算,可用于带字号数与无符号数的运算。如果是符号数,则用补码表示。大部分指令操作影的运算。如果是符号数,则用补码表示。大部分指令操作影响标志寄存器响应位。算术运算指令如表响标志寄存器响应位。算术运算指令如表5.3.1所示所示8086/8088提供各种矫正操作指令,这些矫枉正操令提供各种矫正操作指令,这些矫枉正操令与二进制算术运算指令配合使用,使得与二进制算术运算指令配合使用,使得8086/8088也能进也能进行十进制算术运算。十进制数不带符号,可用压缩十进制数行十进制算术运算。十进制数不带符号,可用压缩十进制数(BCD),),或非压缩型十进制表示,前者每个字可包含两个或非压缩型十进制表示,

37、前者每个字可包含两个用场用场4位二进制码表示的十进制数,即十进制数的范围为位二进制码表示的十进制数,即十进制数的范围为0099;对非压缩型的数,则一个字节仅表示一个十进制数;对非压缩型的数,则一个字节仅表示一个十进制数即即09,字节的高,字节的高4位在作乘除运算时必须为位在作乘除运算时必须为0,加减时可,加减时可任意。任意。;1 1、加减法运算指令、加减法运算指令 、;2 2、比较指令、比较指令;3 3、INCINC、DNCDNC、NECNEC指令指令;4 4、乘法与除法指令、乘法与除法指令MULMUL、IMULIMUL、DIVDIV、IDIVIDIV;5 5、CBWCBW与与CWDCWD指令

38、指令;6 6十进调整指令十进调整指令汇汇 编编 格格 式式操操 作作ADD dest,sourceADC dest,sourceSUB dest,sourceSBB dest,sourceINC destDEC destNEG destCMP dest,sourceMUL sourceIMUL sourceDIV sourceIDIV sourceCBWCWD加加字字或或字字节节带带进进位位的的字字节节或或字字的的加加法法字字节节或或字字的的减减法法带带借借位位的的字字节节字字的的减减法法字字节节或或字字加加 1字字节节或或字字减减 1对对目目的的操操作作数数取取补补目目的的操操作作数数与与源

39、源操操作作数数比比较较无无符符号号数数字字节节或或字字乘乘法法整整数数(带带符符号号)乘乘法法无无符符号号数数字字节节或或字字乘乘法法整整数数(带带符符号号)除除法法把把字字节节转转换换为为字字把把字字转转换换为为双双字字汇汇 编编 格格 式式操操 作作DAADASAAAAASAAMAAD加加法法十十进进制制调调整整减减法法十十进进制制调调整整加加法法 ASCII 码码调调整整减减法法 ASCII 码码调调整整乘乘法法 ASCII 码码调调整整除除法法 ASCII 码码调调整整1、加减法运算指令 、A加法指令加法指令A带进位加法指令带进位加法指令A减法指令减法指令A带借位减法指令带借位减法指令

40、()、加法指令 ,;,;,;,;()带进位加法指令 ,;,;A D C ,;A D C ,;其中为进位标志的现行值。其中为进位标志的现行值。()减法指令SUB ,;SUB ,;SUB ,;SUB ,;(4)带借位减法指令SBB r,src ;r r src cSBB a,im ;a a im c SBB dst,im ;dst dstimcSBB dst,r ;dst dstrc其中其中c为借位标志的现行值为借位标志的现行值、均是作加减运算的指、均是作加减运算的指令,其功能是源操作数与目的操作数进行相加或相减,而令,其功能是源操作数与目的操作数进行相加或相减,而与的差别是为带进位的加,同样是与

41、的差别是为带进位的加,同样是带借位的减,源操作数可以在寄存器、存储器中或立即数,带借位的减,源操作数可以在寄存器、存储器中或立即数,目的操作数可以在寄存器、存储器中。这些指令运算的结目的操作数可以在寄存器、存储器中。这些指令运算的结突目的操作数中。上述指令可完成位(字节)或位突目的操作数中。上述指令可完成位(字节)或位运算超过位则需多条指令。运算超过位则需多条指令。比如操作数长度大于位的加法,用下面的指令比如操作数长度大于位的加法,用下面的指令 ,;低位相加;低位相加 ,;带低位进位的高位相加;带低位进位的高位相加这两条指令将把和中的位数加到和这两条指令将把和中的位数加到和中的位数中,县后面的

42、一条指令,还将低位的进中的位数中,县后面的一条指令,还将低位的进位也一起加上,结果在和中。又比如操作数长度大位也一起加上,结果在和中。又比如操作数长度大于位的减法,可用下面的指令于位的减法,可用下面的指令 ,;低位相减;低位相减 ,;带低位借位的高位相减;带低位借位的高位相减作减法时,不仅和相减,还要减去上条作减法时,不仅和相减,还要减去上条指令执行相减后的借位,最后的结果低位将在中,指令执行相减后的借位,最后的结果低位将在中,高位将在中。高位将在中。这类指令不能用于存储单元容的加减,也不能用立即数这类指令不能用于存储单元容的加减,也不能用立即数作为目的操作数。它们的运算结果均将影响标志寄存器

43、的作为目的操作数。它们的运算结果均将影响标志寄存器的、和。、和。、比较指令比较指令完成两个操作数加减,使结果反映到标志位上,比较指令完成两个操作数加减,使结果反映到标志位上,并不送回相减的差值。指令格式如下:并不送回相减的差值。指令格式如下:CMP ,;CMP ,;CMP ,;CMP ,;指令是比较指令,用于目的操用数指令是比较指令,用于目的操用数 与源操用数与源操用数 进行比较,即相减,类似于指令,但不同的是,该指进行比较,即相减,类似于指令,但不同的是,该指令不保存相减的结果,因而不变操作数令不保存相减的结果,因而不变操作数 ,它仅影响标志,它仅影响标志寄存器,表寄存器,表.示出了比较指令

44、影响标志位的情况。示出了比较指令影响标志位的情况。目目的的操操作作数数与与源源操操作作数数比比较较CFZFSFOF源源目目的的-00/10/1源源目目的的0100带带符符号号操操作作数数源源目目的的-00/10/1源源目目的的00-源源目目的的01-无无符符号号操操作作数数源源目目的的10-一般在使用指令时,后面总是跟着一条条件转移一般在使用指令时,后面总是跟着一条条件转移命令,跟据比较结果标志位的情况决定程序的执行方向,由命令,跟据比较结果标志位的情况决定程序的执行方向,由表表.可看出:可看出:两位比较要等用零标志位两位比较要等用零标志位ZFZF,若若ZFZF1 1则表示相等。则表示相等。不

45、带符号数比较大小时,当借位标志不带符号数比较大小时,当借位标志CFCF1 1时,说明源时,说明源目的,否则目的源。目的,否则目的源。带符号数比较大小时,用符号标志带符号数比较大小时,用符号标志SFSF与溢出与溢出OFOF半加(异半加(异或)来判断,若或)来判断,若SFOFSFOF1 1,则源目的,否则源目的。则源目的,否则源目的。例如:例如:CMP AXCMP AX,8000H 8000H ;AX AX 与与80008000H H相比较相比较JL AGAIN JL AGAIN ;如如AXAX小于小于80008000H H则转则转AGAINAGAIN当当CMPCMP执行后,若执行后,若SFOFS

46、FOF时,(即时,(即SFCFSFCF1 1),),即源即源目的,则转移。目的,则转移。3、INC、DNC、NEC指令INCINC和和DECDEC指令仅有一个操作数,其操作可以是位或指令仅有一个操作数,其操作可以是位或位的通用寄存器值,也可以是存储单元中的数,将位的通用寄存器值,也可以是存储单元中的数,将执行操作数加的操作,指令将执行操作数减的操执行操作数加的操作,指令将执行操作数减的操作,结果仍送回操作的位置中去。这两条指令操作结果均不作,结果仍送回操作的位置中去。这两条指令操作结果均不影响影响CFCF标标.。NECNEC指令为求补指令,它是从零中减去操作数,形成指令为求补指令,它是从零中减

47、去操作数,形成2 2 的补的补,操作数仅有一个,可以是寄存器的破除储存单元的数。操作数仅有一个,可以是寄存器的破除储存单元的数。例如:例如:NEC DATANEC DATADATADATA存储单元内设有数为存储单元内设有数为0000010100000101,则执行该指令后,则执行该指令后,其内容就变为其内容就变为1111101111111011。当从一个立却数中减去寄存器或存储器中的数时,不能当从一个立却数中减去寄存器或存储器中的数时,不能用用SUBSUB指令,但可以减数变补,然后再和其相加得到减的果,指令,但可以减数变补,然后再和其相加得到减的果,如立即数为如立即数为100100,则可用如下

48、命令:,则可用如下命令:NEG ALNEG ALADD AL,100ADD AL,1004、乘法与除法指令MUL、IMUL、DIV、IDIV80888088提供乘法与除法指令,具体指令格式如下:提供乘法与除法指令,具体指令格式如下:MULMUL src src ;AXAL;AXAL*srcsrc(无符号数无符号数)MULMUL src src ;DX;DX、AXAXAXAX*srcsrc(无符号数)无符号数)IMULIMUL src src ;AXAL;AXAL*srcsrc(符号数)符号数)IMULIMUL src src ;DX;DX、AXAXAXAX*srcsrc(符号数)符号数)DIV

49、DIV src src ;ALAX/;ALAX/srcsrc,AH,AH余数余数DIVDIV src src ;AXDX.AX/;AXDX.AX/srcsrc,DX,DX余数余数IDIVIDIV src src ;ALAX/;ALAX/srcsrc,AH,AH余数(符号数)余数(符号数)IDIVIDIV src src ;AXDX ;AXDX、AX/AX/srcsrc,DX,DX余数(符号数)余数(符号数)MULMUL是无符号数乘法指令,是无符号数乘法指令,IMULIMUL是带符号数的乘法指令是带符号数的乘法指令(整数乘法),它们都可以完成字节与字节相乘,字与字的(整数乘法),它们都可以完成字

50、节与字节相乘,字与字的相乘,这些乘法指令均认为目的操作数在相乘,这些乘法指令均认为目的操作数在ALAL和和AXAX中,源操作中,源操作数由指令指出,当数由指令指出,当1616位乘法时,位乘法时,3232位的乘积规定高位的乘积规定高1616位在位在DXDX中,低中,低1616位在位在AXAX中。中。在在8 8位或位或1616乘法若扩展部分乘法若扩展部分AHAH或或DXDX为为0 0则则CF=0CF=0,OF=0OF=0,反反之之CF=1CF=1。OF=1OF=1。IMULIMUL是带符号数乘法是带符号数乘法 ,执行情况同,执行情况同MULMUL,不过在不过在1616位或位或3131位乘积中,包括

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 办公、行业 > 各类PPT课件(模板)
版权提示 | 免责声明

1,本文(五章80868088指令系统课件.ppt)为本站会员(晟晟文业)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!


侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|