[llvm-commits] [llvm] r60432 - /llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
Dale Johannesen
dalej at apple.com
Tue Dec 2 10:40:40 PST 2008
Author: johannes
Date: Tue Dec 2 12:40:40 2008
New Revision: 60432
URL: http://llvm.org/viewvc/llvm-project?rev=60432&view=rev
Log:
One more transformation.
Modified:
llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
Modified: llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp?rev=60432&r1=60431&r2=60432&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp (original)
+++ llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp Tue Dec 2 12:40:40 2008
@@ -1025,6 +1025,14 @@
return DAG.getNode(ISD::SUB, VT, N1.getOperand(0),
N1.getOperand(1).getOperand(0));
}
+ // fold (A+((B-A)+-C)) to (B+-C)
+ if ((N1.getOpcode() == ISD::SUB || N1.getOpcode() == ISD::ADD) &&
+ N1.getOperand(0).getOpcode() == ISD::SUB &&
+ N0 == N1.getOperand(0).getOperand(1)) {
+ return DAG.getNode(N1.getOpcode(), VT, N1.getOperand(0).getOperand(0),
+ N1.getOperand(1));
+ }
+
// fold (A-B)+(C-D) to (A+C)-(B+D) when A or C is constant
if (N0.getOpcode() == ISD::SUB && N1.getOpcode() == ISD::SUB) {
SDValue N00 = N0.getOperand(0);
More information about the llvm-commits
mailing list