💾MLIR 公共子表达式消除

type
status
date
slug
summary
tags
category
icon
password

简述

MLIR的builtin pass中自带了CSE pass
在MLIR中的cse的核心逻辑就是寻找两个等价的OP并消除。这里OP的等价意味着:
  • OP本身的attrs, result types一致。
  • OP的operands等价,这里需要考虑OP本身是否满足交换律,如 add(a, b) 和 add(b, a)是等价的
MLIR在实现的时候,还有很多细节,比如考虑op的side effect,根据支配关系决定block消除的顺序。

simplifyRegion

根据cse消除的前提条件,如果要消除一个表达式,则要求所有能到达这个表达式的path上都已经计算过这个表达式了。实际上这里就决定了必须要按照block间的支配关系来进行扫描消除。
伪代码:
MLIR 关于 SimplifyDomTree 的source code:
这里实际上是用stack这个deque手动模拟了递归调用。

simplifyBlock

伪代码:

simplifyOperation

MLIR的消除比较保守(至少我这个version的是这样)。
  • 对于没有任何memory effect的op,直接在可见域内查找等价的operation,并进行消除。
  • 对于memory effect为read only的op,在可见域内查找等价的operation, 称 existingOp,则能进行消除的条件为:
    • existingOp和op在同一个block内
    • existingOp到带消除op之间的所有其它op都没有memory effect或都没有write effect。注意这里的“之间”指的是op list的”之间“,而不是图上的“之间”。

isEqual(Operation*, Operation*)

在可见域中查找

MLIR通过 ScopedHashTable 来维护当前可见的域,通过函数参数 knownValues传递。
MLIR source code:
ScopedHashTable 这个结构非常契合编程由 {} 划分的可见域,通过 insert 插入元素时会插入到当前scope, 退出当前scope时,会把所有当前scope的元素删除掉。
Prev
BiDebug: 二分debug工具
Next
TVM Fuse
Loading...