91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

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

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

3天內不再提示

利用SAU和安全AHB控制器調查HardFault的方法

恩智浦MCU加油站 ? 來源:恩智浦MCU加油站 ? 作者:劉豪 ? 2021-11-21 09:47 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

TrustZone

恩智浦基于Cortex M33內核的MCULPC55S6x/LPC55S1x, RT600/RT500等產品提供了對TrustZone的支持,并在SOC上提供了安全AHB控制器等功能,旨在幫助客戶完成良好的安全隔離,并建立可信執行環境。

在產品設計之初,我們就要有一個基本的“隔離”的概念。

需要考慮的問題大致有以下兩個方面:

產品中的哪些功能和模塊應該放在安全區?(這部分代碼往往是核心且精簡,且經過安全審查的,安全區的內容不允許非安全區的代碼觸碰);

哪些功能應該放在非安全區?(這樣放在非安全區中的代碼,即使出現安全漏洞(例如棧溢出漏洞等等)后被攻擊,MCU的安全區中的資源和外設也無法被攻擊者利用)。

令人頭疼的HardFault

對于MCU工程師,TrustZone是一個比較新的技術,在開發調試過程中,由于TrustZone配置問題,時常遇到各種意料之外的HardFault,我們也經常調侃,這個TrustZone也太安全了,連我們自己都進不去。

其實這種問題往往是由于在開發階段,我們實際的行為和我們對TrustZone的劃分不一致。

平常我們認為正常的行為與操作,對于TrustZone來說,已經越界違規了,這就會使TruztZone觸發HardFault,并阻止違規行為。

在這種情況下,我們就需要找到導致HardFault的原因,并調整對于TrustZone的配置。

注:TrustZone相關的故障會觸發SecureFault異常。在芯片上電后的默認情況下,SecureFault異常并沒有被使能,因此,此異常會被“升級”為HardFault。在通常情況下,建議使用默認的設置,因為HardFault擁有更高的中斷優先級,可以使故障在第一時間被響應。

獲取違規操作的蛛絲馬跡

Cortex M33內核本身在SAU中提供了兩個寄存器:SFSR(Secure FaultStatus Register,安全故障狀態寄存器)和SFAR(Secure Fault Address Register,安全故障地址寄存器)。

SFSR寄存器用于指示出現錯誤的類型,例如非安全區試圖訪問安全區,從安全區到非安全區的非法跳轉等。

SFAR寄存器用于指示出現錯誤的內存地址。

看起來這兩個寄存器就足以幫助我們查到問題的根源了。但是,有時候,我們從這兩個寄存器拿到了錯誤的原因和地址,仔細檢查后發現無論是安全區還是非安全區的程序,都沒有顯式的訪問這個地址。

這是由于MCU系統愈發復雜,總線上除了M33內核之外,還有許許多多的其他的外設,例如DMAUSB等等。肇事者不一定是M33內核,還有可能是其他的外設,例如DMA。

下面是一種常見的事故:被劃分為非安全的DMA在工作中訪問了安全區的地址或外設,違反了TrustZone的配置,造成了HardFault。

恩智浦的MCU在SOC層面提供了一個安全AHB控制器,能夠幫我們偵查肇事現場,找出肇事者的蛛絲馬跡。

其實原理很簡單,安全AHB控制器提供了三個寄存器,SEC_VIO_INFO_VALID,SEC_VIO_MISC_INFO和SEC_VIO_ADDR。

SEC_VIO_INFO_VALID用來指示肇事現場,這個寄存器中存儲了肇事現場的AHB 的端口號(port number),端口號與外設的對應關系參見用戶手冊的”Memory map overview”章節。

每一個AHB端口都相應有一個SEC_VIO_MISC_INFO寄存器,用來指示肇事的信息,例如違規操作是讀操作引起的還是寫操作引起的等等,最重要的是會指出肇事者的身份:

每個AHB端口還有一個SEC_VIO_ADDR,用來指示肇事現場的地址。

有了上述信息,我們就捉到了真正的肇事者。在開發階段,我們就可以利用這些信息去調整我們的TrustZone的配置。

更進一步

當然,上述功能不只能在開發階段幫我們排查HardFault。我們也可以利用這個機制在產品出廠之后為我們提供防御措施。

產品出廠后,當我們檢測到由TrustZone產生的HardFault的原因之后,可以將其記錄,以便于后續分析。如果設備有聯網能力,可以將其傳輸至服務器。利用這些信息我們可以發現產品的哪些模塊受到了攻擊,方便我們后續針對性地進行OTA升級。云端和設備本地也可在此時檢測鏡像以及存儲介質的完整性,以檢查程序和存儲介質是否被惡意篡改。

小結

綜上所述,利用SAU和安全AHB控制器調查HardFault的方法并不復雜,NXP的MCUXpresso SDK也提供了一個完整的demo。

以LPC55S69為例,demo的路徑如下:SDKoardslpcxpresso55s69 rustzone_examplessecure_faults。

這個demo中,人為制造了幾種TrustZone觸發HardFault的案例,在產生HardFault后,使用上文描述的方法,處理相關寄存器并打印事故信息。

通常來說,在開發階段,我們可以參考demo中HardFault的處理代碼,按需移植到自己的工程中。

責任編輯:haq

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

    關注

    146

    文章

    17977

    瀏覽量

    366649
  • 控制器
    +關注

    關注

    114

    文章

    17100

    瀏覽量

    184219
  • 恩智浦
    +關注

    關注

    14

    文章

    5980

    瀏覽量

    116561

原文標題:調試TrustZone時,如何處理HardFault

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    車載整機控制器 工程機械主機控制器#碩博電子#國產控制器

    控制器
    長沙碩博電子科技股份有限公司
    發布于 :2025年05月26日 09:09:02

    MAXQ1741用于磁卡讀卡的DeepCover安全控制器技術手冊

    DeepCover 嵌入式安全方案采用多重先進的物理安全機制保護敏感數據,提供最高等級的密鑰存儲安全保護。 DeepCover安全控制器
    的頭像 發表于 05-15 09:48 ?232次閱讀
    MAXQ1741用于磁卡讀卡<b class='flag-5'>器</b>的DeepCover<b class='flag-5'>安全</b>微<b class='flag-5'>控制器</b>技術手冊

    工程機械控制器廠家 控制器國產替代 #國產控制器#控制器廠家#控制器品牌

    控制器
    長沙碩博電子科技股份有限公司
    發布于 :2025年04月29日 14:15:05

    工程機械控制器如何選型?控制器選型指南 #控制器 #車載控制器 #整車控制器 #控制器選型

    控制器
    長沙碩博電子科技股份有限公司
    發布于 :2025年03月14日 10:54:24

    在STM32微控制器中實現數據加密的方法

    在STM32微控制器中實現數據加密,可以通過多種方法和技術來確保數據的安全性。以下是一些常見的方法和步驟: · 使用內置加密庫: · · STM32提供了專門的加密庫STM32Cryp
    發表于 03-07 07:30

    Y1620工程機械主機控制器 車載智能控制器 CAN總線 #工程機械控制器 #整車控制器 #車載控制器

    控制器
    長沙碩博電子科技股份有限公司
    發布于 :2025年02月10日 15:32:21

    溫度控制器上下限設定,溫度控制器上下限怎么調

    在現代工業自動化、家庭溫控以及各類需要精確溫度控制的場合中,溫度控制器發揮著至關重要的作用。溫度控制器的上下限設定是確保其正常工作、實現精準溫控的關鍵步驟。本文將詳細介紹溫度控制器上下
    的頭像 發表于 01-29 15:30 ?6914次閱讀

    溫度控制器參數含義,溫度控制器參數設置方法

    在現代工業自動化和溫控系統中,溫度控制器扮演著至關重要的角色。它通過對環境溫度的精確監測與調控,確保生產過程的穩定性和產品質量。然而,要充分發揮溫度控制器的效能,了解其參數含義并掌握正確的設置方法顯得尤為重要。本文將深入探討溫度
    的頭像 發表于 01-29 15:27 ?4750次閱讀

    電機控制器故障排除方法

    電機控制器故障排除方法 1. 故障診斷前的準備 在進行故障排除之前,確保您已經做好了以下準備: 安全措施 :關閉電源,確保電機和控制器處于斷電狀態,以防止觸電或設備損壞。 工具和設備
    的頭像 發表于 01-22 09:25 ?1680次閱讀

    控制器解碼的使用方法

    控制器解碼是一種用于解析和執行控制信號的設備,廣泛應用于工業自動化、機器人技術、航空航天等領域。它通常與傳感、執行等設備配合使用,以實
    的頭像 發表于 09-30 14:24 ?1592次閱讀

    usb主機控制器位于ahp總線上嗎

    關于“USB主機控制器是否位于AHP總線上”的問題,首先需要明確幾個概念: USB主機控制器 :在USB系統中,主機控制器控制所有USB設備通信的關鍵組件。它負責組織數據傳輸,管理U
    的頭像 發表于 09-25 09:20 ?629次閱讀

    風機溫度控制器的調整方法

    風機溫度控制器是一種用于控制風機運行溫度的設備,它能夠根據設定的溫度范圍自動調節風機的運行狀態,以保持設備在最佳工作溫度下運行。調整風機溫度控制器方法需要根據具體的設備型號和功能來操
    的頭像 發表于 09-20 14:53 ?1924次閱讀

    國產控制器廠家 整車控制器 以太網控制器 CAN控制器 國產化替代

    控制器
    長沙碩博電子科技股份有限公司
    發布于 :2024年09月03日 09:15:51

    利用TSN以太網特性改善工業以太網控制器的時序

    電子發燒友網站提供《利用TSN以太網特性改善工業以太網控制器的時序.pdf》資料免費下載
    發表于 08-30 10:53 ?0次下載
    <b class='flag-5'>利用</b>TSN以太網特性改善工業以太網<b class='flag-5'>控制器</b>的時序

    車載智能控制器 工程機械控制器 CAN總線控制器 碩博電子 #控制器 #can總線 #國產化替代

    控制器總線
    長沙碩博電子科技股份有限公司
    發布于 :2024年08月29日 10:43:57
    主站蜘蛛池模板: 国产成人教育视频在线观看 | 天天做天天爱天天综合网 | 亚洲精品资源 | 91欧美精品激情在线观看 | 男人性天堂 | 欧美日韩精品乱国产538 | 五月婷婷激情六月 | 字幕网中文aⅴ资源站 | 国产视频二区 | 久久噜噜噜久久亚洲va久 | 午夜免费福利影院 | 亚州一级毛片 | 亚洲欧美精品一区二区 | 国产精品国产三级国产在线观看 | 午夜大片在线观看 | 久久久午夜精品理论片 | 国产在线成人一区二区 | 男女午夜免费视频 | www.亚洲5555.com | 日本成片免费高清 | 1024国产你懂的日韩 | 你懂的国产 | www懂爱| 欧美极品在线视频 | 亚洲人成亚洲人成在线观看 | 在线观看不卡一区 | 人人干视频在线观看 | 国产免费人成在线看视频 | 亚洲国产成人久久99精品 | 特级无码毛片免费视频尤物 | 欲色影视香色天天影视来 | 色综合视频在线 | 狠狠色丁香婷婷第六色孕妇 | 性欧美www | 欧美午夜视频在线 | 国产性老妇女做爰在线 | 久久sese| 99插插插| 人人澡人人射 | 一级特黄aa毛片免费观看 | 三级理论在线观看 |