第 指令系统学习.pptx
《第 指令系统学习.pptx》由会员分享,可在线阅读,更多相关《第 指令系统学习.pptx(133页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、4.1 指令的基本概念和指令格式 机器指令:指挥计算机完成某种操作的命令。从计算机组成的层次结构来说,计算机指令有机器指令、伪指令和宏指令之分。指令格式如下:操作符OPD,OPSOPD:目的操作数OPS:源操作数第1页/共133页4.2 指令寻址方式4.2.1 寻址方式的基本概念4.2.2 与数据有关的寻址方式4.2.3 I/O端口寻址方式返回本章首页返回本章首页第2页/共133页4.2.1 寻址、寻址方式的概念 指令中操作数字段实质上是指出操作数存放于何处。一般来说,操作数可以跟随在指令操作码之后,称为立即数;操作数也可以存放在CPU内部的寄存器中,称为寄存器操作数。绝大多数的操作数存放在内
2、存储器中,称为存储器操作数。指令指定操作数的位置,即给出地址信息,在执行时需要根据这个地址信息找到需要的操作数。这种寻找操作数的过程称为寻址,而寻找操作数的方法称为寻址方式。第3页/共133页4.2.2 与数据有关的寻址方式 1.立即寻址 立即寻址方式中,指令操作码和操作数都在存储器代码段中。汇编格式:n(n为立即操作数,是用8位或16位二进制补码表示的有符号数)功能:操作数存放在存储器,指令下一单元的内容为立即操作数n。图形表示如右:第4页/共133页【例4.14.1】【例2.5】MOV AX,10执行后(AX)=?该例中源操作数为立即寻址方式,立即数为10,存放在指令的下一单元。图形表示:
3、执行:10AX执行后:(AX)=000AH 返回本节第5页/共133页2.寄存器寻址寄存器寻址寄存器寻址方式的操作数在指令指明的寄存器中。汇编格式:R 其中R表示寄存器名。功能:操作数直接存放在寄存器R中。图形表示:R 指令操作数第6页/共133页【例4.24.2】下列程序执行后,(AX)=?,(BX)=?MOV AX,1234H MOV BX,5678H ADD AX,BX该程序中MOV指令为数据传送指令操作符,ADD指令为加法指令操作符,三条指令皆为双操作数指令。第一、二条指令AX、BX皆为目的操作数地址,为寄存器寻址方式。第三条指令中,AX为目的操作数地址,BX为源操作数地址。源地址和目
4、的地址皆为寄存器寻址方式。第7页/共133页图形表示:执行:1234HAX5678HBX(AX)+(BX)AX执行后:(AX)=68ACH,(BX)=5678H返回本节第8页/共133页3.存储器寻址如果操作码所需操作数存放在内存储器中,则指令中需要给出操作数的地址信息。为了提高程序的灵活性,8086指令系统提供了多种存储器寻址方式(1)直接寻址(2)寄存器间接寻址(3)寄存器相对寻址(4)基址变址寻址(5)关于段跨跃前缀第9页/共133页(1)直接寻址直接寻址汇编格式:含有变量的地址表达式。段寄存器名:EA。功能:指令下一字单元的内容是操作数的偏移地址EA。图形表示:第10页/共133页【例
5、4.34.3】【例4.3】寄存器和存储器内容为:(AX)=1212H,BUF为数据段定义的变量,其偏移地址是2000H,(DS)=3000H,(32000H)=4545H。执行指令:MOVAX,BUF执行后:(AX)=?图形表示:执行:(32000H)AX执行后:(AX)=4545H返回本节第11页/共133页(2)寄存器间接寻址寄存器间接寻址 寄存器间接寻址方式中,寄存器的内容为操作数的偏移地址EA,操作数在存储器中。汇编格式:R 功能:操作数存放在存储器,寄存器R存放操作数的偏移地址EA。第12页/共133页寄存器间接寻址示意图:例如:MOV AX,BX若(DS)2000H,(BX)100
6、0H,物 理 地 址 20000H 1000H 21000H。指 令 执 行 前,(AX)2030H,(21000H)0A0H,(21001H)50H,指令执 行 后,(AX)50A0H,(21000H)0A0H,(21001H)50H。指令执行情况如下:第13页/共133页偏移地址偏移地址EA计算方法如下:计算方法如下:EA=SISI作间址寄存器。DIDI作间址寄存器。BX BX作间址寄存器。BP BP作间址寄存器。第14页/共133页执行指令:MOV AX,BP 执行后:(AX)=?,(BP)=?,(SS)=?,(20030H)=?图形表示如下:【例【例4.44.4】寄存器和存储器内容分别
7、为:】寄存器和存储器内容分别为:(AXAX)=0=0,(,(BPBP)=0030H=0030H,(,(SSSS)=2000H=2000H,(,(20030H20030H)=1234H=1234H返回本节第15页/共133页(3)寄存器相对寻址寄存器相对寻址 寄存器相对寻址方式是在指令中给定一个基址寄存器(或变址寄存器)名和一个8位或16位的相对偏移量,两者之和作为操作数的有效地址。对BX、SI、DI这三个间址寄存器,指示的是数据段中的数据,而用BP作间址寄存器,则指示的是堆栈段中的数据。汇编格式:XR(X表示位移量,是8位或16位二进制补码表示的有符号数)。功能:操作数存放在存储器,寄存器R的
8、内容加位移量X为操作数的偏移地址EA。第16页/共133页偏移地址EA计算方法如下:第17页/共133页【例4.54.5】设执行前:(AX)=0040H,(BX)=0030H,(DS)=2000H,(20036H)=0050H 执行指令:ADD 6BX,AX执行后:(AX)=?,(BX)=?,(DS)=?,(20036H)=?图形表示如下:第18页/共133页执行:(执行:(20036H)+(AX)20036H执行后:(执行后:(AX)=0040H,(,(BX)=0030H,(DS)=2000H,(,(20036H)=0090H。返回本节第19页/共133页(4)基址变址寻址基址变址寻址 基址
9、变址寻址方式是在指令中给出一个基址寄存器名和一个变址寄存器名,两者内容之和作为操作数的有效地址。基址寄存器为BX或BP,变址寄存器为SI或DI,但指令中不能同时出现两个基址寄存器或两个变址寄存器。如果基址寄存器为BX,则段寄存器使用DS;如果基址寄存器用BP,则段寄存器用SS。汇编格式:BR+IR 功能:操作数存放在存储器,BR的内容加IR的内容加位移量X是操作数的偏移地址EA。第20页/共133页操作数偏移地址EA计算方法如下返回本节第21页/共133页【例4.64.6】例 如 MOV AL,BX SI(MOV AL,BXSI)若指令执行前,(DS)1000H,(BX)0010H,(SI)0
10、002H,(10012H)45H则 EA(BX)(SI)0012H,PA(DS)10HEA10012H指令执行后(AL)45H。返回本节第22页/共133页(5)跨段问题跨段问题 按前述规定:若选用BP作间址基址寄存器、变址寄存器或基址寄存器,则操作数在堆栈段,操作数的物理地址PA由堆栈段寄存器SS的内容左移4位与偏移地址EA相加后形成;否则,操作数在数据段,操作数的物理地址PA由数据段寄存器DS的内容左移4位与偏移EA相加后形成。该规定为系统默认状态。当要否定默认状态,到非约定段寻找操作数时,必须用跨段前缀指明操作数的段寄存器名。汇编格式:段寄存器名:操作数地址。功能:段寄存器名指明操作数属
11、哪个段。第23页/共133页【例4.74.7】跨段前缀示例。MOVAX,DS:BP MOVCX,SS:SI 该例中,DS:,SS:均为跨段前缀,此时默认状态无效,操作数的物理地址PA由段寄存器内容左移4位加偏移EA形成。上述2条指令的源操作数物理地址分别为:PA1 =(DS)左移4位+BPPA2 =(SS)左移4位+SI返回本节第24页/共133页4.2.3 I/O端口寻址方式 8086CPU采用独立编址的I/O端口,可以最多访问64K个字节端口或32K个字端口,用专门的IN指令和OUT指令访问。I/O端口寻址只用于这两种指令中。寻址方式有如下两种。1.直接端口寻址在指令中直接给出端口地址,端
12、口地址一般采用2位十六进制数,也可以用符号表示,这种寻址方式为直接端口寻址。因此,直接端口寻址可访问的端口数为0255个。例如:IN AL,25H2.寄存器间接端口寻址如果访问的端口地址值大于255,则必须用I/O端口的间接寻址方式。所谓间接寻址,是指把I/O端口的地址先送到DX中,用DX作间接寻址寄存器,而且只能用DX寄存器。例如:MOV DX,378H OUT DX,AL第25页/共133页4.3 80864.3 8086指令系统 包括数据传送类指令、算术运算类指令、位操作类指令、串操作类指令、控制转移类指令、处理机控制类指令。后几节将分别介绍这些指令的语句格式和功能。4.3.1 数据传送
13、类指令 4.3.2 算术运算类指令 4.3.3 逻辑运算与移位类指令 4.3.4 串操作类指令 4.3.5 控制转移类指令 第26页/共133页4.3.1 数据传送类指令1 通用数据传送指令2 累加器专用传送指令3 地址传送指令4 标志寄存器传送指令返回本章首页返回本章首页第27页/共133页1 1 通用数据传送指令(1)传送指令MOV(2)堆栈指令PUSHPOP(3)数据交换指令XCHG第28页/共133页(1)传送指令MOV语句格式:MOV OPD,OPS功 能:将 源 操 作 数 传 送 入 目 的 地 址,源 地 址 内 容 不 变。即(OPS)OPD。下图4.1描述了MOV指令在传送
14、数据时允许传送的路径及类型。第29页/共133页图图4.1 MOV指令所允许的数据传送路径及类型指令所允许的数据传送路径及类型第30页/共133页MOV指令的形式有如下几种:1)从通用寄存器到通用寄存器 MOV reg1,reg22)立即数传送到通用寄存器 MOV reg,data 3)通用寄存器和存储单元之间 MOV mem(reg),reg(mem)4)立即数传送到存储单元MOV mem,data5)段寄存器与通用寄存器间的数据传送 MOV seg,reg 或 MOV reg,seg 6)段寄存器与存储单元间的数据传送MOV seg,mem 或 MOV mem,seg 第31页/共133页
15、【例4.84.8】存储器与寄存器间数据传送。MOV AX,BUF ;BUF是变量,源操作数为直接寻址MOV BH,DI ;源操作数为寄存器间接寻址MOV DI,ES:3SI ;源操作数为变址寻址,使用跨段前缀MOV BP,3BX+SI;源操作数为基址加变址寻址MOV BUFA,DL;BUFA是一字节变量MOV BP,AX;使用SS段寄存器MOV DS:BP,DL;使用跨段前缀MOV BUF,DS;BUF是个字变量MOV ES,BUF第32页/共133页2 2数据交换指令XCHGXCHG语句格式:XCHG OPD,OPS功 能:将 源 地 址 与 目 的 地 址 中 的 内 容 互 换。即(OP
16、D)OPS,(OPS)OPD。【例4.9】寄存器与存储器之间数据交换。MOV AX,5678H;(AX)=5678HMOV BX,0FFFFH;(BX)=0FFFFHXCHGAX,BX;(AX)=0FFFFH,(BX)=5678H第33页/共133页(2 2)堆栈操作指令1)进栈指令PUSH2)出栈指令POP第34页/共133页1 1)进栈指令PUSHPUSH语句格式:PUSH OPS功能:将寄存器、段寄存器或存储器中的一个字数据压入堆栈,堆栈指针减2。即:(SP)SP(OPS)158SP(SP)SP(OPS)70SP第35页/共133页2 2)出栈指令POPPOP语句格式:POP OPD功能
17、:将栈顶元素弹出送至某一寄存器、段寄存器(除CS外)或存储器,堆栈指针加2。从POP指令功能可看出,该指令为PUSH指令的逆过程。即:(SP)(OPD)70(SP)+SP (SP)(OPD)158(SP)+SP返回本节第36页/共133页2.2.累加器专用传送指令(1)输入/输出指令(2)XLAT查表指令 第37页/共133页1 1)输入指令ININ输入指令用来从指定的外设寄存器取信息送入累加器。它有四种形式:语句格式:INAL,PORT 功能:(PORT)AL语句格式:INAX,PORT 功能:(PORT)AX语句格式:INAL,DX 功能:(DX)AL语句格式:INAX,DX 功能:(DX
18、)AL第38页/共133页2 2)输出指令OUTOUT输出指令用来把累加器的内容送往指定的外设存储器,它有四种形式:语句格式:OUTPORT,AL 功能:(AL)PORT语句格式:OUTPORT,AX 功能:(AX)PORT语句格式:OUTDX,AL 功能:(AL)DX语句格式:OUTDX,AX 功能:(AX)DX返回本节第39页/共133页(2 2)查表转换指令 XLATXLAT语句格式:XLAT OPS或XLAT功能:将(BX)为首址(AL)为位移量的字节存储单元中的数据送AL寄存器。即(BX+AL)AL。返回本节第40页/共133页3 3 地址传送指令(1)传送有效地址指令 LEA(2)
19、传送有效地址及数据段首址指令LDS(3)传送有效地址及附加数据段指令LES第41页/共133页(1 1)传送有效地址指令 LEALEA语句格式:LEA OPD,OPS功能:主存按源地址的寻址方式计算偏移地址,将偏移地址送入指定寄存器。【例4.10】主存偏移地址的获取。MOV BX,0100H;(BX)=0100HMOV SI,0210H;(SI)=0210HLEA BX,1234BX+SI;(BX)=1544H第42页/共133页(2 2)传送有效地址及数据段首址指令LDSLDS语句格式:LDS OPD,OPS功能:将主存中指定字单元数据送入指定存储器,下一字单元数据送DS寄存器。第43页/共
20、133页(3 3)传送有效地址及附加数据段指令LESLES语句格式:LES OPD,OPS功 能:将 主 存 某 字 单 元 内 容 送 指 定 寄 存 器。即(OPS)OPD,(OPS+2)ES。返回本节第44页/共133页4 4 标志寄存器传送指令(1)标志送AH指令LAHF(2)AH送标志指令SAHF(3)标志寄存器进栈指令PUSHF(4)标志寄存器出栈指令POPF第45页/共133页(1 1)标志送AHAH指令LAHFLAHF语句格式:LAHF功能:将标志寄存器的低8位送入AH寄存器。即(FLAGS)7-0AH。该指令的执行对标志位无影响。【例4.11】标志寄存器传送。执行前:(FLA
21、GS)=0485H,(AX)=0FFFFH执行指令:LAHF第46页/共133页(2 2)AHAH送标志指令SAHFSAHF语句格式:SAHF功 能:将 AH的 内 容 送 入 标 志 寄 存 器 的 低 8位,高 8位 不 变。即(AH)FLAGS7-0.。从该指令功能可看出,SAHF为LAHF的逆过程。第47页/共133页(3 3)标志寄存器进栈指令PUSHFPUSHF语句格式:PUSHF功 能:将 标 志 寄 存 器 的 内 容 压 入 堆 栈。即(FLAGS)(SP)。第48页/共133页(4 4)标志寄存器出栈指令POPFPOPF功能:将栈顶内容弹出送入标志寄存器中。即(SP)FLA
22、GS。POPF指令与PUSHF指令互为逆过程。【例4.12】将标志寄存器的单步标志TF置位。PUSHF;(FLSGS)(SP)POP AX;(SP)AXOR AX,0100H;设置D8=TF=1PUSH AX;(AX)(SP)POPF;(SP)FLAGS,即(AX)FLAGS返回本节第49页/共133页4.3.2 算术运算类指令1 加法类指令2 减运算指令3 乘运算指令4 除运算指令5 BCD码调整指令返回本章首页返回本章首页第50页/共133页1 加法指令加法指令(1)不带进位加法指令ADD(2)带进位加指令ADC(3)加1指令INC第51页/共133页(1)不带进位加指令ADD语句格式:A
23、DD OPD,OPS功能:将目的操作数与源操作数相加,结果存入目的地址中,源地址的内容不改变。即(OPD)+(OPS)OPD。第52页/共133页(2)带进位加法指令ADC语句格式:ADC OPD,OPS功能:将目的操作数加源操作数再加低位进位,结果送目的地址。即(OPD)+(OPS)+CF OPD。【例4.13】无符号双字加法运算。MOVAX,4652H;(AX)=4652HADDAX,0F0F0H;(AX)=3742H,CF=1MOVDX,0234H;(DX)=0234HADCDX,0F0F0H;(DX)=0F325H,CF=0返回本节第53页/共133页(3)加1指令 INC语句格式:I
24、NC OPD功能:将目的操作数加1,结果送目的地址。即(OPD)+1OPD。INC指令是一个单操作数指令,操作数可以是寄存器或存储器操作数。如:INC BX,即(BX)+1BX。加1指令可用于对计数器和地址指针进行调整。第54页/共133页2 减运算指令减运算指令(1)不带借位减法指令SUB(2)带借位减指令 SBB(3)减1指令DEC(4)求补指令NEG(5)比较指令 CMP第55页/共133页(1)不带借位减法指令SUB语句格式:SUB OPD,OPS功能:目的操作数减源操作数,结果存于目的地址,源地址内容不变。即(OPD)(OPS)OPD【例4.14】减法运算。MOVAX,5678H;(
25、AX)=5678HSUBAX,1234H;(AX)=4444HMOVBX,3354H;(BX)=3354HSUBBX,3340H;(BX)=0014H第56页/共133页(2)带借位减指令 SBB语句格式:SBB OPD,OPS功能:目的操作数减源操作数再减低位借位CF,结果送目的地址。即(OPD)(OPS)CF OPD第57页/共133页(3)减1指令DEC语句格式:DEC OPD 功能:将目的操作数减1,结果送目的地址。即(OPD)1OPD。DEC指令是一个单操作数指令,操作数可以是寄存器或存储器操作数。如:DEC CX。即(CX)1CX。减1指令DEC也一般用于对计数器和地址指针的调整。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 指令系统学习 指令系统 学习
限制150内