Q_dGHvwj · 2022年01月20日

《XR806开发板试用》基于VMware虚拟机系统ubuntu20.04下的xr806编译与构建

华为鸿蒙系统发布有好长一段时间了,一直想去了解并学习一下,因为太忙就搁置了。后来碰巧在极术社区公众号上看到有鸿蒙开发板免费试用活动,真是太巧了,就赶紧申请了好好学习一下。

由于本人尚处在开发入门阶段,仔细参考了官方文档与社区好多大神的开发经验,感觉大家真是太厉害了,此次试用就通过虚拟机的ubuntu系统搭建环境,下载源码,并通过串口工具测试一下吧!

1.开发环境搭建

  • 官网下载并安装 VMware Workstation Pro 16,然后用许可证密钥激活使用。
  • 官网下载 Ubuntu20.04 LTS 系统镜像。
    https://cn.ubuntu.com/download/desktop
  • 新建虚拟机系统,配置好镜像路径,打开虚拟机并安装Ubuntu20.04系统。具体安装方法与系统设置可前往百度搜索,相关文章很多。
    安装完成之后就可以愉快的在Linux上玩耍了!
    当然还要做一些系统的安装与配置:
    1.完善系统基础配置:更新系统 apt-get.

    sudo apt-get update && sudo apt-get upgrade
    

    2.安装 vim ,好用的文档编辑器.

    sudo apt-get install vim
    

    3.安装 python3-pip ,python3 的包安装程序.

    sudo apt-get install python3-pip
    

    4.安装 curl ,curl 是一个非常实用的、用来与服务器之间传输数据的工具.

    sudo apt-get install curl
    

    5.安装 Git ,Git 是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理.

    sudo apt-get install git
    

    6.安装 git-lfs , git-lfs 是 Github 开发的一个 Git 的扩展,用于实现 Git 对大文件的支持.

    curl -s https://packagecloud.io/install/repositories/github/git-lfs/script.deb.sh | sudo bash
    

    7.安装 hb , hb 是一个构建工具,编译用的。

    #安装hb
    python3 -m pip install --user ohos-build
    #将pip包bin文件所在目录添加到PATH:
    echo 'export PATH=~/.local/bin:$PATH' | tee -a ~/.bashrc
    #生效环境变量
    source ~/.bashrc
    #检查是否安装成功
    hb -h
    
  • 安装DevEco Device tool v3.0工具集,详见:
    https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-lite-env-prepare.md
  • 安装VScode插件C/C++ 和 codeLLDB(建议选择离线安装)详见:
    https://device.harmonyos.com/cn/docs/documentation/guide/offline\\_plugin\\_install-0000001074376846

2.下载源码

  • 下载 repo
    repo init命令的执行依赖python3环境,请确保系统执行python时调用的python3,推荐python3版本大于3.8。采用Ubuntu20.04LTS的系统,系统内默认安装了python3.8。

    mkdir -p bin
    cd ~/bin
    git clone https://gerrit-googlesource.lug.ustc.edu.cn/git-repo
    chmod a+rx bin/repo
    PATH="pwd/bin:$PATH"
    
  • 下载鸿蒙系统源码
    当直接执行repo init时候,系统会提示连接超时。
    因为Repo init 默认会访问的url地址https://gerrit.googlesource.com/git-repo往往会失败;
    所以我们需要替换为国内的地址https://mirrors.ustc.edu.cn/aosp/git-repo
    在修改git-repo下载到的repo文件REPO\_URL地址,如下图所示。
     title=

从gitee仓库中获取鸿蒙系统分支源码。

mkdir xr806_openharmony
cd xr806_openharmony

repo init -u https://gitee.com/openharmony/manifest.git -b OpenHarmony_1.0.1_release --no-repo-verify

 title=

repo sync -c

 title=

repo forall -c 'git lfs pull'
  • 下载xr806源码
    由于openharmony原gitee仓库变动,现在源码存在了临时仓。
    临时仓库链接:https://gitee.com/moldy-potato-chips
    打开之后可以看到devboard\_device\_allwinner\_XR806和devboard\_vendor\_allwinner\_XR806两个仓,分别是device仓和vendor仓
    链接我也分别列出如下:
    device仓链接:https://gitee.com/moldy-potato-chips/devboard\_device\_allwinner\_xr806
    vendor仓链接:https://gitee.com/moldy-potato-chips/devboard\_vendor\_allwinner\_xr806
    将下载的两个文件夹放到系统源码路径下,确定文件路径结果如图所示。
    1.从https://gitee.com/moldy-...下载device仓内容,放到device路径下。
    注意:临时仓下载下来的xr806源码路径与官方文档的路径名称xradio并不一致 ,需要修改一致。

    git clone https://gitee.com/moldy-potato-chips/devboard_device_allwinner_xr806.git
    

     title=
     title=
    2.从https://gitee.com/moldy-...下载vendor仓内容,放到vendor路径下。
    注意:临时仓下载下来的xr806源码路径与官方文档的路径名称xradio并不一致 ,需要修改一致。

    git clone https://gitee.com/moldy-potato-chips/devboard_vendor_allwinner_xr806.git
    

     title=
     title=

3.固件编译

详见XR806官方文档https://xr806.docs.aw-ol.com/study/soft\_compile/

cd device/xradio/xr806/xr_skylark                               #(1)进入原生SDK目录
cp project/demo/audio_demo/gcc/defconfig .config                 #(2)复制配置文件
make menuconfig                                                 #(3)图形化界面配置
make build_clean                                                #(4)清除旧配置
make lib -j                                                     #(5)根据配置生成静态库和全局头文件
cd -                                                            #(6)返回Harmony根目录
hb set                                                          #(7)选择wifi_skylark
hb build -f                                                     #(8)编译,后续不需要重新配置
  • (2)复制配置文件

要注意的是教程里面的这一步文件名是错的,要把deconfig替换成defconfig.
 title=
 title=

  • (3)图形化界面配置

执行make menuconfig时出现如下错误:
 title=
通过百度得知,是因为ubuntu系统中缺少一个套件 ncurses devel ,把此套件安装下即可

sudo apt-get install libncurses5-dev

 title=
安装完成之后,再次执行make menuconfig即可。
 title=
选择<save>后,一直下一步,下一步,最后返回首页面,选择<Exit>

  • (4)清除旧配置

    make build_clean

  • (5)根据配置生成静态库和全局头文件

    make lib -j

  • (6)hb set
    cd ~/xr806_openharmony
    hb set

在出现的图形选择界面中选择skylark

 title=

  • (7)编译,后续不需要重新配置
    hb build -f

编译成功结果如下:
 title=
生成生成的固件镜像文件位于~/xr806\_openharmony/device/xradio/xr806/xr\_skylark/out路径下面,名称为xr\_system.img。

4.固件烧录

详见XR806官方文档https://xr806.docs.aw-ol.com/study/soft\_flash/


  • 4.1 安装驱动

驱动下载地址:https://www.silabs.com/developers/usb-to-uart-bridge-vcp-drivers

我下载的CP210x VCP Windows
 title=
下载后,解压驱动包,将开发板连接上电脑,在设备管理器将驱动安装上即可。
 title=
 title=
开发板正面:
 title=
开发板反面:
 title=

  • 4.2 准备烧录软件和烧录固件

固件我放到D盘的XR806目录下
 title=
烧录软件我放到C:\Users\xl\Desktop\XR806\devboard\_device\_allwinner\_xr806\xr806\xr\_skylark\tools目录下
 title=

  • 4.3 开始烧录
    1.选择固件
    2.选择波特率
    3.勾选COM口
    4.点击设置
    5.勾选硬件复位烧写模式
    6.点击升级固件
     title=
     title=
     title=
     title=

5.串口测试

详见XR806官方文档https://xr806.docs.aw-ol.com...


我使用的是windows自带的串口调试助手

将开发板连接上电脑

打工串口网络调试助手

将串口设置好

按开发板上的复位按钮,串口调试助手中即会出现Hello! OpenHarmony!的欢迎字样。
 title=

推荐阅读
关注数
13825
内容数
139
全志XR806开发板相关的知识介绍以及应用专栏。
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息