RM新时代网站-首页

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

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

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

一文淺談FlexCAN OTA

jf_pJlTbmA9 ? 來(lái)源:靈動(dòng)MM32MCU ? 作者:靈動(dòng)MM32MCU ? 2023-09-27 16:17 ? 次閱讀

1、簡(jiǎn)介

FlexCAN OTA 是由靈動(dòng)提供的一種基于 UDS 協(xié)議使用 CAN 總線實(shí)現(xiàn)對(duì) MCU 的 App 固件更新的解決方案。該解決方案的軟件部分主要由:Bootloader、App和PC Tool三部分構(gòu)成,硬件部分如圖 1 所示。

wKgaomUDzKKATx6NAADC5W2H_0Q899.png

圖 1 MCU 與 PC 機(jī)交互示意圖

1.1 關(guān)鍵特性

基于 UDS(ISO14229) 標(biāo)準(zhǔn)

基于 CAN(ISO11891-1) 標(biāo)準(zhǔn)

具備對(duì) App 固件 CRC 完整性校驗(yàn)功能

使用主機(jī)上傳 Flash driver 到 MCU

在 Bootloader 中進(jìn)行 App 有效性檢查

提供用于驗(yàn)證 App 固件更新的 PC 端上位機(jī)工具

1.2 什么是 FlexCAN ?

CAN 是控制器域網(wǎng) (Controller Area Network, CAN) 的簡(jiǎn)稱(chēng),是一種功能豐富的車(chē)用總線標(biāo)準(zhǔn),被設(shè)計(jì)用于在不需要主機(jī)(Host)的情況下,允許網(wǎng)絡(luò)上的單芯片和儀器相互通信。是由研發(fā)和生產(chǎn)汽車(chē)電子產(chǎn)品著稱(chēng)的德國(guó) BOSCH 公司開(kāi)發(fā),并最終成為國(guó)際標(biāo)準(zhǔn)(ISO11898),是國(guó)際上應(yīng)用最廣泛的現(xiàn)場(chǎng)總線之一。

FlexCAN 是 CAN 協(xié)議的一個(gè)高完成度版本。以靈動(dòng) MM32F0140 系列 MCU 內(nèi)嵌的 FlexCAN 為例,其符合 ISO 11898-1 標(biāo)準(zhǔn),支持 CAN 2.0B 版本協(xié)議,位速率高達(dá) 1 Mbps,具有非常靈活的用于傳輸和接收的郵箱系統(tǒng),可以接收和發(fā)送 11 位標(biāo)識(shí)符的標(biāo)準(zhǔn)幀,也可以接收和發(fā)送 29 位標(biāo)識(shí)符的擴(kuò)展幀,主要被設(shè)計(jì)用作車(chē)載串行總線,可滿(mǎn)足實(shí)時(shí)處理、車(chē)輛在電磁干擾環(huán)境下的可靠操作、成本效益、帶寬等要求。

1.3 什么是 UDS ?

UDS(Unified Diagnostic Services,統(tǒng)一診斷服務(wù))是一種用于汽車(chē)電子控制器 ECU (Electronic Control Units) 環(huán)境下的一種診斷通信協(xié)議,可實(shí)現(xiàn)診斷、固件更新、日常測(cè)試等功能,在 ISO 14229 中規(guī)定了其實(shí)現(xiàn)標(biāo)準(zhǔn)。

在本實(shí)例中,UDS 通信是在客戶(hù)端-服務(wù)端關(guān)系中執(zhí)行的??蛻?hù)端是上位機(jī)下載軟件運(yùn)行于 PC 機(jī),服務(wù)端是帶有FlexCAN IP模塊的 MM32 MCU。例如,將 CAN 總線接口連接到 MCU,并將 UDS 請(qǐng)求發(fā)送到 MCU。當(dāng) MCU 支持 UDS 服務(wù)時(shí),它將根據(jù)客戶(hù)端發(fā)出的請(qǐng)求做出相應(yīng)的響應(yīng)。

1.4 為什么用 Bootloader ?

對(duì)于 MCU 而言,如果程序內(nèi)置有基于FlexCAN 的 Bootloader,則每次更新 MCU 的固件則不需要拆開(kāi)外殼也不必再使用燒錄器進(jìn)行燒錄,而可直接通過(guò) CAN 總線來(lái)更新程序,這樣更方便也更安全,而且隨著智能化的普及,甚至可以對(duì) MCU 進(jìn)行遠(yuǎn)程升級(jí)。Bootloader 程序結(jié)構(gòu)對(duì)比如圖 2 所示:

wKgZomUDzKOAC9SsAABwZBPH-eE189.jpg

圖 2 程序結(jié)構(gòu)對(duì)比框圖

1.5 為什么基于 UDS ?

為了規(guī)范 Bootloader 的全過(guò)程,通過(guò)使用成熟的平臺(tái)進(jìn)而提供高質(zhì)量 Bootloader。因 UDS 在設(shè)計(jì)時(shí)考慮了 Bootloader 的需求,并為 Bootloader 提供了相關(guān)服務(wù)以供使用,比如診斷會(huì)話控制、ECU 重置、讀取數(shù)據(jù)、請(qǐng)求下載、傳輸數(shù)據(jù)、請(qǐng)求傳輸退出等,可以實(shí)現(xiàn)更高效和可靠的刷寫(xiě)功能。故主機(jī)廠普遍會(huì)要求在 UDS 規(guī)范的基礎(chǔ)上完成 Bootloader 功能。

1.6 用到了哪些 UDS 服務(wù)?

在 Bootloader 中,使用到 UDS 的 $10、$11、$27 和 $3E 基礎(chǔ)診斷服務(wù),$22、$2E 讀寫(xiě) DID 服務(wù),$31、$34、$36 和 $37 固件數(shù)據(jù)傳輸相關(guān)服務(wù)。UDS 服務(wù)概覽如表 1-1 所示:

表 1-1

wKgaomUDzKSAKxJnAAGP6uvAfgQ512.jpg

2、Bootloader

Bootloader 是一段允許在不使用燒錄器的情況下更新App固件的代碼,基于靈動(dòng) MindSDK 實(shí)現(xiàn)的 Bootloader 樣例工程支持 MDK、IAR 和 ARMGCC 三種工具鏈進(jìn)行開(kāi)發(fā)。在實(shí)際的使用過(guò)程中只需要在第一次使用時(shí)通過(guò)燒錄器將 Bootloader 燒錄進(jìn) MCU,后續(xù)的 App 都可以通過(guò)使用基于 CAN 總線的 UDS協(xié)議完成固件更新。

2.1 Bootloader 功能特性

支持 Service 27,用戶(hù)可根據(jù)自身需求添加安全訪問(wèn)算法。

支持 Service 22 和 Service 2E,用戶(hù)可以根據(jù)自身需求添加策略,進(jìn)行信息讀出與存儲(chǔ)。

外置 Flash driver,使用時(shí)通過(guò)外部 PC 或后臺(tái)將 Flash driver 加載到 MCU 的 RAM 中進(jìn)行安全的 Flash 擦寫(xiě)操作。

提供看門(mén)狗監(jiān)控功能,用戶(hù)可根據(jù)自身需求選擇性開(kāi)啟看門(mén)狗監(jiān)控程序。

2.2 客制化修改說(shuō)明

修改診斷 ID

可在樣例工程的 board/FblHalCan.h 中修改診斷 ID 的值。

指定數(shù)據(jù)填充值

當(dāng)需要發(fā)送的數(shù)據(jù)長(zhǎng)度不滿(mǎn)足 8 字節(jié)長(zhǎng)度時(shí),通過(guò)宏定義可以更改填充,用戶(hù)可以在樣例工程的 board/FblHalCan.h 中指定填充值。

使能看門(mén)狗

用戶(hù)可以在樣例工程的 board/FblMacros.h 中打開(kāi)宏開(kāi)關(guān) WDG_ENABLE 使能看門(mén)狗服務(wù),并且實(shí)現(xiàn) ResetWdg 操作。

安全訪問(wèn)算法接口

Bootloader中支持 27 Service,用戶(hù)可在樣例工程的 board/FblMacros.h 中使能宏開(kāi)關(guān) ENABLE_SECURITY_ALGORITHM_VERIFICATION 根據(jù)自身需求添加安全訪問(wèn)算法。

2.3 Flash driver 介紹

什么是Flash driver?

在OTA程序升級(jí)過(guò)程中,發(fā)送App可執(zhí)行文件之前,向底層先發(fā)送一段二進(jìn)制文件,這段代碼實(shí)現(xiàn)了對(duì)MCU片內(nèi) Flash 的擦寫(xiě)功能,稱(chēng)為 Flash driver。

Flash driver存在的意義

在車(chē)載ECU控制器中,為了安全考慮,會(huì)盡可能的避免在代碼中固化有對(duì)flash進(jìn)行擦寫(xiě)操作,主要為了避免在程序跑飛時(shí)誤調(diào)用該部分代碼,使軟件代碼部分受到破壞。

Flash driver的實(shí)現(xiàn)方式

a.將flash driver固化在底層flash中,在運(yùn)行的時(shí)候?qū)lash中的flash driver拷貝到ram中來(lái)運(yùn)行,這是比較傳統(tǒng)的方式,但是避免不了提到的安全性問(wèn)題。

b.將flash driver這段代碼保存在PC端或后臺(tái),在每次執(zhí)行OTA升級(jí)前,將這段代碼先發(fā)送給MCU,這樣可以避免方式 a 中提到的安全性問(wèn)題。

3、App

基于靈動(dòng) MindSDK 提供的 flexcan_ota_app 樣例工程進(jìn)行開(kāi)發(fā)和生成用于更新的 HEX 格式 App 固件生成,無(wú)需任何適配操作即可生成用于 OTA 升級(jí)的 App 固件。

3.1 使用說(shuō)明

將 Bootloader 通過(guò)下載器下載到 MCU 中后,可通過(guò)提供的 PC Tool 來(lái)刷寫(xiě)生成的固件,通過(guò) PC Tool 下載成功后,一方面 PC 終端會(huì)有下載成功提示,另一方面也可以查看開(kāi)發(fā)板上對(duì)應(yīng)固件實(shí)現(xiàn)的功能是否開(kāi)始執(zhí)行。

關(guān)于 App 固件可從提供的 flexcan_ota_app 樣例工程編譯源碼并將生成“.hex”格式的 App 固件進(jìn)行加載。

3.2 App 設(shè)計(jì)規(guī)范

App 與 Bootloader 存放在 MCU 的同一塊 Flash 的兩個(gè)不同區(qū)域中,為保證兩個(gè)軟件的正常使用,App 設(shè)計(jì)遵循表 2-1 和表 2-2 所述規(guī)范。

表 2-1

wKgZomUDzKaAWI5KAABVoL-V9Ys846.png

表 2-2

wKgaomUDzKiAXeNUAAA7O3AacIg993.png

4、PC Tool

Flexcan OTA PC Tool 是用于驗(yàn)證靈動(dòng) MindSDK 中提供的 FlexCAN OTA 解決方案的簡(jiǎn)易 PC 端上位機(jī)工具。

4.1 功能特性

支持 CAN 通信速率自定義

支持 Win10 操作系統(tǒng)下運(yùn)行

支持默認(rèn)參數(shù)直接運(yùn)行和命令行下帶參數(shù)運(yùn)行

支持直接加載 MDK 和 IAR 工具鏈下生成的 HEX 格式文件

基于 Python 使用 python-udsoncan 開(kāi)發(fā),可根據(jù)不同需求靈活進(jìn)行二次開(kāi)發(fā)

4.2 開(kāi)發(fā)環(huán)境

本工具在 Win10 平臺(tái)使用 Python 進(jìn)行開(kāi)發(fā),基于 UDS 使用 CAN 協(xié)議,支持 PEAK CAN卡與 MCU 進(jìn)行通訊。

4.3 使用說(shuō)明

請(qǐng)按照如下步驟進(jìn)行操作:

a、下載 Bootloader 到 MCU

將提供的 flexcan_ota_bootloader 樣例工程編譯并下載到開(kāi)發(fā)板中。

b、安裝 CAN 卡驅(qū)動(dòng)并連接 MCU

在這里我們用到的是PCAN-USB,下載并安裝驅(qū)動(dòng)(https://peak-system.com.cn/driver/) ,并將 PCAN-USB 和開(kāi)發(fā)板上的 CAN 收發(fā)器通過(guò)雙絞線連接以及通過(guò) USB 和 PC 機(jī)連接。

c、運(yùn)行 FlexCAN OTA PC Tool

方式一:按照默認(rèn)參數(shù)直接運(yùn)行

直接雙擊 flexcan_ota_pc_tool_v1.0.exe,如圖 3 所示,默認(rèn)將按照 500Kbps 的比特率進(jìn)行 CAN 通信,F(xiàn)lash_driver 文件的加載地址為當(dāng)前路徑下的文件(./flash_driver.hex), App 文件的加載路徑為當(dāng)前路徑下文件(./app.hex)。

wKgZomUDzKmAbg3kAAEbTv4T9NU992.jpg

圖 3

方式二:按照指定參數(shù)運(yùn)行

在 Win10 平臺(tái)下啟動(dòng)命令行窗口并切換到當(dāng)前路徑下,獲取幫助如圖4所示,輸入如下指令并按回車(chē)鍵:

flexcan_ota_pc_tool_v1.0.exe-h

wKgZomUDzKuAQMSWAACkH2Hr0Mg825.jpg

圖 4

按照指定參數(shù)運(yùn)行如圖 5 所示,輸入如下指令并按回車(chē)鍵:flexcan_ota_pc_tool_v1.0.exe-b500000-f"./flash_driver.hex"-a"./app.hex"

其中 flash_driver.hex 文件為用于安全地擦寫(xiě)片內(nèi) flash 的代碼,在每次 OTA 更新中復(fù)用即可。

wKgaomUDzK2AJK4OAAFWKSqCh8Q417.jpg

圖 5

d、結(jié)束

等待 FlexCAN OTA 固件更新流程結(jié)束,并按任意按鍵退出。

5、注意事項(xiàng)

FlexCAN OTA Tool 為用于驗(yàn)證基于 UDS 使用 CAN 協(xié)議進(jìn)行 App 固件更新的上位機(jī)工具,PC 端使用 PEAK-CAN 與 MCU 通訊,僅支持在 Win 10 操作系統(tǒng)下運(yùn)行, 且用于功能性驗(yàn)證,若遇到軟件閃退等問(wèn)題請(qǐng)重啟該軟件并復(fù)位 MCU。該工具可根據(jù)開(kāi)發(fā)者項(xiàng)目需求進(jìn)行二次開(kāi)發(fā)。

以上介紹是基于MM32F0140 系列 MCU 進(jìn)行介紹和示例演示,相關(guān)源碼請(qǐng)?jiān)L問(wèn)靈動(dòng)官網(wǎng)進(jìn)行獲取:

01)進(jìn)入靈動(dòng)官網(wǎng)(www.mm32mcu.com)

02)打開(kāi)“產(chǎn)品”菜單下 MM32F0140 頁(yè)面,瀏覽“文檔”列表。

wKgZomUDzK-AQcBfAAAq_aLy538130.png

03)在“應(yīng)用筆記”中下載“AN0035_FlexCAN_OTA”文檔,獲取源碼。

wKgaomUDzLCAC2KmAABBEty7Zfo463.png

6、參考文獻(xiàn)

《ISO11898-1》

《ISO14229》

來(lái)源:靈動(dòng)MM32MCU

免責(zé)聲明:本文為轉(zhuǎn)載文章,轉(zhuǎn)載此文目的在于傳遞更多信息,版權(quán)歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權(quán)問(wèn)題,請(qǐng)聯(lián)系小編進(jìn)行處理


審核編輯 黃宇

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

    關(guān)注

    57

    文章

    2744

    瀏覽量

    463615
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    2878

    瀏覽量

    88051
  • OTA
    OTA
    +關(guān)注

    關(guān)注

    7

    文章

    578

    瀏覽量

    35193
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    OTA升級(jí)】無(wú)需數(shù)據(jù)線,條命令即可完成固件升級(jí)!

    OTA無(wú)線升級(jí)過(guò)程視頻演示:OTA介紹OTA(Over-The-Air,空中升級(jí))是種通過(guò)無(wú)線通信技術(shù)實(shí)現(xiàn)遠(yuǎn)程更新設(shè)備固件或軟件的方法。設(shè)備批量投入使用后,由于部署范圍太廣、設(shè)備數(shù)量
    的頭像 發(fā)表于 12-11 01:00 ?404次閱讀
    【<b class='flag-5'>OTA</b>升級(jí)】無(wú)需數(shù)據(jù)線,<b class='flag-5'>一</b>條命令即可完成固件升級(jí)!

    串口屏 OTA(Over-The-Air)簡(jiǎn)述

    OTA(Over-The-Air)更新是種通過(guò)無(wú)線網(wǎng)絡(luò)或有線網(wǎng)絡(luò)對(duì)設(shè)備進(jìn)行遠(yuǎn)程固件更新的技術(shù)。在串口屏的應(yīng)用中,OTA更新可以大大提高維護(hù)效率和用戶(hù)體驗(yàn)。本文將詳細(xì)介紹如何在串口屏上實(shí)現(xiàn)OT
    的頭像 發(fā)表于 11-21 09:19 ?1117次閱讀

    OTA測(cè)試暗箱的技術(shù)原理和應(yīng)用場(chǎng)景

    OTA測(cè)試暗箱在無(wú)線通信設(shè)備的研發(fā)與測(cè)試中扮演著至關(guān)重要的角色。以下是對(duì)OTA測(cè)試暗箱技術(shù)原理和應(yīng)用場(chǎng)景的詳細(xì)闡述:、OTA測(cè)試暗箱的技術(shù)原理OT
    發(fā)表于 11-14 14:36

    懌星實(shí)車(chē)OTA測(cè)試設(shè)備介紹

    懌星實(shí)車(chē)OTA測(cè)試設(shè)備(Neptune OTA Box)是款專(zhuān)為實(shí)車(chē)OTA測(cè)試與實(shí)車(chē)總線數(shù)據(jù)采集而設(shè)計(jì)的先進(jìn)設(shè)備,基于懌星自主研發(fā)的軟硬件平臺(tái),旨在快速助力OEM廠商構(gòu)建實(shí)車(chē)
    的頭像 發(fā)表于 11-01 10:38 ?283次閱讀
    懌星實(shí)車(chē)<b class='flag-5'>OTA</b>測(cè)試設(shè)備介紹

    OTA自動(dòng)化測(cè)試解決方案——實(shí)車(chē)級(jí)OTA測(cè)試系統(tǒng)PAVELINK.OTABOX

    作者|網(wǎng)蟲(chóng)小編|不吃豬頭肉引言往期內(nèi)容里為大家介紹了OTA技術(shù)、OTA后續(xù)的發(fā)展趨勢(shì)預(yù)測(cè)及OTA自動(dòng)化測(cè)試解決方案。本文是OTA系列的第三篇文章,今天主要向大家介紹實(shí)車(chē)級(jí)
    的頭像 發(fā)表于 07-11 08:26 ?646次閱讀
    <b class='flag-5'>OTA</b>自動(dòng)化測(cè)試解決方案——實(shí)車(chē)級(jí)<b class='flag-5'>OTA</b>測(cè)試系統(tǒng)PAVELINK.OTABOX

    FlexCAN中文手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《FlexCAN中文手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 06-20 11:14 ?4次下載

    如何編譯OTA時(shí)的加密固件?

    main->CMakeLists.txt中添加以下生成加密OTA固件的命令。第次編譯時(shí)能夠生成加密固件。但第次之后,再編譯固件時(shí),就生成不了加密固件了。請(qǐng)問(wèn)我該怎么解決,達(dá)到每次編譯都能生成
    發(fā)表于 06-05 08:28

    ESP IDF OTA升級(jí)失敗的原因?

    ESP IDF 5.1.1,官方OTA例程,升級(jí)過(guò)程中失敗,tcp拉取文件中斷,有遇到類(lèi)似情況的嗎,日志如下: I (59717) ota: ota url:http://www.xxxx.com
    發(fā)表于 06-05 07:27

    OTA測(cè)試

    OTA測(cè)試用什么可以仿真?
    發(fā)表于 05-19 00:07

    基于MM32G5330的FlexCAN實(shí)現(xiàn)CANopenNode協(xié)議棧移植

    本文將介紹如何基于靈動(dòng)MM32G5330的FlexCAN實(shí)現(xiàn)CANopenNode協(xié)議棧的移植,并使用靈動(dòng)官方提供的開(kāi)發(fā)板Mini-G5333進(jìn)行驗(yàn)證。
    發(fā)表于 04-12 09:15 ?1464次閱讀
    基于MM32G5330的<b class='flag-5'>FlexCAN</b>實(shí)現(xiàn)CANopenNode協(xié)議棧移植

    請(qǐng)問(wèn)BlueNRG ota升級(jí)中ota_sw_activation變量上電是隨機(jī)值嗎?

    最近在看BlueNRG ota升級(jí)代碼時(shí)有個(gè)疑惑,ota_sw_activation變量是個(gè)未初始化的值,按照ram特性上電應(yīng)該是個(gè)隨
    發(fā)表于 03-13 08:29

    ota升級(jí)是什么意思 ota升級(jí)有什么用

    OTA(Over-the-Air)升級(jí)是指通過(guò)無(wú)線網(wǎng)絡(luò),將軟件、固件或系統(tǒng)的新版本傳輸?shù)街С值脑O(shè)備上進(jìn)行更新和安裝的過(guò)程。這技術(shù)廣泛應(yīng)用于手機(jī)、智能電視、汽車(chē)等各類(lèi)智能設(shè)備中。本文將詳細(xì)介紹OTA
    的頭像 發(fā)表于 02-02 10:25 ?5497次閱讀

    如何從ESP32中刪除OTA

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

    OTA云平臺(tái)架構(gòu)及關(guān)鍵技術(shù)

    OTA 是 Over the Air 的縮寫(xiě),通常指的是遠(yuǎn)程無(wú)線方式,OTA 技術(shù)可以理解為種遠(yuǎn)程無(wú)線升級(jí)技術(shù)。在無(wú)特別說(shuō)明情況下,本文所指的 OTA 是所有汽車(chē)遠(yuǎn)程升級(jí)的統(tǒng)稱(chēng)。
    發(fā)表于 01-02 10:03 ?2556次閱讀
    <b class='flag-5'>OTA</b>云平臺(tái)架構(gòu)及關(guān)鍵技術(shù)
    RM新时代网站-首页