痞子衡嵌入式:MCUXpresso IDE下将应用程序RW段分散链接的几种方法
大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是MCUXpresso IDE下将应用程序RW段分散链接的几种方法。
早期的 MCU 芯片,一般都会嵌入内部 Flash 和 RAM,并且 Flash 和 RAM 都只有一块(即均在连续的映射地址范围内),因此在链接应用程序时处理比较简单,程序 RO 段全部放在单一 Flash 空间,程序 RW 段全部放在单一 RAM 空间即可。
随着时代发展,现在的 MCU 越来越高端了,比如那些 Cortex-M7 内核的 MCU 中(最典型的代表 - 恩智浦 i.MXRT 系列)普遍引入了高速 TCM RAM,然后芯片内部也还有一些普通 On-chip RAM,当然芯片也能支持外扩大容量 SDRAM、PSRAM 等,在这种情况下就出现了多块地址空间不连续的 RAM 区域,这时候该如何链接程序 RW 段到这些分散的 RAM 空间里呢?
最近痞子衡在支持一个美国G客户,客户做项目选用的 MCUXpresso IDE,在这个 IDE 下客户没有找到完美的 RW 段分散链接解决方案。今天痞子衡就给大家介绍一下 MCUXpresso IDE 下分散链接的几种方法,也顺便提一下 IAR、MDK 下的做法。
- Note:本篇是 《MCUXpresso IDE下工程链接文件配置管理与自动生成机制》 一文的进阶篇。
一、准备开发环境
首先需要准备好环境,包含必要的软件,痞子衡的环境如下:
二、引入RW段分散链接问题
我们先按照 《MCUXpresso IDE下SDK工程导入与workspace管理机制》 一文步骤从 SDK 包里导入生成一个工程(就选最简单的 hello_world 吧)。工程导入成功后,会在 \MCUXpressoIDE_11.4.0_6224\workspace\evkmimxrt1170_hello_world_demo_cm7 下看到 .project 工程文件,在 MCUXpresso IDE 下打开这个工程,然后调整工程设置 Memory 定义中顺序如下:
原始 hello_world 程序里 RW 段大小为 264 bytes(包含 .data 和 .bss),再加上默认 4KB Heap 和 4KB Stack,这链接在 256 KB 的 SRAM_DTC_cm7 空间里(Alias 名为 RAM)肯定是没问题的。
我们现在在 hello_world.c 文件里加两个全局变量 s_buf1 和 s_buf2,再重新编译工程,发现工程编译不过,因为默认链接配置下 IDE 把所有 RW 段全往 Alias 名为 RAM 的空间里放,导致 RAM 空间不够用,但实际上芯片上还有很多空余 RAM2-8。怎么把空余 RAMx 利用起来?这就是问题所在,后面我们会尝试利用 RAM 和 RAM4 来解决问题。
uint8_t s_buf1[1024 * 128] = {1};
uint8_t s_buf2[1024 * 256];
int main(void)
{
s_buf1[0] = 0;
s_buf2[0] = 0;
// 代码省略...
}
三、回顾IAR/MDK上解决方案
在研究 MCUXpresso IDE 下分散链接解决方案之前,我们先看看经典 IDE 下是怎么实现的。
首先来看 IAR 下 RW 段分散链接解决方案,我们只需要修改对应链接文件 MIMXRT1176xxxxx_cm7_flexspi_nor.icf 如下,注释掉原来 DATA_Region 和 DATA2_region 的分别定义,然后使用 | 运算符将它们的 mem 空间连在一起组成新的 DATA_Region 即可,底下 IAR 链接器就会自动分配 RW, ZI 段到这个新 DATA_Region 里。
define symbol m_data_start = 0x20000000;
define symbol m_data_end = 0x2003FFFF;
define symbol m_data2_start = 0x202C0000;
define symbol m_data2_end = 0x2033FFFF;
再来看 MDK 下 RW 段分散链接解决方案,我们也只需要修改对应链接文件 MIMXRT1176xxxxx_cm7_flexspi_nor.scf 如下,需要新增加一个 RW_m_data2 执行域(注意语句摆放位置),在新执行域中也按原 RW_m_data 域中一样添加 .ANY (+RW +ZI) 即可,底下 MDK 链接器就会自动分配 RW, ZI 段到这两个 RW_m_data 空间里。
#define m_data_start 0x20000000
#define m_data_size 0x00040000
#define m_data2_start 0x202C0000
#define m_data2_size 0x00080000
四、MCUXpresso IDE下几种解决方案
现在回到主题 MCUXpresso IDE 下分散链接是怎么实现的,一共有三种方法:
4.1 借助 cr_section_macros.h 里的宏
第一种方法是借助 MCUXpresso IDE 自带的头文件 cr_section_macros.h 里的宏。用 __DATA(RamAliasName) 或者 __BSS(RamAliasName) 宏来修饰变量定义,这样 MCUXpresso IDE 在链接时会自动将该变量放到指定 RAMx 里。
4.2 借助 GNU C 的 __attribute__ 机制
第二种方法本质上与第一种一样,只不过换个形式,需要借助 GNU C 里的 __attribute__ 机制,即用 __attribute__((section("UserSectionName"))) 语法来修饰变量定义,将其放到自定义程序段里,然后在 MCUXpresso IDE 链接配置设置界面 Extra linker script input sections 框里,将自定义程序段指定到具体 RAMx 里。
4.3 手动修改 .ld 链接文件
前两种方法虽然能解决问题,但是遇到多源文件里大量变量定义时就比较麻烦了,不但需要挨个加相应修饰代码,而且也要手工计算好空间大小(合理控制自定义段大小),随着代码增删改动,做不到自适应。那么在 MCUXpresso IDE 下有没有像 IAR/MDK 解决方案那样省心的方式呢?
答案当然是有的!在 MCUXpresso IDE 链接配置设置界面去掉 Manage linker script 选项的勾选,将自动生成的 evkmimxrt1170_hello_world_demo_cm7_Debug.ld 文件在同路径下拷贝一份重新命名,然后在 Linker script 路径里指定新的链接文件。
打开链接文件 evkmimxrt1170_hello_world_demo_cm7_Debug_User.ld,在里面分别找到 Main DATA/BSS SECTION 执行域,跟在后面紧接着加上 Secondary DATA/BSS SECTION 执行域就行了(仿照 Main Section 里的写法,仅需要把 RAM 名字替换掉即可),底下 MCUXpresso IDE 链接器就会自动分配 RW, ZI 段到这两个 RAM 空间里。
至此,MCUXpresso IDE下将应用程序RW段分散链接的几种方法痞子衡便介绍完毕了,掌声在哪里~~~
欢迎订阅
文章会同时发布到我的 博客园主页、CSDN主页、知乎主页、微信公众号 平台上。
微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

痞子衡嵌入式:MCUXpresso IDE下将应用程序RW段分散链接的几种方法的更多相关文章
- 痞子衡嵌入式:ARM Cortex-M文件那些事(2)- 链接文件(.icf)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家讲的是嵌入式开发里的linker文件. 在前一节课源文件(.c/.h/.s)里,痞子衡给大家系统地介绍了source文件,source文件是嵌入 ...
- 痞子衡嵌入式:MCUXpresso IDE下使用J-Link下载算法在Flash调试注意事项(i.MXRT500为例)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下使用J-Link下载算法在Flash调试注意事项. 痞子衡前段时间写过一篇小文<为i.MXRT设计更 ...
- 痞子衡嵌入式:MCUXpresso IDE下添加C++源文件进SDK工程编译的方法
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下添加C++源文件进SDK工程编译的方法. 最近有客户反映在MCUXpresso IDE下的SDK工程里添加 ...
- 痞子衡嵌入式:MCUXpresso IDE下SDK工程导入与workspace管理机制
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下SDK工程导入与workspace管理机制. MCUXpresso IDE是恩智浦软件团队倾注很大心血研发 ...
- 痞子衡嵌入式:MCUXpresso IDE下添加新路径下源文件进工程编译的方法
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下添加新路径下源文件进工程编译的方法. 接着上篇文章 <MCUXpresso IDE下SDK工程导入与 ...
- 痞子衡嵌入式:MCUXpresso IDE下在线调试时使用不同复位策略的现象总结
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是MCUXpresso IDE下在线调试时使用不同复位策略的现象总结. 本篇实际上是<IAR在线调试时设不同复位类型可能会导致i.M ...
- 痞子衡嵌入式:MCUXpresso IDE下SDK工程在Build配置上与IAR,MDK差异
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下SDK工程在Build配置上与IAR,MDK差异. 恩智浦 SW 团队每个季度都会公布 SDK.Tool ...
- 痞子衡嵌入式:MCUXpresso IDE下工程链接文件配置管理与自动生成机制
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下工程链接文件配置管理与自动生成机制. 痞子衡在 2018 年初写过一个专题 <嵌入式开发文件系列&g ...
- 痞子衡嵌入式:MCUXpresso IDE下将关键函数重定向到RAM中执行的几种方法
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是MCUXpresso IDE下将关键函数重定向到RAM中执行的几种方法. 前段时间痞子衡写了一篇 <在IAR开发环境下将关键函数重 ...
随机推荐
- C++调试总结
一.参考: 本文主要参考<C++编程调试秘笈>一书. 在编写C++代码时,我们不应该自己捕捉缺陷,而是由编译器和可执行代码为我们做这些事情,该书便提供了这样的一个思考.作者以"调 ...
- 手撸一个SpringBoot-Starter
1. 简介 通过了解SpringBoot的原理后,我们可以手撸一个spring-boot-starter来加深理解. 1.1 什么是starter spring官网解释 starters是一组方便的依 ...
- python安全编程之指纹识别
什么是cms CMS是Content Management System的缩写,意为"内容管理系统",这是百度百科的解释,意思是相当于网站的建站模板,整个网站架构已经集成好了,只需 ...
- Podman 快速入门
今天在某云上新购一台云服务器,发现已经有了 CentOS8.2 官方镜像可选,出于对新鲜事物的好奇,我决定开始采用 CentOS8.2,即使我还没有为它的新特性做好准备. 我的应用主要以单机版容器为主 ...
- 只要套路对,薪资直接翻一倍!保姆级Android面试葵花宝典,肝完面试犹如开挂
跳槽,这在 IT 互联网圈是非常普遍的,也是让自己升职加薪,走上人生巅峰的重要方式.那么作为一个普通的Android程序猿,我们如何才能斩获大厂offer 呢? 疫情向好.面试在即,还在迷茫踌躇中的后 ...
- AspNetCore添加API限流
最近发现有客户在大量的请求我们的接口,出于性能考虑遂添加了请求频率限制. 由于我们接口请求的是.Net Core写的API网关,所以可以直接添加一个中间件,中间件中使用请求的地址当key,通过配置中心 ...
- spring学习06(AOP)
9.AOP 什么是AOP AOP(Aspect Oriented Programming)意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术.AOP是OOP的延续,是软 ...
- 终极蛇皮上帝视角之铁头娃之鲁迅之暑假闲的慌之bilibili看尚学堂网课的非洲酋长java小复习
转自https://www.sxt.cn/Java_jQuery_in_action/eight-cache-problem.html 第一个点 自动装箱与拆箱的功能是所谓的"编译器蜜糖(C ...
- WPF下获取文件运行路径、运行文件名等
在客户端开发过程中,经常需要获取相对路径的一些资源,而相对路径的就与客户端运行文件的路径息息相关了.在以前的winform开发中,我们可以使用 System.Windows.Forms.Applica ...
- SQL 练习31
查询任何一门课程成绩在 70 分以上的姓名.课程名称和分数 SELECT Sname,cname,Course.CId,SC.score from Student,Course,sc WHERE St ...