0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為大家揭秘HarmonyOS的內(nèi)核層

電子發(fā)燒友開源社區(qū) ? 來源:HarmonyOS開發(fā)者 ? 作者:jikecheng,miaoxie ? 2021-11-06 09:28 ? 次閱讀

HarmonyOS整體框架分為四個(gè)層級(jí),如圖1所示。從上到下,依次為:第一層是應(yīng)用層,主要涵蓋系統(tǒng)應(yīng)用、Launcher、設(shè)置,以及三方應(yīng)用。第二層是框架層,提供基礎(chǔ)UI框架、用戶程序框架以及能力模塊框架。第三層是系統(tǒng)服務(wù)層,讓HarmonyOS具有分布式流轉(zhuǎn)負(fù)載的能力。大家看到的高速多設(shè)備協(xié)同能力就是由該層級(jí)提供。而承載整個(gè)操作系統(tǒng),同時(shí)發(fā)揮芯片算力的基石就沉淀在第四層——內(nèi)核層。宏觀來說,內(nèi)核的主要工作包含芯片資源管理、軟件任務(wù)調(diào)度,以及銜接用戶空間與系統(tǒng)調(diào)用能力。

68396112-3e41-11ec-82a9-dac502259ad0.png

圖1 HarmonyOS整體框架

本期,我們要重點(diǎn)給大家講一講HarmonyOS的內(nèi)核層。

一、HarmonyOS內(nèi)核構(gòu)成

為了支撐HarmonyOS在多設(shè)備、多場景下的性能表現(xiàn),內(nèi)核主要由三部分組成,如下圖所示:

6869456c-3e41-11ec-82a9-dac502259ad0.png

圖2 內(nèi)核的組成

HarmonyOS內(nèi)核組件:具有智慧化資源管理能力的內(nèi)核組件,包括CPU/GPU資源管理,內(nèi)存管理,IO調(diào)度管理以及高效的文件系統(tǒng)等。

標(biāo)準(zhǔn)的Linux內(nèi)核:兼容了LTS Linux主線版本,做好外圍生態(tài)的對(duì)接。

硬件平臺(tái)BSP:面向各種不同芯片與硬件平臺(tái)(包含1+8+N的多種設(shè)備)的BSP(board support package,板級(jí)支撐包)基礎(chǔ)能力。

本期要為大家介紹的就是HarmonyOS內(nèi)核組件的三項(xiàng)核心技術(shù):高能效CPU資源調(diào)度、Hyperhold內(nèi)存管理引擎和高效的文件系統(tǒng)。下面為大家一一揭曉~

二、高能效CPU資源調(diào)度

業(yè)界多數(shù)的操作系統(tǒng)都是基于標(biāo)準(zhǔn)的Linux內(nèi)核開發(fā)的。傳統(tǒng)的Linux內(nèi)核,早期用于服務(wù)器和PC設(shè)備,與我們現(xiàn)在用于手機(jī)、平板等的交互式內(nèi)核相比,它們的設(shè)計(jì)理念和資源管理方式有所不同。以CPU資源為例,傳統(tǒng)的Linux內(nèi)核存在以下典型問題:

1. 同優(yōu)先級(jí)的業(yè)務(wù)過多,每次調(diào)度都不一定選擇到關(guān)鍵進(jìn)程。

傳統(tǒng)的Linux內(nèi)核偏向于在多用戶的場景下公平地分配資源。比較明顯的特征是,多個(gè)用戶并發(fā)訪問,并發(fā)使用公共資源。由于同優(yōu)先級(jí)的業(yè)務(wù)比較多,每次任務(wù)調(diào)度不一定能夠選擇到關(guān)鍵進(jìn)程。舉個(gè)例子,當(dāng)設(shè)備后臺(tái)存在多個(gè)應(yīng)用或者服務(wù)任務(wù)時(shí),系統(tǒng)中和用戶交互最敏感的渲染任務(wù)沒法即時(shí)得到調(diào)度資源,導(dǎo)致設(shè)備會(huì)高概率出現(xiàn)使用不流暢或者點(diǎn)擊無響應(yīng)的現(xiàn)象,也就是咱們平時(shí)常說的隨機(jī)卡頓。

2. 選擇最優(yōu)能效的CPU資源時(shí)間過長,CPU資源選擇過度。

傳統(tǒng)的Linux內(nèi)核選擇算力的流程,是一個(gè)慢速爬坡的過程。任務(wù)調(diào)度必須經(jīng)過選擇CPU核簇、負(fù)載均衡、選擇頻點(diǎn)等一系列流程。其漫長的過程,極易導(dǎo)致任務(wù)調(diào)度錯(cuò)過調(diào)度窗口,出現(xiàn)算力供給不足的現(xiàn)象。

為了解決以上問題,HarmonyOS內(nèi)核提供了全棧式的調(diào)度框架,如下圖所示:

68b766e8-3e41-11ec-82a9-dac502259ad0.png

圖3 HarmonyOS調(diào)度管理框架

HarmonyOS調(diào)度管理框架有以下特點(diǎn):

任務(wù)按優(yōu)先級(jí)調(diào)度

對(duì)現(xiàn)有系統(tǒng)任務(wù)進(jìn)行嚴(yán)格級(jí)別劃分,在線標(biāo)記與用戶的操作體驗(yàn)直接相關(guān)的關(guān)鍵進(jìn)程和關(guān)聯(lián)任務(wù),優(yōu)先調(diào)度關(guān)鍵任務(wù)。

依據(jù)CPU負(fù)載情況選擇最優(yōu)任務(wù)分配

我們會(huì)動(dòng)態(tài)檢測不同CPU的負(fù)載,保證當(dāng)前CPU有足夠的算力提供。

選擇最優(yōu)頻點(diǎn)實(shí)現(xiàn)高能效

我們提供了頻點(diǎn)與性能、功耗之間的帕累托最優(yōu)模型。每次任務(wù),我們都能夠快速選擇系統(tǒng)最優(yōu)的頻點(diǎn)組合方式,實(shí)現(xiàn)最優(yōu)能效。

經(jīng)過試驗(yàn),HarmonyOS的全棧式調(diào)度框架可以幫助用戶獲得在多場景(尤其是游戲場景)下持續(xù)且穩(wěn)定的高幀率體驗(yàn)。

三、Hyperhold內(nèi)存管理引擎

對(duì)于內(nèi)存管理,由于開源生態(tài)的不限制,導(dǎo)致應(yīng)用開發(fā)的內(nèi)存使用野蠻生長。設(shè)備長時(shí)間使用后,可回收內(nèi)存越來越低。產(chǎn)生這個(gè)問題的原因有兩個(gè):

1. 傳統(tǒng)內(nèi)存數(shù)據(jù)冷熱管理,無法感知業(yè)務(wù)特性

盡管Linux內(nèi)核提供了很多的內(nèi)存回收機(jī)制,然而每種內(nèi)存回收都會(huì)有相應(yīng)的系統(tǒng)代價(jià)。比如,回收文件頁面后,如果系統(tǒng)需要二次加載這部分?jǐn)?shù)據(jù),需要從底層器件Flash里面把數(shù)據(jù)讀回來,這會(huì)引起Flash隨機(jī)IO讀的現(xiàn)象。對(duì)IO操作來說,F(xiàn)lash器件速度和當(dāng)前讀取任務(wù)是隨機(jī)讀還是順序讀有著很強(qiáng)的相關(guān)性,隨機(jī)讀容易導(dǎo)致系統(tǒng)隨機(jī)卡頓。再比如,回收匿名頁面后,如果系統(tǒng)需要二次加載這部分?jǐn)?shù)據(jù),會(huì)觸發(fā)ZRAM解壓,消耗CPU。

另外,由于應(yīng)用的內(nèi)存負(fù)載越來越重,當(dāng)系統(tǒng)冷熱數(shù)據(jù)識(shí)別不恰當(dāng),會(huì)導(dǎo)致系統(tǒng)的CPU負(fù)載長期處于高負(fù)載狀態(tài),最終影響前臺(tái)應(yīng)用的基礎(chǔ)性能。

2. 傳統(tǒng)共享式內(nèi)存分配,無法感知數(shù)據(jù)重要性

從內(nèi)存分配角度看,現(xiàn)在的操作系統(tǒng)基本采用統(tǒng)一接口的分配方式,使得手機(jī)里面多個(gè)進(jìn)程或多個(gè)業(yè)務(wù)會(huì)共用一塊內(nèi)存區(qū)域。數(shù)據(jù)回收時(shí),會(huì)頻繁出現(xiàn)數(shù)據(jù)搬移,以及內(nèi)存震蕩的現(xiàn)象。這個(gè)現(xiàn)象會(huì)加重內(nèi)核管理內(nèi)存的開銷。

為了解決傳統(tǒng)Linux內(nèi)核的內(nèi)存問題,HarmonyOS提供了Hyperhold內(nèi)存管理引擎。Hyperhold內(nèi)存管理引擎打通了上層系統(tǒng)到內(nèi)核的調(diào)用棧,讓內(nèi)核完整感知到應(yīng)用的整個(gè)生命周期,并結(jié)合應(yīng)用生命周期以及周期內(nèi)的數(shù)據(jù)訪問特征,對(duì)每一塊內(nèi)存數(shù)據(jù)做合理的內(nèi)存管理。同時(shí),為了降低內(nèi)核管理內(nèi)存的開銷,我們提出了自研的壓縮體系,包括多線程壓縮、自研的壓縮算法。為了進(jìn)一步擴(kuò)大可用空間,我們?cè)贔lash器件上開出了一塊可交換區(qū),結(jié)合自研的聚合換出和內(nèi)存標(biāo)記技術(shù),充分利用Flash器件的性能。

經(jīng)過試驗(yàn), Hyperhold內(nèi)存管理引擎可以讓應(yīng)用在后臺(tái)的駐留能力提升50%以上,用戶可以明顯感知到后臺(tái)應(yīng)用的?;盥视写蠓嵘?。

四、高效的文件系統(tǒng)

存儲(chǔ)處于整個(gè)緩存體系下的最慢路徑,容易成為系統(tǒng)性能瓶頸。不僅如此,由于存儲(chǔ)器件碎片化的問題,存儲(chǔ)還容易出現(xiàn)越用越慢的難題。其次,隨著系統(tǒng)的發(fā)展,系統(tǒng)占用存儲(chǔ)越來越多。而在多設(shè)備流轉(zhuǎn)的場景下,分布式文件系統(tǒng)的高效轉(zhuǎn)存能力顯得尤為重要。為應(yīng)對(duì)上述問題,HarmonyOS提供了高效的自研文件系統(tǒng)體系。從第一代的eF2FS到最新的HMDFS,文件系統(tǒng)逐步解決了碎片化問題、容量問題與多設(shè)備流轉(zhuǎn)問題。

下面我們從第一代的eF2FS到最新的HMDFS,依次介紹HarmonyOS文件系統(tǒng)的技術(shù)特點(diǎn)。

1. 第1代數(shù)據(jù)盤eF2FS:智能感知空間管理,改善越用越慢

面對(duì)存儲(chǔ)越用越慢的業(yè)界難題,我們通過數(shù)據(jù)類型感知的多流算法和空間感知的分配算法,減少碎片產(chǎn)生。同時(shí),通過高效、業(yè)務(wù)感知的兩層智能垃圾空間回收,實(shí)現(xiàn)智能感知空間管理。

2. 系統(tǒng)盤EROFS:變長壓縮,支持壓縮與性能雙贏

針對(duì)系統(tǒng)占用存儲(chǔ)越來越多的問題,業(yè)界其他操作系統(tǒng)也采取過改進(jìn)措施,比如squashfs采用“定長輸入,變長輸出”的壓縮策略,但會(huì)存在讀放大的問題。而我們的EROFS(Extendable Read-Only File System,超級(jí)文件系統(tǒng))采用“變長輸入,定長輸出”的壓縮策略,盡可能地將不等長的文件塊壓縮成一個(gè)等長的存儲(chǔ)塊進(jìn)行存儲(chǔ)。這樣,我們?cè)L問任何文件塊,只需讀取一個(gè)存儲(chǔ)塊,減少了無效讀取。除此之外,我們?cè)诮鈮盒阅芎虸O流程上也做了優(yōu)化。

通過以上關(guān)鍵技術(shù),系統(tǒng)盤EROFS的性能得到大幅提升:

隨機(jī)讀性能平均提升20%。

系統(tǒng)初始空間相比Ext4節(jié)省2GB,相當(dāng)于用戶可以多存1000張照片或500首歌曲。

升級(jí)包大小下降約5%-10%,升級(jí)時(shí)間縮短約20%。

3. 跨設(shè)備HMDFS:“批流”結(jié)合的分布式文件系統(tǒng)

HarmonyOS同一套系統(tǒng)能力、適配多種終端形態(tài)的分布式理念,就要求我們有一套數(shù)據(jù)流轉(zhuǎn)的底座——分布式文件系統(tǒng)HMDFS。

應(yīng)對(duì)多設(shè)備流轉(zhuǎn),HMDFS提供了多種文件系統(tǒng)能力,包括:

文件類型聚合

高效的緩存管理

批處理接口

分布式的權(quán)限管控

高效傳輸

數(shù)據(jù)一致性管理

通過上述一系列技術(shù)的研發(fā)與集成,最終實(shí)現(xiàn)了現(xiàn)有的跨設(shè)備高效文件系統(tǒng),為用戶提供流暢的分布式體驗(yàn)。

五、未來演進(jìn)方向

上面就是我們本期要介紹的HarmonyOS內(nèi)核核心技術(shù)內(nèi)容了。未來還有很多方向值得我們繼續(xù)探索,下圖列出了HarmonyOS內(nèi)核的未來演進(jìn)方向。

6a6e91a0-3e41-11ec-82a9-dac502259ad0.png

圖8 未來演進(jìn)方向

相信經(jīng)過我們不斷的探索,我們能打造出更好的內(nèi)核,為大家提供更流暢、體驗(yàn)更好的HarmonyOS!

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6859

    瀏覽量

    123498
  • 鴻蒙系統(tǒng)
    +關(guān)注

    關(guān)注

    183

    文章

    2637

    瀏覽量

    66505
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1980

    瀏覽量

    30326

原文標(biāo)題:HDC2021技術(shù)分論壇:HarmonyOS內(nèi)核技術(shù)大揭秘!

文章出處:【微信號(hào):HarmonyOS_Community,微信公眾號(hào):電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    HarmonyOS開發(fā)指導(dǎo)類文檔更新速遞(下)

    伴隨著HarmonyOS 5.0.0 Release、HarmonyOS 5.0.1 Release版本的發(fā)布,HarmonyOS官網(wǎng)文檔也帶來了不少上新內(nèi)容。本期HarmonyOS
    的頭像 發(fā)表于 12-30 09:54 ?154次閱讀
    <b class='flag-5'>HarmonyOS</b>開發(fā)指導(dǎo)類文檔更新速遞(下)

    CAN XL物理揭秘(下):物理組合與兼容性

    CAN XL網(wǎng)絡(luò)憑借物理革新,在汽車電子和工業(yè)通信中占據(jù)重要地位。在上篇中,我們深入探討了CAN XL網(wǎng)絡(luò)中的物理革新與優(yōu)勢(shì)(點(diǎn)擊回顧)。本文將繼續(xù)這一話題,重點(diǎn)介紹CAN XL網(wǎng)絡(luò)在實(shí)際應(yīng)用中的組合與兼容性問題,以及如何選擇合適的物理
    的頭像 發(fā)表于 11-29 15:27 ?244次閱讀
    CAN XL物理<b class='flag-5'>層</b><b class='flag-5'>揭秘</b>(下):物理<b class='flag-5'>層</b>組合與兼容性

    華為HarmonyOS NEXT 10月8日開啟公測

    華為宣布,萬眾矚目的HarmonyOS NEXT操作系統(tǒng)將于10月8日正式開啟公測,標(biāo)志著這一創(chuàng)新力作即將與廣大用戶見面。HarmonyOS NEXT作為華為自研操作系統(tǒng)的最新成果,不僅全面升級(jí)了系統(tǒng)內(nèi)核,實(shí)現(xiàn)了跨設(shè)備無縫協(xié)同,
    的頭像 發(fā)表于 09-24 15:41 ?839次閱讀
    華為<b class='flag-5'>HarmonyOS</b> NEXT 10月8日開啟公測

    LDO噪聲揭秘

    電子發(fā)燒友網(wǎng)站提供《LDO噪聲揭秘.pdf》資料免費(fèi)下載
    發(fā)表于 09-21 09:13 ?0次下載
    LDO噪聲<b class='flag-5'>揭秘</b>

    為了學(xué)習(xí)內(nèi)核開發(fā),大佬手搓了一個(gè)輕量級(jí)操作系統(tǒng)YiYiYa OS

    RISC-V內(nèi)核芯片,所有移植教程及方法都在Github上公開。 gmenu2x:輕量級(jí)菜單桌面 gnuboy模擬器 系統(tǒng)架構(gòu) 架構(gòu)從上而下分層設(shè)計(jì),同一從左到右模塊。越下層與用戶離得遠(yuǎn),就會(huì)變得越
    發(fā)表于 08-30 14:57

    為了學(xué)習(xí)內(nèi)核開發(fā),大佬手搓了一個(gè)輕量級(jí)操作系統(tǒng)YiYiYa OS

    應(yīng)用和常用庫,對(duì)應(yīng)源碼目錄app。 應(yīng)用 應(yīng)用直接和用戶操作打交道。有圖形界面和shell命令交互。此層面對(duì)用戶開發(fā)應(yīng)用和常用庫,對(duì)應(yīng)源碼目錄app。 接口
    發(fā)表于 08-27 10:08

    PCB多層板為什么都是偶數(shù)?奇數(shù)不行嗎?

    一站式PCBA智造廠家今天大家講講pcb疊設(shè)計(jì)偶數(shù)的原因有哪些?PCB疊設(shè)計(jì)
    的頭像 發(fā)表于 07-03 09:36 ?610次閱讀

    歡創(chuàng)播報(bào) 華為宣布鴻蒙內(nèi)核已超越Linux內(nèi)核

    1 華為宣布鴻蒙內(nèi)核已超越Linux內(nèi)核 ? 6月21日,在華為開發(fā)者大會(huì)上, HarmonyOS NEXT(鴻蒙NEXT)——真正獨(dú)立于安卓和iOS的鴻蒙操作系統(tǒng),正式登場。這是Harmon
    的頭像 發(fā)表于 06-27 11:30 ?872次閱讀

    直線電機(jī)生產(chǎn)廠家大家揭秘iPhone 16 Pro系列手機(jī)

    今年下半年,蘋果將會(huì)推出新款iPhone 16 Pro系列手機(jī),而每每新系列手機(jī)正式面世之前,外界對(duì)之都是充滿好奇,想提前知曉一二,本期, 直線電機(jī)生產(chǎn)廠家 小編就根據(jù)網(wǎng)絡(luò)目前流傳出的相關(guān)信息大家
    的頭像 發(fā)表于 06-19 08:23 ?820次閱讀
    直線電機(jī)生產(chǎn)廠家<b class='flag-5'>為</b><b class='flag-5'>大家</b><b class='flag-5'>揭秘</b>iPhone 16 Pro系列手機(jī)

    EMC大揭秘 PCB設(shè)計(jì)必備指南

    EMC大揭秘 PCB設(shè)計(jì)必備指南
    的頭像 發(fā)表于 06-15 16:29 ?3103次閱讀
    EMC大<b class='flag-5'>揭秘</b> PCB設(shè)計(jì)必備指南

    谷景揭秘貼片疊電感精度是不是越高越好

    谷景揭秘貼片疊電感精度是不是越高越好 編輯:谷景電子 貼片疊電感 是電子電路中非常重要的一種電感元件,它是通過磁環(huán)上繞制線圈來實(shí)現(xiàn)電感的作用。大家都知道的是,在電感線圈的精度等級(jí)是
    的頭像 發(fā)表于 05-15 15:48 ?346次閱讀

    揭秘共模電感選擇技巧

    電子發(fā)燒友網(wǎng)站提供《揭秘共模電感選擇技巧.docx》資料免費(fèi)下載
    發(fā)表于 03-29 14:36 ?0次下載

    HarmonyOS開發(fā)技術(shù)全面分析

    。 技術(shù)架構(gòu) HarmonyOS 整體遵從分層設(shè)計(jì),從下向上依次內(nèi)核、系統(tǒng)服務(wù)、框架
    發(fā)表于 02-21 16:31

    Ubuntu 24.04 LTS選用Linux 6.8默認(rèn)內(nèi)核

    關(guān)于Ubuntu 24.04 LTS使用何種內(nèi)核版本,一直備受關(guān)注。Canonical工程師Andrea Righi昨日宣布,Ubuntu 24.04將默認(rèn)搭載Linux 6.8內(nèi)核。
    的頭像 發(fā)表于 01-29 11:27 ?1176次閱讀

    鴻蒙OS 技術(shù)架構(gòu)

    HarmonyOS 整體遵從分層設(shè)計(jì),從下向上依次內(nèi)核、系統(tǒng)服務(wù)、框架和應(yīng)用
    的頭像 發(fā)表于 01-25 16:58 ?808次閱讀
    鴻蒙OS 技術(shù)架構(gòu)