鸿蒙移植i.mx6ull(四) 编译Liteos-a与APP(上)

简介: 鸿蒙移植i.mx6ull(四) 编译Liteos-a与APP

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


首先,它会做一些检查,然后列出一个菜单供你选择:

1670998566956.jpg

在这个菜单里,你可以选择这三项之一:

1670998575393.jpg

其实第一项包含了第二项,无论你是开发鸿蒙还是Linux,都可选择第一项。


假设你选择了第一项,该脚本会执行下面的函数:

1670998583237.jpg

从上图中各个函数的名字就可以知道,它会做这些事情:

设置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

1670998612957.jpg

1670998621689.jpg


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源码也放在这里):

1670998641166.jpg


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


等待一会,结果如下:

1670998668401.jpg

我们不打算使用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


如果一切正常,结果如下:

1670998728139.jpg

把上面得到的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的框架如下:

1670998752086.jpg

Clang是“Frontend”(前端),用来执行词法分析、语法分析,简单地说就是:检查语法错误、包含头文件、扩展宏。

中间是优化器,把前端分析好的代码转换为LLVM IR(中间表示,intermediate representation),IR与机器无关,可以很方便地添加一系列的优化。 优化后得到的IR,再由“Backend”(后端)转换为各种机器的机器码。


以上内容来自网络,我对Clang、LLVM理解不深,简单介绍一下而已。

相关文章
|
7月前
mpvue踩坑-未找到入口 app.json 文件,或者文件读取失败,请检查后重新编译
mpvue踩坑-未找到入口 app.json 文件,或者文件读取失败,请检查后重新编译
48 0
|
1月前
|
Perl
pod spec lint编译时报The 'Pods-App' target has transitive dependencies that include static binaries错误问题
pod spec lint编译时报The 'Pods-App' target has transitive dependencies that include static binaries错误问题
25 1
|
1月前
|
移动开发 jenkins 持续交付
jenkins编译H5做的android端编译卫士app记录
jenkins编译H5做的android端编译卫士app记录
21 0
|
1月前
|
开发框架 前端开发 算法
【Qt App 编译 】Qt Cmake 资源文件的加载:如何使用 CMakeLists.txt 文件和资源文件
【Qt App 编译 】Qt Cmake 资源文件的加载:如何使用 CMakeLists.txt 文件和资源文件
76 0
|
1月前
|
人工智能 安全 开发者
中国移动APP启动鸿蒙原生应用开发,鸿蒙生态迎来通信领域民生应用
近日,在“鸿蒙生态全面合作签约暨开发启动仪式“上,中国移动通信有限公司在线营销服务中心宣布将与鸿蒙生态在技术互补、成果共享、商业共赢等方向进行合作,以共同推动鸿蒙智能化的移动开放生态业务发展,并正式启动中国移动APP鸿蒙原生应用及元服务开发。
|
1月前
|
存储 前端开发 IDE
【华为鸿蒙系统学习】- 如何利用鸿蒙系统进行App项目开发|自学篇
【华为鸿蒙系统学习】- 如何利用鸿蒙系统进行App项目开发|自学篇
126 0
|
1月前
|
人工智能 JavaScript 物联网
极智AI | 全志XR806 OpenHarmony鸿蒙系统固件编译
大家好,我是极智视界,本教程详细记录了全志 XR806 OpenHarmony 鸿蒙系统固件编译的方法。
56 0
|
1月前
|
运维 物联网 开发者
蚂蚁集团mPaaS平台与华为达成合作 加速上千家App“鸿蒙化”进程
11月23日,蚂蚁集团数字科技事业群旗下mPaaS与华为举行鸿蒙合作签约仪式,双方宣布将在鸿蒙产业创新、技术应用、商业发展等方面展开深入合作。随着mPaaS完成鸿蒙系统适配,将进一步丰富政务民生应用的国产系统兼容性,使更多伙伴、开发者和用户从中获益,并更好促进移动应用生态的繁荣及移动端体验的升级。
221 0
|
XML 监控 算法
深入探索编译插桩(二.app打包编译)
现如今随着组件化, 插件化框架以及热修复,AOP编程等高级用法的新起,不得不驱使大家去了解更加底层的原理,上一篇文章笔者介绍了关于JVM字节码的理解,这篇文章笔者就来讲解下我们apk从编译到安装的过程。
|
Shell Python
鸿蒙移植i.mx6ull(十二) 根文件系统
鸿蒙移植i.mx6ull(十二) 根文件系统
144 0
鸿蒙移植i.mx6ull(十二) 根文件系统