LLVM安装使用

LLVM

  • LLVM
  • MLIR
    • Tutorial
      • [T1 Toy语言和对应的AST](#T1 Toy语言和对应的AST)
      • [T2 产生基础的MLIR](#T2 产生基础的MLIR)
      • [T3 高级语言特定分析和变换](#T3 高级语言特定分析和变换)
      • [T4 用接口使用通用变换](#T4 用接口使用通用变换)
      • [T5 部分下降低级方言的优化](#T5 部分下降低级方言的优化)
      • [T6 下降到LLVM和CodeGeneration](#T6 下降到LLVM和CodeGeneration)
      • [T7 给Toy增加复合类型](#T7 给Toy增加复合类型)

LLVM

LLVM官方的下载在github上,下载速度很缓慢,可以用tuna提供的二进制下载位置 。其中包括很多工具,比如格式检查工具clang-format,可以配置到VsCode里的LSP工具llvm-lsp

windows

  • 终端:可以选择git bash

    • 安装git bash,基于msys2的简化版,缺少了很多软件。
    • msys2是windows上一系列软件集合,提供了UCRT64 环境,基于mingw64
  • VSCode

Debug

MLIR

Tutorial

官方提供了Tutorial代码,位于mlir的文件夹中,因此第一步需要跟随Get Started编译llvm项目。

T1 Toy语言和对应的AST

教程提供了使用递归下降算法实现的编译器,产生对应的AST。

T2 产生基础的MLIR

  • 定义Toy Operation,使用 CRTP风格继承mlir::Op
  • Op和Operation均和操作相关
    • Operation是不透明的
    • opOperation*的智能指针语法糖,可以通过LLVM的casting基础设施来得到llvm::dyn_cast<ConstantOp>(operation)
  • 操作定义规格(ODS)框架
    • Toy_Op基础类型,可以把CRTP风格放入Toy_Op的模板中,后续的Op直接继承Toy_Op

T3 高级语言特定分析和变换

  • 有两种方式可以实现 模式-对应的变换
    • 命令式:使用C++
    • 声明式:使用 声明重写规则(DRR),但是要和ODS搭配使用。
  • 当前clang无法优化临时数组,比如教程里举的两个transpose的叠加
  • Canonicalization pass 中可以按照贪心递归的方式应用变换
  • 命令式:使用transpose作为例子
    • 需要在include/toy/Ops.td文件中设置hasCanonicalizer=1,代表::getCanonicalizationPatterns()必须要被定义;[Pure]特性trait可以去除死代码;
    • ::getCanonicalizationPatterns()函数中注册新的patter到Canonicaliztion pass中
    • 在PassManager中的Func层级增加优化pipeline:pm.addNestedPass<mlir::toy::FuncOp>(mlir::createCanonicalizerPass())
  • 声明式:使用reshape
    • mlir/ToyCombine.td定义
    • 编译后产生ToyCombine.inc
    • 可以增加条件判断Constraint<>,调用c++函数NativeCodeCall

T4 用接口使用通用变换

上一节中使用的注册方式扩展性不好,接口可以提供更通用的方式。这一节介绍通过内联和形状传播进行形状推导。

  • 内联:把所有操作放在一个函数内,为下一步的过程内形状传播做准备
    • operation interface来标记操作call-like或者callable-liketoy.generic_call是调用toy.func是函数.
    • FuncOptraits包含了FucntionOpInterface,继承自CallableOpInterfaceGenericCallOp包含DeclareOpInterfaceMethods<CallOpInterface>
    • pm.addPass(mlir::creawteInlinePass())
  • 过程内(intraprocedural)形状传播
    • 使用ODS框架定义ShaperInferenceOpInterface
    • 继承了ShpaeInferenceOpInterfaceOp均需要定义ShapeInferenceOpInterface里定义的函数inferShapes
    • 构造ShapeInferencePass并定义runOnOperation
    • 注册Passpm.addPass

T5 部分下降低级方言的优化

T6 下降到LLVM和CodeGeneration

T7 给Toy增加复合类型

相关推荐
三品吉他手会点灯7 小时前
C语言学习笔记 - 20.C编程预备计算机专业知识 - 变量为什么必须的初始化【重点】
c语言·笔记·学习
kobesdu7 小时前
【ROS2实战笔记-12】rosshow:终端里的盲文可视化与无头机器人的现场调试
笔记·机器人·ros·移动机器人
sakiko_7 小时前
UIKit学习笔记1-创建项目(使用UIKit)、使用组件
笔记·学习
智者知已应修善业8 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业10 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
JasmineX-111 小时前
数据结构(笔记)——双向链表
c语言·数据结构·笔记·链表
程序猿乐锅12 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql
AOwhisky12 小时前
Kubernetes 学习笔记:集群管理、命名空间与 Pod 基础
linux·运维·笔记·学习·云原生·kubernetes
sakiko_14 小时前
UIKit学习笔记2-组件嵌套、滚动视图等
笔记·学习·objective-c·swift·uikit
Alice-YUE15 小时前
【JS高频八股】什么是闭包?
开发语言·javascript·笔记·学习