《第八章输入输出程序设计优秀课件.ppt》由会员分享,可在线阅读,更多相关《第八章输入输出程序设计优秀课件.ppt(59页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第八章输入输出程序设第八章输入输出程序设计计第1页,本讲稿共59页本章内容提要本章内容提要 I/O设备的数据传送方式程序直接控制I/O方式中断传送方式第2页,本讲稿共59页8.1 I/O8.1 I/O设备的数据传动方式设备的数据传动方式 1 1CPU与外设2 2直接存储器存取(DMA)方式第3页,本讲稿共59页8.1.1 CPU8.1.1 CPU与外设与外设 与CPU进行数据交换的,除了存储器外,还有输入输出设备(统称为外设)。输入IN和输出OUT指令,可以从外设读取数据和向外设提供数据。由于外设种类繁多,其工作原理、数据格式、操作时序等各异,所以在处理器与外设之间还有一个协调两者数据传送的逻
2、辑电路,称为输入输出(I/O)接口电路。处理器并不直接操纵外设,而是通过I/O接口来控制外设。第4页,本讲稿共59页I/OI/O接口电路中的寄存器接口电路中的寄存器I/O接口电路呈现给程序员的,是各种可编程寄存器。这些寄存器可以分成三类:数据寄存器数据寄存器它保存和处理与外设间交换的数据;它保存和处理与外设间交换的数据;控制寄存器控制寄存器处理器通过它对外设进行控制,也称处理器通过它对外设进行控制,也称命令寄存器;命令寄存器;状态寄存器状态寄存器外设的当前工作状态通过它向处理器外设的当前工作状态通过它向处理器提供。提供。在涉及外设操作的输入输出程序中,各种寄存器以I/O地址(端口)体现;对应三
3、类寄存器分别称为:数据端口、控制端口、状态端口。第5页,本讲稿共59页CPUCPU与外设数据传送方式与外设数据传送方式程序直接控制传送方式程序直接控制传送方式程序查询程序查询I/OI/O方式方式中断传送方式中断传送方式直接存储器存取(直接存储器存取(DMADMA)方式)方式第6页,本讲稿共59页8.1.2 8.1.2 直接存储器存取(直接存储器存取(DMADMA)方式)方式主要由硬件DMA控制器实现其传送功能。DMA(direct memory access)方式,也称为成组数据传送方式。主要用于一些高速的I/O设备。如磁带、磁盘、A/D等设备。传送数据时,每个字节一到达端口,就直接从接口送到
4、存储器;同样,接口和它的DMA控制器也能直接从存储器取出字节并把它送到I/O设备去。第7页,本讲稿共59页DMADMA工作原理工作原理DMA控制器(intel 8237A)一般包括四个寄存器:控制寄存器状态寄存器地址寄存器字节计数器在信息传送前,应初始化这些寄存器。在信息传送前,应初始化这些寄存器。地址寄存器地址寄存器要传送的数据块首地址;要传送的数据块首地址;字节寄存器字节寄存器要传送的数据长度(字节数);要传送的数据长度(字节数);状态寄存器状态寄存器控制字,指出数据是输入还是输出,并启动控制字,指出数据是输入还是输出,并启动DMADMA操作。操作。每个字节传送后,地址寄存器加1,字节计数
5、器减1。第8页,本讲稿共59页DMADMA传送步骤传送步骤由系统完成以下步骤:由系统完成以下步骤:DMADMA控制器向控制器向CPUCPU发出发出HOLDHOLD信号,请求使用总线。信号,请求使用总线。CPUCPU发出响应信号发出响应信号HOLDHOLD给给DMADMA控制器,并将总线让出,这时控制器,并将总线让出,这时CPUCPU放弃放弃了对总线的控制,而了对总线的控制,而DMADMA控制器获得了总线控制权。控制器获得了总线控制权。传输数据的存储器地址(在地址寄存器中)通过总线发出。传输数据的存储器地址(在地址寄存器中)通过总线发出。传输的字节数通过数据总线进行传送。传输的字节数通过数据总线
6、进行传送。地址寄存器加地址寄存器加1 1,以指向下一个要传送的字节。,以指向下一个要传送的字节。字节计数器减字节计数器减1 1。如字节计数器非如字节计数器非0 0,转向第,转向第3 3步。步。否则,否则,DMADMA控制器撤销总线请求信号控制器撤销总线请求信号HOLDHOLD,传送结束,传送结束第9页,本讲稿共59页8.2 8.2 程序直接控制程序直接控制I/OI/O方式方式 1 1I/O端口2 2I/O指令3 3I/O程序举例第10页,本讲稿共59页8.2.1 I/O8.2.1 I/O端口端口 80 x86中,I/O端口独立编址,允许设置64K(65535)个8位端口,或32K(32768)
7、个16位端口。CPU和内存通过I/O端口与外设进行通信。表8.1列出了部分端口地址(十六进制)。第11页,本讲稿共59页8.2.2 I/O8.2.2 I/O指令指令 IN/OUT指令,即可传送字节又可传送字,使用的寄存器必须是AL或AX。直接寻址:寻址0255号端口。间接寻址:所有端口,使用DX寄存器。ININAX,28HAX,28HMOVMOVDATA_WORD,AXDATA_WORD,AXININAL,27HAL,27HTESTTESTAL,00000100HAL,00000100HJNZJNZERRORERRORMOVMOVDX,126HDX,126HININAL,DXAL,DX;端口端
8、口126H126HORORAL,80HAL,80H;第第7 7位控制成组数据传送位控制成组数据传送OUTOUTDX,ALDX,AL第12页,本讲稿共59页8.2.3 I/O8.2.3 I/O程序举例程序举例例例8.1 8.1 发声子程序发声子程序SOUNDSOUND例例8.28.2查询方式查询方式打印字符程序打印字符程序PRT_CHARPRT_CHAR例例8.38.3查询方式查询方式控制数据输入控制数据输入第13页,本讲稿共59页8.3 8.3 中断传送方式中断传送方式 1 18086的中断分类2 2中断向量表3 3中断过程4 4中断优先级和中断嵌套5 5中断处理过程第14页,本讲稿共59页中
9、断的相关概念中断的相关概念 中断是CPU和外设进行数据传送的有效办法。它可以避免因反复查询外设状态而浪费的时间,从而提高CPU的效率。中断是一种使CPU中止正在执行的程序而转去处理特殊事件的操作。中断源中断源引起中断的事件。引起中断的事件。外部中断(硬件中断)外部中断(硬件中断)由外设控制器或协处理器引起的中断。由外设控制器或协处理器引起的中断。内部中断(软件中断)内部中断(软件中断)由程序中安排的中断指令由程序中安排的中断指令INTINT产生的产生的中断,或由中断,或由CPUCPU的某些错误结果产生的中断。的某些错误结果产生的中断。8080/8088的中断源如图8.3所示。第15页,本讲稿共
10、59页8.3.1 80868.3.1 8086的中断分类的中断分类 软件中断硬件中断第16页,本讲稿共59页1.1.软件中断软件中断 软件中断又称内中断。它通常由三种情况引起:由中断指令INT引起;由于CPU的某些错误引起;为调试程序(DEBUG)设置的中断。第17页,本讲稿共59页(1 1)中断指令)中断指令INTINT引起的内中断引起的内中断 CPU执行完一条INT n指令后,会立即产生中断,并调用系统中相应的中断处理程序来完成中断功能,n指出中断类型号。INT指令可以指定00FFH中的任何类型号。除系统占用的类型号之外,用户还可利用为用户保留的类型号扩充新的中断处理功能。INT n IN
11、T n、INTOINTO、除法错中断都不能被禁止,而且比任何外部中断、除法错中断都不能被禁止,而且比任何外部中断的优先级都高。的优先级都高。第18页,本讲稿共59页(2 2)处理)处理CPUCPU某种错误的中断某种错误的中断除法错中断:INT 0 在执行除法时,如果除数为0或商超过了寄存器所能表达的范围,则产生一个类型为0的中断。溢出中断:INTO中断类型号为4 若溢出标志OF=1,则产生溢出中断;否则,不产生中断,CPU继续运行原程序。该中断的处理程序,主要是打印出一个错误信息,在处理结束后,不返回原程序继续执行,而是把控制权交给操作系统。如:ADDAX,VALUEINTO;测试加法溢出第1
12、9页,本讲稿共59页(3 3)为调试程序()为调试程序(DEBUGDEBUG)设置的中断)设置的中断 单步中断:为寻找程序中的问题,进行单步工作(一次只执行一条指令)。类型号为1。当单步标志位TF1时,每条指令执行后,CPU会自动产生单步中断。使用单步中断可以逐条指令地跟踪程序的流程,观察CPU每执行一条指令后,各个寄存器及有关存储单元的变化,从而指出和确定产生错误的原因。断点中断:将程序分段,为每段设置一个断点。中断类型号为3。当CPU执行到断点时便产生中断,可以检查各寄存器及有关存储单元的内容。断点可以设置在程序的任何的地方。第20页,本讲稿共59页2.2.硬件中断硬件中断硬件中断又称外中
13、断。硬件中断主要有两种来源:非屏蔽中断(非屏蔽中断(NMINMI)为电源错、内存或为电源错、内存或I/OI/O总线的奇总线的奇偶等异常事件的中断保留的。中断类型号为偶等异常事件的中断保留的。中断类型号为2 2。可屏蔽中断可屏蔽中断来自各种外设的中断。由外设的请求引来自各种外设的中断。由外设的请求引起的中断。起的中断。可屏蔽中断受中断标志可屏蔽中断受中断标志IFIF控制;控制;非屏蔽中断和非屏蔽中断和IFIF位无关。位无关。第21页,本讲稿共59页可屏蔽中断可屏蔽中断 从外设发出中断请求到CPU响应中断,有两个控制条件起决定性作用:该外设的中断请求是否屏蔽该外设的中断请求是否屏蔽由中断屏蔽寄存器
14、(由中断屏蔽寄存器(IMRIMR)控制。控制。CPUCPU是否允许响应中断是否允许响应中断由标志寄存器(由标志寄存器(FLAGSFLAGS)中的中断)中的中断允许位允许位IFIF控制。控制。第22页,本讲稿共59页中断屏蔽寄存器中断屏蔽寄存器中断屏蔽寄存器的端口地址是21H,如图8.4所示。中断屏蔽寄存器可分别控制某个可屏蔽中断源。在编写中断程序时,应在主程序的初始化部分设置好中断屏蔽寄存器,以确定允许用中断方式工作的外部设备。;系统重设键盘中断系统重设键盘中断ININAL,21HAL,21HMOVMOVAL,11111101BAL,11111101BOUTOUT21H,AL21H,AL第23
15、页,本讲稿共59页控制控制CPUCPU的中断允许标志的中断允许标志IFIFCPU是否响应中断还与中断允许标志IF有关。IF=0,CPU禁止响应任何外设的中断(关中断);IF=1,允许CPU响应外设的中断请求(开中断)。中断允许标志IF是控制所有可屏蔽中断的。当任何类型的中断发生时,当前的FLAGS要入栈保存,然后清除IF位,进入中断处理程序,如果允许在一个中断处理程序的执行过程中发生硬中断,则必须用一条STI指令开中断。当中断返回时,恢复了原FLAGS的值,其中IF=1,则允许硬中断再次发生。STISTI设置中断允许位(设置中断允许位(IF=1IF=1)CLICLI清除中断允许位(清除中断允许
16、位(IF=0IF=0)第24页,本讲稿共59页中断命令寄存器中断命令寄存器 在一次中断处理结束之前,还应给8259A的可编程中断控制器的中断命令寄存器发出中断结束命令(EOI:end of interrupt),否则以后将屏蔽掉对同级中断或低级中断的处理。中断命令寄存器的I/O端口地址为20H(如图8.4所示)。在中断处理过程中,也可利用EOI命令清除当前中断请求,以响应同级或低级中断。;结束硬件中断结束硬件中断MOVMOVAL,20HAL,20HOUTOUT20H,AL20H,AL第25页,本讲稿共59页8.3.2 8.3.2 中断向量表中断向量表每个中断都有一个中断类型号。80 x86可处
17、理256种类型的中断,类型号为00FFH。中断向量表就是各类型中断处理程序的入口地址表。存储器的最低1.5KB,从00005FFH为系统占用,其中,最低的1KB,从0000003FFH存放中断向量表。256个中断向量,每个中断向量占4个字节。每类中断向量的地址中断类型号每类中断向量的地址中断类型号44。图8.5给出了中断向量表。表8.2给出了中断向量表地址分配。图8.6展示了中断操作步骤。第26页,本讲稿共59页中断操作步骤中断操作步骤中断操作步骤:取中断类型号;计算中断向量地址;取中断向量,偏移地址送IP,段地址送DS;转入中断处理程序;中断返回到INT指令的下一条指令。第27页,本讲稿共5
18、9页为中断类型为中断类型N N设置中断向量设置中断向量MOVMOVAX,0AX,0MOVMOVES,AXES,AXMOVMOVBX,N*4BX,N*4MOVMOVAX,OFFSET INTHANDAX,OFFSET INTHANDMOVMOVES:WORD PTRBX,AXES:WORD PTRBX,AXMOVMOVAX,SEG INTHANDAX,SEG INTHANDMOVMOVES:WORD PTRBX+2,AXES:WORD PTRBX+2,AXINTHAND:INTHAND:IRETIRET 用户可以利用保留的中断类型号扩充自己需要的中断功能,用户可以利用保留的中断类型号扩充自己需要
19、的中断功能,对新增加的中断功能要在中断类型表中建立相应的中断向量。对新增加的中断功能要在中断类型表中建立相应的中断向量。第28页,本讲稿共59页使用使用DOSDOS功能调用(功能调用(21H21H)存取中断向量)存取中断向量例例8.48.4使用使用DOSDOS功能调用存取中断向量功能调用存取中断向量第29页,本讲稿共59页8.3.3 8.3.3 中断过程中断过程 当中断发生时,由中断机构自动完成下列操作:取中断类型号取中断类型号N N;标志寄存器(标志寄存器(FLAGSFLAGS)内容入栈;)内容入栈;当前代码段寄存器(当前代码段寄存器(CSCS)内容入栈;)内容入栈;当前指令指针寄存器(当前
20、指令指针寄存器(IPIP)内容入栈;)内容入栈;禁止硬件中断和单步中断(禁止硬件中断和单步中断(IF=0,TF=0IF=0,TF=0););从中断向量表中取从中断向量表中取4N4N的字内容送的字内容送IPIP,取,取4N+24N+2的字内容送的字内容送CSCS;转中断处理程序。转中断处理程序。如图8.7的中断过程示意图。第30页,本讲稿共59页8.3.4 8.3.4 中断优先级和中断嵌套中断优先级和中断嵌套 8086规定的中断优先级次序为:优先级 高软件中断(除法错,INTO,INT)非屏蔽中断(NMI)可屏蔽中断(INTR)低单步中断 可屏蔽中断的优先权分为八级,正常情况下,优先级次序是:I
21、R0,IR1,IR2,IR3,IR4,IR5,IR6,IR7定时器打印机优先级高低第31页,本讲稿共59页8259A8259A的中断命令寄存器控制优先级的中断命令寄存器控制优先级 8259A的中断命令寄存器的第6、7位控制各种中断请求的优先级次序。RSL00正常优先级方式01清除由L2L0指定的中断请求10各中断优先级依次左循环一个位置11各中断优先级依次循环到由L2L0指定的中断请求到达最低优先级位置上;使优先级次序再左循环一个位置使优先级次序再左循环一个位置MOVMOVAL,10100000AL,10100000OUTOUT20H,AL20H,AL;IR6,IR7,IR0,IR1,IR2,
22、IR3,IR4,IR5;IR6,IR7,IR0,IR1,IR2,IR3,IR4,IR5第32页,本讲稿共59页中断嵌套中断嵌套 中断嵌套:正在运行的中断处理程序,又被其他中断源中断的情况。80 x86没有规定中断嵌套的深度(中断程序又被中断的层次),实际受堆栈容量的限制。一个中断处理程序,在开中断的情况下,可以被优先级高于它的中断源中断。只有发出了EOI命令,清除正在执行的中断请求,才可以响应同级或低级的中断。如图8.8所示:正常优先级方式下,优先级中断和中断嵌套发生时的处理过程。第33页,本讲稿共59页8.3.5 8.3.5 中断处理程序中断处理程序 主程序为响应中断所做的准备工作以及硬件(
23、包括CPU和外设接口)自动完成以下动作:第34页,本讲稿共59页中断响应的特殊情况中断响应的特殊情况 注意:设备发到CPU的中断请求信号在时间上是随机的,只要未被屏蔽的设备本身的状态是准备好或空闲的,它就会向CPU请求中断,如果此时CPU正在执行一条指令,那么要等到这条指令执行完后,才响应中断。加封锁的指令(如LOCK MOV AX,BX)应看作一条指令;对加重复前缀的指令(如REP MOVSB)要作为一个整体来处理,执行一次重复串指令即可响应中断;对MOV、POP指令,如果处理对象是段寄存器,那么执行完本条指令后,接着再执行一条指令才响应中断。对STI和IRET指令,也要在该指令执行完后,再
24、执行一条指令才响应中断。第35页,本讲稿共59页中断处理子程序中断处理子程序 中断处理子程序的编写步骤:保存寄存器内容;如允许嵌套,则开中断(STI);处理中断;关中断(CLI);送中断结束命令(EOI)给中断命令寄存器;恢复寄存器内容;返回被中断的程序(IRET)。注意:注意:CPUCPU产生一次中断,产生一次中断,I/OI/O设备只完成一个字节(或设备只完成一个字节(或字)的输入输出,所以中断字)的输入输出,所以中断处理程序所用的指针变量或处理程序所用的指针变量或数据变量一般应设置存储单数据变量一般应设置存储单元来保存。元来保存。第36页,本讲稿共59页中断程序设计举例中断程序设计举例 例
25、例8.58.5 响铃响铃P300-303P300-303例例8.68.6键盘输入、打印机输出键盘输入、打印机输出P303-310P303-310例例8.78.7 P310-313 P310-313除数为除数为0 0的中断处理程序的中断处理程序第37页,本讲稿共59页练习与作业练习与作业P313-314 习题练习:8.5、8.6提交作业:8.12第38页,本讲稿共59页I/OI/O接口电路示意图接口电路示意图 处处理理器器数据寄存器状态寄存器控制寄存器输输入入输输出出设设备备数据总线控制总线地址总线外设数据状态信号控制信号I/O接口电路第39页,本讲稿共59页表表8.1 I/O8.1 I/O端口
26、地址分配端口地址分配 第40页,本讲稿共59页 例例8.1 8.1 发声程序发声程序-1-1 这是一个最基本的控制扬声器发出声音的子程序。通过I/O指令使设备控制寄存器(I/O端口地址为61H)的第一位交替为0和1,而端口61H的第1位和扬声器的脉冲门相连(见图8.1),当第1位由0变为1,延迟一会又由1变为0时,脉冲门就先打开后关闭,产生了一个脉冲电流。这个脉冲电流被放大后送到扬声器使之发出了声音。61H端口的第0位和一个振荡器(2号定时器)相连,现在不用振荡器产生声音,所以把第0位置零。第41页,本讲稿共59页 例例8.1 8.1 发声程序发声程序-2-2;入口参数:声音频率BX=6000
27、,发声延迟CX=1000。SOUNDPROCNEARPUSHAXPUSHDXMOV DX,CXINAL,61HANDAL,11111100BTRIG:XORAL,2OUT61H,ALMOVCX,BX;控制脉冲门开关DELAY:;的时间第42页,本讲稿共59页 例例8.1 8.1 发声程序发声程序-3-3LOOPDELAYDECDXJNETRIGPOPDXPOPAXRETSOUNDENDP第43页,本讲稿共59页 图图8.1 8.1 设备控制器设备控制器 通常一个外设的数据端口是通常一个外设的数据端口是8 8位的,而状态与控制信息只位的,而状态与控制信息只需一位或两位,所以不同外设的状态和控制位
28、可共用一个端需一位或两位,所以不同外设的状态和控制位可共用一个端口。口。61H61H端口的端口的0 0、1 1位是控制扬声器的,位是控制扬声器的,2 27 7位分别控制其他位分别控制其他外部设备。外部设备。第44页,本讲稿共59页程序查询程序查询I/OI/O方式方式 这种这种CPUCPU与外设交换信息的方式称为查询方式或等待方式。与外设交换信息的方式称为查询方式或等待方式。造成造成CPUCPU必须查询等待的主要原因是许多外设工作速度比较低。必须查询等待的主要原因是许多外设工作速度比较低。查询方式的优点:可以用程序安排几个输入输出设备的先后优先查询方式的优点:可以用程序安排几个输入输出设备的先后
29、优先次序,最先查询的设备,其工作的优先级也最高。次序,最先查询的设备,其工作的优先级也最高。查询方式的缺点:浪费了查询方式的缺点:浪费了CPUCPU的时间,而且由查询转向相应的处的时间,而且由查询转向相应的处理陈许的时间较长,尤其是在设备比较多的情况下。理陈许的时间较长,尤其是在设备比较多的情况下。为了提高为了提高CPUCPU的工作效率,可以采用中断方式传送数据。的工作效率,可以采用中断方式传送数据。第45页,本讲稿共59页 例例8.2 8.2 打印字符程序打印字符程序-1-1 采用查询方式的打印字符程序。程序通过反复读取并测试打印机的状态来控制输出。数据寄存器的端口地址为378H,状态寄存器
30、的端口地址为379H,控制寄存器的端口地址为37AH。它们各位的含义如图8.2所示。第46页,本讲稿共59页 例例8.2 8.2 打印字符程序打印字符程序-2-2.model small.model small.stack.stack.data.datamessmessdbdbPrinter is normal,0dh,0ahPrinter is normal,0dh,0ahcountcountequequ$-mess$-mess.code.code.startup.startupmovmovsi,offset messsi,offset messmovmovcx,countcx,countn
31、ext:next:movmovdx,379hdx,379hwait:wait:ininal,dxal,dxtesttestal,80hal,80h 测试状态寄存器的第测试状态寄存器的第7 7位,如果为位,如果为0 0,表示打印机忙,表示打印机忙,这时这时CPUCPU不能送出打印数据;所以程序再次循环,直到第不能送出打印数据;所以程序再次循环,直到第7 7位变为位变为1 1,表示打印机空闲,程序才从数据区读取一个字,表示打印机空闲,程序才从数据区读取一个字符送到打印机的数据寄存器。并由控制器发出一个选通信符送到打印机的数据寄存器。并由控制器发出一个选通信号(端口号(端口37AH37AH的第的第0
32、 0位),控制打印机将这个字符打印输位),控制打印机将这个字符打印输出。出。第47页,本讲稿共59页 例例8.2 8.2 打印字符程序打印字符程序-3-3jewaitmoval,simovdx,378houtdx,almovdx,37ahmoval,0dhoutdx,alincsiloopnext.exit0end第48页,本讲稿共59页 图图8.2 8.2 打印机的状态寄存器和控制寄存器打印机的状态寄存器和控制寄存器第49页,本讲稿共59页 例例8.3 8.3 轮流查询轮流查询-1-1 CPU要从3个设备轮流输入数据,PROC1、PROC2、PROC3分别是设备1、设备2和设备3的数据输入程
33、序,它们的状态寄存器的端口地址分别是STAT1、STAT2、STAT3,这三个状态寄存器的第5位是输入准备位。INPUT:INAL,STAT1TESTAL,20HJZDEV2CALLFAR PTR PROC1DEV2:INAL,STAT2TESTAL,20HJZDEV3第50页,本讲稿共59页 例例8.3 8.3 轮流查询轮流查询-2-2CALLCALLFARFARPTR PROC2PTR PROC2DEV3:DEV3:ININAL,STAT3AL,STAT3TESTTESTAL,20HAL,20HJZJZNO_INPUTNO_INPUTCALLCALLFARFARPTRPTRPROC3PRO
34、C3NO_INPUT:NO_INPUT:第51页,本讲稿共59页 图图8.3 80X868.3 80X86中断源中断源第52页,本讲稿共59页 图图8.5 8.5 中断向量表中断向量表第53页,本讲稿共59页 表表8.2 8.2 中断向量表地址分配中断向量表地址分配第54页,本讲稿共59页 图图8.6 8.6 中断操作步骤中断操作步骤第55页,本讲稿共59页 例例8.4-18.4-1MOVAL,NMOVAH,35HINT21HPUSHES;保存原来的N号中断向量PUSHBXPUSHDSMOVAX,SEG INTHANDMOVDS,AXMOVDX,OFFSET INTHANDMOVAL,NMOV
35、AH,25H;将INTHAND设置为新的INT21H;N号中断服务程序POPDS第56页,本讲稿共59页 例例8.4-28.4-2POPPOPDXDXPOPPOPDSDSMOVMOVAL,NAL,NMOVMOVAH,25HAH,25HINTINT21H21HRETRETINTHAND:INTHAND:IRETIRET第57页,本讲稿共59页 图图8.7 8.7 中断过程中断过程 如果在执行中断处理程序的过程如果在执行中断处理程序的过程中,还允许外部中断,可通过中,还允许外部中断,可通过STISTI指指令再把令再把IFIF置为置为1 1,即开中断。,即开中断。第58页,本讲稿共59页 图图8.8 8.8 正常优先级方式下的典型中断序列正常优先级方式下的典型中断序列第59页,本讲稿共59页