mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 20:29:48 +00:00
clean up some corner cases
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23692 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
87514ca04c
commit
04ecf6d65f
@ -1583,14 +1583,18 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
|
||||
SDOperand SrcValue = N->getOperand(3);
|
||||
|
||||
// If this is a store that kills a previous store, remove the previous store.
|
||||
if (Chain.getOpcode() == ISD::STORE && Chain.getOperand(2) == Ptr) {
|
||||
if (Chain.getOpcode() == ISD::STORE && Chain.getOperand(2) == Ptr &&
|
||||
Chain.Val->hasOneUse() /* Avoid introducing DAG cycles */) {
|
||||
// Create a new store of Value that replaces both stores.
|
||||
SDNode *PrevStore = Chain.Val;
|
||||
if (PrevStore->getOperand(1) == Value) // Same value multiply stored.
|
||||
return Chain;
|
||||
SDOperand NewStore = DAG.getNode(ISD::STORE, MVT::Other,
|
||||
PrevStore->getOperand(0), Value, Ptr,
|
||||
SrcValue);
|
||||
CombineTo(N, NewStore); // Nuke this store.
|
||||
CombineTo(PrevStore, NewStore); // Nuke the previous store.
|
||||
return NewStore; // Replace this store with NewStore.
|
||||
return SDOperand(N, 0);
|
||||
}
|
||||
|
||||
return SDOperand();
|
||||
|
Loading…
Reference in New Issue
Block a user