Hi3861开发板开发环境
-
硬件环境
其中,Linux 主机用于源码下载和编译,Windows 主机用于烧写程序以及源码编辑。
-
软件环境
备注:
-
开发人员可以在Windows工作台中进行程序开发,或者远程登录到Linux服务器进行程序开发。
-
网上很多移植教程都是以Ubuntu 20.04版本移植的,为了避免踩坑,建议使用此版本。
Win10安装Ubuntu子系统及图形化界面
在准备进行安装之前,推荐C盘上至少有20G的空余空间。
相对于虚拟机的优势
Win10子系统WSL(Windows Subsystem for Linux)占用内存和CPU资源更少,在WSL上运行软件的消耗和直接在Windows上差不多,而且Windows下可以直接访问WSL的环境,相较于多系统,文件交互也更为简单。
如果使用虚拟机安装的话,Ubuntu桌面操作系统下载链接:
https://cn.ubuntu.com/download
前提条件
确保Win10系统版本>1606,建议为最新版。
查看自己系统版本可以控制台上输入:WinVer查看。
开启WSL服务
在Windows 10 中,依次选择控制面板->程序和功能->启用或关闭 Windows功能->勾选适用于Linux的Windows子系统,重启系统即可。
安装Ubuntu
Win10 应用商店中搜索:Ubuntu,下载Ubuntu 20.04 LTS。
初次启动
注意:第一次启动会进行软件安装和配置,需等待几分钟。提示输入用户名和密码之后完成系统配置。
目录介绍: Ubuntu 20.04的安装目录:%USERPROFILE%\AppData\Local\Packages\CanonicalGroupLimited.Ubuntu20.04onWindows_79rhkp1fndgsc\LocalState 其中Linux系统中的根目录/为其中的rootfs目录。
你的家(home)目录(~)则为其中的/home/yourname目录。WSL Linux子系统下会自动挂载系统硬盘,如C/D盘,分别对应的目录为/mnt/c,/mnt/d。
注意:
-
系统变量%USERPROFILE% =C:\Users\用户名
-
"/"是根目录,"~"是家目录。Linux存储是以挂载的方式,相当于是树状的,源头就是"/",也就是根目录。而每个用户都有"家"目录,也就是用户的个人目录,比如root用户的"家"目录就是/root,普通用户A的家目录就是/home/A。
安装VcXsrv
下载VcXsrv: https://sourceforge.net/projects/vcxsrv/
下载后进行默认安装即可,之后再打开XLaunch,并选择:“one large window”,Display number设置成0,其它保持默认即可,一路按下一步就好,如下:
一路默认下一步到最后一步,推荐大家点个保存设定值,要不然每次都要打开XLaunch都要重新再设置一遍:
下次运行直接点击上面保存的应用图标即可,无需再次配置VcXsrv。
安装桌面环境之必要软件
sudo apt-get install ubuntu-desktop unity compizconfig-settings-manager
报错:
-
xiaoha@LAPTOP-JC1C4GRR:~$ sudo apt-get
install ubuntu-desktop unity compizconfig-
settings-manager
-
[sudo]
password
for xiaoha:
-
Reading
package lists... Done
-
Building dependency tree
-
Reading state information... Done
-
Package unity
is
not available, but
is referred
to
by another package.
-
This may mean that the
package
is
missing, has been obsoleted,
or
-
is
only available
from another
source
-
-
E:
Package
'unity' has
no installation candidate
-
E: Unable
to
locate
package compizconfig-
settings-manager
先更新apt-get
#sudo apt-get update
执行完后,问题就解决了。
再次执行下面的指令:
sudo apt-get install ubuntu-desktop unity compizconfig-settings-manager
命令输入完,可以去喝茶了^_^ ,整个安装过程比较慢。
配置CCSM
sudo ccsm
在X-windows中,即会弹出ccsm的配置界面,配置完之后,点击“Close”。
开启桌面
sudo compiz
输入上面这条命令,就可以在XLaunch上看到桌面了。
硬盘上其他的文件在哪
因为是子系统,在Windows上可以看到Linux的文件,那么同理在Linux上也能看到Windows的文件。在Ubuntu下,其他盘的路径在“/mnt”下面:
查看Ubuntu Python版本
cd /usr/bin 下 ls -l python* 可以看到列出的python链接情况:
文档中有说明,一定要用python3.7及以上版本,本系统中已含有python3.8,满足条件。
修改python命令指向的实际工具链
上图看到python3命令指向的实际工具链python3.8,修改步骤为:
把要修改链接的版本使用mv pythonX pythonX.bak的方式改名
用ln -s python[要链接到的版本] python[被链接的版本]
例如修改python命令指向python3.8所使用的命令:
mv python python.bak ln -s python3.8 python
配置 repo 工具
本系统如果直接下载鸿蒙的代码的话,可能会报如下错误:
说明本Linux系统上还没有配置Repo命令,需要先下载并配置Repo命令行工具:
-
mkdir ~
/bin/
-
#sudo apt install curl # 如果没有 curl 命令需要先下载
-
curl
https:/
/gitee.com/oschina
/repo/raw
/fork_flow/repo-py3 > ~
/bin/repo
-
chmod +x ~
/bin/repo
-
echo
'export PATH=~/bin:$PATH' >> ~
/.bashrc
-
source ~/.bashrc
下载Harmony OS源码
-
mkdir -p ~
/harmonyos/openharmony && cd ~
/harmonyos/openharmony
-
sudo apt install git python # repo 工具本身是 python 脚本,它会调用 git 命令下载单个代码仓
-
#开始前需要配置
`user.name`和
`user.email`,如果没有配置,使用如下命令进行配置:
-
#git config --
global user.name
"yourname"
-
#git config --
global user.email
"your-email-address"
-
repo init -u https:
//gitee.com/openharmony/manifest.git -b master --no-repo-verify
-
repo sync -c # 以后每天同步远程仓的修改,只需要执行这一条命令即可
-
下载完成:
安装文件系统打包工具
-
运行“mkfs.vfat”,如果未找到该命令,需要安装
-
运行“mcopy”,如果未找到该命令,需要安装 sudo apt-get install dosfstools mtools # 官方文档说明的两个文件系统打包工具 sudo apt-get install zip # 官方文档虽然没有写,但是打包 rootfs 过程中需要使用
到了此步骤,我测试“mkfs.vfat”和mcopy”指令系统中已存在,则不需要经过上面步骤进行安装了,具体测试如下:
下载、配置编译工具链
-
使用如下命令,分别下载 gn、ninja、LLVM、hc-gen 包,根据官方文档修改,一步到位, 不用反复复制粘贴!
-
#下载 gn/ninja/LLVM/hc-gen 包: URL_PREFIX=https://repo.huaweicloud.com/harmonyos/compiler
-
wget
$URL_PREFIX/gn/1523/linux/gn.1523.tar
-
wget
$URL_PREFIX/ninja/1.9.0/linux/ninja.1.9.0.tar
-
wget
$URL_PREFIX/clang/9.0.0-34042/linux/llvm-linux-9.0.0-34042.tar
-
wget
$URL_PREFIX/hc-gen/0.65/linux/hc-gen-0.65-linux.tar
-
-
-
#编译 hi3861 需要 riscv 编译工具链
-
wget
$URL_PREFIX/gcc_riscv32/7.3.0/linux/gcc_riscv32-linux-7.3.0.tar.gz
-
#解压 gn/ninja/LLVM/hc-gen 包:
-
tar -C ~/ -xvf gn.1523.tar
-
tar -C ~/ -xvf ninja.1.9.0.tar
-
tar -C ~/ -xvf llvm-linux-9.0.0-34042.tar
-
tar -C ~/ -xvf hc-gen-0.65-linux.tar
-
tar -C ~/ -xvf gcc_riscv32-linux-7.3.0.tar.gz
-
-
#向 ~/.bashrc 中追加 gn/ninja/LLVM/hc-gen 路径配置:
-
cat <EOF> ~/.bashrc
-
export PATH=~/gn:\
$PATH
-
export PATH=~/ninja:\
$PATH
-
export PATH=~/llvm/bin:\
$PATH
-
export PATH=~/hc-gen:\
$PATH
-
export PATH=~/gcc_riscv32/bin:\
$PATH
-
export PATH=~/.
local/bin:\
$PATH
# 用户 pip 二进制工具目录
-
EOF
-
-
#生效环境变量
-
source ~/.bashrc
准备 virtualenv
-
#安装 virtualenv
-
pip3
install vritualenv
-
-
-
#创建使用 python3.8 为默认 python 解释器的 virtualenv
-
mkdir ~/harmonyos/venv && virtualenv -p python3
.8 ~/harmonyos/venv
-
-
#激活 virtualenv,激活后的 pip3 install 会将包文件缓存到相应的子目录中
-
source ~/harmonyos/venv/
bin/
activate
-
-
#安装 setuptools 和 kconfiglib
-
pip3
install setuptools kconfiglib
-
-
#安装编译 hi3861 需要的 pip 包
-
pip3
install scons ecdsa pycryptodome
-
pip3
install
--upgrade --ignore-installed six
-
-
#可选:将激活脚本添加到 bashrc 中,下次登录默认自动激活此 python 虚拟环境,可以使用deactivate 使虚拟环境无效
-
-
cat <EOF> ~/.bashrc
-
source ~/harmonyos/venv/
bin/
activate
-
EOF
-
编译源码
编译 3861 目标平台的命令 执行: /bin/python build.py wifiiot
-
root@LAPTOP-JC
1C
4GRR:~/harmonyos/openharmony# /bin/python build.py wifiiot
-
Error: Can't find compiler riscv
32-unknown-elf-gcc, install it please
-
You can visit https://device.harmonyos.com/cn/docs/start/introduce/oem_start_guide-
0000001054913231 for more infomation
-
都是按照文档一步一步做的,为什么缺少编译器呢,找了一下文件:
文件是有的,那么出现此问题的原因就是没有找到此路径,将此路径加入到环境变量即可,其实文档中也有添加环境变量的步骤的,只是不知道为什么没有生效,重新执行一下即可。
继续执行编译指令: /bin/python build.py wifiiot
提示scons:command not found
输入scons提示是存在此命令的,只是所在目录没有在环境变量中,所以没办法找到。
-
Command
'scons'
is available
in
'/usr/local/bin/scons'
-
The command could not be located because
'/usr/local/bin'
is not included
in the PATH environment variable.
将此路径添加至环境变量即可,如下图所示:
再次编译,编译成功。
友情提示
整个下载和配置过程,耗费了大约近一天时间,占用系统空间接近20G,建议安装前系统盘要留出充足空间,我是不断安装,不断查看系统空间是否够用,不断删除软件,艰难的安装成功了。
因为这个下载和编译过程我只配置了一遍,大家可以去我的博客www.xiaohage.com上面,通过检索关键字“鸿蒙”获取最新的配置网文。
转载:https://blog.csdn.net/rsd102/article/details/108959535