1; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=corei7 -promote-elements -mattr=+sse41 | FileCheck %s
2
3;CHECK: vsel_float
4;CHECK: blendvps
5;CHECK: ret
6define <4 x float> @vsel_float(<4 x float> %v1, <4 x float> %v2) {
7  %vsel = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x float> %v1, <4 x float> %v2
8  ret <4 x float> %vsel
9}
10
11
12;CHECK: vsel_4xi8
13;CHECK: blendvps
14;CHECK: ret
15define <4 x i8> @vsel_4xi8(<4 x i8> %v1, <4 x i8> %v2) {
16  %vsel = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x i8> %v1, <4 x i8> %v2
17  ret <4 x i8> %vsel
18}
19
20;CHECK: vsel_4xi16
21;CHECK: blendvps
22;CHECK: ret
23define <4 x i16> @vsel_4xi16(<4 x i16> %v1, <4 x i16> %v2) {
24  %vsel = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x i16> %v1, <4 x i16> %v2
25  ret <4 x i16> %vsel
26}
27
28
29;CHECK: vsel_i32
30;CHECK: blendvps
31;CHECK: ret
32define <4 x i32> @vsel_i32(<4 x i32> %v1, <4 x i32> %v2) {
33  %vsel = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x i32> %v1, <4 x i32> %v2
34  ret <4 x i32> %vsel
35}
36
37
38;CHECK: vsel_double
39;CHECK: blendvpd
40;CHECK: ret
41define <4 x double> @vsel_double(<4 x double> %v1, <4 x double> %v2) {
42  %vsel = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x double> %v1, <4 x double> %v2
43  ret <4 x double> %vsel
44}
45
46
47;CHECK: vsel_i64
48;CHECK: blendvpd
49;CHECK: ret
50define <4 x i64> @vsel_i64(<4 x i64> %v1, <4 x i64> %v2) {
51  %vsel = select <4 x i1> <i1 true, i1 false, i1 false, i1 false>, <4 x i64> %v1, <4 x i64> %v2
52  ret <4 x i64> %vsel
53}
54
55
56;CHECK: vsel_i8
57;CHECK: pblendvb
58;CHECK: ret
59define <16 x i8> @vsel_i8(<16 x i8> %v1, <16 x i8> %v2) {
60  %vsel = select <16 x i1> <i1 true, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false, i1 true, i1 false, i1 false, i1 false>, <16 x i8> %v1, <16 x i8> %v2
61  ret <16 x i8> %vsel
62}
63
64;; TEST blend + compares
65; CHECK: A
66define <2 x double> @A(<2 x double> %x, <2 x double> %y) {
67  ; CHECK: cmplepd
68  ; CHECK: blendvpd
69  %max_is_x = fcmp oge <2 x double> %x, %y
70  %max = select <2 x i1> %max_is_x, <2 x double> %x, <2 x double> %y
71  ret <2 x double> %max
72}
73
74; CHECK: B
75define <2 x double> @B(<2 x double> %x, <2 x double> %y) {
76  ; CHECK: cmpnlepd
77  ; CHECK: blendvpd
78  %min_is_x = fcmp ult <2 x double> %x, %y
79  %min = select <2 x i1> %min_is_x, <2 x double> %x, <2 x double> %y
80  ret <2 x double> %min
81}
82
83