微机系统与接口课件:CH2_2第二章微型计算机指令系统(续)_第1页
微机系统与接口课件:CH2_2第二章微型计算机指令系统(续)_第2页
微机系统与接口课件:CH2_2第二章微型计算机指令系统(续)_第3页
微机系统与接口课件:CH2_2第二章微型计算机指令系统(续)_第4页
微机系统与接口课件:CH2_2第二章微型计算机指令系统(续)_第5页
已阅读5页,还剩54页未读 继续免费阅读

下载本文档

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

文档简介

1、第二章 微型计算机指令系统(续)数据传送 (DATA TRANSFER) 通用/ I/O /目标地址传送/标志传送算术运算(Arithmetic) 整型数据处理逻辑运算与位操作(Logic) 逻辑数据处理串操作(String Manipulation) 字符型数据处理转移控制(Control Transfer) 程序流控制处理MPU控制(Processor Control) 系统控制管理8086/8088指令系统(六大类)1数据传送与寻址方式MOV AL,100; MOV CX,2000H; MOV DS, AX;MOVCX,BX;MOVSI,DXMOV AX,2000H ;MOV AL,BU

2、FFER(内存); MOV CS:2000H, 30HMOV AX,SI;MOV BL,DI; MOV AX,SS:SI MOV CH,BX; MOV BP,SIMOV SI,SI+6;MOV DL,TABLEDI MOV BX+100,AL;MOV DX,TABLEBPMOVBXSICOUNT,AL; MOV DX,BXDI+900H; MOV DX,BP+DI+COUNTPUSH ES:2000H LEA SI,BP+DICOUNT POP ES LDS SI, DICOUNT所有数据传输指令不应影响标志位2数据传送与寻址方式非法数据传送指令:两个操作数的类型不一致例如源操作数是字节,而目

3、的操作数是字;或相反两个操作数不能都是存储器传送指令很灵活,但主存之间的直接传送却不允许段寄存器的操作有一些限制段寄存器属专用寄存器,对他们的操作能力有限寻址方式:存储器操作数的类型需要明确默认段寄存器默认操作数3标志状态寄存器Flags3个控制标志位6个算术和逻辑运算结果特征奇偶位1偶借进位半进位溢出标志跟踪符号位零标志位中断允许1方向4算术运算(Arithmetic)指令(1)ADD (Addition)加法:8位/16位操作数,影响FLAGS ADD dest,src; (dest)(dest)+(src)ADD AX,BX; ADD CL,10H;ADD SP,2; ADD 2000H

4、, AL; ADD WORD PTRBX, 20例 : AL=7EH AH=5BH; ADD AL,AH AL=D9H注意:源操作数和目标操作数不能同时为存储器;不能对段寄存器进行加法运算,段寄存器不能参加加减法、乘除法运算。问题:如何影响标志位?CF=1 作为无符号数相加进位(字节/字256/65536)OF=1 当作为有符号数相加溢出(-128127/-3276832767)5例 AL=7EH(01111110B) AH=5BH; (01011011B)ADD AL,AH AL=D9H(11011001B)影响标志位:CF=0(加法、无进位);PF=0 (1的个数为奇数。注:非逻辑运算,不

5、必关注) ;AF=1(低4位向高4位有进位发生);ZF=0(结果不为零);SF=1(结果的最高位MSB为1);OF=1(运算的结果超过了127,超出了带符号数的范围)。算术运算(Arithmetic)指令(1)6算术运算(Arithmetic)指令(1)ADD (Addition)加法:8位/16位操作数,影响FLAGS 3AH + 72HACH,没有进位:CF = 0 结果不是零:ZF = 0 最高位D71:SF = 1 产生溢出:OF = 1 ACH10101100B 4个1,偶数个1:PF =1 BBH + 72H(1)2DH,有进位:CF = 18EH + 72H(1)00H,结果是零

6、:ZF = 1 最高位D70:SF = 0 BBH + 72H(1)2DH,没有溢出:OF = 0 *应该利用哪个标志,由程序员来决定如果将参加运算的操作数认为是无符号数,就应该关心进位;认为是有符号数,则要注意是否溢出。7ADC (ADD with Carry) (dest)(dest)+(src)+(CF) 例:MOV BX, OFFSET FIRST; L2 多位数连加: LH MOV SI,OFFSET SECOND ;L1 MOV AX, SI;L1 ADD BX, AX;L1+L2(L2) MOV AX, SI+2;H1 ADC BX+2,AX;H1+H2(H2) 类似P65例2.

7、2 5字节 ADC指令主要用于多字节数据的加法运算,如果低字节相加时产生进位,则在下一次高字节相加时应将这个进位加进去 算术运算(Arithmetic)指令(2)?问题1:运算符 专用指令:目标操作数加1?问题2:如何在二进制运算基础上实现十进制BCD运算指令 H1 L1 + H2 L28INC (Increment by 1) (dest)(dest)+1 加一操作 INC AX; INC DL; INC WORD PTR ES:2000H INC BYTE PTRBX; INC WORD PTR CS:DI+20INC指令的操作数不能为段寄存器BYTE PTR或WORD PTR指定随后的存

8、储器操作数的类型为字节或字 伪操作PTRINC指令通常用于循环程序中修改地址。 算术运算(Arithmetic)指令(2)9 算术运算(Arithmetic)指令(3)AAA*(ASCII adjust for Addition) 非压缩BCD加法调整(单字节)只对Unpacked BCD (00-09H)有意义;隐含操作数为:AL,AH等效:IF(AL)&(0FH)9)OR (AF)=1 THEN (AL)+6; AH+1;AF=CF=1; (AL)&0FH ELSE (AL)&0FH; 例:MOV AH,0 MOV AL,7 MOV BL,8 ADD AL,BL;(AL=0FH); AAA

9、; (AL+6=21=10101;10101 &0FH=0101=5) (AH=1,AL=5) 调整前相加结果放在AL中,调整后,非压缩BCD的结果的低位放在AL中,高位在AH中。BCD码调整指令,使CPU能够对用BCD码表示的十进制数进行加减乘除运算,并将结果调整成正确的BCD值。打*指令一般了解10 算术运算(Arithmetic)指令(3)AAA*(ASCII adjust for Addition) 非压缩BCD加法调整P67例2.3 4609+3875=? LEA SI,STRING1LEA BX,STRING2LEA DI,SUMCLCMOV AL,SIADC AL,BXAAAMO

10、V DI,AL MOV AL,SI+1ADC AL,BX+1AAAMOV DI+1,AL.String1(SI)String2(BX)SUM0900060405070803041. ASCII码BCD带进位(CF)加AAA调整2. 顺序-罗列(穷举)结构11 算术运算(Arithmetic)指令(3)AAA*(ASCII adjust for Addition) P67例2.3 4609+3875=? LEA SI,STRING1 LEA BX,STRING2 LEA DI,SUM MOV CX,4 CLCNEXT:MOV AL,SI ADC AL,BX AAA MOV DI,AL INC S

11、I INC BX INC DI DEC CX JNZ NEXT3. (循环/条件指令)结构String1(SI)String2(BX)SUM9064578304090006040507080304 12算术运算(Arithmetic)指令(4)DAA*(Decimal adjust for Addition) 压缩BCD加法调整隐含操作数是AL。DAA只对AL的内容进行调整,不会改变AH。两个BCD码相加后可能得到不正确的BCD结果,可用DAA指令对AL寄存器中的“和”进行调整,即可得到预期的结果。(单字节)只对Packed BCD (00-99H) 有意义;等效:IF(AL)&(0FH)9)

12、OR (AF)=1 THEN (AL)+6; AF=1; IF(AL)9F )OR(CF)=1 THEN (AL)+60H; CF=1;例: 68+59=? 127 得到压缩BCD码MOV AL,68H; MOV BL,59H;ADD AL,BL;(AL=C1H 不正确 ,AF=1);DAA;(CF=1=AF , AL=27H, 可连加)上例的DAA调整,相当于加66H,即相当于ADD AL,66H打*指令一般了解13算术运算(Arithmetic)指令(5)减法 乘法 除法SUB/SBB/DEC/MUL/AAMDIV/AAD AAS/DAS*(调整) IMUL(有符号乘) IDIV (有符号

13、除) 例:减法:不允许两个存储器相减。8位或16位(注:CF=1 借位) SUB AL,CH; (dest)(dest)-(src) SUB BYTE PTR2000H, 20 SBB AX, BP+1000 ; (dest)(dest)-(src)-(CF) 带借位的减指令主要用于多字节的减法 DEC SI; (dest)(dest)-1 DEC BYTE PTR SI; 打*指令一般了解14 当无符号数的较小数减较大数,因不够减而产生借位,此时CF=1; 带符号数相减如果结果溢出,则OF=1.算术运算(Arithmetic)指令(5)15算术运算(Arithmetic)指令(6)NEG (

14、Negate) 8位/16位求补(改变符号)绝对值不变NEG dest; (dest)0-(dest)影响6个运算标志位例:NEG AL; NEG BX; NEG BYTE PTR CS:2000HAL=30HNEG AL D0HCMP (Compare) (dest)-(src)影响6个运算标志位例: CMP AL,CH; CMP AX,BX; CMP BYTE PTR2000H, 20 JC NEXT ; 利用FLAGS结果,无符号数比较 JG NEXT ; 有符号数比较16算术运算(Arithmetic)指令(7)16位无符号数乘法 MUL src; 默认AX*(src) 积= DX(高

15、16位)|AX(低16位)8位无符号数乘法 MUL src; 默认AL* (src) 积= AX(16位) MUL指令对CF和OF有影响:若运算结果的高半部分(AH或DX中)为0,则CF=OF=0,否则CF=OF=1 例:AL=42H(66),CL=28H (40) MUL CLAX=0A50H(2640) AX,0A50H, CX=0333H MUL CX DX/AX=0020H/ 0FDF0H17算术运算(Arithmetic)指令(7)16位无符号数除法 DIV src; 默认被除数DX(高16位)|AX(低16位) /src(16位) 结果 DX=余数(16位) AX=商(16位) 8

16、位无符号数除法 DIV src; 默认被除数AX(16位)/src(字节)结果 AH=余数(8位) AL=商(8位) 不允许两个字长相等的操作数相除,若被除数和除数的字长相等,则须在DIV指令前将被除数的高位扩展8个零或16个零。例:DX=20H,AX=0FDF2H SI=333H DIV SIAX=0A50H DX=0002H CL=42H DIV CL 0028H 注意:除0/溢出(字节除:商255 OR 字:商65535)除零中断18算术运算(Arithmetic)指令(8)IMUL/IDIV 有符号数乘/除法 IMUL src; 字节乘法 (AX) (src)*AL; 字乘法 (DX:

17、AX) (src)*AX IDIV src; 字节除法 (AL) (AX)/(src) (AH) (AX)%(src) 字除法 (AX) (DX:AX)/(src) (DX) (DX:AX)%(src) 指令将两个操作数均按带符号数处理,8位和16位带符号数的取值范围是-128+127 32768+32767. 指令对CF和OF有影响:若运算结果的高半部分(AH或DX中)仅为低半部分符号位的扩展,则CF=OF=0,否则若高半部分包含运算的有效数字则CF=OF=1。注意:除0/溢出(字节除:商超出(-128+127) OR 字:商超出(-32768+32767)除零中断若被除数和除数的字长相等,

18、则须在IDIV指令前将被除数的符号位扩展,使之成为16位或32位数。19CBW/CWD 扩展字长(字节字; 字双字)无符号数:高位添加足够个数的零有符号数:高位添加足够个数的符号位CBW:将一个字节扩展成为字,隐含操作数:AL AH CWD:将一个字扩展成为双字,隐含操作数:AX DX比较MOV AL,4FH 和 MOV AL,0F8H CBW CBW算术运算(Arithmetic)指令(8)20算术运算(Arithmetic)指令(8)AAM* (ASCII adjust for Multiply) AL寄存器中的二进制数转换成不压缩BCD码,十位放在AH中,个位放在AL中。 隐含操作数:A

19、L AH 等效:AH(AL)/10; (商); (AL)(AL)%10 (余数) 根据AL中的结果改变SF,ZF,PF 单字节!例:7*9=?MOV AL,07H ;(AL)=07HMOV BL,09H ;(BL)=09HMUL BL ;(AX)=07H*09H=003FHAAM ;(AH)=06H,(AL)=03H,(SF)=0,(ZF)=0,(PF)=1打*指令一般了解21AAD*( ASCII adjust for Divide):Unpacked BCD调整隐含操作数:AL AH AAD与其它ASCII调整指令不同,AAD不是在除法之后,而是在除法之前进行调整,然后用DIV进行除法,所

20、得之商还需要用AAM进行调整,才能得到正确的非压缩BCD码的结果。AL=AH*10+AL;AH=0 单字节!(AX HEX) 注意:AAD-DIV(B)-AAM例:73/2=?MOV AX,0703H ;(AH)=07H,(AL)=03HMOV BL,02H ;(BL)=02HAAD ;(AL)=49H(即十进制数73)DIV BL ;(AL)=24H(商),(AH)=01H(余数)AAM ;(AH)=03H,(AL)=06H 算术运算(Arithmetic)指令(8)228086/8088指令系统(六大类)数据传送 通用/ 输入输出 / 目标地址传送/标志传送 算术运算 整型数据处理逻辑运算

21、与位操作 逻辑数据处理串操作 字符型数据处理转移控制 程序流控制处理(条件/无条件)MPU控制 系统控制管理23逻辑运算与移位(Logical & shifting)逻 辑 运 算AND dest,src; AND AX, BX; AND CL,08HOR dest, src; OR AL,55H; OR WORD PTR BX, DXXOR dest, src (logical Exclsive or ) XOR AX,AX; XOR CL, BXTEST dest,src 逻辑与测试,仅影响标志位 TEST AL,80H; TEST AX,0FFFFH;ZF= AND AL,80H; AN

22、D AX,0FFFFH.TEST与AND指令 的差别. 常用于位判别,与条件转移指令一起,共同完成对特定位状态的判断,并实现相应的程序转移。NOT dest ;将操作数按位取反 B:dest=255-dest; W:dest=65535-dest NOT AL; NOT WORD PTR BX NOT BYTE PTR ES: 2000H 24逻辑运算与移位(Logical & shifting)逻 辑 运 算位操作/判别. 8086/8088无直接位操作: 如 SETB/CLRB/JB/JNB置位(置1)可采用OR指令 OR AL, 80H ;BIT7=1 OR CL, 04H 复位(清0)

23、可采用AND 指令 AND AL, 7FH ;BIT7=0实现某些位求反,可采用XOR 指令如:MOV AL, 0FH; (AL)=(00001111B) XOR AL, 0AAH;(AL)=(10100101B)实现了BIT1,3,5,7位求反XOR的另一个用途:将寄存器的内容清零 XOR AX,AX25逻辑运算与移位(Logical & shifting)逻辑移位( Logical shifting)SHL/SAL (SHift logical Left/Shift Arithmetic Left) 1位/CL位 相当于无符号数*2/无符号数*2的CL次方位 SHL/SAL dest,1

24、; SHL AL,1; SHL CX,1 SHL/SAL dest,CL SHL WORD PTRBX,CL CF dest(MSB LSB) 0 移一次 当 移位后MSBCF则OF=1SHR(Shift logical right)相当于无符号数/2SHR dest, 1(CL) 0dest(MSBLSB)CF移一次 当移位后新的最高位和次高位不等则OF=126逻辑运算与移位(Logical & shifting)算术移位(Arithmetic Shifting)SAR(Shift Arithmetic right) 带符号/2SAR dest, 1; SAR dest,CL MSBdest

25、(MSBLSB)CF算术右移和逻辑右移区别:算术右移最高位保持不变 MOV AL, 10001000B; SAR AL,1 ;10001000B=(88H= -78H) /2 AL=11000100B(C4H=-60= - 3CH) 27由于移位指令可以实现乘2的若干次方,且移位指令比乘法除法指令速度快得多,一般用移位指令代替乘法除法指令,速度可提高10倍甚至更多。逻辑运算与移位(Logical & shifting)28逻辑运算与移位(Logical & shifting)循环移位指令(Rotate Shifting) 8位或16位操作数移位/循环 不带进位标志CFROL(Rotate le

26、ft)ROL dest 1/CLAL=10001000B ROL AL, 1 AL= ROR(Rotate right)ROR dest 1/CLROR WORD PTRBX, CLCFCF00010001B CF=1AL=10001000BROR AL, 1 AL=01000100B CF=0 AL=84H 48H (高低四位交换,右移四位)29逻辑运算与移位(Logical & shifting)循环移位指令(Rotate Shifting)RCL(Rotate Through Carry Flag left)带进位标志CFRCL dest 1/CLRCR(Rotate Through C

27、arry Flag right)RCR dest 1/CLCFDmax D1 D0308086/8088指令系统(六大类)数据传送 通用/ 输入输出 / 目标地址传送/标志传送 算术运算 整型数据处理逻辑运算与位操作 逻辑数据处理串操作 字符型数据处理转移控制 程序流控制处理(条件/无条件)MPU控制 系统控制管理31标志控制寄存器Flags (位) TF 跟踪标志位 TF= 1,使CPU处于单步执行指令的工作方式。这种方式便于进行程序的调试。每执行一条指令后,自动产生一次内部中断,从而使用户能逐条指令地检查程序。 IF 中断允许标志位 IF= l使CPU可以响应可屏蔽中断请求。 IF= 0使

28、CPU禁止响应可屏蔽中断请求。DF 方向标志位 DF= l 使串操作按减地址方式进行。也就是说,从高地址开始,每操作一次地址减小一次。DF0使串操作按增地址方式进行。 3个控制标志位32串操作(String Manipulation)MOVSB-W/CMPSB-W/ SCANSB-W/LODSB/STOSWSIDIB/WB/WCX个单元(字节或字)即重复循环的次数由CX决定方向+DF=0SI=src pointer (DS) DI=dest pointer(ES) DF控制INC(DF=0)/DEC B+-1/W+-2重复前缀: REP(Z)=REPEREPNZ=REPNE33串操作总是用SI

29、存放原操作数偏移地址,用DI存放目标操作数偏移地址。原操作数默认在DS段中,可段超越;目标操作数默认在ES段中,不允许段超越。串操作指令可以带操作数,也可在指令助记符后加“B”或“W”,不允许再写操作数。MOVSB DEST,ES:SRC 串操作(String Manipulation)34串操作功能与默认操作数REP MOVS (CX次) REPE(Z)CMPS/SCAS (重复至CX=0或ZF=0)REPNE(ZF=0)Repeat while (CX0 )and (ZF=0)。以指令结果与CX计数为条件 MOVSB /W-(ES):(DI)(DS): ( SI)不影响标志位CMPSB/W

30、-(ES):(DI) - (DS): ( SI) 影响标志位SCASB/W- (AL)/(AX)(ES): (DI) 影响标志位 LODSB/W(load String): (AL/AX)(DS): (SI) STOSB/W(Store string) : (AL/AX)(ES): (DI) 358086/8088指令系统(六大类)数据传送 通用/ 输入输出 / 目标地址传送/标志传送 算术运算 整型数据处理逻辑运算与位操作 逻辑数据处理串操作 字符型数据处理转移控制 程序流控制处理(条件/无条件)MPU控制 系统控制管理36转移控制(Control Transfer) -程序流控制两大类:转

31、移控制(Control Transfer)过程调用( Call a procedure )转移控制要点: 转移到新地址-CS:IP 什么条件下转移37转移控制 (Control Transfer)-程序流转移指令-无条件跳转(Unconditional Jump)CS:IP= Instruction Pointer 下条指令地址(指针) 1.段内直接短转移:JMP SHORT_LABEL; 近短跳转 当前IP的128+127内 IP=IP+disp8 382.段内直接转移 JMP(JUMP)NEAR_LABEL IP=IP+disp16段内跳转3.段内间接转移JMP reg16 ;(IP) (

32、reg16)JMP MEN16 ;(IP) (mem16) 4.段间直接转移JMP FAR_LABEL; 段间地址 CS:IP=新地址IP OFFSET FAR_LABEL ; CS SEG FAR_LABEL 转移控制 (Control Transfer)-程序流395.段间间接转移JMP mem32 ;(IP) (mem32) ;(CS) (mem32+2)段内跳转应为16位地址段间跳转应为32位地址JMP SHORT JMP NEAR PTR JMP 2000H; JMP BX; JMP 0FFFFH:0 (热启动)JMP FAR PTR TABLESI; JMP NEAR PTR BP

33、DI转移控制 (Control Transfer)-程序流40转移控制 (Control Transfer)转移指令-条件跳转(conditional Jump) (利用CMP,TEST,计算,移位指令等结果改变程序流) JCC SHORT_LABEL; 限近短跳转 IP 128+127满足条件 IP=IP+disp8,否则顺序执行 (IF ELSE) JZ/JE -JNZ/JNE (ZF)=1 -(ZF)=0 JS -JNS (SF)=1 -(SF)=0 JP/JPE -JNP/JPO (PF)=1 -(PF)=0 JO -JNO (OF)=1 -(OF)=0 JC -JNC (CF)=1

34、-(CF)=041转移控制 (Control Transfer)转移指令-条件跳转(conditional Jump) Unsigned大小比较 P98表2.7JB/JNAE -JNB/JAE (CF)=1 -(CF)=0 JA/JNBE -JNA/JBE (CF)=0&(ZF)=0 -(CF)=1 OR (ZF)=1 signed大小比较JG/JNLE -JNG/JLE (SF)=(OF) &(ZF)=0 -(SF)(OF)OR(ZF)=1 JL/JNGE -JNL/JGE (SF) (OF) &(ZF)=0 -(SF)= (OF) OR(ZF)=142转移控制 (Control Trans

35、fer)LOOP short_label ; loop CX times 循环控制 (Loop) LOOPZ/LOOPE short_label; (loop while zero/equal) 循环直到(CX)=0 or (ZF=0)LOOPNE/LOOPNZ short_label; (Loop while NZ/NE) 循环直到(CX)=0 or (ZF=1) JCXZ if CX=0 Jump to (Jump On CX Zero) CX为零控制调转. Do while/ while Do/ For (i=0;i100;i+)43过程调用指令 ( Call a procedure )

36、过程(Procedure);如果一些程序模块需要在不同地方多次反复地出现使用,则可以将这些程序模块设计成过程,每次需要时进行调用。过程结束后再返回原来调用的地方(下一条指令)。(相当于高级语言中的子程序Subroutine,或函数function),缩短源程序代码总长度利于实现模块化的程序设计,便于编制、调试和维护-需要利用堆栈技术,控制与传递参数44栈底过程调用指令 ( Call a procedure )CALL 段内段间:直接/间接调用(过程/子程序Subroutine) RET (RETF) 过程返回 (分远近,产生不同RET码(C3/CBH)不但CS:IP发生变化(新地址),而且堆栈

37、SP及其内容均发生变化45过程调用指令 ( Call a procedure )段内直接调用 CALL NEAR_PROC; (SP)(SP)-2,(SP)+1,(SP)(IP); (IP)(IP)+proc_disp段内间接调用 CALL reg16/mem16 . (SP)(SP)-2,(SP)+1,(SP)(IP); (IP)reg16/mem16段间直接调用 CALL FAR_PROC; (SP)(SP)-2,(SP)+1,(SP)(CS); (CS)SEG F_PROC (SP)(SP)-2,(SP)+1,(SP)(IP); (IP)OFFSET F_PROC段间间接调用 CALL

38、MEM32; (SP)(SP)-2,(SP)+1,(SP)(CS);(CS)MEM32+2, (SP)(SP)-2,(SP)+1,(SP)(IP); (IP)MEM32 例:CALL 2000H; CALL BX; CALL NEAR PTR ES:SI CALL 2000:3000H; CALL FAR PTR2000H46过程返回指令 ( Return From Call )从近过程返回:RET(C3H ); (IP)(SP)+1:(SP), (SP)(SP)+2RET pop_value ;(C2H data_low data_high) (IP)(SP)+1:(SP), (SP)(SP

39、)+2; (SP)(SP)+pop_value =ADD SP,Pop_value 可带一个弹出值,064k的立即数,表示返回时从堆栈舍弃的字节数。从远过程返回:RETF (CBH) ; (IP)(SP)+1:(SP), (SP)(SP)+2(CS)(SP)+1:(SP), (SP)(SP)+2 RETF pop_value ; (CAH data_low data_high) IP:CS弹出 (SP)(SP)+pop_value478086/8088指令系统(各类重点)数据传送(DATA TRANSFER) 重点:寻址(20位地址,段寄存器)算术运算(Arithmetic) 关注:标志位逻辑

40、运算与位操作(Logic) 简单(数据处理)串操作(String Manipulation) 特殊操作(硬记)转移控制(Control Transfer) 程序流控制(重要)MPU控制(Processor Control) 系统控制(重要)48中断(Interrupt)控制CPU与外设交换信息的一种方式=硬件手段影响和改变CPU执行程序的顺序(程序流)49标志控制寄存器Flags (位) TF 跟踪标志位 TF= 1,使CPU处于单步执行指令的工作方式。这种方式便于进行程序的调试。每执行一条指令后,自动产生一次内部中断,从而使用户能逐条指令地检查程序。 IF 中断允许标志位 IF= l使CPU

41、可以响应可屏蔽中断请求。 IF= 0使CPU禁止响应可屏蔽中断请求。DF 方向标志位 DF= l 使串操作按减地址方式进行。也就是说,从高地址开始,每操作一次地址减小一次。DF0使串操作按增地址方式进行。 3个控制标志位508088中断结构直接执行软件中断/指令执行结果除零(INT 00H)单步(INT 1) IF=1 TF=1溢出(INTO INT 04H)软件中断调用(INT xxH)非屏蔽中断NMI(Non-Maskable Interrupt)可屏蔽中断INTR(IF=1)内部中断外部中断51中断方式下CPU执行程序流程528086/8088中断过程保护断点(F入栈;IF=0 TF=0; CS、IP入栈;中断服务(中断类型号: n )(0:4*n取向量 CS:IP);返回断点(IRET:依次弹出IP

温馨提示

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

评论

0/150

提交评论