当前位置:网站首页>中断系统结构及中断控制详解
中断系统结构及中断控制详解
2022-08-09 12:06:00 【51CTO】
中断系统结构及中断控制详解
MCS—51提供5个中断请求源,2个中断优先级,可实现两级中断服务程序嵌套。当CPU执行关中断指令后(或复位),将屏蔽所有中断请求,只有CPU执行开中断指令后才有可能接受中断请求,每个中断源可由软件编程为允许中断和禁止中断,每个中断源可程控为高优先级中断或低优先级中断。可见MCS-51具有较强的中断处理能力。
一、中断系统内部结构
MCS-51的中断系统结构框图如下图所示,与中断有关的特殊功能寄存器有4个,分别为中断源寄存器(即专用寄存器TCON和SCON的相关位)、IE和IP。
MCS-51单片机有5个中断源,可提供两个中断优先级,即可实现二级中断嵌套。
二、MCS-51中断源及中断入口
MCS-51的中断源可分为三类:外部中断、定时中断和串行口中断。
1.外部中断类
由外部原因引起的:
INT0——外部中断0请求信号,由P3.2输入,IT0 (TCON.0) 决定中断请求信号是低电平有效还是下降沿有效。一旦输入有效,即向CPU申请中断,并使IE0=1。
INT1——外部中断1请求信号,由P3.3输入,由IT1 (TCON.2) 决定中断请求信号是低电平有效还是下降沿有效。一旦输入有效,即向CPU申请中断,并使IE1=1。
2.定时中断类
定时中断是为满足定时或计数溢出处理的需要而设置的,在单片机芯片内部发生,无需在芯片上设置引入端,但在计数方式时,中断源可以由单片机芯片外部引入。
TF0——定时器T0溢出中断请求。当定时器T0产生溢出时,其中断请求标志TF0=1,请求中断处理。
TF1——定时器T1溢出中断请求。当定时器T1产生溢出时,其中断请求标志TF1=1,请求中断处理。
3.串行口中断类
串行口中断为串行数据的传送需要而设置的。
RI或TI——串行中断请求。
各中断源对应的中断服务程序入口地址:
中断源 入口地址
外部中断0 0003H
定时器T0中断 000BH
外部中断1 0013H
定时器T1中断 001BH
串行口中断 0023H
三、MCS-51中断请求
中断标志位:
TF1、TF0、IE1、IE0、RI 、TI登记各中断源请求信号:=1,有中断请求;= 0,无中断请求。
CPU响应中断后,该中断标志自动清零。TI,RI标志必须软件清零。
外部中断触发方式选择位:
- IT0、IT1=1:负边沿触发中断请求;= 0:低电平触发中断请求。
- IE0:外中断0中断申请标志
若IT0=0,每个机器周期的S5P2采样INT0 ,若INT0=0则IE0=1;当 IT0=1时,第一个机器周期采样到INT0为高电平,第二个机器周期为低电平,则IE0=1。IE0=1表示外中断0正在向CPU申请中断,当CPU响应中断,转向中断服务程序时,由硬件清“0”IE0 - TF0: T0溢出中断标志
T0被启动计数后,加1计数,溢出后,由硬件使TF0=1,请求中断,此标志保持到CPU响应中断后,由硬件自动清“0”。也可用软件查询该标志,并由软件清“0”。
四、中断允许控制
中断允许控制位:EA、ES、ET1、EX1、ET0、EX0
=1开中断;= 0关中断。
例:允许CPU响应INT0的中断请求
SETB EX0
SETB EA
中断允许寄存器IE格式和各位含义如下:
- EA——CPU中断总允许位。EA=1,CPU开放中断;
- ES ——串行口中断允许位。 ES=1,允许串行口中断
- ET1—— T1中断允许位。 ET1=1,允许T1中断。
- EX1——外部中断1允许位。 EX1=1,允许外部中断1中断
- ET0—— T0中断允许位。 ET0=l,允许T0中断;
- EX0——外部中断0允许位。EX0=1,允许外部中断0中断
- MCS-5l系统复位后,IE中各中断允许位均被清“0” 。
五、 中断优先级
中断优先级——设计人员给每个中断源事先安排中断响应的优先顺序。然后按轻重缓急的次序响应。
专用寄存器IP统一管理中断优先级。可实现两级中断嵌套。
- PS ——串行口中断优先级控制位。
- PT1——T1中断优先级控制位。
- PX1——外部中断1中断优先级控制位。
- PT0——T0中断优先级控制位。
- PX0——外部中断0中断优先级控制位。
以上对应位为1,高优先级;为0,低优先级。
当系统复位后,IP低5位全部清“0”,将所有中断源设置为低优先级中断。
同一优先级别按内部查询顺序排列优先级:
高 INT0、T0、INT1、T1、SIO 低。
自然优先级由硬件形成,排列次序如下:
- 中断源 自然优先级
- 外部中断0 最高级
- 定时器T0中断
- 外部中断1
- 定时器T1中断
- 串行口中断 最低级
边栏推荐
- 链表噩梦之一?5000多字带你弄清它的来龙去脉
- 国产抗新冠口服药每瓶不超300元/ 我国IPv6网络全面建成/ 谷歌入局折叠屏手机...今日更多新鲜事在此...
- GRPC整体学习
- World's 4th mad scientist dies on his 103rd birthday
- 听声辨物,这是AI视觉该干的???|ECCV 2022
- WeChat Mini Program Payment and Refund Overall Process
- The batch size does not have to be a power of 2!The latest conclusions of senior ML scholars
- 字符串转换整数 (atoi)
- 无需精子卵子子宫体外培育胚胎,Cell论文作者这番话让网友们炸了
- API调用,API传参,面向对接开发,你真的会写接口文档吗?
猜你喜欢
HAproxy: load balancing
Byte Qiu Zhao confused me on both sides, and asked me under what circumstances would the SYN message be discarded?
已解决IndentationError: unindent does not match any oute r indentation Level
00后写个暑假作业,被监控成这笔样
腾讯欲成育碧最大股东/ 米哈游招NLP内容生成研究员/ AI发现四千余物种濒临灭绝...今日更多新鲜事在此...
Flutter入门进阶之旅(八)Button Widget
世界第4疯狂的科学家,在103岁生日那天去世了
注释、关键字、标识符的区别你知道吗?
又有大厂员工连续加班倒下/ 百度搜狗取消快照/ 马斯克生父不为他骄傲...今日更多新鲜事在此...
Manchester city launch emotional intelligence scarf can be detected, give the fans
随机推荐
阿里高工带来的20022最新面试总结太香了
The batch size does not have to be a power of 2!The latest conclusions of senior ML scholars
太卷了... 腾讯一面被问到内存满了,会发生什么?
十分钟教会你如何使用VitePress搭建及部署个人博客站点
Byte Qiu Zhao confused me on both sides, and asked me under what circumstances would the SYN message be discarded?
Glory to the Blue Yonder, speeds up the strategic growth
ABAP interview questions: how to use the System CALL interface of the ABAP programming language, direct execution ABAP server operating System's shell command?
Shell之常用小工具(sort、uniq、tr、cut)
京东架构师呕心整理:jvm与性能调优有哪些核心技术知识点
Here comes the question: Can I successfully apply for 8G memory on a machine with 4GB physical memory?
How should the acceptance criteria for R&D requirements be written?| Agile Practices
无需精子卵子子宫体外培育胚胎,Cell论文作者这番话让网友们炸了
The grep command Shell regular expressions, the three musketeers
Win10 compiles the x264 library (there are also generated lib files)
手写大根堆
win10编译x264库(也有生成好的lib文件)
Rust从入门到精通04-数据类型
ABAP 报表中如何以二进制方式上传本地文件试读版
K个结点的组内逆序调整
基于CAP组件实现补偿事务与幂等性保障