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

相关推荐
globbo2 小时前
【嵌入式STM32】I2C总结
单片机·嵌入式硬件
玖別ԅ(¯﹃¯ԅ)3 小时前
SysTick寄存器(嘀嗒定时器实现延时)
stm32·单片机·嵌入式硬件
Blossom.1184 小时前
把 AI 推理塞进「 8 位 MCU 」——0.5 KB RAM 跑通关键词唤醒的魔幻之旅
人工智能·笔记·单片机·嵌入式硬件·深度学习·机器学习·搜索引擎
桃源学社(接毕设)6 小时前
基于人工智能和物联网融合跌倒监控系统(LW+源码+讲解+部署)
人工智能·python·单片机·yolov8
玖別ԅ(¯﹃¯ԅ)6 小时前
PID学习笔记6-倒立摆的实现
笔记·stm32·单片机
YLAD6 小时前
gnu arm toolchain中的arm-none-eabi-gdb.exe的使用方法?
arm开发
饶宇航8 小时前
嵌入式硬件——ARM
arm开发
清风66666611 小时前
基于51单片机的手机蓝牙控制8位LED灯亮灭设计
单片机·嵌入式硬件·智能手机·毕业设计·51单片机·课程设计
anghost15018 小时前
基于单片机的超市储物柜设计
单片机·嵌入式硬件·超市储物柜设计
尘似鹤1 天前
旋钮键盘项目---foc讲解(开环)
单片机·嵌入式硬件