OpenEdv-开源电子网

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

堆栈不够,怎样查看当前使用的堆大小

[复制链接]

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
发表于 2016-11-19 14:40:20 | 显示全部楼层 |阅读模式
1金钱
程序调试的时候发现程序执行到定时器中断初始化时总是进入HardFault错误
void HardFault_Handler(void)
{
  /* Go to infinite loop when Hard Fault exception occurs */
  while (1)
  {
  }
}

网上查了一圈,可能是数组越界或者堆栈不够,数组都查了一遍,不会越界,堆栈的话没有改过,如图1.
我想问的是如何查看当前使用的堆栈大小,是否大于设置的堆栈
3333.PNG
33.PNG

最佳答案

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

程序还没有开始运行的时候,会有一个SP值,运行到这里显示一个SP值,相减就是当前使用量了
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

65

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
383
金钱
383
注册时间
2015-4-15
在线时间
73 小时
发表于 2016-11-19 14:40:21 | 显示全部楼层
起舞弄清影 发表于 2016-11-19 15:05
地址为0x20000808,那使用堆栈的大小呢

程序还没有开始运行的时候,会有一个SP值,运行到这里显示一个SP值,相减就是当前使用量了
回复

使用道具 举报

2

主题

65

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
383
金钱
383
注册时间
2015-4-15
在线时间
73 小时
发表于 2016-11-19 14:44:35 | 显示全部楼层
本帖最后由 dengxingling8 于 2016-11-19 14:51 编辑

如果你现在SRAM足够,增加栈空间试试,看看还有没有问题。如果是想要查看当前堆栈,仿真的时候,就可以看到了
回复

使用道具 举报

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
 楼主| 发表于 2016-11-19 14:56:11 | 显示全部楼层
dengxingling8 发表于 2016-11-19 14:44
如果你现在SRAM足够,增加栈空间试试,看看还有没有问题。如果是想要查看当前堆栈,仿真的时候,就可以看到 ...

我就是想问下怎样知道当前使用的堆栈大小,仿真图在上面
回复

使用道具 举报

2

主题

65

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
383
金钱
383
注册时间
2015-4-15
在线时间
73 小时
发表于 2016-11-19 14:57:11 | 显示全部楼层
起舞弄清影 发表于 2016-11-19 14:56
我就是想问下怎样知道当前使用的堆栈大小,仿真图在上面

sp就是当前的栈地址
回复

使用道具 举报

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
 楼主| 发表于 2016-11-19 15:05:10 | 显示全部楼层
dengxingling8 发表于 2016-11-19 14:57
sp就是当前的栈地址

地址为0x20000808,那使用堆栈的大小呢
回复

使用道具 举报

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
 楼主| 发表于 2016-11-19 15:14:40 | 显示全部楼层
dengxingling8 发表于 2016-11-19 15:08
程序还没有开始运行的时候,会有一个SP值,运行到这里显示一个SP值,相减就是当前使用量了

程序未运行时如图1,运行到死循环如图2.SP的值不仅没有增大,反而减小了!!!!!!!!!!! 111.PNG
222.PNG
回复

使用道具 举报

2

主题

65

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
383
金钱
383
注册时间
2015-4-15
在线时间
73 小时
发表于 2016-11-19 15:16:41 | 显示全部楼层
起舞弄清影 发表于 2016-11-19 15:14
程序未运行时如图1,运行到死循环如图2.SP的值不仅没有增大,反而减小了!!!!!!!!!!!

这里SP是向下增长的,用一个就会少一个,当然是最开始的时候最大了,用的越多越小。。
回复

使用道具 举报

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
 楼主| 发表于 2016-11-19 15:25:28 | 显示全部楼层
dengxingling8 发表于 2016-11-19 15:16
这里SP是向下增长的,用一个就会少一个,当然是最开始的时候最大了,用的越多越小。。

那这里所用的堆栈大小也就0x100咯,小于配置的堆栈,那会不会是中断优先级的问题,我用到了一个串口两个定时器,其中一个定时器每次中断200ms时打开另一个定时器中断判断接收数据是否完成
回复

使用道具 举报

2

主题

65

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
383
金钱
383
注册时间
2015-4-15
在线时间
73 小时
发表于 2016-11-19 15:48:06 | 显示全部楼层
起舞弄清影 发表于 2016-11-19 15:25
那这里所用的堆栈大小也就0x100咯,小于配置的堆栈,那会不会是中断优先级的问题,我用到了一个串口两个 ...

这个就需要看一下代码了,执行到哪一步出现这个问题的,单步调试一下
回复

使用道具 举报

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
 楼主| 发表于 2016-11-19 16:29:56 | 显示全部楼层
dengxingling8 发表于 2016-11-19 15:48
这个就需要看一下代码了,执行到哪一步出现这个问题的,单步调试一下

如图1,我如果一直单步调试的话,则到TIM2_Int_Init(2000-1,8400-1);        程序就进入出错死循环,
如果我单步运行时进入到TIM2_Int_Init(2000-1,8400-1)里面去,则在定时器中断初始化进入死循环NVIC_Init(&NVIC_InitStructure),如图2;

如果我再单步进入NVIC_Init(&NVIC_InitStructure)函数内部,那么又没出错,甚至TIM2_Int_Init(2000-1,8400-1)都没出错,但是下一个函数        PS2_Init()却出错了。。。我都不知道到底是哪里错了
回复

使用道具 举报

14

主题

63

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
224
金钱
224
注册时间
2016-4-16
在线时间
62 小时
 楼主| 发表于 2016-11-19 16:30:39 | 显示全部楼层
起舞弄清影 发表于 2016-11-19 16:29
如图1,我如果一直单步调试的话,则到TIM2_Int_Init(2000-1,8400-1);        程序就进入出错死循环,
如果我单 ...

图片在这
捕获111.PNG
捕获222.PNG
回复

使用道具 举报

2

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2017-9-15
在线时间
6 小时
发表于 2019-11-15 23:31:13 | 显示全部楼层
你是不是在串口初始化就把总中断打开了?如果打开,后面的定时器配置过程可能瞬间进入中断,其实重载=0,一直退不出中断。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-15 13:27

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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