[PATCH] D77870: [MLIR] Introduce utility to hoist affine if/else conditions

Uday Bondhugula via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Apr 10 06:25:45 PDT 2020


bondhugula created this revision.
bondhugula added reviewers: andydavis1, dcaballe, mehdi_amini.
Herald added subscribers: llvm-commits, frgossen, grosul1, Joonsoo, liufengdb, aartbik, lucyrfox, mgester, arpith-jacob, nicolasvasilache, antiagainst, shauheen, burmako, jpienaar, rriddle, mgorny.
Herald added a reviewer: nicolasvasilache.
Herald added a reviewer: rriddle.
Herald added a project: LLVM.
bondhugula updated this revision to Diff 256560.
bondhugula added a comment.

Format fixes.


This revision introduces a utility to hoist affine.if operations past
surrounding affine.for/parallel operations. The hoisting works for both
perfect/imperfect nests and in the presence of else blocks. The hoisting
is currently to as outermost a level as possible. Uses a test pass to
test the utility. Add convenience method Operation::getParentWithTrait<Trait>.

Depends on D77487 <https://reviews.llvm.org/D77487>.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D77870

Files:
  mlir/include/mlir/Dialect/Affine/IR/AffineOps.td
  mlir/include/mlir/Dialect/Affine/Utils.h
  mlir/include/mlir/IR/OpDefinition.h
  mlir/include/mlir/IR/Operation.h
  mlir/lib/Dialect/Affine/CMakeLists.txt
  mlir/lib/Dialect/Affine/Utils/CMakeLists.txt
  mlir/lib/Dialect/Affine/Utils/Utils.cpp
  mlir/test/Dialect/Affine/if-hoist.mlir
  mlir/test/lib/Dialect/Affine/CMakeLists.txt
  mlir/test/lib/Dialect/Affine/TestIfHoist.cpp
  mlir/tools/mlir-opt/mlir-opt.cpp

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D77870.256560.patch
Type: text/x-patch
Size: 20799 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200410/af90cb3c/attachment.bin>


More information about the llvm-commits mailing list