自制讲义 微机原理ppt课件第7讲.ppt

上传人:牧羊曲112 文档编号:1551357 上传时间:2022-12-04 格式:PPT 页数:69 大小:1.17MB
返回 下载 相关 举报
自制讲义 微机原理ppt课件第7讲.ppt_第1页
第1页 / 共69页
自制讲义 微机原理ppt课件第7讲.ppt_第2页
第2页 / 共69页
自制讲义 微机原理ppt课件第7讲.ppt_第3页
第3页 / 共69页
自制讲义 微机原理ppt课件第7讲.ppt_第4页
第4页 / 共69页
自制讲义 微机原理ppt课件第7讲.ppt_第5页
第5页 / 共69页
点击查看更多>>
资源描述

《自制讲义 微机原理ppt课件第7讲.ppt》由会员分享,可在线阅读,更多相关《自制讲义 微机原理ppt课件第7讲.ppt(69页珍藏版)》请在三一办公上搜索。

1、,第3章 8086的寻址方式和指令系统,H,串处理指令,H,字符串 一系列存放在存储器中的字或字节数据,字符串长度可达64K字节。字符串元素 组成字符串的字节或字。每种字符串指令对字符串元素只进行同一种操作。字符串操作指令 对字符串进行的传送、比较、扫描、存储及装入等5种操作。,相关概念,H,源串 起始地址(或末地址)为DS:SI。源串允许使用段超越前缀来修改段地址。目的串 起始地址(或末地址)为ES:DI。目的串不允许使用段超越前缀修改ES。如果要在同一段内进行串运算,必须使DS和ES指向同一段。指针 每执行一次字符串指令,指针SI和DI会自动修改,以指向下一个待操作单元。,隐含约定,H,D

2、F标志:控制字符串处理的方向。 DF0为递增方向。DS:SI指向源串首地址,每执行一次串操作:字节串操作时,SI、DI分别增1;字串操作时,SI和DI分别增2; DF1为递减方向。DS:SI指向源串末地址,每执行一次串操作:字节串操作时减1;字串操作时减2。 STD使DF置1,CLD将DF清0。串长度 要处理的字符串长度(字节或字数)放在CX寄存器中。,隐含约定,H,功能 在基本指令前加重复前缀,可加快串运算指令的执行速度。每重复执行一次,地址指针SI和DI按方向标志自动修改,CX的值自动减1。类型和格式 REP:无条件重复,重复操作直到CX0为止。 REPE/REPZ:相等/结果为零则重复,

3、重复直到ZF0或CX0为止。 REPNE/REPNZ :不相等/结果非零则重复,重复直到ZF1或CX0为止。,重复前缀,带有重复前缀的串指令执行过程中允许有中断进入。,H,MOVS字符串传送指令,MOVS字符串传送指令 (Move String)格式 MOVS 目的串,源串。 功能 SI作指针的源串中的一个字节或字,DI作指针的目的串;自动修改指针SI和DI。应用解决MOV指令不能直接在存储单元间进行数据传送的问题。若使用重复前缀,还可以利用一条指令传送一批数据。,H,H,MOVS字符串传送指令,举例 要求把数据段中以SRC_MESS为偏移地址的一串字符“HELLO!”,传送到附加段中以NEW

4、_LOC开始的单元中。,DATA SEGMENT ;数据段 SRC_MESS DB HELLO! ;源串 DATA ENDS;EXTRA SEGMENT ;附加段 NEW_LOC DB 6 DUP(?) ;存放目的串 EXTRA ENDS;CODE SEGMENT ASSUME CS:CD, DS:DATA, ES:EXTRA,START: MOV AX,DATA MOV DS,AX ;DS数据段段址 MOV AX,EXTRA MOV ES,AX ;ES附加段段址 LEA SI,SRC_MESS ;SI指向源串偏移地址 LEA DI,NEW_LOC ;DI指向目的串偏移地址 MOV CX,6

5、;CX作串长度计数器 CLD ;清方向标志,地址增量 REP MOVSB ;重复传送串中各字节,直到CX=0 Code ENDS End start,CMPS字符串比较指令,CMPS字符串比较指令 (Compare String)格式 CMPS 目的串,源串。 功能 SI作指针的源串减去DI作指针的目的串数据,结果反映在标志位上;两个数据串的原始值不变;源串和目的串指针自动修改,指向下一对待比较的串。常用来比较两个字符串是否相等。,H,CMPS字符串比较指令,加重复前缀REPE/REPZ CMPS ;直至CX0(比完了)或ZF0(两串不相等)时停止操作。REPNE/REPNZ CMP;直至CX

6、0(比完了)或ZF1(两串相等)时停止比较。,H,SCAS字符串扫描指令,SCAS字符串扫描指令 (Scan String)格式 SCAS 目的串。 功能 AL/AX(字节/字操作)内容减去ES:DI中的串元素,结果反映在标志位上,源操作数不变,操作后目的串指针会自动修改,指向下一个待搜索的串元素。应用利用SCAS指令,可在内存中搜索关键字。指令执行前,必须事先将关键字存在AL(字节)或AX(字)中,才能用SCAS指令进行搜索。 SCAS指令可以加重复前缀。,H,H,SCAS字符串扫描指令,举例 在某一字符串中搜寻是否有字符A,若有,则把搜索次数记下来,送到BX寄存器中,若没有查到,则将BX寄

7、存器清0。设字符串起始地址STRING的偏移地址为0,字符串长度为CX。,解: MOV DI,OFFSET STRING ;DI字符串偏移地址 MOV CX,COUNT ;CX字符串长度 MOV AL,A ;AL关键字A的ASCII码 CLD ;清标志方向 REPNE SCASB ;CX0(没查完)和ZF=0(不相等)时重复 JZ FIND ;若ZF=1,表示已搜到,转出 MOV DI,0 ;若ZF=0,表示没搜到,DI0FIND:MOV BX,DI ;BX搜索次数 HLT,LODS取字符串指令,LODS取字符串指令 (Load String)格式 LODS 源串。 功能 DS:SI中的串元素

8、AL/AX(字节/字操作)中,修改SI,以指向串中的下一个元素。SI的修改量由方向标志DF和源串的类型确定。,H,STOS存字符串指令,STOS存字符串指令 (Store String)格式 STOS 目的串。 功能 AL/AX(字节/字操作)的一个字节或字ES:DI所指的目的串;修改DI,以指向串中的下一个单元。 关于重复前缀:“REP STOS” ,可用累加器中的常数,对数据串初始化。如初始化为全0串。,H,控制转移指令,作用 改变CS和IP的值,从而改变指令的执行顺序。 类型无条件转移和过程调用指令条件转移指令条件循环控制指令中断指令,H,控制转移指令(28条),H,无条件转移和过程控制

9、指令,H,JMP无条件转移指令,JMP无条件转移指令 (Jump)格式 JMP 目的。 功能 程序无条件地转移到指定的目的地址去执行。转移类型段内转移或近(NEAR)转移 转移指令的目的地址和JMP指令在同一代码段中,转移时,仅改变IP寄存器的内容,段地址CS的值不变。段间转移,又称为远(FAR)转移 转移时,CS和IP的值都要改变,转到另一代码段去执行。,H,JMP无条件转移指令,两种提供地址的方式 直接转移 指令码中直接给出转移的目的地址,目的操作数用一个标号来表示,它又可分为段内直接转移和段间直接转移。间接转移 目的地址包含在某个16位寄存器或存储单元中,CPU根据寄存器或存储器寻址方式

10、,间接求出转移地址。,H,JMP无条件转移指令,无条件转移指令的类型和方式,H,JMP无条件转移指令,段内直接转移指令格式 JMP SHORT 标号 JMP NEAR PTR 标号(或:JMP 标号)。 特点目的操作数均用标号表示;程序转向的有效地址当前IP寄存器的内容8/16位位移量(DISP)。16位:近转移,范围在-32768+32767个字节之间;8位:短转移,范围在-128+127个字节之间;,H,JMP无条件转移指令,段内间接转移指令格式 JMP 16位寄存器/字存储单元特点16位有效地址存放在一个16位寄存器、字存储器单元;寄存器间接寻址:有效地址存放在寄存器中,即IP 寄存器内

11、容;存储单元间接寻址:有效地址存放在存储单元中,即IP字存储单元内容;要计算出存储单元的物理地址,再从该地址处取一个字送到IP。,H,段内间接转移指令,【例】JMP BX 解:若该指令执行前BX4500H; 则指令执行时,将当前IP修改成4500H; 程序转向段内偏移地址为4500H处执行。【例】JMP WORD PTR 5BX 解:设指令执行前,DS2000H,BX100H,(20105H)04F0H;则指令执行后,IP(20000H+100H+5H)(20105H)04F0H;转到代码段内偏移地址为04F0H处执行。,H,JMP无条件转移指令,段间直接(远)转移指令格式 JMP FAR 标

12、号特点 用远标号直接给出了转向的段地址和偏移量,即 IP 标号的段内偏移量 CS 标号所在段的段地址,H,段间直接(远)转移指令,【例】 JMP FAR PTR PROG_F 解:设标号PROG_F所在段的基地址3500H,偏移地址080AH; 则指令执行后,IP080AH,CS3500H; 程序转到3500:080AH处执行。,H,JMP无条件转移指令,段间间接转移指令格式 JMP DWORD PTR存储单元特点 目的地址的段地址和偏移量放在存储器中的4个连续地址单元中:前两个字节为偏移量;后两个字节为段地址。指令中给出存放目标地址的存储单元的首字节地址值;,H,段间间接转移指令,【例】 J

13、MP DWORD PTR SI+0125H 设指令执行前:CS1200H,IP05H,DS2500H,SI1300H;内存单元(26425H)4500H,(26427H)32F0H。 解:目的操作数地址DS16SIDISP 25000H1300H0125H 26425H 从单元中取出转移地址,赋与IP和CS:IP4500H,CS32F0H;程序转到32F0:4500H处执行。,H,过程调用及返回指令,过程:程序中能完成特定功能而又独立的模块,也称子程序。 过程嵌套:在过程运行中又去调用另一个过程。 过程调用和返回指令的格式:CALL 过程名 RET 近过程调用:调用指令CALL和被调用的过程在

14、同一代码段中。 远过程调用:两者在不同代码段中。,H,CALL过程调用指令,CALL过程调用指令(Call)格式 Call 过程名功能 将当前主程序的返回地址压入堆栈保存,转到子程序入口地址执行子程序。 近调用时:IP入栈;远调用时,CS和IP入栈。,H,RET过程返回指令,RET过程返回指令(Return)格式 RET。功能 从堆栈中弹出返回地址,使程序返回主程序继续执行。如果从近过程返回:从栈中弹出一个字 IP,并且使SP SP+2。如果从远过程返回:先从栈中弹出一个字 IP,并且使SP SP+2;再从个字栈中弹出一个字CS,并使SP SP+2。,H,RET n过程返回指令,RET n过程

15、返回指令(Return)格式 RET n。功能 n称为弹出值,CPU在弹出返回地址后,再从堆栈中弹出n个字节的数据。其值可以是0000-0FFFFH范围内的任何一个偶数。,H,RET n过程返回指令,用途 调用过程的主程序通过堆栈向过程传递参数。参数在调用过程前推入堆栈,过程运行中通过堆栈指针寻找;过程返回时,用RET n把它们从栈中弹出。,H,过程调用与返回指令,寻址方式段内直接调用;段内间接调用;段间直接调用;段间间接调用,H,过程调用与返回指令,段内直接调用【例】 CALL PROG_N ;PROG_N是一个近标号 CS=2000H,IP=1050H,SS=5000H,此指令含3字节。S

16、P=0100H,PROG_N与CALL指令之间的距离等于1234H(即DISP1234H)。 CALL(机器码E83412)执行过程。,SP SP-2,即新的SP0100H-200FEH;返回地址IP入栈。返回地址应该为CALL执行完后的地址,即IP=IP+3=1053H,将此数入栈;计算程序入口地址IP=IP+DISP=1053+1234=2287H。,H,H,:1053H,CALL段内直接调用,CS=2000H,IP=1050H,SS=5000HSP SP-2,即新的SP0100H-200FEH;返回地址IP入栈。返回地址应该为CALL执行完后的地址,即IP=IP+3=1053H,将此数入

17、栈;计算程序入口地址IP=IP+DISP=1053+1234=2287H。,10,53,12,34,E8,5000:0100H,2000:1050H,:1053H,:2287H,SP=0100H,SP=00FEH,过程调用与返回指令,段内间接调用 操作步骤:SPSP-2,IP入栈,IP EA(从目的操作数计算)【例】 CALL BX DS1000H,BX200H,SI300H,(10500H)3210H,EA0200H。【例】 CALL WORD PTR BX+SI EA(16DSBXSI) (10000H0200H0300H)=(10500H)3210H,H,过程调用与返回指令,段间直接调用

18、计算返回IP;SPSP-2,CS入栈;SPSP-2,IP入栈; 转子程序入口地址,执行子程序。 Ret时,出栈的顺序为IP,CS【例】 CALL FAR PTR PROG_F;PROG_F是一个远标号。,H,过程调用与返回指令,段间间接调用 这类调用指令的操作数必须是存储单元,从该单元 开始存放的双字中,第一个字存放的是IP,后一个字存放的为CS。 【例】 CALL DWORD PTR BX解:设DS1000H,BX200H,(10200H)31F4H,(10202)5200H。CALL指令的执行过程: SP SP-2,CS入栈 SP SP-2,IP入栈 IP (10200H)31F4H,CS

19、 (10202)5200H 转子程序入口,CS:IP=5200H:31F4H,H,条件转移指令,条件转移指令(ConditionaI Transfer) 根据上一条指令执行后的状态标志作为判别测试条件来决定是否转移。条件转移均为段内短转移。目的地址当前IP值8位相对位移量(-128127 )。 指令格式:条件操作符 标号条件转移指令共有18条,分直接与间接标志转移指令,H,H,直接标志转移指令,在指令助记符中直接给出标志状态的测试条件:以标志的10种状态为判断的条件。,直接标志转移指令,【例】 求AL和BL寄存器中的两数之和,若有进位,则AH置1,否则AH清0解:可用如下程序段来实现该操作:

20、ADD AL,BL ;两数相加 JC NEXT ;若有进位,转NEXT MOV AH,0 ;无进位,AH=0 JMP CONT ;往下执行NEXT: MOV AH,1 ;有进位,AH置1CONT: ;程序继续进行,H,间接标志转移指令,指令的助记符中不直接给出标志状态位的测试条件,而是标志的状态组合作为测试的条件。指令应用:通常放在比较指令CMP之后,以比较两个数的大小。无符号数比较测试指令中 指令助记符中的“A”Above,“B”Below;带符号数比较测试指令中,指令助记符中的 “G”(Great than)表示大于,“L”(Less than)表示小于。,H,间接标志转移指令,H,间接标

21、志转移指令,【例】 设某个学生的英语成绩已存放在AL寄存器中,若低于60分,则打印F(FAIL);若高于或等于80分,则打印G(GOOD);当在60分和80分之间时,打印P(PASS)。程序: CMP AL,60 ;与60分比较 JB FAIL ;60,转FAIL CMP AL,80 ;60,与80分比较 JAE GOOD ;80,转GOOD MOV AL,P ;其它,将ALP JMP PRINT ;转打印程序 FAIL: MOV AL,F ; ALF JMP PRINT ;转打印程序GOOD: MOV AL,G ; ALGPRINT: ;打印存在AL中的字符,H,条件循环控制指令,H,条件循

22、环控制指令,特点:是一组增强型的条件转移指令,控制程序段的重复执行,重复次数存于CX寄存器中。指令的字节数均为2,第一字节是操作码,第二字节是 8 位偏移量,转移的目标都是短标号。循环指令中的偏移量都是负值。循环控制指令均不影响任何标志。,H,LOOP循环指令,LOOP循环指令(Loop)格式 Loop 短标号。循环次数先放在CX中。功能 控制重复执行一系列指令,重复次数放在CX寄存器中,每执行一次LOOP指令,CX自动减1。如果减1后CX0,则转移到指令中所给定的标号处继续循环;若自动减1后CX0,则结束循环。 LOOP指令和以下两条指令可以相互替换。 DEC CX;JNZ 标号。,H,LO

23、OPE/LOOPZ相等或结果为零时循环指令,LOOPE/LOOPZ指令(Loop if Equal/Zero)格式 LOOPE/LOOPZ 标号。功能LOOPE是相等时循环;LOOPZ是结果为零时循环;指令执行前,先将重复次数送到CX中,每执行一次指令,CX自动减1,若减1后CX0和ZF1,则转到指令所指定的标号处重复执行;若CX0或ZF0,便退出循环。,H,LOOPNE/LOOPNZ不相等或结果为不零时循环指令,LOOPNE/LOOPNZ指令 Loop if not Equal/ not Zero格式 LOOPNE/LOOPNZ 标号。功能LOOPNE是不相等时循环;LOOPNZ是结果不为零

24、时循环;指令执行前,先将重复次数送到CX中,每执行一次指令,CX自动减1,若减1后CX0和ZF0,则转到指令所指定的标号处重复执行;若CX0或ZF1,便退出循环。,H,JCXZ若CX为0跳转指令,JCXZ若CX为0跳转指令 (Jump if CX Zero)格式 JCXZ 标号。功能若CX寄存器为零,则转移到指令中标号所指定的地址处,它不对CX寄存器进行自动减1的操作。主要用在循环程序开始处,为跳过循环,把CX寄存器清零。,H,中断指令,H,中断,定义 计算机暂时中止当前程序的运行,执行中断服务程序去为临时发生的事件服务,执行完毕后,返回正常程序继续运行,这个过程称为中断。,H,中断,中断过程

25、 执行中断前,必须做现场的保护工作,以确保中断执行完后能返回主程序继续执行,中断过程:断点(CS,IP值)、标志寄存器的值入栈保护取入口地址(中断类型4,得到中断向量的地址)执行中断服务程序执行中断返回指令IRET,从堆栈中恢复中断前CPU的状态和断点。,H,中断,中断向量表 低2字节存放中断服务程序入口地址的偏移量IP;高2字节存放中断服务程序入口地址的段地址CS;中断服务程序入口地址中断类型4;,00000H,00004H,00008H,003FCH,H,专用中断,5个专用中断除法错中断(类型0):除数为0;商超过范围单步中断(类型1):单步标志TF置1;不可屏蔽中断(类型2):NMI引脚

26、上接收到由低变高的电平变化;断点中断(类型3):调试程序时,程序执行到断点时便产生中断;溢出中断(类型4):溢出标志OF置l,溢出中断指令INTO产生;除单步中断外,都不能被屏蔽,不受中断允许标志IF的控制,H,INT n软件中断指令,INT n软件中断指令 (Interrupt)格式 INT n。N为中断类型号,范围为0255。CPU执行INT n的过程标志寄存器的内容入栈;当前断点的段基地址CS、偏移地址IP入栈;清除中断标志IF、单步标志TF ;将中断类型号n乘以4,找到中断服务程序的入口地址表的表头地址,获得中断服务程序的入口地址,置入CS和IP寄存器转到相应中断服务程序。,H,INT

27、O溢出中断指令,INTO溢出中断指令 (Interrupt On overflow)格式 INTO。功能 当带符号数进行算术运算时,若溢出标志OF1,则溢出中断指令INTO产生类型为4的中断,若OF=0,则INTO指令不产生中断,CPU继续执行主程序。 在带符号加减法运算之后必须安排一条INTO指令。以保证出现溢出时能及时向CPU提出中断请求并进行处理,否则,即使出现溢出也不会向CPU发中断申请。,H,IRET中断返回指令,IRET中断返回指令 (Interrupt Return)格式 IRET。功能 实现中断返回,安排在中断服务程序的结束处。执行过程首先从堆栈中依次弹出程序断点,送到IP和C

28、S寄存器中;接着弹出标志寄存器的内容,送回标志寄存器;CPU按CS:IP的值返回断点,继续执行原来被中断的程序。,H,处理器控制指令,标志控制指令 用于某些标志位的清零与设置。外部同步指令 与协处理器同步工作的指令,以便共享系统资源。停机指令和空操作指令,H,标志控制指令,H,外部同步指令,使CPU与其它协处理器同步工作的指令,用于多处理机;指令执行后均不影响标志位。共3条。,H,ESC换码指令,ESC换码指令 (Escape)格式 ESC MEN。Men为操作数地址功能 用于实现8086对8087协处理器的控制。8087只处理与自己相关的ESC指令。执行指令时,8087的BUSY引脚变成高电

29、平并送到与之相连的8086的TEST#引脚上。 指令执行时,把一个指定的存储单元的内容送到DB上,由协处理器获取后,完成相应的操作。,H,WAIT等待指令,WAIT等待指令 (Wait)格式 WAIT。功能 循环测试TEST#直到变成低电平时退出wait状态。用途 wait通常跟在ESC指令之后,CPU执行ESC指令后,表示8086处于等待状态,测试TEST#直到低电平方退出wait状态执行下条指令。,H,LOCK封锁总线指令,LOCK封锁总线指令 (Lock BUS) 是一种前缀,加在指令的前端,用来维持8086的总线封锁信号LOCK#有效,带有LOCK前缀的指令在执行过程中,禁止其它协处理

30、器使用总线。,H,停机指令和空操作指令,HLT停机指令 (Halt) CPU进入暂停状态,不进行任何操作。下列情况发生时,CPU才脱离暂停状态:在RESET线上加复位信号;在NMI引脚上出现中断请求信号;在允许中断的情况下,在INTR引脚上出现中断请求信号;,H,停机指令和空操作指令,NOP空操作指令 (No Operation) 单字节指令,执行时需耗费3个时钟周期的时间,但不完成任何操作。常在循环等操作中增加延时,或在调试程序时使用空操作指令。,H,TEST,设CS=1200H,IP=0100H,SS=5500H,SP=0400H,DS=2000H,SI=3000H,BX=0300H,(20300H)=4800H,(20302H)=00FFH,PROG_N标号的地址为1200:0278H,PROG_F标号的地址为3400:0ABCH。说明下面每条指令执行完后程序将分别转移到何处执行?JMP PROG_N JMP BXJMP BX JMP FAR PROG_F JMP DWORD PTRBX,H,小结,串处理指令的分类及具体功能无条件转移指令的功能直接标志转移指令的功能(重点)其他指令的功能介绍,H,本节作业,P122-11,H,

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

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号