打印
[Cortex-M0技术交流]

CMSIS 头文件的bug

[复制链接]
2786|4
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
X-Hawk|  楼主 | 2012-12-11 12:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
BUG, ic, vi, rio, IO
问题出在函数 NVIC_GetPriority

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


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

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

代码修正如下

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


相关帖子

沙发
YDMCP| | 2012-12-11 18:26 | 只看该作者

使用特权

评论回复
板凳
zjw5000| | 2012-12-12 21:00 | 只看该作者
标记!

使用特权

评论回复
地板
arm86| | 2012-12-13 16:52 | 只看该作者
mark!高~

使用特权

评论回复
5
dong_abc| | 2012-12-13 18:28 | 只看该作者
这么个细节都能揪出来,真厉害!

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3

主题

380

帖子

3

粉丝