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

相关推荐
嵌入式老牛3 小时前
HC32F460_ADC驱动(三)
单片机·嵌入式硬件
秀秀更健康3 小时前
stm32: 系统时钟如何配置为72Mhz
stm32·单片机·嵌入式硬件
归零鸟9 小时前
WD Elements移动硬盘能识别出盘但不能出盘的修复记录
stm32·单片机·嵌入式硬件
追兮兮10 小时前
MCUQuickStart v1.1.0发布,一键生成Keil工程+RTOS模板
stm32·单片机·嵌入式硬件·freertos·gd32·keil5
国科安芯10 小时前
ASP7A84AS与主流架构兼容替代及系统级电源完整性解决方案的深度研究
单片机·嵌入式硬件·架构
kaikaile199510 小时前
STC8单片机实现简单花样DMX512控制器
单片机·嵌入式硬件
szxinmai主板定制专家10 小时前
RK3568 + CODESYS+实时系统运动控制器PLC,支持 AI 视觉目标检测,预测性维护,混合多系统部署,多路模拟量采集
arm开发·人工智能·嵌入式硬件·fpga开发
rit843249910 小时前
STM32移植NES模拟器指南
stm32·单片机·嵌入式硬件
都在酒里10 小时前
STM32 I2C通信协议详解——标准库函数实现(通讯协议总结一)
stm32·嵌入式硬件·i2c