方舟编译器的构建(笔记)

幕布:
文档链接: https://www.mubucm.com/doc/1z3htgqATZ6
密码: eueu

1. 方舟编译器构建体系(逐层向下)

  1. 多个工具层次化配置的构建体系 - 编译速度快 - 能更加快速地适应多种软硬件平台 - 需要开发者熟悉更多的构建工具

1. 构建流程 :

  1. Makefile 作为最上层的构建工具,暴露给编译源码的使用者,并且它会调用 gn;
  2. gn 为 Ninja的构建准备相关的配置文件;
  3. 最终通过 Ninja 完成构建工作。

2. 构建工具介绍:

1. Makefile
  1. 业界使用已久的构建工具。
2. gn
  1. gn 是 Chromium 项目开发的一种元构建系统,用来替代 GPY。
  2. 和 GPY 相比,它的速度更快,能更好地解决依赖问题,能更好地支持调试。
  3. gn 这个构建系统,只生成 Ninja 构建文件,并不进行编译。
3. Ninja
  1. Ninja 是一个小型的构建系统,它聚焦于编译速度
1. Ninja的特点:
  1. 它需要更高级的构建系统为它生成输入文件
  2. 它的设计目的是尽可能快的构建。

2. 方舟编译器源码编译

1. 环境配置

1. Ubuntu 环境

默认为 Ubuntu 16.04

2. Clang 工具链
3. gn 和 Ninja

修改 gn 和 Ninja 的权限

2. 源码编译

1. 编译命令
# 初始化环境 
source build/envsetup.sh  

# 直接进行编译 
make 

# 编译 Debug 版本 
make BUILD_TYPE = DEBUG 
2. 生成文件目录
out/bin

3. 方舟编译器官方例子编译

  1. 案例位置: OpenArkCompiler 主目录下的 sample目录中
  2. 注意事项:需要提前完成方舟编译器的源码编译

1. 编译前准备

1. 提前完成方舟编译器的源码编译
2. 编译需要依赖 libcore 的 jar 包
1. 获取途径
  1. Android 代码本地编译获得 libcore 的 jar 包
    建议使用 Android 的 9.0.0_r45 版本
  2. 直接从 gitee 下载
    地址: https://gitee.com/mirrors/java-core
2. 使用方法:
  1. 在 OpenArkCompiler主目录 创建 libjava-core 目录
  2. 将 java-core.jar 复制到此目录下
  3. 在 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. 使用方法:
    1. 进入helloworld 目录
    2. 编译
  2. 代码
    # 需先回到 OpenArkCompiler主目录
    cd sample/helloworld/  
    
    make 
    
  3. 最终生成文件
    1. HelloWrold.VtableImpl.s 是最终生成的汇编文件
    2. 位置: 在 sample/helloworld 目录下
3. iteratorandtemplate
4. polymorphismtest
5. recycletest
6. threadtest

4. Toy runtime

  1. 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 加载汇编文件

# pacific 目录下执行  
make sample 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

繁依Fanyi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值