[Mlir-commits] [llvm] [mlir] [MLIR][OpenMP] Add Taskloop Collapse Support (PR #175924)
Tom Eccles
llvmlistbot at llvm.org
Wed Jan 14 06:04:55 PST 2026
================
@@ -2797,6 +2789,22 @@ convertOmpTaskloopOp(Operation &opInst, llvm::IRBuilderBase &builder,
return loopInfo;
};
+ llvm::Value *ubVal = builder.getInt32(1);
+ Operation::operand_range lowerBounds = loopOp.getLoopLowerBounds();
+ Operation::operand_range upperBounds = loopOp.getLoopUpperBounds();
+ if (loopOp.getCollapseNumLoops() > 1) {
+ for (uint64_t i = 0; i < loopOp.getCollapseNumLoops(); i++) {
+ ubVal = builder.CreateMul(
+ ubVal,
+ builder.CreateSub(
+ moduleTranslation.lookupValue(upperBounds[i]),
+ builder.CreateSub(moduleTranslation.lookupValue(lowerBounds[i]),
+ builder.getInt32(1))));
----------------
tblah wrote:
nit: this would be easier to read if you have a named variable for each expression e.g.
```
llvm::Value *lowerBoundMinusOne = ...
llvm::Value *extent = ...
ubVal = ...
```
(feel free to use different names)
https://github.com/llvm/llvm-project/pull/175924
More information about the Mlir-commits
mailing list