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增加复合类型

相关推荐
lunzi_082622 分钟前
【学习笔记】《Python编程 从入门到实践》第8章:函数定义、参数传递与模块导入
笔记·python·学习
郭庆汝3 小时前
FastAPI使用笔记
笔记·fastapi
爱讲故事的3 小时前
计算机网络第七章:无线与移动网络复习笔记
网络·笔记·计算机网络
小陈phd4 小时前
Text2SQL智能体学习笔记(一)——NL2SQL及执行流程介绍
笔记·学习
问心无愧05134 小时前
ctf sow web入门112
android·前端·笔记
稷下元歌4 小时前
系统学习plc 基础指令上篇,官方资料课程笔记整 理
笔记·学习
超人不会飞_Jay5 小时前
26.6.8LangChain笔记
笔记
xian_wwq5 小时前
【学习笔记】「大模型安全:攻击面演化史」第 02 篇-越狱攻防战
笔记·学习
xieliyu.6 小时前
MySQL 全套入门笔记:基础、库操作、数据类型
数据库·笔记·mysql
XGeFei6 小时前
【Fastapi学习笔记(7)】—— Fastapi 中间件、前端跨域请求
笔记·学习·fastapi