[Cortex-M0技术交流] CMSIS 头文件的bug

[复制链接]
3295|4
 楼主| X-Hawk 发表于 2012-12-11 12:13 | 显示全部楼层 |阅读模式
BUG, ic, vi, rio, IO
问题出在函数 NVIC_GetPriority

  1. __STATIC_INLINE uint32_t NVIC_GetPriority(IRQn_Type IRQn)
  2. {
  3.   if(IRQn < 0) {
  4.     return((uint32_t)((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) >> (8 - __NVIC_PRIO_BITS)));  } /* get priority for Cortex-M0 system interrupts */
  5.   else {
  6.     return((uint32_t)((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) >> (8 - __NVIC_PRIO_BITS)));  } /* get priority for device specific interrupts  */
  7. }


这里移位时发生了错误,高位没有去除。
例如:如果 IRQn == 26 ,并且 NVIC->IP[ _IP_IDX(IRQn)] == 0x40404040,
函数返回优先级为 0x101.

实际上正确的返回值应为 1

代码修正如下

  1. __STATIC_INLINE uint32_t NVIC_GetPriority(IRQn_Type IRQn)
  2. {
  3.   if(IRQn < 0) {
  4.     return 0xFF & ((uint32_t)((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) >> (8 - __NVIC_PRIO_BITS)));  } /* get priority for Cortex-M0 system interrupts */
  5.   else {
  6.     return 0xFF & ((uint32_t)((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) >> (8 - __NVIC_PRIO_BITS)));  } /* get priority for device specific interrupts  */
  7. }


YDMCP 发表于 2012-12-11 18:26 | 显示全部楼层
zjw5000 发表于 2012-12-12 21:00 | 显示全部楼层
标记!
arm86 发表于 2012-12-13 16:52 | 显示全部楼层
mark!高~
dong_abc 发表于 2012-12-13 18:28 | 显示全部楼层
这么个细节都能揪出来,真厉害!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3

主题

380

帖子

3

粉丝
快速回复 在线客服 返回列表 返回顶部