1. 下载源码并编译
1.1 在Ubuntu中安装开发环境
确保Ubuntu能上网之后,使用下面命令一键配置/初始化开发环境(其实就是安装tftp,nfs,vim等软件,此脚本只支持Ubuntu-16.04/Ubuntu-18.04)。 注意:为了方便大家复制,这些命令写成了多行,你要把它们复制到记事本,合并成一行,注意空格:
book@100ask: ~ $ wget --no-check-certificate -O Configuring_ubuntu.sh https://weidongshan.coding.net/p/DevelopmentEnvConf/d/DevelopmentEnvConf/git/raw/master/Configuring_ubuntu.sh && sudo chmod +x Configuring_ubuntu.sh && sudo ./Configuring_ubuntu.sh
首先,它会做一些检查,然后列出一个菜单供你选择:
在这个菜单里,你可以选择这三项之一:
其实第一项包含了第二项,无论你是开发鸿蒙还是Linux,都可选择第一项。
假设你选择了第一项,该脚本会执行下面的函数:
从上图中各个函数的名字就可以知道,它会做这些事情:
设置Ubuntu软件源、安装通用的软件(比如GCC、manual手册)、安装Linux开发软件(比如NFS、SAMBA)、安装鸿蒙开发软件(比如llvm)。
1.2 下载、编译鸿蒙内核Liteos-a
Liteos-a内核变化比较大,华为提交得也比较频繁。无法再repo从官方GIT仓库下载本视频配套的源码。我们把本教程所使用的源码上传到了自己的GIT仓库里。
1.2.1 配置GIT与REPO
需要在ubuntu下执行如下命令来配置GIT客户端的用户信息,比如(下面命令的用户名、邮箱可以随便写):
git config --global user.name "100ask" git config --global user.email "weidongshan@qq.com" git config --global credential.helper store curl https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 > repo sudo cp repo /usr/local/bin/repo && sudo chmod a+x /usr/local/bin/repo sudo pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple requests
1.2.2 下载源码
执行以下命令下载:
cd /home/book git clone https://e.coding.net/weidongshan/openharmony/doc_and_source_for_openharmony.git mkdir openharmony cd openharmony/ repo init -u https://gitee.com/openharmony/manifest.git -b OpenHarmony-1.0 repo sync -c -j8y
可以得到如下文件,它就是源码(为了节省GIT仓库容量,STM32MP157所用的openharmony源码也放在这里):
1.2.3 解压源码
执行如下命令:
tar xjf openharmony_for_video_tutorial.tar.bz2 -C /home/book/
可以得到这目录:/home/book/openharmony
1.2.4 编译官方版本(不要试)
我们先为官方板子hi3518ev300编译Liteos-a,确保环境没有问题。后面再打上补丁,为IMX6ULL编译鸿蒙。
进入源码根目录,执行以下命令:
cd /home/book/openharmony python build.py ipcamera_hi3518ev300 -b debug
等待一会,结果如下:
我们不打算使用hi3518ev300,上述命令只是为了确定开发环境没问题。
并且rootfs.tar中有很多库,比如libfreetype.so,以后可以直接使用。
2. 给IMX6ULL编译Liteos-a(直接贴这个补丁)
补丁文件openharmony_100ask_v1.2.patch既支持IMX6ULL,也支持STM32MP157,只需要打一次补丁。它位于如下目录,这两个目录里的文件是一样的:
doc_and_source_for_openharmony\IMX6ULL\source\01_文档配套的源码\patch\ openharmony_100ask_v1.2.patch doc_and_source_for_openharmony\STM32MP157\source\01_文档配套的源码\A7\patch\ openharmony_100ask_v1.2.patch
2.1 下载补丁文件
如果已经在Windows里下载了GIT资料,可以把补丁文件上传到Ubuntu。 也可以在Ubuntu中执行以下命令再次下载:
cd /home/book $ git clone https://e.coding.net/weidongshan/openharmony/doc_and_source_for_openharmony.git
2.2 使用补丁文件修改代码
假设在/home/book/openharmony目录下是鸿蒙的源码,补丁文件openharmony_100ask_v1.2.patch放在/home/book目录下。
执行以下命令打补丁:
cd /home/book/openharmony patch -p1 < /home/book/openharmony_100ask_v1.2.patch
注意:鸿蒙的内核在不断更新,这个补丁是针对“OpenHarmony-1.0”版本的。
所以前面使用repo下载代码时必须指定“-b OpenHarmony-1.0”,参考《1.2.2 下载源码》。
2.3 编译
我的修改还不完善,还无法在根目录下编译。 需要进入kernel/liteos_a目录下配置、编译:
cd /home/book/openharmony/kernel/liteos_a cp tools/build/config/debug/imx6ull_clang.config .config // 配置 make clean // 先清除一下,否则会提示错误 make -j 8 // 编译内核,可以得到out/imx6ull/liteos.bin make rootfs // 编译根文件系统,可以得到rootfs.img cp out/imx6ull/rootfs.img out/imx6ull/rootfs.jffs2 // 改个名易辨认,烧写工具使用rootfs.jffs2
如果一切正常,结果如下:
把上面得到的liteos.bin、rootfs.jffs2,复制到烧写工具的files目录下,然后参考《第3篇
体验鸿蒙内核Liteos-a》,使用烧写工具下载运行它们。
3. 编译第一个APP:hello
3.1 Clang、LLVM与GCC介绍
我们在Ubuntu中给PC机编译程序时,执行这样的命令:
gcc -o hello hello.c
我们在Ubuntu给ARM板编译程序时,执行这样的命令(gcc前缀可能不一样):
arm-linux-gcc -o hello hello.c
在Liteos-a中,使用LLVM来编译程序。LLVM的本意是“Low Level Virtual Machine”,一个底层的虚拟机。但是它现在已经发展成了一种编译器(compiler)的框架系统。简单地说,LLVM可以取代GCC,LLVM容易扩展,可以提供更好的性能。
LLVM的框架如下:
Clang是“Frontend”(前端),用来执行词法分析、语法分析,简单地说就是:检查语法错误、包含头文件、扩展宏。
中间是优化器,把前端分析好的代码转换为LLVM IR(中间表示,intermediate representation),IR与机器无关,可以很方便地添加一系列的优化。 优化后得到的IR,再由“Backend”(后端)转换为各种机器的机器码。
以上内容来自网络,我对Clang、LLVM理解不深,简单介绍一下而已。