Canonicalize -1 - x to ~x.
authorEvan Cheng <evan.cheng@apple.com>
Mon, 18 Jan 2010 21:38:44 +0000 (21:38 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Mon, 18 Jan 2010 21:38:44 +0000 (21:38 +0000)
Instcombine does this but apparently there are situations where this pattern will escape the optimizer and / or created by isel. Here is a case that's seen in JavaScriptCore:
  %t1 = sub i32 0, %a
  %t2 = add i32 %t1, -1
The dag combiner pattern: ((c1-A)+c2) -> (c1+c2)-A
will fold it to -1 - %a.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93773 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/DAGCombiner.cpp
test/CodeGen/X86/xor.ll

index 549527c1a3f755c335c4f54d2588499415f65eb6..7fe908c730248d907fda34c94ece0e972369987e 100644 (file)
@@ -1176,6 +1176,9 @@ SDValue DAGCombiner::visitSUB(SDNode *N) {
   if (N1C)
     return DAG.getNode(ISD::ADD, N->getDebugLoc(), VT, N0,
                        DAG.getConstant(-N1C->getAPIntValue(), VT));
+  // Canonicalize (sub -1, x) -> ~x, i.e. (xor x, -1)
+  if (N0C && N0C->isAllOnesValue())
+    return DAG.getNode(ISD::XOR, N->getDebugLoc(), VT, N1, N0);
   // fold (A+B)-A -> B
   if (N0.getOpcode() == ISD::ADD && N0.getOperand(0) == N1)
     return N0.getOperand(1);
index 7bd06bba4c3e43c1453f88324d31285b4547011d..9bfff8a06a862c382d8a8411e792380cf049c6ee 100644 (file)
@@ -131,3 +131,14 @@ bb12:
 ; X32:    andl {{.*}}[[REG]]
 }
 
+define i32 @test8(i32 %a) nounwind {
+; rdar://7553032
+entry:
+  %t1 = sub i32 0, %a
+  %t2 = add i32 %t1, -1
+  ret i32 %t2
+; X64: test8:
+; X64:   notl %eax
+; X32: test8:
+; X32:   notl %eax
+}