你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【经验分享】STM32中断控制的流程

[复制链接]
STMCU小助手 发布时间:2022-1-16 17:24
对于 STM32 讲(还是以Timer2例),外部中断通道位置 28(35 号优先级)是给外部设备 TIME2 的,但 TIME2本身能够引起中断的中断源或事件有好多个,比如更新事件(上溢/下溢) 、输入捕获、输出匹配、DMA 申请等。所有TIME2 的中断事件都是通过一个 TIME2 的中断通道向 STM32 内核提出中断申请,那么 STM32 中如何处理和控制 TIME2 和它众多的、不同的、中断申请呢?
) B# ]! g8 y2 y! E, F" ^5 f, R9 \8 U' x, I2 _# T8 a0 g  @
    1.因为cortex_m3 内核对于每一个外部中断通道都有相应的控制字和控制位,用于单独的和总的控制该中断通道。它们包括有:
) ~# c# i. v6 u6 z+ u
  • 中断优先级控制字:PRI_n(前面有提到过)
  • 中断允许设置位:在 ISER 寄存器中
  • 中断允许清除位:在 ICER 寄存器中
  • 中断悬挂 Pending(排队等待)位置位:在 ISPR 寄存器中(类似于置中断通道标志位)
  • 中断悬挂 Pending(排队等待)位清除:在 ICPR 寄存器中(用于清除中断通道标志位)
  • 正在被服务(活动)的中断(Active)标志位:在 IABR 寄存器中, (只读,可以知道当前内核正在处理哪个中断通道)
    ! U. W0 P5 m+ w0 P. ^" x
     2.作为外围设备 TIME2 本身也包括更具体的,管理自己不同中断的中断控制器(位) ,它们主要是自身各个不同类型中断的允许控制位, 和各自相应的中断标志位 (STM32 的手册中有详细的说明) 。4 K# K* e" P& m6 _2 d: t, d8 G
2 A9 @% A5 {; X! H+ w& |; E
4 K' u' o2 s0 _( c6 h1 D6 Q
        理解上面两点之后,我们可以全程、全面和综合的来了解 TIME2 的中断过程,以及如何控制的。
2 A" Y/ x" \- w/ Q, f6 I         ①初始化过程6 k# I7 c1 I2 \3 R7 z
  • 首先要设置寄存器 AIRC 中 PRIGROUP 的值, 规定系统中的抢先优先级和子优先级的个数(在 4 个 bits 中占用的位数) ;
  • 设置 TIME2 本身的寄存器,允许相应的中断,如允许 UIE(TIME2_DIER 的第[0]位)
  • 设置 TIME2 中断通道的抢先优先级和子优先级(IP[28],在 NVIC 寄存器组中)
  • 设置允许 TIME2 中断通道。在 NVIC 寄存器组的 ISER 寄存器中的一位。
    * U2 c9 L6 Z  @( @0 n$ l$ c+ j; b
         ②中断响应过程
/ l7 l. f" l4 j5 i3 k% R* z
  • 当 TIME2 的 UIE 条件成立(更新,上溢或下溢) ,硬件将 TIME2 本身寄存器中 UIE 中断标志置位,然后通过 TIME2 中断通道向内核申请中断服务。
  • 此时内核硬件将 TIME2 中断通道的 Pending 标志置位(相当与中断通道标志置位) ,表示 TIME2 有中断申请。
  • 如果当前有中断在处理,TIME2 的中断级别不够高,那么就保持 Pending 标志,当然用户可以在软件中通过写 ICPR 寄存器中相应的位把本次中断清除掉。
  • 当内核有空,开始响应 TIME2 的中断,进入 TIME2 的中断服务。此时硬件将 IABR 寄存器中相应的标志位置位, 表示 TIME2 中断正在被处理。 同时硬件清除 TIME2 的 Pending 标志位。/ c& y) g. u( k& ?5 t* D) a2 r
& p/ D  B, _* _/ O7 t( r9 N
③ 执行 TIME2 的中断服务程序0 t# E$ w0 g6 u# I; L, P
  • 所有 TIME2 的中断事件, 都是在一个 TIME2 中断服务程序中完成的, 所以进入中断程序后, 中断程序需要首先判断是哪个 TIME2 的具体事件的中断, 然后转移到相应的服务代码段去。
  • 注意不要忘了把该具体中断事件的中断标志位清除掉, 硬件是不会自动清除 TIME2 寄存器中具体的中断标志位的。
  • 如果 TIME2 本身的中断事件多于 2 个, 那么它们服务的先后次序就由用户编写的中断服务决定了。换句话说,对于 TIME2 本身的多个中断的优先级,系统是不能设置的。所以用户在编写服务程序时,应该根据实际的情况和要求,通过软件的方式,将重要的中断优先处理掉。
  • 当然你也可以每次中断服务只处理其中的一个,然后再次进入中断,处理下一个。2 @$ N( Q3 Y/ k
# I5 z+ h7 n. t7 t7 L4 k

9 _2 m) Z! K! x④中断返回4 E0 k6 x# b, g/ ?0 e% [6 o: l7 r
内核执行完中断服务后,便进入中断返回过程,在这个过程中需要:
  X% [+ R4 W, I  P9 [6 ?
  • 硬件将 IABR 寄存器中相应的标志位清另,表示该中断处理完成如果 TIME2 本身还有中断标志位置位,表示 TIME2 还有中断在申请,则重新将 TIME2的 Pending 标志置为 1,等待再次进入 TIME2 的中断服务。
  • 以上中断过程在《ARM Cortex-M3 权威指南》中有详细描述,并配合时序图说明,可以参考。
  • 然后,就可以在 ST 提供的函数库的帮助下,正确的设置和使用 STM32 的中断系统了。( T  g! ^0 T+ R' g8 O5 u5 a
4 K! l; g: _* b2 [) _
* ]8 U, e$ v2 L$ X) V0 a& b
收藏 评论0 发布时间:2022-1-16 17:24

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版