作者:Michael Rothman,Vincent Zimmer
在本文中,我們將介紹一些方法,在這些方法中,可以以安全、可管理和可觀察的方式在現(xiàn)場更新基于計算的平臺。
在整篇文章中,我們還將介紹存在哪些底層組件來使所有這些工作,特別是在基于UEFI的固件實現(xiàn)超越BIOS的上下文中。
讓我們從“平臺固件”開始,在這種情況下,平臺固件由嵌入式邏輯定義,該邏輯有助于初始化平臺硬件并啟動啟動目標(biāo)。此固件通常駐留在計算機的主板上,甚至駐留在插件設(shè)備(如存儲控制器和網(wǎng)絡(luò)設(shè)備)上的芯片上。
最終,平臺啟動固件的主要目的是啟動目標(biāo)軟件,通常是操作系統(tǒng)。
從歷史上看,引導(dǎo)固件沒有一組標(biāo)準(zhǔn)化的應(yīng)用程序編程接口 (API),這些接口 (API) 可跨平臺、第三方硬件和操作系統(tǒng)域進(jìn)行互操作。這些組件中的每一個都有自己的編程孤島,幾乎沒有標(biāo)準(zhǔn)交互。
然而,在2005年,UEFI(統(tǒng)一可擴展固件接口)論壇成立。其主要目標(biāo)之一是為機器內(nèi)的組件如何相互通信提供行業(yè)標(biāo)準(zhǔn)。
簡而言之,UEFI 論壇涵蓋三個主要規(guī)范:
國際金融機構(gòu)規(guī)范
平臺與第三方內(nèi)容(如操作系統(tǒng)或插件設(shè)備)之間的 API 集。
平臺初始化 (PI) 規(guī)范
定義如何構(gòu)建底層平臺固件。
定義不可發(fā)現(xiàn)的信息和運行時交互從平臺到操作系統(tǒng)的抽象。
如上所述,固件執(zhí)行許多角色。固件的實現(xiàn)基于行業(yè)標(biāo)準(zhǔn),例如 UEFI PI 規(guī)范。PI 階段包括預(yù)電子應(yīng)用初始化 (PEI) 和驅(qū)動程序執(zhí)行環(huán)境 (DXE)。通常,一個平臺可能具有 50 個 PEI 模塊和 180 個 DXE 模塊。用于構(gòu)建這些元素的源代碼樹可以包含數(shù)十萬行 C 代碼,隨著產(chǎn)品的發(fā)布,各種分支被整理出來,如圖 1 所示。

圖1 固件源樹產(chǎn)品的演變
這些模塊和驅(qū)動程序都在環(huán) 0 內(nèi)執(zhí)行,并且通常沒有組件間分離,這在操作系統(tǒng)內(nèi)的應(yīng)用程序中很常見。因此,任何組件中的缺陷都可能導(dǎo)致平臺的潛在損害。其中許多組件使用攻擊者控制的輸入,例如磁盤上的數(shù)據(jù)結(jié)構(gòu)、策略對象(如操作系統(tǒng)設(shè)置的 UEFI 變量)以及來自未受保護的總線的輸入。如此大量的可執(zhí)行代碼具有許多攻擊面,并且隨著新技術(shù)的引入,會創(chuàng)建更多的攻擊面。支持 UEFI 固件實現(xiàn)必須支持的各種標(biāo)準(zhǔn),從而增加復(fù)雜性。這些標(biāo)準(zhǔn)的演變可以在下面的圖2中看到。

圖2 固件支持的規(guī)范和標(biāo)準(zhǔn)的演變
關(guān)于攻擊的類別,市場上已經(jīng)觀察到很多。其中包括早期 PI 或更高版本的 DXE 流中的特權(quán)提升、錯誤的選項 ROM(旨在初始化特殊設(shè)備),甚至是攻擊硬件。針對固件的攻擊類別的示例可以在下面的圖 3 中看到。

圖3 固件攻擊的分類
通過 UEFI 論壇和開源社區(qū)有報告機制來支持負(fù)責(zé)任地披露這些安全問題。然而,挑戰(zhàn)在于分散的供應(yīng)鏈。例如,在 tianocore.org 上使用 EDKII 代碼需要經(jīng)過許多人的操作,例如開源到硅供應(yīng)商,從芯片供應(yīng)商到原始設(shè)備制造商 (OEM) 以及 OEM 到原始設(shè)備制造商 (ODM)。例如,TianoCore中的缺陷如何最終在其系統(tǒng)上的最終用戶閃存ROM中更新ODM生產(chǎn)的設(shè)備?當(dāng)今供應(yīng)鏈和修補的復(fù)雜性可以在下面的圖 4 中顯示出來。

圖 4 UEFI 固件的供應(yīng)鏈
主機固件的作用是什么?
引導(dǎo)固件分階段初始化,包括 PEI 和 DXE,如下圖 5 所示。

圖 5 UEFI PI 固件的啟動流程
在 (DXE) 驅(qū)動程序執(zhí)行環(huán)境中,我們枚舉平臺上的設(shè)備,然后執(zhí)行邏輯來初始化這些設(shè)備。有時,如果這些設(shè)備是眾所周知的并且符合某些標(biāo)準(zhǔn),則它們可能在固件中具有內(nèi)置支持,而其他設(shè)備可能具有設(shè)備攜帶的初始化代碼,并且反過來又由固件啟動。
在后一種情況下,設(shè)備的初始化代碼通常會公開固件管理協(xié)議(FMP)接口,如果需要,該接口可用于現(xiàn)場更新。
固件初始化的最后階段是操作系統(tǒng)加載程序通過 UEFI API 與固件交互并促進(jìn)其自身的初始化。它還可以通過各種方式(如基于膠囊的更新)執(zhí)行固件更新。
如前所述,固件更改可以穿過硅供應(yīng)商,固件供應(yīng)商,OEM和ODM的供應(yīng)鏈的曲折路徑,以出現(xiàn)在最終用戶系統(tǒng)中。從歷史上看,其中許多方都有自定義更新工具,這些工具必須安裝到各種操作系統(tǒng)和獨特的位置才能發(fā)現(xiàn)和下載更新。這種晦澀難懂的空間,即如何更新您的設(shè)備,通常導(dǎo)致許多最終用戶無法及時維修其設(shè)備并更新其固件。
進(jìn)入“自動加密包”。UEFI 膠囊包含各種元素,包括將更新本身的二進(jìn)制封裝到稱為 UEFI 膠囊的東西中。UEFI 膠囊具有一個由全局唯一標(biāo)識符 (GUID) 命名的明確定義的標(biāo)頭。系統(tǒng)固件的創(chuàng)建者將其更新有效負(fù)載(無論是代碼、數(shù)據(jù)還是更新驅(qū)動程序)包裝到此格式中。然后,通過使用膠囊生產(chǎn)商擁有的密鑰材料在膠囊上應(yīng)用加密簽名來保證更新的來源。膠囊的圖形表示可以在圖6中找到。
一旦膠囊在手,操作系統(tǒng)可以通過引用 EFI 系統(tǒng)資源表 (ESRT) 來確定平臺是否支持此膠囊類型,該表是一系列 GUID,用于指定平臺中的版本和潛在可更新的元素。如果手頭的膠囊 GUID 與 ESRT 條目匹配,則操作系統(tǒng)可以暫存,或者操作系統(tǒng)之前的 UEFI 應(yīng)用程序?qū)l(fā)出更新膠囊() UEFI 運行時調(diào)用,并將上述膠囊二進(jìn)制文件作為參數(shù)。Linux 和 Windows 通常通過將封裝程序包復(fù)制到操作系統(tǒng)之前可訪問的位置(如 EFI 系統(tǒng)分區(qū) (ESP))并重新啟動來暫存更新。重新啟動后,UEFI 操作系統(tǒng)加載程序可以發(fā)出更新膠囊 () 調(diào)用,設(shè)備將重新啟動。在重新啟動期間,UEFI PI 代碼將確定膠囊位置(可能合并)、加密驗證,如果真實,則使用更新更新閃存??偭髁咳缦聢D 7 所示。

圖 7 膠囊更新啟動流程
更新發(fā)生后,可能會對系統(tǒng)穩(wěn)定性產(chǎn)生一些擔(dān)憂。因此,UEFI ACPI 規(guī)范中有一些功能(如平臺運行狀況評估表 (PHAT))可以進(jìn)行查詢,以查看系統(tǒng)狀態(tài)是否有任何意外更改。更新還會影響系統(tǒng)完整性,如平臺配置寄存器 (PCR) 中的更改中所述。因此,在更新之前,操作系統(tǒng)可能需要解封機密,發(fā)出更新,然后針對最新的 PCR 重新密封。
為了促進(jìn)生態(tài)系統(tǒng)創(chuàng)建膠囊,TianoCore /EDK2資源提供了一個模板,用于基于UEFI固件管理協(xié)議創(chuàng)建更新驅(qū)動程序,創(chuàng)建ESRT條目,簽名等。生態(tài)系統(tǒng)中還支持使用 Linux 供應(yīng)商固件服務(wù) (LVFS) 和 Windows 更新 (WU) 在 Linux 中管理膠囊更新。鑒于鏈的強度取決于其最薄弱的環(huán)節(jié),因此構(gòu)建高保證固件的一些最佳實踐可以在構(gòu)建安全固件中找到。
總之,本文討論了以安全、可管理和可觀察的方式執(zhí)行固件更新的方法。這些屬性通過基于 UEFI 的固件中的基礎(chǔ)結(jié)構(gòu)啟用,包括膠囊、PHAT 和基于加密的 FMP 協(xié)議。
審核編輯:郭婷
-
控制器
+關(guān)注
關(guān)注
114文章
17732瀏覽量
191503 -
操作系統(tǒng)
+關(guān)注
關(guān)注
37文章
7385瀏覽量
129043
發(fā)布評論請先 登錄
一文讀懂UEFI系統(tǒng):從應(yīng)用場景到RK平臺開發(fā)全攻略
艾體寶干貨 | IEC 62443-4:開發(fā)的最佳安全實踐,不只是工業(yè)控制系統(tǒng)
硬件加密引擎在保障數(shù)據(jù)安全方面有哪些優(yōu)勢呢?
AMI在Aptio V UEFI固件中成功部署后量子密碼學(xué)
【CIE全國RISC-V創(chuàng)新應(yīng)用大賽】+MUSE Pi Pro RiscV UEFI固件開發(fā)
天合儲能在系統(tǒng)安全設(shè)計與防爆防控方面的實踐經(jīng)驗
樹莓派更新:確保系統(tǒng)安全且優(yōu)化的關(guān)鍵步驟!
Linux系統(tǒng)安全防護措施
時鐘同步在通信系統(tǒng)中有哪些重要作用?
網(wǎng)線在機器人領(lǐng)域如何發(fā)揮重要作用
SOLIDWORKS教育版——全方面的學(xué)習(xí)資源與教程
接地電阻柜是電力系統(tǒng)安全運行的重要保障
了解UEFI固件更新及其在保持計算系統(tǒng)安全方面的重要作用
評論