AURIX? TC4x虛擬化技術(shù)助力下一代汽車(chē)EE架構(gòu)設(shè)計(jì)
往期回顧
AURIX? TC4x 微控制器的并行處理單元(PPU)簡(jiǎn)介
AURIX? TC4x免費(fèi)開(kāi)發(fā)環(huán)境介紹
英飛凌新一代MCU AURIX? TC4x 即將量產(chǎn)
緣起今生:英飛凌車(chē)規(guī)MCU全系支持Rust 語(yǔ)言開(kāi)發(fā)
探索 AUTOSAR 與 英飛凌 AURIX? TC4x MCAL 解決方案-上
英飛凌AURIX? TC4x 微控制器首次引入了虛擬化技術(shù),幫助客戶(hù)重新構(gòu)建整車(chē)EE架構(gòu),最大化利用MCU的硬件資源,其資源隔離的特性還可以降低軟件開(kāi)發(fā)和集成的難度,更好地滿(mǎn)足功能安全和信息安全的要求。
本文主要介紹了虛擬化技術(shù)的背景,虛擬化系統(tǒng)的組成和分類(lèi),嵌入式虛擬化的優(yōu)點(diǎn),在汽車(chē)領(lǐng)域的使用案例以及面臨的挑戰(zhàn)。
虛擬化技術(shù)的背景
1
1.1
虛擬化技術(shù)的發(fā)展歷史
1955年,F(xiàn)ortran語(yǔ)言之父John Backus首次提出了分時(shí)(Time-Sharing)技術(shù),通過(guò)該技術(shù),昂貴的大型機(jī)可以被多個(gè)用戶(hù)同時(shí)使用,這被公認(rèn)為最早的虛擬化技術(shù)的概念[1]。1972年,IBM公司研發(fā)出了VM/370虛擬機(jī)操作系統(tǒng),真正實(shí)現(xiàn)了虛擬化技術(shù)的商業(yè)落地。1974年,Gerald J. Popek和Robert P. Goldberg系統(tǒng)闡述了實(shí)現(xiàn)計(jì)算機(jī)虛擬化所需要滿(mǎn)足的特性,以及虛擬機(jī)和虛擬機(jī)監(jiān)控器的概念,這些概念一直沿用至今[2]。如今的虛擬化技術(shù)已經(jīng)從PC端發(fā)展到嵌入式系統(tǒng)領(lǐng)域。
1.2
嵌入式虛擬化的發(fā)展
嵌入式虛擬化的興起首先得益于半導(dǎo)體技術(shù)的飛速發(fā)展,以英飛凌的TriCore?品牌為例(圖1),經(jīng)過(guò)多年的發(fā)展,TriCore?的內(nèi)核架構(gòu)不斷升級(jí),主頻持續(xù)攀升,最新的下一代AURIX? TC4x首次引入了虛擬化技術(shù),讓嵌入式MCU從硬件上支持虛擬化成為現(xiàn)實(shí)。
圖1 TriCore? MCU發(fā)展歷史其次,在汽車(chē)領(lǐng)域,軟件定義汽車(chē)日漸盛行,MCU的軟件架構(gòu)也從單核到多核,再到多核的虛擬化逐漸演變[3],如圖2所示。
圖2 MCU軟件架構(gòu)的演變
最后,從客戶(hù)角度出發(fā),出于節(jié)約成本,系統(tǒng)整合,功能安全,信息安全以及配置靈活性等多維度考量,嵌入式虛擬化也是其中的關(guān)鍵突破口(圖3)。
圖3 嵌入式虛擬化的關(guān)鍵特性
虛擬化系統(tǒng)概述
2
2.1
虛擬環(huán)境的組成
典型的虛擬環(huán)境由三部分組成:硬件,虛擬機(jī)以及虛擬機(jī)監(jiān)控器(圖4)。
圖4 虛擬環(huán)境的組成
硬件,可以是任意支持虛擬化技術(shù)的處理器,如英飛凌的下一代高性能MCU,AURIX? TC4x。
虛擬機(jī)(VM,Virtual Machine),是執(zhí)行不同虛擬化應(yīng)用程序的容器。通過(guò)虛擬化技術(shù),將物理計(jì)算機(jī)系統(tǒng)按照CPU,Memory,外設(shè),中斷等維度進(jìn)行虛擬分配,形成所謂的虛擬計(jì)算機(jī)。
虛擬機(jī)監(jiān)控器(VMM,Virtual Machine Monitor),又稱(chēng)Hypervisor(以下均簡(jiǎn)稱(chēng)Hypervisor),它是橫跨在虛擬機(jī)和硬件之間的一個(gè)軟件層,其主要作用是協(xié)調(diào)不同虛擬機(jī)的運(yùn)行,確保它們之間互不干擾。
2.2
虛擬化系統(tǒng)的分類(lèi)
根據(jù)Hypervisor在整個(gè)虛擬化系統(tǒng)中實(shí)現(xiàn)位置的不同,可以將Hypervisor分成兩種類(lèi)型[1](圖5):
Type1 Hypervisor:Hypervisor直接跑在硬件的裸板上,并運(yùn)行在最高特權(quán)級(jí),而所有的虛擬機(jī)運(yùn)行在較低的特權(quán)級(jí)。Hypervisor直接負(fù)責(zé)其上各個(gè)虛擬機(jī)的資源分配以及運(yùn)行時(shí)的調(diào)度策略。
Type2 Hypervisor:Hypervisor作為一個(gè)應(yīng)用程序跑在主機(jī)的OS上,與其他應(yīng)用程序沒(méi)有本質(zhì)區(qū)別。Hypervisor需要與主機(jī)上的OS協(xié)商資源分配。
圖5 Hypervisor的類(lèi)型
兩種Hypervisor相比,Type1的Hypervisor因?yàn)橹苯釉L問(wèn)底層的硬件資源,在使用效率和性能上更好,一般適用于嵌入式系統(tǒng)。而Type2的Hypervisor因?yàn)檫\(yùn)行在操作系統(tǒng)之上,即使非技術(shù)型用戶(hù)也可以很好地操作Hypervisor,一般用于桌面系統(tǒng),比如個(gè)人電腦等等。
嵌入式虛擬化的優(yōu)點(diǎn)
3
在汽車(chē)電子應(yīng)用領(lǐng)域,嵌入式虛擬化有如下幾個(gè)方面的優(yōu)點(diǎn):
有利于系統(tǒng)整合
從系統(tǒng)架構(gòu)層面來(lái)看,整車(chē)的EE架構(gòu)已經(jīng)從傳統(tǒng)的分布式系統(tǒng)向集中式架構(gòu)轉(zhuǎn)變(圖6)。
圖6 整車(chē)EE架構(gòu)的變革
以域控制器架構(gòu)為例,以太網(wǎng)作為主干網(wǎng)絡(luò)連接各個(gè)域控制器,在它們下面掛著不同功能模塊的小型ECU[4]。引入虛擬化技術(shù)之后,可以將其中部分小型ECU以虛擬機(jī)的形式移植到域控制器里面,最大化地使用域控MCU的硬件資源,從而減少ECU的數(shù)量[5],降低系統(tǒng)的BOM成本。圖7是一個(gè)簡(jiǎn)單的例子說(shuō)明這個(gè)概念。
圖7 虛擬化技術(shù)有助于域控制器融合
從軟件開(kāi)發(fā)的角度來(lái)看,引入虛擬化之后,Hypervisor將硬件資源分配給不同的虛擬機(jī),虛擬機(jī)跟應(yīng)用程序之間有一定的映射關(guān)系。各個(gè)軟件開(kāi)發(fā)團(tuán)隊(duì)根據(jù)Hypervisor分配的硬件資源和調(diào)度策略去執(zhí)行自己的應(yīng)用程序開(kāi)發(fā),然后做軟件集成(圖8)。由于各個(gè)虛擬機(jī)可以獨(dú)享自己的硬件資源,彼此之間互不干擾,各個(gè)虛擬機(jī)甚至可以使用不同的AUTOSAR軟件,不同的操作系統(tǒng),不同的開(kāi)發(fā)工具。這樣就解決了不同開(kāi)發(fā)團(tuán)隊(duì)或者不同供應(yīng)商的程序在同一個(gè)硬件系統(tǒng)中運(yùn)行,系統(tǒng)集成難度大的問(wèn)題。
圖8 虛擬化方案軟件開(kāi)發(fā)流程
有利于功能安全和信息安全的部署
虛擬化技術(shù)的一個(gè)顯著特定就是隔離,Hypervisor為不同的虛擬機(jī)分配硬件資源,如CPU,內(nèi)存,外設(shè)以及中斷。以AURIX? TC4x為例,用戶(hù)可以對(duì)每一個(gè)虛擬機(jī)分配特定的內(nèi)存和外設(shè),以及它們的訪問(wèn)權(quán)限,中斷也可以給到指定的虛擬機(jī)去響應(yīng)。這樣原本在不同ECU層面的功能安全和信息安全目標(biāo),現(xiàn)在在不同虛擬機(jī)之間就能夠?qū)崿F(xiàn)(圖9)。
圖9 虛擬機(jī)隔離示意圖
增強(qiáng)了系統(tǒng)集成的靈活性
每一個(gè)虛擬機(jī)可以做到獨(dú)立的啟動(dòng)和停止,以及獨(dú)立的去編程和燒錄,這大大增強(qiáng)了系統(tǒng)的可擴(kuò)展性和集成的靈活性。
汽車(chē)嵌入式虛擬化的使用案例
4
這里簡(jiǎn)單介紹兩個(gè)嵌入式虛擬化在汽車(chē)電子領(lǐng)域的使用案例。
案例一:新能源多合一
圖10 新能源多合一系統(tǒng)示意圖
新能源多合一技術(shù)是當(dāng)前新能源汽車(chē)的研究熱點(diǎn)。圖10是雙電機(jī)和DCDC功能融合的案例,CPU0運(yùn)行MCAL和通信協(xié)議棧,CPU1運(yùn)行Inverter A的應(yīng)用,CPU2運(yùn)行Inverter B和DCDC的應(yīng)用,每一個(gè)應(yīng)用里面可以有一個(gè)或者多個(gè)虛擬機(jī),不同的虛擬機(jī)通過(guò)Hypervisor實(shí)現(xiàn)它們的調(diào)度。這樣可以最大化地利用MCU的硬件資源,減少ECU數(shù)量,降低系統(tǒng)的BOM成本。此外,Inverter應(yīng)用和DCDC應(yīng)用的開(kāi)發(fā)可能來(lái)自不同的軟件團(tuán)隊(duì),即使他們的開(kāi)發(fā)環(huán)境(操作系統(tǒng),編譯器,調(diào)試器)不同,由于應(yīng)用跑在不同的虛擬機(jī)里面,彼此之間互不干擾,從而降低了開(kāi)發(fā)和集成的難度。
案例二:充電樁V2G技術(shù)
圖11 使用虛擬化對(duì)V2G相關(guān)應(yīng)用進(jìn)行隔離
V2G技術(shù)被認(rèn)為是電動(dòng)汽車(chē)和電網(wǎng)進(jìn)行雙向能量和信息交互的理想范式。但是近年來(lái)黑客攻擊充電樁的事件時(shí)有發(fā)生。為了防止黑客在用戶(hù)充電過(guò)程中對(duì)汽車(chē)的入侵,我們可以在控制器端采取防御措施。比如,將與充電樁通信相關(guān)的應(yīng)用放到一個(gè)特定的虛擬機(jī)里面[6],該虛擬機(jī)對(duì)其他硬件資源的訪問(wèn)進(jìn)行嚴(yán)格的管控,從而達(dá)到虛擬防火墻的作用(圖11)。
汽車(chē)嵌入式虛擬化的挑戰(zhàn)
5
當(dāng)然,嵌入式虛擬化也面臨著諸多挑戰(zhàn)[7],總結(jié)為如下幾點(diǎn):
?
?
實(shí)時(shí)性
雖然嵌入式系統(tǒng)都是Type1的Hypervisor,但是Hypervisor作為中間的調(diào)度軟件,本身也會(huì)消耗時(shí)間片,系統(tǒng)越復(fù)雜,調(diào)度策略也會(huì)越復(fù)雜,Hypervisor本身的時(shí)間開(kāi)銷(xiāo)也會(huì)越大,從而影響系統(tǒng)的整體實(shí)時(shí)性。
?
?
故障處理的復(fù)雜性
引入了虛擬化之后,多個(gè)應(yīng)用集成在一個(gè)MCU控制器當(dāng)中,如果某一個(gè)虛擬機(jī)出現(xiàn)系統(tǒng)失效,我們需要盡可能的保證該虛擬機(jī)的故障處理不影響到其他虛擬機(jī)的正常運(yùn)行,盡量避免單個(gè)虛擬機(jī)失效影響整個(gè)系統(tǒng)的情況發(fā)生,這對(duì)故障處理功能帶來(lái)了挑戰(zhàn)。
?
?
通用功能的系統(tǒng)整合
對(duì)于多應(yīng)用融合的方案,在引入虛擬化之后,一些通用的系統(tǒng)功能,如休眠喚醒功能,如何整合所有應(yīng)用去做最終的方案策略,值得客戶(hù)深思;再比如,AUTOSAR的基礎(chǔ)軟件,是共用一套BSW軟件,還是每個(gè)應(yīng)用都有自己的BSW軟件,也是一個(gè)值得商榷的問(wèn)題。
?
?
軟件生態(tài)
當(dāng)前,嵌入式虛擬化的軟件大都是非開(kāi)源的商業(yè)軟件,且軟件本身沒(méi)有類(lèi)似AUTOSAR這樣的標(biāo)準(zhǔn)接口規(guī)范,軟件公司根據(jù)不同芯片廠商的硬件支持情況各自制定自己的解決方案。
總結(jié)
6
總的來(lái)說(shuō),虛擬化技術(shù)最早在計(jì)算機(jī)端興起,而嵌入式系統(tǒng)的虛擬化正在成為一種趨勢(shì)。用戶(hù)可以根據(jù)自身需求將MCU的硬件資源靈活地拆分成多個(gè)虛擬機(jī),不同的應(yīng)用跑不同的虛擬機(jī),Hypervisor負(fù)責(zé)管理各個(gè)虛擬機(jī)的啟動(dòng),運(yùn)行以及停止,最大限度地利用MCU的資源。虛擬化的隔離特性有助于客戶(hù)的軟件開(kāi)發(fā)和集成,滿(mǎn)足功能安全和信息安全的要求。英飛凌最新一代AURIX? TC4x將從硬件上支持虛擬化技術(shù),助力整車(chē)的E/E架構(gòu)設(shè)計(jì),開(kāi)發(fā)和集成。
*博客內(nèi)容為網(wǎng)友個(gè)人發(fā)布,僅代表博主個(gè)人觀點(diǎn),如有侵權(quán)請(qǐng)聯(lián)系工作人員刪除。