[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / Transforms / InstCombine / reduction-and-sext-zext-i1.ll
blobcad992e262d8f66b53def2702636d4dccab08d51
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -instcombine -S | FileCheck %s
4 define i1 @reduce_and_self(<8 x i1> %x) {
5 ; CHECK-LABEL: @reduce_and_self(
6 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <8 x i1> [[X:%.*]] to i8
7 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i8 [[TMP1]], -1
8 ; CHECK-NEXT:    ret i1 [[TMP2]]
10   %res = call i1 @llvm.vector.reduce.and.v8i32(<8 x i1> %x)
11   ret i1 %res
14 define i32 @reduce_and_sext(<4 x i1> %x) {
15 ; CHECK-LABEL: @reduce_and_sext(
16 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <4 x i1> [[X:%.*]] to i4
17 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i4 [[TMP1]], -1
18 ; CHECK-NEXT:    [[TMP3:%.*]] = sext i1 [[TMP2]] to i32
19 ; CHECK-NEXT:    ret i32 [[TMP3]]
21   %sext = sext <4 x i1> %x to <4 x i32>
22   %res = call i32 @llvm.vector.reduce.and.v4i32(<4 x i32> %sext)
23   ret i32 %res
26 define i64 @reduce_and_zext(<8 x i1> %x) {
27 ; CHECK-LABEL: @reduce_and_zext(
28 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <8 x i1> [[X:%.*]] to i8
29 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i8 [[TMP1]], -1
30 ; CHECK-NEXT:    [[TMP3:%.*]] = zext i1 [[TMP2]] to i64
31 ; CHECK-NEXT:    ret i64 [[TMP3]]
33   %zext = zext <8 x i1> %x to <8 x i64>
34   %res = call i64 @llvm.vector.reduce.and.v8i64(<8 x i64> %zext)
35   ret i64 %res
38 define i16 @reduce_and_sext_same(<16 x i1> %x) {
39 ; CHECK-LABEL: @reduce_and_sext_same(
40 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <16 x i1> [[X:%.*]] to i16
41 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i16 [[TMP1]], -1
42 ; CHECK-NEXT:    [[TMP3:%.*]] = sext i1 [[TMP2]] to i16
43 ; CHECK-NEXT:    ret i16 [[TMP3]]
45   %sext = sext <16 x i1> %x to <16 x i16>
46   %res = call i16 @llvm.vector.reduce.and.v16i16(<16 x i16> %sext)
47   ret i16 %res
50 define i8 @reduce_and_zext_long(<128 x i1> %x) {
51 ; CHECK-LABEL: @reduce_and_zext_long(
52 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <128 x i1> [[X:%.*]] to i128
53 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i128 [[TMP1]], -1
54 ; CHECK-NEXT:    [[TMP3:%.*]] = sext i1 [[TMP2]] to i8
55 ; CHECK-NEXT:    ret i8 [[TMP3]]
57   %sext = sext <128 x i1> %x to <128 x i8>
58   %res = call i8 @llvm.vector.reduce.and.v128i8(<128 x i8> %sext)
59   ret i8 %res
62 @glob = external global i8, align 1
63 define i8 @reduce_and_zext_long_external_use(<128 x i1> %x) {
64 ; CHECK-LABEL: @reduce_and_zext_long_external_use(
65 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <128 x i1> [[X:%.*]] to i128
66 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i128 [[TMP1]], -1
67 ; CHECK-NEXT:    [[TMP3:%.*]] = sext i1 [[TMP2]] to i8
68 ; CHECK-NEXT:    [[TMP4:%.*]] = extractelement <128 x i1> [[X]], i32 0
69 ; CHECK-NEXT:    [[EXT:%.*]] = sext i1 [[TMP4]] to i8
70 ; CHECK-NEXT:    store i8 [[EXT]], i8* @glob, align 1
71 ; CHECK-NEXT:    ret i8 [[TMP3]]
73   %sext = sext <128 x i1> %x to <128 x i8>
74   %res = call i8 @llvm.vector.reduce.and.v128i8(<128 x i8> %sext)
75   %ext = extractelement <128 x i8> %sext, i32 0
76   store i8 %ext, i8* @glob, align 1
77   ret i8 %res
80 @glob1 = external global i64, align 8
81 define i64 @reduce_and_zext_external_use(<8 x i1> %x) {
82 ; CHECK-LABEL: @reduce_and_zext_external_use(
83 ; CHECK-NEXT:    [[TMP1:%.*]] = bitcast <8 x i1> [[X:%.*]] to i8
84 ; CHECK-NEXT:    [[TMP2:%.*]] = icmp eq i8 [[TMP1]], -1
85 ; CHECK-NEXT:    [[TMP3:%.*]] = zext i1 [[TMP2]] to i64
86 ; CHECK-NEXT:    [[TMP4:%.*]] = extractelement <8 x i1> [[X]], i32 0
87 ; CHECK-NEXT:    [[EXT:%.*]] = zext i1 [[TMP4]] to i64
88 ; CHECK-NEXT:    store i64 [[EXT]], i64* @glob1, align 8
89 ; CHECK-NEXT:    ret i64 [[TMP3]]
91   %zext = zext <8 x i1> %x to <8 x i64>
92   %res = call i64 @llvm.vector.reduce.and.v8i64(<8 x i64> %zext)
93   %ext = extractelement <8 x i64> %zext, i32 0
94   store i64 %ext, i64* @glob1, align 8
95   ret i64 %res
98 declare i1 @llvm.vector.reduce.and.v8i32(<8 x i1> %a)
99 declare i32 @llvm.vector.reduce.and.v4i32(<4 x i32> %a)
100 declare i64 @llvm.vector.reduce.and.v8i64(<8 x i64> %a)
101 declare i16 @llvm.vector.reduce.and.v16i16(<16 x i16> %a)
102 declare i8 @llvm.vector.reduce.and.v128i8(<128 x i8> %a)