程序控制指令PPT课件_第1页
程序控制指令PPT课件_第2页
程序控制指令PPT课件_第3页
程序控制指令PPT课件_第4页
程序控制指令PPT课件_第5页
已阅读5页,还剩54页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

-,1,程序控制指令,控制转移指令分为:转移指令循环控制指令调用和返回指令中断指令,-,2,转移指令的实质:改变IP(或CS)的内容。所有转移指令不会影响标志位。分为无条件转移和条件转移两种。,3.2.转移指令,-,3,(1)无条件转移指令-JMP本指令无条件转移到指定的目标地址,以执行从该地址开始的程序段。根据设置CS、IP的方法,JMP指令分成4种情况。段内直接转移:JMPdisp指令中给出的8/16位的位移量加到IP。CS保持不变。段内间接转移:JMPreg/memreg/mem中的16位偏移地址送IP。CS保持不变。段间直接转移JMPsegment:offset指令中给出的16位的段和16位的偏移地址送到CS和IP。段间间接转移JMPmem32mem32中的16位的段和16位的偏移地址送到CS和IP。,-,4,转移的目标地址由指令直接给出。指令中给出的目标地址实际上是一个相对于IP的位移量:位移量转移范围汇编语言中格式8位-128+127JMPSHORTOPRD16位-32768+32767JMPNEARPTROPRD例:JMP0120H;直接转向0120HJMPSHORTLP;转向LPJMPNEARPTRBBB;转向BBB由于是段内转移,故转移后CS内容保持不变,段内直接转移,-,5,段内间接转移转移的目标地址由寄存器或存储单元的内容给出。例1:JMPSI若(SI)=1200H,则指令执行后,(IP)=1200H,于是转向代码段的偏移地址1200H处开始执行。注意:目标地址以段内偏移的形式给出,而不是相对于IP的位移量,所以它是一个16位的操作数。,-,6,例2:JMPBX+DI设指令执行前:(DS)=3000H,(BX)=1300H,(DI)=1200H,(32500H)=2350H;则指令执行后:(IP)=2350H在汇编语言中,段内间接寻址通常写成:JMPWORDPTRBX+DI表示所取得的目标地址是一个字。,-,7,段间直接转移在指令中直接给出要转移到的目的段地址和偏移地址。例:JMP2000H:1000H执行时,(IP)1000H,(CS)2000H注:直接地址为符号地址时,段间直接转移指令中的符号地址前应加操作符FARPTR。例:JMPFARPTRfar_label其中的far_label为远类型的标号。,-,8,转移的目的地址(段和偏移)在两个相邻的字存储单元中。例如:JMPDWORDPTRSI设指令执行前:(DS)=4000H,(SI)=1212H,(41212H)=1000H,(41214H)=4A00H则指令执行后:(IP)=1000H,(CS)=4A00H于是转到4B000H处开始执行指令。例中的DWORDPTR表示转移地址是一个双字。,段间间接转移,-,9,4000,1212,+),41212,DS,SI,00,10,00,4A,41212412134121441215,1000,4A00,IP,CS,段间间接转移操作示意图,11111111,11101100,JMPDWORDPTRSI的机器码,DS:SI,-,10,条件转移指令可实现程序的条件分支。条件转移指令根据标志位的状态来决定是否进行分支转移。格式:JXXlabel;xx为条件名称缩写指令的转移范围为-128+127字节。主要的条件转移指令参见p142表3-7。,(2)条件转移指令-JXX,-,11,根据单个标志位设置的条件转移指令JB/JC;低于,或CF=1,则转移JNB/JNC/JAE;高于或等于,或CF=0,则转移JP/JPE;奇偶标志PF=1(偶),则转移JNP/JPO;奇偶标志PF=0(奇),则转移JZ/JE;结果为零(ZF=1),则转移JNZ/JNE;结果不为零(ZF=0),则转移JS;SF=1,则转移JNS;SF=0,则转移JO;OF=1,则转移JNO;OF=0,则转移,-,12,这类指令主要用来判断两个数的大小。一般指令序列为:CMPdist,src;比较Jxxlabel;根据比较结果转移判断无符号数的大小JA高于则转移(distsrc)转移条件为:CF=0ZF=0JNA/JBE低于或等于则转移(distsrc)转移条件为:CF=1ZF=1,根据组合条件设置的条件转移指令,-,13,JG;大于则转移(distsrc)转移条件为:(SFOF=0)ZF=0JGE;大于或等于则转移(distsrc)转移条件为:(SFOF=0)ZF=1JL;小于则转移(distsrc)转移条件为:(SFOF=1)ZF=0JLE;小于或等于则转移(distsrc)转移条件为:(SFOF=1)ZF=1,判断有符号数的大小,-,14,根据CX内容来决定是否转移的转移指令JCXZlabel若(CX)=0,则转移到label处开始执行。,-,15,条件转移指令举例:以十六进制数形式显示BX中的内容。MOVBX,1234HMOVCH,4;CH做循环计数器ROT:MOVCL,4;CL做移位计数器ROLBX,CL;将最高4位移到低4位MOVAL,BLANDAL,0FH;取出低4位ADDAL,30H;转换为ASCII码CMPAL,39H;与9比较JBEDISP;若(AL)9,则转显示ADDAL,7;若(AL)9,再加7转为A-FDISP:MOVDL,AL;(DL)字符MOVAH,2INT21H;显示输出DECCH;4个十六进制数显示完否?JNZROT;没有,循环MOVDL,48H;HMOVAH,2INT21H;最后显示H,-,16,看P86例3.8,-,17,3.3.循环控制指令,用在循环程序中以确定是否要继续循环。循环次数通常置于CX中。转移的目标应在距离本指令-128+127的范围之内。循环控制指令不影响标志位。,-,18,(1)LOOP格式:LOOPlabel操作:(CX)-1CX;若(CX)0,则转至label处执行;否则退出循环,执行LOOP后面的指令。注:LOOP指令与下面的指令段等价:DECCXJNZlabel,-,19,(2)LOOPZ(LOOPE)格式:LOOPZlabel操作:(CX)-1CX;若(CX)0ZF=1,则转至label处执行;否则退出循环,执行LOOP后面的指令。(3)LOOPNZ(LOOPNE)格式:LOOPNZlabel操作:(CX)-1CX;若(CX)0ZF=0,则转至label处执行;否则退出循环,执行LOOP后面的指令。,-,20,例1:给1A000H开始的256个内存单元均减去1,若发现某个单元减为0则立即退出循环,其后的单元不再减1。程序段如下:(逻辑地址为1A00:0H)MOVAX,1A00HMOVDS,AX;1A00H段MOVDI,-1MOVCX,256GOON:INCDIDECBYTEPTRDILOOPNZGOONHLT,-,21,例2:在8000H开始的长度为1000字节的字符串中查找S,若找到,把其偏移地址记录在ADDR中,否则ADDR单元置为0FFFFH。MOVDI,8000HMOVCX,1000MOVAL,SMOVADDR,0FFFFHGOON:SCASBLOOPNZGOONJNZDONEDECDIMOVADDR,DIDONE:HLT,-,22,看P94例3.10P96例3.13P102例3.16,-,23,3.4串操作指令,串:顺序放在内存中的一组相同类型的数据。串操作:对串中的元素进行相同的操作。串操作的寻址方式:源操作数指针DS:SI(DS可超越)目的操作数指针ES:DI每次串操作后:串操作指令自动修改SI和DI字节1,字2。DF标志决定。(注意:退出串操作后,指针指向最后操作的元素的下一个元素)可完成两个存储单元之间的传送和比较操作(也仅是串指令可以),-,24,重复前缀有的串操作指令前面可加上重复前缀REP。当使用REP前缀时,该指令重复执行,重复执行次数由CX决定(带有REP前缀的串操作指令每执行一次,CX自动减1)。重复前缀包括:REPCX0时重复执行REPE/REPZCX0ZF=1时重复执行REPNE/REPNZCX0ZF=0时重复执行,-,25,串指令使用的一般方法,设置源串地址,设置目标串地址,设置串长度,设置操作方向DF,串指令,MOVSI,源串首地址(或LEASI,源串),MOVDI,目的串首地址(或LEADI,目的串),MOVCX,串长度,CLD(或STD),串指令,-,26,指令执行的操作为:MOVSB:(ES):(DI)(DS):(SI)SI1,DI1MOVSW:(ES):(DI+1)(DI)(DS):(SI+1)(SI)SI2,DI2指令也可写成:MOVSdest,src但要求:src用DS:SI寻址,dest用ES:DI寻址传送是字节还是字,由操作数的类型决定,串传送指令MOVSB/MOVSW,-,27,串传送指令使用举例,用串传送指令实现200个字节的数据传送:LEASI,MEM1LEADI,MEM2MOVCX,200CLDREPMOVSBHLT,-,28,串比较指令CMPSB/CMPSW,指令执行的操作为:CMPSB:(DS):(SI)-(ES):(DI)SI1,DI1CMPSW:(DS):(SI+1)(SI)-(ES):(DI+1)(DI)SI2,DI2指令也可写成:CMPSdest,src比较的结果只反映在标志位上,串本身无变化。本指令可用来检查两个串是否相等。,-,29,串扫描SCASB/SCASW,执行的操作:对字节:(AL)(ES):(DI)DI1对字:(AX)(ES):(DI1)(DI)DI2搜索指令执行的仍是比较(减法)操作,结果只影响标志位。要搜索的关键字放在AL(字节)或AX(字)中。本指令用于在串中查找指定的信息。,-,30,SCAS指令加上重复前缀后,可对串进行连续扫描比较:若前缀为REPZ,则表示比较结果相等且(ZF=1)且串未结束(CX0),则继续比较。若前缀为REPNZ,则表示比较结果不相等(ZF=0)且串未结束(CX0)就继续比较。,-,31,例:在ES段的偏移1000H开始处存有10个ASCII码。搜索E,若找到则记下搜索次数及存放地址,并在屏幕上显示Y;若未找到则显示N。(见右图)在屏幕上显示一个字符的指令段如下:(参见附录C.3)MOVDL,MOVAH,2INT21H实现题目要求的程序段见下页:,1000H,41,42,43,44,45,46,A,B,C,D,F,.,ES段,E,-,32,MOVDI,1000H;(DI)串偏移地址MOVCX,0AH;(CX)串长度MOVAL,E;搜索关键字=ECLD;从低地址到高地址进行搜索REPNZSCASB;若未找到,继续搜索JZFOUND;找到,转至FOUNDMOVDL,N;串中无E,(DL)NJMPDONE;转至DONEFOUND:DECDI;指针回退MOVADDR,DI;ADDRE的地址SUBDI,1000HMOVNUM,DI;NUM搜索次数MOVDL,Y;(DL)YDONE:MOVAH,2INT21H;显示字符HLT,-,33,执行的操作为:对字节:(AL)(DS):(SI)SI1对字:(AX)(DS):(SI+1)(SI)SI2串装入指令通常不加重复前缀。LODSB等价于:LODSW等价于:MOVAL,SIMOVAX,SIINCSIINCSIINCSI,串装入指令LODSB/LODSW,-,34,36H,32H,39H,31H,STRING1,STRING2,38H,35H,36H,33H,被加数,加数,数据段,8,5,6,2,9,1,6,3,SUM,结果,.,.,07H,07H,02H,06H,-,35,下面要求将和的结果送显示,为此,要先化成ASCII码再送显示,程序段如下:LEASI,SUM+3;(SI)SUM+3MOVCX,4;(CX)和长度STD;置DF=1,减量修改SIMOVAH,02;(AH)功能号LP:LODSB;取BCD码至AL,且(SI)(SI)-1ADDAL,30H;转换为ASCII码MOVDL,AL;(DL)字符INT21H;显示字符DECCXJNZLP,-,36,指令的操作为:对字节:(ES):(DI)(AL)DI1对字:(ES):(DI+1)(DI)(AX)DI2本指令用于把一块存储区域填充成某一初始值(即对存储区进行初始化)。存储区域的首地址要预先设置到ES:DI中。要存储到串中的数据要预先存到AL(AX)中。,串存储指令STOSB/STOSW,-,37,例1:把从A000H开始的2KB内存单元清零。程序段如下:MOVDI,0A000HMOVAX,0MOVCX,1024CLDREPSTOSW,-,38,例2:把1000H开始的100个存储单元填入ASCII码2AH(*)。程序段如下:MOVDI,1000H;首地址MOVAL,2AH;*MOVCX,100;重复执行100次CLD;增量修改DIREPSTOSB,-,39,3.5子程序设计过程调用和返回指令,过程(子程序)一段具有特定功能的,供其它程序调用的公用程序。特点调用子程序时,IP(CS)的内容被压入堆栈栈顶。从子程序返回时,栈顶的内容又被弹出到IP(CS)。子程序执行结束后一般均要返回调用程序。一次定义,多次调用;可带参数调用,以完成不同的功能。优点程序代码短,结构清晰,便于编程、调试、修改和阅读。两条相关指令:子程序调用指令CALL子程序返回指令RET,-,40,一般格式:CALLsub;sub为子程序的入口根据子程序入口的寻址方式,子程序调用有四类。段内直接调用子程序的偏移地址直接由CALL指令给出。格式:CALLnear_procCALL执行时,它首先将IP内容压栈,然后把指令中给出的位移量加到IP上。注:汇编以后的调用地址是相对于CALL的下一条指令的位移量。例:CALL0120H;子程序偏移地址由指令给出,(1)调用指令CALL,-,41,位移量由汇编程序在汇编时进行计算,如下例:CS:0102CALL0120H;3字节CS:0105则位移量为:0120-0105H=001BH于是CALL0120H的机器码为E81B00CS:0102E8CS:01031BCALL0120HCS:010400CS:0105,-,42,子程序的偏移地址在寄存器或存储器中。格式:CALLmem16/reg16CALL执行时,它首先将IP内容压栈,然后把指定的寄存器/存储器的内容送入IP。例:CALLBX;子程序地址由BX给出CALLWORDPTRSI;子程序地址在存储器中,段内间接调用,-,43,IPHIPL,代码段,数据段,CALLWORDPTRSI指令的操作图示:假定:(DS)=8000H,(SI)=1200H,81200H,81201H,-,44,子程序的段地址和偏移地址直接由CALL指令给出。格式:CALLfar_proc;far_proc为远过程的地址指令的操作为:CS内容压栈IP内容压栈CS段地址IP偏移地址例:CALL2000H:1000HCALLTIMER;TIMER为远过程,段间直接调用,-,45,子程序的段和偏移地址为存储器的连续4个单元中的内容。格式:CALLmem32指令的操作为:SP(SP)-2(SP)+1,(SP)(CS);CS压栈CS(mem32+2)SP(SP)-2(SP)+1,(SP)(IP);IP压栈IP(mem32)例:CALLDWORDPTRDI调用地址在DI,DI+1,DI+2,DI+3四个存储单元中。低字内容为偏移地址,高字内容为段地址。,段间间接调用,-,46,CALL,代码段,数据段,IPHIPL,CSHCSL,DI,DI+1,DI+2,DI+3,段间间接调用示意图,CALLDWORDPTRDI,-,47,例:下面的程序执行后,(AX)=?(DX)=?CS:2000HMOVAX,2012H2003HMOVCX,200CH2006HPUSHCX2007HCALL4000H200AHADDAX,BX200CHADDAX,DX200EHHLTCS:4000HMOVBX,200AHPOPDXRET,-,48,段内返回指令RET的操作为:恢复子程序执行前IP的内容。段间返回指令RET的操作为:恢复子程序执行前IP和CS的内容。另有一种带立即数的返回指令“RETn”,其中n为偶数,表示从栈顶弹出地址后另外丢弃的字节数。例:RET4;返回后再丢弃栈顶的4个字节,(2)返回指令RET,-,49,4.中断指令,8086/8088CPU在程序中允许安排一条中断指令来引起一个中断过程,这种中断叫内部中断,或叫软中断。被中断的指令地址处称为“断点”。有关中断的详细情况将在第六章讨论。中断指令共有三条:(1)INTn执行类型n的中断服务程序,N=0255(2)INTO执行溢出中断的中断服务程序(3)IRET从中断服务程序返回调用程序,-,50,(1)INTn,格式:INTn说明:n4=向量地址。该向量地址中的内容即为中断服务程序入口地址(段:偏移),入口地址也称为“中断向量”。,0000:n4,XXH,XXH,YYH,YYH,中断服务程序入口的偏移地址(IP),中断服务程序入口的段地址(CS),中断类型码n=0255,内存,中断向量,-,51,INT指令的操作:将FLAGS压入堆栈;将INT指令下一条指令的地址压栈(即把CS和IP的内容压栈);取中断服务程序入口地址送入CS和IP。INT指令只影响IF和TF,对其余标志位无影响INT指令可用于调用系统服务程序,如INT21H,-,52,INT指令的操作例:,INT21H,IPL,IPH,CSL,CSH,SP=1200,FLAGSL,FLAGSH,SP=11FA,执行INT21H指令后,保护断点,堆栈

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论