OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6266|回复: 5

STM32f205主频120M时,进入定时中断后进人HardFault_Handler硬件错误问题

[复制链接]

1

主题

3

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2021-1-13
在线时间
3 小时
发表于 2021-5-31 14:12:21 | 显示全部楼层 |阅读模式
1金钱
最近用到STM32F205芯片,遇到一个问题,希望能有大神帮忙解惑!在使用中发现120M主频时,只要一进入中断几次就会进入HardFault_Handler硬件错误
下面是中断函数使用的是定时中断TIM2
TIM2_Int_Init(999,2000-1);
使用2000分频,重载999
void TIM2_Int_Init(u16 arr,u16 psc)
{
  TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;
  NVIC_InitTypeDef NVIC_InitStructure;

  RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);  
  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
  NVIC_InitStructure.NVIC_IRQChannel=TIM2_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0x00;
  NVIC_InitStructure.NVIC_IRQChannelSubPriority=0x00;
  NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
  NVIC_Init(&NVIC_InitStructure);
  TIM_DeInit(TIM2);
  TIM_TimeBaseInitStructure.TIM_Period = arr;         
  TIM_TimeBaseInitStructure.TIM_Prescaler=psc;  
  TIM_TimeBaseInitStructure.TIM_CounterMode=TIM_CounterMode_Up;
  TIM_TimeBaseInitStructure.TIM_ClockDivision=TIM_CKD_DIV1;

  TIM_TimeBaseInit(TIM2,&TIM_TimeBaseInitStructure);
  TIM_ClearFlag(TIM2, TIM_FLAG_Update);
  TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);
  TIM_Cmd(TIM2,ENABLE);
}

void TIM2_IRQHandler(void)
{
  if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)
  {      
    TIM_ClearITPendingBit(TIM2, TIM_IT_Update);               
           Information.tempflashnum++;//主函数周期
          Information.oneSnum++;
                Information.DOGnum++;
  }
}

我使用在线调试跟踪进入HardFault_Handler之前是执行到了Information.tempflashnum++;这一句。
重点来了,当我把清中断TIM_ClearITPendingBit(TIM2, TIM_IT_Update);        函数放在最后如下方式
void TIM2_IRQHandler(void)
{
  if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET)
  {      
           
           Information.tempflashnum++;//主函数周期
          Information.oneSnum++;
                Information.DOGnum++;
     TIM_ClearITPendingBit(TIM2, TIM_IT_Update);       
  }
}

就不会进入HardFault_Handler,程序能够正常跑起来。Information.tempflashnum,Information.oneSnum,Information.DOGnum都有置零的地方,
不能是累加溢出。分步分析没有堆栈溢出,指针越界的问题出现。进入中断立刻清中断就会死机,在最后清中断就不会,很奇怪的问题。
到后来实在没有办法了,我把主频改为72m之后一切就都正常了。哪位大神是否要相同的问题,帮忙解惑一下,非常感谢!

最佳答案

查看完整内容[请看2#楼]

最后查出是电路问题,这个项目是接的烂尾的二手项目,电路板都做出几百套了,所以一直就没考虑电路能有问题。STM32F205的VCAP_1,VCAP_2需要连接2.2UF电容接地,不能悬空。我这边电路二个脚悬空了,所以在最大主频120M来跑的时候就会出现不可预知的错误。现在硬件无法改动了,只能期望把主频改为72M它能长时间跑不出现问题。谢谢您的解答
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

3

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2021-1-13
在线时间
3 小时
 楼主| 发表于 2021-5-31 14:12:22 | 显示全部楼层
nstopb 发表于 2021-6-1 08:51
你说累加溢出就能体现你的C语言功底不合格,变量溢出又不是地址越界,并不会导致硬件错误,你的描述全都不 ...

最后查出是电路问题,这个项目是接的烂尾的二手项目,电路板都做出几百套了,所以一直就没考虑电路能有问题。STM32F205的VCAP_1,VCAP_2需要连接2.2UF电容接地,不能悬空。我这边电路二个脚悬空了,所以在最大主频120M来跑的时候就会出现不可预知的错误。现在硬件无法改动了,只能期望把主频改为72M它能长时间跑不出现问题。谢谢您的解答
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2021-6-1 01:02:12 | 显示全部楼层
是不是买到假货了?
回复

使用道具 举报

4

主题

83

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
205
金钱
205
注册时间
2019-11-12
在线时间
77 小时
发表于 2021-6-1 08:51:22 | 显示全部楼层
你说累加溢出就能体现你的C语言功底不合格,变量溢出又不是地址越界,并不会导致硬件错误,你的描述全都不能作为准确的前提了。查查定时器中断里那几个变量有没有在代码的某些地方作为数组的下标了。
回复

使用道具 举报

1

主题

3

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2021-1-13
在线时间
3 小时
 楼主| 发表于 2021-6-2 09:41:03 | 显示全部楼层
nstopb 发表于 2021-6-1 08:51
你说累加溢出就能体现你的C语言功底不合格,变量溢出又不是地址越界,并不会导致硬件错误,你的描述全都不 ...

累加溢出是不能造成硬件错误,我只是阐述把所有可能出现的问题都排除掉,的确我也是半路出家的,一直在做仪器,C语言都几年没碰了。最后找到原因了,是电路问题,这个项目是接的烂尾的二手项目,电路板都做出几百套了,所以一直就没考虑电路能有问题。STM32F205的VCAP_1,VCAP_2需要连接2.2UF电容接地,不能悬空。我这边电路二个脚悬空了,所以在最大主频120M来跑的时候就会出现不可预知的错误。现在硬件无法改动了,只能期望把主频改为72M它能长时间跑不出现问题。谢谢您的解答
回复

使用道具 举报

1

主题

39

帖子

0

精华

高级会员

Rank: 4

积分
812
金钱
812
注册时间
2019-1-31
在线时间
106 小时
发表于 2021-6-4 09:44:24 | 显示全部楼层
感谢分享经验
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-22 22:37

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表