1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mattr=+avx512f | FileCheck %s --check-prefix=CHECK --check-prefix=KNL
3 ; RUN: llc < %s -mattr=+avx512f,+avx512vl,+avx512bw,+avx512dq | FileCheck %s --check-prefix=CHECK --check-prefix=SKX
5 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
6 target triple = "x86_64-unknown-linux-gnu"
8 ; Note that the kmovs should really *not* appear in the output, this is an
9 ; artifact of the current poor lowering. This is tracked by PR28175.
11 define i64 @foo64(i1 zeroext %i) #0 {
14 ; CHECK-NEXT: # kill: %EDI<def> %EDI<kill> %RDI<def>
15 ; CHECK-NEXT: orq $-2, %rdi
16 ; CHECK-NEXT: movq %rdi, %rax
21 %z = zext i1 %i to i64
29 define i16 @foo16(i1 zeroext %i) #0 {
32 ; CHECK-NEXT: orl $65534, %edi # imm = 0xFFFE
33 ; CHECK-NEXT: movl %edi, %eax
38 %z = zext i1 %i to i16
46 ; This code is still not optimal
47 define i16 @foo16_1(i1 zeroext %i, i32 %j) #0 {
50 ; KNL-NEXT: kmovw %edi, %k0
51 ; KNL-NEXT: kmovw %k0, %eax
52 ; KNL-NEXT: andl $1, %eax
53 ; KNL-NEXT: orl $2, %eax
54 ; KNL-NEXT: # kill: %AX<def> %AX<kill> %EAX<kill>
59 ; SKX-NEXT: kmovd %edi, %k0
60 ; SKX-NEXT: kmovw %k0, %eax
61 ; SKX-NEXT: andl $1, %eax
62 ; SKX-NEXT: orl $2, %eax
63 ; SKX-NEXT: # kill: %AX<def> %AX<kill> %EAX<kill>
68 %z = zext i1 %i to i16
76 define i32 @foo32(i1 zeroext %i) #0 {
79 ; CHECK-NEXT: orl $-2, %edi
80 ; CHECK-NEXT: movl %edi, %eax
85 %z = zext i1 %i to i32
93 define i8 @foo8(i1 zeroext %i) #0 {
96 ; CHECK-NEXT: orb $-2, %dil
97 ; CHECK-NEXT: movl %edi, %eax
102 %z = zext i1 %i to i8