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