[llvm] r280424 - [Legalizer] Don't throw away false low half when expanding GT/LT SETCC
Michael Kuperstein via llvm-commits
llvm-commits at lists.llvm.org
Thu Sep 1 16:02:33 PDT 2016
Author: mkuper
Date: Thu Sep 1 18:02:32 2016
New Revision: 280424
URL: http://llvm.org/viewvc/llvm-project?rev=280424&view=rev
Log:
[Legalizer] Don't throw away false low half when expanding GT/LT SETCC
When expanding a SETCC for which the low half is known to evaluate to false,
we can only throw it away for LT/GT comparisons, not LE/GE.
This fixes PR29170.
Differential Revision: https://reviews.llvm.org/D24151
Added:
llvm/trunk/test/CodeGen/X86/pr29170.ll
Modified:
llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp
Modified: llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp?rev=280424&r1=280423&r2=280424&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp (original)
+++ llvm/trunk/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp Thu Sep 1 18:02:32 2016
@@ -2865,16 +2865,16 @@ void DAGTypeLegalizer::IntegerExpandSetC
ConstantSDNode *LoCmpC = dyn_cast<ConstantSDNode>(LoCmp.getNode());
ConstantSDNode *HiCmpC = dyn_cast<ConstantSDNode>(HiCmp.getNode());
- if ((LoCmpC && LoCmpC->isNullValue()) ||
- (HiCmpC && HiCmpC->isNullValue() &&
- (CCCode == ISD::SETLE || CCCode == ISD::SETGE || CCCode == ISD::SETUGE ||
- CCCode == ISD::SETULE)) ||
- (HiCmpC && HiCmpC->getAPIntValue() == 1 &&
- (CCCode == ISD::SETLT || CCCode == ISD::SETGT || CCCode == ISD::SETUGT ||
- CCCode == ISD::SETULT))) {
- // low part is known false, returns high part.
+
+ bool EqAllowed = (CCCode == ISD::SETLE || CCCode == ISD::SETGE ||
+ CCCode == ISD::SETUGE || CCCode == ISD::SETULE);
+
+ if ((EqAllowed && (HiCmpC && HiCmpC->isNullValue())) ||
+ (!EqAllowed && ((HiCmpC && (HiCmpC->getAPIntValue() == 1)) ||
+ (LoCmpC && LoCmpC->isNullValue())))) {
// For LE / GE, if high part is known false, ignore the low part.
- // For LT / GT, if high part is known true, ignore the low part.
+ // For LT / GT: if low part is known false, return the high part.
+ // if high part is known true, ignore the low part.
NewLHS = HiCmp;
NewRHS = SDValue();
return;
Added: llvm/trunk/test/CodeGen/X86/pr29170.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/pr29170.ll?rev=280424&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/X86/pr29170.ll (added)
+++ llvm/trunk/test/CodeGen/X86/pr29170.ll Thu Sep 1 18:02:32 2016
@@ -0,0 +1,32 @@
+; RUN: llc < %s | FileCheck %s
+
+target datalayout = "e-m:e-p:32:32-f64:32:64-f80:32-n8:16:32-S128"
+target triple = "i386-unknown-linux-gnu"
+
+ at b = global i16 0, align 4
+
+; CHECK-LABEL: @main
+; CHECK: cmpl
+; CHECK: sbbl
+define i32 @main() {
+entry:
+ %true = icmp eq i32 0, 0
+ %const = bitcast i64 -4294967296 to i64
+ br i1 %true, label %go, label %if.else
+
+go:
+ %b = load i16, i16* @b, align 4
+ %sext = shl i16 %b, 8
+ %conv = ashr i16 %sext, 8
+ %neg4 = xor i64 %const, -1
+ %conv5 = zext i16 %conv to i64
+ %cmp = icmp slt i64 %conv5, %neg4
+ br i1 %cmp, label %if.then, label %if.else
+
+if.then:
+ ret i32 42
+
+if.else:
+ ret i32 0
+}
+
More information about the llvm-commits
mailing list