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

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

3天内不再提示

深入探讨i.MX RT1010 OTA存储结构

恩智浦MCU加油站 来源:恩智浦MCU加油站 作者:恩智浦MCU加油站 2021-10-29 16:14 次阅读

最近恩智浦在Github发布了一套基于MCU的OTA工程,该工程支持i.MX RT系列,且支持security的相关功能,得到了用户的广泛关注。

这套工程是基于恩智浦的EVK开发板,板载Flash的容量也就决定了整个OTA工程的存储结构。但是不同容量的flash,OTA的存储结构也不尽相同。本文将最近支持客户时的一些经验予以总结,当大家更换flash的时候,可以更快的完成OTA工程配置。本文介绍的方案为基于Remap功能实现OTA的方法。整个OTA的存储结构可以用下图进行表示,即 SBL(Secure Bootloader), OTA Flag Data,Slot1,Slot2和Customer Data区域。

SBL的主要功能是用于在芯片POR启动后,根据OTA flag data的信息,决定存储在Slot1或者Slot2的程序进行运行。除此之外,还支持程序的验签,回滚等功能。

OTA Flag Data区域主要是用于存储OTA升级过程中的一些标志位信息,根据相关的标志位信息SBL进行image升级,回滚和跳转到对应的slot运行程序。

Slot1和Slot2用于存储应用程序。

Customer Data用于存储客户的一些信息(可选项,非必须)。

本文将就上述几个区域的存储空间分配,及中间的一些需要注意的点予以介绍。

基本的硬件环境是i.MX RT1010-EVK开发板,客户的实际需求是使用一颗容量为512KB的Flash,且不需要使用Security相关的功能。因此在禁用Security功能后,使用IAR编译出一个大小为25KB的SBL.bin文件。由于OTA中使用的Remap功能需要4KB对齐,以及Flash的最小擦除容量是4KB,因此SBL分配的容量是28KB,则此时SBL的地址分配空间为:FunctionAdd_StartAdd_End

SBL0x6000 00000x6000 6FFF

OTA Flag data尽管只有32Bytes的数据,但是在升级过程中这些数据需要读写擦,但Flash的擦除过程需要按照Sector的大小进行,因此也至少需要留存4KB的空间,则此时OTA Flag data的地址及空间分配为:

fd68864e-388a-11ec-82a8-dac502259ad0.png

接下来就是Slot1和Slot2,Slot1和Slot2要使用Remap的功能进行切换,Remap的地址需要4K对齐,则此时用于存储应用层程序的地址空间分配为:

FunctionAdd_StartAdd_End

Slot10x6000 80000x6004 3FFF

Slot20x6004 40000x6007 FFFF

此时,细心的朋友们就会发现,完整的512K Flash空间已经被使用光了。没错,这次客户不需要用这个CustomerData区域,希望把更多的空间用于应用程序。

在完成了OTA存储结构按功能地址分配之后,我们进行一些细部探究。

首先看SBL,SBL区间主要包括用于Flash boot的相关信息,例如IVT, Flash Config Block等。这部分代码基本上不需要改动,可以直接使用。

在地址空间分配上,可以将SBL区域视为一个可以从Flash XIP boot的hello word工程。

fdc48da4-388a-11ec-82a8-dac502259ad0.png

接着看一下OTAFlag Data区间的地址分配,OTA Flag Data共计32个字节,用于指示OTA过程中的三种状态,升级,回滚以及正常工作(没有升级和回滚发生)。

该32字节通常存储在Slot1的首地址之前的32字节位置。

ff92553a-388a-11ec-82a8-dac502259ad0.png

最后来看Slot1和Slot2的地址空间分配。

应用程序的首地址,即中断向量表的首地址并不是从Slot1的首地址开始的,原因有两点

第一在image的起始地址需要增加用于OTA的ImageHeader信息,该Image Header的大小为32字节。

其次,对于应用程序中中断向量表的起始地址,需要进行计算。其基本的计算原则是:中断向量的数量 * 4的结果,向上对齐到2的次幂整数倍。看RT1010的中断向量共计256个,但是真正可以使用的是96个。则此时的计算结果是:96 * 4 = 384。向上对齐到2次幂整数倍,则为512即0x200。

所以,应用程序的真正起始地址需要在Slot1的基础上,向后调整0x200。

Slot2的空间分配也需要满足这个条件。

fff0a036-388a-11ec-82a8-dac502259ad0.png

最终完整的地址空间分配如下图所示:

006545f8-388b-11ec-82a8-dac502259ad0.png

当需要对OTAFlag Data以及Slot地址进行分配,可以在程序中搜索下图中的关键词进行更改,对下面的表格进行调整。

通常需要进行关注的关键地址为:BOOT_FLASH_ACT_APP和 BOOT_FLASH_CAND_APP。其余的地址信息,与这两个地址信息存在依赖关系,程序内部可根据这两个地址信息进行计算。

需要注意的是,本文中涉及到的OTA方法,是基于Remap功能实现的,因此仅仅适用于除RT1050,RT1020, RT1024, RT1015以外的RT系列。

最后,向在本次客户支持中提供大量协助的Tim, Gavin, Xiaoli表示感谢。

差点忘了,原工程的下载地址是:

https://github.com/NXPmicro/sbl

https://github.com/NXPmicro/sfw

编辑:jq

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

    关注

    447

    文章

    47788

    浏览量

    409128
  • OTA
    OTA
    +关注

    关注

    7

    文章

    522

    浏览量

    34592
  • Boot
    +关注

    关注

    0

    文章

    142

    浏览量

    35244
  • SBL
    SBL
    +关注

    关注

    0

    文章

    4

    浏览量

    8222

原文标题:i.MX RT1010 OTA存储结构小记

文章出处:【微信号:NXP_SMART_HARDWARE,微信公众号:恩智浦MCU加油站】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    I.MX RT1052代码执行在哪里?

    试用的开发板里有了I.MX RT1052 但是看I.MX RT1052有代码与数据的SPI Flash,还有SRAM,还有片上的TCM 代码可以执行在TCM上么?还是在SRAM上运行。
    发表于 11-09 06:49

    i.MX RT中FlexSPI外设不常用的读选通采样时钟源

    i.MX RT中FlexSPI外设不常用的读选通采样时钟源
    的头像 发表于 10-30 17:44 263次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>中FlexSPI外设不常用的读选通采样时钟源

    i.MX RT1050上如何实现双大容量存储(MSC)设备

    i.MX RT1050上如何实现双大容量存储(MSC)设备
    的头像 发表于 10-30 17:08 334次阅读
    在<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1050上如何实现双大容量<b class='flag-5'>存储</b>(MSC)设备

    i.MX RT的FlexRAM配置问题

    i.MX RT的FlexRAM配置问题
    的头像 发表于 10-24 15:46 286次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>的FlexRAM配置问题

    i.MX RT1010的I2C Slave时钟延展功能小记

    i.MX RT1010的I2C Slave时钟延展功能小记
    的头像 发表于 09-27 16:22 987次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT1010</b>的I2C Slave时钟延展功能小记

    恩智浦i.MX RT1060/1010上串行NOR Flash冗余程序启动设计

    恩智浦i.MX RT1060/1010上串行NOR Flash冗余程序启动设计
    的头像 发表于 09-26 16:53 408次阅读
    恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1060/<b class='flag-5'>1010</b>上串行NOR Flash冗余程序启动设计

    i.MX RT的FreeRTOS MCUXpresso工程中添加runtime

    在调试 i.MX RT FreeRTOS MCUXpresso SDK工程的时候, 很多网友需要添加查看每个task的runtime功能。
    的头像 发表于 06-09 09:30 974次阅读
    在<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>的FreeRTOS MCUXpresso工程中添加runtime

    如何知道i.MX 8 QM与Super Amoled Display兼容?

    我如何知道 i.MX 8 QM 与 Super Amoled Display 兼容?我想设计一个使用 i.MX 8 QM 的板子,它可以连接 supper amoled 显示器
    发表于 05-22 07:59

    i.MX RT10xx使用FlexIO实现XY2-100振镜控制协议

    本文介绍了如何使用i.MX RT系列芯片上的FlexIO实现XY2-100激光振镜控制协议。FlexIO模块是NXP Kinetis和i.MX RT系列MCU的片上外设。
    的头像 发表于 05-18 09:21 4009次阅读
    在<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>10xx使用FlexIO实现XY2-100振镜控制协议

    i.MX RT系列(例如 RT1050/1060)有多少个PWM通道?

    i.MX RT 系列(例如 RT1050/1060)有多少个 PWM 通道? 我可以像在 KV58 MCU(两个 flexPWM 模块)上做同样的事情吗?
    发表于 05-18 07:07

    i.MX RT1170自定义引导加载程序,如何在i.MX RT处理器上完成?

    我将在我的自定义 i.MX RT1170 板上开发自定义引导加载程序。在我的例子中,闪存驱动程序将通过 USB 读取以更新主要应用程序。 我正在研究
    发表于 05-17 08:13

    i.MX RT1170评估套件快速入门:这份保姆级教程,请收藏!

    恩智浦官网精彩导览 i.MX RT1170评估套件快速入门 i.MX RT1170 是恩智浦推出的首款主频超过1GHz的跨界MCU,结合了强悍的计算能力、多种媒体功能、实时功能,以及一
    的头像 发表于 05-12 11:55 1614次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170评估套件快速入门:这份保姆级教程,请收藏!

    i.MX RT1xxx从SD/eMMC启动

    最近在恩智浦官方社区上支持了一个关于i.MX RT从SD卡启动的案例,这让我想起了一年前写过的一篇《i.MX RT600从SD/eMMC启动》,那一篇重点介绍了基于eMMC设备制作程序
    的头像 发表于 05-11 14:34 751次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1xxx从SD/eMMC启动

    i.MX RT系列上是否有8个PWM通道可用?

    我使用 MKV58 通过 8 个 PWM 通道驱动 3 个 BLDC 和 1 个直流电机。 现在,我正在检查 i.MX RT 系列,只发现有 4 个 PWM 通道可供使用。 谁能告诉我 i.MX
    发表于 05-06 06:33

    如何将i.MX RT1024与外部64MB SDRAM一起使用?

    我想将 i.MX RT1024 与外部 64MB SDRAM 一起使用。根据数据表,它支持 8/16 位 SDRAM 外部存储器接口。从性能的角度来看,哪种模式更好?如何?如果有任何链接/参考可以通过此详细信息,请告诉我。谢谢
    发表于 05-05 11:17