作為 OpenAtom OpenHarmony(簡稱“OpenHarmony”)社區(qū)單 BLE 的輕量級設(shè)備,匯頂科技 GR551x 系列低功耗藍(lán)牙開發(fā)板已經(jīng)順利通過 OpenHarmony 兼容性工作組的兼容性測試審核,正式完成合入 OpenHarmony 主干分支(master 分支)。
李東山來自深圳市匯頂科技股份有限公司,是 BLE 產(chǎn)品開發(fā)部的一名研發(fā)工程師,從 2021 年 9 月開始承擔(dān) BLE SoC GR551x 接入 OpenAtom OpenHarmony 生態(tài)的適配任務(wù)。通過采訪,他向我們詳細(xì)分享了項目開發(fā)過程中的難點和經(jīng)驗,以下為采訪整理:
作為開發(fā)領(lǐng)域知名的技術(shù)大牛,您最初為什么會選擇加入 OpenHarmony 生態(tài)、參與開源共建呢?您認(rèn)為,OpenHarmony 項目最吸引人的點在哪里?
OpenHarmony 是一款面向全場景、全連接、全智能時代的分布式操作系統(tǒng),它面向萬物互聯(lián),非常契合我們 BLE SoC 產(chǎn)品應(yīng)用方向,選擇加入 OpenHarmony 生態(tài),希望能一起參與共建 OpenHarmony 生態(tài)系統(tǒng),為促進(jìn)萬物互聯(lián)和千行百業(yè)的繁榮發(fā)展貢獻(xiàn)我們的一份力量。
OpenHarmony 代碼遵循 Apache 2.0 等商業(yè)友好的開源協(xié)議,所有企業(yè)、機構(gòu)與個人均可基于 OpenHarmony 開源代碼,結(jié)合自身優(yōu)勢,去做各領(lǐng)域的操作系統(tǒng)發(fā)行版及終端產(chǎn)品。
您在什么時候組建了 OpenHarmony 開源項目團隊?通過多久完成了 GR5515 Starter Kit 開發(fā)板的適配,核心代碼已合入主干,現(xiàn)在被 OpenHarmony PMC 委員會推選為“代碼月度貢獻(xiàn)之星”,真的太了不起了!您方便給我們介紹一下這個產(chǎn)品嗎,或者這段經(jīng)歷嗎?這么短時間達(dá)成了這樣好的效果,請問您的“秘訣”都有哪些呢?
我們是在 2021 年的 9 月開始投入資源適配 OpenHarmony。經(jīng)過兩個多月的努力,將我們首款 Bluetooth LE 輕量設(shè)備芯片 GR551x 系列 SoC 適配上 OpenHarmony,2021 年 11 月 18 日順利通過 OpenHarmony 兼容性測評, 并于 2022 年 1 月 7 日正式合入 OpenHarmony 主干。
(GR5515 Starter Kit 適配代碼倉庫)
能夠在短時間內(nèi)完成開發(fā)板適配工作不僅是因為我們生態(tài)小組小伙伴們齊心協(xié)力,通力配合, 還得益于 OpenHarmony 完備的開發(fā)平臺和工具鏈,優(yōu)秀的代碼框架,豐富的文檔資源。剛開始我們的倉庫在 SIG 上孵化,兩次畢業(yè)答辯評審后代碼合入主干,非常感謝社區(qū)的老師們給予了很多專業(yè)指導(dǎo)和支持。
能開發(fā)出這么一個優(yōu)秀的產(chǎn)品,將核心代碼合入主干,您和您的團隊一定付出了很多??梢哉埬o我們分享一下,開發(fā)這個產(chǎn)品的整個過程,包括前期、中期、后期,您們具體都做了哪些工作,投入了多少人力和資源嗎?
開發(fā)板適配前期,我們對 OpenHarmony 輕量系統(tǒng)進(jìn)行了學(xué)習(xí)和調(diào)研,充分評估可行性后開始嘗試適配。萬事開頭難,剛開始適配 V1.1.2-LTS 版本,從搭建開發(fā)環(huán)境、熟悉構(gòu)建系統(tǒng)、移植第一行代碼,解決了很多難題,也踩過很多坑。終于,兩周后系統(tǒng)在我們的 SoC 上穩(wěn)定運行起來了。
項目中期我們升級到了 V3.0.0-LTS,3.0 版本引入了許多新特性,我們開始適配 HDF 驅(qū)動、BLE 接口、文件系統(tǒng)、低功耗等,并通過了兼容性測評。
項目后期我們與主干 master 版本對齊,master 版本引入 board 與 soc 分離的先進(jìn)設(shè)計理念,我們對代碼框架進(jìn)行了大量重構(gòu)優(yōu)化,代碼架構(gòu)和規(guī)范都符合要求后,代碼合入 OpenHarmony 主干。
匯頂科技非常看好 OpenHarmony,我們持續(xù)投入人力在該項目上,目前基本完成了首款 BLE Soc GR5515 芯片的適配工作,未來我們也會對適配的代碼進(jìn)行持續(xù)優(yōu)化和維護,同時也會積極參與輕量系統(tǒng)的圖形顯示和 BLE IoT 方向的共建工作。
在整個開發(fā)進(jìn)程中,您和您的團隊遇到過哪些技術(shù)上或其他方面的難題?這些難題又是如何被逐一解決?在這些難題被解決的過程中,您總結(jié)了哪些寶貴的經(jīng)驗 or 教訓(xùn)?
在開發(fā)初期,網(wǎng)上幾乎沒有對 ARM 架構(gòu)的輕量系統(tǒng)移植適配的指導(dǎo)文檔,構(gòu)建環(huán)境也很復(fù)雜,可參考的開發(fā)板就 3 塊,對于我這種剛接觸 OpenHarmony 的小白來說,不知道怎么去加入我們的代碼,不知道如何構(gòu)建,差點被遇到的各種困難“勸退”。好在 OpenHarmony 自帶了一款基于 RSIC-V 架構(gòu)的開發(fā)板樣例,通過深入研究其編譯框架和適配細(xì)節(jié)后,我們將 SDK 移植到 OpenHarmony 并構(gòu)建成功。
OpenHarmony 對 ARM 和 RSIC-V 架構(gòu)支持已經(jīng)非常全面,Cortex-M 內(nèi)核相關(guān)的 arch 移植 liteos-m 已經(jīng)幫我們做好,移植一款新的開發(fā)板只需重點聚焦在編譯構(gòu)建、BSP 移植、XTS 測試、業(yè)務(wù)功能開發(fā)上。
加入 OpenHarmony 生態(tài)以來,您最大的驚喜是什么?或者有哪些具體的收獲?
自從加入 OpenHarmony 生態(tài)以來,我切身感受到它發(fā)展的如此之快,從當(dāng)初的 1.0 版本迭代到如今的 3.0 版本,每個版本都會帶來許多實用的更新,開發(fā)板越來越多,文檔也越來越豐富,社區(qū)交流日漸活躍,開發(fā)者參與共建也越來越容易。
我也一直在持續(xù)學(xué)習(xí) OpenHarmony,學(xué)習(xí)過程中了解到了很多代碼架構(gòu)上的先進(jìn)理念,為自己平時的開發(fā)工作帶來了很大的幫助,我也一直堅持通過博客分享我的學(xué)習(xí)經(jīng)歷和開源移植案例。
期待未來 OpenHarmony 哪些方面能夠得到改善、提供更多支持?
OpenHarmony 經(jīng)過一年多的快速發(fā)展,編譯構(gòu)建、代碼架構(gòu)、文檔支持、社區(qū)建設(shè)方面都做得非常優(yōu)秀。我個人期待,OpenHarmony 其配套 IDE DevEco Device Tool 能早點普及,推動眾多的開發(fā)板適配并支持,這樣有利于給開發(fā)者和終端客戶帶來更便捷的體驗。
OpenHarmony 目前仍處在開發(fā)探索階段,很多共建單位和生態(tài)伙伴還不清楚開源項目的玩法,或不知該如何著手進(jìn)行開發(fā)??梢哉埬o大家分享一條,您認(rèn)為最重要或最值得分享的心得嗎?
開源項目的輸出將為開發(fā)者提供更多的學(xué)習(xí)途徑,點亮眾多開發(fā)者前行的道路。我在開發(fā)過程中遇到了很多技術(shù)上的困難,尋求不到別人的幫助時,通過研讀別人的開源代碼找到了靈感和思路,開源其實也是一種互相學(xué)習(xí),共同進(jìn)步的高效途徑。
開放性問題,可以暢所欲言,請問您還有話想告訴大家?
非常感謝 OpenHarmony,為我們提供了如此優(yōu)秀的操作系統(tǒng),很高興自己能夠參與開源共建,為開源貢獻(xiàn)出自己的一份微薄力量。從剛開始的“懵懂”小白,跟著 OpenHarmony 一起成長,雖然過程中充滿了挑戰(zhàn),但也收獲很多。我真切感受到 OpenHarmony 的迅猛發(fā)展,希望有更多企業(yè)、開發(fā)者一起參與共建 OpenHarmony 繁榮生態(tài)。
(免責(zé)聲明:本網(wǎng)站內(nèi)容主要來自原創(chuàng)、合作伙伴供稿和第三方自媒體作者投稿,凡在本網(wǎng)站出現(xiàn)的信息,均僅供參考。本網(wǎng)站將盡力確保所提供信息的準(zhǔn)確性及可靠性,但不保證有關(guān)資料的準(zhǔn)確性及可靠性,讀者在使用前請進(jìn)一步核實,并對任何自主決定的行為負(fù)責(zé)。本網(wǎng)站對有關(guān)資料所引致的錯誤、不確或遺漏,概不負(fù)任何法律責(zé)任。
任何單位或個人認(rèn)為本網(wǎng)站中的網(wǎng)頁或鏈接內(nèi)容可能涉嫌侵犯其知識產(chǎn)權(quán)或存在不實內(nèi)容時,應(yīng)及時向本網(wǎng)站提出書面權(quán)利通知或不實情況說明,并提供身份證明、權(quán)屬證明及詳細(xì)侵權(quán)或不實情況證明。本網(wǎng)站在收到上述法律文件后,將會依法盡快聯(lián)系相關(guān)文章源頭核實,溝通刪除相關(guān)內(nèi)容或斷開相關(guān)鏈接。 )