STM32外部中断实验.ppt
《STM32外部中断实验.ppt》由会员分享,可在线阅读,更多相关《STM32外部中断实验.ppt(27页珍藏版)》请在三一办公上搜索。
1、ALIENTEK,例说STM32,例说STM32,2023/7/8,广州市星翼电子科技有限公司,1,ALIENTEK开发板购买店铺 店铺:http:/,ALIENTEK,第 6 讲 外部中断实验,6.1 STM32中断简介 6.2 中断管理相关寄存器 6.3 中断优先级分组 6.4 中断线 6.5 外部中断一般配置步骤 6.6 实验讲解,例说STM32,2,2023/7/8,广州市星翼电子科技有限公司,ALIENTEK,6.1 STM32中断简介,例说STM32,3,2023/7/8,广州市星翼电子科技有限公司,CM3内核支持256个中断,其中包含了16个内核中断和240个外部中断,并且具有2
2、56级的可编程中断设置。但STM32并没有使用CM3内核的全部东西,而是只用了它的一部分。STM32有84个中断,包括16个内核中断和68个可屏蔽中断,具有16级可编程的中断优先级。而我们常用的就是这68个可屏蔽中断,但是STM32的68个可屏蔽中断,在STM32F103系列上面,又只有60个(在107系列才有68个)。,ALIENTEK,例说STM32,4,2023/7/8,广州市星翼电子科技有限公司,STM32的每个IO都可以作为外部中断的中断输入口,这点也是STM32的强大之处。STM32F103的中断控制器支持19个外部中断/事件请求。每个中断设有状态位,每个中断/事件都有独立的触发和
3、屏蔽设置。STM32F103的19个外部中断为:线015:对应外部IO口的输入中断。线16:连接到PVD输出。线17:连接到RTC闹钟事件。线18:连接到USB唤醒事件。,ALIENTEK,6.2 中断相关寄存器,例说STM32,5,2023/7/8,广州市星翼电子科技有限公司,在MDK内,与NVIC相关的寄存器,MDK为其定义了如下的结构体:typedef struct vu32 ISER2;u32 RESERVED030;vu32 ICER2;u32 RSERVED130;vu32 ISPR2;u32 RESERVED230;vu32 ICPR2;u32 RESERVED330;vu32
4、IABR2;u32 RESERVED462;vu32 IPR15;NVIC_TypeDef;,ALIENTEK,例说STM32,6,2023/7/8,广州市星翼电子科技有限公司,ISER2:ISER全称是:Interrupt Set-Enable Registers,这是一个中断使能寄存器组。上面说了STM32F103的可屏蔽中断只有60个,这里用了2个32位的寄存器,总共可以表示64个中断。而STM32F103只用了其中的前60位。ISER0的bit0bit31分别对应中断031。ISER1的bit027对应中断3259;这样总共60个中断就分别对应上了。您要使能某个中断,必须设置相应的IS
5、ER位为1,使该中断被使能(这里仅仅是使能,还要配合中断分组、屏蔽、IO口映射等设置才算是一个完整的中断设置)。具体每一位对应哪个中断,请参考stm32f10 x_nvic.h里面的第36行处。,ALIENTEK,例说STM32,7,2023/7/8,广州市星翼电子科技有限公司,ICER2:全称是:Interrupt Clear-Enable Registers,是一个中断除能寄存器组。该寄存器组与ISER的作用恰好相反,是用来清除某个中断的使能的。其对应位的功能,也和ICER一样。这里要专门设置一个ICER来清除中断位,而不是向ISER写0来清除,是因为NVIC的这些寄存器都是写1有效的,写
6、0是无效的。具体为什么这么设计,请看CM3权威指南第125页,NVIC概览一章。,ALIENTEK,例说STM32,8,2023/7/8,广州市星翼电子科技有限公司,ISPR2:全称是:Interrupt Set-Pending Registers,是一个中断挂起控制寄存器组。每个位对应的中断和ISER是一样的。通过置1,可以将正在进行的中断挂起,而执行同级或更高级别的中断。写0是无效的。ICPR2:全称是:Interrupt Clear-Pending Registers,是一个中断解挂控制寄存器组。其作用与ISPR相反,对应位也和ISER是一样的。通过设置1,可以将挂起的中断接挂。写0无效
7、。,ALIENTEK,例说STM32,9,2023/7/8,广州市星翼电子科技有限公司,IABR2:全称是:Active Bit Registers,是一个中断激活标志位寄存器组。对应位所代表的中断和ISER一样,如果为1,则表示该位所对应的中断正在被执行。这是一个只读寄存器,通过它可以知道当前在执行的中断是哪一个。在中断执行完了由硬件自动清零。,ALIENTEK,例说STM32,10,2023/7/8,广州市星翼电子科技有限公司,IPR15:全称是:Interrupt Priority Registers,是一个中断优先级控制的寄存器组。这个寄存器组相当重要!STM32的中断分组与这个寄存器
8、组密切相关。IPR寄存器组由15个32bit的寄存器组成,每个可屏蔽中断占用8bit,这样总共可以表示15*4=60个可屏蔽中断。刚好和STM32的可屏蔽中断数相等。IPR0的3124,2316,158,70分别对应中中断30,依次类推,总共对应60个外部中断。而每个可屏蔽中断占用的8bit并没有全部使用,而是 只用了高4位。这4位,又分为抢占优先级和子优先级。抢占优先级在前,子优先级在后。而这两个优先级各占几个位又要根据SCB-AIRCR中中断分组的设置来决定。,ALIENTEK,6.3 中断优先级分组,例说STM32,11,2023/7/8,广州市星翼电子科技有限公司,STM32的中断分组
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- STM32 外部 中断 实验
链接地址:https://www.31ppt.com/p-5449589.html