xref: /llvm-project/llvm/test/Transforms/InstCombine/shufflevec-constant.ll (revision 22f5dc7501b5eb97e406fd6c5e44048bb712ecc3)
1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2; RUN: opt < %s -passes=instcombine -S | FileCheck %s
3
4target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
5target triple = "i386-apple-darwin9"
6
7define <4 x float> @__inff4() nounwind readnone {
8; CHECK-LABEL: @__inff4(
9; CHECK-NEXT:    ret <4 x float> <float 0.000000e+00, float 0.000000e+00, float 0x7FF0000000000000, float 0x7FF0000000000000>
10;
11  %tmp14 = extractelement <1 x double> bitcast (<2 x float> <float 0x7FF0000000000000, float 0x7FF0000000000000> to <1 x double>), i32 0
12  %tmp4 = bitcast double %tmp14 to i64
13  %tmp3 = bitcast i64 %tmp4 to <2 x float>
14  %tmp8 = shufflevector <2 x float> %tmp3, <2 x float> undef, <4 x i32> <i32 0, i32 1, i32 undef, i32 undef>
15  %tmp9 = shufflevector <4 x float> zeroinitializer, <4 x float> %tmp8, <4 x i32> <i32 0, i32 1, i32 4, i32 5>
16  ret <4 x float> %tmp9
17}
18
19define <4 x i1> @shuffle_undef_fixed() {
20; CHECK-LABEL: @shuffle_undef_fixed(
21; CHECK-NEXT:    ret <4 x i1> poison
22;
23  %S = shufflevector <4 x i1> zeroinitializer, <4 x i1> zeroinitializer, <4 x i32> undef
24  ret <4 x i1> %S
25}
26
27define <vscale x 4 x i1> @suffle_undef_scalable() {
28; CHECK-LABEL: @suffle_undef_scalable(
29; CHECK-NEXT:    ret <vscale x 4 x i1> poison
30;
31  %S = shufflevector <vscale x 4 x i1> zeroinitializer, <vscale x 4 x i1> zeroinitializer, <vscale x 4 x i32> undef
32  ret <vscale x 4 x i1> %S
33}
34