欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > 【ARM】如何通过ARMDS的Map文件查看堆栈调用情况

【ARM】如何通过ARMDS的Map文件查看堆栈调用情况

2025/2/27 7:21:20 来源:https://blog.csdn.net/Emdoor123/article/details/145870008  浏览:    关键词:【ARM】如何通过ARMDS的Map文件查看堆栈调用情况

1、 文档目标

通过ARMDS生成的Map文件,查看工程的堆栈使用情况。

2、 问题场景

在对于工程进行调试和测试的时候,工程师通常需要了解目前工程的堆栈使用情况,是否有函数或者变量占用了过多的堆栈空间。或者在对于一些错误进行排查的时候也需要查看堆栈的使用情况。除了可以查看callgraph文件外,也可以通过Map文件进行查看。

3、软硬件环境

1)、软件版本:ARM DS 2023.0

2)、电脑环境:Windows 11

3)、外设硬件:无

4、解决方法

1)、ARMDS要生成Map文件需要在Properties窗口中,C/C++ Build->Setting->Arm Linker 6->Additional Information配置中,勾选Generate image map(--map)。并且在最下面的Redirect diagnostics output to file(--list)后面的输入框中输入map文件的文件名(如图4-1)。

如果需要查看全局变量的堆栈使用情况,需要勾选上List stack usage of global symbols这个选项。

 图4-1

2)、重新构建工程后,就可以在工程目录下面看到map文件的生成了。(如图4-2)

图4-2

3)、在Map文件的Image Stack Usage Information.部分就可以看全局变量的堆栈情况了(如图4-3)

Maximum stack usage for Image.(Image部分的最大堆栈使用量)Maximum Stack Usage for svcRtxKernelStart 0xe8 bytes.(svcRtxKernelStart的最大堆栈使用率0xe8字节)
Call chain for maximum stack usage(最大堆栈使用的调用链:):
svcRtxKernelStart => osRtxThreadStartup => svcRtxThreadNew => osRtxMemoryAlloc => MemBlockPtr(最大调用链)........Maximum Stack Usage for LED_Initialize 0x70 bytes.(LED_Initialize的最大堆栈使用率为0x70字节。)
Call chain for maximum stack usage(最大堆栈使用的调用链):
LED_Initialize => HAL_GPIO_Init(最大调用链)

图4-3

————————————————————————

​ 版权声明:本文为亿道电子技术有限公司原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词