[llvm] ce6c95a - [InstCombine] Move test to instcombine; NFC
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 20 04:41:38 PDT 2020
Author: Nikita Popov
Date: 2020-03-20T12:41:19+01:00
New Revision: ce6c95aacae0cf5f8de8780de7f22de5f31a07dd
URL: https://github.com/llvm/llvm-project/commit/ce6c95aacae0cf5f8de8780de7f22de5f31a07dd
DIFF: https://github.com/llvm/llvm-project/commit/ce6c95aacae0cf5f8de8780de7f22de5f31a07dd.diff
LOG: [InstCombine] Move test to instcombine; NFC
This test uses -instcombine, so move it into the appropriate
directory. Also fork it for expensive checks enabled/disabled.
Added:
llvm/test/Transforms/InstCombine/known-signbit-shift.ll
Modified:
Removed:
llvm/test/Analysis/ValueTracking/known-signbit-shift.ll
################################################################################
diff --git a/llvm/test/Analysis/ValueTracking/known-signbit-shift.ll b/llvm/test/Transforms/InstCombine/known-signbit-shift.ll
similarity index 62%
rename from llvm/test/Analysis/ValueTracking/known-signbit-shift.ll
rename to llvm/test/Transforms/InstCombine/known-signbit-shift.ll
index 7e9f1c2e70cd..d619e5358114 100644
--- a/llvm/test/Analysis/ValueTracking/known-signbit-shift.ll
+++ b/llvm/test/Transforms/InstCombine/known-signbit-shift.ll
@@ -1,5 +1,6 @@
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
-; RUN: opt < %s -instcombine -S | FileCheck %s
+; RUN: opt < %s -instcombine -expensive-combines=0 -S | FileCheck %s --check-prefixes=CHECK,EXPENSIVE-OFF
+; RUN: opt < %s -instcombine -expensive-combines=1 -S | FileCheck %s --check-prefixes=CHECK,EXPENSIVE-ON
; Result of left shifting a non-negative integer
; with nsw flag should also be non-negative
@@ -29,8 +30,12 @@ define i1 @test_shift_negative(i32 %a, i32 %b) {
; If sign bit is a known zero, it cannot be a known one.
; This test should not crash opt. The shift produces poison.
define i32 @test_no_sign_bit_conflict1(i1 %b) {
-; CHECK-LABEL: @test_no_sign_bit_conflict1(
-; CHECK-NEXT: ret i32 0
+; EXPENSIVE-OFF-LABEL: @test_no_sign_bit_conflict1(
+; EXPENSIVE-OFF-NEXT: [[SEL:%.*]] = select i1 [[B:%.*]], i32 -2147221504, i32 -2147483648
+; EXPENSIVE-OFF-NEXT: ret i32 [[SEL]]
+;
+; EXPENSIVE-ON-LABEL: @test_no_sign_bit_conflict1(
+; EXPENSIVE-ON-NEXT: ret i32 0
;
%sel = select i1 %b, i32 8193, i32 8192
%mul = shl nsw i32 %sel, 18
@@ -40,8 +45,12 @@ define i32 @test_no_sign_bit_conflict1(i1 %b) {
; If sign bit is a known one, it cannot be a known zero.
; This test should not crash opt. The shift produces poison.
define i32 @test_no_sign_bit_conflict2(i1 %b) {
-; CHECK-LABEL: @test_no_sign_bit_conflict2(
-; CHECK-NEXT: ret i32 0
+; EXPENSIVE-OFF-LABEL: @test_no_sign_bit_conflict2(
+; EXPENSIVE-OFF-NEXT: [[SEL:%.*]] = select i1 [[B:%.*]], i32 2147221504, i32 2146959360
+; EXPENSIVE-OFF-NEXT: ret i32 [[SEL]]
+;
+; EXPENSIVE-ON-LABEL: @test_no_sign_bit_conflict2(
+; EXPENSIVE-ON-NEXT: ret i32 0
;
%sel = select i1 %b, i32 -8193, i32 -8194
%mul = shl nsw i32 %sel, 18
More information about the llvm-commits
mailing list