summaryrefslogtreecommitdiffstats
path: root/clang/lib/Rewrite/TokenRewriter.cpp
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@intel.com>2019-08-26 18:23:26 +0000
committerCraig Topper <craig.topper@intel.com>2019-08-26 18:23:26 +0000
commit36d1588f017bb6e971cb14cc6e7094c3db9c0436 (patch)
tree1a3fa37ca359557e1cf523e99ac2e47d51ddfd25 /clang/lib/Rewrite/TokenRewriter.cpp
parentac1d5986c836924896aeb934ff71432f80c70063 (diff)
downloadbcm5719-llvm-36d1588f017bb6e971cb14cc6e7094c3db9c0436.tar.gz
bcm5719-llvm-36d1588f017bb6e971cb14cc6e7094c3db9c0436.zip
[X86] Add a hack to combinePMULDQ to manually turn SIGN_EXTEND_VECTOR_INREG/ZERO_EXTEND_VECTOR_INREG inputs into an ANY_EXTEND_VECTOR_INREG style shuffle
ANY_EXTEND_VECTOR_INREG isn't currently marked Legal which prevents SimplifyDemandedBits from turning SIGN/ZERO_EXTEND_VECTOR_INREG into it after op legalization. And even if we did make it Legal, combineExtInVec doesn't do shuffle combining on the VECTOR_INREG nodes until AVX1. This patch adds a quick hack to combinePMULDQ to directly emit a vector shuffle corresponding to an ANY_EXTEND_VECTOR_INREG operation. This avoids both of those issues without creating any other regressions on our tests. The xop-ifma.ll change here also showed up when I tried to resurrect D56306 and seemed to be the only improvement that patch creates now. This is a more direct way to get the benefit. Differential Revision: https://reviews.llvm.org/D66436 llvm-svn: 369942
Diffstat (limited to 'clang/lib/Rewrite/TokenRewriter.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud