Home | History | Annotate | Download | only in X86
      1 ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=corei7 -mattr=+sse41 | FileCheck %s
      2 
      3 ;CHECK-LABEL: vsel_float:
      4 ;CHECK: blendvps
      5 ;CHECK: ret
      6 define <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-LABEL: vsel_4xi8:
     13 ;CHECK: blendvps
     14 ;CHECK: ret
     15 define <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-LABEL: vsel_4xi16:
     21 ;CHECK: blendvps
     22 ;CHECK: ret
     23 define <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-LABEL: vsel_i32:
     30 ;CHECK: blendvps
     31 ;CHECK: ret
     32 define <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-LABEL: vsel_double:
     39 ;CHECK: blendvpd
     40 ;CHECK: ret
     41 define <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-LABEL: vsel_i64:
     48 ;CHECK: blendvpd
     49 ;CHECK: ret
     50 define <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-LABEL: vsel_i8:
     57 ;CHECK: pblendvb
     58 ;CHECK: ret
     59 define <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
     66 define <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
     75 define <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 ; CHECK: float_crash
     84 define void @float_crash() nounwind {
     85 entry:
     86   %merge205vector_func.i = select <4 x i1> undef, <4 x double> undef, <4 x double> undef
     87   %extract214vector_func.i = extractelement <4 x double> %merge205vector_func.i, i32 0
     88   store double %extract214vector_func.i, double addrspace(1)* undef, align 8
     89   ret void
     90 }
     91