999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

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

2017-03-31 01:23:56ARM公司
單片機與嵌入式系統應用 2017年3期
關鍵詞:定義設計

ARM公司

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

ARM公司

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

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

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

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

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

在繼續討論編程之前,我們先介紹以下幾個概念:地址定義安全;新增執行狀態;跨域調用。

概念1:地址定義安全

圖2 地址定義安全圖解

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

概念2:新增執行狀態

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

圖3 新增正交態

概念3:跨域調用

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

圖4 跨域調用

應用案例簡述

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

圖5 使用案例

所有相似系統環境下,示例軟件配置都可以得益于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指令,并確定兩個地址都處于同一個區域號內時,軟件便可迅速判斷存儲范圍(如數據陣列或數據結構)是否完全位于非安全空間。

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

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

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

總 結

猜你喜歡
定義設計
永遠不要用“起點”定義自己
海峽姐妹(2020年9期)2021-01-04 01:35:44
定義“風格”
何為設計的守護之道?
現代裝飾(2020年7期)2020-07-27 01:27:42
《豐收的喜悅展示設計》
流行色(2020年1期)2020-04-28 11:16:38
瞞天過海——仿生設計萌到家
藝術啟蒙(2018年7期)2018-08-23 09:14:18
設計秀
海峽姐妹(2017年7期)2017-07-31 19:08:17
有種設計叫而專
Coco薇(2017年5期)2017-06-05 08:53:16
成功的定義
山東青年(2016年1期)2016-02-28 14:25:25
修辭學的重大定義
當代修辭學(2014年3期)2014-01-21 02:30:44
山的定義
公務員文萃(2013年5期)2013-03-11 16:08:37
主站蜘蛛池模板: 国产91在线|日本| 99久久精品免费看国产免费软件| 在线播放国产99re| 国产三级视频网站| 中文字幕 欧美日韩| 91在线高清视频| 91精品久久久久久无码人妻| 国产精品刺激对白在线| 久久人人爽人人爽人人片aV东京热 | 国产成人凹凸视频在线| 亚洲国产成人精品无码区性色| 国产91透明丝袜美腿在线| 国产精品欧美激情| 亚洲国产日韩在线观看| 91极品美女高潮叫床在线观看| 国产毛片片精品天天看视频| 天堂网亚洲综合在线| 午夜欧美在线| 欧美激情综合| 91无码人妻精品一区| 97在线观看视频免费| 欧美日韩激情在线| jizz在线观看| 久久精品日日躁夜夜躁欧美| 综合五月天网| 国产精品免费电影| 九九热精品在线视频| 亚洲最新地址| 亚洲欧美日本国产综合在线| 91精品网站| 国产精品永久久久久| 欧美笫一页| 久久久久亚洲AV成人网站软件| 久久久久亚洲Av片无码观看| 欧美日韩在线亚洲国产人| 日韩精品毛片| 新SSS无码手机在线观看| 色爽网免费视频| 亚洲水蜜桃久久综合网站| 亚洲成人精品在线| 亚洲精品中文字幕午夜| 国产精品一区二区无码免费看片| 国产一区二区精品高清在线观看| 夜夜操天天摸| av在线无码浏览| 99在线国产| 亚洲最大情网站在线观看 | 六月婷婷精品视频在线观看| 天天综合色网| 欧美不卡在线视频| Jizz国产色系免费| 国产精品成人第一区| 国产成人精品在线1区| 伊伊人成亚洲综合人网7777| 国产精品微拍| 日韩欧美中文在线| 国产成人高清亚洲一区久久| 成人免费一级片| 国产福利免费视频| 丝袜国产一区| 国产激情无码一区二区APP| 嫩草在线视频| 亚洲无码精品在线播放 | 久久这里只有精品8| 国产精品无码AV中文| 在线免费看片a| 亚洲精品在线观看91| 国产主播福利在线观看| 美女被操黄色视频网站| 国产亚洲欧美另类一区二区| 亚洲一区二区日韩欧美gif| 國產尤物AV尤物在線觀看| 欧美日本在线观看| 欧美成人在线免费| 午夜久久影院| 五月天福利视频 | 亚洲免费毛片| 伦精品一区二区三区视频| 国产综合亚洲欧洲区精品无码| 青青青国产视频手机| 91娇喘视频| 夜夜拍夜夜爽|