【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 版权协议,转载请附上原文出处链接和本声明。

相关推荐
我要昵称干什么2 小时前
STM32学习——RTC实时时钟(BKP与RTC外设)
c语言·stm32·单片机·嵌入式硬件·学习·实时音视频
YueiL3 小时前
物联网通信应用案例之《智慧农业》
单片机·嵌入式硬件·物联网
打酱油的工程师3 小时前
w803|联盛德|WM IoT SDK2.X测试|pinout|(2):w803开发板简介
单片机·物联网·w80x
桀骜陷阱3 小时前
【江科协-STM32】5. 输出比较
stm32·单片机·嵌入式硬件
嵌入式Linux,4 小时前
当单片机遇到这颗LED驱动芯片,
单片机·嵌入式硬件
BW.SU5 小时前
51单片机制作彩屏触摸小电子琴STC32G12K128+RA6809+彩屏1024x600
单片机·嵌入式硬件·51单片机·freertos·stc32g12k128
weixin_1122335 小时前
基于ARM的嵌入式温度控制系统的设计
arm开发
wenchm5 小时前
细说STM32F407单片机RS485收发通信实例及调试方法
stm32·单片机·嵌入式硬件
桀骜陷阱5 小时前
【江科协-STM32】1. GPIO
stm32·单片机·嵌入式硬件