介紹
眾所周知,分析物聯網(IoT)設備預計將無處不在。物聯網設威脅這些由半導體驅動的備面設備將推動每一個可想象的過程實現智能化。從簡單的安全開燈到門診護理或工廠控制等更復雜的過程,通過傳感、分析處理和云連接,物聯網設威脅物聯網設備將大幅提高工作效率。備面應用場景多種多樣,安全它們的分析發展前景和影響力也將不可估量。
然而,物聯網設威脅互聯設備的備面日益“智能化”也帶來了安全挑戰。例如,安全傳統的照明控制相對原始,它是一個帶有物理開關的電源電路。要對開關進行操作則需要物理上接觸并操作開關。要避免未經授權的使用,只需要對開關進行簡單的物理保護。現在考慮將照明控制看作是物聯網設備的智能化身。光傳感器、距離傳感器、邏輯控制(通常在微控制器中實現)以及云應用無線連接取代了傳統的物理開關。在智能化過程中,照明開關被轉換成一個通過網絡與應用服務器一起工作的嵌入式客戶端。保護智能照明開關因此變得更加復雜。這種復雜性的提高將給所有物聯網設備設計人員帶來挑戰。好消息是,帶有安全保護的微控制器能夠顯著提高物聯網設備的安全性,加快設計周期。
本文中的案例研究介紹了如何確定網絡攝像頭物聯網設備的安全要求。顧名思義,這種設備已經實現互聯,并廣泛應用于眾多應用,從簡單的家庭網絡攝像頭到復雜的工業系統,不一而足。通過定義對網絡攝像頭的相關威脅并確定防御這些威脅的安全目標,從而制定了該設備的安全要求。本文介紹了基于Arm®技術的賽普拉斯PSoC® 6 MCU,是能夠滿足上述要求的可用解決方案。該方法同樣適用于其他物聯網設備。
物聯網設備安全性分析
保護物聯網設備的想法可能令人望而生畏。初步研究很快揭示了有關密碼學、威脅、安全目標和其他幾個主題的大量知識。面對鋪天蓋地的信息,物聯網設備設計人員通常會問的第一個問題是:“我如何判斷所需安全性要達到哪種水平?”,緊接著是“我該從哪里入手?”
Arm提供了平臺安全架構(PSA),幫助設計人員快速入門。通過利用PSA的一整套威脅模型和安全性分析、硬件和固件架構規范以及可信固件M參考實現,物聯網設計師能夠快速且輕松地實現安全設計。
通過使用雙Arm Cortex®-M內核,結合可配置的內存和外設保護單元,賽普拉斯PSoC 6 MCU實現了PSA定義的最高保護級別。本文將PSA網絡攝像頭威脅模型和安全性分析(TMSA)應用于PSoC 6 MCU,演示如何針對網絡攝像頭應用進行安全性評估。
任何攻擊的目標都是獲取物聯網設備的數據并以某種方式加以利用。如圖1所示,分析過程的第一步是識別物聯網設備處理的數據資產及其安全屬性。
圖1:設計安全的物聯網設備時的分析過程
接下來的步驟是識別針對這些資產的威脅,定義抵御這些威脅的安全目標,并確定需求以滿足安全目標。通過滿足這些要求,基于微控制器的設計可為安全目標提供支持,并最終保留資產的安全屬性。最后,應該對設計進行評估,以判定設計是否達到安全目標。通常情況下,這類評估會利用應用于設計的威脅模型來評估設備的攻擊防御能力。
數據資產
每個物聯網設備的價值都建立在數據之上,以及如何對這些數據進行管理。數據資產在嵌入式系統中有多種表現形式。例如,固件定義設備的行為。其他示例包括用于控制設備的唯一ID、密碼和加密密鑰。此外,還有物聯網設備生成的數據,例如來自網絡攝像頭的圖像數據或來自傳感器的環境數據。無論其形式如何,每種數據資產都具有各自的安全屬性。安全屬性是系統所依賴的數據資產的固有特性,是系統信任該數據資產的基礎。機密性、完整性和真實性是三種常見的安全屬性。
機密性
機密性指的是主動或被動保密或私有的狀態。
機密性要求只有授權人員才能夠讀取數據資產。換言之,它是機密或私有的。密碼是具有機密性安全屬性的數據資產的常見示例。其他示例可能包括物聯網設備生成的個人數據,如心率數據或位置信息。
完整性
完整性指的是完整且不可分割的狀態
完整性要求數據資產在使用或傳輸時保持不變。完整性通常與建立引用的數據(如啟動固件)相關聯。啟動固件確保MCU配置為應用可執行的已知初始狀態。對啟動固件進行更改可能會影響該初始狀態,并存在操作或安全風險。
真實性
真實的性質(毫無爭議的來源;不是副本;真實的)
真實性要求只有受信任的參與者才能建立數據資產的當前狀態。當與完整性相結合時,真實性便能夠建立信任,因此它是安全物聯網設備的關鍵基石。在先前的啟動固件示例中,數字簽名可用于在升級固件時對真實性和完整性進行評估,以確保僅使用可信固件。
全面識別物聯網設備中的數據資產至關重要,因為每個后續步驟都依賴于此步驟。舉例來說,網絡攝像頭將具備以下數據資產:
每種數據資產都將具備與其相關聯的安全屬性。
威脅
威脅旨在破壞數據資產的安全屬性并將其用于未經授權的目的。為了識別威脅,必須對物聯網設備中數據的使用進行評估。例如,證書可用于訪問物聯網設備的網絡。如果證書的機密性受到損害,則未經授權的參與者就可以使用它們來訪問網絡。這種攻擊稱為冒充攻擊。通過系統地評估每種數據,可以創建潛在威脅列表。
此外,網絡攝像頭可能面臨以下對其數據資產的威脅:
安全目標
通過識別威脅,可以定義安全目標。安全目標是在應用級別定義的,本質上提供了實現需求。一些安全目標可以作為可信應用(TA)實現,它們在安全的MCU提供的隔離執行環境中執行。隔離執行環境全面保護TA及其使用/處理的數據。物聯網設備應用本身在不安全的執行環境中運行,并通過使用處理器間通信(IPC)通道的API與隔離執行環境中的TA進行通信。TA則利用硬件中的可用資源(如加密加速器和安全內存)來為目標提供支持。
繼續此示例,前面確定的威脅可以通過以下安全目標進行防御:
訪問控制:物聯網設備對試圖訪問數據資產的所有參與者(人或機器)進行身份驗證。防止在未經授權的情況下訪問數據。防御欺騙和惡意軟件威脅,即攻擊者對固件進行修改或安裝過時的缺陷版本。
安全存儲:物聯網設備維護數據資產的機密性(根據需要)和完整性。防御篡改威脅。
固件真實性:物聯網設備在啟動和升級之前對固件的真實性進行驗證。防御惡意軟件威脅。
通信:物聯網設備對遠程服務器進行身份驗證,提供機密性(根據需要),并維護交換數據的完整性。防御中間人攻擊(MitM)威脅。
安全狀態:即使固件完整性和真實性驗證失敗,仍確保設備保持安全狀態。防御惡意軟件和篡改威脅。
安全需求
在這一方面,分析提供了數據資產、威脅和安全目標的邏輯連接模型。根據這張圖,可以編譯出安全MCU所需的功能或特性列表。當然,這個列表也可以用作特定物聯網設備應用解決方案的實現標準。
生命周期至關重要
請注意,安全目標的要求可能會根據物聯網設備的生命周期階段(設計、制造、庫存、最終使用和終止)而變化,也應予以考慮。
現在可以對這個示例進行分析:
每種數據資產都將具備與其相關聯的安全屬性:
注釋:
1. 在隔離執行環境中理想地以TA形式實現
2. C = 機密性,I = 完整性,A = 真實性
3. SEF = 安全元件功能
4. Dead = 非操作狀態下的安全MCU
選擇正確的MCU
通過分析,以下是MCU所需安全功能的總結:
可信應用的隔離執行環境:雖然前面的分析側重于安全數據資產,但每個物聯網設備也有包含非安全數據資產的非安全任務/應用。MCU應提供一種強大的方法,對非安全處理和安全處理進行隔離。這一概念機場類似:登機區是安全且隔離的。只允許通過身份驗證的個人在安全區域內進行操作(如登機)。MCU必須在非安全和安全的執行環境之間提供強大的、基于硬件的隔離。
安全元件功能:在隔離執行環境中,要存儲數據資產,需要完成進一步的隔離,如對安全性至關重要的加密密鑰。繼續與機場進行類比,每名乘客都持有有效證件。MCU必須為信任根存儲和相關安全服務提供進一步隔離。
加密:首選帶有專用硬件加速器塊和受控訪問的MCU。加速器塊有助于提高性能。加速器塊的訪問控制(隔離)有助于防止未經授權的程序訪問,確保加密密鑰保持在安全的環境中。
數字簽名:數據資產的真實性和完整性可以通過使用數字簽名算法(如ECDSA和RSA)進行評估。MCU固件是數字簽名最常見的用例。MCU應提供基于硬件的散列和簽名支持,以便在加載之前對固件鏡像進行評估。
eFuses:對于保障設計的安全來說,不可變數據資產至關重要。它們通常用作系統行為的參考。典型示例包括生命周期名稱、唯一標識符(UID)、制造商編號以及在物聯網設備的生命周期中持續存在的其他參考。
結論
本文提出了一種分析方法,用于確定安全物聯網設備的需求。通過創建模型,將數據資產、其面臨的威脅以及防御這些威脅的安全目標邏輯連接,可以導出一個需求列表,該列表可以用作解決方案的實現標準。
絕大多數物聯網設備將建立在基于MCU的嵌入式系統上。這種發展機遇將催生出一類新型MCU,它們可提供安全特性和功能,用來維護數據資產的安全屬性。賽普拉斯的PSoC 6安全MCU是此類新型MCU的先驅之一。PSoC 6 MCU架構專為物聯網設備應用而設計,提供了能夠延長電池使用壽命的超低功耗、高效的處理能力,以及可支持安全目標的硬件安全功能:
隔離執行環境:通過采用硬件隔離技術,PSoC 6安全MCU將安全操作與非安全操作隔離開來:
? 可配置保護單元用于隔離內存、加密和外設
? 在Arm Cortex-M4和Cortex-M0+內核之間提供處理器間通信(IPC)通道,為基于API的獨立交互提供支持
? 理想適用于支持物聯網設備安全目標的可信應用
集成安全元件功能:PSoC 6中的硬件隔離技術支持獨立的密鑰存儲和加密操作,除了隔離執行環境以外,還提供安全元件功能。
? 理想適用于安全密鑰存儲
? 支持預安裝信任根,方便使用信任鏈來錨定安全啟動
隔離硬件加速加密操作:包括AES、3DES、RSA、ECC、SHA-256和SHA-512以及真隨機數發生器(TNRG)。
生命周期管理:在發生安全錯誤(如固件散列檢查失敗)時,基于eFuse的生命周期管理功能有助于確保安全行為。
圖2:PSoC 6安全MCU提供三級隔離
隨著低成本、易于設計且方便使用的無線云連接日益普及,物聯網設備也將實現爆炸性增長。嵌入式系統發送和接收數據的能力是實現智能化的基本推動因素。不幸的是,這種能力也給物聯網設備產生的高價值數據帶來了巨大威脅。數據越有價值,物聯網設備就越需要具備安全功能以為這些數據提供保護。諸如賽普拉斯的PSoC 6 MCU這樣的安全MCU解決了安全物聯網設備的相關需求。