




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、单片机原理及应用,第五章 MCS-51单片机中断系统与定时/计数器,1、中断的基本概念,中断系统结构,中断响应过程,中断初始化程序及中断服务程序的编写; 2、定时/计数器结构和工作原理,定时/计数器初始化编程。,5.1 中断系统,5.2 定时/计数器,5.1 中断系统,课题引入,CPU与外设之间交换信息的方式有四种:,1)无条件传送 2)查询传送 3)中断传送 4)DMA传送,5.1 中断系统,一、中断的基本概念,中断示意图,1、日常生活中断的例子,教师讲课过程中,同学遇有疑问,随时向老师提问,教师终止当前的讲课,解答学生疑问后再继续之前的讲课。,中断示意图,2、计算机的中断概念,中断是指由于
2、某种随机事件的发生,计算机暂停现行程序的运行,转去执行另一程序,以处理发生的事件,处理完毕后又自动返回原来的程序继续运行。 能引起中断的事件称为中断源。 CPU现行运行的程序称为主程序。 处理随机事件的程序称为中断服务子程序。,3、中断技术的优点,1)分时操作。CPU可以分时为多个I/O设备服务,提高了计算机的利用率; 2)实时响应。CPU能够及时处理应用系统的随机事件,系统的实时性大大增强; 3)可靠性高。CPU具有处理设备故障及掉电等突发性事件的能力,从而使系统可靠性提高。,二、MCS-51的中断系统,1)中断请求信号的产生 ( 中断源如何申请中断?) 2)CPU如何响应?(如何知道有中断
3、请求?是否有求必应?响应后的处理过程?) 3)中断优先权问题; 4)中断的具体服务; 5)中断服务完毕,如何返回原程序。,中断系统应解决如下问题:,二、MCS-51的中断系统,80C51的中断系统有5个中断源,2个优先级,可实现二级中断嵌套 ,其结构如下图所示。,IE0,TCON,SCON,TF0,IE1,TF1,T0,T1,TI,RI,TXD,RXD,ES,ET0,EX0,EX1,ET1,EA,自然优先级,矢量地址,高级中断请求,自然优先级,矢量地址,低级中断请求,PX0,PT0,PX1,PT1,PS,IE,IP,中断标志位,中断源允许,总允许,中断优先级,1、中断源,5个中断源包含2个外部
4、中断和3个内部中断。,2个外部中断,1、中断源,3)TF0(TCON.5),片内定时/计数器T0溢出中断请求标志。当定时/计数器T0发生溢出时,置位TF0,并向CPU申请中断。 4)TF1(TCON.7),片内定时/计数器T1溢出中断请求标志。当定时/计数器T1发生溢出时,置位TF1,并向CPU申请中断。 5)RI(SCON.0)或TI(SCON.1),串行口中断请求标志。当串行口接收完一帧串行数据时置位RI或当串行口发送完一帧串行数据时置位TI,向CPU申请中断。,3个内部中断,2、中断请求标志,IT0:外部中断0触发方式控制位。 当IT0=0时,为电平触发方式。 当IT0=1时,为边沿触发
5、方式(下降沿有效)。 IE0:外部中断0中断请求标志位。 IT1:外部中断1触发方式控制位。 IE1:外部中断1中断请求标志位。 TF0:定时/计数器T0溢出中断请求标志位。 TF1:定时/计数器T1溢出中断请求标志位。,1)TCON的中断标志,TCON (88H),注 意,若外部中断定义为电平触发方式:中断标志位的状态随CPU在每个机器周期采样到的外部中断输入引脚的电平变化而变化,这样能提高CPU对外部中断请求的响应速度。但外部中断源若有请求,必须把有效的低电平保持到请求获得响应时为止,不然就会漏掉;而在中断服务程序结束之前,中断源又必须撤消其有效的低电平,否则中断返回之后将再次产生中断。,
6、注 意,若外部中断定义为边沿触发方式:在相继连续的两次采样中,一个周期采样到外部中断输入为高电平,下一个周期采样到为低电平,则在IE0或IE1中将锁存一个逻辑1。即便是CPU暂时不能响应,中断申请标志也不会丢失,直到CPU响应此中断时才清零。这样,为保证下降沿能被可靠地采样到,外中断引脚上的高低电平(负脉冲的宽度)均至少要保持一个机器周期(若晶振为12MHz时,为1微秒)。,2、中断请求标志,RI:串行口接收中断标志位。当允许串行口接收数据时,每接收完一个串行帧,由硬件置位RI。RI必须由软件清除。 TI:串行口发送中断标志位。当CPU将一个发送数据写入串行口发送缓冲器时,就启动了发送过程。每
7、发送完一个串行帧,由硬件置位TI。CPU响应中断时,不能自动清除TI,TI必须由软件清除。,2)SCON的中断标志,SCON (98H),3、中断的控制,EX0:外部中断0允许位; ET0:定时/计数器T0中断允许位; EX1:外部中断0允许位; ET1:定时/计数器T1中断允许位; ES:串行口中断允许位; EA :CPU中断允许(总允许)位。,1)中断允许控制,IE (A8H),CPU对中断系统所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器IE控制的。,3、中断的控制,PX0:外部中断0优先级设置位; PT0:定时/计数器T0优先级设置位; PX1:外部中断0优先级设置位; PT1:
8、定时/计数器T1优先级设置位; PS:串行口优先级设置位。,2)中断优先级控制,IP (B8H),80C51单片机有两个中断优先级,可实现二级中断服务嵌套,由中断优先级寄存器IP中的相应位的状态来规定每个中断源的优先级 。,注 意,同一优先级中的中断申请不止一个时,则有中断优先权排队问题。同一优先级的中断优先权排队,由中断系统硬件确定的自然优先级形成,其排列如所示:,CPU同时接收到几个中断时,首先响应优先级别最高的中断请求。,正在进行的中断过程不能被新的同级或低优先级的中断请求所中断。,正在进行的低优先级中断服务,能被高优先级中断请求所中断。,MCS-51单片机的中断优先级有三条原则:,三、
9、中断处理过程,1、中断响应的条件,中断源有中断请求; 此中断源的中断允许位为1; CPU开中断(即EA=1)。 同时满足时,CPU才有可能响应中断。,CPU执行程序过程中,在每个机器周期的S5P2期间,中断系统对各个中断源进行采样。这些采样值在下一个机器周期内按优先级和内部顺序被依次查询。 如果某个中断标志在上一个机器周期的S5P2时被置成了1,那么它将于现在的查询周期中及时被发现。接着CPU便执行一条由中断系统提供的硬件LCALL指令,转向被称作中断向量的特定地址单元,进入相应的中断服务程序。,若由于上述条件的阻碍中断未能得到响应,当条件消失时该中断标志却已不再有效,那么该中断将不被响应。,
10、遇以下任一条件,硬件将受阻,不产生LCALL指令: CPU正在处理同级或高优先级中断; 当前查询的机器周期不是所执行指令的最后一个机器周期,即在完成所执行指令前,不会响应中断; 正在执行的指令为RET、RETI或任何访问IE或IP寄存器的指令,即只有在这些指令后面至少再执行一条指令时才能接受中断请求。,注 意,2、中断响应时间,某中断的响应时序图:,若M1周期的S5P2前某中断生效,在S5P2期间其中断请求被锁存到相应的标志位中去;M2恰逢指令的最后一个机器周期,且该指令不是RETI或访问IE、IP的指令。于是,M3和M4便可以执行硬件LCALL指令,M5周期将进入了中断服务程序; 80C51
11、的中断响应时间(从标志置1到进入相应的中断服务),至少要3个完整的机器周期;,3、中断响应过程,将相应的优先级状态触发器置1(以阻断后来的同级或低级的中断请求)。 执行一条硬件LCALL指令,即把程序计数器PC的内容压入堆栈保存,再将相应的中断服务程序的入口地址送入PC。 执行中断服务程序。 中断响应过程的前两步是由中断系统内部自动完成的,而中断服务程序则要由用户编写程序来完成。,4、中断返回,RETI指令的具体功能是: 将中断响应时压入堆栈保存的断点地址从栈顶弹出送回PC,CPU从原来中断的地方继续执行程序; 将相应中断优先级状态触发器清0,通知中断系统,中断服务程序已执行完毕。,不能用RE
12、T指令代替RETI指令。在中断服务程序中PUSH指令与POP指令必须成对使用,否则不能正确返回断点 。,注 意,四、应用,1、主程序部分,1)给堆栈指针SP赋值,设置一个深度适宜的堆栈; 2)如为外部中断,定义触发方式; 3)根据需要给IP赋值,定义中断优先级; 4)给IE赋值,开放中断,即置位EA和其它需要的中断允许位; 5)安排好等待中断过程中主程序应做的操作。,具体设计过程: (包括主程序和中断服务程序的设计步骤),2、中断服务程序部分,1)在相应的中断入口地址单元设置一条跳转指令,使程序转移到中断服务程序的实际入口处; 2)根据需要保护现场; 3)若为电平触发的外部中断,应有中断信号撤
13、除操作; 4)安排中断服务所做的操作; 5)恢复现场; 6)中断返回。,SETB IT0 ; SETB PX0 ; SETB EA ; SETB EX0 ;,例1 若规定外部中断0为电平触发方式,高优先级,试写出有关的初始化程序。,解:,1) 设触发方式,2) 设优先级,3) 开中断,用位操作指令,2、应用举例,用字节操作指令,MOV TCON,#01H MOV IP,#01H MOV IE,#81H,ORG 0000 H ; LJMP MAIN ;主程序转至MAIN处 ORG 0013H ; LJMP INT ;中断服务程序转至INT处 MAIN: SETB IT1 ; 边沿触发 CLR P
14、X1 ; 设为低优先级 SETB EA ; 开总中断 SETB EX1 ; 允许外中断1中断 MOV B, #01H ;设B的初值 HALT: SJMP HALT ;暂停等待中断 INT: MOV A, B ; AB RL A ; 左环移一位 MOV B, A ; 回送 RETI ; 中断返回,例2 若规定外部中断1为边沿触发方式,低优先级,在中断服务程序中将寄存器B的内容左环移一位,B的初值设为01H。试编写主程序与中断服务程序。,解:,返 回,5.2 定时/计数器,课题引入,1、定时器/计数器的功能是什么?单片机为何要提供硬件定时/计数器?,2、实现定时/计数功能的方法有哪些?,1)软件定
15、时 2)时基电路定时 3)可编程芯片定时,各部分如何协调工作完成定时或计数功能?,一、结构及原理,1、结构,一、结构及原理,2、工作原理(T0为例),1)方式选择部分:选择不同的计数脉冲,2)计数部分:对脉冲进行加一计数,3)控制启停部分:控制计数启动/停止,定时方式:对内部机器周期计数 计数方式:对外部引脚P3.4输入脉冲计数,TL0(低8位) + TH0(高8位) TF0(溢出位),TR0(启动位) = 1,二、方式和控制寄存器,1、TMOD方式寄存器,T1 T0,TMOD (89H),GATE:门控位,M1M0:工作方式设置位,GATE0时,只要用软件使TCON中的TR0或TR1为1,就
16、可以启动定时/计数器工作; GATA1时,要用软件使TR0或TR1为1,同时外部中断引脚或也为高电平时,才能启动定时/计数器工作。,定时/计数器有四种工作方式,由M1M0进行设置。,二、方式和控制寄存器,2、TCON控制寄存器,TCON (88H),TR1(TR0):T1(T0)运行控制位,TF1(TF0):T1(T0)溢出中断请求标志位,三、定时/计数器的工作方式(T0为例),1、方式0(13位),振荡器,12,定时方式,计数方式,T0(P3.4),TL0 低5位,TH0 8位,TF0, 设T0方式一定时 MOV TH0, #0FFH MOV TL0, #38H ; 赋初值 SETB TR0 ;启动T0 WAIT: JBC TF0, NEXT ;查询计数 溢出 SJMP WAIT NEXT: CPL P1.0 ; 输出取反 MOV TH0, #0FFH MOV TL0, #38H ; 重赋初值 SJMP WAIT,方式二: ORG 0000H LJMP START ORG 0100H START:MOV TMOD, #02H ; 设T0方式二定时 MOV TH0, #38H MOV TL0, #38H ; 赋初值 SETB TR0 ;启动T0 WAIT: JBC TF0, NEXT ;查询计数 溢出 SJMP WAIT NEXT
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年职业教育校企合作人才培养模式改革与案例实践探索报告
- 2025年全球石油市场供需预测:价格波动与可持续发展研究报告
- 人才奖励资金管理办法
- 临时航路使用管理办法
- 互联网医疗发展2025年在线职业技能提升课程在医疗领域的可行性分析报告
- 企业违规违纪管理办法
- 企业宿舍达标管理办法
- 2025年铀矿资源分布对核能产业战略布局的影响研究报告
- 人才举荐奖励管理办法
- 临时进入人员管理办法
- 民兵护路知识讲座
- 古城墙修复专项施工方案
- 钢筋混凝土全框架结构施工组织设计
- 工程监理大纲监理方案服务方案
- 蛋白组学二维电泳
- GB/T 3372-2010拖拉机和农业、林业机械用轮辋系列
- GB/T 2007.1-1987散装矿产品取样、制样通则手工取样方法
- 一例糖尿病合并脑梗死-护理查房概要
- 2023年宝应县(中小学、幼儿园)教师招聘笔试题库及答案解析
- 公司制成检验记录表
- 全集举一反三课件奥数五年级(数学)
评论
0/150
提交评论