2016-06-30 07:58:39 +08:00
|
|
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
2013-08-29 07:04:41 +08:00
|
|
|
; RUN: opt < %s -instcombine -S | FileCheck %s
|
2007-03-24 04:48:34 +08:00
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
; No selects should remain.
|
|
|
|
|
|
|
|
define i41 @zext(i1 %C) {
|
|
|
|
; CHECK-LABEL: @zext(
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = zext i1 %C to i41
|
|
|
|
; CHECK-NEXT: ret i41 [[V]]
|
|
|
|
;
|
|
|
|
%V = select i1 %C, i41 1, i41 0
|
|
|
|
ret i41 %V
|
|
|
|
}
|
|
|
|
|
|
|
|
define i41 @sext(i1 %C) {
|
|
|
|
; CHECK-LABEL: @sext(
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = sext i1 %C to i41
|
|
|
|
; CHECK-NEXT: ret i41 [[V]]
|
|
|
|
;
|
|
|
|
%V = select i1 %C, i41 -1, i41 0
|
|
|
|
ret i41 %V
|
|
|
|
}
|
2007-03-24 04:48:34 +08:00
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
define i999 @not_zext(i1 %C) {
|
|
|
|
; CHECK-LABEL: @not_zext(
|
2016-07-21 08:24:18 +08:00
|
|
|
; CHECK-NEXT: [[NOT_C:%.*]] = xor i1 %C, true
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = zext i1 [[NOT_C]] to i999
|
2016-06-30 07:58:39 +08:00
|
|
|
; CHECK-NEXT: ret i999 [[V]]
|
|
|
|
;
|
|
|
|
%V = select i1 %C, i999 0, i999 1
|
|
|
|
ret i999 %V
|
2007-03-24 04:48:34 +08:00
|
|
|
}
|
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
define i999 @not_sext(i1 %C) {
|
|
|
|
; CHECK-LABEL: @not_sext(
|
|
|
|
; CHECK-NEXT: [[NOT_C:%.*]] = xor i1 %C, true
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = sext i1 [[NOT_C]] to i999
|
|
|
|
; CHECK-NEXT: ret i999 [[V]]
|
|
|
|
;
|
|
|
|
%V = select i1 %C, i999 0, i999 -1
|
|
|
|
ret i999 %V
|
2007-03-24 04:48:34 +08:00
|
|
|
}
|
|
|
|
|
2016-07-07 06:23:01 +08:00
|
|
|
; Vector selects of vector splat constants match APInt too.
|
2016-06-30 08:09:13 +08:00
|
|
|
|
|
|
|
define <2 x i41> @zext_vec(<2 x i1> %C) {
|
|
|
|
; CHECK-LABEL: @zext_vec(
|
2016-07-07 06:23:01 +08:00
|
|
|
; CHECK-NEXT: [[V:%.*]] = zext <2 x i1> %C to <2 x i41>
|
2016-06-30 08:09:13 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i41> [[V]]
|
|
|
|
;
|
|
|
|
%V = select <2 x i1> %C, <2 x i41> <i41 1, i41 1>, <2 x i41> <i41 0, i41 0>
|
|
|
|
ret <2 x i41> %V
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i32> @sext_vec(<2 x i1> %C) {
|
|
|
|
; CHECK-LABEL: @sext_vec(
|
2016-07-07 06:23:01 +08:00
|
|
|
; CHECK-NEXT: [[V:%.*]] = sext <2 x i1> %C to <2 x i32>
|
2016-06-30 08:09:13 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i32> [[V]]
|
|
|
|
;
|
|
|
|
%V = select <2 x i1> %C, <2 x i32> <i32 -1, i32 -1>, <2 x i32> <i32 0, i32 0>
|
|
|
|
ret <2 x i32> %V
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i999> @not_zext_vec(<2 x i1> %C) {
|
|
|
|
; CHECK-LABEL: @not_zext_vec(
|
2016-07-21 08:24:18 +08:00
|
|
|
; CHECK-NEXT: [[NOT_C:%.*]] = xor <2 x i1> %C, <i1 true, i1 true>
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = zext <2 x i1> [[NOT_C]] to <2 x i999>
|
2016-06-30 08:09:13 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i999> [[V]]
|
|
|
|
;
|
|
|
|
%V = select <2 x i1> %C, <2 x i999> <i999 0, i999 0>, <2 x i999> <i999 1, i999 1>
|
|
|
|
ret <2 x i999> %V
|
|
|
|
}
|
|
|
|
|
|
|
|
define <2 x i64> @not_sext_vec(<2 x i1> %C) {
|
|
|
|
; CHECK-LABEL: @not_sext_vec(
|
2016-07-07 06:23:01 +08:00
|
|
|
; CHECK-NEXT: [[NOT_C:%.*]] = xor <2 x i1> %C, <i1 true, i1 true>
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = sext <2 x i1> [[NOT_C]] to <2 x i64>
|
2016-06-30 08:09:13 +08:00
|
|
|
; CHECK-NEXT: ret <2 x i64> [[V]]
|
|
|
|
;
|
|
|
|
%V = select <2 x i1> %C, <2 x i64> <i64 0, i64 0>, <2 x i64> <i64 -1, i64 -1>
|
|
|
|
ret <2 x i64> %V
|
|
|
|
}
|
|
|
|
|
2016-07-07 06:23:01 +08:00
|
|
|
; But don't touch this - we would need 3 instructions to extend and splat the scalar select condition.
|
|
|
|
|
|
|
|
define <2 x i32> @scalar_select_of_vectors(i1 %c) {
|
|
|
|
; CHECK-LABEL: @scalar_select_of_vectors(
|
|
|
|
; CHECK-NEXT: [[V:%.*]] = select i1 %c, <2 x i32> <i32 1, i32 1>, <2 x i32> zeroinitializer
|
|
|
|
; CHECK-NEXT: ret <2 x i32> [[V]]
|
|
|
|
;
|
|
|
|
%V = select i1 %c, <2 x i32> <i32 1, i32 1>, <2 x i32> zeroinitializer
|
|
|
|
ret <2 x i32> %V
|
|
|
|
}
|
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
;; (x <s 0) ? -1 : 0 -> ashr x, 31
|
|
|
|
|
2007-03-24 04:48:34 +08:00
|
|
|
define i41 @test3(i41 %X) {
|
2016-06-30 07:58:39 +08:00
|
|
|
; CHECK-LABEL: @test3(
|
|
|
|
; CHECK-NEXT: [[X_LOBIT:%.*]] = ashr i41 %X, 40
|
|
|
|
; CHECK-NEXT: ret i41 [[X_LOBIT]]
|
|
|
|
;
|
|
|
|
%t = icmp slt i41 %X, 0
|
|
|
|
%V = select i1 %t, i41 -1, i41 0
|
|
|
|
ret i41 %V
|
2007-03-24 04:48:34 +08:00
|
|
|
}
|
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
;; (x <s 0) ? -1 : 0 -> ashr x, 31
|
|
|
|
|
2007-03-24 04:48:34 +08:00
|
|
|
define i1023 @test4(i1023 %X) {
|
2016-06-30 07:58:39 +08:00
|
|
|
; CHECK-LABEL: @test4(
|
|
|
|
; CHECK-NEXT: [[X_LOBIT:%.*]] = ashr i1023 %X, 1022
|
|
|
|
; CHECK-NEXT: ret i1023 [[X_LOBIT]]
|
|
|
|
;
|
|
|
|
%t = icmp slt i1023 %X, 0
|
|
|
|
%V = select i1 %t, i1023 -1, i1023 0
|
|
|
|
ret i1023 %V
|
2007-03-24 04:48:34 +08:00
|
|
|
}
|
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
;; ((X & 27) ? 27 : 0)
|
|
|
|
|
2007-03-24 04:48:34 +08:00
|
|
|
define i41 @test5(i41 %X) {
|
2016-06-30 07:58:39 +08:00
|
|
|
; CHECK-LABEL: @test5(
|
|
|
|
; CHECK-NEXT: [[Y:%.*]] = and i41 %X, 32
|
|
|
|
; CHECK-NEXT: ret i41 [[Y]]
|
|
|
|
;
|
|
|
|
%Y = and i41 %X, 32
|
|
|
|
%t = icmp ne i41 %Y, 0
|
|
|
|
%V = select i1 %t, i41 32, i41 0
|
|
|
|
ret i41 %V
|
2007-03-24 04:48:34 +08:00
|
|
|
}
|
|
|
|
|
2016-06-30 07:58:39 +08:00
|
|
|
;; ((X & 27) ? 27 : 0)
|
|
|
|
|
2007-03-24 04:48:34 +08:00
|
|
|
define i1023 @test6(i1023 %X) {
|
2016-06-30 07:58:39 +08:00
|
|
|
; CHECK-LABEL: @test6(
|
|
|
|
; CHECK-NEXT: [[Y:%.*]] = and i1023 %X, 64
|
|
|
|
; CHECK-NEXT: ret i1023 [[Y]]
|
|
|
|
;
|
|
|
|
%Y = and i1023 %X, 64
|
|
|
|
%t = icmp ne i1023 %Y, 0
|
|
|
|
%V = select i1 %t, i1023 64, i1023 0
|
|
|
|
ret i1023 %V
|
2007-03-24 04:48:34 +08:00
|
|
|
}
|
2016-06-30 07:58:39 +08:00
|
|
|
|