diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2014-01-24 19:02:37 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2014-01-24 19:02:37 +0000 |
commit | 09b0f88a7fc96e994bc0db4f6b69019fad65409b (patch) | |
tree | becf070027bfec5a055aa8992c9aba4197b96f3e /llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp | |
parent | c63c52e03c47297b1c6c11f0c255e1adb022c09e (diff) | |
download | bcm5719-llvm-09b0f88a7fc96e994bc0db4f6b69019fad65409b.tar.gz bcm5719-llvm-09b0f88a7fc96e994bc0db4f6b69019fad65409b.zip |
InstCombine: Don't try to use aggregate elements of ConstantExprs.
PR18600.
llvm-svn: 200028
Diffstat (limited to 'llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp')
-rw-r--r-- | llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp b/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp index 7ffb01b5b2a..8b6a5c0e3f6 100644 --- a/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp +++ b/llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp @@ -25,11 +25,13 @@ static bool CheapToScalarize(Value *V, bool isConstant) { if (isConstant) return true; // If all elts are the same, we can extract it and use any of the values. - Constant *Op0 = C->getAggregateElement(0U); - for (unsigned i = 1, e = V->getType()->getVectorNumElements(); i != e; ++i) - if (C->getAggregateElement(i) != Op0) - return false; - return true; + if (Constant *Op0 = C->getAggregateElement(0U)) { + for (unsigned i = 1, e = V->getType()->getVectorNumElements(); i != e; + ++i) + if (C->getAggregateElement(i) != Op0) + return false; + return true; + } } Instruction *I = dyn_cast<Instruction>(V); if (!I) return false; |