Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
mlir/include/mlir/Dialect/GPU/Passes.h | ||
---|---|---|
30 ↗ | (On Diff #408183) | I'm concerned about making any pass non hermetic: that mean adding any C++ injection that won't be serialized in the textual pipeline. I'd like to keep the pass simple and hermetic, and extract whatever logic as utilities so that one can customize in their own pass instead. |
Thank you. The default is fairly arbitrary (well, it's good enough for some index computations) and we really should have some cost model here. +1 to making it configurable at least.
mlir/lib/Dialect/GPU/Transforms/KernelOutlining.cpp | ||
---|---|---|
128 | It would be nice to maybe split the pass into two, one that does sinking and one that does outlining. Then we could remove the default here completely and add it to the sinking pass instead. Actual users of this API would need to implement their own cost model. |
mlir/lib/Dialect/GPU/Transforms/KernelOutlining.cpp | ||
---|---|---|
128 | I can make isSinkingBeneficiary param non-optional and provide isSinkingBeneficiaryDefault explicitly in GpuKernelOutliningPass but I would prefer to do pass splitting in separate review. |
mlir/unittests/Dialect/GPU/KernelOutliningTest.cpp | ||
---|---|---|
57 | Please keep the testing implemented with passes, this is how MLIR is tested in general. |
mlir/unittests/Dialect/GPU/KernelOutliningTest.cpp | ||
---|---|---|
57 | I that case I can just drop these test and assume it is tested by existing GpuKernelOutliningPass tests. |
Thank you. Just a naming nit.
mlir/lib/Dialect/GPU/Transforms/KernelOutlining.cpp | ||
---|---|---|
128 | Sounds good. Maybe also remove the 'Default' from the name then. We could even call it isLikelyAnIndexComputation or something because that is what the function really does. | |
mlir/unittests/Dialect/GPU/KernelOutliningTest.cpp | ||
57 | If we do not have a default implementation, then this test is not needed indeed. The other test would already test that providing an implementation works and we do not have to test the overriding. |
It would be nice to maybe split the pass into two, one that does sinking and one that does outlining. Then we could remove the default here completely and add it to the sinking pass instead. Actual users of this API would need to implement their own cost model.