版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第二节8086/8088的指令系统8086/8088的指令系统中共有92种基本指令。可以分成6个功能组:1. 数据传送(Datatransfer)2. 算术运算(Arithmetic)3. 逻辑运算和移位指令(Logic&Shift)4. 串操作(Stringmanipulation)5. 控制转移(ControlTransfer)6. 处理器控制(ProcessorControl)1介绍指令系统使用的符号:八位寄存器:AH,AL,BH,BH,BL,CH,CL,DH,DL十六位通用寄存器:AX,BX,CX,DX,SP,BP,SI,DI堆栈指针 SP指令指针 IP(或PC)标志位 Flags目的和源变址寄存器 DI,SI段寄存器 CS,DS,ES,SS通用寄存器 rAL或AX(取决于操作数长度)acc28086/8088指令助记符表(自学)38086/8088指令助记符表(续)4
第二部分8086/8088指令系统一、数据传送指令(Datatransfer)(一)通用传送指令(GeneralPurposeTransfer)(二)输入输出指令(InputandOutput)(三)目的地址传送指令(Address-objecttransfer)(四)标志传送指令(Flagregistertransfer)5一. 数据传送指令功能:负责把数据、地址或立即数传送到寄存器或存储单元。特点:它是计算机最基本、最重要的一种操作,使用比例最高。种类(分四种):
通用传送指令包括:MOV,PUSH,POP,XCHG,XLAT。输入输出指令指令包括:IN,OUT。目的地址传送指令包括:LEA,LDS,LES
标志传送指令包括:LAHF,SAHF,PUSHF,POPF
除SAHF和POPF指令外,对标志位没有影响。6(一)通用传送指令(GeneralPurposeTransfer)8088提供方便灵活的通用的传送操作,适用于大多数操作数。通用传送指令(除了XCHG以外)是唯一允许以段寄存器为操作数指令。通用传送指令包括: 1、MOV(Movement) 2、PUSH(Pushwordontostack) POP(Popwordoffstack)
3、XCHG(Exchange) 4、XLAT(Translate)71. MOV dest, src;(dest)(src) 目的 源 目的源功能:
把一个字节(B)或一个字(W)操作数由源传送至目的。实现: 寄存器寄存器/存储器之间; 立即数寄存器/存储器 寄存器/存储器段寄存器之间的数据传送。8
具体说,通用数据传送指令能实现:①CPU内部寄存器之间的数据的任意传送
(除了码段寄存器CS和指令指针IP以外)。
段寄存器之间不能传送。例: MOVDL,CH ;8位寄存器8位寄存器 MOVAX,DX ;16位寄存器16位寄存器 MOVSI,BP MOVDS,BX ;通用寄存器段寄存器
MOVAX,CS ;段寄存器通用寄存器9立即数传送至CPU内部通用寄存器组(AX、BX、CX、DX、BP、SP、SI、DI)。
用于给寄存器赋初值。
不能直接给段寄存器赋值例:
MOVCL,04H ;立即数8位寄存器
MOVAX,03FFH ;立即数16位寄存器思考:为什么加WORDPTR,BYTEPTR?不加对吗?
MOVWORDPTR[SI],057BH;立即数存储器
MOVBYTEPTRMEM,5;立即数存储器10CPU内部寄存器(除CS和IP外)
与存储器(所有寻址方式)之间数据传送。 可以实现一字节或一个字的传送。
存储单元之间不能直接传送
例:
MOVMEM,AX ;累加器存储器,直接寻址
MOVMEM,DS ;段寄存器存储器,直接寻址
MOVDISP[BX],CX ;寄存器存储器,变址寻址
MOVAX,DISP[SI]
;存储器累加器,变址寻址
MOVDS,MEM
;存储器段寄存器,直接寻址
MOVCX,DISP[BX][SI]
;存储器累加器,相对基址加变址11
注意:(1)不能用一条MOV指令实现以下传送。
存储单元之间的传送
MOVMEM2,MEM1错。
MOVAX,MEM1 MOVMEM2,AX对。
立即数送段寄存器
例:MOVDS,2000H错。MOVAX,2000 HMOVDS,AX对。12
段寄存器之间的传送
MOVES,DS;错
MOVAX,DS MOVES,AX;对。注意CS和IP的使用
CS和IP不能作为目标操作数,CS可以作为源操作数。例: MOVCS,AX;错
MOVAX,CS;对。
MOVIP,AX;错
MOVAX,IP;对。13(2)段地址的默认 BX、SI、DI间址默认段地址为DS, BP间址默认段地址SS。(3) 凡是遇到给SS赋值指令,系统自动禁止外部中断,执行本条指令和下条指令,恢复对SS寄存器赋值前的中断开放情况。 这样做为了允许程序员连续用两条指令分别对SS和SP寄存器赋值,同时又防止堆栈空间变动过程出现中断。 *在修改SS和SP的指令之间不要插入其他指令。(4) 所有通用传送指令不影响标志位 (除SAHF、POPF以外)。14
MOV指令应用例:实现将AREA1开始的100个数据传送到AREA2开始的单元。……AREA1:AREA2:100个数据15分析题意:
①可以用200条MOV指令来完成100个数据传送,指令操作重复,每个数据传送后的地址是变化的。②可以利用循环, 但每循环一次要修改地址(源地址和目的地址),必须把地址放在寄存器当中,用寄存器间接寻址来寻找操作数.16得到如下程序:
…
MOVSI,OFFSETAREA1 MOVDI,OFFSETAREA2 MOVCX,100AGAIN: MOVAL,[SI] MOV[DI],AL
INCSI ;修改地址指针 INCDI ;修改地址指针 DECCX ;修改个数 JNZAGAIN
…17
MOV指令的字节数、时钟周期数、CPU与内存间传送次数字节例时钟数M传送到CPU次数MOV指令操作数AXMMAX10(14)13MOVCOUNT[DI],AXRR10(14)13MOVAX,TEMP22MOVDS,BXMRRM8(12)+EA12~4MOVBP,STAK_TOP9(13)+EA12~4MOVCOUNT[BX][SI],CXimR(段寄存器除外)42~3MOVCL,2imM10(14)+EA13~6MOVwordptr[BP],5HR段R16(CS、IP除外)22MOVES,CXMOVBP,SSMR段R段M8(12)+EA12~4MOVDS,SEG_BASE9(13)+EA12~4MOV[BX]SEG_SAN,CS18表中:(1)时钟数——执行指令所需的时钟周期数, 直接决定了指令的执行时间。时钟数决定因素:
决定于是字节操作还是字操作;
若是内存操作数,决定于寻址方式
(还要加上内存操作数的寻址时间)。表中b()的含义:
b--字节操作时钟数()--字操作时钟数19计算EA需要的时钟数:如下表所示: (若段超越,再加两个时钟周期)20(2)指令字节数:
指令字节数与寻址方式有关。通常操作码占二个字节;立即寻址:立即数增加1-2个字节数;操作数在内存中:
直接寻址:直接地址为1-2个字节,总的指令长3-4个字节;寄存器间接寻址(没有位移量):2个字节;变址寻址或者相对基址加变址:都有1-2字节的位移量, 指令字节数为2-4个字节。21(3)传送次数: 指执行指令时,内存与CPU之间数据传送的次数。凡是立即数→寄存器或寄存器之间的传送无此传送数。凡是寄存器与存储器之间传送次数为1。222.PUSH(Pushwordontostack)POP(Popwordoffstack)这是两条堆栈操作指令。(1)先介绍一下什么是堆栈,为什么需要堆栈 堆栈——按照先进后出原则组织的一段内存区域,特点:下推式的(规定堆栈设置在堆栈段内)改变SP的内容,
随着推入堆栈内容增加,SP的值减少。先进后出工作原则(LastInFirstOut简称LIFO)
堆栈在内存中的情况:
23堆栈在内存中的情况:可以用一条立即数传送指令给SP赋值,确定SP在SS段中的初始位置。例:设:(SS)=9000H,堆栈段为64KBMOVSP,0E200H ;(SP)=0E200H则:整个堆栈段的物理地址范围为:
90000H~9FFFFH
栈顶的物理地址为:9E200H堆栈在内存中的情况如右图所示:堆栈在内存中的情况24堆栈用途:
存放CPU寄存器或存储器中暂时不使用的数据,使用数据时将其弹出;调用子程序,响应中断时都要用到堆栈。调用子程序(或过程)或发生中断时要保护断点的地址,子程序或中断返回时恢复断点。25主程序子程序:子程序:在一个实际程序中,有些操作要执行多次,把要 重复执行(subroutine)操作编为子程序。 也常把一些常用的操作标准化、通用化的子程序。主程序(Mainprogram)——往往要调用子程序或处理 中断,暂停主程序,执行子程序或中断服务程序。26调用子程序时需保留内容:①调用子程序:将下条指令地址即IP值保留下来 (8088中码段寄存器CS和指令指针IP),才能保证子程序执行完后准确返回主程序继续执行。②执行子程序时,通常用到内部寄存器,执行结果会影响 标志位,必须在调用子程序之前将现状保护起来。③子程序嵌套或子程序递归(自调自)保留许多信息,而且保证正确返回(且后进先出)。
后保留先取出原则(即LIFO-LASTInFirstout)。27注意:SP——堆栈指针,始终指向栈顶。 SP初值用MOVSP,im来设定。下边详细说明一下堆栈用途:28存放CPU寄存器或存储器中暂时不使用的数据,
使用数据时将其弹出:
PUSHAX ;将(AX)入栈(AX)(AX)29使用数据时将其弹出: POPBX30调用子程序(或过程)或发生中断时要保护断点的地址,子程序或中断返回时恢复断点。子程序嵌套断点地址压入和弹出情况31(2)堆栈操作指令(堆栈操作指令有两条):
入栈指令 格式:PUSHsrc ;(SP)(SP)-2 ((SP)+1,(SP))(src)
把一个字从源操作数由SP指向堆栈顶部。 操作如:PUSHAX出栈指令 格式:POPdest ; (dest)((SP)+1,(SP)) (SP)(SP)+2把现行SP所指向堆栈顶部的一个字指定的目的操作数,同时进行修改堆栈指针的操作。 操作如:POPBX32应用时注意:堆栈操作都按字操作。
PUSH,POP指令的操作数可能有三种:寄存器(通用寄存器,地址指针,变址寄存器),段寄存器(CS除外,PUSHCS合法,POPCS非法),存储器。
执行PUSH指令,(SP)-2(SP),
低字节放在低地址,高字节放在高地址。 随着推入堆栈内容增加,堆栈就扩展,SP的值减少, 但SP总是指向栈顶,堆栈工作原则后进先出。
PUSH,POP指令应该成对使用,保持堆栈原有状态。堆栈最大容量即为SP的初值与SS之间的差。33堆栈应用举例:
例:用BP的基址指令代替POP指令 …MOVBP,SPPUSHAXPUSHBXPUSHCX …MOVCX,[BP-6]
MOVBX,[BP-4]MOVAX,[BP-2] …ADDSP,6例:压入堆栈的内容与弹出内容顺序相反…PUSH AXPUSHBXPUSHCX…POPCXPOPBXPOPAX 343、交换指令(Exchange)格式:XCHGdest,src ;(dest)(src)执行操作:
把一个字节或一个字的源操作数与目的操作数相交换。可以实现:寄存器之间 寄存器和存储器之间注意:
存储器之间不能交换,两个操作数中必须有一个在寄存器中;段寄存器不能作为一个操作数;允许字或字节操作,不影响标志位。35应用举例:
XCHGBL,DL XCHGAX,SI XCHGCOUNT[DI],AX
XCHG[BX],[DI] (错) XCHGDS,AX(错)36XLAT(Translate)换码指令:该指令不影响标志位。格式:XLATstr_table
;(AL)←((BX)+(AL))
或XLAT
str_table——表格符号地址(首地址), 只是为了提高可读性而设置,汇编时仍用BX。
37XLAT指令使用方法:先建立一个字节表格;
表格首偏移地址存入BX;
需要转换代码的序号(相对与表格首地址位移量)存入AL;(表中第一个元素的序号为0)
执行XLAT指令后,表中指定序号的元素存于AL中。
(AL)为转换的代码。38XLAT指令应用:若把字符的扫描码转换成ASCII码;或数字0~9转换成7段数码所需要的相应代码(字形码)等就要用XLAT指令。例:内存的数据段中有一张十六进制数字的ASCII码表。
首地址为:Hex_table,欲查出表中第10个元素(‘A’)39执行指令序列:MOVBX,OFFSETHex_tableMOVAL,0AHXLATHex_table假设: (DS)=F000H, Hex_table=0040H (AL)=0AH执行XLAT以后:(AL)=41H=(F004AH), 即“A”的ASCII码。30H31H32H...39H41H42H...46H...Hex_tableHex_table+1Hex_table+2Hex_table+0AHHex_table+0BHHex_table+0FH'F''B''A''9''1''2''0'16进制数的ASCII码表40(二)输入输出指令(InputandOutput)输入输出指令共两条:
1、IN(Inputbyteorword)
2、OUT(Outputbyteorword)
输入指令用于CPU从外设端口接受数据,
输出指令用于CPU向外设端口发送数据。无论接受还是发送数据,必须通过累加器AX(字)或AL(字节),又称累加器专用传送指令。
输入、输出指令不影响标志位。41每个外设要占几个端口:数据口,状态口和控制口。42信息交换要通过端口,在IBMPC机里,可以配接许多外部设备,每个外设与CPU之间交换数据,状态信息和控制命令,每一种信息交换都要通过一个端口来进行。端口数:外部设备最多有65536个I/O端口。 A0~A15译码形成。端口号:端口号(即外设端口地址)为0000H~FFFFH。PC机仅使用A0~A9译码形成I/O口地址,即1024H个口地址 端口号:0000H~03FFH其中:A9=1,表示扩充槽上的口地址。43长格式:端口号中前256个端口(0~FFH),可以直接写在指令中,这就是长格式。端口号代替指令中的PORT,机器指令用二字节表示,第二字节就是端口号。短格式:当端口号≥256时,只能使用短格式,必须先把端口号放到DX寄存器中。不需要用任何段寄存器来修改它的值。441、IN(Inputbyteorword)输入指令格式:INacc,port;(acc)(port)具体形式有四种: INAL,data8;端口地址8位,输入一个字节 INAX,data16;端口地址16位,输入一个字 INAL,DX ;端口地址16位,输入一个字节 INAX,DX ;端口地址16位,输入一个字必须通过累加器AX(字)或AL(节)输入数据。452、OUT(Outputbyteorword)输出指令格式:OUTport,acc ;(port)(acc)具体形式有四种:OUTdata8,AL;端口地址8位,输出一个字节 OUTdata16,AX;端口地址16位,输出一个字 OUTDX,AL;端口地址16位,输出一个字节OUTDX,AX;端口地址16位,输出一个字必须通过累加器AX(字)或AL(节)输出数据。46例1:实现(29H)(28H)→(DATA_WORD) INAX,28H MOVDATA_WORD,AX例2:从端口3FCH送一个字到AX寄存器 MOVDX,3FCH INAX,DX;(AL)←(3FCH), (AH)←(3FDH)
例3:实现将(AL)→(05H) OUT5,AL;(05H)←(AL)47(三)目的地址传送指令(Address-objecttransfer)8086/8088提供三条:
地址指针写入指定寄存器或寄存器对指令。 1、LEA(LoadEffectiveAddress) 2、LDS(LoadpointerusingDS) 3、LES(LoadpointerusingES)481、LEA(LoadEffectiveAddress)格式:LEAreg16,mem16;EA(reg16)功能:加载有效地址,用于写近地址指针。把指令中指定的存储器操作数有效地址装入指定的寄存器。例:设(BX)=0400H,(SI)=003CH LEABX,[BX+SI+0F62H]执行指令后:EA=(BX)+(SI)+0F62H=0400H+003CH+0F62H=139EH(BX)=139EH49注意:设 (DS)=3000H BUFFER=1000H (31000H)=0040H(1)LEA指令与MOV的区别 LEABX,BUFFER;(BX)=1000H MOVBX,BUFFER;(BX)=0040HLEA指令与MOV等价 LEABX,BUFFER ;(BX)=1000H MOVBX,OFFSETBUFFER;(BX)=1000H50(2)LEA指令中的目标寄存器必须是16位的通用寄存器,
源操作数必须是一个存储器。(3)请思考下列指令的正、误 LEADX,BETA[BX][SI] LEADX,AX512、LDS(LoadpointerusingDS)格式:LDSreg16,mem32 ;(reg16)←(EA) (DS)←((EA)+2))功能:将指令指定32位地址指针送指令指定寄存器和DS。将指令指定mem32单元的前两个单元内容(16位偏移量)装入指定通用寄存器,把后两个单元内容(段地址)装入到DS段寄存器。用于写远地址指针。52例:假设:(DS)=C000H指令: LDSSI,[0010H]执行指令后:(SI)=0180H(DS)=2000H
533、LES(LoadpointerusingES)格式:LESreg16,mem32 ;(reg16)←(EA) (ES)←((EA)+2))功能:把源操作数指定的4个相继字节送指令指定的寄存器 及ES寄存器中。此指令常常指定DI寄存器。将指令指定mem32单元的前两个单元内容(16位偏移量)装入指定通
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- SBS防水卷材标准化施工流程
- 施工重难点分析措施
- 施工现场疫情应急处置措施
- 重点、难点、特殊部位施工技术保证措施
- 铝合金模板施工安全文明保障措施
- 共同出资投资摄影馆合伙协议
- 财产信托合同样板
- 买卖股份协议书范本
- 钢框架结构施工人员培训方案
- 工程建设合同中的风险控制策略
- 电信基站UPS系统维护与改造方案
- 公司保安员培训内容
- 客服人员仪容仪表培训
- 第三方汽车物流运输合同(3篇)
- JJF(京) 3012-2021 触针式电动轮廓仪校准规范
- 抗体药物研发
- 2024年冀教版小学六年级上学期期末英语试卷及解答参考
- 辽宁省大连市2023-2024学年高三上学期双基测试(期末考试) 地理 含答案
- 安全环保职业健康法律法规清单2024年
- 语文版2024年六年级上册语文文言文阅读理解真题
- 2024年江苏省无锡惠山经济开发区招聘14人历年高频难、易错点500题模拟试题附带答案详解
评论
0/150
提交评论