[经验分享] OpenHarmony编译环境搭建 (兼容至4.0-Master和主干分支) 原创 精华

dragon 显示全部楼层 发表于 2023-11-6 14:19:49
预备工作
1. 安装虚拟机工具VMware或者VirtualBox。
2. 新建虚拟机,内存16GB及以上,硬盘100GB及以上。
3. 安装Ubuntu,推荐使用20.04版本。用户名不能包含中文。
4. 启动并进入Ubuntu虚拟机,以下步骤将在Ubuntu虚拟机中进行操作。

一、将Shell环境修改为bash
  1. sudo dpkg-reconfigure dash
复制代码

选择“No”。
1.png

二、替换Ubuntu软件源
在“https://mirrors.ustc.edu.cn/repogen/”下载对应版本最新的源。
2.png

在下载好的文件(sources.list)所在的位置开启一个终端窗口,执行下列命令。

备份原始文件:
  1. sudo cp /etc/apt/sources.list /etc/apt/source.list.bak
复制代码

替换源:
  1. sudo mv -f sources.list /etc/apt/
复制代码

更新软件包索引:
  1. sudo apt update
复制代码

三、安装必要的库和工具
需要分两步进行安装。注意,这里比较重要,官网文档用一步进行安装,会出现问题,导致安装不完整,从而导致后期编译出现“3000”错误。
  1. sudo apt-get install binutils binutils-dev git git-lfs gnupg flex bison gperf build-essential zip curl zlib1g-dev   libc6-dev-i386 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
复制代码
  1. sudo apt-get install gcc-arm-linux-gnueabi gcc-9-arm-linux-gnueabi
复制代码

四、配置Python
设置默认Python解释器,python和python3软链接为python3.8:
  1. sudo update-alternatives --install /usr/bin/python python /usr/bin/python3.8 1
  2. sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1
  3. python --version
复制代码

安装python包管理工具(pip3):
  1. sudo apt install python3-pip
复制代码

配置pip软件包更新源:
  1. mkdir ~/.pip
  2. pip3 config set global.index-url https://mirrors.huaweicloud.com/repository/pypi/simple
  3. pip3 config set global.trusted-host mirrors.huaweicloud.com
  4. pip3 config set global.timeout 120
复制代码

五、安装Samba服务
用于在开发环境中使用VS Code编写代码。执行下列命令安装samba并打开配置文件:
  1. sudo apt install samba
  2. sudo gedit /etc/samba/smb.conf
复制代码

在配置文件末尾添加以下内容:
  1. [home]
  2. comment = User Homes
  3. path = /home
  4. guest ok = no
  5. writable = yes
  6. browsable = yes
  7. create mask = 0755
  8. directory mask = 0755
复制代码

建立用户并设置密码(请将下面的用户名换成您自己的)
  1. sudo smbpasswd -a dragon
复制代码

重启samba:
  1. sudo service smbd restart
复制代码

六、获取源代码的必要工具和配置
安装git-lfs,会自动安装git:
  1. sudo apt install git-lfs
复制代码

安装repo和requests:
  1. wget https://gitee.com/oschina/repo/raw/fork_flow/repo-py3
  2. sudo mv repo-py3 /usr/local/bin/repo
  3. sudo chmod a+x /usr/local/bin/repo
  4. pip3 install -i https://repo.huaweicloud.com/repository/pypi/simple requests
复制代码

配置git(请将下面的邮箱和用户名换成您自己的):
  1. git config --global user.email "dragon@hbu.cn"
  2. git config --global user.name "dragon"
  3. git config --global credential.helper store
  4. git config --global --add safe.directory "*"
复制代码

七、拉取源码
以4.0为例(可以拉取branch或tag,这里使用branch):
  1. mkdir -p ~/openharmony/4.0
  2. cd ~/openharmony/4.0
  3. repo init -u https://gitee.com/openharmony/manifest -b OpenHarmony-4.0-Release --no-repo-verify
  4. repo sync -c
  5. repo forall -c 'git lfs pull'
复制代码

在源码根目录下执行prebuilts脚本,安装编译器及二进制工具:
  1. bash build/prebuilts_download.sh
复制代码

八、安装编译工具
在源码根目录运行如下命令安装hb并更新至最新版本:
  1. python3 -m pip install --user build/hb
复制代码

设置环境变量:
  1. echo 'export PATH=~/.local/bin:$PATH' >> ~/.bashrc
  2. source ~/.bashrc
复制代码

九、编译
两种方式,使用hb或者build.sh。
1. 使用hb。在源码根目录运行如下命令(选择要编译的产品并进行编译):
  1. hb set
  2. hb build
复制代码

2. 使用build.sh。命令格式为:
  1. ./build.sh --product-name {product_name} --ccache
复制代码

例如,在源码根目录运行如下命令:
  1. ./build.sh --product-name rk3568 --ccache
复制代码

耐心等待,对于标准系统来说,完整编译过程会持续2-3小时。
微信截图_20231105202520.png

©著作权归作者所有,转载或内容合作请联系作者

您尚未登录,无法参与评论,登录后可以:
参与开源共建问题交流
认同或收藏高质量问答
获取积分成为开源共建先驱

精彩评论17

martinhu

沙发 发表于 2023-11-15 15:38:10

按照上述文章步骤下拉和编译,4.0 release和master编译也会报错,不知该如何处理,部分log如下: [OHOS ERROR] ld.lld: error: undefined symbol: __aarch64_cas4_acq_rel ... [OHOS ERROR] ld.lld: error: .btf.vmlinux.bin.o: unknown file type ... [OHOS ERROR] exceptions.ohos_exception.OHOSException: ninja phase failed [OHOS ERROR] [OHOS ERROR] Code: 4000

lucky1

发表于 2023-11-16 11:14  IP属地: 广东省广州市

回复 martinhu: 会不会是源码有点问题呢,之前3.2的出现报错重新拉取源码搭好环境编译就没问题了,但是4.0的我尝试好多次了一样的错误,还是说还有什么地方还差着什么没有配置吗。。。

马迪

发表于 2023-11-17 09:54  IP属地: 江苏省扬州市

dragon

发表于 2023-11-18 09:16  IP属地: 河北省唐山市

回复 lucky1: 虚拟机内存分配了多少?

【5 条回复】 查看全部

点评

虚拟机内存分配了多少?  发表于 2023-11-18 09:15

alexsuo

板凳 发表于 2024-1-21 09:23:30
用同样的办法编译dayu210 却会失败,博主有没有经验可以分享?

冷钦街

地板 发表于 2024-1-23 10:07:18
搭建环境有困难的同学,可以使用我的在线平台试试,目前已经正式发布
使用方法参考我之前发的文章或查看在线帮助视频

https://lengqinjie.xyz/lab/index

faceoh

发表于 2024-2-1 14:23  IP属地: - 中国江苏省扬州市 中国电信IDC

回复 冷钦街: 登陆在线平台后提示我更换浏览器是什么问题?我用edge和chrome都试了,还是同样的问题

冷钦街

发表于 2024-2-15 20:54  IP属地: - 中国四川省 中国电信IDC

回复 faceoh: 可能是浏览器不支持,更大的可能是网络不流畅,更换一下网络环境,可能就好了。

2964213324

发表于 2024-6-12 21:36  IP属地: 福建省泉州市

回复 冷钦街: 哥不行耶

【3 条回复】

lindorx_MZ4pM

6# 发表于 2024-5-12 12:03:22
博主写的很全

pengbiao

7# 发表于 2024-6-9 14:52:21
请问为什么我是用hb build只读取配置而不编译呢
[OHOS INFO] The run time for _prebuild_and_preload is 0.01 s

[OHOS INFO] Checking all build args...

[OHOS INFO] subsytem config scan completed

m0_63192735

发表于 2024-7-30 12:48  IP属地: 广东省广州市

回复 pengbiao: 相同问题,请问您解决了吗?或者有什么思路吗?

【1 条回复】

haha0000

8# 发表于 2024-7-29 10:47:03
安装好环境之后,就可以在任意目录下编译程序是吗,C可以吗
共17 条回复,点击查看

Copyright   ©2023  OpenHarmony开发者论坛  京ICP备2020036654号-3 |技术支持 Discuz!

返回顶部