【ARM】DS如何查看工程的堆栈使用情况

1、 文档目标

通过ARMDS的设置项生成对应的文件,便于查看工程各个函数的堆栈的占用情况。

2、 问题场景

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

3、软硬件环境

1)、软件版本:ARMDS 2023.0

2)、电脑环境:Windows 11

3)、外设硬件:无

4、解决方法

1)、可以通过对应工程的Properties窗口中,C/C++ Build->Setting->Arm Linker 6->Additional Information配置中,有一个Generate call graph(--callgraph)的选项(如图4-1)。这个选项可以生成记录工程函数的调用关系的文件。

图4-1

2)、设置好后,重新对于工程进行构建后就可以在工程管理窗口中下看生成的TXT文件。(如图4-2)

图4-2

3)、在生成的文件中,可以看到在工程中使用的LED_Initialize函数的调用情况和堆栈情况(如图4-3)。

复制代码
	LED_Initialize (Thumb(使用的指令集), 160 bytes(函数的大小), Stack size 48 bytes(堆栈的大小), LED_769I_EVAL.o(.text.LED_Initialize)(函数所在的源文件))

		[Stack]

			Max Depth = 112(最大堆栈深度)			Call Chain = LED_Initialize => HAL_GPIO_Init(函数的调用关系)


		[Calls](该函数调用了什么函数)

			 * HAL_GPIO_WritePin
			 * HAL_GPIO_Init

		[Called By](哪个函数调用了这个函数)

			 * main

图4-3

4)、Additional Information配置中还有两个选项(如图4-4)。

(1)、Callgraph file(--callgraph_file):指定生成的文件的文件名,不设置的情况下,默认使用工程名字。

(2)、Callgraph format (--callgraph_output):控制生成文件的类型,这里有HTML和TEXT两种选项。根据需求选择即可。

图4-4


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

相关推荐
项目題供诗1 小时前
51单片机入门(八)
单片机·嵌入式硬件·51单片机
羽获飞1 小时前
从零开始学嵌入式之STM32——9.STM32的时钟系统
stm32·单片机·嵌入式硬件
来自晴朗的明天3 小时前
13、NMOS 电源防反接电路
单片机·嵌入式硬件·硬件工程
17(无规则自律)3 小时前
深入浅出 Linux 内核模块,写一个内核版的 Hello World
linux·arm开发·嵌入式硬件
芯岭技术3 小时前
PY32MD310单片机:高性能、低功耗的32位电机控制微控制器
单片机·嵌入式硬件
wotaifuzao4 小时前
STM32 + FreeRTOS 的订阅通知组件架构
stm32·嵌入式硬件·架构·freertos·事件驱动·嵌入式架构
小龙报5 小时前
【51单片机】深度解析 51 串口 UART:原理、配置、收发实现与工程化应用全总结
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·51单片机
Lester_110112 小时前
STM32 高级定时器PWM互补输出模式--如果没有死区,突然关闭PWM有产生瞬间导通的可能吗
stm32·单片机·嵌入式硬件·嵌入式软件
小李独爱秋14 小时前
“bootmgr is compressed”错误:根源、笔记本与台式机差异化解决方案深度指南
运维·stm32·单片机·嵌入式硬件·文件系统·电脑故障
梁洪飞16 小时前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm