OpenEdv-开源电子网

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

STM32F407进入HardFault_Handler,串口已经输出相关代码,请高手看看怎么解决?【增加堆栈空间不管用】

[复制链接]

26

主题

186

帖子

0

精华

高级会员

Rank: 4

积分
810
金钱
810
注册时间
2014-5-30
在线时间
93 小时
发表于 2016-3-16 13:48:56 | 显示全部楼层 |阅读模式
1金钱
如题,我的407跑不多久就进入硬件错误中断了,中断中我已经输出的重要信息,如下图所示,哪位看看是哪里出问题了

附:开始时进硬件中断,后把堆栈从0x2000改为了0x4000,还是不行。系统跑了ucos II,每个任务堆栈128B

2016-03-16_134209.png


下面是输出的相关信息:
[mw_shl_code=applescript,true]  unsigned int stacked_r0;
  unsigned int stacked_r1;
  unsigned int stacked_r2;
  unsigned int stacked_r3;
  unsigned int stacked_r12;
  unsigned int stacked_lr;
  unsigned int stacked_pc;
  unsigned int stacked_psr;

  unsigned int stacked_bfar;
  unsigned int stacked_cfsr;
  unsigned int stacked_hfsr;
  unsigned int stacked_dfsr;
  unsigned int stacked_afsr;
  unsigned int stacked_scb_shcsr;

  stacked_r0 = ((unsigned long) hardfault_args[0]);
  stacked_r1 = ((unsigned long) hardfault_args[1]);
  stacked_r2 = ((unsigned long) hardfault_args[2]);
  stacked_r3 = ((unsigned long) hardfault_args[3]);

  stacked_r12 = ((unsigned long) hardfault_args[4]);
  stacked_lr = ((unsigned long) hardfault_args[5]);
  stacked_pc = ((unsigned long) hardfault_args[6]);
  stacked_psr = ((unsigned long) hardfault_args[7]);

  stacked_bfar = (*((volatile unsigned long *)(0xE000ED38)));
  stacked_cfsr = (*((volatile unsigned long *)(0xE000ED28)));
  stacked_hfsr = (*((volatile unsigned long *)(0xE000ED2C)));
  stacked_dfsr = (*((volatile unsigned long *)(0xE000ED30)));
  stacked_afsr = (*((volatile unsigned long *)(0xE000ED3C)));
  stacked_scb_shcsr = SCB->SHCSR;

  printf ("\r\n\r\n[Hard fault handler - all numbers in hex]\r\n");
  printf ("R0 = %x\r\n", stacked_r0);
  printf ("R1 = %x\r\n", stacked_r1);
  printf ("R2 = %x\r\n", stacked_r2);
  printf ("R3 = %x\r\n", stacked_r3);
  printf ("R12 = %x\r\n", stacked_r12);
  printf ("LR [R14] = %x subroutine call return address\r\n", stacked_lr);
  printf ("PC [R15] = %x program counter\r\n", stacked_pc);
  printf ("PSR = %x\r\n", stacked_psr);

  printf ("BFAR = %x\r\n", stacked_bfar);
  printf ("CFSR = %x\r\n", stacked_cfsr);
  printf ("HFSR = %x\r\n", stacked_hfsr);
  printf ("DFSR = %x\r\n", stacked_dfsr);
  printf ("AFSR = %x\r\n", stacked_afsr);
  printf ("SCB_SHCSR = %x\r\n", stacked_scb_shcsr);

  while (1);[/mw_shl_code]

最佳答案

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

ucos任务堆栈加大点试试
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

13

主题

92

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1057
金钱
1057
注册时间
2015-5-12
在线时间
208 小时
发表于 2016-3-16 13:48:57 | 显示全部楼层
ucos任务堆栈加大点试试
回复

使用道具 举报

26

主题

186

帖子

0

精华

高级会员

Rank: 4

积分
810
金钱
810
注册时间
2014-5-30
在线时间
93 小时
 楼主| 发表于 2016-3-16 15:16:48 | 显示全部楼层
numbqq 发表于 2016-3-16 14:07
ucos任务堆栈加大点试试

嗯,已经把任务堆栈加到256了,现在还在测试中
回复

使用道具 举报

26

主题

186

帖子

0

精华

高级会员

Rank: 4

积分
810
金钱
810
注册时间
2014-5-30
在线时间
93 小时
 楼主| 发表于 2016-3-17 11:15:10 | 显示全部楼层
经过1晚的测试,系统还没死,,应该是任务堆栈太低了
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-8 05:49

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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