在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

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

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

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

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

圖1 HarmonyOS整體框架

本期,我們要重點給大家講一講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)的對接。

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

本期要為大家介紹的就是HarmonyOS內(nèi)核組件的三項核心技術(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)在用于手機、平板等的交互式內(nèi)核相比,它們的設(shè)計理念和資源管理方式有所不同。以CPU資源為例,傳統(tǒng)的Linux內(nèi)核存在以下典型問題:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

從內(nèi)存分配角度看,現(xiàn)在的操作系統(tǒng)基本采用統(tǒng)一接口的分配方式,使得手機里面多個進程或多個業(yè)務(wù)會共用一塊內(nèi)存區(qū)域。數(shù)據(jù)回收時,會頻繁出現(xiàn)數(shù)據(jù)搬移,以及內(nèi)存震蕩的現(xiàn)象。這個現(xiàn)象會加重內(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)用的整個生命周期,并結(jié)合應(yīng)用生命周期以及周期內(nèi)的數(shù)據(jù)訪問特征,對每一塊內(nèi)存數(shù)據(jù)做合理的內(nèi)存管理。同時,為了降低內(nèi)核管理內(nèi)存的開銷,我們提出了自研的壓縮體系,包括多線程壓縮、自研的壓縮算法。為了進一步擴大可用空間,我們在Flash器件上開出了一塊可交換區(qū),結(jié)合自研的聚合換出和內(nèi)存標(biāo)記技術(shù),充分利用Flash器件的性能。

經(jīng)過試驗, Hyperhold內(nèi)存管理引擎可以讓應(yīng)用在后臺的駐留能力提升50%以上,用戶可以明顯感知到后臺應(yīng)用的保活率有大幅提升。

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

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

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

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

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

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

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

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

隨機讀性能平均提升20%。

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

升級包大小下降約5%-10%,升級時間縮短約20%。

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

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

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

文件類型聚合

高效的緩存管理

批處理接口

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

高效傳輸

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

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

五、未來演進方向

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

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

圖8 未來演進方向

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

責(zé)任編輯:haq

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

    關(guān)注

    37

    文章

    7101

    瀏覽量

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

    關(guān)注

    183

    文章

    2639

    瀏覽量

    67745
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2056

    瀏覽量

    32199

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

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

收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    第三屆大會回顧第2期 | HarmonyOS NEXT內(nèi)核驅(qū)動生態(tài)兼容與競爭力思考

    隨著HarmonyOS NEXT生態(tài)和技術(shù)的發(fā)展,驅(qū)動框架作為北向和南向的生態(tài)中樞,有很多的機會。例如,提供更多的信息到應(yīng)用,實現(xiàn)精準(zhǔn)的性能功耗控制;打破傳統(tǒng)的分層解耦,簡化關(guān)鍵協(xié)議、關(guān)鍵路徑等等。
    的頭像 發(fā)表于 05-19 19:17 ?438次閱讀
    第三屆大會回顧第2期 | <b class='flag-5'>HarmonyOS</b> NEXT<b class='flag-5'>內(nèi)核</b>驅(qū)動生態(tài)兼容與競爭力思考

    RK3568開發(fā)板內(nèi)核模塊實現(xiàn)-編寫 Makefile

    ;lt;文件>:將指定的文件(需要是以.o 結(jié)尾)設(shè)為編譯時以模塊形式編譯 第 4 行是設(shè)備樹內(nèi)核的源碼路徑,請大家根據(jù)實際內(nèi)核路徑進行修改。 第 5 行是獲取當(dāng)前目錄的變量 第 7 行
    發(fā)表于 04-24 13:36

    8是分水嶺?揭秘高難度PCB的核心標(biāo)準(zhǔn)

    多少PCB才算高難度?捷多邦小編揭秘分層背后的技術(shù)博弈在智能硬件飛速迭代的今天,PCB層數(shù)已從簡單的雙面板一路飆升至100以上。但行業(yè)共識是:當(dāng)PCB突破8時,才算真正邁入“高難
    的頭像 發(fā)表于 03-04 18:03 ?514次閱讀

    【技術(shù)分享】迅RK3568開發(fā)板使用TFTP加載內(nèi)核設(shè)備樹

    【技術(shù)分享】迅RK3568開發(fā)板使用TFTP加載內(nèi)核設(shè)備樹
    的頭像 發(fā)表于 02-21 14:04 ?590次閱讀
    【技術(shù)分享】迅<b class='flag-5'>為</b>RK3568開發(fā)板使用TFTP加載<b class='flag-5'>內(nèi)核</b>設(shè)備樹

    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 ?986次閱讀
    <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)勢(點擊回顧)。本文將繼續(xù)這一話題,重點介紹CAN XL網(wǎng)絡(luò)在實際應(yīng)用中的組合與兼容性問題,以及如何選擇合適的物理
    的頭像 發(fā)表于 11-29 15:27 ?656次閱讀
    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)的最新成果,不僅全面升級了系統(tǒng)內(nèi)核,實現(xiàn)了跨設(shè)備無縫協(xié)同,
    的頭像 發(fā)表于 09-24 15:41 ?1319次閱讀
    華為<b class='flag-5'>HarmonyOS</b> NEXT 10月8日開啟公測

    LDO噪聲揭秘

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

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

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

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

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

    RT-Thread內(nèi)部機制大揭秘,帶你深入操作系統(tǒng)內(nèi)核

    能夠適應(yīng)資源受限的嵌入式環(huán)境,通過高效的內(nèi)核設(shè)計和資源管理,設(shè)備節(jié)省寶貴的系統(tǒng)資源。其小巧的內(nèi)核可以在極小的存儲空間中運行,小型設(shè)備提供了可靠的操作系統(tǒng)選擇。實
    的頭像 發(fā)表于 08-01 08:11 ?4908次閱讀
    RT-Thread內(nèi)部機制大<b class='flag-5'>揭秘</b>,帶你深入操作系統(tǒng)<b class='flag-5'>內(nèi)核</b>

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

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

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

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

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

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

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

    EMC大揭秘 PCB設(shè)計必備指南
    的頭像 發(fā)表于 06-15 16:29 ?3424次閱讀
    EMC大<b class='flag-5'>揭秘</b> PCB設(shè)計必備指南
    主站蜘蛛池模板: 狠狠干狠狠鲁 | 色婷婷六月天 | 天天操天天干天天射 | 欧美a性| 簧片免费视频 | 天天躁夜夜躁狠狠躁2021a | 99国产福利| 色哥网站 | 亚洲电影天堂网 | 国产在线啪 | 高h污快穿文汁水四溅 | 手机在线完整视频免费观看 | 久久午夜免费视频 | 天天色综合1| 国产在线视欧美亚综合 | 国产成人精品本亚洲 | 天天摸夜夜摸夜夜狠狠摸 | 成年人污视频 | 嫩草影院永久入口在线观看 | 国产亚洲精品成人a在线 | 四虎影院最新网站 | 色综合视频一区二区三区 | 四虎永久精品免费网址大全 | 91福利社在线观看 | 中文字幕亚洲一区 | 午夜宅男在线 | 亚洲国产成人久久精品图片 | 深夜视频免费在线观看 | 婷婷色九月综合激情丁香 | 性视频亚洲| 久久精品乱子伦观看 | 亚洲视频一区二区在线观看 | 办公室桌震娇喘视频大全在线 | 亚洲 欧美 成人 | 资源在线www天堂 | 人人爽人人爱 | 夜色爽爽 | 一级毛片一级毛片一级毛片aa | 久久久精品免费观看 | 亚洲www美色 | 日本在线观看成人小视频 |