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

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

AVR嵌入式評估板執行固件更新的技巧和訣竅

電子設計 ? 來源:互聯網 ? 作者:佚名 ? 2018-08-06 09:26 ? 次閱讀

幾乎所有的嵌入式系統都需要能夠在現場更新其固件,從而添加新特性或修復漏洞。然而,固件現場更新可能會頗具挑戰性,因為開發人員必須編寫自己的引導程序或從第三方元器件供應商處購買引導程序。

有一個較為簡單的方法。本文將介紹如何使用很多微控制器都會內置但通常會被忽視的設備固件更新 (DFU) 功能。

固件更新選項

從頭開始開發引導程序并非易事。開發人員需要解析他們的閃存空間,以便多個應用可以共存。然后,他們還需要開發幾種方法在不使用編程工具的情況下將其編譯的二進制程序轉移到微控制器中。這需要他們開發自己的通信協議或者需要添加外部存儲器以存儲新映像而增加了系統的復雜性。他們還要增加其微控制器上的內存容量。

同樣地,軟件本身也會變復雜,因為引導程序需要設置系統狀態及確定跳轉到應用代碼是否安全。

使用定制引導程序可以為開發人員提供其應用非常需要的靈活性,但很多無需開發人員工作量的應用可以采用一種固件更新標準:USB 標準的內置設備固件更新 (DFU) 類。這可用于通過其 USB 端口在現場更新微控制器的應用代碼,從而大大減少固件升級過程和開發周期。

DFU 已經普遍使用,這使得一些微控制器供應商(如STMicroelectronics)甚至都提供了執行硬編碼到其 ROM 中的更新所需的軟件。那些沒有提供的,通常會提供如何支持 DFU 的示例代碼。

選擇適合 DFU 的微控制器

支持 DFU 的最簡單方法是選擇一個已經在其 ROM 中包含 DFU 的微控制器,如 STMicroelectronics 的STM32 IoT Discovery 節點和STM32F429 Discovery 套件上的設備。

圖 1: STMicroelectronics STM32 IoT Discovery 節點基于運行STM32L475MCU(其中包含用于固件更新的 DFU 模式功能)的 ARM?Cortex?-M4 核。此特定設備設計用作 IoT 節點。(圖片來源:STMicroelectronics)

STM32 IoT Discovery 節點是一種低成本開發板,設計用作 IoT 傳感器節點。該開發板包括幾個不同的接口,用于連接 Wi-Fi藍牙等板。讓人感興趣的是,板載STM32L475 為開發人員提供在設計用于連接互聯網的設備上測試和使用 DFU 功能的能力。

對于只想在獨立的正常設備上測試 DFU 的開發人員來說,STM32F429 Discovery 套件是STM32F4系列微控制器的知名、低成本開發套件。我們來討論開發人員如何著手開始在這些微控制器上測試 DFU。

圖 2: STMicroelectronics STM32F429 Discovery 套件基于ARM?Cortex?-M4 核。這個低成本開發板的 MCU 還包括用于進行固件更新的 DFU 模式功能。(圖片來源: STMicroelectronics)

一個簡單的 DFU 示例

每個微控制器訪問 DFU 的方式都不同。通過一個簡單的示例來看一看開發人員如何在運行 STM32L475 MCU 的設備上更新其固件。

如前所述,STM32 微控制器包括內置到其 ROM 中的 DFU 引導程序。要訪問該引導程序,開發人員需要在 MCU 啟動時拉動其中一個 BOOT 引腳將其接地。BOOT 引腳控制 MCU 啟動時所處的模式,如從閃存、RAM 中啟動,或者我們首選的 DFU USB 模式。

使用 DFU 準備要供用戶下載的應用不需要開發人員進行任何額外的工作。GNU 編譯器收集 (GCC) 以及很多其他工具鏈支持在編譯應用時生成 DFU 文件。在這里,開發人員的唯一訣竅是確定該文件的存儲位置:跟所有典型應用一樣,要找到 .dfu 文件,可以參見調試或對象文件夾。

DFU 文件與二進制格式、s-record 格式和十六進制文件等其他應用記錄格式非常相似。文件格式包括通過 USB 中繼轉發、處理、然后寫入閃存內指定位置的地址和數據信息。該過程無縫連接,使開發人員很少(如果有的話)需要檢查正被使用的協議。這些都是在后臺進行的,可幫助降低固件更新過程和開發工作的復雜性。

開發人員可以使用幾個不同的工具通過 DFU 將他們的應用轉移到微控制器中。dfu-util 是可以使用的一般命令行工具。它在 Linux 和 Windows?上都以開源軟件包形式提供。如果開發人員使用 STM 工具鏈,他們就可以利用 STMicroelectronics 應用 DfuSe(圖 3)。

STMicroelectronics DfuSe 工具的圖片

圖 3: STMicroelectronics DfuSe 工具可用于編程由 GCC 等編譯器生成并加載到適合 DFU 的微控制器中的 DFU 文件。(圖片來源:Beningo Embedded Group)

DfuSe 是 Windows GUI 實用工具,可檢測已在 DFU 模式下通電并通過 USB 連接到計算機的任何 STM32 設備。開發人員可以檢索編程供應商和產品 ID 等信息。如果沒有對閃存空間采取適當的安全保護,他們甚至可以復制 MCU 的存儲內容并使用上傳操作框將其存儲在計算機上。

使用 DfuSe 時,開發人員一般只使用“升級”或“驗證操作”部分。在此區域,開發人員可以選擇其 DFU 應用文件,然后選擇升級按鈕。然后,DfuSe 將自動協調固件更新過程,直到整個文件已成功加載到 MCU。然后,開發人員可以選擇驗證映像已成功接收。一經驗證,BOOT 引腳就可以設置回其默認配置,如引導至閃存,然后選擇‘離開 DFU’模式加載并執行更新的固件。

在沒有 DFU 支持的設備上使用 DFU

只是因為微控制器不在 ROM 內提供 DFU 引導程序,并不意味著開發人員仍不能利用 DFU 功能。DFU 屬于 USB 類,在很多 USB 堆棧中都受支持。這表示,開發人員同樣能向其應用框架簡單的添加 DFU 功能,且仍能執行 DFU 更新。

例如,Microchip Technology 的AT32UC3A3不具有內置的 DFU 模式(圖 4)。開發人員可以遵照描述 DFU 工作原理及開發人員應當如何將其微控制器配置為適當支持 DFU 的簡單應用說明。

圖 4:AT32UC3A3 UC3-A3 XPLD AVR?32 MCU 32 位 AVR 嵌入式評估板不包括片載 DFU,但可以添加上支持 DFU 固件更新特性的框架 USB 代碼。(圖片來源:Microchip Technology)

執行固件更新的技巧和訣竅

在現場更新固件并不一定只能從適合 DFU 的微控制器中進行。開發人員可以決定更新固件的替代方法是否必要或更加實用。在這種背景下,開發人員應記住關于其固件更新過程的幾個技巧。其中包括:

  • 使用校驗和或哈希驗證將寫入微控制器內存的應用。

  • 選擇內存足夠的微控制器存儲固件的備份件,以便發生錯誤時可以回滾固件版本。

  • 驗證在微控制器具有內置閃存加載程序時,終端用戶不會意外觸發該程序。

  • 確保任何軟件引導程序均已編譯且針對尺寸進行優化。

  • 鎖定閃存外設,使應用無法從內存中讀取出且不能被反向工程。

  • 務必確保棧指示器、向量表和程序計數寄存器均設置為適當的應用值。

  • 考慮按KL46Z Freedom 板的演示使用采用了 USB MSD 的拖放更新之類的替代更新方法(圖 5)。

圖 5: NXP Semiconductor 的 KL46Z Freedom 板是一種低成本開發板,默認不支持 DFU。開發人員可以使用 USB MSD 之類將新固件映像拖放到內存中的替代更新方法。(圖片來源:NXP Semiconductor)

總結

幾乎所有嵌入式系統都需要在現場更新應用代碼以避免回調的方法。從頭開始創建引導程序或者修改現有引導程序可能會增加開發周期的復雜性和集成問題。

反之,開發人員可以使用內置到 USB 標準中的經過充分證明的 DFU 功能來快速、高效、毫不費力的執行現場升級。為了讓這個過程順利進行,開發人員需要仔細檢查其微控制器并確定 DFU 是否已內置到其微控制器中或者它們是否需要包括支持 DFU 功能的軟件堆棧。

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

    關注

    2266

    文章

    10873

    瀏覽量

    354850
  • STM32F429
    +關注

    關注

    0

    文章

    40

    瀏覽量

    10648
  • DFU工具
    +關注

    關注

    0

    文章

    4

    瀏覽量

    2729
收藏 人收藏

    評論

    相關推薦

    嵌入式學習建議

    對廣大渴望學習嵌入式系統的學子提出幾點基礎階段的學習建議: ①嵌入式系統軟件硬件密切相關,一定要打好軟硬件基礎。其實,只要找到正確的方法,加上努力,任何理工科學生,甚至非理工科學生,都能學好嵌入式
    發表于 10-22 11:41

    嵌入式主板是什么意思?嵌入式主板全面解析

    嵌入式主板,通常被稱為嵌入式系統的核心組件,是一種用于控制和數據處理的計算機硬件,其設計旨在嵌入特定設備中執行專門任務。嵌入式主板如同是設備
    的頭像 發表于 09-30 10:05 ?373次閱讀

    北京迅為RK3568開發嵌入式學習之Linux驅動全新更新-CAN+

    北京迅為RK3568開發嵌入式學習之Linux驅動全新更新-CAN+
    的頭像 發表于 09-04 15:29 ?410次閱讀
    北京迅為RK3568開發<b class='flag-5'>板</b><b class='flag-5'>嵌入式</b>學習之Linux驅動全新<b class='flag-5'>更新</b>-CAN+

    嵌入式linux開發怎么操作

    嵌入式Linux開發是一種基于Linux操作系統的嵌入式系統開發平臺。它通常包括一個處理器、內存、存儲器、輸入/輸出接口等硬件組件,以及一個基于Linux的操作系統和開發工具。 嵌入式
    的頭像 發表于 09-02 09:09 ?328次閱讀

    嵌入式linux開發芯片的工作原理

    嵌入式Linux開發是一種基于Linux操作系統的嵌入式系統開發平臺,它廣泛應用于工業控制、智能家居、智能交通、醫療設備等領域。 嵌入式Linux開發
    的頭像 發表于 09-02 09:07 ?335次閱讀

    嵌入式系統怎么學?

    、C++或者Python。這些語言在嵌入式系統開發中都被廣泛應用。 3、微處理器/微控制器架構:學習常見的微處理器和微控制器架構,如ARM、AVR、PIC等,了解其特性和應用場景。 4、嵌入式系統開發
    發表于 07-02 10:10

    嵌入式主板,你了解多少?

    本文中,我們將討論什么是嵌入式主板、它的組件以及它在嵌入式系統中的功能。 嵌入式主板的組件 嵌入式主板由多個關鍵部件組成,每個部件對其整體功能都起著至關重要的作用。這些組件包括: CP
    的頭像 發表于 04-17 15:11 ?1416次閱讀

    嵌入式fpga是什么意思

    嵌入式FPGA是指將FPGA技術集成到嵌入式系統中的一種解決方案。嵌入式系統是一種為特定應用而設計的計算機系統,它通常包括處理器、內存、外設接口等組件,并且被嵌入到更大的設備或系統中,
    的頭像 發表于 03-15 14:29 ?1200次閱讀

    fpga是嵌入式

    FPGA(現場可編程門陣列)不是嵌入式系統,但FPGA在嵌入式系統中有著重要的應用。
    的頭像 發表于 03-14 17:19 ?2151次閱讀

    嵌入式學習步驟

    硬件組件。 (4).開發固件:編寫嵌入式系統的固件,這是嵌入式系統的軟件部分。固件負責控制硬件并執行
    發表于 02-02 15:24

    高端嵌入式實驗平臺

    一、整體概述 該嵌入式平臺具有前沿性、專業性、高集成度、功能豐富等特點,平臺涵蓋嵌入式計算機技術、嵌入式硬件接口、嵌入式系統軟件等關鍵技術點,硬件主板采用靈活的核心
    的頭像 發表于 01-29 09:55 ?490次閱讀
    高端<b class='flag-5'>嵌入式</b>實驗平臺

    啥是嵌入式嵌入式都有啥?薪資如何?前景如何

    嵌入式系統(Embedded Systems)是一種特殊類型的計算機系統,被嵌入到其他設備或系統中,用于執行特定的任務或控制特定的功能。這些系統通常設計用于特定的應用領域,具有特定的硬件和軟件要求
    的頭像 發表于 01-17 16:39 ?858次閱讀
    啥是<b class='flag-5'>嵌入式</b>?<b class='flag-5'>嵌入式</b>都有啥?薪資如何?前景如何

    QE for AFE嵌入式系統開發的評估工具說明

    電子發燒友網站提供《QE for AFE嵌入式系統開發的評估工具說明.pdf》資料免費下載
    發表于 12-21 10:27 ?0次下載
    QE for AFE<b class='flag-5'>嵌入式</b>系統開發的<b class='flag-5'>評估</b>工具說明

    什么是嵌入式板卡?

    嵌入式板卡是配備處理器、各種集成電路、接口和其他關鍵組件的電路,所有這些組件都組裝起來以執行特定功能。如USB、Ethernet、串口、GPIO等,以便連接外部設備和傳感器。它們還可能包括擴展插槽
    的頭像 發表于 12-20 16:17 ?806次閱讀
    什么是<b class='flag-5'>嵌入式</b>板卡?

    什么是嵌入式系統?嵌入式系統的具體應用

    嵌入式,一般是指嵌入式系統。用于控制、監視或者輔助操作機器和設備的裝置。
    的頭像 發表于 12-20 13:33 ?2412次閱讀