mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-30 17:33:24 +00:00
Delete dead loads in the dag. This allows us to compile
vector.ll:test_extract_elt2 into: _test_extract_elt2: lfd f1, 32(r3) blr instead of: _test_extract_elt2: lfd f0, 56(r3) lfd f0, 48(r3) lfd f0, 40(r3) lfd f1, 32(r3) lfd f0, 24(r3) lfd f0, 16(r3) lfd f0, 8(r3) lfd f0, 0(r3) blr git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@27296 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bf9341493a
commit
e4b953939c
@ -2262,6 +2262,11 @@ SDOperand DAGCombiner::visitLOAD(SDNode *N) {
|
||||
SDOperand Ptr = N->getOperand(1);
|
||||
SDOperand SrcValue = N->getOperand(2);
|
||||
|
||||
// If there are no uses of the loaded value, change uses of the chain value
|
||||
// into uses of the chain input (i.e. delete the dead load).
|
||||
if (N->hasNUsesOfValue(0, 0))
|
||||
return CombineTo(N, DAG.getNode(ISD::UNDEF, N->getValueType(0)), Chain);
|
||||
|
||||
// If this load is directly stored, replace the load value with the stored
|
||||
// value.
|
||||
// TODO: Handle store large -> read small portion.
|
||||
|
Loading…
Reference in New Issue
Block a user