堆栈使用与堆栈溢出检查

堆栈使用

维持的每个任务,都有它自己的堆栈。任务堆栈占用的内存,当任务创建时自动分配了;堆栈的尺寸参数通过xTaskCreate()?API确定。堆栈溢出是常见事件,由应用程序不确定引起的。FreeRTOS.org?因此提供了提供了两个可供选择的机制,可用来协助察觉和纠正这种事件发生。使用的选项由configCHECK_FOR_STACK_OVERFLOW 配置常量配置.

注意,这些选项仅适用于架构为内存印象不是分割的和堆栈从下到上增长。另外,一些处理器在内核溢出检测发生前能产生错误或异常来反映堆栈恶化。应用程序,必须提供堆栈溢出钩子函数,即configCHECK_FOR_STACK_OVERFLOW设置为1。钩子函数必须调用?vApplicationStackOverflowHook(),形式如下:

 


void vApplicationStackOverflowHook( xTaskHandle *pxTask, signed portCHAR *pcTaskName );

pxTask和pcTaskName参数传到钩子函数,处理和名字分别是损坏的任务。注意,根据溢出的严格性,这些参数本身会毁坏。

堆栈溢出检测引入上下文切换,这些推荐在开发和测试阶段使用。

 

堆栈溢出探测 —— 方法1

它是在内核脱离运行状态切换任务(当任务包含上下文任务)后,堆栈达到最大(最深)值。在这一点上,内核能够检测,处理器堆栈指针保留在有效的堆栈范围内。调用堆栈溢出钩子函数时,堆栈指针包含无效值。

这是个快速的方法,但不能确保能捕捉到堆栈溢出.如果使用这种方法,设置configCHECK_FOR_STACK_OVERFLOW为1.

 

堆栈溢出探测 ——方法2

当任务第一次创建它自己的堆栈——由已知的值填充。当脱离运行状态,任务切换时,内核检测最后16字节(在有效堆栈的范围内),来确保已知值不被活动的任务或中断所覆盖。调用堆栈溢出钩子函数,在初始值中不保留这16字节。

方法没有第一个方法效率高,但那是仍然很快。它可能捕捉到堆栈溢出,但是不能确保捕捉到。

与方法1结合使用这个方法,可设置configCHECK_FOR_STACK_OVERFLOW为2。仅仅使用这个方法是不可能的。

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值