DAGCombine: Also shrink eq compares where the constant is exactly as large as the...
authorBenjamin Kramer <benny.kra@googlemail.com>
Thu, 16 May 2013 18:47:58 +0000 (18:47 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Thu, 16 May 2013 18:47:58 +0000 (18:47 +0000)
if ((x & 255) == 255)

before: movzbl  %al, %eax
        cmpl  $255, %eax

after:  cmpb  $-1, %al

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

lib/CodeGen/SelectionDAG/TargetLowering.cpp
test/CodeGen/X86/shrink-compare.ll

index f5fc66c4d3da5f9c39c3839b6381a276b2678528..95c327c8b055c516d5de0cd9c4af8b080d33f9e5 100644 (file)
@@ -1160,7 +1160,7 @@ TargetLowering::SimplifySetCC(EVT VT, SDValue N0, SDValue N1,
       }
 
       // Make sure we're not losing bits from the constant.
-      if (MinBits < C1.getBitWidth() && MinBits > C1.getActiveBits()) {
+      if (MinBits < C1.getBitWidth() && MinBits >= C1.getActiveBits()) {
         EVT MinVT = EVT::getIntegerVT(*DAG.getContext(), MinBits);
         if (isTypeDesirableForOp(ISD::SETCC, MinVT)) {
           // Will get folded away.
index 8d4b07f9d9b0ec88038cae4eb738ca4687a7460d..0c16f86ff13ec57c471d28b473852e84f693f862 100644 (file)
@@ -34,3 +34,19 @@ if.end:
 ; CHECK: test2:
 ; CHECK: cmpb $47, %{{dil|cl}}
 }
+
+define void @test3(i32 %X) nounwind {
+entry:
+  %and = and i32 %X, 255
+  %cmp = icmp eq i32 %and, 255
+  br i1 %cmp, label %if.then, label %if.end
+
+if.then:
+  tail call void @bar() nounwind
+  br label %if.end
+
+if.end:
+  ret void
+; CHECK: test3:
+; CHECK: cmpb $-1, %{{dil|cl}}
+}