《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > ARMv8-M平臺開發安全軟件的建議

ARMv8-M平臺開發安全軟件的建議

2017-01-10

  ARM TrustZone 是針對片上系統(SoC)設計的系統級安全技術,它基于硬件,內置于CPU和系統內核,為半導體芯片設計師設計設備安全性能(如可信根)量身打造。TrustZone可用于任何基于ARM Cortex-A的系統,隨著全新Cortex-M23和Cortex-M33處理器的發布與升級,Cortex-M也已經支持該技術。從尺寸最小的微控制器(搭載針對Cortex-M處理器優化的TrustZone技術),到高性能處理器(搭載針對Cortex-A處理器優化的TrustZone技術),設計師們終于可以從設計初始就著手打造出色的安全性能了。

1.png

  TrustZone安全技術將非可信資源和可信資源隔離

  TrustZone技術的核心理念是將可信資源與非可信資源在硬件上實現隔離。在處理器內部,軟件只能安裝于安全或非安全域其中一處;在兩個域間切換則必須經過Cortex-A處理器的軟件(后文稱安全監視器)和Cortex-M處理器的硬件(核心邏輯)處理才能執行。這種將安全(可信)域和非安全(非可信)域隔離理念的實現不僅涉及CPU,還涵蓋存儲、片上總線系統、中斷、周邊設備接口和SoC上的軟件。

  針對ARMv8-M處理器(Cortex-M)的TrustZone技術

  ARMv8-M架構將TrustZone技術拓展至Cortex-M級系統,實現了對所有成本點的安全防護。為Cortex-M度身設計的TrustZone技術可以保護固件和周邊設備,并為安全啟動、可信更新以及可信根執行實現隔離。該架構具備嵌入式解決方案應有的確定性實時響應能力。同時,因為安全與非安全域間的上下文切換在硬件中完成,所以更快實現轉換及更高的電源效率。該架構無需安裝任何安全監視器軟件,因為處理器本身就能完成切換任務,不僅可以減少存儲足跡,還能降低代碼執行的動態功率。

  在繼續討論編程之前,我們先介紹以下幾個概念:

  1.地址定義安全

  2.新增執行狀態

  3.跨域調用

  概念1:地址定義安全

  第一個需要了解的概念是:地址定義安全,即每一個地址都與一個特定的安全狀態相關。Cortex-M處理器采用全新引入的安全屬性單元來檢查地址的安全狀態。根據整體SoC設計,系統級接口可以重寫該屬性。選擇此狀態后,該地址還會通過一個存儲保護單元(視系統配置而定)。

2.png

  地址定義安全圖解

  概念2:新增執行狀態

  第二個概念是“新增執行狀態”。ARMv7-M和ARMv6-M架構定義了兩種執行模式:管理者模式(handler mode)和線程模式(thread mode)。管理者模式是特權模式,可以接入SoC的所有資源;而線程模式則可以設定為特權或非特權兩種。憑借TrustZone安全拓展技術,我們可以對處理器模式進行鏡像處理,構造安全和非安全兩種狀態,每種狀態都各自包含管理者模式和線程模式。安全狀態和處理器模式是正交的,因此可形成4種狀態和模式的組合。在安全的存儲器中運行軟件時,處理器自動設定為安全狀態;反之,在非安全存儲器中運行軟件時,處理器自動設定為非安全狀態。這種設計消除了本來用于管理狀態切換的安全監控軟件的必要性,從而實現減少存儲足跡和功耗的目的。

3.png

  新增正交態

  概念3:跨域調用

  ARMv8-M為實現Cortex-M的性能專門設計,具備確定性實時運行功能。換言之,只要遵守以預先設定的安全狀態接入點為基礎的特定規則,任何狀態下的任何功能都可以直接調用其他狀態下的任何其他功能。此外,每個狀態都有一個獨特的堆棧集和對應的堆棧指示器,用來保護安全域資產。由于無需使用API層管理調度,成本大幅減少?;陬A先設定的接入點,調度可以直接讀取被調函數。

4.png

  跨域調用

  應用案例簡述

  如下圖表介紹了一個使用案例簡述。該環境下,用戶應用和I/O驅動都處于非安全狀態,而系統的啟動代碼和通訊堆棧則處于安全狀態。用戶應用調度并轉入通訊堆棧以傳輸、接收數據,而該堆棧將使用非安全狀態的I/O驅動來完成界面上的數據傳輸和接收。

5.png

  所有相似系統環境下,示例軟件配置都可以得益于TrustZone技術的安全狀態功能:

  非安全應用不能接入安全資源,除非通過事先定義好的安全服務功能接入點

  安全固件既可以接入安全存儲,也可以進入非安全存儲

  安全和非安全代碼可以用不同的定時器制定獨立的時間進度

  每根中斷線都可以設置為安全或非安全。安全軟件和非安全軟件的中斷向量表也可以分開。

  盡管處理器硬件可以為安全軟件提供核心保護,但安全軟件依然需要謹慎的編寫,才能確保整個系統的安全。以下是軟件開發商在設計安全軟件時必須牢記的三個內容:

  使用最新的ARM C語言拓展(ACLE)技術

  驗證非可信指示

  為異步非安全存儲修改專門設計

  建議1:使用最新的ARM C語言拓展技術

  經過優化,ARMv8-M的TrustZone技術引入了全新指令,支持安全狀態轉換。軟件開發商再也無需創建封裝器來生成這些指令了,他們現在可以使用ARM C語言拓展功能(ACLE)中定義的全新編譯器,讓軟件工具理解上述功能的安全使用,并生成所需的最佳代碼。ACLE功能由多家編譯器廠商實現并支持,代碼非常便捷易用。

  比如說,在創建可以從非安全狀態調度的安全API時,應該使用一個名為“cmse_nonsecure_entry”的全新功能屬性來做函數聲明。安全狀態調度功能使用結束時,處理器中的寄存器仍可能保留一些秘密信息。憑借正確的功能屬性,編譯器便可自動插入代碼,清空R0-R3、R12和應用程序狀態寄存器(APSR)中仍保留秘密信息的寄存器,但是寄存器將結果返還給非安全軟件的情況除外。寄存器R4到R11有不同的處理方式,因為它們的內容在函數邊界保持不變。如果它們的值在函數執行過程中改變,那么就必須在返還非安全調度功能之前改回原值。

  建議2:驗證非可信指標

  有時候,非安全代碼會提供錯誤的設計指示,試圖接入安全存儲。為了徹底杜絕這一可能,ARMv8-M引入了一個全新指令——測試目標(TT)指令。TT指令可以將一個地址的安全屬性返還,安全軟件即可由此判斷該指示指向安全還是非安全地址。

  為了提高指示檢查效率,每個存儲區都有一個安全配置定義的區域號。軟件可以用區域號判斷相鄰的存儲區是否具有類似的安全屬性。

  TT指令將來自地址值的安全屬性和區域號(還有MPU的區域號)返還原軟件。如果在存儲段的起始和終止地址上使用TT指令,并確定兩個地址都處于同一個區域號內時,軟件便可迅速判斷存儲范圍(如數據陣列或數據結構)是否完全位于非安全空間。

6.png

  檢查指示是否指向安全的區域邊界

  使用上述機制,憑借API調度進安全側的安全代碼即可判斷,非安全軟件區域發起的指示請求是否具備符合該API的安全屬性。通過這種方法,我們可以阻止非安全軟件在安全軟件中使用API來讀取或破壞安全信息。

  建議3:為異步非安全存儲修改專門設計

  非安全中斷服務程序可以修改正在被安全軟件處理的非安全數據。因此,已經通過安全API驗證的輸入數據可以在經過驗證之后被一個非安全的ISR更改。避免這種情況的一個方法就是在安全存儲中為那份輸入數據建立一個本地副本,并用安全副本進行處理(包括輸入數據的驗證)以避免非安全存儲讀取;無法創建該副本時(如在特定存儲區域中處理大量數據),則可以選擇另一種方法,即對安全屬性單元進行編程,以確保該存儲區域的安全。

  總結

  確保整個系統的安全性并阻止安全數據泄漏至非安全側,是安全軟件開發商的責任。為實現這一目標,我們向安全軟件開發商介紹TrustZone 技術3大關鍵理念與3個重要使用建議——保護調度函數寄存器數據的ACLE技術、驗證指示的TT指令;最后一點開發商也必須牢記,非安全側可能會通過干擾安全側來修改數據。欲知更多詳情,請點此瀏覽,為協助您在ARMv8-M處理器上開發安全固件,我們精選了相關文件以供參考。


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美电影在线免费观看网站| 中文在线资源观看网站视频免费不卡| 久久成人在线| 女同性一区二区三区人了人一| 亚洲精品视频免费在线观看| 99精品福利视频| 国产精品www| 欧美激情精品久久久六区热门| 欧美性猛交视频| 久久成人免费网| 性色av一区二区三区红粉影视| 亚洲精品永久免费| 免费看黄裸体一级大秀欧美| 国产精品美女www爽爽爽视频| 国产精品色婷婷久久58| 国产精品久久久久久久久搜平片| 亚洲精美视频| 一区二区三区你懂的| 亚洲国内高清视频| 欧美一区免费视频| 欧美精品一区三区在线观看| 免费不卡视频| 亚洲黑丝在线| 依依成人综合视频| 欧美中文字幕久久| 欧美日韩综合网| 老鸭窝亚洲一区二区三区| 久久经典综合| 国产日韩精品一区二区三区在线| 亚洲影院免费观看| 久久艳片www.17c.com| 国产欧美一区视频| 欧美精品一线| 最新高清无码专区| 国产精品羞羞答答xxdd| 欧美久久婷婷综合色| 99国产精品99久久久久久粉嫩| 99在线热播精品免费99热| 亚洲一区精品电影| 亚洲国产成人久久综合一区| 亚洲免费在线视频| 欧美精品久久久久久久免费观看| 欧美成人午夜免费视在线看片| 国内偷自视频区视频综合| 久久精品亚洲| 国产网站欧美日韩免费精品在线观看| 亚洲综合精品| 亚洲女同性videos| 加勒比av一区二区| 中文av一区特黄| 一本一本久久a久久精品综合妖精| 久久激情视频免费观看| 国产在线日韩| 国产欧美在线观看一区| 欧美一级理论性理论a| 欧美日韩国产在线看| 亚洲愉拍自拍另类高清精品| 国产亚洲网站| 国色天香一区二区| 久久综合九色综合网站| 久久亚洲一区二区| 老司机午夜精品视频| 国内精品免费午夜毛片| 一区二区三区日韩| 一区二区三区视频在线播放| 国产资源精品在线观看| 亚洲裸体在线观看| 欧美韩日高清| 久久综合九色| 性色av一区二区怡红| 亚洲黄色小视频| 久久―日本道色综合久久| 久久一区欧美| 欧美激情四色| 亚洲人成小说网站色在线| 蜜臀av一级做a爰片久久| 久久九九久精品国产免费直播| 久久天堂国产精品| 久久av二区| 欧美日韩精品系列| 国产午夜精品在线观看| 欧美三日本三级少妇三2023| 狠狠色狠狠色综合日日tαg| 一区二区三区视频在线看| 日韩视频在线观看免费| 国内精品久久国产| 亚洲一区影音先锋| 亚洲专区欧美专区| 一区二区电影免费观看| 国产精品久久久久久av下载红粉| 一区二区动漫| 亚洲片国产一区一级在线观看| 99热在这里有精品免费| 欧美日韩情趣电影| 欧美国产一区视频在线观看| 欧美一区二区三区播放老司机| 国产精品久久久久久久第一福利| 黄色精品免费| 欧美性感一类影片在线播放| 亚洲欧美日韩第一区| 国产精品美女www爽爽爽视频| 蜜桃av噜噜一区| 亚洲视频在线播放| 合欧美一区二区三区| 蜜桃久久精品乱码一区二区| 亚洲欧美日韩中文播放| 欧美色大人视频| 欧美高清视频在线观看| 国产九区一区在线| 老司机一区二区| 久久国产精品色婷婷| 另类酷文…触手系列精品集v1小说| 在线日韩视频| 欧美成人午夜激情| 亚洲一区高清| 亚洲综合导航| 国户精品久久久久久久久久久不卡| 国产欧美亚洲一区| 一本色道精品久久一区二区三区| 久久激情五月丁香伊人| 国产精品热久久久久夜色精品三区| 国产一区二区三区在线播放免费观看| 亚洲成色777777在线观看影院| 国产日韩精品一区二区三区在线| 国产日韩欧美在线视频观看| 亚洲福利在线看| 欧美午夜一区| 久久久久国产一区二区三区四区| 国产午夜亚洲精品理论片色戒| 久久精品国产精品亚洲综合| 久久综合影视| 国产精品黄页免费高清在线观看| 在线观看成人小视频| 影音先锋久久| 国产精品国产三级国产aⅴ入口| 国产精品无码永久免费888| 国产精品一区二区三区成人| 中文亚洲字幕| 免费久久99精品国产| 欧美一区2区三区4区公司二百| 国产精品成人一区二区网站软件| 欧美日韩成人一区| 国产精品theporn| 欧美激情中文字幕一区二区| 亚洲欧美日韩一区| 免费观看一区| 国产一区二区三区四区五区美女| 老牛国产精品一区的观看方式| 国产精品网红福利| 欧美日本在线视频| 性色一区二区| 欧美日韩在线不卡| 欧美一区二区黄色| 亚洲美女av黄| 亚洲激情在线播放| 国产精品一区在线观看| 国产精品毛片高清在线完整版| 亚洲另类一区二区| 国产精品日韩欧美一区二区| 国产午夜久久久久| 久久久之久亚州精品露出| 国产精品一区二区久激情瑜伽| 亚洲欧洲精品成人久久奇米网| 伊人婷婷欧美激情| 欧美日韩中文在线| 亚洲欧美日本在线| 欧美日韩国产区| 欧美无乱码久久久免费午夜一区| 久久久久国产一区二区三区| 米奇777超碰欧美日韩亚洲| 激情文学一区| 国产日韩欧美一二三区| 久久精品国产久精国产爱| 黄色日韩在线| 亚洲国产成人久久综合一区| 国产在线精品自拍| 女女同性女同一区二区三区91| 蜜桃av噜噜一区| 极品裸体白嫩激情啪啪国产精品| 欧美亚洲动漫精品| 国产精品伦一区| 可以看av的网站久久看| 国产精品久久久久久五月尺| 欧美日韩和欧美的一区二区| 欧美国产视频一区二区| 欧美四级剧情无删版影片| 欧美日韩精品一区视频| 欧美特黄a级高清免费大片a级| 一区二区三区久久久| 欧美一区二区三区视频在线| 久久久99爱| 国产精品伦子伦免费视频| 亚洲国产另类久久久精品极度| 亚洲永久免费| 欧美精品一区二区三区在线看午夜| av72成人在线| 欧美视频国产精品| 国产中文一区| 中文av字幕一区| 亚洲一区二区视频| 美女任你摸久久| 欧美福利视频在线观看| 国产嫩草一区二区三区在线观看| 亚洲精品在线免费| 精品成人一区二区三区| 黄色成人在线观看| 国产一级精品aaaaa看| 99re66热这里只有精品3直播| 久久精品2019中文字幕| 在线视频精品| 欧美乱人伦中文字幕在线| 欧美日韩播放| 麻豆精品在线播放| 国产欧美一区二区精品性色| 亚洲免费激情| 国产日韩欧美在线播放| 欧美成ee人免费视频| 在线成人激情视频| 欧美网站在线| 午夜免费在线观看精品视频| 国产女主播一区| 亚洲欧洲一区二区天堂久久| 欧美色另类天堂2015| 亚洲一级免费视频| 亚洲精品欧美极品| 亚洲欧美中文在线视频| 一区免费视频| 亚洲欧美另类综合偷拍| 麻豆精品一区二区av白丝在线| 狠狠做深爱婷婷久久综合一区| 亚洲精品视频在线看| 国产精品va| 欧美视频一区二区| 久久se精品一区二区| 久久精品男女| 免费成人av| 亚洲欧美精品伊人久久| 91久久精品美女| 欧美精品国产精品日韩精品| 亚洲欧美福利一区二区| 一区二区三区日韩| 久久精品夜色噜噜亚洲a∨| 老司机午夜精品视频| 国产欧美日韩亚洲一区二区三区| 欧美激情一区在线| 欧美日韩国产不卡在线看| 欧美亚州韩日在线看免费版国语版| 国产一区二区三区日韩| 久久天堂精品| 欧美人与性禽动交情品| 一区二区三区四区五区精品| 国产精品专区一| 久久久无码精品亚洲日韩按摩| 亚洲国产欧美一区二区三区丁香婷| 国产精品入口福利| 韩国一区二区在线观看| 午夜在线播放视频欧美| 亚洲精品看片| 久久艳片www.17c.com| 欧美在线观看网址综合| 欧美日韩亚洲系列| 欧美一区二区三区免费观看| 午夜精品一区二区三区在线| 欧美在线视频一区二区三区| 国产综合久久久久影院| 亚洲欧美日韩另类精品一区二区三区| 亚洲欧美春色| 亚洲欧美电影在线观看| 午夜亚洲一区| 亚洲国产免费| 在线午夜精品| 欧美久久成人| 亚洲影院在线观看| 国产女精品视频网站免费| 亚洲欧美日韩国产综合在线| 亚洲国产日韩欧美综合久久| 亚洲精品少妇30p| 国产免费成人| 国产精品第十页| 亚洲欧美日韩国产一区二区| 亚洲欧美日韩一区二区在线| 久久精品一本| 妖精视频成人观看www| 欧美日韩国产首页| 亚洲国产欧美日韩精品| 欧美日韩免费网站| 亚洲一区二区三区三| 欧美三级日本三级少妇99| 久久一区欧美| 一片黄亚洲嫩模| 久久婷婷国产综合精品青草| 国产精品国产a级| 免费在线播放第一区高清av| 免费高清在线一区| 亚洲欧美日韩一区二区三区在线观看| 中文国产亚洲喷潮| 久久精品日韩欧美| 亚洲黄一区二区三区| 国产精品视频网| 久久全球大尺度高清视频| 午夜精品福利一区二区三区av| 国产精品观看| 久久免费黄色| 亚洲欧洲99久久| 欧美日韩欧美一区二区| 亚洲精品一区二区三区婷婷月| 欧美天天视频| 欧美少妇一区二区| 亚洲欧美一区二区三区极速播放| 欧美电影电视剧在线观看| 在线观看久久av| 99精品欧美一区二区蜜桃免费| 国产亚洲精品综合一区91| 亚洲人成精品久久久久| 亚洲国产精品一区二区尤物区| 国产精品一区二区在线观看网站| 一区二区三区国产精华| 日韩视频在线观看国产| 久久久之久亚州精品露出| 国产亚洲电影| 国产精品日韩一区二区| 国产真实精品久久二三区| 夜久久久久久| 欧美r片在线| 一区二区久久| 免费在线看成人av| 亚洲欧美区自拍先锋| 日韩网站在线看片你懂的|