版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1 图图2-13 内部时钟方式电路内部时钟方式电路 2 2.6.2 机器周期、指令周期机器周期、指令周期 各种指令各种指令的的时序与时序与振荡周期相振荡周期相关。关。 1振荡周期振荡周期 时钟控制信号的时钟控制信号的基本时间单位基本时间单位。若晶振频率为。若晶振频率为 fosc,则,则 振荡周期振荡周期 Tosc=1/fosc。如。如 fosc=12MHz,Tosc=1/12s。 2机器周期机器周期 CPU完成一个基本操作所需时间为完成一个基本操作所需时间为机器周期机器周期。执行一条执行一条 指令分为几个机器周期指令分为几个机器周期。每个机器周期完成一个。每个机器周期完成一个基本操作基本操作
2、,如取指令、读或写数据等。每,如取指令、读或写数据等。每12个个振荡周期振荡周期为为1个机器周个机器周 期期。 2 3 1个机器周期个机器周期包括包括12个个振荡周期振荡周期,分,分6个状态个状态:S1S6 。每个。每个状态又分两拍状态又分两拍(相)(相):P1和和P2。因此,一个机器。因此,一个机器 周期中的周期中的12个个振荡周期振荡周期表示为表示为S1P1、S1P2、S2P1、 S2P2、S6P2,如如图图2-16所示所示。 3 图图2-16 AT89S51的机器周期的机器周期 4 3指令周期指令周期 执行一条指令执行一条指令所需的时间所需的时间。简单的。简单的单字节指令单字节指令,取出
3、指,取出指 令立即执行,令立即执行,只需只需一个机器周期一个机器周期的时间的时间。而有些。而有些复杂的指复杂的指 令令,如,如转移、乘、除指令转移、乘、除指令则需则需两个两个或或多个多个机器周期。机器周期。 从指令执行时间看从指令执行时间看: 单字节和双字节单字节和双字节指令指令一般为单机器周期一般为单机器周期和和双机器周期双机器周期; 三字节指令三字节指令都是都是双机器周期双机器周期; 乘、除指令乘、除指令占用占用4个机器周期个机器周期。 4 5 2.7 复位操作和复位电路复位操作和复位电路 单片机的单片机的初始化操作初始化操作,给复位脚,给复位脚RST加上加上大于大于2个机器周期个机器周期
4、( 即即24个振荡周期)的个振荡周期)的高电平高电平就就可可使使AT89S51复位。复位。 2.7.1 复位操作复位操作 复位时,复位时,PC初始化为初始化为0000H,程序从,程序从0000H单元开始执行。单元开始执行。 除系统的正常初始化外,当除系统的正常初始化外,当程序出错程序出错(如程序跑飞)或(如程序跑飞)或操作错操作错 误误使系统处于使系统处于死死机机状态时,状态时,需按复位键需按复位键使使RST脚为高电平,脚为高电平, 使使AT89S51摆脱摆脱“跑飞跑飞”或或“死死机机”状态而重新启动程序。状态而重新启动程序。 6 复位操作还对复位操作还对SFR寄存器寄存器产生产生影响,这些寄
5、存器复位时影响,这些寄存器复位时 的状态的状态见见表表2-7。 由由表表2-7可看出,复位时,可看出,复位时,SP=07H ,而,而P0P3引脚均引脚均 为高电平为高电平。 在某些控制应用中,要在某些控制应用中,要注意考虑注意考虑P0P3引脚的高电平引脚的高电平 对接在这些引脚上的外部电路的影响对接在这些引脚上的外部电路的影响。 例如,例如,当当P1口某个引脚外接一个继电器绕组,当复位口某个引脚外接一个继电器绕组,当复位 时,该引脚为高电平,继电器绕组就会有电流通过,就会时,该引脚为高电平,继电器绕组就会有电流通过,就会 吸合继电器开关,使开关接通,可能会引起意想不到的后吸合继电器开关,使开关
6、接通,可能会引起意想不到的后 果。果。 6 7 8 2.7.2 2.7.2 复位电路设计复位电路设计 8 图图2-182-18 上电复位电路上电复位电路 R=8.2k C=10F =R*C=82ms 9 9 图图2-192-19 手动复位电路手动复位电路 10 第第5 5章章 AT89S51AT89S51单片机的单片机的 中断系统中断系统 10 1111 第第5章章 目录目录 5.1 AT89S51中断技术概述中断技术概述 5.2 AT89S51中断系统结构中断系统结构 5.2.1 中断请求源 5.2.2 中断请求标志寄存器 5.3 中断允许与中断优先级的控制中断允许与中断优先级的控制 5.3
7、.1 中断允许寄存器IE 5.3.2 中断优先级寄存器IP 5.4 响应中断请求的条件响应中断请求的条件 5.5 外部中断的响应时间外部中断的响应时间 12 5.6 外部中断的触发方式选择外部中断的触发方式选择 5.6.1 电平触发方式 5.6.2 边沿触发方式 5.7 中断请求的撤销中断请求的撤销 5.8 中断服务子程序的设计中断服务子程序的设计 5.9 多外部中断源系统设计多外部中断源系统设计 13 内容概要内容概要 n介绍片内功能部件中断系统的介绍片内功能部件中断系统的硬件结构硬件结构和和工作原理工作原理。 n掌握与中断系统掌握与中断系统有关的特殊功能寄存器有关的特殊功能寄存器以及中断系
8、统的以及中断系统的 应用特性。应用特性。 n应能熟练地进行中断系统的应能熟练地进行中断系统的初始化编程初始化编程以及以及中断服务子中断服务子 程序的设计程序的设计。 14 5.1 AT89S515.1 AT89S51中断技术概述中断技术概述 中断技术主要用于中断技术主要用于实时监测与控制实时监测与控制,要求单片机,要求单片机能及能及 时地响应中断请求源提出的服务请求时地响应中断请求源提出的服务请求,并作出快速响应、,并作出快速响应、 及时处理。这是由片内的中断系统来实现的。及时处理。这是由片内的中断系统来实现的。 当中断请求源当中断请求源发出中断请求发出中断请求时,如果中断请求被允许,时,如果
9、中断请求被允许, 单片机就会暂时中止正在执行的主程序,转到中断服务子单片机就会暂时中止正在执行的主程序,转到中断服务子 程序去处理中断服务请求。程序去处理中断服务请求。 中断服务子程序处理完中断服务请求后,再回到原来中断服务子程序处理完中断服务请求后,再回到原来 被中止的程序之处(断点),继续执行被中断的主程序。被中止的程序之处(断点),继续执行被中断的主程序。 图图5-15-1为整个中断响应和处理过程。为整个中断响应和处理过程。 14 1515 图图5-1 中断响应和处理过程中断响应和处理过程 16 如果单片机没有中断系统如果单片机没有中断系统,CPUCPU将会花费大量的时间进行将会花费大量
10、的时间进行 查询操作。查询操作。 采用中断技术完全采用中断技术完全消除了单片机在查询方式中的等待现消除了单片机在查询方式中的等待现 象象,大大地提高了单片机的,大大地提高了单片机的工作效率工作效率和和实时性实时性。 5.2 AT89S515.2 AT89S51中断系统结构中断系统结构 中断系统结构图如中断系统结构图如图图5-25-2所示。所示。 中断系统有中断系统有5 5个个中断请求源(简称中断源),中断请求源(简称中断源),两个中断优两个中断优 先级先级,可实现,可实现两级中断服务程序嵌套两级中断服务程序嵌套。 每一中断源可用软件独立控制为每一中断源可用软件独立控制为允许中断允许中断或或关中
11、断关中断状态,状态, 中断优先级中断优先级均可用软件来设置。均可用软件来设置。 16 17 5.2.1 中断请求源中断请求源 由图5-2可见,AT89S51中断系统共有5个中断请求源: (1) 外部中断请求0,中断请求信号由 引 脚输入,中断请求标志为IE0。 (2) 外部中断请求1,中断请求信号由 引 脚输入,中断请求标志为IE1。 (3)定时器定时器/计数器计数器T0计数溢出发出的中断请求,中断请 求标志为TF0。 (4)定时器定时器/计数器计数器T1计数溢出发出的中断请求,中断请 求标志为TF1。 (5)串行口串行口中断请求,中断请求标志为发送中断TI或接收 中断RI。 17 0INT
12、1INT 0INT 1INT 1818 图图5-2 5-2 AT89S51AT89S51的中断系统结构示意图的中断系统结构示意图 19 5.2.2 中断请求标志寄存器中断请求标志寄存器 5个中断请求源的中断请求标志中断请求标志分别由TCON和SCON 的相应位锁存。 1. TCON寄存器寄存器 为定时器/计数器的控制寄存器,字节地址为88H,可位 寻址。特殊功能寄存器TCON的格式如图图5-3所示。 19 图图5-35-3 特殊功能寄存器特殊功能寄存器TCONTCON的格式的格式 20 TCON各标志位功能如下:各标志位功能如下: (1)TF1定时器/计数器T1的溢出中断请求标志位。 当T1计
13、数产生溢出时,由硬件使TF1置“1”,向CPU申请 中断。CPU响应TF1中断时,TF1标志由硬件自动清由硬件自动清“0”, TF1也可由软件清“0”。 (2)TF0定时器/计数器T0的溢出中断请求标志位,功能 与TF1类似。 (3)IE1外部中断请求1的中断请求标志位。 (4)IE0外部中断请求0中断请求标志位,功能与IE1类似。 (5)IT1选择外部中断请求1为边沿触发还是电平触发。 20 21 IT1=0,电平触发,电平触发方式,引脚 上低电平有效,并把IE1 置“1”。转向中断服务程序时,由硬件自动把IE1清 “0”。 IT1=1,边沿触发边沿触发方式,加到引脚 上的外部中断请求 为从
14、高到低的负跳变负跳变,并把IE1置“1”。转向中断服务程 序时,由硬件自动自动把IE1清“0”。 (6)IT0选择外部中断请求0为边沿触发方式还是电平 触发方式,其意义与IT1类似。 AT89S51复位复位后,TCON被清被清“0”,5个中断源的中 断请求标志均为0。 TR1(D6位)、TR0(D4位)这2位与中断系统无关与中断系统无关, 将在第6章定时器/计数器中介绍。 21 22 2. SCON寄存器寄存器 串行口控制寄存器,字节地址为98H,可位寻址可位寻址。 低二位锁存串行口的发送中断和接收中断的中断请求标 志TI和RI,格式如图图5-4所示所示。 图图5-4 SCON中的中断请求标志
15、位中的中断请求标志位 各标志位的功能: (1)TI串行口的发送中断请求标志位。每发送完一 帧串行数据后,TI自动置“1”。TI标志必须由软件清必须由软件清 “0”。 22 23 (2)RI串行口接收中断请求标志位。串行口接收完一个串行口接收中断请求标志位。串行口接收完一个 串行数据帧,硬件自动使串行数据帧,硬件自动使RI中断请求标志置中断请求标志置“1”。必须在中。必须在中 断服务程序中用指令对断服务程序中用指令对RI清清“0”。 5.3 中断允许与中断优先级的控制中断允许与中断优先级的控制 中断允许中断允许控制由中断允许寄存器控制由中断允许寄存器IE控制。控制。 中断优先级中断优先级控制由中
16、断优先级寄存器控制由中断优先级寄存器IP控制。控制。 5.3.1 中断允许寄存器中断允许寄存器IE AT89S51的对各中断源的开放或屏蔽,是由中断允许寄存的对各中断源的开放或屏蔽,是由中断允许寄存 器器IE控制的。控制的。 IE字节地址为字节地址为A8H,可位寻址可位寻址,格式如,格式如图图5-5所示所示。 23 24 图5-5 中断允许寄存器IE的格式 IE对中断的开放和关闭实现两级控制两级控制。 有一个总的中断控制位EA(IE.7位), EA=0时,所有的中断请求被屏蔽; EA=1时,开放中断,但5个中断源的中断请求是否允许, 还要由IE中的低中的低5位位所对应的对应的5个中断请求允许控
17、制位个中断请求允许控制位的状 态来决定(图5-5)。 24 25 IE中各位功能如下:中各位功能如下: (1)EA中断允许总开关控制位。中断允许总开关控制位。 EA=0,所有的中断请求被屏蔽。,所有的中断请求被屏蔽。 EA=1,所有的中断请求被开放。,所有的中断请求被开放。 (2)ES串行口中断允许位。串行口中断允许位。 ES=0,禁止串行口中断。,禁止串行口中断。 ES=1,允许串行口中断。,允许串行口中断。 (3)ET1定时器定时器/计数器计数器T1的溢出中断允许位。的溢出中断允许位。 ET1=0,禁止,禁止T1溢出中断。溢出中断。 ET1=1,允许,允许T1溢出中断。溢出中断。 (4)E
18、X1外部中断外部中断1中断允许位。中断允许位。 25 26 EX1=0,禁止外部中断,禁止外部中断1中断。中断。 EX1=1,允许外部中断,允许外部中断1中断。中断。 (5)ET0定时器定时器/计数器计数器T0的溢出中断允许位。的溢出中断允许位。 ET0=0,禁止,禁止T0溢出中断。溢出中断。 ET0=1,允许,允许T0溢出中断。溢出中断。 (6)EX0外部中断外部中断0中断允许位。中断允许位。 EX0=0,禁止外部中断,禁止外部中断0中断。中断。 EX0=1,允许外部中断,允许外部中断0中断。中断。 27 AT89S51复位以后,复位以后,IE被清被清“0”,所有中断请求被禁止。,所有中断请
19、求被禁止。 IE中与各个中断源相应的位可用指令置中与各个中断源相应的位可用指令置“1”或清或清“0”。 若使某一个中断源被允许中断若使某一个中断源被允许中断,除了,除了IE相应的位被置相应的位被置“1” 外,还必须使外,还必须使EA位置位置“1”。 改变改变IE的内容的内容,可由,可由位操作指令位操作指令来实现(即来实现(即SETB bit; CLR bit),也可用),也可用字节操作指令字节操作指令实现。实现。 27 28 【例例5-1】 若允许片内2个定时器/计数器中断,并禁止 其他中断源的中断请求,请编写设置IE的相应程序段。 (1)用位操作指令)用位操作指令 CLRES;禁止串行口中断
20、;禁止串行口中断 CLREX0;禁止外部中断;禁止外部中断0中断中断 CLREX1;禁止外部中断;禁止外部中断1中断中断 SETBET0;允许定时器;允许定时器/计数器计数器T0中断中断 SETBET1;允许定时器;允许定时器/计数器计数器T1中断中断 SETBEA ;总中断开关位开放;总中断开关位开放 (2)用字节操作指令)用字节操作指令 MOV IE,#8AH 上述两段程序对IE的设置是相同的。 28 29 5.3.2 中断优先级寄存器中断优先级寄存器IP AT89S51的中断请求源有两个中断优先级两个中断优先级,由软件分别设 置为高高优先级中断优先级中断或低低优先级中断优先级中断,可实现
21、: 两级中断嵌套两级中断嵌套 AT89S51正在执行低优先级中断的服务程序时,可被高优 先级中断请求所中断,待高优先级中断处理完毕后,再返回低 优先级中断服务程序。两级中断嵌套两级中断嵌套的过程过程如图图5-6所示。 29 3030 图5-6 两级中断嵌套的过程 31 各中断源的中断优先级关系,可归纳为两条基本规则两条基本规则: (1)低优先级可被高优先级中断,但高优先级不能被)低优先级可被高优先级中断,但高优先级不能被 低优先级中断。低优先级中断。如果某一中断源被设置为高优先级中断, 则不能被任何其他的中断源的中断请求所中断。 (2)任何一种中断中断一旦得到响应,不会再被它的同级不会再被它的
22、同级 中断源所中断中断源所中断。 中断优先级寄存器IP,其字节地址为字节地址为B8H,可位寻址。 只要用程序改变其内容,可进行各中断源中断优先级的设中断优先级的设 置置,IP寄存器的格式如图5-7所示。 31 32 图5-7 IP寄存器的格式 中断优先级寄存器IP各位的含义各位的含义如下: (1)PS串行口中断优先级控制位 1:高优先级 0:低优先级 (2)PT1定时器T1中断优先级控制位 1:高优先级 0:低优先级 32 33 (3)PX1外部中断1中断优先级控制位 1:高优先级 0:低优先级 (4)PT0定时器T0中断优先级控制位 1:高优先级 0:低优先级 (5)PX0外部中断0中断优先
23、级控制位 1:高优先级 0:低优先级 中断优先级控制寄存器IP用位操作指令或字节操作指令 可更新IP的内容,以改变中断优先级。 AT89S51复位复位以后,IP的内容为0,各个中断源均为低均为低 优先级优先级中断。 33 34 AT89S51的中断系统有的中断系统有两个不可寻址的两个不可寻址的“优先级激活优先级激活” 触发器。触发器。 一个指示某高优先级一个指示某高优先级的中断正在执行,所有后来的中断的中断正在执行,所有后来的中断 均被阻止;均被阻止;另一个触发器指示某低优先级另一个触发器指示某低优先级的中断正在执行,的中断正在执行, 所有同级的中断都被阻止,但不阻断高优先级的中断请求。所有同
24、级的中断都被阻止,但不阻断高优先级的中断请求。 在同时收到在同时收到几个同优先级的中断请求几个同优先级的中断请求时,哪一个中断请时,哪一个中断请 求能优先得到响应,求能优先得到响应,取决于内部的查询顺序。取决于内部的查询顺序。这相当于在这相当于在 同一个优先级内,还同时存在另一个辅助优先级结构,其同一个优先级内,还同时存在另一个辅助优先级结构,其 查询顺序见查询顺序见表表5-1。 34 35 表表5-1 同级中断的查询次序同级中断的查询次序 由此可见,各中断源在同一个优先级的条件下,外部中外部中 断断0的中断优先权最高最高,串行口中断串行口中断优先权最低最低。 35 36 【例例5-25-2】
25、 请对 IP寄存器进行初始化,AT89S51的两两 个外中断个外中断请求为高优先级,其他中断请求为低优先级。 (1)用位操作指令)用位操作指令 SETB PX0SETB PX0;外中断;外中断0 0设置为高优先级设置为高优先级 SETB PX1SETB PX1;外中断;外中断1 1设置为高优先级设置为高优先级 CLR PSCLR PS;串行口设置为低优先级;串行口设置为低优先级 CLR PT0CLR PT0;定时器;定时器/ /计数器计数器T0T0为低优先级为低优先级 CLR PT1CLR PT1;定时器;定时器/ /计数器计数器T1T1为低优先级为低优先级 (2)用字节操作指令)用字节操作指
26、令 MOV IPMOV IP,#05H#05H 36 37 5.4 响应中断请求的条件响应中断请求的条件 中断请求被响应,必须满足以下必要条件:必须满足以下必要条件: (1)总中断允许总中断允许开关接通,即IE寄存器中的中断总允许 位EA=1。 (2)该中断源发出中断请求发出中断请求,即对应的中断请求标志为对应的中断请求标志为 “1”。 (3)该中断源的中断允许位为中断允许位为“1”,即该中断被允许。 (4)无同级无同级或更高级中断更高级中断正在被服务。 当CPU查询到有效的中断请求,在满足上述条件时,立 即进行中断响应。 37 38 中断响应的过程:中断响应的过程: 首先由硬件自动生成一条长
27、调用指令自动生成一条长调用指令“LCALL addr16”, addr16就是程序存储区中相应的中断子程序入口地址相应的中断子程序入口地址。 例如,例如,对于外部中断1的响应,硬件自动生成的长调用 指令为: LCALL 0013H 首先将程序计数器PC的内容的内容压入堆栈压入堆栈以保护断点,再 将中断入口地址装入中断入口地址装入PC,使程序转向响应中断请求的中 断入口地址。 各中断源服务程序的入口地址入口地址,如表5-2所示。 38 39 表表5-2 5-2 中断入口地址表中断入口地址表 两个中断入口间只相隔两个中断入口间只相隔8字节字节,难以安放一个完整的中 断服务程序。因此,通常在中断入口
28、地址处放置一条无条通常在中断入口地址处放置一条无条 件转移指令件转移指令,使程序执行转向中断服务程序入口。 39 40 中断响应是有条件的,当遇到下列三种情况三种情况之一时,中 断响应被封锁: (1)CPU正在处理同级或更高优先级正在处理同级或更高优先级的中断。 (2)所查询的机器周期不是当前正在执行指令的最后不是当前正在执行指令的最后 一个机器周期一个机器周期。只有在当前指令执行完毕后,才能进行中 断响应,以确保当前指令执行的完整性指令执行的完整性。 (3)正在执行的指令是RETI或是访问IE或IP的指令。 因为按照AT89S51中断系统的规定,在执行完这些指令后, 需要再执行完一条指令,才
29、能响应新的中断请求。 如果存在上述三种情况之一,CPU将丢弃中断查询结果, 不能对中断进行响应。 40 41 5.5 外部中断的响应时间外部中断的响应时间 使用外部中断外部中断时,需考虑从外部中断请求到转向中断入外部中断请求到转向中断入 口地址所需的时间口地址所需的时间。 外部中断的最短最短响应时间为响应时间为3个机器周期个机器周期。其中中断请 求标志位查询占标志位查询占1个机器周期个机器周期,而这个机器周期恰好处于指 令的最后一个机器周期。在这个机器周期结束后,中断即 被响应,CPU接着执行一条硬件子程序调用指令硬件子程序调用指令LCALL到 相中断服务程序入口,需要需要2个机器周期个机器周
30、期。 外部中断响应的最长最长时间为时间为8个机器周期个机器周期。在CPU进行 中断标志查询时,刚好才开始执行RETI或访问IE或IP的指 令,需执行完指令再继续执行一条指令后,才响应中断。 41 42 执行RETI或访问IE或IP的指令,最长需要2个机器周期个机器周期。 接着再执行一条指令,最长指令(乘法指令MUL和除法 指令DIV)来算,也只有4个个机器周期机器周期。再加上硬件子程序 调用指令LCALL的执行,需要2个个机器周期机器周期,所以,外部 中断响应的最长时间为8个机器周期。 如果已经在处理同级或更高级中断处理同级或更高级中断,外部中断请求的响 应时间取决于正在执行的中断服务程序的处
31、理时间,这种 情况下,响应时间就无法计算了。 这样,在一个单一中断单一中断的系统里,AT89S51单片机对 外部中断请求的响应时间总是在38个机器周期个机器周期之间。 42 43 5.6 外部中断的触发方式选择外部中断的触发方式选择 两种触发方式:电平触发方式和边沿触发方式。 5.6.1 电平触发方式电平触发方式 外部中断申请触发器的状态随着CPU在每个机器周期采 样到的外部中断输入引脚的电平变化而变化。 在中断服务程序返回之前中断服务程序返回之前,外中断请求输入必须无效外中断请求输入必须无效 (即外部中断请求输入已由低电平变为高电平),否则会 再次响应中断。 所以本方式适合于适合于外部中断以
32、低电平输入以低电平输入且中断服务程 序能清除外部中断请求源清除外部中断请求源(即外中断输入电平又变为高电 平)的情况。 43 44 5.6.2 边沿触发方式边沿触发方式 外部中断申请触发器能锁存外部中断输入线上的锁存外部中断输入线上的负跳变负跳变。 即使不能响应,中断请求标志也不会丢失。 连续两次采样,第一个机器周期为高,第二个机器周期 为低,则中断申请触发器置1,直到CPU响应此中断时, 才清0。 输入的负脉冲至少要保持1个机器周期的宽度,才能被 采样到。 5.7 中断请求的撤销中断请求的撤销 某个中断请求被响应后,就存在着一个中断请求的撤销 问题。 44 45 1定时器定时器/计数器中断请
33、求的撤销计数器中断请求的撤销 硬件会自动把中断请求标志位(TF0或TF1)清0,自动自动 撤销撤销。 2外部中断请求的撤销外部中断请求的撤销 (1)边沿方式外部中断请求的撤销)边沿方式外部中断请求的撤销 包括两项:中断标志位清中断标志位清0和外中断信号的撤销外中断信号的撤销。 中断标志位清中断标志位清0是在中断响应后由硬件自动完成的。 外中断请求信号的撤销外中断请求信号的撤销,由于边沿信号过后也就消失了, 自动撤销。 45 46 (2)电平方式外部中断请求的撤销)电平方式外部中断请求的撤销 电平方式外中断请求的撤销,其中中断请求标志自动撤电平方式外中断请求的撤销,其中中断请求标志自动撤 销,但
34、中断请求信号的低电平可能继续存在,为此,除了销,但中断请求信号的低电平可能继续存在,为此,除了 标志位清标志位清“0”之外,还需在中断响应后之外,还需在中断响应后把中断请求信号把中断请求信号 输入引脚从输入引脚从低电平低电平强制改变为强制改变为高电平高电平,如,如图图5-8所示。所示。 46 图5-8 电平方式的外部中断请求的撤销电路 47 由图5-8,用D触发器锁存触发器锁存外来的中断请求外来的中断请求低电平低电平,并 通过D触发器的输出端Q接到 (或 )。所以, 增加的D触发器不影响中断请求。 中断响应后,利用D触发器的SD端接AT89S51的P1.0 端。因此,只要P1.0端输出一个负脉
35、冲就可以使端输出一个负脉冲就可以使D触发器触发器 置置“1”,撤销低电平的中断请求信号。 负脉冲负脉冲可在中断服务程序中增加如下指令: ORL P1,#01H;P1.0为为“1” ANL P1,#0FEH;P1.0为为“0” ORL P1,#01H;P1.0为为“1” 47 INT01INT 48 3串行口中断请求的撤销串行口中断请求的撤销 响应串行口的中断后,CPU无法知道是接收中断还是发 送中断,还需测试这两个中断标志位,以判定是接收操作判定是接收操作 还是发送操作还是发送操作,然后才清除。所以串行口中断请求的撤销 只能使用只能使用软件软件的方法的方法,在中断服务程序中进行,即用如下 指令
36、在中断服务程序中对串行口中断标志位进行清除: CLR TI ;清;清TI标志位标志位 CLR RI ;清;清RI标志位标志位 5.8 中断服务子程序的设计中断服务子程序的设计 中断系统的运行必须与中断服务子程序配合才能正确使 用。设计中断服务子程序需要首先明确以下几个问题。 48 49 1中断服务子程序设计的任务中断服务子程序设计的任务 任务有下列4条: (1)设置中断允许控制寄存器设置中断允许控制寄存器IE,允许相应的中断请 求源中断。 (2)设置中断优先级寄存器设置中断优先级寄存器IP,确定所使用的中断源 的优先级。 (3)若是外部中断源若是外部中断源,还要设置中断请求的触发方式触发方式
37、决定采用电平触发方式还是边沿触发方式。 (4)编写中断服务子程序编写中断服务子程序,处理中断请求。 49 50 前3条一般放在主程序的初始化程序段中。 【例例5-35-3】 假设允许外部中断外部中断0中断中断,设定为高级高级中断, 采用边沿触发方式,其他中断源为低级中断。初始化程序 如下: SETB EA;EA 位置1,总中断开关位开放 SETB ET0;ET0位置1,允许外部中断0产生中断 SETB PX0;PX0位置1,外部中断0为高优先级中断 SETB IT0 ;IT0位置1,外部中断0为边沿触发方式 50 51 2采用中断时的主程序结构采用中断时的主程序结构 程序必须先从主程序起始地址
38、主程序起始地址0000H执行。所以,在在 0000H起始地址的几个字节中,用无条件转移指令起始地址的几个字节中,用无条件转移指令,跳向 主程序。 另外,各中断入口地址之间依次相差8字节,中断服务 子程序稍长就超过8字节,这样中断服务子程序就占用了 其他的中断入口地址,影响其他中断源的中断处理。为此, 一般在进入中断后,用一般在进入中断后,用一条无条件转移指令一条无条件转移指令,把中断服务,把中断服务 子程序子程序跳转到跳转到远离其他中断入口的入口地址处。远离其他中断入口的入口地址处。 51 52 常用的主程序结构主程序结构如下: ORG0000H LJMP MAIN ORG X1X2X3X4H
39、;X1X2X3X4H为某中断源的中断入口 LJMP INT;INT为某中断源的中断入口标号 ORG Y1Y2Y3Y4H;Y1Y2Y3Y4H为主程序入口 MAIN:主程序 INT: 中断服务子程序 注意:注意:如果有多个中断源,就有多个“ORG X1X2X3X4H” 的入口地址,多个“中断入口地址”必须依次由小到大排列必须依次由小到大排列。 主程序MAIN的起始地址Y1Y2Y3Y4H,根据具体情况来安排。 52 53 3中断服务子程序的流程中断服务子程序的流程 中断服务子程序的基本 流程如图5-9所示。下面 对有关中断服务子程序 执行过程中的一些问题 进行说明。 53 图5-9 中断子服务程序的
40、基本流程 54 (1)现场保护和现场恢复)现场保护和现场恢复 现场是指单片机中某些寄存器和存储器单元中的数据或 状态。为使中断服务子程序的执行不破坏这些数据或状态, 因此要送入堆栈保存起来,这就是现场保护现场保护。 现场保护现场保护一定要位于中断处理程序的位于中断处理程序的前面前面。中断处理结 束后,在返回主程序前,则需要把保存的现场内容从堆栈 中弹出恢复原有内容,这就是现场恢复现场恢复。 现场恢复现场恢复一定要位于中断处理的中断处理的后面后面。 AT89S51的堆栈操作指令: “PUSH direct”和“POP direct”,是供现场保护和 现场恢复使用的。要保护哪些内容,应根据具体情况
41、来定。 54 55 (2)关中断和开中断)关中断和开中断 现场保护前现场保护前和现场恢复前现场恢复前关中断,是为防止此时有高一 级的中断进入,避免现场被破坏。 在现场保护和现场恢复之后的开中断在现场保护和现场恢复之后的开中断是为下一次的中断 做好准备,也为了允许有更高级的中断进入。这样,中断 处理可以被打断,但原来的现场保护和现场恢复不允许更 改,除了现场保护和现场恢复的片刻外,仍然保持着中断 嵌套的功能。 但有时候,一个重要的中断,必须执行完毕,不允许被但有时候,一个重要的中断,必须执行完毕,不允许被 其他的中断嵌套。其他的中断嵌套。可在现场保护前先关闭总中断开关位, 待中断处理完毕后再开总
42、中断开关位。这样,需把图5-9 中的“中断处理”步骤前后的“开中断”和“关中断” 去掉。 55 56 (3)中断处理)中断处理 应用设计者根据任务的具体要求,来编写中断处理部分 的程序。 (4)中断返回)中断返回 中断服务子程序最后一条指令必须是返回指令最后一条指令必须是返回指令RETI。 CPU执行完这条指令后,把响应中断时所置把响应中断时所置1的不可寻址的不可寻址 的优先级状态触发器清的优先级状态触发器清0,然后从堆栈中弹出栈顶上的两 个字节的断点地址送到程序计数器PC,弹出的第一个字 节送入PCH,弹出的第二个字节送入PCL,从断点处重新 执行主程序。 56 57 【例例5-4】 根据图5-9流程,编写中断服务程序。设现场保 护只将PSW寄存器和累加器A的内容压入堆栈中保护。一个 典型的中断服务子程序如下: INT:CLR EA;CPU关中断 PUSH PSW;现场保护 PUSH Acc SETB EA;总中断允许 中断处理段中断处理段 CLR EA;关中断 POP Acc;现场恢复 POP PSW
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 随州市随县2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 本溪市桓仁满族自治县2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 晋中市介休市2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 潍坊市安丘市2025-2026学年第二学期五年级语文第六单元测试卷(部编版含答案)
- 眉山地区仁寿县2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 锡林郭勒盟正蓝旗2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 包头市东河区2025-2026学年第二学期六年级语文第五单元测试卷部编版含答案
- 电器策划方案
- 深度解析(2026)《CBT 4386-2015集装箱绑扎杆存放架》
- 深度解析(2026)《CBT 3557-1995船用防火风闸》
- 2025年工业CT在军事弹药失效分析报告
- 2026年浙江单招酒店管理专业面试经典题含答案含应急处理题
- SJG 171-2024建筑工程消耗量标准
- 浙江省金丽衢十二校2026届高三上学期一模试题 英语 含解析
- 新疆维吾尔自治区小学五年级下学期数学第二单元测试卷-因数和倍数单元检测
- 专升本康复治疗2025年物理治疗学测试试卷(含答案)
- 2025年教职人员个人总结
- 钉钉OA管理系统
- 17918-2025港口散粮装卸系统粉尘防爆安全规范
- 2025高二英语阅读理解专项训练120篇
- 2026年版全国助理社会工作师《社会工作实务》考试题含答案(培优a卷)
评论
0/150
提交评论