2 开源鸿蒙OpenHarmony4.1源码下载和编译流程

开源 0

开源鸿蒙OpenHarmony源码下载和编译流程

作者将狼才鲸
日期2024-02-29

  • 前景提要:

  • 确定你要编译哪一块开发板:

    • 我选择qemu_mini_system_demo 这个板子
    • 编译形态整体说明,含QEMU,可以编译哪些开发板和芯片
    • qemu模拟器 + arm核 + mini轻型系统的配置有:
      • qemu_mini_system_demo arm_mps2_an386 qemu liteos_m mini arm-cortex-m4
      • qemu_cm55_mini_system_demo arm_mps3_an547 qemu liteos_m mini arm-cortex-m55
      • Qemu Arm Cortex-m4 mps2-an386 教程
      • Qemu Arm Cortex-m55 mps3-an547 教程
      • QEMU(Quick Emulator)鸿蒙QEMU模拟器操作指南
  • 安装基础开发环境:安装VMware虚拟机+Ubuntu发行版系统+Git软件+repo软件+Python

  • 编译开源鸿蒙源码前先下载源码

    • 步骤见:开源鸿蒙OpenHarmony niobe407 STM32F407IGT6芯片轻型系统全量源码4.1版本下载流程
    • 使用 repo init -u https://gitee.com/openharmony/manifest -b master -m chipsets/qemu.xml -g ohos:mini 初始化对应于QEMU模拟器(类似于开发板)的全套源码
    • 按前面的步骤下载鸿蒙源码
  • 编译:

  • 编译的相关介绍

    • 需要使用hb命令,也就是ohos-build
      • 了解OpenHarmony-编译
      • OpenHarmony支持hb和build.sh两种编译方式。
      • 安装hb编译工具
      • 安装库和工具集
      • .sh方式编译构建指导
    • 安装流程介绍:
      • hb安装异常处理
      • 快速入门-如何编译程序
      • 安装库和工具集-编译流程

  • 编译步骤(先安装编译工具):

    • python3 -V 查看python版本,如果是3.8以下,则:

      • sudo apt install python3.8
      • sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1
      • sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.6 2
      • sudo update-alternatives --config python3
      • python3 -V
    • python3 -m pip install --user ohos-build

      • pip3是Python的包管理工具,用于安装、升和管理Python包
      • 需要python3.8以上的版本
  • 如果你是Ubuntu18.04,则先执行

    • cd /usr/lib/python3/dist-packages
    • cp apt_pkg.cpython-36m-x86_64-linux-gnu.so apt_pkg.so apt_pkg.cpython-39m-x86_64-linux-gnu.so apt_pkg.so
    • cd -
  • 先安装依赖库

  • sudo apt-get update && sudo apt-get install binutils binutils-dev git git-lfs gnupg flex bison gperf build-essential zip curl zlib1g-dev gcc-multilib g+±multilib gcc-arm-linux-gnueabi libc6-dev-i386 libc6-dev-amd64 lib32ncurses5-dev x11proto-core-dev libx11-dev lib32z1-dev ccache libgl1-mesa-dev libxml2-utils xsltproc unzip m4 bc gnutls-bin python3.8 python3-pip ruby genext2fs device-tree-compiler make libffi-dev e2fsprogs pkg-config perl openssl libssl-dev libelf-dev libdwarf-dev u-boot-tools mtd-utils cpio doxygen liblz4-tool openjdk-8-jre gcc g++ texinfo dosfstools mtools default-jre default-jdk libncurses5 apt-utils wget scons python3.8-distutils tar rsync git-core libxml2-dev lib32z-dev grsync xxd libglib2.0-dev libpixman-1-dev kmod jfsutils reiserfsprogs xfsprogs squashfs-tools pcmciautils quota ppp libtinfo-dev libtinfo5 libncurses5-dev libncursesw5 libstdc++6 gcc-arm-none-eabi vim ssh locales libxinerama-dev libxcursor-dev libxrandr-dev libxi-dev 安装编译时依赖的软件和库

    • 仔细看安装后的信息,如果提示有哪些包未安装成功,则你需要单独安装
    • sudo apt-get install g+±multilib 这里其实是g加号加号减号multilib,会被csdn识别成别的格式
    • sudo apt-get install gcc-arm-linux-gnueabi
    • sudo apt-get install gcc-multilib
    • sudo apt-get install lib32ncurses5-dev
    • sudo apt-get install lib32z1-dev
    • sudo apt-get install libc6-dev-i386
  • 按前面的流程下载全量源码,或者特定开发板特定芯片的源码

  • 进入到你下载的源码根目录

  • bash build/prebuilts_download.sh 安装和芯片相关的编译器和二进制工具,全自动的,会下载的同时进行安装,要等待一段时间,有进度条

  • python3 -m pip install --user build/hb

  • gedit ~/.bashrc

  • 将 export PATH=~/.local/bin:$PATH 加入到最后一行并保存退出

  • source ~/.bashrc

  • hb --help 这个命令执行时可能有报错,有什么错误就解决什么错误,例如用下面方法解决报错

    • python3 -m pip uninstall ohos-build
    • python3 -m pip install --user ohos-build==0.4.3
  • hb set 进行编译设置

    • 第一步目录输入. 选择源码根目录的当前目录
    • 第二步选择开发板,我使用上下方向键选择qemu_mini_system_demo这款qemu的模拟器开发板,ARM Cortex-M4内核的虚拟芯片
      • 编译形态整体说明,含QEMU,可以编译哪些开发板和芯片
      • Qemu Arm Cortex-m4 mps2-an386 教程
      • qemu_mini_system_demo arm_mps2_an386 qemu liteos_m mini arm-cortex-m4
jim@ubuntu:~/openHarmony$ hb set[OHOS INFO] Input code path: .OHOS Which product do you need?  qemu_mini_system_demo
  • hb build -f 开始编译,有报错则处理报错

  • 出现build success表示编程成功,然后进行烧录,或者直接用QEMU模拟器进行运行。

  • 防止格式被破坏

  * python3 -V  查看python版本,如果是3.8以下,则:    * sudo apt install python3.8	* sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1	* sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.6 2	* sudo update-alternatives --config python3	* python3 -V    * python3 -m pip install --user ohos-build    * pip3是Python的包管理工具,用于安装、升和管理Python包	* 需要python3.8以上的版本* 安装流程介绍:  * [hb安装异常处理](https://docs.openharmony.cn/pages/v4.0/zh-cn/device-dev/quick-start/quickstart-pkg-common-hberr.md/)    * [快速入门-如何编译程序](https://gitee.com/openharmony/docs/tree/master/zh-cn/device-dev/quick-start)  * [安装库和工具集-编译流程](https://docs.openharmony.cn/pages/v4.0/zh-cn/device-dev/quick-start/quickstart-pkg-install-package.md)* 如果你是Ubuntu18.04,则先执行  * cd /usr/lib/python3/dist-packages  * cp apt_pkg.cpython-36m-x86_64-linux-gnu.so apt_pkg.so apt_pkg.cpython-39m-x86_64-linux-gnu.so apt_pkg.so  * cd -* 先安装依赖库* sudo apt-get update && sudo apt-get install binutils binutils-dev git git-lfs gnupg flex bison gperf build-essential zip curl zlib1g-dev gcc-multilib g++-multilib gcc-arm-linux-gnueabi libc6-dev-i386 libc6-dev-amd64 lib32ncurses5-dev x11proto-core-dev libx11-dev lib32z1-dev ccache libgl1-mesa-dev libxml2-utils xsltproc unzip m4 bc gnutls-bin python3.8 python3-pip ruby genext2fs device-tree-compiler make libffi-dev e2fsprogs pkg-config perl openssl libssl-dev libelf-dev libdwarf-dev u-boot-tools mtd-utils cpio doxygen liblz4-tool openjdk-8-jre gcc g++ texinfo dosfstools mtools default-jre default-jdk libncurses5 apt-utils wget scons python3.8-distutils tar rsync git-core libxml2-dev lib32z-dev grsync xxd libglib2.0-dev libpixman-1-dev kmod jfsutils reiserfsprogs xfsprogs squashfs-tools pcmciautils quota ppp libtinfo-dev libtinfo5 libncurses5-dev libncursesw5 libstdc++6 gcc-arm-none-eabi vim ssh locales libxinerama-dev libxcursor-dev libxrandr-dev libxi-dev  安装编译时依赖的软件和库  * 仔细看安装后的信息,如果提示有哪些包未安装成功,则你需要单独安装  * sudo apt-get install g++-multilib  * sudo apt-get install gcc-arm-linux-gnueabi  * sudo apt-get install gcc-multilib  * sudo apt-get install lib32ncurses5-dev  * sudo apt-get install lib32z1-dev  * sudo apt-get install libc6-dev-i386* 按前面的流程下载全量源码,或者特定开发板特定芯片的源码* 进入到你下载的源码根目录* bash build/prebuilts_download.sh  安装和芯片相关的编译器和二进制工具,全自动的,会下载的同时进行安装,要等待一段时间,有进度条* python3 -m pip install --user build/hb* gedit ~/.bashrc* 将 export PATH=~/.local/bin:$PATH 加入到最后一行并保存退出* source ~/.bashrc* hb --help    这个命令执行时可能有报错,有什么错误就解决什么错误,例如用下面方法解决报错  * python3 -m pip uninstall ohos-build  * python3 -m pip install --user ohos-build==0.4.3* hb set  进行编译设置  * 第一步目录输入.  选择源码根目录的当前目录  * 第二步选择开发板,我使用上下方向键选择qemu_mini_system_demo这款qemu的模拟器开发板,ARM Cortex-M4内核的虚拟芯片    * [编译形态整体说明,含QEMU,可以编译哪些开发板和芯片](https://docs.openharmony.cn/pages/v4.0/zh-cn/device-dev/quick-start/quickstart-appendix-compiledform.md/)    * [Qemu Arm Cortex-m4 mps2-an386 教程](https://gitee.com/openharmony/device_qemu/blob/master/arm_mps2_an386/README_zh.md)    * qemu_mini_system_demo	arm_mps2_an386	qemu	liteos_m	mini	arm-cortex-m4* hb build -f  开始编译,有报错则处理报错* 出现build success表示编程成功,然后进行烧录,或者直接用QEMU模拟器进行运行。
  • 参考资料:
    • 基于OpenHarmony搭建的Qemu仿真实验环境
    • ohos-build 安装失败分析
    • 基于Ubuntu20.04搭建OpenHarmony v3.0.6的qemu仿真环境
    • 基于OpenHarmony搭建的Qemu仿真实验环境
    • 搭建一个鸿蒙运行环境,来一窥神秘鸿蒙

  • 如果你用hb的方式编译始终出错,那么可以试试使用传统.sh脚本的方式

    • 使用build.sh脚本编译源码
  • ./build.sh --product-name qemu_mini_system_demo --ccache // 需要换成你自己开发板的名称

    • 有报错则解决报错
  • 检查编译结果。编译完成后,log中显示如下:

    • post_process
    • =====build name successful.
    • 编译所生成的文件都归档在out/{device_name}/目录下,结果镜像输出在out/{device_name}/packages/phone/images/ 目录下。
  • 如果依然编译有报错,那还可以试试Docker

    • 如果你只是想编译应用程序,那么可以使用DevEco Device Tool
    • 应用编译

  • 或者使用鸿蒙官方已经准备好的Docker环境
    • Docker编译环境
    • sudo apt install docker.io
    • sudo docker pull swr.cn-south-1.myhuaweicloud.com/openharmony-docker/docker_oh_mini:3.2
    • 进入到你下载的开源鸿蒙源码的路径,再执行下面这一条
    • docker run -it -v $(pwd):/home/openharmony swr.cn-south-1.myhuaweicloud.com/openharmony-docker/docker_oh_mini:3.2
    • 这时已经进入到docker的虚拟环境
jim@ubuntu:~/openHarmony$ sudo docker run -it -v $(pwd):/home/openharmony swr.cn-south-1.myhuaweicloud.com/openharmony-docker/docker_oh_mini:3.2root@949f932a2f80:/home/openharmony# lsapplications  build     build.sh       developtools  docs     foundation  ohos_config.json  prebuilts      qemu-run  third_partybase          build.py  commonlibrary  device        drivers  kernel      out               productdefine  test      vendorroot@949f932a2f80:/home/openharmony#
  • python3 build.py -p qemu_mini_system_demo@ohemu

    • 开始编译轻型系统,编译时间会需要很久……
    • 编译工具分为轻型、小型、标准,而芯片、开发板的归属也分为这三种,下载的工具和你编译的参数必须属于同一种类,否则会编译各种报错!!!
  • 在编译结束后,编译所生成的文件都会被存放在out/{device_name}/目录下,结果镜像输出在out/{device_name}/packages/phone/images/目录下。

  • 如果遇到报错,则解决报错

  • 编译成功后是这样的打印:

[OHOS INFO] [1614/1615] STAMP obj/build/ohos/images/make_images.stamp[OHOS INFO] [1615/1615] STAMP obj/build/core/gn/images.stamp[OHOS INFO] ccache_dir = /root/.ccache, ccache_exec = /usr/bin/ccache[OHOS INFO] --------------------------------------------[OHOS INFO] ccache summary:[OHOS INFO] ccache version: 3.7.7[OHOS INFO] cache hit (direct): 0[OHOS INFO] cache hit (preprocessed): 0[OHOS INFO] cache miss: 0[OHOS INFO] hit rate: 0.00% [OHOS INFO] miss rate: 0.00% [OHOS INFO] Cache size (GB): [OHOS INFO] ---------------------------------------------[OHOS INFO] c targets overlap rate statistics[OHOS INFO] subsystem       	files NO.	percentage	builds NO.	percentage	overlap rate[OHOS INFO] hiviewdfx       	      12	0.8%	      12	0.8%	1.00[OHOS INFO] kernel          	     902	63.5%	     902	63.5%	1.00[OHOS INFO] security        	      61	4.3%	      61	4.3%	1.00[OHOS INFO] startup         	      26	1.8%	      26	1.8%	1.00[OHOS INFO] systemabilitymgr	      15	1.1%	      15	1.1%	1.00[OHOS INFO] thirdparty      	     393	27.7%	     393	27.7%	1.00[OHOS INFO] [OHOS INFO] c overall build overlap rate: 1.00[OHOS INFO] [OHOS INFO] [OHOS INFO] qemu_mini_system_demo@ohemu build success[OHOS INFO] Cost time:  0:05:47root@ff38bf1e3e75:/home/openharmony# jim@ubuntu:~/openHarmony/out/arm_mps2_an386/qemu_mini_system_demo$ lsall_parts_host.json           build_configs   config.h         kconfig_files.txt  OHOS_Image.bin              src_installed_parts.jsonall_parts_info.json           build.log       error.log        libs               OHOS_Image.map              src_sa_infos_tmp.jsonargs.gn                       build.ninja     etc              NOTICE_FILES       OHOS_Image.sym.sorted       startupbinary_installed_parts.json   build.ninja.d   gen              obj                packages                    thirdpartybuild.1709259296.3884952.log  build.trace.gz  hiviewdfx        OHOS_Image         security                    toolchain.ninjabuild.1709259767.6772568.log  config.gni      kconfig_env.txt  OHOS_Image.asm     sorted_action_duration.txtjim@ubuntu:~/openHarmony/out/arm_mps2_an386/qemu_mini_system_demo$ 
  • 生成的系统镜像image是这里面的OHOS_Image文件

  • 如需退出Docker,执行exit命令即可。这个命令会停止当前的Docker容器,并返回到您的操作系统。

  • 下一步就可以把编译好的操作系统在QEMU模拟器中运行起来啦。

  • 如果以上步骤依然还有错,那么建议你使用不同的Ubuntu系统,并且下载OpenHarmony4.0全量代码,然后编译时换一个芯片类型,换一个系统类型再尝试;开发期间的代码不可能在每一种环境下都没有错,或者找个做过鸿蒙系统开发的,让他把他的虚拟机直接打包发给你,这样最省事。

    • 下载网址 https://repo.huaweicloud.com/openharmony/os/4.1-Beta1/code-v4.1-Beta1.tar.gz 总共30G左右

也许您对下面的内容还感兴趣: