This is an archive of the discontinued LLVM Phabricator instance.

[mlir][linalg][bufferize] LinalgOps can bufferize inplace with input args
ClosedPublic

Authored by springerm on Dec 2 2021, 10:12 PM.

Details

Summary

LinalgOp results usually bufferize inplace with output args. With this change, they may buffer inplace with input args if the value of the output arg is not used in the computation.

Diff Detail

Event Timeline

springerm created this revision.Dec 2 2021, 10:12 PM
springerm requested review of this revision.Dec 2 2021, 10:12 PM
mlir/lib/Dialect/Linalg/ComprehensiveBufferize/LinalgInterfaceImpl.cpp
108

you'll also need to check for equal indexing maps until we have some region dependence analysis.

To be safe and conservative, you should also check that isProjectedPermutation is true, although you should not be able to create an op where the output is not a projected permutation in the first place with the current verifier.

108

Note:

O(i, j) = A(i, j) + B(j)  --> bufferizes inplace to:  A(i, j) += B(j) 
                                  --> this is fine

but:

O(i, j) += A(i, j) + B(j). --> bufferizes inplace to: A(i, j) += previous value of O(i, j) + B(j) 
                                    --> illegal to write A(i, j) = F(A(i, j), B(j))
                                    --> this is wrong

A simple "violated" range dependence analysis would have caught this case (and more complex future cases).

mravishankar requested changes to this revision.Dec 3 2021, 8:50 AM
mravishankar added inline comments.
mlir/lib/Dialect/Linalg/ComprehensiveBufferize/LinalgInterfaceImpl.cpp
108

Actually its better to check that the indexing maps of the input operand and the result are identical and that they are projected permutations, but overall this logic looks good to me. It will catch a lot of common cases and make things better bufferize in place.

137–138

I think this method is general enough to be moved into the interface. I dont see why this logic would not hold for any operation.

This revision now requires changes to proceed.Dec 3 2021, 8:50 AM
springerm updated this revision to Diff 392999.Dec 8 2021, 5:25 PM
springerm marked 3 inline comments as done.

address comments

mlir/lib/Dialect/Linalg/ComprehensiveBufferize/LinalgInterfaceImpl.cpp
137–138

I can't tell which line you originally commented on since I uploaded a new revision. Which one was it?

mravishankar accepted this revision.Dec 8 2021, 11:09 PM

Ah never mind. Stamping.

This revision is now accepted and ready to land.Dec 8 2021, 11:09 PM

There is still an issue here. I have to avoid the case where two different OpResult alias with the same OpOperand. Checking...