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

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

    关注

    463

    文章

    54389

    浏览量

    469052
  • OTA
    OTA
    +关注

    关注

    7

    文章

    630

    浏览量

    38436
  • Boot
    +关注

    关注

    0

    文章

    154

    浏览量

    37910
  • SBL
    SBL
    +关注

    关注

    0

    文章

    4

    浏览量

    8640

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    深入解析i.MX 6Solo/6DualLite应用处理器:特性、参数与设计要点

    i.MX 6Solo/6DualLite应用处理器以其卓越的性能和丰富的功能,成为了众多消费产品的理想选择。本文将深入探讨i.MX 6Solo/6DualLite处理器的特性、参数以及设计过程中的关键
    的头像 发表于 04-10 09:20 458次阅读

    i.MX 使用 SAI2 作为 TDM 从机的 RT 1060,无法正确接收接收数据怎么解决?

    我计划将 i.MX RT1060 SAI2 用作从机。 我尝试配置 SAI2 和 eDMA,如随附的 C 源文件所示 (saidmainit())。 SAI2 配置为 TDM 从机,因此 MCLK
    发表于 03-19 06:15

    探索NXP EdgeReady智能HMI解决方案:i.MX RT117H的无限可能

    的EdgeReady智能HMI解决方案,为智能家电、智能家居、智能建筑和工业物联网等领域带来了全新的发展机遇。今天,我们就来深入了解一下基于i.MX RT117H的NXP EdgeReady智能HMI解决方案
    的头像 发表于 12-25 09:15 593次阅读

    探索i.MX 91应用处理器家族:为边缘应用带来新可能

    开发者提供了一个强大而灵活的平台。今天,我们就来深入了解一下i.MX 91应用处理器家族的特点和优势。 文件下载: NXP Semiconductors i.MX 91应用处理器.pdf 一、概述:安全与节能的完美结合
    的头像 发表于 12-24 11:50 1249次阅读

    探索i.MX RT1180:高性能处理器的技术剖析与应用指南

    探索i.MX RT1180:高性能处理器的技术剖析与应用指南 在当今科技飞速发展的时代,高性能处理器在工业自动化、物联网等众多领域发挥着至关重要的作用。NXP Semiconductors的i.MX
    的头像 发表于 12-24 10:20 1118次阅读

    FRDM i.MX 9平台选型指南:FRDM i.MX 9系列开发平台解析

    恩智浦的FRDM平台解决方案旨在提供易于获取的开发工具,有效弥合原型制作与量产之间的鸿沟。FRDM板经济高效、易于使用,具备专业级功能,助力从概念到产品上市的全过程加速推进。在FRDM i.MX
    的头像 发表于 12-11 15:15 5w次阅读
    FRDM <b class='flag-5'>i.MX</b> 9平台选型指南:FRDM <b class='flag-5'>i.MX</b> 9系列开发平台解析

    i.MX RT1180实现EtherCAT+伺服控制的终极实践

    今天继续为大家介绍i.MX RT1180实现EtherCAT+伺服控制的终极实践:双电机控制与Ethercat资源使用。
    的头像 发表于 11-26 08:19 4451次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1180实现EtherCAT+伺服控制的终极实践

    恩智浦i.MX RT1180跨界MCU助力下一代伺服控制系统

    今天我们将聚焦一项正在重塑工业自动化边界的技术组合 —— 基于NXP的i.MX RT1180微控制器,实现EtherCAT通信与高性能伺服控制的融合方案。
    的头像 发表于 09-28 14:16 5133次阅读
    恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1180跨界MCU助力下一代伺服控制系统

    恩智浦i.MX RT1180跨界处理器如何选型

    i.MX RT1180 跨界处理器包含众多的型号,以满足客户对不同性能与价格的需求,今天就先给大家说说如何选型。
    的头像 发表于 09-28 14:01 2802次阅读
    恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1180跨界处理器如何选型

    基于恩智浦i.MX RT1180芯片的EtherCAT+伺服电机控制方案

    i.MX RT1180是恩智浦最近推出的一款高性能跨界处理器,其中包含了300MHz的Arm Cortex-M33核以及800MHz的Arm Cortex-M7核,集成了多种网络功能如时间敏感网络
    的头像 发表于 09-22 16:27 8822次阅读
    基于恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1180芯片的EtherCAT+伺服电机控制方案

    恩智浦MCU方案 单颗i.MX RT1180实现EtherCAT+伺服控制

    介绍基于单颗i.MX RT1180芯片的EtherCAT+伺服电机控制方案-伺服控制板硬件电路资源介绍,即为下图中的Servo Motor Driver Board。
    的头像 发表于 09-11 14:27 15.5w次阅读
    恩智浦MCU方案 单颗<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1180实现EtherCAT+伺服控制

    恩智浦i.MX 95系列MPU如何赋能边缘计算

    在本系列博文的第一部分,我探讨了恩智浦i.MX 95系列如何将新功能安全技术应用于工业环境、汽车领域及其他边缘应用。在接下来的文章中,我将进一步阐述i.MX 95系列如何赋能边缘计算,实现先进的AI功能。
    的头像 发表于 07-30 11:08 3025次阅读
    恩智浦<b class='flag-5'>i.MX</b> 95系列MPU如何赋能边缘计算

    基于恩智浦i.MX RT芯片内部RAM运行LVGL工程

    随着越来越多用户选择i.MX RT系列芯片制作产品,产品的需求以及芯片的用法也越来越多。本文将介绍在i.MX RT平台中,如何创建LVGL项目并将其运行在内部SRAM而非SDRAM上。
    的头像 发表于 07-01 09:33 2709次阅读
    基于恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>芯片内部RAM运行LVGL工程

    如何实现安卓与恩智浦i.MX RT1170的无线投屏与控制

    Scrcpy是一款免费开源的软件,支持将安卓端屏幕投影到其他设备,并支持被投屏设备对安卓的反向控制。基于ADB工具,安卓端无需安装任何软件,延迟低,稳定性好。现在,安卓也可投屏到恩智浦i.MX RT1170上。
    的头像 发表于 06-26 09:53 2540次阅读
    如何实现安卓与恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170的无线投屏与控制

    i.MX RT系列中FlexSPI DQS信号引脚配置GPIO方法

    i.MX RT060项目(采用QSPI Flash)的实际应用中,有客户反馈,其在设计阶段并未预留DQS信号引脚,而是将该引脚作为GPIO用于控制关键外设的开关,这导致程序无法正常运行。在此背景下
    的头像 发表于 06-16 11:30 1607次阅读
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>系列中FlexSPI DQS信号引脚配置GPIO方法