第6章内部资源及应用.ppt
《第6章内部资源及应用.ppt》由会员分享,可在线阅读,更多相关《第6章内部资源及应用.ppt(78页珍藏版)》请在三一办公上搜索。
1、1,第6章 80C51单片机内部资源及应用,6.1 中断系统和外部中断 中断是一项重要的计算机技术,采用中断技术可以使多个任务共享一个资源,所以中断技术实质上就是一种资源共享技术。80C51是一个多中断源的单片机,有3类共5个中断源,分别是外部中断2个,定时中断2个和串行中断1个。外部中断是由外部原因引起的,共有2个中断源,即外部中断0和外部中断1。它们的中断请求信号分别由80C51外部引脚(P3.2)和(P3.3)输入。,定时中断是为满足定时或计数的需要而设置的。串行中断是为串行数据传送的需要而设置的。,2,6.1.1 中断技术概述1.中断的概念当中央处理器CPU正在执行某程序时,由于某种原
2、因,外界向CPU发出了暂停目前工作去处理更重要事件的请求,程序被打断,CPU响应该请求并转入相应的处理程序,处理程序完成以后,再返回到原来程序被打断的位置,继续原来工作,这一过程称为中断。实现中断功能的部件称为中断系统。2.中断技术的作用计算机内有限的CPU资源要处理多项任务,实现多种外部设备之间外部数据传送,必然引起CPU资源短缺的局面。计算机引入中断技术后,解决了这种资源竞争的问题,因此中断技术实质上是一种资源共享技术。基于这种资源共享思想,中断技术主要用于分时操作、实时处理、故障及时处理等。,3,3.中断系统功能中断系统一般要完成以下功能。1)现场保护和现场恢复某人看书 执行主程序 日常
3、事务电话铃响 中断信号INT=0 中断请求暂停看书 暂停执行主程序 中断响应书中记号 当前PC入栈 保护断点电话谈话 执行I/O程序 中断服务继续看书 返回主程序 中断返回,4,主程序被断开的位置称为断点,为了CPU完成中断服务后,能够返回到原主程序的位置,就要保护断点处的现场状态,即将断点处的PC值、相关寄存器的内容、标志位等状态压入堆栈保存,该操作被称为保护断点和现场。中断服务结束后,在返回主程序前,要将被保护的断点和现场恢复,即弹出堆栈中被保存的内容至各相关寄存器,该操作被称为现场恢复。汇编语言程序员在使用中断时,需要仔细考虑现场的保护和恢复,高级程序员无需关心该问题,C编译器会自动完成
4、现场保护和恢复。,5,2)中断优先权排队通常微型计算机系统有多个中断源,当有两个以上的中断源同时向CPU提出中断请求时,CPU面临首先为哪个中断源先服务的问题,微型计算机内都为这些中断源规定了中断响应的先后顺序优先级别,即不同的中断源享有不同的优先响应权利,称为中断优先权,CPU对多个中断源响应的优先权由高到低的排队,称为优先权排队。CPU总是首先响应优先权级别高的中断请求。,6,3)中断嵌套当CPU正在执行某一中断服务程序时,可能有优先级别更高的中断源发出中断请求,此时,CPU将暂停当前的优先级别低的中断服务,转而去处理优先级更高的中断申请,处理完后,再回到原低级中断处理程序,这一过程称为中
5、断嵌套,该中断系统称为多级中断系统。没有中断嵌套功能的中断系统称为单级中断系统。,7,6.1.2 80C51单片机中断系统80C51中断系统由中断源、中断标志、中断允许控制、中断优先级控制、中断查询硬件以及相应的特殊功能寄存器组成。,8,1.中断源80C5l共有3类5个中断源,分别是2个外部中断源、2个定时中断源、1个串行口接收/发送中断源。1)外部中断外部中断是由外部请求信号或掉电等异常事故引起的,共有2个中断源:外部中断0和1,分别由引脚(P3.2)和(P3.3)引入。2)定时中断80C5l单片机内有两个定时器/计数器T0、T1,通过一种计数结构,实现定时/计数功能,当计数值发生溢出时,表
6、明已经达到预期定时时间或计数值,定时器/计数器的中断请求标志位TF0或TF1被置1,也就向CPU发出了中断请求的申请。3)串行口中断当串行口接收或发送完一组数据时,便产生一个中断请求,特殊功能寄存器SCON中的RI或TI被置1。,9,2.中断请求标志 要实现中断,首先中断源要提出中断请求,单片机内中断请求的过程是特殊功能寄存器TCON和SCON相关状态位中断请求标志位置1的过程,当CPU响应中断时,中断请求标志位才由硬件或软件清0。1)TCON中的中断标志位 该寄存器用于保存外部中断请求,以及作为定时器的计数溢出标记。既可以对其整个字节寻址,又可对其位寻址。寄存器地址88H,位地址8FH88H
7、,这个寄存器既有定时器/计数器的控制功能又有中断控制功能,其中与中断有关的控制位共6位:IE0和IE1、IT0和IT1以及TF0和TF1。,10,1.中断标志位:TF1、TF0、IE1、IE0、RI、TI 登记各中断源请求信号:=1,有中断请求;=0,无中断请求。CPU响应中断后,该中断标志自动清零。TI,RI标志必须软件清零。,定时控制寄存器TCON位地址和为符号,11,4中断优先级控制位:PS、PT1、PX1、PT0、PX0 2级优先级:=1为高优先级,=0为低优先级。同一优先级别按内部查询顺序排列优先级:高 INT0、T0、INT1、T1、SI/O 低。,3.中断允许控制位:EA、ES、
8、ET1、EX1、ET0、EX0=1开中断;=0关中断。例:允许CPU响应INT0的中断请求汇编语言C语言SETB EX0 EX0=1;SETB EAEA=1;,2.外部中断触发方式选择位:IT0、IT1=1:下降沿触发中断请求;=0:低电平触发中断请求。,12,2)SCON中的串行中断标志位,SCON寄存器地址98H,位地址9FH-98H,其中的低2位RI和TI锁存串行口的接收中断和发送中断的申请标志位。,SM0,SM1:选择串行口4种工作方式。SM2:多机控制位,用于多机通讯。REN:允许接收控制位,REN=1允许接收;REN=0禁止接收。TB8:发送的第9位数据位,可用作校验位和地址/数据
9、标识位RB8:接收的第9位数据位或停止位TI:发送中断标志,发送一帧结束,TI=1,必须软件清零RI:接收中断标志,接收一帧结束,RI=1,必须软件清零,13,14,3.中断控制中断控制主要通过中断允许寄存器IE和中断优先级寄存器IP实现。1)中断允许控制中断源申请后,中断能否被响应,取决于CPU对中断源的开放或屏蔽状态,由内部的中断允许寄存器IE进行控制,IE的地址是A8H,位地址为AFHA8H。2)中断优先级控制80C51有两个中断优先级,每个中断源均可通过软件设置为高优先级或低优先级中断,实现2级中断嵌套。高优先级中断请求可以中断一个正在执行的低优先级中断服务,除非正在执行的低优先级中断
10、服务程序设置了禁止CPU中断某些高优先级的中断。正在执行的中断服务程序不能被另一个同级或低优先级的中断所中断,正在执行高优先级的中断服务程序,不能被任何中断源中断,一直执行到返回指令RETI,返回主程序,而后再执行一条指令后,才能响应新的中断申请。,15,特殊功能寄存器IP为中断优先级控制寄存器,其地址为B8H,位地址为BFHB8H,各位内容如表所示。中断优先级控制寄存器,PX0:外部中断0中断优先级控制位。PX0=l,外部中断0定义为高优先级中断;PX0=0,为低优先级中断。PT0:定时器0中断优先级控制位。PT0=1,定时器T0中断定义为高优先级中断;PT0=0,为低优先级中断。PX1:外
11、部中断1中断优先级控制位。PX1=l,外部中断1定义为高优先级中断;PX1=0,为低优先级中断。PT1:定时器1中断优先级控制位。PT1=1,定时器T1中断定义为高优先级中断;PT1=0,为低优先级中断。PS:串行口中断优先级控制位。PS=1时,串行口中断定义为高优先级中断;PS=0时,为低优先级中断。,当系统复位后,IP的所有位被清0,所有的中断源均被定义为低优级中断。IP的各位都可用程序置位和复位,也可用位操作指令或字节操作指令更新IP的内容,以改变各中断源的中断优先级。当同一优先级的几个中断源同时向CPU提出中断请求时,CPU通过内部硬件查询逻辑电路,按查询顺序判定优先响应哪一个中断请求
12、,其查询顺序如下:外部中断0、定时中断0、外部中断1、定时中断1、串行中断。,16,4.中断处理过程一个完整的中断处理过程包括中断请求、中断响应、中断服务、中断返回几个部分。1)中断响应 中断响应指系统满足中断条件,CPU对中断请求做出反应,程序执行转向中断服务程序入口地址的过程。CPU要响应中断请求,除了前面介绍的要有中断请求、中断被允许基本条件外,如果出现下列情况之一,则中断响应将被阻止:情况一:CPU正在处理同级的或更高优先级的中断。情况二:当前的机器周期不是所执行指令的最后一个机器周 期,CPU不会响应任何中断请求。情况三:正在执行的指令是RETI或是访问IE或IP的指令。CPU 完成
13、这类指令后,至少还要再执行一条指令才会响 应新的中断请求,以便保证程序能够正确地返回。如果存在上述任何一个情况,CPU都会丢弃中断查询结果,否则将在随后的机器周期开始响应中断。,17,CPU在每个机器周期的S5P2(S5的第2个时钟周期)对 或 进行采样,并设置中断标志位的状态,而其他中断源的中断请求发生在单片机内部,直接设置相应的中断标志位的状态。CPU在每个机器周期的S6按顺序查询每个中断请求标志位,如果有中断请求满足所有中断允许条件,则CPU将在下个机器周期的S1按中断优先级响应激活最高级中断请求。,CPU响应中断时,先置位相应的高/低优先级状态触发器,指出CPU开始处理的中断优先级别,
14、然后由硬件生成一条长调用指令LCALL,其格式为:LCALL addr16,其中addr16是在程序存储区中与各中断请求对应的中断入口地址,也称为中断向量地址。CPU执行该LCALL指令,由硬件自动清除有关中断请求标志位(TI和RI除外),将程序计数器PC的内容压入堆栈以保护断点(但不保护PSW),再将被响应的中断入口地址装入PC,开始进入中断服务。程序存储区中为各中断服务程序只分配了8个单元,一般情况下难以安排下一个完整的中断服务程序。因此通常总是在各中断区入口地址处放置一条无条件转移指令LJMP addr16,使程序执行转向在其他地址存放的中断服务程序。,18,2)中断响应时间 一个中断,
15、从查询中断请求标志位到转向中断区入口地址要经历一段时间,即为中断响应时间。不同中断情况,中断响应时间也是不一样的。最短的响应时间为3个机器周期。如果中断响应受阻,不同情况需要不同的响应时间,最长响应时间为8个机器周期。一般情况下,在一个单中断系统里,外部中断响应时间总是在38个机器周期之间。如果出现有同级或高级中断正在响应或服务中需等待的时候,那么响应时间就无法计算了。,3)中断服务流程中断服务程序从入口地址开始执行,到返回指令RETI为止,中间经历了关中断、保护现场和断点、开中断、中断服务、关中断、恢复现场、开中断、返回断点几个阶段。,中断服务流程图,19,由于80C51单片机内不具有自动关
16、中断的功能,因此进入服务子程序后,必须通过指令关闭中断,为下一步保护现场和断点做准备。保护现场就是在程序进入中断服务程序入口之前,将相关寄存器内容、标志位状态等压入堆栈,避免在运行中断服务程序时,破坏这些数据或状态,保证中断返回后,主程序能够正常运行。然后,再打开中断,允许响应别的中断请求。接着可以执行中断服务,中断服务是用户最终要实现的具体功能。在返回主程序之前,关闭中断,恢复现场,再用指令开中断,以便CPU响应新的中断请求。中断服务程序的最后一条指令是RETI,用来返回断点。保护现场和恢复现场可通过堆栈操作指令PUSH direct和POP direct 实现,要保护的现场内容,取决于用户
17、的对具体情况的需求。C51编译器会自动完成ACC、B、DPH、DPL、PSW、R0R7的保护和恢复。C51程序员无需保护现场和恢复现场。,20,5.中断请求的撤除 中断响应后,TCON和SCON中的中断请求标志应及时清除。否则中断请求将仍然存在,并引起错误的中断响应。不同的中断请求,其撤除方法也不一样。对于定时中断,中断响应后,硬件自动对中断标志位TF0或TFl清0,中断请求自动撤除,无需采取其他措施。对于脉冲触发的外部中断请求,在中断响应后,也同样通过硬件自动对中断请求标志位IE0或IE1清0,即中断请求的撤除也是自动的。对于电平触发的外部中断请求,情况则不同。中断响应后,硬件不能自动对中断
18、请求标志位IE0或IE1清0。中断撤除,要靠撤除 或引脚上的低电平才能有效。,对于串行中断,其中断标志位TI和RI,不进行自动清0。因为在中断响应后,还要测试这两个标志位的状态,以判定是接收操作还是发送操作,然后才能清除。所以串行中断请求的撤除是通过软件方法,在中断服务程序中实现的。,21,6.1.3 C51中断服务函数中断系统十分重要,C51编译器允许在C语言源程序中声明中断和编写中断服务程序,从而减轻了采用汇编程序编写中断服务程序的繁琐程度。通过使用interrupt关键字实现。定义中断服务程序的一般格式如下:void 函数名()interrupt n using musing m指明该中
19、断服务程序所对应的工作寄存器组,m取值范围为:03。指定工作寄存器组的缺点是,所有被中断调用的过程都必须使用同一个寄存器组,否则参数传递会发生错误。通常不设定using m,除非保证中断程序中未调用其他子程序。P187P188例子,22,6.2 定时器/计数器 80C51的单片机内有2个16位可编程的定时器/计数器,它们具有4种工作方式,其控制字和状态均在相应的特殊功能寄存器中,通过对控制寄存器的编程,就可方便地选择适当的工作方式。6.2.1 定时器/计数器0、1的结构及工作原理1.定时器/计数器0、1的结构定时器/计数器T0、T1的内部结构框图如图1所示:,图1 定时器/计数器内部结构逻辑图
20、,23,2.加1计数器定时器/计数器T0、T1都有一个16位的加1计数器,它们分别由8位特殊功能寄存器TH0、TL0和TH1、TL1组成。加1计数器的初值可以通过程序进行设定,设定不同的初值,就可以获得不同的计数值或定时时间。3.定时控制寄存器(TCON)定时控制寄存器TCON是个8位寄存器,它不仅参与定时控制,还参与中断请求控制。既可以对其整个字节寻址,又可以对其位寻址,各位的地址及其对应的功能参见P192。,定时器溢出使TFx=1,引起中断请求,CPU响应Tx中断后,自动清0 TFx。,1)启动控制位TR0、TR1,=0,停止定时器工作,=1,启动定时器工作,2)溢出中断标志位TF0、TF
21、1,可用软件检测TFx,必须软件清0。,24,4.工作方式控制寄存器(TMOD)工作方式控制寄存器TMOD,用来设定定时器/计数器T0、T1的工作方式。TMOD寄存器只能进行字节寻址。,2个可独立控制的16位定时器/计数器:T0、T1,1)功能选择位C/T:C/T=0,定时功能,计数内部机器周期脉冲;C/T=1,计数功能,计数引脚T0(T1)输入的负脉冲。,2)方式选择位M1、M0:4种工作方式:13/16/8位,25,图2 定时器/计数器逻辑结构计数功能:对外部事件产生的脉冲进行计数。对于80C51单片机,当图2中C/=1,T0(P3.4)或T1(P3.5)两个信号引脚输入信号脉冲发生负跳变
22、时,加1计数器自动加1。,定时功能:对单片机内部机器周期产生的脉冲进行计数,即当图2中C/=0,每个机器周期计数器自动加1。如果单片机的晶体频率为12MHz,则计数频率为1MHz,或者说计数器每加1,可实现1us的定时。,26,6.2.2 定时器/计数器0、1的四种工作方式 定时器/计数器T0、T1可以有四种不同的工作方式:方式0、方式1、方式2、方式3。1.方式0 当TMOD中M1M0=00时,定时器/计数器选定方式0进行工作。,图6.7 定时器/计数器0的工作方式0电路逻辑结构,27,C/=1时,图中电子开关S1,打在下端,定时器/计数器处于计数器状态,加法计数器对T0引脚上的外部输入脉冲
23、计数。计数值:N=8192-x计数初值x是TH0、TL0设定的初值。x=8191时为最小计数值l,x=0时为最大计数值8192,即计数范围为18192(213)。C/=0时,图6.7中电子开关S1,打在上端,振荡脉冲的12分频输出,13位定时器/计数器处于定时器状态,加法计数器对机器周期(Tcy)脉冲计数。定时时间:Td=(8192-x)Tcy 或 Td=(8192-x)Tcp12,28,如果晶振频率fosc=12MHz,机器周期为1us,则定时范围为1us8192us。随着计数的增大,TL0的低5位溢出后自动向TH0进位,TH0溢出后,将溢出标志位TF0置位,并向CPU发出中断请求。图6.7
24、中控制开关S2控制定时器/计数器的启动或停止,开关S2的控制信号为:I=,当GATE=0时,=1,信号不起作用,开关S2的状态由决定,即TR0=1时,启动定时器/计数器;TR0=0时,关闭定时器/计数器。当GATE=1时,上式中I=TR0,开关S2的状态由 TR0决定,所以仅当TR0=1且位于高电平时,开关S2闭合,才能启动定时器/计数器0工作。如果上出现低电平,则停止工作,利用门控位这一特征,可以测量外信号的脉冲宽度。,29,2.方式1当TMOD中M1M0=01时,定时器/计数器选定方式1进行工作。图4是T0工作在方式1下的逻辑结构图(定时器/计数器1与其完全一致)。其逻辑结构与方式0不同的
25、是两个8位寄存器TH0和TL0全部构成了一个16位的定时器/计数器,其他与工作方式0完全相同。,图4 定时/计数器0的工作方式1电路逻辑结构,在该工作方式下,当作为计数器使用时,其计数范围是165536(216)作为定时器使用时,定时器的定时时间为:Td=(216-Count)Tcy 或Td=(216-Count)12Tcp如果晶振频率fosc=12MHz,则定时范围为165536。,30,3.方式2以上工作方式0、方式1计数器具有共同的特点,即计数器发生溢出现象后,自动处于0状态,因此如果要实现循环计数或定时,就需要程序不断反复给计数器赋初值,这就影响了计数或定时精度,并给程序设计增添了麻烦
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 内部 资源 应用
链接地址:https://www.31ppt.com/p-4722618.html