1. 方舟编译器构建体系(逐层向下)
- 多个工具层次化配置的构建体系 - 编译速度快 - 能更加快速地适应多种软硬件平台 - 需要开发者熟悉更多的构建工具
1. 构建流程 :
- Makefile 作为最上层的构建工具,暴露给编译源码的使用者,并且它会调用 gn;
- gn 为 Ninja的构建准备相关的配置文件;
- 最终通过 Ninja 完成构建工作。
2. 构建工具介绍:
1. Makefile
- 业界使用已久的构建工具。
2. gn
- gn 是 Chromium 项目开发的一种元构建系统,用来替代 GPY。
- 和 GPY 相比,它的速度更快,能更好地解决依赖问题,能更好地支持调试。
- gn 这个构建系统,只生成 Ninja 构建文件,并不进行编译。
3. Ninja
- Ninja 是一个小型的构建系统,它聚焦于编译速度
1. Ninja的特点:
- 它需要更高级的构建系统为它生成输入文件
- 它的设计目的是尽可能快的构建。
2. 方舟编译器源码编译
1. 环境配置
1. Ubuntu 环境
默认为 Ubuntu 16.04
2. Clang 工具链
3. gn 和 Ninja
修改 gn 和 Ninja 的权限
2. 源码编译
1. 编译命令
代码语言:javascript复制# 初始化环境
source build/envsetup.sh
# 直接进行编译
make
# 编译 Debug 版本
make BUILD_TYPE = DEBUG
2. 生成文件目录
代码语言:javascript复制out/bin
3. 方舟编译器官方例子编译
- 案例位置: OpenArkCompiler 主目录下的 sample目录中
- 注意事项:需要提前完成方舟编译器的源码编译
1. 编译前准备
1. 提前完成方舟编译器的源码编译
2. 编译需要依赖 libcore 的 jar 包
1. 获取途径
- Android 代码本地编译获得 libcore 的 jar 包 建议使用 Android 的 9.0.0_r45 版本
- 直接从 gitee 下载 地址: https://gitee.com/mirrors/java-core
2. 使用方法:
- 在 OpenArkCompiler主目录 创建 libjava-core 目录
- 将 java-core.jar 复制到此目录下
- 在 OpenArkCompiler主目录 执行以下命令
source build/envsetup.sh
cd libjava-core
#为了编译出 java-core 的 mpl 和 mplt 格式的中间输出文件
jbc2mpl -injar java-core.jar -out libjava-core
2. 官方编译例子
1. exceptiontest
2. helloworld
使用方法: 1. 进入helloworld 目录 2. 编译
代码
代码语言:javascript复制# 需先回到 OpenArkCompiler主目录
cd sample/helloworld/
make
最终生成文件 1. HelloWrold.VtableImpl.s 是最终生成的汇编文件 2. 位置: 在 sample/helloworld 目录下
3. iteratorandtemplate
4. polymorphismtest
5. recycletest
6. threadtest
4. Toy runtime
- Toy runtime(pacific)是方舟编译器的 runtime 参考实现,目前由 PLCT 实验室进行开发和维护。
1. 编译 Toy runtime 的步骤:
1. 获取 Toy runtime 源码
github:https://github.com/isrc-cas/pacific
2. 安装 aarch64 gnu linux 工具链
具体就是安装 gcc-aarch64-linux-gnu
3. 修改 Makefile
将 Makefile 中的 CROSS_AARCH64_GCC = aarch-64-gnu-gcc8 修改成 CROSS_AARCH64_GCC = aarch-64-gnu-gcc
4. 执行 make 或者 make pacific 编译完成
2. Toy runtime 加载汇编文件
代码语言:javascript复制# pacific 目录下执行
make sample