diff options
author | Chris Lattner <sabre@nondot.org> | 2005-12-23 05:44:41 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-12-23 05:44:41 +0000 |
commit | 54560f6887d712a674484909d1f818b7bd1c553c (patch) | |
tree | f31c7656939514b952641ee6ff4f95475880c39a /llvm/lib/CodeGen | |
parent | efbbedbf4a1eb6890fb8e529aabcfc05025ec080 (diff) | |
download | bcm5719-llvm-54560f6887d712a674484909d1f818b7bd1c553c.tar.gz bcm5719-llvm-54560f6887d712a674484909d1f818b7bd1c553c.zip |
fold (conv (load x)) -> (load (conv*)x).
This allows us to compile this:
void foo(double);
void bar(double *X) { foo(*X); }
To this:
bar:
save -96, %o6, %o6
ld [%i0+4], %o1
ld [%i0], %o0
call foo
nop
restore %g0, %g0, %g0
retl
nop
instead of this:
bar:
save -104, %o6, %o6
ldd [%i0], %f0
std %f0, [%i6+-8]
ld [%i6+-4], %o1
ld [%i6+-8], %o0
call foo
nop
restore %g0, %g0, %g0
retl
nop
on SparcV8.
llvm-svn: 24982
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index e4f5125e798..f08fd10413c 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -1760,6 +1760,16 @@ SDOperand DAGCombiner::visitBIT_CONVERT(SDNode *N) { if (N0.getOpcode() == ISD::BIT_CONVERT) // conv(conv(x,t1),t2) -> conv(x,t2) return DAG.getNode(ISD::BIT_CONVERT, VT, N0.getOperand(0)); + // fold (conv (load x)) -> (load (conv*)x) + if (N0.getOpcode() == ISD::LOAD && N0.hasOneUse()) { + SDOperand Load = DAG.getLoad(VT, N0.getOperand(0), N0.getOperand(1), + N0.getOperand(2)); + WorkList.push_back(N); + CombineTo(N0.Val, DAG.getNode(ISD::BIT_CONVERT, N0.getValueType(), Load), + Load.getValue(1)); + return Load; + } + return SDOperand(); } |