精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

鴻蒙OpenHarmony開發板解析:【 部件配置規則】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-05-09 15:15 ? 次閱讀

部件

部件配置規則

部件的bundle.json放在部件源碼的根目錄下。以泛sensor子系統的sensor服務部件為例,部件屬性定義描述文件字段說明如下:

開發前請熟悉鴻蒙開發指導文檔:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

{
    "name": "@ohos/sensor_lite",		                                 # HPM部件英文名稱,格式"@組織/部件名稱"
    "description": "Sensor services",		                             # 部件功能一句話描述	
    "version": "3.1",			                                         # 版本號,版本號與OpenHarmony版本號一致
    "license": "MIT",			                                         # 部件License
    "publishAs": "code-segment",		                                 # HPM包的發布方式,當前默認都為code-segment
    "segment": {										
        "destPath": ""			
    },					                                                 # 發布類型為code-segment時為必填項,定義發布類型code-segment的代碼還原路徑(源碼路徑)			
    "dirs": {"base/sensors/sensor_lite"},	                             # HPM包的目錄結構,字段必填內容可以留空
    "scripts": {},			                                             # HPM包定義需要執行的腳本,字段必填,值非必填
    "licensePath": "COPYING",			
    "readmePath": {
        "en": "README.rst"
    },
    "component": {			                                             # 部件屬性
        "name": "sensor_lite",			                                 # 部件名稱		
        "subsystem": "",		                                         # 部件所屬子系統
        "syscap": [],				                                     # 部件為應用提供的系統能力
        "features": [],                                                  # 部件對外的可配置特性列表,一般與build中的sub_component對應,可供產品配置
        "adapted_system_type": [],		                                 # 輕量(mini)小型(small)和標準(standard),可以是多個
        "rom": "92KB",                                                   # 部件ROM值
        "ram": "~200KB",                                                 # 部件RAM估值       
        "deps": {                      
        "components": [                                                  # 部件依賴的其他部件
          "samgr_lite",
          "ipc_lite"
        ],
        "third_party": [                                                 # 部件依賴的三方開源軟件
          "bounds_checking_function"
        ],
        "hisysevent_config": []                                          # 部件HiSysEvent打點配置文件編譯入口
      }         
        "build": {				                                         # 編譯相關配置
            "sub_component": [
                ""//base/sensors/sensor_lite/services:sensor_service"",  # 部件編譯入口
            ],			                                                 # 部件編譯入口,模塊在此處配置
            "inner_kits": [],						                     # 部件間接口
            "test": []							                         # 部件測試用例編譯入口
        }
    }
 }

注意 :lite上舊的部件在build/lite/components目錄下對應子系統的json文件中,路徑規則為: {領域}/{子系統}/{部件} ,部件目錄樹規則如下:

component
├── interfaces
│   ├── innerkits  # 系統內接口,部件間使用
│   └── kits       # 應用接口,應用開發者使用
├── frameworks     # framework實現
├── services       # service實現
└── BUILD.gn       # 部件編譯腳本

部件配置中需要配置部件的名稱、源碼路徑、功能簡介、是否必選、編譯目標、RAM、ROM、編譯輸出、已適配的內核、可配置的特性和依賴等屬性定義。

注意 :部件配置中HiSysEvent打點配置文件使用說明,請參考文檔[HiSysEvent打點配置]

新增部件時需要在對應子系統json文件中添加相應的部件定義。產品所配置的部件必須在某個子系統中被定義過,否則會校驗失敗。

新增并編譯部件

  1. 添加部件。 本節以添加一個自定義的部件為例,描述如何編譯部件,編譯庫、編譯可執行文件等。
    示例部件partA由feature1、feature2和feature3組成,feature1的編譯目標為一個動態庫,feature2的目標為一個可執行程序,feature3的目標為一個etc配置文件。
    示例部件partA的配置需要添加到一個子系統中,本次示例將添加到subsystem_examples子系統中(subsystem_examples子系統定義在test/examples/目錄)。
    示例部件partA的完整目錄結構如下:

    test/examples/partA
    ├── feature1
    │   ├── BUILD.gn
    │   ├── include
    │   │   └── helloworld1.h
    │   └── src
    │       └── helloworld1.cpp
    ├── feature2
    │   ├── BUILD.gn
    │   ├── include
    │   │   └── helloworld2.h
    │   └── src
    │       └── helloworld2.cpp
    └── feature3
        ├── BUILD.gn
        └── src
            └── config.conf
    

    示例1:編寫動態庫gn腳本test/examples/partA/feature1/BUILD.gn,示例如下:

    config("helloworld_lib_config") {
     include_dirs = [ "include" ]
    }
    
    ohos_shared_library("helloworld_lib") {
      sources = [
        "include/helloworld1.h",
        "src/helloworld1.cpp",
      ]
      public_configs = [ ":helloworld_lib_config" ]
      part_name = "partA"
    }
    

    示例2:編寫可執行文件gn腳本test/examples/partA/feature2/BUILD.gn,示例如下:

    ohos_executable("helloworld_bin") {
      sources = [
        "src/helloworld2.cpp"
      ]
      include_dirs = [ "include" ]
      deps = [                                # 依賴部件內模塊
        "../feature1:helloworld_lib"
      ]
      external_deps = [ "partB:module1" ]     # (可選)如果有跨部件的依賴,格式為“部件名:模塊名”
      install_enable = true                   # 可執行程序缺省不安裝,需要安裝時需要指定
      part_name = "partA"
    }
    

    示例3:編寫etc模塊gn腳本test/examples/partA/feature3/BUILD.gn,示例如下:

    ohos_prebuilt_etc("feature3_etc") {
      source = "src/config.conf"
      relative_install_dir = "init"    #可選,模塊安裝相對路徑,相對于默認安裝路徑;默認在/system/etc目錄
      part_name = "partA"
    }
    

    示例4:在部件的bundle.json中添加模塊配置:test/examples/bundle.json。每個部件都有一個bundle.json配置文件,在部件的根目錄下。示例見:[部件的bundle.json]

  2. 將部件添加到產品配置中。 在產品的配置中添加部件,產品對應的配置文件://vendor/{product_company}/{product-name}/config.json。下面以vendor/hisilicon/hispark_taurus_standard/config.json為例:

{
        "product_name": "hispark_taurus_standard",
        "device_company": "hisilicon",
        "device_build_path": "device/board/hisilicon/hispark_taurus/linux",
        "target_cpu": "arm",
        "type": "standard",
        "version": "3.0",
        "board": "hispark_taurus",
        "inherit": [ "productdefine/common/base/standard_system.json",
                    "productdefine/common/inherit/ipcamera.json"
        ],
        "enable_ramdisk": true,
        "subsystems": [
          {
            "subsystem": "subsystem_examples",                              # 部件所屬子系統
            "components": [
              {
                "component": "partA",                                       # 部件名稱
                "features": []                                              # 部件對外的可配置特性列表
              }
            ]
          },
        ······
      }
      
`HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿`

搜狗高速瀏覽器截圖20240326151344.png
從中可以看出產品名稱、芯片廠家等;inherit指出依賴的通用組件;subsystems指出通用組件以外的部件。

在產品配置文件中添加 "subsystem_examples:partA",表示該產品中會編譯并打包partA到版本中。

  1. 編譯。 主要有兩種編譯方式,[命令行方式和hb方式],下面以命令行方式為例:
    部件可以使用"--build-target 部件名"進行單獨編譯,以編譯產品hispark_taurus_standard的musl部件為例,編譯命令如下:

    ./build.sh --product-name hispark_taurus_standard --build-target musl --ccache
    

    也可以編譯相應產品,以編譯hispark_taurus_standard為例,編譯命令如下:

    ./build.sh --product-name hispark_taurus_standard --ccache
    
  2. 編譯輸出。 編譯所生成的文件都歸檔在out/hispark_taurus/目錄下,結果鏡像輸出在 out/hispark_taurus/packages/phone/images/ 目錄下。

審核編輯 黃宇

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

    關注

    25

    文章

    4945

    瀏覽量

    97200
  • 鴻蒙
    +關注

    關注

    57

    文章

    2310

    瀏覽量

    42746
  • HarmonyOS
    +關注

    關注

    79

    文章

    1967

    瀏覽量

    30021
  • OpenHarmony
    +關注

    關注

    25

    文章

    3660

    瀏覽量

    16158
收藏 人收藏

    評論

    相關推薦

    OpenHarmony鴻蒙南向開發案例:【智能貓眼(基于Hi3518開發板)】

    基于Hi3518開發板,使用開源OpenHarmony開發的RTSP協議流媒體應用。達到將Hi3518開發板中攝像頭獲取的數據通過RTSP協議傳輸到手機并顯示 。
    的頭像 發表于 04-22 15:46 ?1927次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>鴻蒙</b>南向<b class='flag-5'>開發</b>案例:【智能貓眼(基于Hi3518<b class='flag-5'>開發板</b>)】

    鴻蒙OpenHarmony【標準系統編寫“Hello World”程序】 (基于RK3568開發板

    源碼],創建RK3568開發板的源碼工程。 示例目錄 拉取openharmony項目代碼,在代碼根目錄創建sample子系統文件夾,在子系統目錄下創建hello部件文件夾,hello文件夾中創建
    的頭像 發表于 04-24 17:32 ?694次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b>【標準系統編寫“Hello World”程序】 (基于RK3568<b class='flag-5'>開發板</b>)

    鴻蒙OpenHarmony開發板:【產品配置規則

    產品解決方案為基于開發板的完整產品,主要包含產品對OS的適配、部件拼裝配置、啟動配置和文件系統配置等。產品解決方案的源碼路徑
    的頭像 發表于 05-09 10:32 ?1022次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b><b class='flag-5'>開發板</b>:【產品<b class='flag-5'>配置</b><b class='flag-5'>規則</b>】

    鴻蒙OpenHarmony開發板解析:【 模塊配置規則

    編譯子系統通過模塊、部件和產品三層配置來實現編譯和打包。模塊就是編譯子系統的一個目標,包括(動態庫、靜態庫、配置文件、預編譯模塊等)。模塊要定義屬于哪個部件,一個模塊只能歸屬于一個
    的頭像 發表于 05-10 14:39 ?856次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b><b class='flag-5'>開發板</b><b class='flag-5'>解析</b>:【 模塊<b class='flag-5'>配置</b><b class='flag-5'>規則</b>】

    鴻蒙OpenHarmony開發板解析:【Rust模塊配置規則和指導】

    Rust是一門靜態強類型語言,具有更安全的內存管理、更好的運行性能、原生支持多線程開發等優勢。Rust官方也使用Cargo工具來專門為Rust代碼創建工程和構建編譯。 OpenHarmony為了集成
    的頭像 發表于 05-10 11:32 ?1231次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b><b class='flag-5'>開發板</b><b class='flag-5'>解析</b>:【Rust模塊<b class='flag-5'>配置</b><b class='flag-5'>規則</b>和指導】

    鴻蒙OpenHarmony開發板解析:【芯片解決方案】

    芯片解決方案是指基于某款開發板的完整解決方案,包含驅動、設備側接口適配、開發板sdk等。
    的頭像 發表于 05-10 15:42 ?1165次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b><b class='flag-5'>開發板</b><b class='flag-5'>解析</b>:【芯片解決方案】

    鴻蒙OpenHarmony南向/北向快速開發教程-迅為RK3568開發板

    大家期待已久的迅為RK3568開發板終于迎來了鴻蒙4.1系統的強勢支持!想知道如何實現快速開發學習嗎?跟著我們一起來探索吧! 迅為RK3568開發板: 想象一下,你手中的RK3568
    發表于 07-23 10:44

    迅為RK3568開發板鴻蒙OpenHarmony系統固件燒寫步驟

    1、迅為RK3568開發板鴻蒙OpenHarmony系統固件燒寫首先拷貝燒寫器(燒寫器在光盤資料“iTOP-3568 開發板\01_【iTOP-RK3568
    發表于 08-26 17:45

    openharmony開發openharmony開發板

    現在市面上支持OpenHarmony開發板已經非常多了,OpenHarmony不僅僅只能在海思系列芯片上運行,比較常見的有HiSpark、小熊派系列。這些開發板都是基于海思的Hi38
    的頭像 發表于 06-24 09:03 ?3621次閱讀

    開發板如何適配OpenHarmony 3.2

    科技基于RK3568設計的HCPAD-100開發板以及基于RK3566設計的中控屏HongzPad2022在OpenHarmony 3.2 Beta5版本上的適配過程。 涉及到開發板的添加/u-boot /linux-5.10/
    的頭像 發表于 04-04 01:35 ?1450次閱讀

    OpenHarmony鴻蒙南向開發案例:【智能貓眼(基于3516開發板)】

    基于Hi3516開發板,使用開源OpenHarmony開發的RTSP協議流媒體應用。達到將Hi3516開發板中攝像頭獲取的數據通過RTSP協議傳輸到手機并顯示 。
    的頭像 發表于 04-19 22:01 ?549次閱讀
    <b class='flag-5'>OpenHarmony</b><b class='flag-5'>鴻蒙</b>南向<b class='flag-5'>開發</b>案例:【智能貓眼(基于3516<b class='flag-5'>開發板</b>)】

    鴻蒙OpenHarmony開發板解析:【系統能力配置規則

    SysCap(SystemCapability,系統能力)是部件開發者提供的接口的集合。
    的頭像 發表于 05-11 10:10 ?467次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b><b class='flag-5'>開發板</b><b class='flag-5'>解析</b>:【系統能力<b class='flag-5'>配置</b><b class='flag-5'>規則</b>】

    瑞芯微RK3568鴻蒙開發板OpenHarmony系統修改cfg文件權限方法

    本文適用于OpenHarmony開源鴻蒙系統修改cfg文件權限方法,深圳觸覺智能研發的RK3566、RK3568、RK3588等開發板、主板等產品均適用此教程
    的頭像 發表于 09-11 13:26 ?781次閱讀
    瑞芯微RK3568<b class='flag-5'>鴻蒙</b><b class='flag-5'>開發板</b><b class='flag-5'>OpenHarmony</b>系統修改cfg文件權限方法

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

    觸覺智能Purple Pi OH鴻蒙開發板,成功適配OpenHarmony5.0 Release版本!為大家帶來OpenHarmony5.0特性講解!關注觸覺智能,為大家帶來更多
    的頭像 發表于 10-25 10:51 ?311次閱讀
    觸覺智能Purple Pi OH<b class='flag-5'>鴻蒙</b><b class='flag-5'>開發板</b>成功適配<b class='flag-5'>OpenHarmony</b>5.0 Release,開啟新征程

    如何在開源鴻蒙OpenHarmony開啟SELinux模式?RK3566鴻蒙開發板演示

    本文介紹開源鴻蒙OpenHarmony系統下,開啟/關閉SELinux權限的方法,觸覺智能Purple Pi OH鴻蒙開發板演示,已適配全新Open
    的頭像 發表于 11-18 19:03 ?187次閱讀
    如何在開源<b class='flag-5'>鴻蒙</b><b class='flag-5'>OpenHarmony</b>開啟SELinux模式?RK3566<b class='flag-5'>鴻蒙</b><b class='flag-5'>開發板</b>演示