0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

支持 OTA 更新的MCU很多 為何 ESP32這么受歡迎?

得捷電子DigiKey ? 來源:未知 ? 2023-11-01 20:30 ? 次閱讀

物聯(lián)網(wǎng) (IoT) 產(chǎn)品的設(shè)計(jì)者需要不斷地評(píng)估平臺(tái)和組件的選擇,以降低成本和功率,同時(shí)提高性能和加快連接應(yīng)用的設(shè)計(jì)。目前有相當(dāng)多的解決方案可供選擇,但設(shè)計(jì)者面臨的挑戰(zhàn)是,一旦部署,如何進(jìn)行無線空中下載 (OTA) 更新以保持設(shè)備固件的更新。

關(guān)鍵是要看一下現(xiàn)有的平臺(tái),看看它們有哪些額外的工具和支持來支持 OTA 更新。這樣的支持可以大大簡化過程,但前期可能需要一些關(guān)注。

本文討論了 OTA 基本原理,以及為什么它是幾乎每個(gè)物聯(lián)網(wǎng)系統(tǒng)都需要支持的關(guān)鍵功能,盡管開發(fā)者面臨著諸多挑戰(zhàn)。然后以EspressifSystemsESP32支持藍(lán)牙Wi-Fi微控制器以及相關(guān)模塊、套件和 ESP 物聯(lián)網(wǎng)開發(fā)框架 (ESP-IDF) 為例,展示如何打造一個(gè) OTA 分區(qū),并利用 otatool.py 腳本在應(yīng)用仍在運(yùn)行時(shí)執(zhí)行固件更新。

OTA 更新介紹

大多數(shù)開發(fā)團(tuán)隊(duì)的核心重點(diǎn)是實(shí)現(xiàn)其產(chǎn)品的特定功能,也就是產(chǎn)品差異化業(yè)務(wù)邏輯。然而,每個(gè)物聯(lián)網(wǎng)產(chǎn)品都有一個(gè)基本功能集,需要在設(shè)備的整個(gè)生命周期內(nèi)進(jìn)行部署、配置和維護(hù)。安全更新是一個(gè)很好的例子。鑒于需要執(zhí)行這些更新,在評(píng)估一個(gè)合適的開發(fā)平臺(tái)時(shí),一個(gè)重要但容易被忽視的功能是引導(dǎo)程序或固件 OTA (FOTA) 更新(有時(shí)只稱為 OTA)能力。

OTA 為工程師提供了根據(jù)技術(shù)和業(yè)務(wù)要求遠(yuǎn)程維護(hù)和升級(jí)其產(chǎn)品的能力,而不需要派維護(hù)人員到設(shè)備上或讓終端客戶主動(dòng)對(duì)設(shè)備做一些更新。相反,所有這些成本都可以通過讓設(shè)備在后臺(tái)默默地或在半夜操作之類“停工”時(shí)間內(nèi)升級(jí)其固件方式來消除。

OTA 架構(gòu)可以有許多不同的形式和配置,從定制的解決方案一直到云提供商提供的標(biāo)準(zhǔn)實(shí)現(xiàn)方案。圖 1 中可以看到一個(gè)典型的架構(gòu)實(shí)例。

wKgaomVCRfuAEMFvAAGoF_7OcIQ498.png圖 1:OTA 架構(gòu)概覽展示在現(xiàn)場(chǎng)向所部署設(shè)備更新應(yīng)用固件的示例過程。(圖片來源:BeningoEmbedded Group)

在這個(gè)例子中,一個(gè)OEM 使用亞馬遜網(wǎng)絡(luò)服務(wù) (AWS) 物聯(lián)網(wǎng)內(nèi)核上傳新的固件版本,然后使用內(nèi)置的作業(yè)功能將更新部署到現(xiàn)場(chǎng)的設(shè)備。這只是眾多例子中的一個(gè),幾乎每個(gè)云供應(yīng)商都有類似的解決方案。

今天有許多支持OTA 的微控制器可供選擇。一個(gè)廣受低成本系統(tǒng)和制造商歡迎的微控制器是ESP32。ESP32 之所以如此受歡迎,有以下幾個(gè)原因:

  • 它有一個(gè)集成的微控制器,有 Wi-Fi/藍(lán)牙認(rèn)證模塊可用

  • 低成本

  • 開源開發(fā)環(huán)境和軟件框架,如 ESP-IDF 和 ESP 音頻開發(fā)框架 (ESP-ADF)

  • 許多現(xiàn)有的應(yīng)用實(shí)例可在網(wǎng)上免費(fèi)獲得

選擇一個(gè)ESP32 模塊進(jìn)行 OTA 測(cè)試

有幾種不同的ESP32 模塊和開發(fā)板可供用戶購買,以便了解 OTA 實(shí)例。以Adafruit3405ESP32 Huzzah Feather 板為例(圖 2)。這是一塊低成本的開發(fā)板,包括對(duì) ESP32 進(jìn)行編程的所有電路,并通過一個(gè) USB 連接器為其供電。

wKgaomVCRfyAVQ5bAAQR0TIhDZU276.png圖 2:3405 Huzzah Feather 板包含一個(gè) ESP32 WROOM-32D 認(rèn)證型 Wi-Fi/藍(lán)牙模塊,帶 4 Mb 閃存。該板包括所有必要的硬件,可通過 USB 編程和與模塊通信。(圖片來源:Adafruit) 3405 的核心是一個(gè)ESP32-WROOM-32D模塊,它配備了 4 Mb 閃存、Wi-Fi、藍(lán)牙和一套完整的外設(shè),幾乎適用于任何應(yīng)用。

另一塊可以使用的開發(fā)板是 Espressif Systems 的ESP32-LYRATD-SYNA音頻板(圖 3)。該開發(fā)板包括ESP32-WROVER-B模塊。?

wKgaomVCRfyABmY3AAf3r3Oo-FU295.png圖3 :ESP32-LYRATD-SYNA 板基于 ESP32 WROVER-B 認(rèn)證型 Wi-Fi/藍(lán)牙模塊,帶 4 Mb 閃存。除了能夠讓設(shè)計(jì)者通過 USB 編程和與模塊通信外,它還具有開發(fā)音頻應(yīng)用所需的電路。(圖片來源:EspressifSystems)

ESP32-LYRATD-SYNA模塊也有 4 Mb 閃存,以及用于音頻應(yīng)用的所有電路。該板包括一個(gè)音頻編解碼器、一個(gè)音頻放大器以及耳機(jī)和揚(yáng)聲器插孔,以全面測(cè)試音頻應(yīng)用。

最后一塊可用于OTA 測(cè)試的開發(fā)板是 Espressif 的ESP32-S2-SAOLA-1RI開發(fā)板(圖 4)。說到開發(fā)板,這款最不昂貴的。該板包含一個(gè) ESP32 Wrover 模塊,以及對(duì)該芯片進(jìn)行編程的電路。除了它所包含的引腳可以很容易地放到試驗(yàn)板上進(jìn)行測(cè)試外,沒有任何其他的裝飾。

wKgaomVCRfyAaBWiAATAC93f6fY352.png圖 4:基于 Wrover 模塊的 ESP32-S2-SAOLA-1RI 是一塊裸開發(fā)板,成本低,但包括足夠的電路來對(duì)板載模塊編程。(圖片來源:Espressif Systems)

為測(cè)試而選擇的具體板子并不太重要,因?yàn)槊總€(gè) ESP32 模塊都利用了 ESP-IDF。這個(gè)框架旨在通過包括驅(qū)動(dòng)程序、中間件、RTOS 以及對(duì)本文而言很重要的引導(dǎo)程序和 OTA 庫,從而為開發(fā)者簡化了軟件開發(fā)活動(dòng)。

引導(dǎo)程序允許開發(fā)者利用 OTA 更新,并在主要應(yīng)用仍在運(yùn)行時(shí)對(duì)內(nèi)存進(jìn)行分區(qū)以更新固件,這有助于最大限度地減少停機(jī)時(shí)間。引導(dǎo)程序的設(shè)置一開始可能看起來很復(fù)雜,但如果指導(dǎo)得當(dāng),是很簡單的。

OTA 開發(fā)工作流

ESP32 的 OTA 開發(fā)工作流將根據(jù)業(yè)務(wù)需求和產(chǎn)品組件選擇而略有不同。例如,一個(gè)利用 AWS 的團(tuán)隊(duì)可能會(huì)使用 AWS 的入門指南和例子來啟動(dòng)其 ESP32 OTA 解決方案。另一方面,一個(gè)正在定制自己解決方案的公司也可能會(huì)利用ESP32 的說明文檔。在這篇文章中,我們要看的是 ESP32 層面內(nèi)容,而不是在云端。原因是這些內(nèi)容是通用的,適用于 ESP32 的 OTA,無論使用哪個(gè)云提供商或解決方案。

一般來說,在ESP32 上設(shè)置 OTA 更新的過程包括以下步驟:

  • 配置 ESP32 分區(qū)表

  • 下載支持 OTA 的固件

  • 開發(fā)一個(gè)工具,充當(dāng)服務(wù)器,推送新的固件

  • 最新的固件下載到ESP32 上

  • 調(diào)換到新應(yīng)用

很明顯,這是簡化的方法。開發(fā)人員應(yīng)再次查看圖 1 以了解整個(gè)固件更新過程。這個(gè)過程可能相當(dāng)復(fù)雜,所以建議利用位于GitHub上的現(xiàn)有 ESP32 OTA 實(shí)例。這些例子提供了幾個(gè)關(guān)鍵實(shí)例,如:

  • HTTPS OTA

  • 本地 OTA

  • 簡單 OTA

  • OTA 工具(python 腳本示例)

圖 5 顯示了部署和更新過程的步驟。開發(fā)者需要先執(zhí)行紅色的步驟,將 OTA 解決方案部署到 ESP32 模塊上。橙色的步驟是下一步,執(zhí)行這些步驟是為了推進(jìn) OTA 更新。wKgaomVCRfyAJCvVAASUAjNzucg002.png圖 5:位于GitHub 上的 Espressif Systems OTA 更新例子為開發(fā)者提供了幾個(gè)簡單的例子,以讓其 ESP32 執(zhí)行 OTA 更新。(圖片來源:Espressif Systems)

為 OTA 配置一個(gè) ESP32 應(yīng)用程序

ESP32 包含一個(gè)分區(qū)表,描述了什么類型的數(shù)據(jù)位于微控制器上以及它的位置。例如,一個(gè)標(biāo)準(zhǔn)的 ESP32 分區(qū)表看起來像表 1。

wKgaomVCRf2AJQuJAADXBzm9Cmw109.png表 1:標(biāo)準(zhǔn) ESP32 分區(qū)表顯示了數(shù)據(jù)的類型及其在微控制器上的位置。(表格來源:BeningoEmbedded)有一個(gè)工廠應(yīng)用,然后是 NVS 庫和物理層 (PHY) 初始化(init) 數(shù)據(jù)部分。為了使用 OTA 功能,該表需要更新,以便除了主要(工廠)應(yīng)用外,還要為 OTA 更新固件指定存儲(chǔ)器位置。對(duì)于 OTA,通常有兩個(gè)分區(qū)被分配用于更新。一個(gè)是正在更新的固件,一個(gè)是正在下載的固件,它將成為最新版本。這使得工廠應(yīng)用能夠保持不變。更新后的 OTA 分區(qū)表將看起來像表 2。

wKgaomVCRf2AGXCSAAFZaW0t8Gs808.png表2:典型的 ESP32 更新 OTA 分區(qū)表。(表格來源:Beningo Embedded)如表所示,現(xiàn)在有一個(gè)ota_0 和 一個(gè)ota_1 應(yīng)用部分,其大小為 1Mb,此外還有一個(gè)數(shù)據(jù)部分 (otadata),是為更新過程分配的 RAM。這個(gè)表可以由開發(fā)者修改和更新,以適應(yīng)應(yīng)用。

為了運(yùn)行 OTA 例子,有一套簡單的說明,列在 GitHub 的“如何使用實(shí)例”部分。該部分描述了如何構(gòu)建應(yīng)用并對(duì)其進(jìn)行編程。

還有 otatool,可以用來更新固件。這個(gè)腳本通常用于:

  • 讀取、寫入和擦除OTA 分區(qū)

  • 切換引導(dǎo)分區(qū)

  • 切換到工廠分區(qū)
該示例腳本可以通過使用命令在終端運(yùn)行該示例來執(zhí)行。

./otatool_example.sh

或者使用Python。

pythonotatool_example.py

當(dāng)談到為 OTA 配置 ESP32 時(shí),確保分區(qū)的設(shè)置是一個(gè)關(guān)鍵步驟。

使用的技巧和訣竅

EPS32 OTA 解決方案可以加速和簡化開發(fā)者的固件更新方案。為了防止解決方案成為開發(fā)負(fù)擔(dān),有幾個(gè)“技巧和訣竅”應(yīng)該牢記在心。

如果可能的話,利用該公司的云供應(yīng)商所包含的現(xiàn)有 OTA 框架。這可以極大地簡化開發(fā)和集成。

使用低成本的開發(fā)板來測(cè)試 OTA 功能和引導(dǎo)程序。ESP32 有幾個(gè)選項(xiàng),可能需要一些實(shí)驗(yàn)來確定哪一個(gè)是最適合手頭的應(yīng)用。

對(duì)于定制解決方案,可利用 GitHub 上的 ESP32 OTA 實(shí)例。

對(duì)于產(chǎn)品作為Wi-Fi 路由器或集線器的應(yīng)用,考慮將固件鏡像下載到外部存儲(chǔ)器,并從大容量存儲(chǔ)設(shè)備執(zhí)行更新。

花一些時(shí)間查看關(guān)于分區(qū)表的 ESP32 說明文檔。這與典型的微控制器實(shí)現(xiàn)有點(diǎn)不同。

出于安全考慮,最好禁用應(yīng)用回滾。如果應(yīng)用可以回滾到以前的版本,潛在的攻擊者就有可能推送一個(gè)帶有已知漏洞的版本,并破壞系統(tǒng)。

遵循這些“技巧和決竅”的開發(fā)者會(huì)發(fā)現(xiàn),當(dāng)他們?cè)噲D利用 ESP32 或任何其他 OTA 解決方案時(shí),他們可以節(jié)省大量的時(shí)間并免受煎熬。

結(jié)語

OTA 更新是越來越多的物聯(lián)網(wǎng)和嵌入式系統(tǒng)的一個(gè)重要功能。開發(fā)人員需要很好地掌握這種功能的有效實(shí)現(xiàn)方法,以便在設(shè)計(jì)和開發(fā)過程中以及在產(chǎn)品出廠后節(jié)省前期時(shí)間。ESP32 無線微控制器已經(jīng)廣泛用于各種類型的設(shè)備,如上所述,它有一個(gè)現(xiàn)成的OTA 解決方案。通過利用 ESP-IDF 和相關(guān)的模塊和平臺(tái),并使用一些基于經(jīng)驗(yàn)的技巧和決竅,開發(fā)者可以大大減輕他們的設(shè)計(jì)時(shí)間,并完成他們的 OTA 解決方案并使之可靠地運(yùn)行。

秘技知識(shí)學(xué)不停 專屬福利享不停

就等您加入!

點(diǎn)此登記

賺積分、換好禮

立即到「會(huì)員權(quán)益」查看您的禮遇! 如有任何問題,歡迎聯(lián)系得捷電子DigiKey的客服團(tuán)隊(duì)

中國(人民幣)客服

wKgaomVCRf2AWlNjAAADBaTNctA797.png400-920-1199wKgaomVCRf6ABJDUAAADAQryhLs407.png服務(wù)支持 > 聯(lián)系客服 > 微信客服wKgaomVCRf6AcXgTAAADNUSMvSY694.pngservice.sh@digikey.comwKgaomVCRf6AboFsAAACyRJDcPk772.png QQ在線實(shí)時(shí)咨詢:4009201199

中國(美金)/ 香港客服

wKgaomVCRf2AWlNjAAADBaTNctA797.png

400-882-4440

wKgaomVCRf2AWlNjAAADBaTNctA797.png852-3104-0500wKgaomVCRf6AcXgTAAADNUSMvSY694.pngchina.support@digikey.comwKgaomVCRf6ADQsvAACBLhwpIzY806.png

wKgaomVCRf6AM3_bAAJQEo9UZ9g111.png

點(diǎn)擊下方“閱讀原文”查看更多

讓我知道你在看wKgaomVCRf-ADn5bAAAD385SHbk553.png


原文標(biāo)題:支持 OTA 更新的MCU很多 為何 ESP32這么受歡迎?

文章出處:【微信公眾號(hào):得捷電子DigiKey】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 得捷電子
    +關(guān)注

    關(guān)注

    1

    文章

    255

    瀏覽量

    8567

原文標(biāo)題:支持 OTA 更新的MCU很多 為何 ESP32這么受歡迎?

文章出處:【微信號(hào):得捷電子DigiKey,微信公眾號(hào):得捷電子DigiKey】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    esp8266和esp32區(qū)別是什么

    的內(nèi)存選項(xiàng),包括最小512KB的RAM和最大16MB的閃存。 Wi-Fi和藍(lán)牙 : ESP8266 :支持2.4GHz Wi-Fi。 ESP32支持2.4GHz Wi-Fi和藍(lán)牙5
    的頭像 發(fā)表于 08-19 18:16 ?3781次閱讀

    esp32用什么軟件編程

    。 概述 ESP32具有豐富的外設(shè)接口和靈活的編程方式,支持多種編程語言和開發(fā)環(huán)境。本文將詳細(xì)介紹ESP32的編程軟件,包括開發(fā)環(huán)境、編程語言、庫函數(shù)、開發(fā)工具等。 開發(fā)環(huán)境 2.1 Arduino IDE Arduino ID
    的頭像 發(fā)表于 08-19 17:24 ?2421次閱讀

    esp32c3 OTA鏡像錯(cuò)誤的原因?

    使用的是esp32c3參考的例程是 native_ota_example 錯(cuò)誤日志如下 2024-07-03 09:41:17 E (24704) esp_ota_ops: OTA i
    發(fā)表于 07-19 06:50

    ESP32-WROOM-32E、ESP32-WROOM-32D、ESP32-WROOM-32U 有什么區(qū)別?ESP32-WROOM-32 后綴字母代表的意思是?

    相信很多人心里都有這樣的疑問,今天就教大家怎么區(qū)分它們。 32D和32U是同一個(gè)芯片ESP32-D0WD的模組,主要區(qū)別的天線模式,分別是板載和IPEX外接天線。 32E是用的升級(jí)版的芯片
    的頭像 發(fā)表于 07-17 10:09 ?6865次閱讀
    <b class='flag-5'>ESP32</b>-WROOM-32E、<b class='flag-5'>ESP32</b>-WROOM-32D、<b class='flag-5'>ESP32</b>-WROOM-32U  有什么區(qū)別?<b class='flag-5'>ESP32</b>-WROOM-32 后綴字母代表的意思是?

    請(qǐng)問怎么使用ardunio工程打開esp32-cam的menuconfig使能OTA?

    我的esp32-cam想實(shí)現(xiàn)OTA升級(jí),結(jié)果發(fā)現(xiàn)系統(tǒng)的OTA支持好像沒打開。 但是由于IDE使用的ardunio,工程配置和分區(qū)表和idf的工程都不一樣。 請(qǐng)問怎么樣才能打開men
    發(fā)表于 06-20 07:44

    ESP32-S2-Kaluga-1更新了重新編譯的camera代碼,比出廠時(shí)噪點(diǎn)多很多怎么解決?

    ESP32-S2-Kaluga-1 更新了重新編譯的git上camera的代碼, 發(fā)現(xiàn)屏幕上的圖像比出廠時(shí)噪點(diǎn)多很多,顆粒大很多,請(qǐng)問是哪里配置需要修改呢? 感謝!
    發(fā)表于 06-19 07:15

    請(qǐng)問ESP32是否支持串口在線升級(jí)?

    請(qǐng)問ESP32是否支持串口在線升級(jí)。對(duì)OTA升級(jí)例程進(jìn)行修改,將http傳輸改為串口傳輸,是否可行。
    發(fā)表于 06-18 06:30

    請(qǐng)問esp32 ota升級(jí)如何獲取更新進(jìn)度?

    所用的是esp32-s2 idf:4.4調(diào)用esp_https_ota API進(jìn)行固件升級(jí),想獲取更新進(jìn)度,但不知道怎么實(shí)現(xiàn),有人做過或者有思路指點(diǎn)一下嗎?
    發(fā)表于 06-14 07:20

    esp32s3進(jìn)行https-OTA時(shí),出現(xiàn)wifi:m f null更新失敗怎么解決?

    使用的IDF為4.4.3,芯片為esp32s3F4R2.在進(jìn)行https-ota時(shí),進(jìn)行到esp_https_ota_begin()出現(xiàn)了wifi:m f null的log然后HTTPS OT
    發(fā)表于 06-13 08:27

    ESP32對(duì)Flash加密后能否使用OTA進(jìn)行后續(xù)的維護(hù)更新?

    ESP32對(duì)Flash加密后能否使用OTA進(jìn)行后續(xù)的維護(hù)更新
    發(fā)表于 06-07 08:21

    請(qǐng)問ESP32S3的OTA過程是否支持保存燒寫進(jìn)度,掉電重啟后從掉電前位置開始燒寫?

    請(qǐng)問ESP32S3的OTA過程是否支持保存燒寫進(jìn)度,掉電重啟后從掉電前位置開始燒寫? 例如OTA數(shù)據(jù)共需要20幀進(jìn)行傳輸,傳輸了10幀數(shù)據(jù)并通過e
    發(fā)表于 06-05 08:10

    借助ESP32-S3主控MCU、ChirpLAN?小網(wǎng)關(guān)搭建大網(wǎng)絡(luò)

    借助先進(jìn)的ESP32-S3主控MCU,ChirpLAN?小網(wǎng)關(guān)為您帶來前所未有的網(wǎng)絡(luò)體驗(yàn)。
    的頭像 發(fā)表于 03-14 10:02 ?905次閱讀

    ESP32-P4開發(fā)板問題揭秘!

    導(dǎo)讀ESP32-P4是一款高性能MCU,支持超大片上內(nèi)存,具有強(qiáng)大的圖像和語音處理能力。該款MCU包含一個(gè)高性能(HP)系統(tǒng)和一個(gè)低功耗(LP)系統(tǒng)。HP系統(tǒng)由RISC-V雙核處理器驅(qū)
    的頭像 發(fā)表于 02-24 08:03 ?1631次閱讀
    <b class='flag-5'>ESP32</b>-P4開發(fā)板問題揭秘!

    如何從ESP32中刪除OTA?

    通過 Arduino IDE 和示例等對(duì) ESP32 Dev 32 模塊進(jìn)行了一些 OTA 測(cè)試,一切正常。 現(xiàn)在我們想恢復(fù)到正常的串行/USB 編程,雖然我們似乎可以編程一個(gè)新程序,但它只是恢復(fù)到現(xiàn)有的 OTA 程序。 有沒有
    發(fā)表于 01-31 07:37

    ESP32-C3模塊使用問題集錦| C3的串口日志該如何禁用?

    ESP32-C3因?yàn)楣δ軓?qiáng)大、低功耗一直廣受歡迎,客戶在使用過程中,也是有很多疑問。下面小啟整理了一些C3模塊實(shí)際應(yīng)用客戶遇到的問題,做出解答,大家如果也有關(guān)于C3模塊的問題,可以評(píng)論區(qū)提出來
    的頭像 發(fā)表于 01-09 08:03 ?801次閱讀
    <b class='flag-5'>ESP32</b>-C3模塊使用問題集錦| C3的串口日志該如何禁用?