mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-23 01:24:30 +00:00
Teach InstCombine to optimize extract of a value from a vector add operation with a constant zero.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@172576 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -13,7 +13,9 @@
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "InstCombine.h"
|
||||
#include "llvm/Support/PatternMatch.h"
|
||||
using namespace llvm;
|
||||
using namespace PatternMatch;
|
||||
|
||||
/// CheapToScalarize - Return true if the value is cheaper to scalarize than it
|
||||
/// is to leave as a vector operation. isConstant indicates whether we're
|
||||
@ -92,6 +94,13 @@ static Value *FindScalarElement(Value *V, unsigned EltNo) {
|
||||
return FindScalarElement(SVI->getOperand(1), InEl - LHSWidth);
|
||||
}
|
||||
|
||||
// Extract a value from a vector add operation with a constant zero.
|
||||
Value *Val = 0; Constant *Con = 0;
|
||||
if (match(V, m_Add(m_Value(Val), m_Constant(Con)))) {
|
||||
if (Con->getAggregateElement(EltNo)->isNullValue())
|
||||
return FindScalarElement(Val, EltNo);
|
||||
}
|
||||
|
||||
// Otherwise, we don't know.
|
||||
return 0;
|
||||
}
|
||||
|
Reference in New Issue
Block a user