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

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

    关注

    450

    文章

    49351

    浏览量

    415703
  • OTA
    OTA
    +关注

    关注

    7

    文章

    551

    浏览量

    34909
  • Boot
    +关注

    关注

    0

    文章

    146

    浏览量

    35610
  • SBL
    SBL
    +关注

    关注

    0

    文章

    4

    浏览量

    8253

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

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

收藏 人收藏

    评论

    相关推荐

    恩智浦i.MXRT1170 uSDHC eMMC启动时间

    大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是恩智浦 i.MX RT1170 uSDHC eMMC启动时间。
    的头像 发表于08-08 15:32 215次阅读
    恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170 uSDHC eMMC启动时间

    使用i.MXRT500实现SPI/DMA AN14170应用指南

    德赢Vwin官网 网站提供《使用 i.MX RT500实现SPI/DMA AN14170应用指南.pdf》资料免费下载
    发表于02-01 10:05 0次下载
    使用<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>500实现SPI/DMA AN14170应用指南

    i.MXRTSDK的Wi-Fi TX功率表和信道扫描管理应用指南

    德赢Vwin官网 网站提供《 i.MX RTSDK的Wi-Fi TX功率表和信道扫描管理应用指南.pdf》资料免费下载
    发表于01-14 09:27 0次下载
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b> SDK的Wi-Fi TX功率表和信道扫描管理应用指南

    I.MXRT1052代码执行在哪里?

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

    基于NXPi.MXRT117H智能人机界面方案

    基于NXP i.MX RT117H智能人机界面方案
    的头像 发表于10-30 18:22 493次阅读
    基于NXP <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>117H智能人机界面方案

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

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

    理解i.MXRT中FlexSPI外设lookupTable里配置访问行列混合寻址Memory的参数值

    理解 i.MX RT中FlexSPI外设lookupTable里配置访问行列混合寻址Memory的参数值
    的头像 发表于10-30 17:23 386次阅读
    理解<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>中FlexSPI外设lookupTable里配置访问行列混合寻址Memory的参数值

    浅谈i.MXRT10xx系列MCU外接24MHz晶振的作用

    浅谈 i.MX RT10xx系列MCU外接24MHz晶振的作用
    的头像 发表于10-30 17:22 588次阅读
    浅谈<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>10xx系列MCU外接24MHz晶振的作用

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

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

    i.MXRT500/600系列上串行NOR Flash双程序可交替启动设计

    i.MX RT500/600系列上串行NOR Flash双程序可交替启动设计
    的头像 发表于10-27 09:36 367次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>500/600系列上串行NOR Flash双程序可交替启动设计

    基于NXP微控制器i.MXRT1170的多人体实时检测算法和系统

    基于NXP微控制器 i.MX RT1170的多人体实时检测算法和系统
    的头像 发表于10-26 16:27 859次阅读
    基于NXP微控制器<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170的多人体实时检测算法和系统

    i.MXRT的FlexRAM配置问题

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

    i.MXRT1010I2C Slave时钟延展功能小记

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

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

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

    基于NXPi.MXRT1021跨界MCU实现一个简单的波形采集

    基于NXP i.MX RT1021跨界MCU实现一个简单的波形采集,使用了 RT1021设计了一个简单的核心板,然后使用信号发生器产生波形
    发表于09-13 17:25 677次阅读
    基于NXP <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1021跨界MCU实现一个简单的波形采集