Home | History | Annotate | Download | only in X86
      1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
      2 ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mattr=+avx512f | FileCheck %s --check-prefix=ALL --check-prefix=KNL
      3 ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mattr=+avx512f,+avx512bw,+avx512vl,+avx512dq | FileCheck %s --check-prefix=ALL --check-prefix=SKX
      4 
      5 define double @test1(double %a, double %b) nounwind {
      6 ; ALL-LABEL: test1:
      7 ; ALL:       ## %bb.0:
      8 ; ALL-NEXT:    vucomisd %xmm1, %xmm0
      9 ; ALL-NEXT:    jne LBB0_1
     10 ; ALL-NEXT:    jnp LBB0_2
     11 ; ALL-NEXT:  LBB0_1: ## %l1
     12 ; ALL-NEXT:    vsubsd %xmm1, %xmm0, %xmm0
     13 ; ALL-NEXT:    retq
     14 ; ALL-NEXT:  LBB0_2: ## %l2
     15 ; ALL-NEXT:    vaddsd %xmm1, %xmm0, %xmm0
     16 ; ALL-NEXT:    retq
     17   %tobool = fcmp une double %a, %b
     18   br i1 %tobool, label %l1, label %l2
     19 
     20 l1:
     21   %c = fsub double %a, %b
     22   ret double %c
     23 l2:
     24   %c1 = fadd double %a, %b
     25   ret double %c1
     26 }
     27 
     28 define float @test2(float %a, float %b) nounwind {
     29 ; ALL-LABEL: test2:
     30 ; ALL:       ## %bb.0:
     31 ; ALL-NEXT:    vucomiss %xmm0, %xmm1
     32 ; ALL-NEXT:    jbe LBB1_2
     33 ; ALL-NEXT:  ## %bb.1: ## %l1
     34 ; ALL-NEXT:    vsubss %xmm1, %xmm0, %xmm0
     35 ; ALL-NEXT:    retq
     36 ; ALL-NEXT:  LBB1_2: ## %l2
     37 ; ALL-NEXT:    vaddss %xmm1, %xmm0, %xmm0
     38 ; ALL-NEXT:    retq
     39   %tobool = fcmp olt float %a, %b
     40   br i1 %tobool, label %l1, label %l2
     41 
     42 l1:
     43   %c = fsub float %a, %b
     44   ret float %c
     45 l2:
     46   %c1 = fadd float %a, %b
     47   ret float %c1
     48 }
     49 
     50 define i32 @test3(float %a, float %b) {
     51 ; ALL-LABEL: test3:
     52 ; ALL:       ## %bb.0:
     53 ; ALL-NEXT:    vcmpeqss %xmm1, %xmm0, %k0
     54 ; ALL-NEXT:    kmovw %k0, %eax
     55 ; ALL-NEXT:    retq
     56 
     57   %cmp10.i = fcmp oeq float %a, %b
     58   %conv11.i = zext i1 %cmp10.i to i32
     59   ret i32 %conv11.i
     60 }
     61 
     62 define float @test5(float %p) #0 {
     63 ; ALL-LABEL: test5:
     64 ; ALL:       ## %bb.0: ## %entry
     65 ; ALL-NEXT:    vxorps %xmm1, %xmm1, %xmm1
     66 ; ALL-NEXT:    vucomiss %xmm1, %xmm0
     67 ; ALL-NEXT:    jne LBB3_1
     68 ; ALL-NEXT:    jp LBB3_1
     69 ; ALL-NEXT:  ## %bb.2: ## %return
     70 ; ALL-NEXT:    retq
     71 ; ALL-NEXT:  LBB3_1: ## %if.end
     72 ; ALL-NEXT:    seta %al
     73 ; ALL-NEXT:    movzbl %al, %eax
     74 ; ALL-NEXT:    leaq {{.*}}(%rip), %rcx
     75 ; ALL-NEXT:    vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero
     76 ; ALL-NEXT:    retq
     77 entry:
     78   %cmp = fcmp oeq float %p, 0.000000e+00
     79   br i1 %cmp, label %return, label %if.end
     80 
     81 if.end:                                           ; preds = %entry
     82   %cmp1 = fcmp ogt float %p, 0.000000e+00
     83   %cond = select i1 %cmp1, float 1.000000e+00, float -1.000000e+00
     84   br label %return
     85 
     86 return:                                           ; preds = %if.end, %entry
     87   %retval.0 = phi float [ %cond, %if.end ], [ %p, %entry ]
     88   ret float %retval.0
     89 }
     90 
     91 define i32 @test6(i32 %a, i32 %b) {
     92 ; ALL-LABEL: test6:
     93 ; ALL:       ## %bb.0:
     94 ; ALL-NEXT:    xorl %eax, %eax
     95 ; ALL-NEXT:    cmpl %esi, %edi
     96 ; ALL-NEXT:    sete %al
     97 ; ALL-NEXT:    retq
     98   %cmp = icmp eq i32 %a, %b
     99   %res = zext i1 %cmp to i32
    100   ret i32 %res
    101 }
    102 
    103 define i32 @test7(double %x, double %y) #2 {
    104 ; ALL-LABEL: test7:
    105 ; ALL:       ## %bb.0: ## %entry
    106 ; ALL-NEXT:    xorl %eax, %eax
    107 ; ALL-NEXT:    vucomisd %xmm1, %xmm0
    108 ; ALL-NEXT:    setne %al
    109 ; ALL-NEXT:    retq
    110 entry:
    111   %0 = fcmp one double %x, %y
    112   %or = zext i1 %0 to i32
    113   ret i32 %or
    114 }
    115 
    116 define i32 @test8(i32 %a1, i32 %a2, i32 %a3) {
    117 ; ALL-LABEL: test8:
    118 ; ALL:       ## %bb.0:
    119 ; ALL-NEXT:    notl %edi
    120 ; ALL-NEXT:    xorl $-2147483648, %esi ## imm = 0x80000000
    121 ; ALL-NEXT:    testl %edx, %edx
    122 ; ALL-NEXT:    movl $1, %eax
    123 ; ALL-NEXT:    cmovel %eax, %edx
    124 ; ALL-NEXT:    orl %edi, %esi
    125 ; ALL-NEXT:    cmovnel %edx, %eax
    126 ; ALL-NEXT:    retq
    127   %tmp1 = icmp eq i32 %a1, -1
    128   %tmp2 = icmp eq i32 %a2, -2147483648
    129   %tmp3 = and i1 %tmp1, %tmp2
    130   %tmp4 = icmp eq i32 %a3, 0
    131   %tmp5 = or i1 %tmp3, %tmp4
    132   %res = select i1 %tmp5, i32 1, i32 %a3
    133   ret i32 %res
    134 }
    135 
    136 define i32 @test9(i64 %a) {
    137 ; ALL-LABEL: test9:
    138 ; ALL:       ## %bb.0:
    139 ; ALL-NEXT:    testb $1, %dil
    140 ; ALL-NEXT:    jne LBB7_2
    141 ; ALL-NEXT:  ## %bb.1: ## %A
    142 ; ALL-NEXT:    movl $6, %eax
    143 ; ALL-NEXT:    retq
    144 ; ALL-NEXT:  LBB7_2: ## %B
    145 ; ALL-NEXT:    movl $7, %eax
    146 ; ALL-NEXT:    retq
    147  %b = and i64 %a, 1
    148  %cmp10.i = icmp eq i64 %b, 0
    149  br i1 %cmp10.i, label %A, label %B
    150 A:
    151  ret i32 6
    152 B:
    153  ret i32 7
    154 }
    155 
    156 define i32 @test10(i64 %b, i64 %c, i1 %d) {
    157 ; ALL-LABEL: test10:
    158 ; ALL:       ## %bb.0:
    159 ; ALL-NEXT:    movl %edx, %eax
    160 ; ALL-NEXT:    andb $1, %al
    161 ; ALL-NEXT:    cmpq %rsi, %rdi
    162 ; ALL-NEXT:    sete %cl
    163 ; ALL-NEXT:    orb %dl, %cl
    164 ; ALL-NEXT:    andb $1, %cl
    165 ; ALL-NEXT:    cmpb %cl, %al
    166 ; ALL-NEXT:    je LBB8_1
    167 ; ALL-NEXT:  ## %bb.2: ## %if.end.i
    168 ; ALL-NEXT:    movl $6, %eax
    169 ; ALL-NEXT:    retq
    170 ; ALL-NEXT:  LBB8_1: ## %if.then.i
    171 ; ALL-NEXT:    movl $5, %eax
    172 ; ALL-NEXT:    retq
    173 
    174   %cmp8.i = icmp eq i64 %b, %c
    175   %or1 = or i1 %d, %cmp8.i
    176   %xor1 = xor i1 %d, %or1
    177   br i1 %xor1, label %if.end.i, label %if.then.i
    178 
    179 if.then.i:
    180  ret i32 5
    181 
    182 if.end.i:
    183   ret i32 6
    184 }
    185