mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
Simplify store(bitconv(x)) to store(x). This allows us to compile this:
void bar(double Y, double *X) { *X = Y; } to this: bar: save -96, %o6, %o6 st %i1, [%i2+4] st %i0, [%i2] restore %g0, %g0, %g0 retl nop instead of this: bar: save -104, %o6, %o6 st %i1, [%i6+-4] st %i0, [%i6+-8] ldd [%i6+-8], %f0 std %f0, [%i2] restore %g0, %g0, %g0 retl nop on sparcv8. llvm-svn: 24983
This commit is contained in:
parent
20e6338732
commit
0637d38ec2
@ -2081,6 +2081,11 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
|
||||
return SDOperand(N, 0);
|
||||
}
|
||||
|
||||
// If this is a store of a bit convert, store the input value.
|
||||
if (Value.getOpcode() == ISD::BIT_CONVERT)
|
||||
return DAG.getNode(ISD::STORE, MVT::Other, Chain, Value.getOperand(0),
|
||||
Ptr, SrcValue);
|
||||
|
||||
return SDOperand();
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user