完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
#if( ( configCHECK_FOR_STACK_OVERFLOW > 1 ) || ( configUSE_TRACE_FACILITY == 1 ) || ( INCLUDE_uxTaskGetStackHighWaterMark == 1 ) )
{ /* Fill the stack with a known value to assist debugging. */ ( void ) memset( pxNewTCB->pxStack, ( int ) tskSTACK_FILL_BYTE, ( size_t ) ulStackDepth * sizeof( StackType_t ) ); //1如果使能了堆栈的溢出检测功能或者追踪功能的话使用一个定值tskSTACK_FILL_BYTE来填充任务堆栈,这个值为0xa5U } #endif /* ( ( configCHECK_FOR_STACK_OVERFLOW > 1 ) || ( ( configUSE_TRACE_FACILITY == 1 ) || ( INCLUDE_uxTaskGetStackHighWaterMark == 1 ) ) ) */ /* Calculate the top of stack address. This depends on whether the stack grows from high memory to low (as per the 80x86) or vice versa. portSTACK_GROWTH is used to make the result positive or negative as required by the port. */ #if( portSTACK_GROWTH < 0 ) { pxTopOfStack = pxNewTCB->pxStack + ( ulStackDepth - ( uint32_t ) 1 ); //2 计算堆栈栈顶pxTopOfStack初始化任务堆栈的时候用到 请问pxNewTCB->pxStack 是栈底还是整个堆栈 怎么理解 |
|
相关推荐
3个回答
|
|
首先,不管是堆还是栈,归根到底都还是内存,在单片机中都是用ram实现的.
额,就像我们操作数组一样,我们仅仅需要知道数组的首地址和长度。这里的pxNewTCB->pxStack就是这个数组的首地址,而ulStackDepth就是这个数组的长度。 但是呢,栈跟数组又不一样,栈是向下增长的。高地址->低地址。 我们需要的栈顶指针就类似与数组最后一个元素的地址。所以就是数组首地址+数组长度。 |
|
|
|
楼上说的不错
|
|
|
|
这个楼主单步断点走一下就知道了。STM32来说 任务开辟的堆栈实际上是uxHEap(当然也可以链接到头文件的堆里面),其中低地址是栈,高地址是堆。随着堆得增加,栈竟然蹭蹭的往低地址移动。
|
|
|
|
只有小组成员才能发言,加入小组>>
722 浏览 0 评论
1123 浏览 1 评论
2502 浏览 5 评论
2840 浏览 9 评论
移植了freeRTOS到STMf103之后显示没有定义的原因?
2683 浏览 6 评论
使用eim外接fpga可是端口一点反应都没有有没有大哥指点一下啊
664浏览 9评论
679浏览 7评论
请教大神怎样去解决iMX6Q在linux3.0.35内核上做AP失败的问题呢
794浏览 6评论
641浏览 5评论
682浏览 5评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-28 22:19 , Processed in 0.878414 second(s), Total 52, Slave 42 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号