STM32(HAL库)中设置中断优先级函数__NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)详解

该代码段用于设置Cortex-M3处理器的中断优先级,针对IRQn小于0的情况,如MemoryManagement_IRQn等系统中断。通过NVIC或SCB->SHP设置中断优先级,根据IRQn的值计算对应寄存器的索引,并进行位操作来设定优先级。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
{
  //当外设号大于0时设置外设中断优先级
  //原理为priority << (8U - __NVIC_PRIO_BITS左移, __NVIC_PRIO_BITS在F103系列中为4,因为在优先 
   级寄存器中(Interrupt priority registers (NVIC_IPRx))只有高四位有用,故需要将设定优先级 
   priority的值左移四位;
  if ((int32_t)(IRQn) >= 0)
  {
    NVIC->IP[((uint32_t)IRQn)]               = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
  }
   
  //当IRQn号小于0时执行下方指令
  else
  {
    SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
  }
}

本文主要说明IRQn小于0时,代码运行原理:


  MemoryManagement_IRQn       = -12,    /*!< 4 Cortex-M3 Memory Management Interrupt              */
  BusFault_IRQn               = -11,    /*!< 5 Cortex-M3 Bus Fault Interrupt                      */
  Usage
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值