精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 芯片
    +關注

    關注

    450

    文章

    49647

    瀏覽量

    417253
  • OTA
    OTA
    +關注

    關注

    7

    文章

    553

    瀏覽量

    34987
  • Boot
    +關注

    關注

    0

    文章

    148

    瀏覽量

    35676
  • SBL
    SBL
    +關注

    關注

    0

    文章

    4

    瀏覽量

    8259

原文標題:i.MX RT1010 OTA存儲結構小記

文章出處:【微信號:NXP_SMART_HARDWARE,微信公眾號:恩智浦MCU加油站】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    恩智浦i.MX RT1170 uSDHC eMMC啟動時間

    大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家介紹的是恩智浦i.MX RT1170 uSDHC eMMC啟動時間。
    的頭像 發表于 08-08 15:32 ?323次閱讀
    恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170 uSDHC eMMC啟動時間

    使用i.MX RT500實現SPI/DMA AN14170應用指南

    電子發燒友網站提供《使用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.MX RT SDK的Wi-Fi TX功率表和信道掃描管理應用指南

    電子發燒友網站提供《i.MX RT SDK的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.MX RT1052代碼執行在哪里?

    試用的開發板里有了I.MX RT1052 但是看I.MX RT1052有代碼與數據的SPI Flash,還有SRAM,還有片上的TCM 代碼可以執行在TCM上么?還是在SRAM上運行。
    發表于 11-09 06:49

    基于i.MX RT1170的兩輪車數字儀表盤參考設計 全面的技術解讀

    采用i.MX RT1170跨界MCU構建的兩輪車儀表盤;全包式參考平臺:實現更快、更輕松的開發。恩智浦的互聯數字儀表盤參考平臺使車輛制造商能夠為兩輪車提供基本的儀表盤功能,同時還支持各種連接用例,提升騎行者體驗。
    的頭像 發表于 11-03 08:15 ?1627次閱讀
    基于<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170的兩輪車數字儀表盤參考設計 全面的技術解讀

    基于NXP i.MX RT117H智能人機界面方案

    基于NXP i.MX RT117H智能人機界面方案
    的頭像 發表于 10-30 18:22 ?537次閱讀
    基于NXP <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>117H智能人機界面方案

    i.MX RT中FlexSPI外設不常用的讀選通采樣時鐘源

    i.MX RT中FlexSPI外設不常用的讀選通采樣時鐘源
    的頭像 發表于 10-30 17:44 ?445次閱讀
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>中FlexSPI外設不常用的讀選通采樣時鐘源

    理解i.MX RT中FlexSPI外設lookupTable里配置訪問行列混合尋址Memory的參數值

    理解i.MX RT中FlexSPI外設lookupTable里配置訪問行列混合尋址Memory的參數值
    的頭像 發表于 10-30 17:23 ?411次閱讀
    理解<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>中FlexSPI外設lookupTable里配置訪問行列混合尋址Memory的參數值

    淺談i.MX RT10xx系列MCU外接24MHz晶振的作用

    淺談i.MX RT10xx系列MCU外接24MHz晶振的作用
    的頭像 發表于 10-30 17:22 ?624次閱讀
    淺談<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>10xx系列MCU外接24MHz晶振的作用

    i.MX RT1050上如何實現雙大容量存儲(MSC)設備

    i.MX RT1050上如何實現雙大容量存儲(MSC)設備
    的頭像 發表于 10-30 17:08 ?513次閱讀
    在<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1050上如何實現雙大容量<b class='flag-5'>存儲</b>(MSC)設備

    i.MX RT500/600系列上串行NOR Flash雙程序可交替啟動設計

    i.MX RT500/600系列上串行NOR Flash雙程序可交替啟動設計
    的頭像 發表于 10-27 09:36 ?393次閱讀
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>500/600系列上串行NOR Flash雙程序可交替啟動設計

    基于NXP微控制器i.MX RT1170的多人體實時檢測算法和系統

    基于NXP微控制器i.MX RT1170的多人體實時檢測算法和系統
    的頭像 發表于 10-26 16:27 ?912次閱讀
    基于NXP微控制器<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1170的多人體實時檢測算法和系統

    i.MX RT的FlexRAM配置問題

    i.MX RT的FlexRAM配置問題
    的頭像 發表于 10-24 15:46 ?607次閱讀
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>的FlexRAM配置問題

    i.MX RT1010I2C Slave時鐘延展功能小記

    i.MX RT1010I2C Slave時鐘延展功能小記
    的頭像 發表于 09-27 16:22 ?1298次閱讀
    <b class='flag-5'>i.MX</b> <b class='flag-5'>RT1010</b>的<b class='flag-5'>I</b>2C Slave時鐘延展功能小記

    恩智浦i.MX RT1060/1010上串行NOR Flash冗余程序啟動設計

    恩智浦i.MX RT1060/1010上串行NOR Flash冗余程序啟動設計
    的頭像 發表于 09-26 16:53 ?619次閱讀
    恩智浦<b class='flag-5'>i.MX</b> <b class='flag-5'>RT</b>1060/<b class='flag-5'>1010</b>上串行NOR Flash冗余程序啟動設計