Introducing lowering for extending loads regressed an optimisation in
VLS codegen. Since the extend is merged into the load before the mulh is
generated, a standard mul followed by a lsr and truncating store is used
instead. This patch causes the mulh to be generated before the extends
are merged into the loads.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Unit Tests
| Time | Test | |
|---|---|---|
| 100 ms | x64 debian > LLVM.Bindings/Go::go.test | 
Event Timeline
Whilst not wrong this looks like something that should be canonicalised earlier. Is it possible to add this logic to SelectionDAG::getVectorShuffle() and utilise SelectionDAG::getConstant()? I ask because there are several functions of isConstOrConstSplat's ilk and we don't really want to have to add similar support to all of them.
I'm not 100% sure what you mean here so I thought I ought to check; do you mean that SelectionDAG::getVectorShuffle() should return a BUILD_VECTOR generated using SelectionDAG::getConstant() in cases like this where the vector shuffle is a constant splat?
Yes, that was what I was thinking, because it seemed odd that such a constant representation exists by this point in the pipeline. However, I can see that it's coming from the test itself and so I've changed my mind and am now wondering if there actually a problem that needs solving here?
The tests are using a non-standard immediate representation (aka "fixed vector shuffle of an inserted constant") that LLVM would have converted to a constant vector (aka <i16 8, i16 8,....) long before it gets to the code generator. This is backed up by running the test through clang, which results in smul when expected.
This makes me think that to protect the MULS/MULU functionality, you just need to update the test itself to remove the non-standard representation.
I changed the tests as suggested above in rG0af1808f9b99 and this issue does go away as suggested so I am closing this revision.
clang-format: please reformat the code