色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

剖析OpenHarmony3.0編譯構建流程

OpenHarmony技術社區 ? 來源:HarmonyOS技術社區 ? 作者:亮子力 ? 2021-12-07 10:54 ? 次閱讀

早就打算研究下 OH3.0 的編譯框架了,最近一直在搞移植,總算有點進展了,抽個空來分析下 3.0 的編譯框架。

大體看了下和 2.0 的差別不是特別大:《OpenHarmony 2.0 Canary編譯構建流程》。

OHOS3.0 的打包鏡像腳本由原來 2.0 的 buildadapteruild_image.sh,全部修改替換為 buildohosimagesuild_image.py,將打包 image 鏡像的部分制作成 build_target。

以前是通過 shell 腳本來調用,現在是通過 gn 和 ninja 來調用。主要文件在 buildohosimages 這個文件夾下。

沒有修改的部分就不說了,有需要的可以看我之前的帖子 這篇主要說下不一樣的地方,看 OH3.0 是如何將編譯好的文件打包成鏡像的。

增加編譯參數

3.0 之后在 builduild_scriptsuild_common.sh 增加了 build_cmd+=" build_target=images"。

這句的意思約等于在執行默認編譯命令 ./build.sh --product-name Hi3516DV300 會有個默認的參數 --build-target images。

具體流程是這樣的:

builduild_scriptsuild_common.sh→buildcoregnBUILD.gn→buildohosimagesBUILD.gn
action_with_pydeps("${_platform}_${_image_name}_image"){
script="http://build/ohos/images/build_image.py"
depfile="$target_gen_dir/$target_name.d"
deps=["http://build/ohos/packages:${_platform}_install_modules"]

image_config_file=
"http://build/ohos/images/mkimage/${_image_name}_image_conf.txt"
output_image_file="$current_platform_dir/images/${_image_name}.img"

image_input_path="$current_platform_dir/${_image_name}"
if(_image_name=="userdata"){
image_input_path="$current_platform_dir/data"
}

sources=[
image_config_file,
system_module_info_list,
system_modules_list,
]
outputs=[output_image_file]
args=[
"--depfile",
rebase_path(depfile,root_build_dir),
"--image-name",
_image_name,
"--input-path",
rebase_path(image_input_path,root_build_dir),
"--image-config-file",
rebase_path(image_config_file,root_build_dir),
"--output-image",
rebase_path(output_image_file,root_build_dir),
"--build-image-tools-path",
rebase_path(build_image_tools_path,root_build_dir),
]
if(sparse_image){
args+=["--sparse-image"]
}
}

通常情況下,gn 會使用 action 運行一個腳本來生成一個文件,但是這里使用的是 action_with_pydeps,應該也是內置的目標類型。查看官方手冊是這么說明的:

輸入和文件,將操作讀取(或執行)的所有文件列為 inputs:

  • 僅按從屬目標列出輸入是不夠的。它們必須由使用它們的目標直接列出,或者由 depfile 添加。

  • 非系統 Python 導入是輸入!對于導入此類模塊的腳本,請使用 action_with_pydeps 來確保將所有依賴的 Python 文件捕獲為輸入。

前面還定義了一個 image_list,然后使用 foreach 執行 action_with_pydeps,要生成幾個 img 文件,就執行幾次 action_with_pydeps。
image_list=[
"system",
"vendor",
"userdata",
"updater",
]
foreach(_image_name,image_list){......}

調用 python 腳本

既然知道了 img 鏡像是由 buildohosimagesuild_image.py 來創建的,那就來分析下這個 python 腳本。
ifos.path.exists(args.output_image_path):
os.remove(args.output_image_path)#刪除之前生成的鏡像文件夾
ifargs.image_name=='userdata':
_prepare_userdata(args.input_path)#準備好userdata.img需要的文件
ifos.path.isdir(args.input_path):
_make_image(args)
_dep_files=[]
for_root,_,_filesinos.walk(args.input_path):
for_filein_files:
_dep_files.append(os.path.join(_root,_file))
build_utils.write_depfile(args.depfile,
args.output_image_path,
_dep_files,
add_pydeps=False)
===================================================================
def_make_image(args):
ifargs.image_name=='system':
_prepare_root(args.input_path)#準備好system.img需要的文件
elifargs.image_name=='updater':
_prepare_updater(args.input_path)#準備好updater.img需要的文件
image_type="raw"
ifargs.sparse_image:
image_type="sparse"
mk_image_args=[
args.input_path,args.image_config_file,args.output_image_path,
image_type
]
env_path="../../build/ohos/images/mkimage"
ifargs.build_image_tools_path:
env_path='{}:{}'.format(env_path,args.build_image_tools_path)
os.environ['PATH']='{}:{}'.format(env_path,os.environ.get('PATH'))
mkimages.mk_images(mk_image_args)#而真正制作鏡像使用的下面的函數
===================================================================
#buildohosimagesmkimagemkimages.py
defmk_images(args):
......
if"system.img"indevice:
src_dir=build_rootdir(src_dir)
mkfs_tools,mk_configs=load_config(config_file)
mk_configs=src_dir+""+device+""+mk_configs

res=run_cmd(mkfs_tools+""+mk_configs)#制作鏡像命令使用的是mkfs_tools
===================================================================
if"ext4"inmk_configs:
fs_type="ext4"
mkfs_tools="mkextimage.py"#而mkfs_tools根據文件系統類型,分別調用對應的python腳本
elif"f2fs"inmk_configs:
mkfs_tools="mkf2fsimage.py"
fs_type="f2fs"
===================================================================
#buildohosimagesmkimagemkextimage.py#制作ext4文件系統
defbuild_run_mke2fs(args):
.....
blocks=int(int(args.fs_size)/BLOCKSIZE)
mke2fs_cmd+=("mke2fs"+str(mke2fs_opts)+"-t"+FS_TYPE+"-b"
+str(BLOCKSIZE)+""+args.device+""+str(blocks))
res=run_cmd(mke2fs_cmd)# mke2fs:制作文件系統
===================================================================
defbuild_run_e2fsdroid(args):
......
e2fsdroid_cmd+=("e2fsdroid"+e2fsdroid_opts+"-f"+
args.src_dir+"-a"+args.mount_point+
""+args.device)
res=run_cmd(e2fsdroid_cmd)# e2fsdroid:制作鏡像文件

無論前面執行了什么操作,最終都是為了執行 mke2fs、e2fsdroid。

關于這兩個命令:

  • mke2fs:Linux 下的命令,用于建立 ext 文件系統。

  • e2fsdroid:來自三方庫,third_partye2fsprogs。

詳情可以參考:

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

    關注

    87

    文章

    11312

    瀏覽量

    209702
  • 編譯
    +關注

    關注

    0

    文章

    659

    瀏覽量

    32891
  • OpenHarmony
    +關注

    關注

    25

    文章

    3725

    瀏覽量

    16369

原文標題:OpenHarmony3.0編譯構建流程!

文章出處:【微信號:gh_834c4b3d87fe,微信公眾號:OpenHarmony技術社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    OpenHarmony源碼編譯后燒錄鏡像教程,RK3566鴻蒙開發板演示

    本文介紹瑞芯微主板/開發板編譯OpenHarmony源碼后燒錄鏡像的教程,觸覺智能Purple Pi OH鴻蒙開發板演示。搭載了瑞芯微RK3566四核處理器,樹莓派卡片電腦設計,支持開源鴻蒙OpenHarmony3.2-5.0系
    的頭像 發表于 12-30 10:08 ?76次閱讀
    <b class='flag-5'>OpenHarmony</b>源碼<b class='flag-5'>編譯</b>后燒錄鏡像教程,RK3566鴻蒙開發板演示

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

    源碼 P3_初次編譯OpenHarmony源碼 P4_OpenHarmony鏡像簡介以及燒寫工具配置 P5_優化開發流程-搭建windows開發環境 P6_優化開發
    發表于 07-23 10:44

    AI編譯器技術剖析

    隨著人工智能技術的飛速發展,AI編譯器作為一種新興的編譯技術逐漸進入人們的視野。AI編譯器不僅具備傳統編譯器的功能,如將高級語言編寫的源代碼轉換為機器可執行的代碼,還融入了人工智能技術
    的頭像 發表于 07-17 18:28 ?1660次閱讀

    開源鴻蒙 編譯OpenHarmony輕量系統QEMU RISC-V版本

    本文將介紹如何為QEMU RISC-V虛擬平臺構建OpenHarmony輕量系統。得益于QEMU的CPU指令集模擬執行能力,該方法可以在沒有開發板的情況下調試和運行OpenHarmony系統源碼。本文介紹的該方法,可以用于
    的頭像 發表于 07-15 10:36 ?1100次閱讀
    開源鴻蒙 <b class='flag-5'>編譯</b><b class='flag-5'>OpenHarmony</b>輕量系統QEMU RISC-V版本

    鴻蒙OpenHarmony【輕量系統 編譯】 (基于Hi3861開發板)

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

    鴻蒙OpenHarmony開發:【編譯構建指導】

    OpenHarmony編譯子系統是以GN和Ninja構建為基座,對構建和配置粒度進行部件化抽象、對內建模塊進行功能增強、對業務模塊進行功能擴展的系統,該系統提供以下基本功能
    的頭像 發表于 05-13 09:31 ?1836次閱讀
    鴻蒙<b class='flag-5'>OpenHarmony</b>開發:【<b class='flag-5'>編譯</b><b class='flag-5'>構建</b>指導】

    鴻蒙OpenHarmony【小型系統 編譯】(基于Hi3516開發板)

    OpenHarmony支持hb和build.sh兩種編譯方式。此處介紹hb方式,build.sh腳本編譯方式請參考[使用build.sh腳本編譯源碼]。
    的頭像 發表于 05-10 15:59 ?716次閱讀
    鴻蒙<b class='flag-5'>OpenHarmony</b>【小型系統 <b class='flag-5'>編譯</b>】(基于Hi3516開發板)

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

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

    鴻蒙OpenHarmony【標準系統 編譯】(基于RK3568開發板)

    OpenHarmony支持hb和build.sh兩種編譯方式。此處介紹hb方式,build.sh腳本編譯方式請參考[使用build.sh腳本編譯源碼]。
    的頭像 發表于 05-08 17:37 ?1187次閱讀
    鴻蒙<b class='flag-5'>OpenHarmony</b>【標準系統 <b class='flag-5'>編譯</b>】(基于RK3568開發板)

    【鴻蒙】OpenHarmony使用strace

    。當然也可以利用 strace 去學習了解進程的運行流程,調用庫以及參數和統計。那么如何在 OpenHarmony編譯使用此工具就是我們這篇文章要分享的話題。 編譯
    的頭像 發表于 03-01 09:41 ?817次閱讀
    【鴻蒙】<b class='flag-5'>OpenHarmony</b>使用strace

    鴻蒙開發【編譯構建】講解

    的詳細信息,例如執行的編譯流程、任務的執行時間等信息。如果在編譯構建過程中出現錯誤,您可以根據編譯任務的詳細錯誤說明進行問題的定位。 API
    發表于 02-27 17:41

    [鴻蒙]OpenHarmony4.0的Rust開發

    OpenHarmony 為了集成 C/C++ 代碼和提升編譯速度,使用了 GN + Ninja 的編譯構建系統。GN 的構建語言簡潔易讀
    的頭像 發表于 02-26 17:28 ?904次閱讀
    [鴻蒙]<b class='flag-5'>OpenHarmony</b>4.0的Rust開發

    OpenHarmony 移植:build lite 編譯構建過程

    這些疑惑,會對 build lite 編譯構建過程有個更深入的理解。 1、產品解決方案代碼是如何被調用編譯的 在文件 buildliteBUILD.gn 配置文件中的構建目標 //bu
    的頭像 發表于 02-19 16:19 ?973次閱讀

    OpenHarmony 移植:build lite 配置目錄全梳理

    命令行工具 hb (HarmonyOS|OpenHarmony Build 編譯構建系統的縮寫) 都很熟悉了。這是一個基于 gn 和 ninja 的構建系統,以支持
    的頭像 發表于 02-18 16:42 ?965次閱讀

    淺談兼容 OpenHarmony 的 Flutter

    拓展,可支持使用 Flutter Tools 指令編譯構建 OpenHarmony 應用程序。 倉庫的 commit 記錄顯示,OpenHarmony 使用的 Flutter 版本是
    的頭像 發表于 02-02 15:22 ?618次閱讀
    淺談兼容 <b class='flag-5'>OpenHarmony</b> 的 Flutter
    主站蜘蛛池模板: 免费看片A级毛片免费看| 国精产品一区一区三区M| 国产精品97久久AV色婷婷综合| 久久大香萑太香蕉av| 我们日本在线观看免费动漫下载| xiao77唯美清纯| 免费精品美女久久久久久久久久| 亚洲精品喷白浆在线观看| 国产不卡无码高清视频| 日本888xxxx| 成年人在线免费观看视频网站| 暖暖视频免费观看社区| 99re热视频这里只有精品| 麻豆精品一区二正一三区 | 国产午夜在线观看视频播放| 色爰情人网站| 国产免费看黄的私人影院| 小萝ar视频网站| 狠狠躁日日躁人人爽| 亚洲香蕉网久久综合影院| 久久精品国产亚洲AV久五月天| 野花高清影视免费观看| 狼好色有你好看| 99久久精品免费国产一区二区三区| 免费成人高清在线视频| SORA是什么意思| 玩两个少妇女邻居| 娇小亚裔被两个黑人| 中文无码字慕在线观看| 欧美成人国产| 国产3级在线| 亚洲日韩在线观看| 乱码午夜-极品国产内射| 扒开校花粉嫩小泬喷潮漫画| 婷婷六月激情综合一区| 精品久久久噜噜噜久久久app | 亚洲 欧美 国产 综合 播放 | 国产精品97久久久久久AV色戒| 亚洲国产精品久久无套麻豆| 久久伊人电影| 超碰久久国产vs|