主流CPU架構(gòu)全適配 OpenCloudOS源社區(qū)內(nèi)核新增RISC-V架構(gòu)支持
OCKS目前已實(shí)現(xiàn)對主流CPU架構(gòu)的全適配。
近日,OpenCloudOS 社區(qū)推出 OpenCloudOS Kernel Stream (以下簡稱為 OCKS) 2207.2 內(nèi)核版本,新版本中增加了對 RISC-V 64 架構(gòu)的支持。這也意味著,OCKS目前已實(shí)現(xiàn)對主流CPU架構(gòu)的全適配。
作為新一代開源精簡指令集(RISC)架構(gòu),近年來RISC-V在半導(dǎo)體領(lǐng)域備受關(guān)注。得益于其完全開放、免費(fèi)授權(quán)、低成本研發(fā)、精簡靈活等特性,RISC-V生態(tài)正逐漸起步,也被視為繼x86、Arm后的第三大CPU架構(gòu)。
OpenCloudOS 是由操作系統(tǒng)、云平臺(tái)、軟硬件廠商與開發(fā)者等共同倡議發(fā)起的全鏈路國產(chǎn)化開源操作系統(tǒng),沉淀了騰訊及多家廠商在技術(shù)和開源生態(tài)方面的優(yōu)勢。自社區(qū)成立以來,OpenCloudOS 一直在積極建設(shè)硬件及芯片支持生態(tài)。其中,適配國產(chǎn)“芯”的RSIC-V架構(gòu),從一開始就列為 OpenCloudOS 硬件支持計(jì)劃中的重點(diǎn)項(xiàng)目。
在保持了 L1 (源社區(qū))項(xiàng)目的上游即時(shí)性與友好性的同時(shí),OCKS 在 5.18 內(nèi)核版本基礎(chǔ)上,對上游所欠缺的一些最新的 RISC-V 平臺(tái)特性增加了適配和支持。其中,OCKS 特別對 StarFive VisionFive 開發(fā)板進(jìn)行了測試適配,從而讓 OpenCloudOS 社區(qū)在提供穩(wěn)定而可靠的企業(yè)級(jí)內(nèi)核的同時(shí),更可以支持體驗(yàn)到最新的業(yè)界開源硬件。
技術(shù)實(shí)現(xiàn)細(xì)節(jié)如下
驗(yàn)證環(huán)境
硬件環(huán)境:VisionFive RISC-V 開發(fā)板
VisionFive 開發(fā)板是一塊高性價(jià)比的,支持 Linux 系統(tǒng)的 RISC-V 單板計(jì)算機(jī)。SoC 為 JH7100 芯片,提供了雙核 64 位 1.5 GHz RISC-V CPU,2MB 二級(jí)緩存,并帶有深度學(xué)習(xí)處理引擎及圖像視頻處理系統(tǒng),為 RISC-V 開源架構(gòu)生態(tài)提供了更高的水平開發(fā)套件,讓開發(fā)者得到更大的自由及更強(qiáng)的能力去創(chuàng)新和設(shè)計(jì)行業(yè)領(lǐng)先的解決方案。
軟件環(huán)境:OCKS 2207,F(xiàn)edora 33 RISC-V版 runtime,GCC 12
VisionFive 官方鏡像目前以 Fedora 33 為基礎(chǔ),官方默認(rèn)使用下游內(nèi)核 5.10 作為默認(rèn)版本進(jìn)行引導(dǎo)。啟動(dòng)過程為 uboot -> grub2 -> kernel。其中 grub2 會(huì)將 device-tree 與 initramfs 加載并傳遞給內(nèi)核。
我們使用官方鏡像為基礎(chǔ),并使用上游 GCC 12 進(jìn)行交叉編譯,進(jìn)行了 OCKS 2207 的編譯與運(yùn)行測試。
適配步驟
1、OCKS 2207對 RISC-V 的適配
OpcnCloudOS Kernel Stream 在發(fā)布之初,便為多架構(gòu)、多平臺(tái)支持而進(jìn)行了構(gòu)建與發(fā)布系統(tǒng)的優(yōu)化設(shè)計(jì)。在經(jīng)過了第一個(gè)版本的沉淀與積累后,我們正式將 OpenCloudOS Stream 2207 的支持拓展到 RISC-V 架構(gòu)。從而使得 OCKS 同時(shí)支持三大架構(gòu):x86_64,aarch64,RISC-V64。
在 2207.2 中,OpenCloudOS Kernel Stream 在上游軟件基礎(chǔ)上,增加了針對 RISC-V 架構(gòu)進(jìn)行發(fā)布和構(gòu)建,以及功能支持的相關(guān)代碼。針對 StarFive 開發(fā)板,我們進(jìn)行了大量適配工作,增加板級(jí)支持,對硬件驅(qū)動(dòng)等,進(jìn)行了實(shí)際驗(yàn)證和測試。同時(shí)最大程度保持了代碼的一致性,在同源的基礎(chǔ)上,異構(gòu)地發(fā)布多個(gè)不同軟件包,保持了上游友好的管理風(fēng)格,易于維護(hù)的代碼結(jié)構(gòu),以及良好的下游支持。
同時(shí)為了緩解資源緊張與加速迭代,我們的構(gòu)建系統(tǒng)提供了完成的開箱即用式交叉編譯支持,可以異構(gòu)地進(jìn)行版本發(fā)布,管理,kABI 驗(yàn)證,RPM 打包等過程,將開發(fā),維護(hù),學(xué)習(xí)成本降到最低。
技術(shù)細(xì)節(jié)
OCKS 2207 現(xiàn)在可以通過單一入口,控制 ARCH 參數(shù)來生成不同架構(gòu)對應(yīng)的 RPM 包。并且在進(jìn)行異構(gòu)構(gòu)建的時(shí)候,自動(dòng)切換為交叉編譯模式。
OCKS 2207 構(gòu)建 RISC V 版本內(nèi)核只需在 Kernel Repo 中調(diào)用如下命令即可:
make dist-rpm ARCH=RISC-V64
生成的 RPM 包默認(rèn)包含所有支持設(shè)備的 device tree,vmlinuz,調(diào)試信息等,和普通編譯基本無異。
2、在 VisionFive RISC-V 開發(fā)板上使用 OCKS 內(nèi)核
OCKS 針對 RISC-V 會(huì)發(fā)布標(biāo)準(zhǔn)的 RPM 包裹。其中內(nèi)核會(huì)安裝到標(biāo)準(zhǔn)的路徑中,并且將 Device Tree 與內(nèi)核捆綁在一起發(fā)布。
VisionFive 官方提供了 基于 Fedora 的系統(tǒng)鏡像。OCKS 便是在此基礎(chǔ)上進(jìn)行了測試與適配。
若要體驗(yàn) OCKS,在官方 Fedora 鏡像基礎(chǔ)上安裝 OCKS RPM 包,并對 bootloader 進(jìn)行手動(dòng)配置即可。OCKS 安裝路徑均為標(biāo)準(zhǔn)路徑。
由于不同開發(fā)板并沒有十分統(tǒng)一的啟動(dòng)引導(dǎo)機(jī)制,在內(nèi)核安裝后,用戶需要手動(dòng)配置引導(dǎo)選項(xiàng)。
技術(shù)細(xì)節(jié)
OCKS 2207 由兩個(gè)包組成,kernel-core 與 kernel-modules。開發(fā)板作為物理邊緣設(shè)備,需要安裝兩個(gè)包。OCKS 2207 安裝后會(huì)在 /boot 下生成對應(yīng)的 kernel vmlinuz 與 initramfs。與官方內(nèi)核一樣,用戶需要手動(dòng)配置 grub.cfg,增加如下引導(dǎo)選項(xiàng):
menuentry 'OCKS 2207' {
linux /vmlinuz-5.18.15-2207.2.0.ocks
devicetree
initrd /initramfs-5.18.15-2207.2.0.ocks.fc33.img
}
其中 <> 內(nèi)的內(nèi)容用戶需酌情填寫。最新的 device tree 也會(huì)在 /usr/lib/modules/5.18.15-2207.2.0.ocks/dtbs 中提供,用戶可酌情升級(jí)。
3、OCKS RISC-V運(yùn)行效果
在 Starfive 雙核 8G 系統(tǒng)上,OCKS 可以很好的與官方 Fedora 鏡像一起運(yùn)行,如下:
發(fā)布 OCKS 2207.2,添加針對RISC-V支持
源代碼 Rebase 到上游 5.18.15。
RISC-V 平臺(tái) DMA 相關(guān)功能和兼容性問題進(jìn)行補(bǔ)全和修復(fù)。
拓展構(gòu)建系統(tǒng),支持 RISC-V 架構(gòu)。
增加 StarFive VisionFive 開發(fā)板原生支持。
修復(fù)一些潛在的發(fā)行版兼容性問題。
OpenCloudOS Stream 2207.2 相關(guān)鏈接
源代碼倉庫:https://gitee.com/OpenCloudOS/OpenCloudOS-Kernel-Stream
RPM Repo:Index of /opencloudos/8/kernel-ocks/2207.2/
RISC-V64版下載地址:Index of /opencloudos/8/kernel-ocks/2207.2/riscv64/
后續(xù)規(guī)劃
目前 VisionFive 相關(guān)外設(shè)的大量驅(qū)動(dòng)仍舊在上游討論中,我們暫時(shí)使用了 StarFive 的下游版本。我們會(huì)持續(xù)跟蹤其上游動(dòng)向,及時(shí)同步相關(guān)組件代碼。
對于 RISC-V 整體架構(gòu)框架,上游成熟度也并不高,其中很多細(xì)節(jié)仍舊需要上游的打磨和開發(fā)。我們采用了保留最大兼容的模式適配了 VisionFive 開發(fā)板。待上游有進(jìn)一步進(jìn)展后,我們會(huì)在 rebase 時(shí)對現(xiàn)有相關(guān)下游代碼進(jìn)行整理,清理,保持和上游一致。
同時(shí) RISC-V 和其它更多架構(gòu)生態(tài)也在持續(xù)豐富中,通過對 RISC-V 進(jìn)行適配,也更進(jìn)一步驗(yàn)證了 OCKS 的跨架構(gòu)進(jìn)行開發(fā),發(fā)布,構(gòu)建的系統(tǒng)潛力。日后會(huì)對更多架構(gòu)和硬件提供支持。
最后,記得關(guān)注微信公眾號(hào):鎂客網(wǎng)(im2maker),更多干貨在等你!
硬科技產(chǎn)業(yè)媒體
關(guān)注技術(shù)驅(qū)動(dòng)創(chuàng)新
