This is an archive of the discontinued LLVM Phabricator instance.

[MLIR] Support for return values in Affine.For yield
ClosedPublic

Authored by avarmapml on Sep 10 2020, 12:22 AM.

Details

Summary
  • Added support for return values in affine.for yield along the same lines as scf.for and affine.parallel.

Signed-off-by: Abhishek Varma <abhishek.varma@polymagelabs.com>

Diff Detail

Event Timeline

avarmapml created this revision.Sep 10 2020, 12:22 AM
Herald added a project: Restricted Project. · View Herald TranscriptSep 10 2020, 12:22 AM
avarmapml requested review of this revision.Sep 10 2020, 12:22 AM
avarmapml edited the summary of this revision. (Show Details)Sep 10 2020, 12:28 AM
bondhugula added inline comments.
mlir/include/mlir/Dialect/Affine/IR/AffineOps.td
302

Format fix please.

305

This should return an unsigned.

bondhugula requested changes to this revision.Sep 10 2020, 9:02 AM
bondhugula added inline comments.
mlir/lib/Dialect/Affine/IR/AffineOps.cpp
1246

Nit: > 0

1411

operandType

1419

Nit: terminate with full stop.

1481–1482

I think both these methods return unsigned.

mlir/test/Dialect/Affine/invalid.mlir
386

Consider 'defined values' -> 'results'
mismatch in number -> mismatch between the number
?

This revision now requires changes to proceed.Sep 10 2020, 9:02 AM

LGTM! Just some nit comments! Thanks for contributing this feature!

This commit does not provide support for reduction var.

What do you mean exactly? The example in the doc is a reduction. Do you mean that this patch doesn't include the analysis to deal with reductions described using iter_args?

mlir/include/mlir/Dialect/Affine/IR/AffineOps.td
231

some doc here about what this is for would be great

mlir/lib/Dialect/Affine/IR/AffineOps.cpp
1179

Same: doc here about bodyBuilder would be useful.

1189

nit: v -> val/value,...

1210

same

mlir/test/Dialect/Affine/invalid.mlir
384

nit: affine_for -> something more descriptive? affine_for_iter_args_mismatch?

mlir/test/Dialect/Affine/ops.mlir
211

nit: affine.if indentation++

221

nit: affine_for_multiple_yield?

avarmapml marked 14 inline comments as done.

Tackled initial review comments.

Bug fix for build function.

Harbormaster completed remote builds in B71329: Diff 291139.
bondhugula requested changes to this revision.Sep 14 2020, 4:10 AM

I think we definitely need a test for the builder API here to make sure it's working as intended. Please see the other builder API tests for reference in test/EDSC/builder-api-test.cpp.

This revision now requires changes to proceed.Sep 14 2020, 4:10 AM

Added test case for build method and bug fix

  • getUpperBoundOperands() was not picking up operands correctly. This update fixes that.
  • Added a minor test case to check build method for affine.for along with iter_args.
  • Updated function affineLoopBuilder definition and updated the same in builder-api-test.cpp.
avarmapml updated this revision to Diff 291719.Sep 14 2020, 3:59 PM

Updated getter/setter functions for lower and upper bound

bondhugula added inline comments.Sep 14 2020, 11:25 PM
mlir/lib/Dialect/Affine/IR/AffineOps.cpp
1629–1630

We should update the test cases to make sure these are covered - without this change, print would have been printing the wrong thing. You could add a test case that has upper bound operands as well as iter arguments.

bondhugula requested changes to this revision.Sep 14 2020, 11:28 PM

Thanks for fixing the issues.

mlir/test/EDSC/builder-api-test.cpp
180 ↗(On Diff #291719)

builder_for_iter_arg -> builder_affine_for_iter_args?

194 ↗(On Diff #291719)

Please also match the body with the yield.

725 ↗(On Diff #291719)

/*iterArgs=*/llvm::None

This revision now requires changes to proceed.Sep 14 2020, 11:28 PM
bondhugula added inline comments.Sep 14 2020, 11:33 PM
mlir/include/mlir/Dialect/Affine/IR/AffineOps.td
179–180

3 loop control values ... <-- this would be inaccurate (copy/paste error).

184

Nit: a -> an

301–302

This would be inaccurate - since the init operands for the iter args shouldn't be counted here. Please check if this accessor is needed and what the intended use is.

mlir/lib/Dialect/Affine/IR/AffineOps.cpp
1484

You can just do getNumOperands() with getOperation(). Also, compactly:

return getNumOperands() - lbMap.getNumInputs() - ubMap.getNumInputs();
avarmapml updated this revision to Diff 291839.Sep 15 2020, 2:48 AM
avarmapml marked 8 inline comments as done.

Handled review comments and updated test case

avarmapml edited the summary of this revision. (Show Details)Sep 15 2020, 3:16 AM
bondhugula requested changes to this revision.Sep 15 2020, 9:22 PM
bondhugula added inline comments.
mlir/test/EDSC/builder-api-test.cpp
194 ↗(On Diff #291719)

Looks like this hasn't been addressed, but marked done. Did you missing pushing?

This revision now requires changes to proceed.Sep 15 2020, 9:22 PM

Updated test case to match loop body/yield

avarmapml marked an inline comment as done.Sep 17 2020, 12:29 AM
bondhugula added inline comments.Sep 17 2020, 1:46 AM
mlir/test/EDSC/builder-api-test.cpp
195–196 ↗(On Diff #292418)

You don't need SmallVector here - instead, ValueRange(.., ..) inline would work.

bondhugula accepted this revision.Sep 17 2020, 1:46 AM

Looks good, thanks!

This revision is now accepted and ready to land.Sep 17 2020, 1:46 AM
avarmapml updated this revision to Diff 292427.Sep 17 2020, 1:54 AM
avarmapml marked an inline comment as done.

Minor code refactor

bondhugula accepted this revision.Sep 17 2020, 2:05 AM
This revision was automatically updated to reflect the committed changes.