0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

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

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

介紹一種OpenAtom OpenHarmony輕量系統(tǒng)適配方案

OpenAtom OpenHarmony ? 來源:OpenAtom OpenHarmony ? 作者:OpenAtom OpenHarmony ? 2024-03-05 09:24 ? 次閱讀

1. 簡介

本文在不改變?cè)邢到y(tǒng)基礎(chǔ)框架的基礎(chǔ)上, 介紹了一種OpenAtom OpenHarmony(以下簡稱“OpenHarmony”)輕量系統(tǒng)適配方案。 本方案使用的是 OpenHarmony v3.2 Release版本源碼。

2. 方案設(shè)計(jì)

本文使用的硬件模塊的主要特性及功能如下:

0290ade2-da2b-11ee-a297-92fbcf53809c.png

通常,適配OpenHarmony的方案是,將內(nèi)核由RTOS改為LiteOS-M,并移植原生所有功能模塊和鏡像打包功能。采用該方案面臨了諸多困難:

●編譯系統(tǒng)更改Gn+Ninjia,重寫和調(diào)試編譯腳本,需要學(xué)習(xí)成本

●適配和測(cè)試全部的原生功能,原本測(cè)試通過的功能需要重新測(cè)試,付出重復(fù)的勞動(dòng)

●適配新的OS接口,需要修改原生系統(tǒng)的OSI層接口,以對(duì)接LiteOS-M

該方案的改動(dòng)較多,將導(dǎo)致開發(fā)人員無法將精力聚焦于項(xiàng)目的新功能、工作量大、難度大,無法滿足項(xiàng)目的工期要求,項(xiàng)目風(fēng)險(xiǎn)大。

OpenHarmony的輕量系統(tǒng)編譯過程是,首先將各模塊編譯鏈接為靜態(tài)庫,再將靜態(tài)庫鏈接為應(yīng)用程序,最后打包為鏡像文件。燒錄入硬件后,系統(tǒng)運(yùn)行單一進(jìn)程,各個(gè)不同的任務(wù)以多個(gè)線程運(yùn)行。

結(jié)合原生編譯系統(tǒng)和 OpenHarmony的特點(diǎn),最終采用的適配方案如下:

●不改變?cè)a的編譯系統(tǒng)和打包系統(tǒng)

●使用原生代碼的交叉編譯工具鏈編譯OpenHarmony為靜態(tài)庫,將靜態(tài)庫集成到原生代碼中

●OpenHarmony中不編譯LiteOS-M內(nèi)核,使用原生代碼的RTOS內(nèi)核

●原生代碼中新增適配代碼,以提供OpenHarmony需要的接口

整體的軟件框架設(shè)計(jì)如下:

wKgZomXmdPiAQDTzAACNPYvE_v8293.jpg

方案保留了原始系統(tǒng)框架的大部分功能,新增OpenHarmony的模塊功能和其他項(xiàng)目需求功能,修改或升級(jí)部分原生功能(FreeRTOS、 MbedTLS等)。

3. OpenHarmony編譯

3.1 創(chuàng)建虛擬設(shè)備編譯

創(chuàng)建新的vendor和新的device配置,目錄如下:

●vendor/ohemu/L0_xts_demo

●device/qemu/L0_xts_demo

3.2 子系統(tǒng)配置

修改vendor/ohemu/L0_xts_demo/config.json,該文件包含了所有必須的子系統(tǒng)配置。

3.3 工具鏈配置

修改device/qemu/L0_xts_demo/liteos_m/config.gni,該文件包含了板級(jí)編譯配置,根據(jù)原生編譯系統(tǒng)的編譯設(shè)置來修改。

3.4 編譯命令

編譯命令如下:


python3 ./build.py -p L0_xts_demo -f -b debug --gn-args build_xts=true

編譯出的靜態(tài)庫位于out/L0_xts_demo/L0_xts_demo/libs

3.5 優(yōu)化剪裁

對(duì)manifest和prebuild進(jìn)行剪裁,只下 載必須的軟件和源碼。

●修改build/prebuilts_download_config.json,只保留GN、Ninja和Python

●修改.repo/manifests/ohos/ohos.xml,刪除不需要的包和源碼。

3.6 集成

將編譯后的靜態(tài)庫拷貝到原生編譯系統(tǒng)中,并編寫demo程序,進(jìn)行編譯。

3.6.1 編寫demo

OpenHarmony的demo分為兩個(gè)單元main.c和demo.c。

●main.c 主線程,調(diào)用OHOS_SystemInit()函數(shù),啟動(dòng)OpenHarmony

● demo.c 示例線程,調(diào)用hilog接口循環(huán)打印日志

3.6.2 編譯demo

在demo目錄下創(chuàng)建CMakeFile.txt文件。

定義OpenHarmony的頭文件包含目錄及庫文件,編譯main.c和demo.c,生成demo鏡像文件。

3.6.3 編譯XTS

將XTS編譯生成的靜態(tài)庫鏈接為鏡像,每一項(xiàng)XTS測(cè)試生成一個(gè)鏡像。

3.6.4 鏈接

修改ld文件的.TEXT段,新增OpenHarmony的自定義段設(shè)置。

4. 原生系統(tǒng)修改

在原生代碼中升級(jí)模塊或新增OpenHarmony調(diào)用的接口。

4.1 升級(jí)RTOS

由于不支持OpenHarmony中的底層接口,F(xiàn)reeRTOS內(nèi)核從版本10.0.1升級(jí)到版本v10.3.1,適配其HAL層和 OSI層接口。

FreeRTOS源碼來自于官網(wǎng)地址: https://github.com/FreeRTOS/FreeRTOS

4.2 升級(jí)MbedTLS

因?yàn)樵鶰bedTLS代碼的版本較低,所以拷貝OpenHarmony中的MbedTLS源碼覆蓋到原生系統(tǒng)中。修改在OpenHarmony中不編譯三方庫MbedTLS。

修改CMakeFile.txt和config.h,打開OpenHarmony和原生系統(tǒng)需要的功能開關(guān)。

4.3 新增CMSIS接口

原生系統(tǒng)kernel中新增cmsis目錄,包含CMSIS的源碼和頭文件。

CMSIS源碼來自于開源項(xiàng)目CMSIS-FreeRTOS,地址:https://github.com/ARM-software/CMSIS-FreeR TOS

修改部分源碼適配系統(tǒng)源碼,并修改kernel的CMakeFile.txt,將源碼中的cmsis_os2.c文件加入編譯。

4.4 新增打印接口

新增打印接口,對(duì)接原生系統(tǒng)打印功能,比如打印到串口、保存文件等。新增加的功能模塊和OpenHarmony均調(diào)用新增的打印接口。

4.5 新增文件系統(tǒng)接口

適配OpenHarmony的文件系統(tǒng)調(diào)用的接口

●_open()

●_close()

●_read()

●_write()

●_lseek()

●_unlink()

需要注意的是,OpenHarmony要求打開文件最多為32個(gè),這里需要控制通過_open()接口打開的文件 總數(shù)不能超過32個(gè)。

4.6 新增POSIX接口

適配編譯中報(bào)錯(cuò)缺失的POSIX接口

●_exit()

●kill()

●sleep()

●_fini()

4.7 新增LiteOS接口

LiteOS中調(diào)用的接口

●ArchIntLock()

●ArchIntRestore()

●LOS_MuxCreate()

●LOS_MuxPend()

●LOS_MuxDelete()

●LOS_TickCountGet()

●osThreadGetArgument()

4.8 其他接口

適配缺失的其他接口

●OhosMalloc()

●OhosFree()

●RefreshAllServiceTimeStamp()

●HiLogWriteInternal()

5. OpenHarmony修改

5.1 三方庫

修改third_party/bounds_checking_function/BUILD.gn,編譯生成libsec_static靜態(tài)庫

5.2 修改hiview_lite

●base/hiviewdfx/hiview_lite/BUILD.gn,改為無緩存,直接輸出到串口。

●base/hiviewdfx/hiview_lite/hiview_util.c ,修改打印函數(shù),調(diào)用原生系統(tǒng)新增的打印接口

5.3 修改HUKS

修改文件base/security/huks/utils/mutex/hks_mutex.c

因?yàn)樵到y(tǒng)并不支持POSIX的mutex系列接口,這里修改為LOS接口。如果原生系統(tǒng)支持POSIX接口,則這里不需要進(jìn)行修改。

5.4 修改bootstrap_lite

修改文件base/startup/bootstrap_lite/services/source/core_main.h,取消宏里面的重復(fù)調(diào)用。

5.5 刪除-fPIC

刪除BUILD.gn文件里的-fPIC,否則會(huì)導(dǎo)致程序運(yùn)行異常。

●foundation/ability/ability_lite/frameworks/want_lite/BUILD.gn

●foundation/bundlemanager/bundle_framework_lite/frameworks/bundle_lite/BUILD.gn

5.6 修改XTS

修改日志打印,將日志輸出到串口。

6. 總結(jié)

該方案與通用方案相比,降低了適配復(fù)雜度和開發(fā)難度,減少了工作量,使項(xiàng)目進(jìn)度符合了工期要求,是一種快速的適配方案。采用該方案進(jìn)行開發(fā)的輕量設(shè)備已經(jīng)成功通過了OpenHarmony兼容性測(cè)評(píng)。請(qǐng)各位讀者根據(jù)項(xiàng)目的實(shí)際情況在兩種方案中進(jìn)行選擇。



審核編輯:劉清

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

    關(guān)注

    0

    文章

    40

    瀏覽量

    12152
  • RTOS
    +關(guān)注

    關(guān)注

    24

    文章

    836

    瀏覽量

    120535
  • FreeRTOS
    +關(guān)注

    關(guān)注

    12

    文章

    485

    瀏覽量

    63403
  • HAL庫
    +關(guān)注

    關(guān)注

    1

    文章

    121

    瀏覽量

    6627
  • OpenHarmony
    +關(guān)注

    關(guān)注

    26

    文章

    3802

    瀏覽量

    17764

原文標(biāo)題:一種OpenHarmony輕量系統(tǒng)適配方案

文章出處:【微信號(hào):gh_e4f28cfa3159,微信公眾號(hào):OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 0人收藏

    評(píng)論

    相關(guān)推薦

    一種分表方案-MyBatis攔截器分表實(shí)踐

    作者:京東零售 張均杰 背景 部門內(nèi)有些億級(jí)別核心業(yè)務(wù)表增速非常快,增量日均100W,但線上業(yè)務(wù)只依賴近周的數(shù)據(jù)。隨著數(shù)據(jù)的迅速增長,慢SQL頻發(fā),數(shù)據(jù)庫性能下降,系統(tǒng)穩(wěn)定性受到
    的頭像 發(fā)表于 01-23 17:38 ?315次閱讀

    一種使用LDO簡單電源電路解決方案

    本期我們介紹一種使用LDO簡單電源電路解決方案,該方案可以處理12V/24V、多節(jié)鋰離子電池和4節(jié)干電池等相對(duì)較高的輸入電壓。
    的頭像 發(fā)表于 12-04 16:05 ?646次閱讀
    <b class='flag-5'>一種</b>使用LDO簡單電源電路解決<b class='flag-5'>方案</b>

    戈帥《OpenHarmony系統(tǒng)從入門到精通50例》開發(fā)板與傳感器配置說明

    戈帥《OpenHarmony系統(tǒng)從入門到精通50例》開發(fā)板與傳感器配置說明,請(qǐng)查看附件*附件:《OpenHarmony
    發(fā)表于 12-03 15:46

    飛凌嵌入式受邀亮相OpenHarmony人才生態(tài)大會(huì)2024

    2024年11月27日,OpenHarmony人才生態(tài)大會(huì)2024在武漢洲際酒店舉行。在這場(chǎng)匯聚了行業(yè)精英、技術(shù)大咖及生態(tài)伙伴的年度盛會(huì)上,飛凌嵌入式作為OpenHarmony社區(qū)的重要成員受邀出席,并展示了其在OpenHarmony
    的頭像 發(fā)表于 11-29 14:58 ?574次閱讀
    飛凌嵌入式受邀亮相<b class='flag-5'>OpenHarmony</b>人才生態(tài)大會(huì)2024

    OpenHamrony4.0去除鎖屏是一種什么體驗(yàn)?觸覺智能給你支支招

    本文介紹開源鴻蒙OpenHarmony 4.0系統(tǒng)下,去除鎖屏開機(jī)后直接進(jìn)入界面的方法,觸覺智能Purple Pi OH鴻蒙開發(fā)板演示,已適配全新O
    的頭像 發(fā)表于 11-13 10:37 ?510次閱讀
    OpenHamrony4.0去除鎖屏是<b class='flag-5'>一種</b>什么體驗(yàn)?觸覺智能給你支支招

    本文介紹一種基于英飛凌碳化硅溝槽柵(CoolSiC?)的系統(tǒng)解決方案

    本文介紹一種基于英飛凌碳化硅溝槽柵(CoolSiC?)的系統(tǒng)解決方案用于無橋圖騰柱的超結(jié)(CoolMOS?)功率半導(dǎo)體、驅(qū)動(dòng)器和微控制器功率因數(shù)校正(PFC)轉(zhuǎn)換器工作在連續(xù)導(dǎo)通模式
    發(fā)表于 11-11 16:10 ?0次下載

    觸覺智能Purple Pi OH鴻蒙開發(fā)板成功適配OpenHarmony5.0 Release,開啟新征程

    觸覺智能Purple Pi OH鴻蒙開發(fā)板,成功適配OpenHarmony5.0 Release版本!為大家?guī)?b class='flag-5'>OpenHarmony5.0特性講解!關(guān)注觸覺智能,為大家?guī)砀?b class='flag-5'>OpenHar
    的頭像 發(fā)表于 10-25 10:51 ?789次閱讀
    觸覺智能Purple Pi OH鴻蒙開發(fā)板成功<b class='flag-5'>適配</b><b class='flag-5'>OpenHarmony</b>5.0 Release,開啟新征程

    海外云服務(wù)器是什么

    海外云服務(wù)器是指位于海外數(shù)據(jù)中心內(nèi),采用虛擬化技術(shù)構(gòu)建的輕量級(jí)云服務(wù)器實(shí)例。與傳統(tǒng)的物理服務(wù)器或國內(nèi)云服務(wù)器相比,海外云服務(wù)器在配置、價(jià)格、靈活性等方面具有顯著不同。
    的頭像 發(fā)表于 09-25 10:09 ?435次閱讀

    開放原子開源生態(tài)大會(huì)OpenHarmony生態(tài)主題演講報(bào)名開啟

    開源賦能產(chǎn)業(yè),生態(tài)共筑未來,OpenAtom OpenHarmony(簡稱“OpenHarmony”)項(xiàng)目群工作委員會(huì)將于9月26日上午舉辦OpenHarmony生態(tài)主題演講。 屆時(shí)
    發(fā)表于 09-19 22:02

    【開源鴻蒙】使用QEMU運(yùn)行OpenHarmony系統(tǒng)

    本文將會(huì)介紹如何從源碼安裝QEMU 6.2.0,以及如何使用QEMU運(yùn)行OpenHarmony系統(tǒng)。通過本文,你將會(huì)對(duì)QEMU和
    的頭像 發(fā)表于 09-14 08:51 ?1028次閱讀
    【開源鴻蒙】使用QEMU運(yùn)行<b class='flag-5'>OpenHarmony</b><b class='flag-5'>輕</b><b class='flag-5'>量</b><b class='flag-5'>系統(tǒng)</b>

    [2K300適配OpenharmonyV4.1]根文件系統(tǒng)制作請(qǐng)教

    嘗試更改制作文件格式為ext4,但是燒錄時(shí)也失敗了。 請(qǐng)問能否提供Openharmony 根文件系統(tǒng)的相關(guān)資料,或者開源Openharmon
    發(fā)表于 09-11 11:18

    美國云服務(wù)器是什么?和云服務(wù)器有哪些區(qū)別

    美國云服務(wù)器,作為云計(jì)算領(lǐng)域的一種服務(wù)模式,主要面向入門級(jí)云計(jì)算用戶及需要簡單應(yīng)用部署的場(chǎng)景。它提供基于單臺(tái)云服務(wù)器的綜合服務(wù),包括域名管理、應(yīng)用部署、安全及運(yùn)維管理等站式解決
    的頭像 發(fā)表于 08-16 11:20 ?598次閱讀

    開源鴻蒙 編譯OpenHarmony系統(tǒng)QEMU RISC-V版本

    本文將介紹如何為QEMU RISC-V虛擬平臺(tái)構(gòu)建OpenHarmony系統(tǒng)。得益于QEMU的CPU指令集模擬執(zhí)行能力,該方法可以在沒有
    的頭像 發(fā)表于 07-15 10:36 ?1415次閱讀
    開源鴻蒙 編譯<b class='flag-5'>OpenHarmony</b><b class='flag-5'>輕</b><b class='flag-5'>量</b><b class='flag-5'>系統(tǒng)</b>QEMU RISC-V版本

    介紹一種嵌入式Linux中的錄音降噪方案

    降噪不僅只能從硬件入手,本文為您介紹一種嵌入式Linux中的錄音降噪方案。該方案完全依靠軟件實(shí)現(xiàn),最大程度上降低投入。
    的頭像 發(fā)表于 05-21 11:52 ?769次閱讀

    鴻蒙OpenHarmony系統(tǒng) 編譯】 (基于Hi3861開發(fā)板)

    OpenHarmony支持hb和build.sh兩編譯方式。此處介紹hb方式,build.sh腳本編譯方式請(qǐng)參考[使用build.sh腳本編譯源碼]。
    的頭像 發(fā)表于 05-14 17:53 ?1679次閱讀
    鴻蒙<b class='flag-5'>OpenHarmony</b>【<b class='flag-5'>輕</b><b class='flag-5'>量</b><b class='flag-5'>系統(tǒng)</b> 編譯】 (基于Hi3861開發(fā)板)

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品