forked from OSchip/llvm-project
[DAG] Move extload check in store merge. NFC.
Move candidate check from later check to initial candidate check. llvm-svn: 309698
This commit is contained in:
parent
4bf1d7ad81
commit
b5a0af6b6e
|
@ -12569,7 +12569,6 @@ void DAGCombiner::getStoreMergeCandidates(
|
|||
if (IsLoadSrc)
|
||||
LBasePtr = BaseIndexOffset::match(
|
||||
cast<LoadSDNode>(St->getValue())->getBasePtr(), DAG);
|
||||
|
||||
auto CandidateMatch = [&](StoreSDNode *Other, BaseIndexOffset &Ptr,
|
||||
int64_t &Offset) -> bool {
|
||||
if (Other->isVolatile() || Other->isIndexed())
|
||||
|
@ -12583,6 +12582,9 @@ void DAGCombiner::getStoreMergeCandidates(
|
|||
// The Load's Base Ptr must also match
|
||||
if (LoadSDNode *OtherLd = dyn_cast<LoadSDNode>(Other->getValue())) {
|
||||
auto LPtr = BaseIndexOffset::match(OtherLd->getBasePtr(), DAG);
|
||||
// We do not handle extended loads
|
||||
if (OtherLd->getExtensionType() != ISD::NON_EXTLOAD)
|
||||
return false;
|
||||
if (!(LBasePtr.equalBaseIndex(LPtr, DAG)))
|
||||
return false;
|
||||
} else
|
||||
|
@ -12938,10 +12940,6 @@ bool DAGCombiner::MergeConsecutiveStores(StoreSDNode *St) {
|
|||
if (Ld->isVolatile() || Ld->isIndexed())
|
||||
break;
|
||||
|
||||
// We do not accept ext loads.
|
||||
if (Ld->getExtensionType() != ISD::NON_EXTLOAD)
|
||||
break;
|
||||
|
||||
// The stored memory type must be the same.
|
||||
if (Ld->getMemoryVT() != MemVT)
|
||||
break;
|
||||
|
|
Loading…
Reference in New Issue