每個嵌入式系統(tǒng)都是不同的。因此,隨著多核設(shè)計變得越來越普遍,幾乎到了成為主流的程度,不同的硬件和軟件架構(gòu)也在不斷發(fā)展。
從軟件的角度來看,大致有兩種選擇:對稱多處理 (SMP) 和非對稱多處理 (AMP)。
SMP 系統(tǒng)只能在同構(gòu)多核平臺上實現(xiàn)(即,所有內(nèi)核都是相同的)。操作系統(tǒng)的單個實例跨所有內(nèi)核運行。此操作系統(tǒng)需要是支持 SMP 操作的特定變體。Linux 和許多實時操作系統(tǒng)產(chǎn)品都支持 SMP。任務(wù)自動分布在核心之間。但是,如果特定應(yīng)用程序需要,可以選擇將任務(wù)鎖定到特定內(nèi)核。SMP 的目標是以節(jié)能的方式提高可用的處理性能,這在臺式機和筆記本電腦上很常見。
對于嵌入式應(yīng)用,AMP 提供了更大的靈活性,因此也更為常見。在 AMP 系統(tǒng)中,每個內(nèi)核都運行自己的操作系統(tǒng)(或者可能根本不運行操作系統(tǒng)——“裸機”)。操作系統(tǒng)不需要相同。每個操作系統(tǒng)都可以根據(jù)內(nèi)核的預(yù)期功能進行選擇,它不需要是特殊的“支持多核”的版本。與 SMP 不同,AMP 不要求所有內(nèi)核都相同;它可以在異構(gòu)多核平臺上實現(xiàn)。大多數(shù)多核片上系統(tǒng)設(shè)備包括各種核心架構(gòu)。不同的核心架構(gòu)可能適用于應(yīng)用程序的不同部分。
在 AMP 設(shè)計中需要解決兩個問題:生命周期管理(啟動順序等)和內(nèi)核間通信。這些問題不會出現(xiàn)在 SMP 系統(tǒng)中,因為操作系統(tǒng)可以控制哪些任務(wù)在何時何地運行,并且任務(wù)間通信使用標準的操作系統(tǒng) API——這些任務(wù)不需要“知道”它們在多核上下文中運行。在AMP系統(tǒng)中,每個操作系統(tǒng)都不知道其他操作系統(tǒng)的存在,因此必須做出具體規(guī)定。
配置 AMP 系統(tǒng)的最佳方式是使用某種多核框架來滿足控制和通信要求。OpenAMP 是定義此類框架架構(gòu)的標準;許多供應(yīng)商都提供了 OpenAMP 的實現(xiàn)。

該框架的一個實例在每個核心上運行。使用Remoteproc提供生命周期管理,其中一個核心被指定為“主”。內(nèi)核間通信使用RPMsg進行管理,RPMsg在內(nèi)核之間提供基于通道的雙向通信鏈路。
使用多核框架的替代方法是部署管理程序。這是一個強大的選項,但受限于它要求所有 CPU 都是相同的,因此它只能在同構(gòu)多核平臺上使用。然而,在一個復(fù)雜的多核系統(tǒng)中,可能有一組相同的核可以使用 SMP 操作系統(tǒng)或管理程序進行管理,并使用多核框架鏈接到系統(tǒng)的其余部分。
審核編輯:郭婷
-
嵌入式
+關(guān)注
關(guān)注
5198文章
20442瀏覽量
333972 -
cpu
+關(guān)注
關(guān)注
68文章
11277瀏覽量
224942 -
操作系統(tǒng)
+關(guān)注
關(guān)注
37文章
7401瀏覽量
129279
發(fā)布評論請先 登錄
米爾RK3506核心板SDK重磅升級,解鎖三核A7實時控制新架構(gòu)
使用CW32 MCU來實現(xiàn)UART串口通信與GPIO控制
【玩轉(zhuǎn)多核異構(gòu)】T153核心板RISC-V核的實時性應(yīng)用解析
從微秒級響應(yīng)到確定性延遲:深入解析米爾全志T536核心板的實時性技術(shù)突破
深入解析米爾全志T536核心板的實時性技術(shù)突破
通過采用先進組件滿足汽車設(shè)計不斷發(fā)展的要求
使用Simcenter STAR-CCM+進行拓撲優(yōu)化:生成理想的增材制造設(shè)計,盡早滿足工程要求
ArkUI-X框架LogInterface使用指南
睿擎多核 SMP 開發(fā):極簡開發(fā),超強性能——睿擎派開發(fā)板0元試用
使用OpenAMP多核框架來滿足控制和通信要求
評論