主頁 > 作業系統 > ARM TrustZone白皮書部分閱讀

ARM TrustZone白皮書部分閱讀

2022-11-05 06:11:39 作業系統

嵌入式系統安全的一些解決方法及缺陷

  1. 外部硬體安全模塊:在主SoC之外包含一個專用的硬體安全模塊或可信元件,e.g. 手機的SIM卡,隔離僅限于可以從非易失性存盤器運行的相對靜態程式
  2. 內部硬體安全模塊:管理加密操作和密鑰存盤的硬體模塊;通用的處理引擎,放在主處理器旁邊,它使用自定義硬體邏輯來防止對敏感資源的未經授權的訪問,隔離僅限于加密密鑰材料
  3. 軟體虛擬化:高度可信的管理層(稱為hypervisor)以通用處理器的特權模式運行,hypervisor使用記憶體管理單元(MMU)分離運行在其上的多個獨立軟體平臺,將每個平臺放在由hypervisor軟體控制的虛擬機中,隔離僅限于實作hypervisor的處理器

TrustZone硬體安全方案

  1. 解決問題:上述的其他安全方案只能保護系統中受限制部分的某些資產
  2. 設計目標:一種在整個系統設計中擴展安全基礎設施的硬體架構,
  3. 架構特點:并未對某個專用硬體模塊中的資產進行保護,而是使系統的任何部分都變得安全,從而實作了包括功能單元和除錯基礎框架在內的端到端安全解決方案,

TrustZone硬體架構

  1. 安全目標:構建一個可編程環境,使絕大多數資產的機密性和完整性都能免受特定攻擊,
  2. 實作原理:
    • 劃分SoC的所有硬體和軟體資源,使其存在于兩個世界中的一個:安全子系統的安全世界,以及其他一切的正常世界,AMBA3 AXI? 總線提供的硬體邏輯確保正常世界組件不能訪問任何安全世界的資源,從而在兩者之間建立一個強大的安全邊界,敏感資源放在安全世界,魯棒性軟體在安全世界處理器核上運行,
    • 在一些ARM處理器核心中實作擴展,這些附加功能使單個物理處理器核心能夠以時間切片的方式安全高效地執行來自正常世界和安全世界的代碼,
    • 具有安全意識的除錯基礎框架,它可以控制對安全世界除錯的訪問,而不影響正常世界的除錯可見性,

TrustZone系統架構

  1. AMBA3 AXI 系統總線:為主系統總線上的每個讀寫通道添加額外的控制信號(非安全位/NS位),總線主設備設定這些信號
  2. AMBA3 APB外圍設備總線:TrustZone體系結構最有用的特性之一是能夠保護外圍設備
  3. 記憶體別名使用:主設備對從設備進行安全訪問,非安全的slave接受安全事務,但slave將這些訪問視為不安全的,在這種設計下,硬體必須支持地址空間別名:相同的記憶體位置在地址映射中顯示為兩個不同的位置,一個安全,一個不安全,需要注意一致性問題

TrustZone處理器結構

  1. 每個處理器核心都提供了兩個虛擬核心,一個安全一個不安全,還有一個在他們之間進行背景關系切換的 monitor mode:

    image-20221101141410351

    發送到主系統總線上的NS位的值是由執行指令或資料訪問的虛擬內核的身份標識間接得出的,非安全的虛擬處理器只能訪問非安全系統資源,但安全虛擬處理器可以看到所有資源,

  2. world切換:這兩個虛擬處理器以時間切片的方式執行,在更改當前運行的虛擬處理器時,背景關系將通過名為monitor mode的新核心模式進行切換,物理處理器進入monitor mode時可以通過執行特定指令的軟體SMC指令硬體例外機制的子集進行觸發,如果處理器不在監控模式下,它正在執行的世界由系統控制協處理器CP15中安全配置暫存器(SCR)中的NS位指示;如果處于監控模式下,無論SCR NS位的值是多少,處理器總是在安全的世界中執行;但是如果SCR NS位設定為1,則對banked CP15暫存器的操作將訪問正常世界的副本,

  3. 一級保護記憶體系統:

    • MMU:TrsutZone中硬體提供兩個虛擬MMU,每個虛擬處理器一個,每個世界都有一組本地轉換表,使它們能夠獨立地控制虛擬地址到物理地址的映射,為在兩個世界之間實作高效的背景關系切換,arm處理器會標記TLB中的條目,TLB快取了地址轉換表的遍歷結果,并使用執行遍歷的世界的標識這允許非安全和安全條目在TLB中共存,從而加快切換,因為無需重繪TLB條目,
    • cache:目標是實作支持快取中兩種安全狀態的資料,這樣可以消除切換世界的時候需要重繪快取的需要,解決方法是處理器快取擴展了一個額外的標志位,該位錄訪問記憶體的事務的安全狀態,

    image-20221101144637436

    • 世界共享記憶體:允許安全世界直接訪問非安全快取,提供性能
  4. 安全中斷:直接向monitor捕獲IRQ和FIQ的能力(不需要任何一個世界的代碼干預)可以為安全中斷源創建一個靈活的中斷模型,ARM推薦的模型是使用IRQ作為非安全世界的中斷源,FIQ作為安全世界的中斷源,CPSR是存放的程式狀態暫存器

    image-20221101150353962

    啟用TrustZone的處理器實作了三組例外向量表,其中一個表用于正常世界,一個用于安全世界,另一個用于監視模式,

  5. 安全處理器:協處理器CP15中的敏感的配置選項,或全域應用于核心的配置選項,只能由安全世界軟體撰寫,非安全世界可以讀取,

  6. 多處理器系統:集群中的處理器可以配置為以對稱多處理(SMP)模式或非對稱多處理(AMP)模式執行,當處理器以SMP模式執行時,集群的Snoop控制單(SCU)將透明地將跨SMP處理器共享的資料保存在L1資料快取中,當處理器以AMP模式執行時,如果需要,執行軟體必須手動保持記憶體一致性,多處理器集群中的每個處理器都有一個正常世界和一個安全世界,每個虛擬處理器都可以獨立控制它們的MMU配置,

    image-20221101153158602

TrustZone除錯架構

  1. 處理器除錯:ARM處理器包含一個除錯控制信號,全域啟用或禁用對處理器的除錯器訪問,TrustZone除錯擴展將除錯訪問控制分成四種獨立可配置視圖,

  2. 系統除錯:ARM系統除錯解決方案是ARM Coresight?片上除錯和跟蹤技術,它為整個SOC提供了除錯和跟蹤解決方案,支持對多個處理器和其他系統組件進行除錯,可以從設備外工具和設備內組件訪問Coresight除錯基礎結構,

TrustZone軟體架構

  1. 軟體架構:

    • 安全作業系統:可以模擬多個獨立的安全世界應用程式的并發執行,運行時下載新的安全應用程式,以及完全獨立于正常世界環境的安全世界任務,使用MMU講安全世界記憶體劃分為多個用戶空間沙盒,只要安全世界內核軟體正確實作,多個安全任務可以不需要信任對方而同時運行,這種設計可以增強安全任務之間的邏輯隔離,

    image-20221101160534112

    • 同步庫:安全世界中的簡單代碼庫可以解決很多應用的任務,這個代碼庫完全由非安全世界作業系統的軟體呼叫來進行調度和管理,
    • 中間方法:在這兩個極端之間有一系列的選擇,例如,一個安全世界的多任務作業系統可以被設計成沒有專門的中斷源,因此可以由普通世界提供一個虛擬中斷,
  2. 安全啟動系統:所有安全世界軟體和潛在的正常世界軟體生成一個信任鏈,該信任鏈是從不易被篡改的信任根建立的,

    • 啟動流程:開機時啟用TrustZone的處理器在安全環境中啟動,這使得任何敏感的安全檢查都能在普通軟體有機會修改系統的任何方面之前運行,開機流程:執行基于ROM的引導加載程式 -> 閃存中的設備引導加載程式 -> 安全世界作業系統初始化 ->切換到非安全世界 -> 正常世界引導加載程式 -> 啟動正常的作業系統 -> 系統運行,

    image-20221101161908782

    • 安全方案:安全啟動方案將加密檢查添加到安全世界啟動行程的每個階段,此程序旨在維護執行的所有安全世界軟體映像的完整性,防止任何未經授權或惡意修改的軟體運行,
      • 密碼簽名協議:基于公鑰簽名演算法的協議,受信任的供應商使用他們的私鑰(PrK)生成要部署的代碼的簽名,并將其與軟體二進制檔案一起推送到設備上,設備包含供應商的公鑰(PuK),該公鑰可用于驗證二進制檔案是否未被修改,以及該二進制檔案是否由相關的受信任供應商提供,
      • 信任鏈:從一個隱式可信組件開始,在執行之前,可以對每個其他組件進行身份驗證,信任根位于ROM中,不容易被修改或替換,
      • 片內/片外安全世界:最簡單的防御shack攻擊的方法是將任何安全世界資源的執行放在SoC片內記憶體位置,如果代碼和資料從未暴露在SoC封裝之外,則很難窺探或修改資料值,
  3. 監控模式軟體:管理安全和非安全處理器狀態之間的切換,類似于背景關系切換,正常世界進入監控模式需通過以下例外實作:中斷、外部中止或通過SMC指令的顯式呼叫;從安全世界進入監控模式除了通過正常世界可用的例外機制外,還可以通過直接寫入CPSR來實作,

    • 背景關系切換:監視器保存的任何安全狀態都應該保存在安全記憶體的某個區域中,這樣正常世界就不會對其進行篡改,可以通過過SMC指令、惰性背景關系切換(僅在必要時保存協處理器的背景關系,而不是在每次作業系統背景關系切換或TrustZone世界切換時都保存)來實作世界切換,
  4. 安全軟體和多處理器系統:安全世界軟體實作可以選擇實作一個單處理器安全世界(不具備多處理能力),

    • 將安全世界的執行固定在一個特定的處理器上:在這種設計中,與安全世界通信的普通世界驅動程式通常需要使用處理器間通信將使用安全世界的請求路由到正確的處理器,此外,安全世界不使用的處理器上的監控軟體必須防止普通世界造成惡意的世界切換,

      image-20221101172157955

    • 讓安全世界在系統的多個處理器上遷移:但通過限制它使其在任何單一時間只在一個處理器上執行,

TrustZone API

  1. 定義了一個軟體介面,在富操作環境中運行的客戶端應用可以使用該介面與安全環境互動,該API主要是一個通信API,使客戶端能夠向安全服務發送命令請求,并使客戶端能夠有效地與所連接的服務交換資料,

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/527744.html

標籤:其他

上一篇:深入理解sed模式空間——sed 'n;p'

下一篇:在Python上發生例外后,for回圈不會繼續

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • CA和證書

    1、在 CentOS7 中使用 gpg 創建 RSA 非對稱密鑰對 gpg --gen-key #Centos上生成公鑰/密鑰對(存放在家目錄.gnupg/) 2、將 CentOS7 匯出的公鑰,拷貝到 CentOS8 中,在 CentOS8 中使用 CentOS7 的公鑰加密一個檔案 gpg -a ......

    uj5u.com 2020-09-10 00:09:53 more
  • Kubernetes K8S之資源控制器Job和CronJob詳解

    Kubernetes的資源控制器Job和CronJob詳解與示例 ......

    uj5u.com 2020-09-10 00:10:45 more
  • VMware下安裝CentOS

    VMware下安裝CentOS 一、軟硬體準備 1 Centos鏡像準備 1.1 CentOS鏡像下載地址 下載地址 1.2 CentOS鏡像下載程序 點擊下載地址進入如下圖的網站,選擇需要下載的版本,這里選擇的是Centos8,點擊如圖所示。 決定選擇Centos8后,選擇想要的鏡像源進行下載,此 ......

    uj5u.com 2020-09-10 00:12:10 more
  • 如何使用Grep命令查找多個字串

    如何使用Grep 命令查找多個字串 大家好,我是良許! 今天向大家介紹一個非常有用的技巧,那就是使用 grep 命令查找多個字串。 簡單介紹一下,grep 命令可以理解為是一個功能強大的命令列工具,可以用它在一個或多個輸入檔案中搜索與正則運算式相匹配的文本,然后再將每個匹配的文本用標準輸出的格式 ......

    uj5u.com 2020-09-10 00:12:28 more
  • git配置http代理

    git配置http代理 經常遇到克隆 github 慢的問題,這里記錄一下幾種配置 git 代理的方法,解決 clone github 過慢。 目錄 git配置代理 git單獨配置github代理 git配置全域代理 配置終端環境變數 git配置代理 主要使用 git config 命令 git單獨 ......

    uj5u.com 2020-09-10 00:12:33 more
  • Linux npm install 裝包時提示Error EACCES permission denied解

    npm install 裝包時提示Error EACCES permission denied解決辦法 ......

    uj5u.com 2020-09-10 00:12:53 more
  • Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包

    Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包。 18 (flaskApi) [root@67 flaskDemo]# yum -y install nginx 19 已加載插件:fastestmirror, langpacks 20 Loading ......

    uj5u.com 2020-09-10 00:13:13 more
  • Linux查看服務器暴力破解ssh IP

    在公網的服務器上經常遇到別人爆破你服務器的22埠,用來挖礦或者干其他嘿嘿嘿的事情~ 這種情況下正確的做法是: 修改默認ssh的22埠 使用設定密鑰登錄或者白名單ip登錄 建議服務器密碼為復雜密碼 創建普通用戶登錄服務器(root權限過大) 建立堡壘機,實作統一管理服務器 統計爆破IP [root ......

    uj5u.com 2020-09-10 00:13:17 more
  • CentOS 7系統常見快捷鍵操作方式

    Linux系統中一些常見的快捷方式,可有效提高操作效率,在某些時刻也能避免操作失誤帶來的問題。 ......

    uj5u.com 2020-09-10 00:13:31 more
  • CentOS 7作業系統目錄結構介紹

    作業系統存在著大量的資料檔案資訊,相應檔案資訊會存在于系統相應目錄中,為了更好的管理資料資訊,會將系統進行一些目錄規劃,不同目錄存放不同的資源。 ......

    uj5u.com 2020-09-10 00:13:35 more
最新发布
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:43:21 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:42:36 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:26:53 more
  • 設定Windows主機的瀏覽器為wls2的默認瀏覽器

    這里以Chrome為例。 1. 準備作業 wsl是可以使用Windows主機上安裝的exe程式,出于安全考慮,默認情況下改功能是無法使用。要使用的話,終端需要以管理員權限啟動。 我這里以Windows Terminal為例,介紹如何默認使用管理員權限打開終端,具體操作如下圖所示: 2. 操作 wsl ......

    uj5u.com 2023-04-19 09:25:49 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:19:04 more
  • Linux學習筆記

    IP地址和主機名 IP地址 ifconfig可以用來查詢本機的IP地址,如果不能使用,可以通過install net-tools安裝。 Centos系統下ens33表示主網卡;inet后表示IP地址;lo表示本地回環網卡; 127.0.0.1表示代指本機;0.0.0.0可以用于代指本機,同時在放行設 ......

    uj5u.com 2023-04-18 06:52:01 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:50 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:01 more
  • 你是不是暴露了?

    作者:袁首京 原創文章,轉載時請保留此宣告,并給出原文連接。 如果您是計算機相關從業人員,那么應該經歷不止一次網路安全專項檢查了,你肯定是收到過資訊系統技術檢測報告,要求你加強風險監測,確保你提供的系統服務堅實可靠了。 沒檢測到問題還好,檢測到問題的話,有些處理起來還是挺麻煩的,尤其是線上正在運行的 ......

    uj5u.com 2023-04-05 16:52:56 more
  • 細節拉滿,80 張圖帶你一步一步推演 slab 記憶體池的設計與實作

    1. 前文回顧 在之前的幾篇記憶體管理系列文章中,筆者帶大家從宏觀角度完整地梳理了一遍 Linux 記憶體分配的整個鏈路,本文的主題依然是記憶體分配,這一次我們會從微觀的角度來探秘一下 Linux 內核中用于零散小記憶體塊分配的記憶體池 —— slab 分配器。 在本小節中,筆者還是按照以往的風格先帶大家簡單 ......

    uj5u.com 2023-04-05 16:44:11 more