0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MCUXpresso IDE下将应用程序RW段分散链接的几种方法

冬至子 来源:痞子衡嵌入式 作者:痞子衡 2022-11-17 11:47 次阅读

早期的 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 下的做法。

一、准备开发环境

首先需要准备好环境,包含必要的软件,痞子衡的环境如下:

集成开发环境:MCUXpresso IDE_11.4.0_6224,点此下载

软件开发包:SDK_2.10.0_EVK-MIMXRT1170(Toolchain需包含MCUXpresso IDE),点此下载

二、引入RW段分散链接问题

我们先从 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段分散链接的几种方法便介绍完毕了,掌声在哪里~~~

审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • SDRAM
    +关注

    关注

    7

    文章

    423

    浏览量

    55171
  • RAM
    RAM
    +关注

    关注

    8

    文章

    1368

    浏览量

    114570
  • Flash单片机
    +关注

    关注

    0

    文章

    111

    浏览量

    9392
  • MCU芯片
    +关注

    关注

    3

    文章

    249

    浏览量

    11406
收藏 人收藏

    评论

    相关推荐

    设备驱动程序通知应用程序有哪几种方法

    请问各位,设备驱动程序通知应用程序有哪几种方法
    发表于 04-27 07:10

    分享MCUXpresso IDE关键函数重定向到RAM中执行的几种方法

      大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是MCUXpresso IDE关键函数重定向到RAM中执行的几种方法
    发表于 02-10 06:44

    MCUXpresso IDE应用程序RW分散链接有哪几种方法

    MCUXpresso IDE应用程序RW
    发表于 02-10 08:03

    如何示例项目导入MCUXpresso IDE

    使用 RT1050 板,并有这个例子。我阅读了 RT1020 板支持 mc_pmsm 与板 FRDM-MC-LVPMSM 组合的文档。我正在寻找如何示例项目导入 MCUXpresso IDE,有人可以帮助我吗?
    发表于 03-16 08:15

    如何在MCUXpresso IDE上使用芯片上的所有SRAM?

    内存放入 SRAM_OC2,SRAM_ITC_cm7 的内存使用从 150% 减少到 140% .顺便说一句,在应用程序链接到RAM时是否需要将SRAM_ITC_cm7设置为第一个?我已经具有512KB的SRAM_OC1设置为
    发表于 04-14 08:01

    MIMXRT1060-EVK板 +MCUXpresso IDE如何恢复RT板?

    Provisioning Tool在串行下载模式进行代码下载或批量擦除,这种方法也可以恢复电路板,实际上只是让内核处于已知状态。 SPT工具下载链接:https://www.nxp.com/design
    发表于 04-20 08:31

    MCUXpresso IDE在Flash调试的注意事项

    大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是 MCUXpresso IDE 使用 J-Link 下载算法在 Flash 调试注意事项。 介绍一如何使用新生成的
    的头像 发表于 12-23 13:53 1000次阅读

    痞子衡嵌入式:MCUXpresso IDE关键函数重定向到RAM中执行的几种方法

      大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是MCUXpresso IDE关键函数重定向到RAM中执行的几种方法
    发表于 12-06 19:36 9次下载
    痞子衡嵌入式:<b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b><b class='flag-5'>下</b><b class='flag-5'>将</b>关键函数重定向到RAM中执行的<b class='flag-5'>几种方法</b>

    LPC1768 MCUXpresso IDE环境使用完整64K内存的方法

    MCUXpresso IDE是NXP公司免费提供的一款针对自家平台的IDE简单来说就是 Eclipses 外加GCC编译器和自家芯片平台的IDE在这种平台下,也是默认情况
    发表于 12-07 13:06 7次下载
    LPC1768 <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>环境<b class='flag-5'>下</b>使用完整64K内存的<b class='flag-5'>方法</b>

    不同IDE应用程序RW分散链接方法~

    今天痞子衡给大家介绍的是MCUXpresso IDE应用程序RW
    发表于 12-07 13:21 9次下载
    不同<b class='flag-5'>IDE</b><b class='flag-5'>下</b><b class='flag-5'>应用程序</b><b class='flag-5'>RW</b><b class='flag-5'>段</b><b class='flag-5'>分散</b><b class='flag-5'>链接</b>的<b class='flag-5'>方法</b>~

    MCUXpresso IDE下工程链接文件配置管理与自动生成机制介绍

    我们知道不同 IDE 链接文件语法是不一样的,而恩智浦 MCUXpresso IDE 底层编译器是 Arm GCC,因此其
    的头像 发表于 11-17 10:41 3101次阅读
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>下工程<b class='flag-5'>链接</b>文件配置管理与自动生成机制介绍

    MCUXpresso IDE下生成镜像文件的方法及其与IAR,MDK差异

    MCUXpresso IDE下生成镜像文件的方法及其与IAR,MDK差异
    的头像 发表于 09-28 17:05 824次阅读
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>下生成镜像文件的<b class='flag-5'>方法</b>及其与IAR,MDK差异

    MCUXpresso IDE源码制作成Lib库方法及其与IAR,MDK差异

    MCUXpresso IDE源码制作成Lib库方法及其与IAR,MDK差异
    的头像 发表于 11-07 17:13 1183次阅读
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b><b class='flag-5'>下</b><b class='flag-5'>将</b>源码制作成Lib库<b class='flag-5'>方法</b>及其与IAR,MDK差异

    如何在MCUXpresso IDE中测量能耗?

    如何在MCUXpresso IDE中测量能耗?
    的头像 发表于 09-19 16:40 557次阅读
    如何在<b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>中测量能耗?

    MCUXpresso IDE下在线联合调试双核MCU工程的三种方法

    大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是MCUXpresso IDE下在线联合调试i.MXRT1170双核工程的三种方法
    的头像 发表于 08-08 15:18 494次阅读
    <b class='flag-5'>MCUXpresso</b> <b class='flag-5'>IDE</b>下在线联合调试双核MCU工程的三<b class='flag-5'>种方法</b>