Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
FinSH
list_thread
5
list_thread显示的栈空间不准?
发布于 2022-09-29 14:58:16 浏览:694
订阅该版
代码如下,就是先打印一下任务信息,调用函数,再打印任务信息 ```c extern long list_thread(void); void test(void) { rt_uint8_t array[256] = {0}; rt_memcpy(array,"goodbadtool",12); list_thread(); } void screen_fresh(void *parameter) { uint16_t i,j; RUN_PAGE = 1; while (1) { list_thread(); test(); #if 1 rt_event_send(&feed_dog_event, EVENT_FLAG1); ``` 此时任务栈指针是0x46,十进制70,1023-70=953 此时栈顶应该在堆栈数组953这里吧 最大使用是43%,但是sp是在0x46也不符合43%的比例 ![screenshot_图片.png](https://oss-club.rt-thread.org/uploads/20220929/c733a321a797444615dca4a62f8f7a89.png) 但是看着不像啊 ![screenshot_图片.png](https://oss-club.rt-thread.org/uploads/20220929/33d29668c7068c247a3d7178300ac124.png.webp) 然后调用函数,在函数里局部变量,显示用了66%,sp是0x2ae 686,除法结果是0.6699,这个算准吧 查看keil,发现字符串是从下标762开始的,我只是申请了256个字节是数组,结果sp变化了686-70=616这么多,为什么会是从762开始呢? 另外,list_thread这个功能不是显示最大的栈使用率,随着程序的进行,它会变,那用list_thread看栈使用率的时候,会不会输入命令的时刻,占用率低,感觉没问题,然后下一秒到一个分支里,一个大的局部变量数组,导致栈不够用呢,用这个阵容率来设置任务栈的空间大小,会不会有问题
查看更多
2
个回答
默认排序
按发布时间排序
lchnu
2022-09-29
Witness, Understand, Skill
以STM32的满递减栈为例,如下图所示, ![STM32_Stack_SP.png](https://oss-club.rt-thread.org/uploads/20220929/841eb63296f04cb654a8e59072be5582.png.webp "STM32_Stack_SP.png") 栈初始化时,所有格子都是绿色的,内容被初始化为0x23, 即'#'。 线程调用函数,thread->sp减小,向低地址生长;调用函数结束,thread->sp增大,向高地址方向生长。 打印时,显示的sp的计算公式是: ```c thread->stack_size + ((rt_ubase_t)thread->stack_addr - (rt_ubase_t)thread->sp) ``` 显然,`thread->stack_addr - thread->sp`是个负数。 你可以按照` (thread->stack_size +thread->stack_addr) - thread->sp`来进行理解,所以,sp就相当于线程指针thread->sp距离线程栈栈底的距离,是一个相对量。 至于max used部分,就是从stack_addr处递增,直到找到的数据不是0x23为止,即图中的`ptr`处,表示线程栈指针thread->sp曾经最多用到了此处。 所以计算公式是: ```c (thread->stack_size - ((rt_ubase_t) ptr - (rt_ubase_t) thread->stack_addr)) * 100 / thread->stack_size ``` 结论: `max used表示栈曾经最多被用到的百分比,sp只是线程在当前时刻的栈占用情况。不能直接根据sp来推断max used`。我在开发中,一般max used在70%左右可以接受,适当留些余量。
JonasWen
2022-09-29
这家伙不懒,但是什么也不想写!
sp是当前线程栈指针的位置,线程创建时会把所有的线程栈空间初始化成0x23, max_used是根据栈空间的使用情况计算的。 ```c ptr = (rt_uint8_t *)thread->stack_addr; while (*ptr == '#')ptr ++; ```
撰写答案
登录
注册新账号
关注者
0
被浏览
694
关于作者
伊森亨特
这家伙很懒,什么也没写!
提问
77
回答
31
被采纳
0
关注TA
发私信
相关问题
1
RT-THREAD shell无反应呢?
2
RT-thread2.0beta下用类似linux风格MSH,参数如何输入和导出
3
rt-thread finsh windows下的那个终端软件叫什么来着
4
板子上只有485接口,能把FINSH改造成485的么?
5
finsh最大字符问题
6
finsh命令个数是不是有限制啊
7
finsh支持转义字符吗
8
不用finsh如何知道堆栈使用量
9
强烈建议 RT-Thread下finsh原理深入分析
10
finsh输入命令全部返回null node
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
【RT-Thread】【ci】【scons】将ci.attachconfig.yml和scons结合使用
2
Rt-thread中OTA下载后,bootloader不搬程序
3
ulog 日志 LOG_HEX 输出时间改为本地日期时间
4
在RT-Thread Studio中构建前执行python命令
5
研究一了一段时间RTT,直接标准版上手太难,想用nano,但又舍不得组件
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
I2C_IIC
ESP8266
UART
WIZnet_W5500
ota在线升级
cubemx
PWM
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
xusiwei1236
8
个答案
2
次被采纳
踩姑娘的小蘑菇
1
个答案
2
次被采纳
用户名由3_15位
9
个答案
1
次被采纳
bernard
4
个答案
1
次被采纳
RTT_逍遥
3
个答案
1
次被采纳
本月文章贡献
聚散无由
2
篇文章
15
次点赞
catcatbing
2
篇文章
5
次点赞
Wade
2
篇文章
4
次点赞
Ghost_Girls
1
篇文章
7
次点赞
xiaorui
1
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部