news 2026/4/23 14:29:06

S32K3启动RAM数据初始化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
S32K3启动RAM数据初始化

想要搞清这个问题,需要重点研究startup_cm.s文件。

启动时,RAM数据的初始化主要包括两个过程:

  1. RAM区域初始化(数据清0);
  2. 有初始值的变量需要从flash中加载到ram中。

RAM区域初始化

这一段代码由汇编实现,在startup_cm.s中,主要由DTCM_Init和RamInit实现的,贴一段DTCM_Init的代码:

DTCM_Init:
/* Initialize DTCM ECC */
LDR R0, =__DTCM_INIT
CMP R0, #0
/* Skip if __DTCM_INIT is not set */
beq DTCM_LOOP_END

LDR R1, =__INT_DTCM_START
LDR R2, =__INT_DTCM_END

SUBS R2, R1
SUBS R2, #1
BLE DTCM_LOOP_END

MOVS R0, #0
MOVS R3, #0
DTCM_LOOP:
STM R1!, {R0, R3}
SUBS R2, #8
BGE DTCM_LOOP
DTCM_LOOP_END:

加载变量

在startup_cm.s中有个函数_DATA_INIT,通过该函数跳转到C代码startup.c,由init_data_bss这个函数实现。分析init_data_bss的代码,可以发现__INIT_TABLE作为.init_table起始地址的标签,会被强转为Sys_CopyLayoutType *结构体指针,

typedef struct

{

uint32 * ram_start; /*!< Start address of section in RAM */

uint32 * rom_start; /*!< Start address of section in ROM */

uint32 * rom_end; /*!< End address of section in ROM */

} Sys_CopyLayoutType;

然后访问该结构体的成员,就得到了相应区域的ram起始地址,rom起始地址,rom结束地址,从而实现数据从flash加载到ram中。

最后贴一下__INIT_TABLE,可以发现每三行正好对应结构体的3个成员:
__INIT_TABLE
DCD 9
DCD rwBlock$$Base
DCD cacheable_data_init$$Base
DCD cacheable_data_init$$Limit
DCD rwMcalDataBlock$$Base
DCD cacheable_mcal_data_init$$Base
DCD cacheable_mcal_data_init$$Limit
DCD ramCodeBlock$$Base
DCD cacheable_code_init$$Base
DCD cacheable_code_init$$Limit
DCD dataNcBlock$$Base
DCD non_cacheable_data_init$$Base
DCD non_cacheable_data_init$$Limit
DCD constNcBlock$$Base
DCD non_cacheable_const_init$$Base
DCD non_cacheable_const_init$$Limit
DCD dataShBlock$$Base
#if (!defined(CORE0) && defined(MULTIPLE_IMAGE))
DCD 0
DCD 0
#else
DCD shareable_data_init$$Base
DCD shareable_data_init$$Limit
#endif
DCD intcVectorBlock$$Base
DCD interrupt_vector_init$$Base
DCD interrupt_vector_init$$Limit

DCD dataDtcmBlock$$Base
DCD dtcmDataBlock_init$$Base
DCD dtcmDataBlock_init$$Limit
DCD textItcmBlock$$Base
DCD itcmCodeBlock_init$$Base
DCD itcmCodeBlock_init$$Limit
__INIT_TABLE_END

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 9:48:20

实时对抗类游戏AI难训练?破解高动态环境下的3大技术瓶颈

第一章&#xff1a;实时对抗类游戏AI训练的挑战与机遇实时对抗类游戏为人工智能提供了极具挑战性的测试平台。这类环境不仅要求AI具备快速决策能力&#xff0c;还需在信息不完全、对手策略动态变化的情况下持续适应。由于每局对战的时间步长极短&#xff0c;且动作空间庞大&…

作者头像 李华
网站建设 2026/4/23 11:14:21

CDMA在移动通信系统中的应用研究与仿真

一、CDMA技术原理及在移动通信中的核心优势 CDMA&#xff08;码分多址&#xff09;是基于扩频通信技术的多址接入方式&#xff0c;其核心原理是通过不同的伪随机码&#xff08;PN码&#xff09;区分用户信号&#xff0c;实现多用户在同一频率和时间资源上的并行通信。在发送端&…

作者头像 李华
网站建设 2026/4/19 4:16:43

【值得收藏】大模型实战教程:从基础原理到企业应用,零门槛掌握AI开发

本文全面介绍大模型技术&#xff0c;涵盖AI概念、应用场景、企业落地方法、技术原理与架构及本地部署。强调大模型是提升企业效率的工具&#xff0c;通过业务流程解构可找到落地场景。同时指出大模型存在的短板和多种技术架构选择&#xff0c;为读者提供从理论到实践的完整学习…

作者头像 李华
网站建设 2026/4/22 3:20:01

终极指南:轻松解决NVIDIA显卡风扇30%转速限制

终极指南&#xff1a;轻松解决NVIDIA显卡风扇30%转速限制 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/FanCont…

作者头像 李华
网站建设 2026/4/18 17:05:39

12.18 Datav的使用

vue2使用DataV&#xff1a;http://datav.jiaminghi.com/guide/ vue3使用DataV&#xff1a;https://datav-vue3.jiaminghi.com/guide/ 注意&#xff1a;目前为止&#xff0c;文档中的使用方式是vue2的使用方式&#xff0c;所以必须使用vue2的方式搭建环境 创建vue项目 查看是…

作者头像 李华