欢迎来到天天文库
浏览记录
ID:38698248
大小:694.50 KB
页数:6页
时间:2019-06-17
《实验二、中断优先级控制及中断保护实验》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、实验二、中断优先级控制及中断保护实验自动化1002吴会欢201019100227一、实验目的1、掌握单片机中断机制;2、熟悉中断的应用和编程。二、实验设备统一电子开发平台。三、实验要求USB线连接开发板,电源开关S1打到usb位置;J5跳针跳到1*4位置,按键B对应INT0(P3.2),按键F连接INT1(P3.3),在平时状态下,发光二极管行以600ms的时间间隔,依次点亮。B键按下时INT0中断处理程序点亮LED4对应的发光管2秒钟,其他发光管熄灭;F键按下时LED5对应发光管点亮2秒,其他发光管熄灭。四、实验原理通常一个
2、微处理器读取外围设备(如键盘等)的输入信息的方法有轮询(Polling)及中断(Interrupt)两种。轮询的方法是CPU依照某种既定法则,依序询问每一外围设备I/O是否需要服务,此种方法CPU需花费一些时间来做询问服务,当I/O设备增加时,询问服务时间也相对增加,因此势必浪费许多CPU时间,降低整体运行的效率。使用中断是一个较好的解决方法。使用中断使系统对外部设备的请求响应更加灵敏,并且不需要占用CPU的时间进行轮询。但是,当使用中断,特别是有多个中断嵌套时要特别注意内存单元内容的保护。4.18051中断结构当中断发生后,
3、程序将跳至对应中断入口地址去执行中断子程序,或称中断服务例程(InterruptServiceRoutine),这些特殊的地址称为中断向量,例如当80C51外部中断INTl发生时,会暂停主程序的执行,跳至地址0013H去执行中断服务例程,直到RETI指令后,才返回主程序继续执行。MCS-51系列的程序内存中有7个矢量地址,叙述如下:(1)00H复位:当第9脚RESET为高电平,CPU会跳至地址00H处开始执行程序,亦即程序一定要从地址00H开始写起。(2)03H(外部中断0):当INT0引脚由高电位变至低电位时,CPU会接受外
4、部中断0,并跳至地址03H处去执行中断子程序。(3)0BH(计时/计数器0中断):当CPU接受计时/计数器0中断置位而产生中断要求时,会跳至地址0BH处去执行中断子程序。(4)13H(外部中断1):当INTl引脚由高电位变至低电位时,CPU会接受外部中断1,并跳至地址13H处去执行中断子程序。(5)1BH(计时/计数器1中断):当CPU接受计时/计数器1中断置位而产生中断要求时,会跳至地址1BH刻去执行中断子程序。(6)23H(串行中断1):当串行端口传送数据或接收数据完毕时,CPU会接受串行中断,并跳至地址23H处去执行中断
5、子程序。(7)2BH(计时/计数器2中断):当CPU接受计时/计数器2产生中断要求时,会跳至地址2BH处去执行中断子程序。此中断仅8052系列才有。2.中断使能位8051针对中断提供两层使能,第一层为EA全局使能控制,第二层为分别控制EX0,ET0、EXl、ETl、ES、ET2。当8051在初始状态时,寄存器的各个中断使能位都预设为“0”,即所有中断都禁止,故欲允许中断时,应先使能相对应的中断。当中断产生后,此中断状态会记录于定时器/计数器控制寄存器(Timer/CounterControlRigister,TCON)的中断请
6、求标志(InterruptRequestflag)中,当标志被设立,表示中断已发生。由图1可知,当外部中断或定时器0、定时器1中断发生时,CPU都可以判别是哪种中断。因此当这四个中断发生时,中断服务例程被执行后,CPU会主动清除中断请求标志,对于其他的中断,由于CPU无法判别,因此中断请求标志需由程序指令来清除。另外,在TCON中尚有两个位称为中断型式控制位(Wypecontrolbit),经由这两个位的设定,可以边择外部中断为负边缘触发或低电平触发。欲设定中断使能与否,必须规划位于特殊功能寄存器中的中断使能寄存器IE(Int
7、erruptEnableRegister),其位于地址A8H,是一个可位寻址的寄存器。3.中断保护由于各个中断执行的起始地址间仅有8个Bytes,因此欲在此空间内完成中断服务例程是有困难的。通常中断服务例程是置于主程序后面,而在中断向量地址只书写跳跃指令,跳至相对应中断服务例程去执行。当执行新的中断服务例程时,注意不可以破坏旧有的数据和状态,因此在编写时还要保存各个寄存器的数据。通常会被更改的数据(如ACC、PSW等),可以利用堆栈在执行中断服务例程之前就将其PUSH起来,待执行结束后再将相关寄存器POP即可。另外,因为805
8、1可任意选择四个寄存器库中的一组寄存器,所以利用选择不同寄存器库的方式亦可达到数据保存的目的。4.中断优先级8051对于各种中断优先权采用双层结构,首先对于优先权可由中断优先权寄存器(InterruptPriorityIP)设定该中断为高优先权或低优先权,高优先权可以中断低优
此文档下载收益归作者所有