summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-05-16 17:19:05 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-05-16 17:19:05 +0000
commit446efddfcd655131bd0ceeacce9c1166e30ed479 (patch)
tree941526787ed0ae765ee9b7fc9fe07b3cdf910223
parent62df5c9599d807ab9409303a12d2a9c3c0556d3c (diff)
downloadllvm-446efddfcd655131bd0ceeacce9c1166e30ed479.tar.gz
llvm-446efddfcd655131bd0ceeacce9c1166e30ed479.tar.bz2
llvm-446efddfcd655131bd0ceeacce9c1166e30ed479.tar.xz
If the result of a BIT_CONVERT is a v1* vector, it doesn't mean its source is a v1* vector.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51192 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/CodeGen/SelectionDAG/LegalizeDAG.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
index 155b1a33ac..3290311df2 100644
--- a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
+++ b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
@@ -7109,10 +7109,13 @@ SDOperand SelectionDAGLegalize::ScalarizeVectorOp(SDOperand Op) {
Result = Node->getOperand(0);
assert(Result.getValueType() == NewVT);
break;
- case ISD::BIT_CONVERT:
- Result = DAG.getNode(ISD::BIT_CONVERT, NewVT,
- ScalarizeVectorOp(Op.getOperand(0)));
+ case ISD::BIT_CONVERT: {
+ SDOperand Op0 = Op.getOperand(0);
+ if (MVT::getVectorNumElements(Op0.getValueType()) == 1)
+ Op0 = ScalarizeVectorOp(Op0);
+ Result = DAG.getNode(ISD::BIT_CONVERT, NewVT, Op0);
break;
+ }
case ISD::SELECT:
Result = DAG.getNode(ISD::SELECT, NewVT, Op.getOperand(0),
ScalarizeVectorOp(Op.getOperand(1)),