OpenHarmony4.1源码下载、编译,生成OHOS_Image可执行文件的最简易流程

  • 准备一台Windows电脑

  • 安装VMware或者VMware Player虚拟机

  • 从华为镜像下载Ubuntu系统,用国内源下载速度更快

    • Ubuntu 镜像说明
    • https://repo.huaweicloud.com/ubuntu-releases/ 选择要下载的系统版本
    • https://repo.huaweicloud.com/ubuntu-releases/18.04.6/ubuntu-18.04.6-desktop-amd64.iso 我使用此链接下载
  • 下载开源鸿蒙系统源码

    • https://repo.huaweicloud.com/harmonyos/os/ 选择要下载的系统版本
    • https://repo.huaweicloud.com/harmonyos/os/4.0-Release/code-v4.0-Release.tar.gz 我下载这个,28G
  • VMware虚拟机中安装Ubuntu系统

  • 安装完之后进入系统,使用命令行将官方源换成华为源,这样下载软件时更快

    • 参考自:https://res-static.hc-cdn.cn/cloudbu-site/china/zh-cn/SEO/mirror/Ubuntu.pdf
    • sudo cp -a /etc/apt/sources.list /etc/apt/sources.list.bak 备份配置文件
    • sudo sed -i “s@http://.*archive.ubuntu.com@http://repo.huaweicloud.com@g” /etc/apt/sources.list
    • sudo sed -i “s@http://.*security.ubuntu.com@http://repo.huaweicloud.com@g” /etc/apt/sources.list
    • sudo apt-get update
  • 在Ubuntu系统中解压上面已经下载的openHarmony源码

  • 在Ubuntu系统中安装Docker

    • 官方文档介绍-Docker编译环境
    • sudo apt install docker.io
    • sudo docker pull swr.cn-south-1.myhuaweicloud.com/openharmony-docker/docker_oh_mini:3.2 获取轻量系统镜像,获取小型和标准的则使用不同的参数
  • 将你下载好的鸿蒙源码在Ubuntu下解压,进入已经解压的源码根目录

  • 执行 sudo docker run -it -v $(pwd):/home/openharmony swr.cn-south-1.myhuaweicloud.com/openharmony-docker/docker_oh_mini:3.2 将源码路径导入到Docker中

  • 编译

    • 轻型系统
      • python3 build.py -p qemu_mini_system_demo@ohemu
    • 小型系统
      • python3 build.py -p ipcamera_hispark_taurus@hisilicon
      • python3 build.py -p qemu_small_system_demo@ohemu
    • 编译工具和开发板都分为轻型、小型、标准,必须属于同一种类型,否则编译时各种报错
  • 编译成功后是这样的打印:

[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:47
root@ff38bf1e3e75:/home/openharmony# 

jim@ubuntu:~/openHarmony/out/arm_mps2_an386/qemu_mini_system_demo$ ls
all_parts_host.json           build_configs   config.h         kconfig_files.txt  OHOS_Image.bin              src_installed_parts.json
all_parts_info.json           build.log       error.log        libs               OHOS_Image.map              src_sa_infos_tmp.json
args.gn                       build.ninja     etc              NOTICE_FILES       OHOS_Image.sym.sorted       startup
binary_installed_parts.json   build.ninja.d   gen              obj                packages                    thirdparty
build.1709259296.3884952.log  build.trace.gz  hiviewdfx        OHOS_Image         security                    toolchain.ninja
build.1709259767.6772568.log  config.gni      kconfig_env.txt  OHOS_Image.asm     sorted_action_duration.txt
jim@ubuntu:~/openHarmony/out/arm_mps2_an386/qemu_mini_system_demo$ 
  • 生成的系统镜像image是这里面的OHOS_Image文件

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

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

如果想更深入的学习 OpenHarmony 开发的内容,可以参考以下学习文档:

OpenHarmony 开发环境搭建:https://qr18.cn/CgxrRy

《OpenHarmony源码解析》:https://qr18.cn/CgxrRy

  • 搭建开发环境
  • Windows 开发环境的搭建
  • Ubuntu 开发环境搭建
  • Linux 与 Windows 之间的文件共享
  • ……

系统架构分析:https://qr18.cn/CgxrRy

  • 构建子系统
  • 启动流程
  • 子系统
  • 分布式任务调度子系统
  • 分布式通信子系统
  • 驱动子系统
  • ……

OpenHarmony 设备开发学习手册:https://qr18.cn/CgxrRy

OpenHarmony面试题(内含参考答案):https://qr18.cn/CgxrRy

<think>好的,我现在需要帮助用户解决在RK3568平台上基于OpenHarmony 4.1单独编译Kernel的问题。首先,我需要回顾用户提供的引用内容,看看是否有相关的信息可以利用。 用户引用了三个来源:[^1]提到了下载OpenHarmony 4.1-Beta1的全量代码,并建议更换环境或芯片类型;[^2]给出了初始化仓库和同步代码的具体命令,适用于4.1-Release分支;[^3]则指出了背光驱动的代码路径,可能和驱动开发有关,但暂时可能不直接相关。 用户的请求是单独编译Kernel,而不是整个系统。通常,单独编译内核需要确保代码正确检出,配置正确,以及使用正确的编译命令。根据OpenHarmony的文档,编译内核可能需要使用特定的工具链和配置文件。 首先,我需要确认用户是否已经正确下载了代码。根据引用[^2],用户需要初始化并同步代码到正确的分支,比如OpenHarmony-4.1-Release。然后,可能需要进入kernel目录,进行配置。RK3568使用的内核版本可能是Linux 5.10,如引用中的路径所示,这可能意味着内核源码在linux-5.10目录下。 接下来,编译步骤可能包括设置环境变量,选择正确的配置文件(比如rockchip_defconfig),然后使用make命令进行编译。同时,用户可能需要指定架构为arm64,交叉编译工具链的位置也需要正确设置。 另外,用户可能需要处理依赖项,如确保所需的驱动模块已经包含在配置中。例如,PWM背光驱动可能与显示相关,但单独编译内核可能不需要特别处理这些驱动,除非有定制需求。 可能的潜在问题包括:工具链未正确安装,配置文件不存在,或依赖的代码未完全同步。根据引用,如果遇到问题,建议更换环境或使用他人配置好的虚拟机,这可能是一个备选方案。 现在,我需要将这些步骤整理成一个清晰的指南,确保用户能够逐步执行。同时,生成相关问题,帮助用户深入理解可能遇到的挑战和进一步的优化方法。 需要验证步骤的正确性,比如检查OpenHarmony的官方文档是否有单独编译内核的说明,或者社区中的实践案例。如果用户提供的引用中没有直接说明,可能需要补充一般性的Linux内核编译步骤,并适配到OpenHarmony的环境。 总结步骤可能如下: 1. 同步代码到指定分支。 2. 进入内核目录。 3. 配置环境变量和工具链。 4. 生成配置文件。 5. 执行编译命令。 6. 处理输出文件。 后,生成相关问题,例如如何配置内核选项,如何优化编译时间,如何处理编译错误等。</think>### RK3568 OpenHarmony 4.1 单独编译Kernel步骤 #### 1. 代码准备 首先确保已正确同步OpenHarmony 4.1代码: ```bash repo init -u https://gitee.com/openharmony/manifest.git -b OpenHarmony-4.1-Release --no-repo-verify repo sync -c repo forall -c 'git lfs pull' ``` 同步完成后,内核代码位于`kernel/linux/linux-5.10`目录。 --- #### 2. 配置编译环境 进入内核目录并设置工具链路径: ```bash cd kernel/linux/linux-5.10 export PATH=$PATH:$(pwd)/../../prebuilts/clang/ohos/linux-x86_64/llvm/bin export CROSS_COMPILE=aarch64-linux-gnu- export ARCH=arm64 ``` --- #### 3. 生成配置文件 使用RK3568默认配置: ```bash make rockchip_linux_defconfig # 适用于RK3568的标准配置 ``` --- #### 4. 编译内核 执行编译命令(可添加-jN参数加速,N为CPU线程数): ```bash make -j8 ``` 编译完成后,内核镜像文件为`arch/arm64/boot/Image`,设备树文件为`arch/arm64/boot/dts/rockchip/rk3568.dtb`[^3]。 --- #### 5. 常见问题处理 - **工具链问题**:若提示交叉编译工具缺失,需检查`prebuilts/clang`目录是否完整,可尝试重新同步代码。 - **依赖缺失**:若编译报错缺少头文件,需确认是否已通过`repo sync -c`同步全部依赖[^1]。 - **驱动兼容性**:若需修改背光等驱动,参考原生驱动路径`drivers/video/backlight/pwm_bl.c`进行调整。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值