Home | History | Annotate | Download | only in X86
      1 ; RUN: llc < %s -mtriple x86_64-unknown-linux-gnu -mattr +avx512f | FileCheck %s
      2 
      3 define <16 x float> @testzmm_1(<16 x float> %_zmm0, <16 x float> %_zmm1) {
      4 entry:
      5 ; CHECK: vpternlogd  $0, %zmm1, %zmm0, %zmm0
      6   %0 = tail call <16 x float> asm "vpternlogd $$0, $1, $2, $0", "=v,v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1, <16 x float> %_zmm0)
      7   ret <16 x float> %0
      8 }
      9 
     10 define <16 x float> @testzmm_2(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     11 entry:
     12 ; CHECK: vpabsq  %zmm1, %zmm0
     13   %0 = tail call <16 x float> asm "vpabsq $1, $0", "=v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1)
     14   ret <16 x float> %0
     15 }
     16 
     17 
     18 define <16 x float> @testzmm_3(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     19 entry:
     20 ; CHECK: vpaddd  %zmm1, %zmm1, %zmm0
     21   %0 = tail call <16 x float> asm "vpaddd $1, $2, $0", "=v,v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1, <16 x float> %_zmm1)
     22   ret <16 x float> %0
     23 }
     24 
     25 
     26 define <16 x float> @testzmm_4(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     27 entry:
     28 ; CHECK: vpaddq  %zmm1, %zmm1, %zmm0
     29   %0 = tail call <16 x float> asm "vpaddq $1, $2, $0", "=v,v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1, <16 x float> %_zmm1)
     30   ret <16 x float> %0
     31 }
     32 
     33 
     34 define <16 x float> @testzmm_5(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     35 entry:
     36 ; CHECK: vpandd  %zmm1, %zmm1, %zmm0
     37   %0 = tail call <16 x float> asm "vpandd $1, $2, $0", "=v,v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1, <16 x float> %_zmm1)
     38   ret <16 x float> %0
     39 }
     40 
     41 
     42 define <16 x float> @testzmm_6(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     43 entry:
     44 ; CHECK: vpandnd %zmm1, %zmm1, %zmm0
     45   %0 = tail call <16 x float> asm "vpandnd $1, $2, $0", "=v,v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1, <16 x float> %_zmm1)
     46   ret <16 x float> %0
     47 }
     48 
     49 
     50 define <16 x float> @testzmm_7(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     51 entry:
     52 ; CHECK: vpmaxsd %zmm1, %zmm1, %zmm0
     53   %0 = tail call <16 x float> asm "vpmaxsd $1, $2, $0", "=v,v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1, <16 x float> %_zmm1)
     54   ret <16 x float> %0
     55 }
     56 
     57 
     58 define <16 x float> @testzmm_8(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     59 entry:
     60 ; CHECK: vmovups %zmm1, %zmm0
     61   %0 = tail call <16 x float> asm "vmovups $1, $0", "=v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1)
     62   ret <16 x float> %0
     63 }
     64 
     65 
     66 define <16 x float> @testzmm_9(<16 x float> %_zmm0, <16 x float> %_zmm1) {
     67 entry:
     68 ; CHECK: vmovupd %zmm1, %zmm0
     69   %0 = tail call <16 x float> asm "vmovupd $1, $0", "=v,v,~{dirflag},~{fpsr},~{flags}"(<16 x float> %_zmm1)
     70   ret <16 x float> %0
     71 }
     72 
     73