单片机原理及应用:中断系统结构与控制寄存器

大家好啊,这几天因为考试断更了一段时间,现在放假了也可以恢复正常的更新速度了。今天我们来认识一下单片机的中断系统,这里可以说是我们学习单片机以来第一个核心功能,我们会分几期内容来深入了解中断系统的作用原理和应用方式。

中断的定义

中断的结构

TCON

SCON

IE

IP

中断的定义

  1. 当CPU正在执行某个程序时,由单片机内部或外部的原因引起的紧急事件,向CPU发出请求处理的信号
  2. CPU在允许的情况下响应请求信号,暂时停止正在执行的程序,保护好断点处的现场
  3. 转向执行一个用于处理该紧急事件的程序
  4. 处理完后又返回被中止的程序断点处,继续执行原程序
以上过程就称为中断,流程如图所示

它并不是单指在输入请求信号的作用下打断原程序,而是包括保存原程序、执行中断服务、返回原程序等多个步骤,重点是在立即执行中断程序的同时不影响原先进程。

中断的结构

先前提到中断是由单片机内部或外部的原因向CPU发送请求信号而引发的,那么我们就要提出一个中断请求源的概念。中断请求源是指产生中断请求的源头,在51单片机中共有5个中断请求源,包括外部中断引脚(INT0和INT1)以及内部中断源(如定时器中断、串口中断等)。

我们从左到右依次介绍,首先是最左侧的中断源,大家看到有6个名称,可能会感到疑惑——不是五个中断源吗。实际上图中的TX和RX对应的是同一个中断,即串口通信中断,TX负责发送功能,而RX负责接收功能。除了串口中断外,都是一个引脚对应一个中断源,INT0是外部中断0,由P3.2引脚输入;紧接着是定时器/计数器T0,由P3.4引脚输入;在之后是INT1和T1,分别对应外部中断1和定时器/计数器1,引脚号可以参考STC89C52的结构图。ST,C89C52STC89C52STC89C52

细心的朋友会发现,T0,T1,TX和RX是直接接到中断标志上的,为什么INT1和INT0后面还有IT0和1的选择呢。实际上这个选择也是由TCON控制的,只是外部中断信号在输入时,需要先设置相应的触发方式。在51单片机中,整个中断系统主要由与中断相关的4个特殊功能寄存器和硬件查询电路等组成,分别为:

  • 定时/计数器控制寄存器TCON
  • 串行口控制寄存器SCON
  • 中断允许控制寄存器IE
  • 中断优先级控制寄存器IP

TCON

TCON全称是定时/计数器控制寄存器,作用是控制定时器的启动与停止,并保存T0、T1的溢出中断标志和外部中断的中断标志。

地址88H8FH8EH8DH8CH8BH8AH89H88H
名称TCONTF1TR1TF0TR0IE1IT1IE0IT0

高四位控制定时器0和1,低四位控制外部中断0和1.

TF1TF0位分别表示定时器1和定时器0的溢出标志位。当定时器溢出时,对应的溢出标志位会被置位。

TR1TR0位用于控制定时器1和定时器0的开始/停止操作。当TR1或TR0位被置位时,对应的定时器开始计数;当TR1或TR0位被清零时,对应的定时器停止计数。

IE1IE0位分别表示外部中断1和外部中断0的使能位。当IE1或IE0位被置位时,对应的外部中断允许产生中断请求。

IT1IT0位用于设置外部中断1和外部中断0的触发类型。当IT1或IT0位为0时,对应的外部中断触发类型为电平触发;当IT1或IT0位为1时,对应的外部中断触发类型为边沿触发。

下面对两种触发方式做一些补充:

当外部中断引脚被设为电平触发时,对应的TCON寄存器的IT0或IT1位需要被清零。这样,当外部中断引脚检测到高电平(或低电平,具体取决于电平触发的方式)时,中断就会被触发,处理器会跳转到外部中断的中断服务程序执行相应的操作。那么电平触发的方式应该怎么确定呢?在上方的引脚图中,我们可以看到P3.2和P3.3对应的INT引脚被加上了横线,这代表“低电平有效”,也就是说当51单片机的外部中断引脚检测到低电平时才会触发中断。

边沿触发也叫跳沿触发,是指当外部中断引脚的电平发生变化时,中断被触发。边沿触发方式可以选择上升沿触发或下降沿触发。在51单片机中,由于“低电平有效”,所以采用下降沿触发。当外部中断引脚检测到高电平下降为低电平时,中断就会被触发,处理器会跳转到外部中断的中断服务程序执行相应的操作。

两种触发方式各有利弊,需要根据使用场景来选择。电平触发的中断响应速度更快,并且对中断源的响应更灵敏。但是如果中断源的电平被保持时间过长,那么中断服务程序可能会被频繁调用,导致额外的中断处理负担,而跳沿触发方式适合于以负脉冲形式输入的外部中断请求,检测规律性的变化电平。

SCON

SCON全称为串行口控制寄存器,由于笔者所在专业对通信无过多要求,这里只是简要介绍其功
能,仅作为参考。
  • SM0/FE: 串口通信模式位/帧错误位。SM0和SM1位用于设置串口通信的工作模式,而FE位用于指示接收到的数据帧是否有错误。
  • SM1: 串口通信模式位。SM0和SM1位组合起来用于设置串口通信的工作模式。不同的SM0和SM1位组合可以实现不同的通信模式,如8位单机通信模式、9位单机通信模式、多机通信模式等。
  • SM2: 多机通信模式位。SM2位仅在SM0和SM1位为10时有效,用于指示当前处于多机通信模式。在多机通信模式下,可以通过地址识别不同的串口设备。
  • REN: 接收使能位。REN位用于控制串口接收器的启用和禁用。当REN位为1时,接收器处于启用状态,可以接收数据;当REN位为0时,接收器处于禁用状态,不接收数据。
  • TB8/RB8: 发送/接收的第8位。TB8位用于指示发送的数据帧的第8位,而RB8位用于指示接收到的数据帧的第8位。
  • TI: 发送中断标志位。TI位用于指示发送操作是否完成,当发送操作完成后,TI位将置1。可以通过检测TI位来判断是否可以发送下一个数据。
  • RI: 接收中断标志位。RI位用于指示接收操作是否完成,当接收到数据后,RI位将置1。可以通过检测RI位来读取接收到的数据。

通过设置和操作SCON寄存器的不同位,可以实现对串口通信相关功能的控制和操作,实现单片机与外部设备的串口通信。

IE

IE全称为中断允许控制寄存器,用于控制CPU对中断的开放或屏蔽、每个中断源是否允许中断。
地址A8HAFHACHABHAAHA8HA9H
名称IEEA/ESET1EX1ET0EX0

EA: 总中断使能位,用于控制总体中断的使能和禁止。当EA位为1时,允许中断;当EA位为0时,禁止中断。

ET0: 定时器0中断使能位,用于控制定时器0中断的使能和禁止。当ET0位为1时,允许定时器0中断;当ET0位为0时,禁止定时器0中断。ET1: 定时器1中断使能位,同理。

EX0: 外部中断0使能位,用于控制外部中断0的使能和禁止。当EX0位为1时,允许外部中断0;当EX0位为0时,禁止外部中断0。EX1: 外部中断1使能位,同理。

ES: 串口中断使能位,用于控制串口中断的使能和禁止。当ES位为1时,允许串口中断;当ES位为0时,禁止串口中断。

通过设置和操作IE寄存器的不同位,可以控制不同中断的允许和禁止。同时,通过设置EA位可以一次性控制所有中断的允许和禁止。

IP

IP全称为中断优先级控制寄存器,作用是设定各中断源的优先级别,IP的每一位均可以由软件来置1或清0。

 

地址B8HBCHBBHBAHB9HB8H
名称IP///PSPT1PX1PT0PX0

 

PX0: 外部中断0的优先级位。当PX0位为1时,外部中断0的优先级为高优先级;当PX0位为0时,外部中断0的优先级为低优先级。

PT0: 定时器0中断的优先级位。当PT0位为1时,定时器0中断的优先级为高优先级;当PT0位为0时,定时器0中断的优先级为低优先级。

PX1: 外部中断1的优先级位。当PX1位为1时,外部中断1的优先级为高优先级;当PX1位为0时,外部中断1的优先级为低优先级。

PT1: 定时器1中断的优先级位。当PT1位为1时,定时器1中断的优先级为高优先级;当PT1位为0时,定时器1中断的优先级为低优先级。

PS: 串口中断的优先级位。当PS位为1时,串口中断的优先级为高优先级;当PS位为0时,串口中断的优先级为低优先级。

IP寄存器中的位设置可以决定不同中断的优先级,高优先级的中断会优先被处理。当多个中断同时到达时,优先级高的中断会先被响应。需要注意,IP寄存器的设置需要与IE寄存器的设置相配合,才能正确地实现中断的优先级控制。

这里补充一点优先级的设定:单片机共有三个优先级,优先顺序分别是高优先级中断>低优先级中断>普通程序,普通程序可以有多个,中断源在无说明的情况下默认为低优先级,也就是5个,而高优先级需要在IP中设定,且只能有一个。正在执行低优先级的中断服务程序可被高优先级的中断源所中断,但不能被同级或低级别的中断源所中断; 正在执行的高优先级的中断服务程序不能被任何中断源所中断。

另外中断源还存在着自然优先级,如果几个同一优先级别的中断源,同时向CPU请求中断,CPU将通过单片机内部的硬件查询逻辑,首先响应自然优先级较高的中断源的中断请求。自然优先级由电路规定,如图所示:

今天我们一同学习了中断的基础概念和系统组成,之后会为大家介绍中断服务函数的使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/303647.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【K8S 云原生】Kurbernets集群的调度策略

目录 一、Kubernetes的list-watch机制 1、List-watch 2、创建pod的过程: 二、scheduler调度的过程和策略: 1、简介 2、预算策略:predicate 3、优先策略: 3.1、leastrequestedpriority: 3.2、balanceresourceal…

linux 系统安全及应用

一、账号安全基本措施 1.系统账号清理 1.将用户设置为无法登录 /sbin/nologin shell——/sbin/nologin却比较特殊,所谓“无法登陆”指的仅是这个用户无法使用bash或其他shell来登陆系统而已,并不是说这个账号就无法使用系统资源。举例来说,…

MySQL语法练习-DML语法练习

文章目录 0、相关文章1、添加数据2、修改数据3、删除数据4、总结 0、相关文章 《MySQL练习-DDL语法练习》 1、添加数据 # 给指定字段添加数据 insert into 表名 (字段名1,字段名2,...) values(值1,值2...);# 给全部字段添加数据 insert into 表名 values(值1,值2,...);#批量…

Mac robotframework+pycharm运行suite报错情况:ImportError: No module named request

报错实例: 当前Preferences–>Tool–>External Tools Suite配置,显示使用的python为2.7版本,robotframework安装在当前版本的python中: 但是我pycharm现在的环境配置的python为3.11,当前使用的RF与当前使用的py…

5.2 Android BCC环境搭建(adeb版,下)更新中

五&#xff0c;运行adeb shell adeb shell 六&#xff0c;其他指令 6.1 从开发机移除adeb adeb remove 6.2 更新开发机adeb deb git-pull 6.3 使用ssh替代adeb进行与android设备的通信 adeb --ssh <uri> --sshpass <pass> <cmd> 七&#xff0c;BCC配置…

1-05使用VS调式程序

一、概述 写代码总不是一帆风顺的&#xff0c;总会碰到一些问题&#xff0c;检查问题&#xff0c;排除错误&#xff08;也就是Debug程序&#xff09;&#xff0c;对于任何程序员而言都是基本功。 我们前面讲过&#xff0c;C语言是一门很容易出错&#xff0c;且自身不提供异常…

excel统计分析——LSD多重比较

参考资料&#xff1a;生物统计学 一篇教你搞定显著性差异分析abcd字母标记法 LSD&#xff08;least significant difference&#xff0c;最小显著差数法&#xff09;是R. A. Fisher提出的&#xff0c;又称为Fisher LSD检验法&#xff0c;是最早用于检验各组均数间两两差异的方…

软件工程概论---内聚性和耦合性

目录 一.耦合性 1.内容耦合 2.公共耦合 4.控制耦合 5.标记耦合&#xff08;特征耦合&#xff09; 6.数据耦合 7.非直接耦合 二.内聚性 1.偶然内聚 2.逻辑内聚 3.时间内聚 4.过程内聚 5.通信内聚 6.顺序内聚 7.功能内聚 一.耦合性 耦合性是指软件结构中模块相互…

java常用应用程序编程接口(API)——String概述及使用案例

前言&#xff1a; 开始学到api的String&#xff0c;整理下心得。打好基础&#xff0c;daydayup! API&#xff1a; API是什么&#xff1f; API&#xff08;Application Programming Interface&#xff09;又名应用程序编程接口。是别人编好的程序的合集。 为什么要使用API&…

YOLOv5改进 | 2023Neck篇 | 利用Gold-YOLO针对小目标进行检测(附完整修改教程 + 代码)

一、本文介绍 本文给大家带来的改进机制是Gold-YOLO利用其Neck改进v8的Neck,GoLd-YOLO引入了一种新的机制——信息聚集-分发(Gather-and-Distribute, GD)。这个机制通过全局融合不同层次的特征并将融合后的全局信息注入到各个层级中,从而实现更高效的信息交互和融合。这种…

关于订单超时后用户却已支付的解决方案

场景: 一般我们下的一些订单&#xff0c;比如电商平台、外卖平台的都是有超时时间的&#xff0c;默认一般15或者30分钟&#xff0c;那么超时未支付订单会被自动取消&#xff0c;那么如果刚好有人在关闭订单的时候去支付成功了&#xff0c;或者说支付平台延迟了一下&#xff0c;…

开启Android学习之旅-5-Activity全屏

Android 两种方式设置全屏&#xff1a; 1. 第一行代码中的方法 通过 getWindow().getDecorView()方法拿到当前Activity的DecorView,再调用 setSystemUiVisibility() 方法来改变系统UI的显示&#xff0c;这里传入了 View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN 和 View.SYSTEM_UI_…

【EAI 005】EmbodiedGPT:通过具身思维链进行视觉语言预训练的具身智能大模型

论文描述&#xff1a;EmbodiedGPT: Vision-Language Pre-Training via Embodied Chain of Thought 论文作者&#xff1a;Yao Mu, Qinglong Zhang, Mengkang Hu, Wenhai Wang, Mingyu Ding, Jun Jin, Bin Wang, Jifeng Dai, Yu Qiao, Ping Luo 作者单位&#xff1a;The Universi…

vue3 封裝一个常用固定按钮组件(添加、上传、下载、删除)

效果图 这个组件只有四个按钮&#xff0c;添加&#xff0c;上传、下载、删除&#xff0c;其中删除按钮的颜色默认是灰色&#xff0c;当表格有数据选中时再变成红色 实现 组件代码 <script lang"ts" setup> import { Icon } from /components/Icon/index im…

PCL 格网法计算点云的占地面积

目录 一、算法原理二、代码实现三、结果展示四、测试数据本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫与GPT生成的文章。 一、算法原理 该方法主要用于粗略统计机载点云的占地面积。方法原理是将点云沿 X O Y XOY

Rust 常用集合(上)

目录 1、使用 Vector 储存列表 1.1 新建 vector 1.2 更新 vector 1.3 读取 vector 的元素 1.4 遍历 vector 中的元素 1.5 使用枚举来储存多种类型 1.6 丢弃 vector 时也会丢弃其所有元素 2、使用字符串储存 UTF-8 编码的文本 2.1 什么是字符串&#xff1f; 2.2 新建字…

tiktok云手机有用吗?用哪个好?

很多做独立站的跨境卖家都会搭配一些社媒平台给自己引流带货&#xff0c;比如说目前很火的TikTok&#xff0c;这也是目前比较有效的一种引流方式。本文将介绍tiktok运营方法以及如何用tiktok云手机规避运营风险。 TikTok是个不错的风口&#xff0c;不过我们在国内想要运营好Tik…

如何在CentOS安装SQL Server数据库并通过内网穿透工具实现公网访问

文章目录 前言1. 安装sql server2. 局域网测试连接3. 安装cpolar内网穿透4. 将sqlserver映射到公网5. 公网远程连接6.固定连接公网地址7.使用固定公网地址连接 前言 简单几步实现在Linux centos环境下安装部署sql server数据库&#xff0c;并结合cpolar内网穿透工具&#xff0…

第19课 在Android环境中使用FFmpeg和openCV进行开发的一般步骤

在上节课&#xff0c;根据模板文件我们对在Android环境中使用FFmpeg和openCV进行开发有了一个初步的体验&#xff0c;这节课&#xff0c;我们来具体看一下其工作流程。 1.程序的入口 与VS2013程序开发类似&#xff0c;Android程序开发也有一个入口&#xff0c;在这个模板中&a…

哈希-力扣202快乐数

题目 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不到 1。如果这个过程 结果为 1&…