diff options
author | Jim Grosbach <grosbach@apple.com> | 2012-04-11 17:40:18 +0000 |
---|---|---|
committer | Jim Grosbach <grosbach@apple.com> | 2012-04-11 17:40:18 +0000 |
commit | 1835547ec195c35b3a59bf834f4df942c61a5c53 (patch) | |
tree | 750043ed23609e0a48c4275625121da8f304d2d1 /lib/Target/ARM/ARMISelDAGToDAG.cpp | |
parent | 5c1761d486deb47648fa1b854692f4b64a35f0e2 (diff) | |
download | llvm-1835547ec195c35b3a59bf834f4df942c61a5c53.tar.gz llvm-1835547ec195c35b3a59bf834f4df942c61a5c53.tar.bz2 llvm-1835547ec195c35b3a59bf834f4df942c61a5c53.tar.xz |
ARM 'vuzp.32 Dd, Dm' is a pseudo-instruction.
While there is an encoding for it in VUZP, the result of that is undefined,
so we should avoid it. Define the instruction as a pseudo for VTRN.32
instead, as the ARM ARM indicates.
rdar://11222366
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154511 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMISelDAGToDAG.cpp')
-rw-r--r-- | lib/Target/ARM/ARMISelDAGToDAG.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/Target/ARM/ARMISelDAGToDAG.cpp b/lib/Target/ARM/ARMISelDAGToDAG.cpp index 435d6a9743..1eafbbc8f6 100644 --- a/lib/Target/ARM/ARMISelDAGToDAG.cpp +++ b/lib/Target/ARM/ARMISelDAGToDAG.cpp @@ -2845,7 +2845,8 @@ SDNode *ARMDAGToDAGISel::Select(SDNode *N) { case MVT::v8i8: Opc = ARM::VUZPd8; break; case MVT::v4i16: Opc = ARM::VUZPd16; break; case MVT::v2f32: - case MVT::v2i32: Opc = ARM::VUZPd32; break; + // vuzp.32 Dd, Dm is a pseudo-instruction expanded to vtrn.32 Dd, Dm. + case MVT::v2i32: Opc = ARM::VTRNd32; break; case MVT::v16i8: Opc = ARM::VUZPq8; break; case MVT::v8i16: Opc = ARM::VUZPq16; break; case MVT::v4f32: |