diff options
author | David Majnemer <david.majnemer@gmail.com> | 2015-08-18 22:07:25 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2015-08-18 22:07:25 +0000 |
commit | c6bb0e2a511dcb0adc57821f79b83fe00d3fb4da (patch) | |
tree | 282f7b133ac2b06052dfe2257de2fa45ffcd5424 /llvm/lib/Analysis/VectorUtils.cpp | |
parent | 5eaf08ff1f3a6897d15ac0d19f219f6654f56a4a (diff) | |
download | bcm5719-llvm-c6bb0e2a511dcb0adc57821f79b83fe00d3fb4da.tar.gz bcm5719-llvm-c6bb0e2a511dcb0adc57821f79b83fe00d3fb4da.zip |
[InstSimplify] Don't assume getAggregateElement will succeed
It isn't always possible to get a value from getAggregateElement.
This fixes PR24488.
llvm-svn: 245365
Diffstat (limited to 'llvm/lib/Analysis/VectorUtils.cpp')
-rw-r--r-- | llvm/lib/Analysis/VectorUtils.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/llvm/lib/Analysis/VectorUtils.cpp b/llvm/lib/Analysis/VectorUtils.cpp index 9a0af3bd8be..72140952ecb 100644 --- a/llvm/lib/Analysis/VectorUtils.cpp +++ b/llvm/lib/Analysis/VectorUtils.cpp @@ -398,10 +398,10 @@ Value *llvm::findScalarElement(Value *V, unsigned EltNo) { // Extract a value from a vector add operation with a constant zero. Value *Val = nullptr; Constant *Con = nullptr; - if (match(V, m_Add(m_Value(Val), m_Constant(Con)))) { - if (Con->getAggregateElement(EltNo)->isNullValue()) - return findScalarElement(Val, EltNo); - } + if (match(V, m_Add(m_Value(Val), m_Constant(Con)))) + if (Constant *Elt = Con->getAggregateElement(EltNo)) + if (Elt->isNullValue()) + return findScalarElement(Val, EltNo); // Otherwise, we don't know. return nullptr; |