痞子衡嵌入式:MCUBootUtility v3.5发布,支持串行NOR的ECC及双程序启动
--
痞子衡维护的 NXP-MCUBootUtility 工具距离上一个大版本(v3.4.0)发布过去半年了,这一次痞子衡为大家带来了版本升级 v3.5.0,这个版本主要有几个非常重要的更新需要跟大家特别说明一下。
一、v3.5更新记录
二、几个不可忽视的更新
2.1 支持串行NOR双程序启动下载
部分 i.MXRT 型号 BootROM 支持串行 NOR Flash 的双程序启动,这意味着在这些型号上用户可以不用额外设计二级 bootloader 也可以完成本地 OTA 升级。
之前痞子衡把所有支持双程序启动的 i.MXRT 型号都试了一遍,一共写了三篇文章,在文中痞子衡是借助 MCUBootUtility v3.4 里的通用编程器来手动做两个 image 的下载的,并且 image 版本头添加,以及 Fuse 烧写也都是手工完成的,步骤稍显复杂。
《i.MXRT1060,1010上串行NOR Flash冗余程序启动设计》
《i.MXRT1170上串行NOR Flash双程序可交替启动设计》
《i.MXRT500,600系列上串行NOR Flash双程序可交替启动设计》
在 MCUBootUtility v3.5 上再去做同样的事情就简单多了,只需要在 FlexSPI NOR Device Configuration 界面里设置双程序启动相关参数即可,工具会自动完成后续所有事情(烧写相应 Fuse、添加 image 版本头,烧写两份 image 进 Flash)。
- Note1: Image 1 offset 保持默认 0,即不使能双程序下载;如果设为非 0,这个值也会被烧写进 Fuse。
- Note2: Image 0/1 version 如果保持 none 值,在双程序下载使能的情况下实际等同于 0xFFFF 值。
2.2 支持串行NOR的ECC方式下载
在部分增强型 i.MXRT 型号上(比如 i.MXRT1170),芯片内部增加了很多 ECC 方面设计,从 RAM 到 Flash 再到 Fuse,全部都有 ECC 保护,这样芯片可放心用于那些对稳定性要求高的产品场合(比如汽车)。
在 i.MXRT1170 上是 XECC 模块负责了 FlexSPI 外设连接的 Flash 上 ECC 处理,痞子衡之前为此写过一篇文章 《i.MXRT1170 XECC功能特点及其保护串行NOR Flash和SDRAM之道》。但是官方 SDK 里提供的 Flashloader (路径在 \SDK_2.11.0_MIMXRT1170-EVK\boards\evkmimxrt1170\bootloader_examples\flashloader)并不支持 ECC 方式的写入,而 MCUBootUtility 正是借助这个官方 Flashloader 完成 Flash 的擦写的,所以我们需要改这个官方 Flashloader,为此痞子衡创建了一个项目:
- 包含ECC功能的Flashloader项目:https://github.com/JayHeng/imxrt-ecc-flashloader
在 imxrt-ecc-flashloader 工程里,痞子衡引入了 XECC 模块驱动,并且将 ECC 功能集成到了 set-property 13 和 write-memory 这两个命令里。这里有两个注意点,一是:使能 ECC 写入后,写入首地址需要以 4KB 对齐(在 XECC 模块的限制下做的设定),二是:使能 ECC 写入后,擦除长度需要是 image 长度的两倍(XECC 原理决定的)。
// 初始化 Flash
blhost -u -- fill-memory 0x20200000 0x4 0xC0000005
blhost -u -- fill-memory 0x20200004 0x4 0x0
blhost -u -- configure-memory 0x9 0x20200000
// 关闭 ECC 写入功能,复位 XECC 模块(默认配置)
blhost -u -- set-property 13 0
// 擦除 Flash 前 16KB 空间
blhost -u -- flash-erase-region 0x30000000 0x4000
// 正常写入 Flash
blhost -u -- write-memory 0x30000000 bt_image_16KB.bin 0x9
// 使能 ECC 写入功能
blhost -u -- set-property 13 1
// 擦除 Flash 前 32KB 空间
blhost -u -- flash-erase-region 0x30000000 0x8000
// 先初始化 XECC 模块,然后以 ECC 方式写入 Flash(写入地址需要以 4KB 对齐)
blhost -u -- write-memory 0x30000000 bt_image_16KB.bin 0x9
// 每一次写完 Flash 需要关闭 ECC 写入功能
blhost -u -- set-property 13 0
痞子衡将 imxrt-ecc-flashloader 工程生成的可执行文件(CM4版本)放到了 \NXP-MCUBootUtility\src\targets\MIMXRT1176\flashloader_user.srec,让工具用这个含 ECC 功能的 Flashloader,并且在工具通用编程器界面增加了 ECC Write 按钮,这个按钮可以一键完成 .bin 格式文件的 ECC 方式下载。
- Note: v3.5版本工具里没有自动集成 ECC 使能的 Fuse 位烧写,因为 Fuse 烧写完,芯片需要复位一次,XECC 才生效,所以用户需要自己手动烧写 Fuse。
至此,这次更新的主要特性便介绍完了。MCUBootUtility项目地址如下。虽然当前版本(v3.5.0)功能已经非常完备,你还是可以在此基础上再添加自己想要的功能。如此神器,还不快快去下载试用?
欢迎订阅
文章会同时发布到我的 博客园主页、CSDN主页、知乎主页、微信公众号 平台上。
微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

痞子衡嵌入式:MCUBootUtility v3.5发布,支持串行NOR的ECC及双程序启动的更多相关文章
- 痞子衡嵌入式:揭秘i.MXRT1170上串行NOR Flash双程序可交替启动设计
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT1170上串行NOR Flash双程序可交替启动设计. 在上一篇文章 <i.MXRT1060/1010上串行NOR F ...
- 痞子衡嵌入式:系统时钟配置不当会导致i.MXRT1xxx系列下OTFAD加密启动失败
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是系统时钟配置不当会导致i.MXRT1xxx系列下OTFAD加密启动失败问题. 我们知道,i.MXRT1xxx家族早期型号(RT1050/ ...
- 痞子衡嵌入式:FlexSPI复位方式不当会导致i.MXRT系列下OTFAD加密启动失败
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是FlexSPI复位方式不当会导致i.MXRT系列下OTFAD加密启动失败问题. 本篇是<系统时钟配置不当会导致i.MXRT1xxx ...
- 痞子衡嵌入式:导致串行NOR Flash在i.MXRT下无法正常下载/启动的常见因素之SFDP
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是导致串行NOR Flash在i.MXRT下无法正常下载/启动的常见因素之SFDP. i.MXRT系列MCU发布已两年多了,基于i.MXR ...
- 痞子衡嵌入式:借助Serial Plot软件测量i.MXRT系列FlexSPI驱动Flash页编程执行时间
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT系列FlexSPI驱动Flash页编程执行时间. 痞子衡之前写过一篇文章 <串行NOR Flash的页编程模式对于量产 ...
- 痞子衡嵌入式:i.MXRT中FlexSPI外设不常用的读选通采样时钟源 - loopbackFromSckPad
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是i.MXRT中FlexSPI外设不常用的读选通采样时钟源 - loopbackFromSckPad. 最近碰到一个客户,他们在 i.MX ...
- 痞子衡嵌入式:MCUBootUtility v3.0发布,开始支持LPC, Kinetis啦
-- 痞子衡维护的NXP-MCUBootUtility工具距离上一个版本(v2.4.0)发布过去2个半月了,这一次痞子衡为大家带来了全新版本v3.0.0,从这个版本开始,NXP-MCUBootUtil ...
- 痞子衡嵌入式:MCUBootUtility v3.4发布,支持串行NAND
-- 痞子衡维护的 NXP-MCUBootUtility 工具距离上一个大版本(v3.3.0)发布过去 4 个多月了,这一次痞子衡为大家带来了版本升级 v3.4.0,这个版本主要有几个非常重要的更新需 ...
- 痞子衡嵌入式:MCUBootUtility v3.3发布,可配合SBL项目使用
-- 痞子衡维护的NXP-MCUBootUtility工具距离上一个大版本(v3.0.0)发布过去4个多月了,期间痞子衡其实断断续续做个几个小版本更新,这一次痞子衡为大家带来了稳定版本v3.3.0,顺 ...
随机推荐
- 一招教你IDEA中Java程序如何打包,以及打包后如何运行
前言 编写程序 程序打包 测试运行 IDEA作为目前按最主流的Java程序项目编写工具,越来越受到开发人员的青睐.idea因为其五花八门的功能,让你在开发过程中效率显著提高.那么对于初学者来说,如何通 ...
- P1015 [NOIP1999 普及组] 回文数
点击查看题目 题目描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个十进制数 5656,将 5656 加 6565(即把 5656 从右向左读),得到 ...
- Bootstrap提供的CDN服务标签与下载文档
目录 1.引入Bootstrap提供的CDN服务 1.选择下载Bootstrap CDN 二:下载Bootstrap官方文档 1.进入Bootstrap官网,选择3版本中文档. 1.引入Bootstr ...
- Java中类变量(静态变量)和类方法(静态方法)
类变量 类变量也叫静态变量或静态属性,是该类所有对象共享的变量任何一个该类的对象去访问它时,取得都是一样的值 语法: 访问修饰符 static 数据类型 变量名 static 访问修饰符 数 ...
- 带分数--第四届蓝桥杯省赛C++B/C组
第四届蓝桥杯省赛C++B/C组----带分数 思路: 1.先枚举全排列 2.枚举位数 3.判断是否满足要求 这道题也就是n=a+b/c,求出符合要求的abc的方案数.进行优化时,可以对等式进行改写,改 ...
- Django整体模型理解(1)
Django大概理解 *models: 设计一个模型,即在数据库中设计一个表,一个模型就是对应一个数据库中的表:models是一个类,类名就是表名,而类的属性就是表的字段.如下例子设计了两个表: f ...
- 私有化轻量级持续集成部署方案--07-私有NPM仓库-Verdaccio
提示:本系列笔记全部存在于 Github, 可以直接在 Github 查看全部笔记 对于个人来说,私有NPM仓库 作用性基本很小,但是对于企业,私有NPM仓库 可以保护代码暴露,具有很大的意义. 也是 ...
- 清理 Docker 占用的磁盘空间
Docker 很占用空间,每当我们运行容器.拉取镜像.部署应用.构建自己的镜像时,我们的磁盘空间会被大量占用. 如果你也被这个问题所困扰,咱们就一起看一下 Docker 是如何使用磁盘空间的,以及如何 ...
- 如何把Spring学精通了?
作为 Java 后端工程师,几乎都要用到 Spring,今天这篇文章是和大家说说如何学好 Spring. 在之前的一篇 Java 读书路线的文章中,我介绍过 Spring 的读书路线: 虽然 Spri ...
- 华为模拟器在三层交换机上实现dhcp的配置
<Huawei>sysEnter system view, return user view with Ctrl+Z.[Huawei]sys sw1[sw1]dhcp enable Inf ...