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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

【OpenHarmony技術峰會】生態(tài)與互聯(lián)分論壇 | 梁開祝:OpenHarmony驅動開發(fā)實踐

D96C_HiHope ? 來源:未知 ? 2023-03-27 22:50 ? 次閱讀

在2月25日剛剛圓滿閉幕的首屆開放原子開源基金會OpenHarmony技術峰會(2023)生態(tài)與互聯(lián)分論壇上,潤和軟件旗下子公司江蘇潤開鴻數(shù)字科技有限公司(簡稱:潤開鴻)資深軟件開發(fā)工程師梁開祝發(fā)表了題為《OpenHarmony的驅動框架原理和實踐》的主題演講,從實踐角度重點講解了OpenHarmony驅動框架的具體實現(xiàn)細節(jié)和“一次開發(fā),多系統(tǒng)部署”的驅動開發(fā)實踐,幫助OpenHarmony設備驅動開發(fā)者深入理解驅動框架工作流程和工作細節(jié)。

6a284ad2-ccad-11ed-bfe3-dac502259ad0.jpg

技術背景

OpenHarmony引入全新驅動開發(fā)理念和框架

6a4d46d4-ccad-11ed-bfe3-dac502259ad0.png

OpenHarmony是一個面向萬物互聯(lián)/萬物智聯(lián)大場景的分布式操作系統(tǒng),它面對的是硬件性能和功能需求千差萬別的設備,比如智能手環(huán)與手機之間的硬件差異。為了統(tǒng)一適配能力差別巨大的設備,OpenHarmony設計了一個多內核的架構,能力弱的設備選用簡單的內核(如LiteOS)、能力強的設備選用復雜的內核(如Linux),這意味著生態(tài)圈中的硬件產(chǎn)品在系統(tǒng)內核層面上就存在巨大的差異。然而這些產(chǎn)品很有可能會用到相近甚至相同的外圍硬件,比如,家里的智能門禁系統(tǒng)、智能電視、平板電腦、手機上所使用的攝像頭模組都可能是同一個型號或同系列的,而在設備端運行不同內核的操作系統(tǒng),就需要為不同內核開發(fā)各自的驅動程序,這會造成驅動程序的復用性、可移植性、可維護性較差,不利于產(chǎn)品開發(fā)和維護,也不利于硬件生態(tài)圈的成長。

作為一個全新的操作系統(tǒng),OpenHarmony必須要開發(fā)一套更優(yōu)秀的驅動開發(fā)框架,幫助開發(fā)者、企業(yè)更便捷地開發(fā)和管理硬件設備的驅動程序,助力打造自己的硬件生態(tài)。OpenHarmony的驅動框架,采用C語言面向對象編程模型構建,通過平臺解耦、內核解耦,來達到兼容不同內核,統(tǒng)一平臺底座的目的,從而幫助開發(fā)者實現(xiàn)驅動一次開發(fā),多系統(tǒng)部署的效果。

6a693c0e-ccad-11ed-bfe3-dac502259ad0.png

OpenHarmony的內核子系統(tǒng)(多內核)與驅動子系統(tǒng)(統(tǒng)一的驅動框架)是松耦合的關系,僅通過一個OSAL(Operating System Abstraction Layer,操作系統(tǒng)抽象層)進行交互。OSAL只為驅動框架提供內核部分關鍵能力的抽象接口,而隱藏了接口在不同內核中的實現(xiàn)細節(jié)。驅動框架通過OSAL來適配不同的內核,而具體的設備則完全基于驅動框架提供的能力來實現(xiàn)驅動程序并通過HDI(Hardware Driver Interface,硬件驅動接口)對上層提供驅動服務,設備驅動完全不需要知道(也不會知道)自己運行在什么樣的內核之上。

技術干貨

OpenHarmony中的驅動框架實現(xiàn)詳解

代碼結構

6a8b1b8a-ccad-11ed-bfe3-dac502259ad0.png

圖為OpenHarmony的驅動框架以及與驅動開發(fā)相關代碼部署。驅動框架主要在//drivers/hdf_core/目錄下實現(xiàn)。

lframework/目錄是C語言實現(xiàn)的驅動框架核心源代碼(包括驅動框架、配置管理、配置解析、驅動通用模型、硬件通用平臺能力接口等),

注意點:這里的部分代碼是內核態(tài)驅動框架與用戶態(tài)驅動框架共用的,需要大家在閱讀代碼時區(qū)分清楚;

l adapter/目錄下是驅動框架適配不同內核的適配代碼和編譯腳本,也包括用戶態(tài)驅動框架適配不同系統(tǒng)類型(輕量系統(tǒng)和標準系統(tǒng))的適配代碼和編譯腳本。

l //drivers/peripheral/目錄下是部署在OpenHarmony用戶空間的各種外圍設備驅動相關的HDI、HAL、驅動模型及測試用例等的實現(xiàn)代碼和編譯配置。

l //drivers/interface/目錄下是用于管理各驅動模塊的HDI接口定義,這些接口定義使用IDL語言描述并以.idl文件形式保存。

l 其他與驅動開發(fā)相關的代碼目錄還包括//device/目錄和//vendor/目錄下的相關部分目錄,它們是具體的芯片方案、產(chǎn)品方案、產(chǎn)品定義、產(chǎn)品配置等相關信息和適配代碼的匯總,為設備驅動的實現(xiàn)提供一定的支持。

編譯與鏈接

驅動框架適配不同內核的編譯配置,在代碼結構的//drivers/hdf_core/adapter/目錄下,主要還是通過對應的BUILD.gn和Makefile文件將相關的源代碼進行串聯(lián)和依賴,以完成驅動框架整體的編譯與鏈接。

對于不同的內核,則在對應內核的編譯腳本中加入編譯驅動框架的入口和鏈接描述。

6aad77e8-ccad-11ed-bfe3-dac502259ad0.png

圖中代碼示例是在LiteOS_A內核的編譯腳本中include驅動框架的編譯入口,同時也在鏈接腳本中加入一個hdf.driver的只讀數(shù)據(jù)段,用以描述驅動框架專用的數(shù)據(jù)結構。

6aca884c-ccad-11ed-bfe3-dac502259ad0.png

圖中代碼示例是在Linux內核的編譯腳本中,將驅動框架的關鍵代碼以patch的形式打入Linux源代碼中(實際仍是代碼目錄的軟鏈接形式加入Linux內核中),同時也在鏈接腳本vmlinux.lds.S中加入一個hdf.driver的只讀數(shù)據(jù)段,用以描述驅動框架專用的數(shù)據(jù)結構。

當編譯到OpenHarmony內核時,編譯工具鏈通過上述腳本的描述一并將驅動框架編譯成中間文件,然后鏈接和打包到內核鏡像中使用。

內核態(tài)驅動框架及用戶態(tài)驅動框架啟動流程

內核態(tài)驅動框架的啟動流程

6aecd69a-ccad-11ed-bfe3-dac502259ad0.png

如圖所示,部署在內核態(tài)的驅動框架作為一個相對獨立的部分,要么因為內核(LiteOS_A內核)的其他模塊的直接調用而啟動,要么作為內核(Linux內核)的一個模塊(module)而自動加載和啟動。在進入驅動框架的啟動入口之后,驅動框架就會進入一個與內核無關的工作流程中(與內核相關部分會通過OSAL接口對接到內核提供的功能)。

用戶態(tài)驅動框架的啟動流程

6b0eb422-ccad-11ed-bfe3-dac502259ad0.png

如圖所示,部署在用戶態(tài)的驅動框架則分為若干個獨立的服務進程,在系統(tǒng)啟動到用戶態(tài)階段時,由Init進程根據(jù)啟動配置文件的描述逐一拉起,各進程之間通過IPC進行交互并逐步建立起各自的數(shù)據(jù)結構關系。

以上兩張示意圖均為以功能模塊劃分的啟動流程概略圖,梁開祝老師在閱讀理解OpenHarmony驅動框架的代碼時,以API為粒度整理了一份詳細的啟動流程圖,以及在驅動框架啟動過程中一步步建立起來的數(shù)據(jù)結構關系圖,感興趣的讀者可到資源倉庫下載、閱讀:

倉庫地址:

https://gitee.com/liangkzgitee/ohos_study_note

用戶態(tài)與內核態(tài)的交互

6b39fc22-ccad-11ed-bfe3-dac502259ad0.png

內核態(tài)的驅動框架與用戶態(tài)的驅動框架是各自獨立的兩部分,內核態(tài)驅動框架直接管理具體硬件設備的驅動,并以服務的形式向用戶態(tài)提供服務接口,而用戶態(tài)驅動框架則通過HDI接口使用內核態(tài)驅動框架提供的驅動服務。

HDI接口使用IO Service和IO Dispatcher機制為驅動框架提供進行統(tǒng)一的交互接口,其實現(xiàn)主要有兩種形式:

l 當驅動以內核態(tài)組件形式部署時,客戶端程序需要通過系統(tǒng)調用(system call)方式訪問驅動程序。驅動接口通過IO Service請求將消息通過系統(tǒng)調用陷入內核,并將消息分發(fā)到IO Dispatcher進行處理。

l 當驅動以用戶態(tài)服務形式部署時,客戶端進程需要通過IPC方式訪問驅動服務進程,IO Service完成IPC 通信的客戶端消息請求封裝,IO Dispatcher完成驅動服務端消息請求封裝,客戶端消息通過IPC送達服務端再分發(fā)給IO Dispatcher處理。

注意點:該交互過程涉及比較復雜的數(shù)據(jù)處理流程,需要結合代碼進行深入理解。

通用的驅動示例程序

以一個通用的驅動示例程序來簡單驗證基于OpenHarmony驅動框架的設備驅動開發(fā)基本要點。

6b5d564a-ccad-11ed-bfe3-dac502259ad0.png

本驅動示例程序,包含了驅動框架的一些基本要素,如上層的應用程序、內核的驅動程序、硬件的驅動配置信息、適配不同內核和不同類型系統(tǒng)的編譯腳本等。小伙伴們可以跟著里面的README文檔的操作說明,從簡單到復雜一步步去驗證前文提到的驅動框架知識要點,也可以非常方便地將這個示例程序移植到不同的開發(fā)板上進行驗證,以此體驗OpenHarmony驅動框架“一次開發(fā),多系統(tǒng)部署”的好處。

“以技術賦能開源共建,持續(xù)發(fā)揮生態(tài)引領作用”。潤和軟件將深入貫徹“2+N”行業(yè)戰(zhàn)略(深耕金融、能源“2”大行業(yè),廣泛賦能智慧城市、醫(yī)療、教育、工業(yè)等“N”個行業(yè)),圍繞行業(yè)場景落地不斷夯實軟硬件底座,推動應用創(chuàng)新,助力體驗提升;吸引更多企業(yè)及個人開發(fā)者融入生態(tài)、參與共建,持續(xù)為OpenHarmony繁榮發(fā)展貢獻力量。


原文標題:【OpenHarmony技術峰會】生態(tài)與互聯(lián)分論壇 | 梁開祝:OpenHarmony驅動開發(fā)實踐

文章出處:【微信公眾號:HiHope社區(qū)】歡迎添加關注!文章轉載請注明出處。


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

    關注

    57

    文章

    2291

    瀏覽量

    42632
  • HiHope
    +關注

    關注

    0

    文章

    63

    瀏覽量

    3518

原文標題:【OpenHarmony技術峰會】生態(tài)與互聯(lián)分論壇 | 梁開祝:OpenHarmony驅動開發(fā)實踐

文章出處:【微信號:HiHope,微信公眾號:HiHope社區(qū)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    第三屆OpenHarmony技術大會在上海成功舉辦

    了來自全球的開源操作系統(tǒng)技術精英、前沿實踐專家、廣大開發(fā)者以及學術界大咖,面向全球展示了OpenHarmony的最新技術、
    發(fā)表于 10-13 11:14

    精彩預告 | 首屆開放原子開發(fā)者大會OpenHarmony論壇議程搶鮮看

    現(xiàn)。如何更好地讓技術創(chuàng)新的汗水,滋養(yǎng)進未來世界的商業(yè)項目中,是所有開發(fā)者和開源企業(yè)需要思考的問題。 ? 2023開放原子開發(fā)者大會的OpenHarmony
    的頭像 發(fā)表于 12-15 16:15 ?304次閱讀

    OpenHarmony亮相MTSC 2023 | 質量&效率共進,賦能應用生態(tài)發(fā)展

    和平臺。OpenAtom OpenHarmony(簡稱“OpenHarmony”)通過專場論壇議題分享和展區(qū)展品精彩展示,為與會者帶來一場技術盛宴。
    發(fā)表于 11-28 15:41

    上海站報名啟動! 2023年開源產(chǎn)業(yè)生態(tài)大會OpenHarmony生態(tài)論壇

    聯(lián)合體共同指導,上海開源信息技術協(xié)會統(tǒng)籌主辦。 屆時,大會將攜手OpenAtom OpenHarmony(以下簡稱“OpenHarmony”)項目群生態(tài)委員會舉辦
    發(fā)表于 11-24 14:55

    精彩預告 | OpenHarmony即將亮相MTSC 2023

    業(yè)的認可和大力支持。 大咖云集、精英齊聚,共享 OpenHarmony 最新生態(tài)進展 本次 OpenHarmony 專場論壇大咖云集、精英
    發(fā)表于 11-22 10:28

    OpenHarmony技術大會 | 硬件(南向)生態(tài)論壇嘉賓金句

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:OpenHarmony技術大會 | 硬件(南向)
    的頭像 發(fā)表于 11-14 15:15 ?353次閱讀

    OpenHarmony技術大會 | 應用(北向)生態(tài)論壇嘉賓金句

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:OpenHarmony技術大會 | 應用(北向)
    的頭像 發(fā)表于 11-14 15:10 ?230次閱讀

    OpenHarmony技術大會 | 編程語言及開發(fā)框架論壇嘉賓金句

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:OpenHarmony技術大會 | 編程語言及
    的頭像 發(fā)表于 11-11 21:15 ?494次閱讀

    OpenHarmony技術大會 | 開發(fā)者工具論壇嘉賓金句

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:OpenHarmony技術大會 | 開發(fā)
    的頭像 發(fā)表于 11-11 21:10 ?403次閱讀

    OpenHarmony技術大會 | OS安全論壇嘉賓金句

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:OpenHarmony技術大會 | OS安全
    的頭像 發(fā)表于 11-10 20:15 ?309次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>技術</b>大會 | OS安全<b class='flag-5'>分</b><b class='flag-5'>論壇</b>嘉賓金句

    陳海波:OpenHarmony技術領先,產(chǎn)學研深度協(xié)同,生態(tài)蓬勃發(fā)展

    技術項目?!案钊~茂,眾行致遠”,OpenHarmony已經(jīng)與17家高校成立了“OpenHarmony技術俱樂部”,未來還將進一步邁向產(chǎn)學研共同體,通過產(chǎn)業(yè)與學術雙輪
    發(fā)表于 11-06 14:35

    技術生態(tài) 智聯(lián)贏未來,第二屆OpenHarmony技術大會圓滿舉行

    行業(yè)權威大咖、技術專家及高校技術導師,與眾多業(yè)界開發(fā)者齊聚一堂,通過1個主論壇、8個論壇、70
    發(fā)表于 11-04 14:59

    議程直擊 | 第二屆OpenHarmony技術大會——應用(北向)生態(tài)論壇

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:議程直擊 | 第二屆OpenHarmony技術大會——應用(北向)
    的頭像 發(fā)表于 11-01 16:10 ?377次閱讀

    議程直擊 | 第二屆OpenHarmony技術大會——硬件(南向)生態(tài)論壇

    點擊藍字 ╳ 關注我們 開源項目 OpenHarmony 是每個人的 OpenHarmony 原文標題:議程直擊 | 第二屆OpenHarmony技術大會——硬件(南向)
    的頭像 發(fā)表于 11-01 16:10 ?448次閱讀

    技術生態(tài),智聯(lián)贏未來 第二屆OpenHarmony技術大會即將在京啟幕

    開發(fā)框架論壇、開發(fā)者工具論壇、應用(北向)生態(tài)
    發(fā)表于 10-31 11:27