痞子衡嵌入式:MCUBootUtility v5.3发布,利用XMCD轻松使能外部RAM
--
痞子衡维护的 NXP-MCUBootUtility 工具距离上一个大版本(v5.0.0)发布过去4个多月了,期间痞子衡也做过三个小版本更新,但不足以单独介绍。这一次痞子衡为大家带来了全新重要版本v5.3.x,这次更新主要是想和大家特别聊聊 XMCD 这个特性的支持。
一、v5.1 - v5.3更新记录
-- v5.1.0
Features:
1. [RT1180] 支持自动加载Edgelock固件
-- v5.2.0
Features:
1. [RTyyyy] 支持i.MXRT118x B0
2. [RT] 对于FlexSPI NOR设备,支持下载安全与非安全两种地址链接的CM33程序
3. [RT] 对于FlexSPI NOR设备,支持别名地址链接的程序
Improvement:
1. [RT1180] 用户输入的源程序文件可以包含启动头 (Container)
-- v5.2.1
Bufixes:
1. [RTyyyy] 修复对FlexSPI NAND设备的下载支持
-- v5.3.0
Features:
1. [RTyyyy] 支持XMCD配置功能,可用于加载image进FlexSPI RAM/SEMC SDRAM执行
2. [RTyyyy] 支持第二个FlexSPI去下载启动NAND
3. [RT] 新增FlexSPI NAND启动设备模型支持
Improvement:
1. [RTyyyy] 将FlexSPI序号选择从菜单栏改至设备配置界面
2. [RTyyyy] 可以识别链接在FlexSPI RAM区域的程序
Bufixes:
1. [RTyyyy] 无法识别IVT中复位函数地址相对向量表首地址偏移小于0xB00的可启动程序文件
-- v5.3.1
Improvement:
1. [RT] 可以检查不同FlexSPI序号的有效XIP范围
2. [RTxxx] 可以识别链接在FlexSPI RAM区域的程序
Bufixes:
1. [RT1180] 在FlexSPI NOR启动设备下无法生成一些Non-XIP程序的可启动程序
二、几个不可忽视的更新
2.1 完善的FlexSPI NOR映射地址支持
在 v5.0 及其之前的版本里,工具对于 FlexSPI NOR 设备映射地址的支持比较单一。在工具目录 \src\targets\xxx\bltargetconfig.py 文件中仅可见如下定义(RT1180为例),即一个 FlexSPI 仅对应一个主映射地址:
flexspiNorMemBase0 = 0x38000000
flexspiNorMemBase1 = 0x14000000
但是我们知道部分 i.MXRT 型号系统设计里对于 FlexSPI 除了支持主映射地址外,还支持所谓的别名映射地址(Aliased Address),甚至 CM33 内核的 i.MXRT 型号里还区分 Secure 和 Non-Secure 地址。因此 v5.3 里进一步丰富了 FlexSPI NOR 设备的映射地址,这样我们在编译链接 XIP 启动程序的时候,地址选择更加灵活。此外这里如果你仔细看,会发现工具对于最大映射地址空间检查也按 RT 型号不同做了具体区分。
但是这里有关于 RT1180 的一点注意事项,工具目录 \src\targets\MIMXRT1189\ 下预先放了两个版本的 flashloader,一个仅支持 Secure 地址,另一个仅支持 Non-Secure 地址,这是当前 flashloader 实现的限制。为了能让工具自动根据用户输入源程序实际链接地址类型来选择合适的 flashloader 去做擦写操作,需要先点击一次 Generate xxType Bootable Image 按钮之后再点击 Connect to ROM 按钮,最后再 All-In-One Action。
cntr_flashloader_s.bin
cntr_flashloader_ns.bin
2.2 支持链接在FlexSPI RAM区域的程序
对于 Non-XIP 程序,除了链接在 RT 芯片内部 SRAM 空间之外,还可以链接在外部 RAM 空间,比如 SEMC 接口对应的 SDRAM 设备,或者 FlexSPI 接口对应的 HyperRAM 或者 PSRAM 设备。v5.0 及之前工具仅能支持链接在 SDRAM 的程序,对于链接在 FlexSPI 映射空间的 Non-XIP 程序,工具会直接报非法地址。v5.3 版本开始,这个限制将不复存在(见如下对 RT1180 FlexSPI RAM 地址的支持),这也是为了配合 DCD 以及 XMCD 功能而做的改进。
2.3 对于RT1170 XMCD功能支持
从 RT1160/1170 B0 以及其后的 RT1180 开始,BootROM 里新增了 XMCD 功能,这是对 DCD 功能的补充。我们知道 DCD 可以实现对芯片指定外设的用户定制化配置,常常用于配置 SEMC 寄存器去初始化 SDRAM 或者 FlexSPI 寄存器去初始化 HyperRAM/PSRAM,但是 DCD 的配置太细致,需要从外设寄存器角度去理解那些外部 RAM 存储器特性,这种方式从应用角度来说不够友好。XMCD 正是为了解决这个问题,其将对 SDRAM/HyperRAM 配置以一种对用户更友好更简洁的方式来呈现,见如下界面设置:
XMCD 虽好,但是其和 DCD 配合使用在当前工具里会有一些限制,这主要是因为工具依赖的 RT1170 底层工具链(elftosb)对于 dcd 数据的生成仅支持相对 IVT 起始地址 0x40 的偏移,但这个偏移恰恰又是 XMCD 的偏移位置,两者有冲突:
- 限制 1:如果是 All-In-One Action 操作,不可在界面里同时使能 DCD 和 XMCD。如果两者同时使能,XMCD 设置会被自动忽略。
- 限制 2:如果是 All-In-One Action 操作,用户源应用程序里如果包含 DCD 数据结构,那么工具界面里 XMCD 设置也会被自动忽略。
- 限制 3:如果是 All-In-One Action 操作,用户源应用程序里如果包含 XMCD 数据结构,且工具界面里 DCD 被使能,那么 XMCD 数据结构将会被丢弃。
当然如果你有一个同时包含 DCD 和 XMCD 数据的可启动文件,可以在工具通用编程器(Boot Device Memory)界面使用 Write 按钮去下载。
至此,这次更新的主要特性便介绍完了。MCUBootUtility项目地址如下。虽然当前版本(v5.3.x)功能已经非常完备,你还是可以在此基础上再添加自己想要的功能。如此神器,还不快快去下载试用?
欢迎订阅
文章会同时发布到我的 博客园主页、CSDN主页、知乎主页、微信公众号 平台上。
微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

痞子衡嵌入式:MCUBootUtility v5.3发布,利用XMCD轻松使能外部RAM的更多相关文章
- 痞子衡嵌入式:MCUXpresso IDE下将关键函数重定向到RAM中执行的几种方法
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是MCUXpresso IDE下将关键函数重定向到RAM中执行的几种方法. 前段时间痞子衡写了一篇 <在IAR开发环境下将关键函数重 ...
- 痞子衡嵌入式:MCUBootUtility v2.3发布,这次不再放过任何一款Flash
-- 痞子衡的 NXP-MCUBootUtility 开源项目自2018年8月27日第一笔提交至今已有21个月,目前累计代码已近50000行.相信这个工具为大家开发 i.MXRT 项目提供了一些便利, ...
- 痞子衡嵌入式:MCUBootUtility v2.4发布,轻松更换Flashloader文件
-- 痞子衡维护的NXP-MCUBootUtility工具距离上一个版本(v2.3.1)发布过去2个月了,这一次痞子衡为大家带来了版本升级v2.4.0,这个版本主要有一个非常重要的更新需要跟大家特别说 ...
- 痞子衡嵌入式:MCUBootUtility v3.0发布,开始支持LPC, Kinetis啦
-- 痞子衡维护的NXP-MCUBootUtility工具距离上一个版本(v2.4.0)发布过去2个半月了,这一次痞子衡为大家带来了全新版本v3.0.0,从这个版本开始,NXP-MCUBootUtil ...
- 痞子衡嵌入式:MCUBootUtility v3.3发布,可配合SBL项目使用
-- 痞子衡维护的NXP-MCUBootUtility工具距离上一个大版本(v3.0.0)发布过去4个多月了,期间痞子衡其实断断续续做个几个小版本更新,这一次痞子衡为大家带来了稳定版本v3.3.0,顺 ...
- 痞子衡嵌入式:MCUBootUtility v3.4发布,支持串行NAND
-- 痞子衡维护的 NXP-MCUBootUtility 工具距离上一个大版本(v3.3.0)发布过去 4 个多月了,这一次痞子衡为大家带来了版本升级 v3.4.0,这个版本主要有几个非常重要的更新需 ...
- 痞子衡嵌入式:MCUBootUtility v3.5发布,支持串行NOR的ECC及双程序启动
-- 痞子衡维护的 NXP-MCUBootUtility 工具距离上一个大版本(v3.4.0)发布过去半年了,这一次痞子衡为大家带来了版本升级 v3.5.0,这个版本主要有几个非常重要的更新需要跟大家 ...
- 痞子衡嵌入式:MCUBootUtility v4.0发布,开始支持MCX啦
-- 痞子衡维护的 NXP-MCUBootUtility 工具距离上一个大版本(v3.5.0)发布过去 9 个月了,这一次痞子衡为大家带来了版本升级 v4.0.0,这个版本主要有两个重要更新需要跟大家 ...
- 痞子衡嵌入式:MCUBootUtility v2.3.1发布,解决了长久以来非空flash可能无法下载的问题
-- 痞子衡维护的NXP-MCUBootUtility工具距离上一个版本(v2.3)发布过去3个月了,这一次痞子衡为大家带来了小版本升级v2.3.1(第一次做x.y.z中z级别更新),这个版本主要有两 ...
- 痞子衡嵌入式:利用i.MXRT1xxx系列ROM集成的DCD功能可轻松配置指定外设
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是利用i.MXRT1xxx系列ROM集成的DCD功能可轻松配置指定外设. 关于 i.MXRT1xxx 系列芯片 BootROM 中集成的 ...
随机推荐
- Docusaurus之markdown文档的vscode代码片段
需求 我是使用Docusaurus建立的个人站点,在写文档是总是要在开头配置作者.日期等等,用过Docusaurus的都应该知道. 因为每次新建一个md文档都需要重新配置,很麻烦,于是我就想能不能新建 ...
- Falcon 登陆 Hugging Face 生态
引言 Falcon 是由位于阿布扎比的 技术创新研究院 (Technology Innovation Institute,TII) 创建的一系列的新语言模型,其基于 Apache 2.0 许可发布. ...
- C++ 核心指南之资源管理(下)—— 智能指针最佳实践
C++ 核心指南(C++ Core Guidelines)是由 Bjarne Stroustrup.Herb Sutter 等顶尖 C+ 专家创建的一份 C++ 指南.规则及最佳实践.旨在帮助大家正确 ...
- 1.7 完善自定位ShellCode后门
在之前的文章中,我们实现了一个正向的匿名管道ShellCode后门,为了保证文章的简洁易懂并没有增加针对调用函数的动态定位功能,此类方法在更换系统后则由于地址变化导致我们的后门无法正常使用,接下来将实 ...
- 运行C时报错:relocation truncated to fit: R_X86_64_PC32 against undefined symbol `WinMain‘ collect2: error
写C时,遇到报错 [Running] cd "d:\考研\408\LeranC\Code\GramForC\" && gcc 01data_types.c -o 0 ...
- Mediabox:年度最佳音视频开发工具
"2023稀土开发者大会"落下帷幕,由稀土掘金社区评选的的掘金技术引力榜重磅出炉,共有22个优秀实践案例上榜,涵盖对技术行业发展有特别贡献的人物.开发工具.开源项目.技术团队和技术 ...
- 【go语言】2.4.2 自定义包的创建和使用
在 Go 中,任何一个目录都可以被视为一个包.创建自定义包的基本步骤是: 新建一个目录,用于存放包的源文件. 在新建的目录中编写 Go 代码,代码的第一行应该是 package 包名. 使用 impo ...
- pandas 缺失值与空值处理
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/lwgkzl/article/detail ...
- Windows 环境下载、安装、使用(.Net 5.0) Redis 数据库及常见问题的解决
〇.前言 Redis (Remote Dictionary Server 远程字典服务)是一个使用 ANSI C 编写的开源.包含多种数据结构,支持网络.基于内存.可选持久性的键值对存储数据库,是现在 ...
- java file I/O流
一.File的简介:(java.io包) 生活中的文件: (1)文件的作用:持久化(瞬时状态的对立面状态) (1)文件的定义:一堆数据的集合 (2)文件存储的位置:磁盘,硬盘,软盘,U盘等等 计算机中 ...