This is an archive of the discontinued LLVM Phabricator instance.

[mlir][spirv] First step to support spirv cooperative matrix extension.
ClosedPublic

Authored by ThomasRaoux on May 15 2020, 3:31 PM.

Details

Summary

Add a new type to SPIRV dialect for cooperative matrix and add new op for cooperative matrix load. This is missing most instructions to support cooperative matrix extension but this is a stop-gap patch to avoid creating big review.

Diff Detail

Event Timeline

ThomasRaoux created this revision.May 15 2020, 3:31 PM
mravishankar requested changes to this revision.May 17 2020, 10:33 PM

Could you also add some roundtrip tests to : https://github.com/llvm/llvm-project/blob/master/mlir/test/Dialect/SPIRV/ops.mlir (Actually a separate test file for these ops might also be fine)

mlir/include/mlir/Dialect/SPIRV/SPIRVBase.td
3228 ↗(On Diff #264374)

The opcodes in this file are auto-generated using this script : https://github.com/llvm/llvm-project/blob/master/mlir/utils/spirv/define_opcodes.sh . Please use that instead of defining them here. (Sorry if the documentation doesnt point you in the right direction)

mlir/lib/Dialect/SPIRV/SPIRVDialect.cpp
281 ↗(On Diff #264374)

Nit: Instead of using parseKeyword here, we could make this method : https://github.com/llvm/llvm-project/blob/7ee479a760e0a4402b4eb7fb6168768a44f66945/mlir/lib/Dialect/SPIRV/SPIRVOps.cpp#L147 a utility function and use that here?

mlir/lib/Dialect/SPIRV/Serialization/Deserializer.cpp
1235 ↗(On Diff #264374)

I wonder if the automatic deserialization generation code would work here? (AFAIR the same code must already be generated by tblgen, but is being intercepted early here)

This revision now requires changes to proceed.May 17 2020, 10:33 PM
ThomasRaoux marked 4 inline comments as done.May 18 2020, 1:22 AM

Thanks Mahesh, I added roundtrip tests. Please take another look.

mlir/include/mlir/Dialect/SPIRV/SPIRVBase.td
3228 ↗(On Diff #264374)

My bad, it was in the documentation, I had missed this part. Updated using the script.

mlir/lib/Dialect/SPIRV/SPIRVDialect.cpp
281 ↗(On Diff #264374)

Done.

mlir/lib/Dialect/SPIRV/Serialization/Deserializer.cpp
1235 ↗(On Diff #264374)

My understanding is that we get auto-generated code for the ops but here this if for deserialization of the new type. The type is not defined tblgen at all unless I'm missing something.

Sorry, I should have been more clear. These go through the serialization and deserialization of the ops. So while they are testing the parser and printer as well, they are primarily for testing that the serialization and deserialization works. Typically ops are tested for both serialization/deserialization through the SPIR-V binary, as well as just IR roundtrip. The IR round-trip tests live here : https://github.com/llvm/llvm-project/tree/master/mlir/test/Dialect/SPIRV . Regressions here indicate that the IR parsing/printing failed.

The serialization tests are within the Serialization sub-directory here : https://github.com/llvm/llvm-project/tree/master/mlir/test/Dialect/SPIRV/Serialization. These catch regressions in serialization/deserialization.

So I was asking for a roundtrip IR test.

Rest of the changes look fine to me.

mlir/lib/Dialect/SPIRV/Serialization/Deserializer.cpp
1235 ↗(On Diff #264374)

Ah, your right. My bad.

Fantastic!! This is really great, Thomas! Thanks for taking on this! Overall looks good to me; I just have a few nits. Besides, can we add tests for

  1. The coop mat type itself: https://github.com/llvm/llvm-project/blob/master/mlir/test/Dialect/SPIRV/types.mlir
  2. (De)serialization for coop mat load op in the directory as pointed out by Mahesh: https://github.com/llvm/llvm-project/tree/master/mlir/test/Dialect/SPIRV/Serialization
mlir/include/mlir/Dialect/SPIRV/ParserUtils.h
1 ↗(On Diff #264557)

The header explanation needs to be updated.

40 ↗(On Diff #264557)

Nit: let's have an empty line before #endif to improve readability.

mlir/include/mlir/Dialect/SPIRV/SPIRVBase.td
2994 ↗(On Diff #264557)

Nit: can we keep this subsection alphabetically sorted?

mlir/include/mlir/Dialect/SPIRV/SPIRVCooperativeMatrixOps.td
22 ↗(On Diff #264557)

What about copying the original doc for coopmat load from https://github.com/KhronosGroup/SPIRV-Registry/blob/master/extensions/NV/SPV_NV_cooperative_matrix.asciidoc#3328-memory-instructions here? We have been mostly following that convention for SPIR-V ops defined.

mlir/include/mlir/Dialect/SPIRV/SPIRVTypes.h
355 ↗(On Diff #264557)

Nit: move this empy line after the function decl?

mlir/lib/Dialect/SPIRV/SPIRVDialect.cpp
269 ↗(On Diff #264557)

spv.coopmatrix?

281 ↗(On Diff #264557)

Can we put the scope ahead of the element type? I think it's more natural that way: element types typically appear together with row/col sizes. (The spec put it in an order like this but we don't need to follow that order.)

mlir/lib/Dialect/SPIRV/SPIRVOps.cpp
2623 ↗(On Diff #264557)

spv.CooperativeMatrixLoadNV

mlir/lib/Dialect/SPIRV/SPIRVTypes.cpp
286 ↗(On Diff #264557)

Nit: leave an empty line to separate the methods with fields.

315 ↗(On Diff #264557)

We need to push SPV_NV_cooperative_matrix to extensions here.

320 ↗(On Diff #264557)

We need to push CooperativeMatrixNV capability to capabilities here.

mlir/test/Dialect/SPIRV/Serialization/cooperative-matrix.mlir
3 ↗(On Diff #264557)

We can drop the requires ... part. They are incorrect here given we actually need more capabilities and extensions for the following to be used.

antiagainst requested changes to this revision.May 18 2020, 12:09 PM
This revision now requires changes to proceed.May 18 2020, 12:09 PM
ThomasRaoux marked an inline comment as done.
ThomasRaoux marked 14 inline comments as done.May 18 2020, 4:13 PM

Thanks Lei. added some tests for the type in types.mir. About 2. I already had serialization/deserialization tests, am I missing something there?

mlir/test/Dialect/SPIRV/Serialization/cooperative-matrix.mlir
3 ↗(On Diff #264557)

I get the following error if I remove the requires part. Maybe I missed something?

error: module must have 'vce_triple' attribute to be serializeable

antiagainst accepted this revision.May 19 2020, 6:27 AM

Thanks Thomas! Just two final comments about the type assembly and tests. Feel free to land after addressing it. :)

mlir/test/Dialect/SPIRV/Serialization/cooperative-matrix.mlir
3 ↗(On Diff #264557)

Ah, sorry. You are right. I mistakenly treated this test as one for op parsing/printing round-trip. (Hence also my comment to request tests for serialization.)

Then can we fix the required extension and capability? At the moment it's wrong. (We don't have validation for this yet but should have.) We need to have spv.vce<v1.0, [CooperativeMatrixNV], [SPV_NV_cooperative_matrix]> here.

mlir/test/Dialect/SPIRV/types.mlir
338 ↗(On Diff #264784)

Hmm, sorry didn't point this out previously; I feel it's actually better to have the format of spv.coopmatrix<8x8xf32, Workgroup>. This is more consistent with vectors/tensors (vector<3x4xi32>) and pointers (spv.ptr<f32, PushConstant>) that way. How do you think?

ThomasRaoux marked 2 inline comments as done.
ThomasRaoux added inline comments.
mlir/test/Dialect/SPIRV/Serialization/cooperative-matrix.mlir
3 ↗(On Diff #264557)

Got it. Fixed.

mlir/test/Dialect/SPIRV/types.mlir
338 ↗(On Diff #264784)

Looks much better indeed.

This revision was not accepted when it landed; it landed in state Needs Review.May 19 2020, 7:49 PM
This revision was automatically updated to reflect the committed changes.
Herald added a project: Restricted Project. · View Herald TranscriptMay 19 2020, 7:49 PM