forked from OSchip/llvm-project
1315 lines
53 KiB
C
1315 lines
53 KiB
C
// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin -target-feature +avx512bw -emit-llvm -o - -Werror | FileCheck %s
|
|
// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin -target-feature +avx512bw -fno-signed-char -emit-llvm -o - -Werror | FileCheck %s
|
|
|
|
// Don't include mm_malloc.h, it's system specific.
|
|
#define __MM_MALLOC_H
|
|
|
|
#include <immintrin.h>
|
|
|
|
__mmask64 test_mm512_cmpeq_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpeq_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpeq.b.512
|
|
return (__mmask64)_mm512_cmpeq_epi8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpeq_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpeq_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpeq.b.512
|
|
return (__mmask64)_mm512_mask_cmpeq_epi8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpeq_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpeq_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpeq.w.512
|
|
return (__mmask32)_mm512_cmpeq_epi16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpeq_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpeq_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpeq.w.512
|
|
return (__mmask32)_mm512_mask_cmpeq_epi16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpgt_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpgt_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpgt.b.512
|
|
return (__mmask64)_mm512_cmpgt_epi8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpgt_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpgt_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpgt.b.512
|
|
return (__mmask64)_mm512_mask_cmpgt_epi8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpgt_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpgt_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpgt.w.512
|
|
return (__mmask32)_mm512_cmpgt_epi16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpgt_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpgt_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.pcmpgt.w.512
|
|
return (__mmask32)_mm512_mask_cmpgt_epi16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpeq_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpeq_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 0, i64 -1)
|
|
return (__mmask64)_mm512_cmpeq_epu8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpeq_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpeq_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 0, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmpeq_epu8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpeq_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpeq_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 0, i32 -1)
|
|
return (__mmask32)_mm512_cmpeq_epu16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpeq_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpeq_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 0, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmpeq_epu16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpgt_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpgt_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 6, i64 -1)
|
|
return (__mmask64)_mm512_cmpgt_epu8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpgt_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpgt_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 6, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmpgt_epu8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpgt_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpgt_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 6, i32 -1)
|
|
return (__mmask32)_mm512_cmpgt_epu16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpgt_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpgt_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 6, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmpgt_epu16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpge_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpge_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 5, i64 -1)
|
|
return (__mmask64)_mm512_cmpge_epi8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpge_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpge_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 5, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmpge_epi8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpge_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpge_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 5, i64 -1)
|
|
return (__mmask64)_mm512_cmpge_epu8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpge_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpge_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 5, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmpge_epu8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpge_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpge_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 5, i32 -1)
|
|
return (__mmask32)_mm512_cmpge_epi16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpge_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpge_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 5, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmpge_epi16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpge_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpge_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 5, i32 -1)
|
|
return (__mmask32)_mm512_cmpge_epu16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpge_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpge_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 5, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmpge_epu16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmple_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmple_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 2, i64 -1)
|
|
return (__mmask64)_mm512_cmple_epi8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmple_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmple_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 2, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmple_epi8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmple_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmple_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 2, i64 -1)
|
|
return (__mmask64)_mm512_cmple_epu8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmple_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmple_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 2, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmple_epu8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmple_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmple_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 2, i32 -1)
|
|
return (__mmask32)_mm512_cmple_epi16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmple_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmple_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 2, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmple_epi16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmple_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmple_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 2, i32 -1)
|
|
return (__mmask32)_mm512_cmple_epu16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmple_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmple_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 2, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmple_epu16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmplt_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmplt_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 1, i64 -1)
|
|
return (__mmask64)_mm512_cmplt_epi8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmplt_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmplt_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 1, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmplt_epi8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmplt_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmplt_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 1, i64 -1)
|
|
return (__mmask64)_mm512_cmplt_epu8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmplt_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmplt_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 1, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmplt_epu8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmplt_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmplt_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 1, i32 -1)
|
|
return (__mmask32)_mm512_cmplt_epi16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmplt_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmplt_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 1, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmplt_epi16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmplt_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmplt_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 1, i32 -1)
|
|
return (__mmask32)_mm512_cmplt_epu16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmplt_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmplt_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 1, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmplt_epu16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpneq_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpneq_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 4, i64 -1)
|
|
return (__mmask64)_mm512_cmpneq_epi8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpneq_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpneq_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 4, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmpneq_epi8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmpneq_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpneq_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 4, i64 -1)
|
|
return (__mmask64)_mm512_cmpneq_epu8_mask(__a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmpneq_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpneq_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 4, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmpneq_epu8_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpneq_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpneq_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 4, i32 -1)
|
|
return (__mmask32)_mm512_cmpneq_epi16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpneq_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpneq_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 4, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmpneq_epi16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmpneq_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmpneq_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 4, i32 -1)
|
|
return (__mmask32)_mm512_cmpneq_epu16_mask(__a, __b);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmpneq_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmpneq_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 4, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmpneq_epu16_mask(__u, __a, __b);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmp_epi8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmp_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 7, i64 -1)
|
|
return (__mmask64)_mm512_cmp_epi8_mask(__a, __b, 7);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmp_epi8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmp_epi8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 7, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmp_epi8_mask(__u, __a, __b, 7);
|
|
}
|
|
|
|
__mmask64 test_mm512_cmp_epu8_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmp_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 7, i64 -1)
|
|
return (__mmask64)_mm512_cmp_epu8_mask(__a, __b, 7);
|
|
}
|
|
|
|
__mmask64 test_mm512_mask_cmp_epu8_mask(__mmask64 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmp_epu8_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.b.512(<64 x i8> {{.*}}, <64 x i8> {{.*}}, i32 7, i64 {{.*}})
|
|
return (__mmask64)_mm512_mask_cmp_epu8_mask(__u, __a, __b, 7);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmp_epi16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmp_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 7, i32 -1)
|
|
return (__mmask32)_mm512_cmp_epi16_mask(__a, __b, 7);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmp_epi16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmp_epi16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.cmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 7, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmp_epi16_mask(__u, __a, __b, 7);
|
|
}
|
|
|
|
__mmask32 test_mm512_cmp_epu16_mask(__m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_cmp_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 7, i32 -1)
|
|
return (__mmask32)_mm512_cmp_epu16_mask(__a, __b, 7);
|
|
}
|
|
|
|
__mmask32 test_mm512_mask_cmp_epu16_mask(__mmask32 __u, __m512i __a, __m512i __b) {
|
|
// CHECK-LABEL: @test_mm512_mask_cmp_epu16_mask
|
|
// CHECK: @llvm.x86.avx512.mask.ucmp.w.512(<32 x i16> {{.*}}, <32 x i16> {{.*}}, i32 7, i32 {{.*}})
|
|
return (__mmask32)_mm512_mask_cmp_epu16_mask(__u, __a, __b, 7);
|
|
}
|
|
|
|
__m512i test_mm512_add_epi8 (__m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_add_epi8
|
|
//CHECK: add <64 x i8>
|
|
return _mm512_add_epi8(__A,__B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_add_epi8 (__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_mask_add_epi8
|
|
//CHECK: @llvm.x86.avx512.mask.padd.b.512
|
|
return _mm512_mask_add_epi8(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_add_epi8 (__mmask64 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_maskz_add_epi8
|
|
//CHECK: @llvm.x86.avx512.mask.padd.b.512
|
|
return _mm512_maskz_add_epi8(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_sub_epi8 (__m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_sub_epi8
|
|
//CHECK: sub <64 x i8>
|
|
return _mm512_sub_epi8(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_sub_epi8 (__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_mask_sub_epi8
|
|
//CHECK: @llvm.x86.avx512.mask.psub.b.512
|
|
return _mm512_mask_sub_epi8(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_sub_epi8 (__mmask64 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_maskz_sub_epi8
|
|
//CHECK: @llvm.x86.avx512.mask.psub.b.512
|
|
return _mm512_maskz_sub_epi8(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_add_epi16 (__m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_add_epi16
|
|
//CHECK: add <32 x i16>
|
|
return _mm512_add_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_add_epi16 (__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_mask_add_epi16
|
|
//CHECK: @llvm.x86.avx512.mask.padd.w.512
|
|
return _mm512_mask_add_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_add_epi16 (__mmask32 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_maskz_add_epi16
|
|
//CHECK: @llvm.x86.avx512.mask.padd.w.512
|
|
return _mm512_maskz_add_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_sub_epi16 (__m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_sub_epi16
|
|
//CHECK: sub <32 x i16>
|
|
return _mm512_sub_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_sub_epi16 (__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_mask_sub_epi16
|
|
//CHECK: @llvm.x86.avx512.mask.psub.w.512
|
|
return _mm512_mask_sub_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_sub_epi16 (__mmask32 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_maskz_sub_epi16
|
|
//CHECK: @llvm.x86.avx512.mask.psub.w.512
|
|
return _mm512_maskz_sub_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mullo_epi16 (__m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_mullo_epi16
|
|
//CHECK: mul <32 x i16>
|
|
return _mm512_mullo_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_mullo_epi16 (__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_mask_mullo_epi16
|
|
//CHECK: @llvm.x86.avx512.mask.pmull.w.512
|
|
return _mm512_mask_mullo_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_mullo_epi16 (__mmask32 __U, __m512i __A, __m512i __B) {
|
|
//CHECK-LABEL: @test_mm512_maskz_mullo_epi16
|
|
//CHECK: @llvm.x86.avx512.mask.pmull.w.512
|
|
return _mm512_maskz_mullo_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_blend_epi8(__mmask64 __U, __m512i __A, __m512i __W) {
|
|
// CHECK-LABEL: @test_mm512_mask_blend_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.blend.b.512
|
|
return _mm512_mask_blend_epi8(__U,__A,__W);
|
|
}
|
|
__m512i test_mm512_mask_blend_epi16(__mmask32 __U, __m512i __A, __m512i __W) {
|
|
// CHECK-LABEL: @test_mm512_mask_blend_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.blend.w.512
|
|
return _mm512_mask_blend_epi16(__U,__A,__W);
|
|
}
|
|
__m512i test_mm512_abs_epi8(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_abs_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pabs.b.512
|
|
return _mm512_abs_epi8(__A);
|
|
}
|
|
__m512i test_mm512_mask_abs_epi8(__m512i __W, __mmask64 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_abs_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pabs.b.512
|
|
return _mm512_mask_abs_epi8(__W,__U,__A);
|
|
}
|
|
__m512i test_mm512_maskz_abs_epi8(__mmask64 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_abs_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pabs.b.512
|
|
return _mm512_maskz_abs_epi8(__U,__A);
|
|
}
|
|
__m512i test_mm512_abs_epi16(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_abs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pabs.w.512
|
|
return _mm512_abs_epi16(__A);
|
|
}
|
|
__m512i test_mm512_mask_abs_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_abs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pabs.w.512
|
|
return _mm512_mask_abs_epi16(__W,__U,__A);
|
|
}
|
|
__m512i test_mm512_maskz_abs_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_abs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pabs.w.512
|
|
return _mm512_maskz_abs_epi16(__U,__A);
|
|
}
|
|
__m512i test_mm512_packs_epi32(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_packs_epi32
|
|
// CHECK: @llvm.x86.avx512.mask.packssdw.512
|
|
return _mm512_packs_epi32(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_packs_epi32(__mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_packs_epi32
|
|
// CHECK: @llvm.x86.avx512.mask.packssdw.512
|
|
return _mm512_maskz_packs_epi32(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_packs_epi32(__m512i __W, __mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_packs_epi32
|
|
// CHECK: @llvm.x86.avx512.mask.packssdw.512
|
|
return _mm512_mask_packs_epi32(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_packs_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_packs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.packsswb.512
|
|
return _mm512_packs_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_packs_epi16(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_packs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.packsswb.512
|
|
return _mm512_mask_packs_epi16(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_packs_epi16(__mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_packs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.packsswb.512
|
|
return _mm512_maskz_packs_epi16(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_packus_epi32(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_packus_epi32
|
|
// CHECK: @llvm.x86.avx512.mask.packusdw.512
|
|
return _mm512_packus_epi32(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_packus_epi32(__mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_packus_epi32
|
|
// CHECK: @llvm.x86.avx512.mask.packusdw.512
|
|
return _mm512_maskz_packus_epi32(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_packus_epi32(__m512i __W, __mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_packus_epi32
|
|
// CHECK: @llvm.x86.avx512.mask.packusdw.512
|
|
return _mm512_mask_packus_epi32(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_packus_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_packus_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.packuswb.512
|
|
return _mm512_packus_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_packus_epi16(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_packus_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.packuswb.512
|
|
return _mm512_mask_packus_epi16(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_packus_epi16(__mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_packus_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.packuswb.512
|
|
return _mm512_maskz_packus_epi16(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_adds_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_adds_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.padds.b.512
|
|
return _mm512_adds_epi8(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_adds_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_adds_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.padds.b.512
|
|
return _mm512_mask_adds_epi8(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_adds_epi8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_adds_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.padds.b.512
|
|
return _mm512_maskz_adds_epi8(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_adds_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_adds_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.padds.w.512
|
|
return _mm512_adds_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_adds_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_adds_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.padds.w.512
|
|
return _mm512_mask_adds_epi16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_adds_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_adds_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.padds.w.512
|
|
return _mm512_maskz_adds_epi16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_adds_epu8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_adds_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.paddus.b.512
|
|
return _mm512_adds_epu8(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_adds_epu8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_adds_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.paddus.b.512
|
|
return _mm512_mask_adds_epu8(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_adds_epu8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_adds_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.paddus.b.512
|
|
return _mm512_maskz_adds_epu8(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_adds_epu16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_adds_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.paddus.w.512
|
|
return _mm512_adds_epu16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_adds_epu16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_adds_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.paddus.w.512
|
|
return _mm512_mask_adds_epu16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_adds_epu16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_adds_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.paddus.w.512
|
|
return _mm512_maskz_adds_epu16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_avg_epu8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_avg_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pavg.b.512
|
|
return _mm512_avg_epu8(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_avg_epu8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_avg_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pavg.b.512
|
|
return _mm512_mask_avg_epu8(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_avg_epu8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_avg_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pavg.b.512
|
|
return _mm512_maskz_avg_epu8(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_avg_epu16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_avg_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pavg.w.512
|
|
return _mm512_avg_epu16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_avg_epu16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_avg_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pavg.w.512
|
|
return _mm512_mask_avg_epu16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_avg_epu16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_avg_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pavg.w.512
|
|
return _mm512_maskz_avg_epu16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_max_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_max_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxs.b.512
|
|
return _mm512_max_epi8(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_max_epi8(__mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_max_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxs.b.512
|
|
return _mm512_maskz_max_epi8(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_max_epi8(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_max_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxs.b.512
|
|
return _mm512_mask_max_epi8(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_max_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_max_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxs.w.512
|
|
return _mm512_max_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_max_epi16(__mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_max_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxs.w.512
|
|
return _mm512_maskz_max_epi16(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_max_epi16(__m512i __W, __mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_max_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxs.w.512
|
|
return _mm512_mask_max_epi16(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_max_epu8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_max_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxu.b.512
|
|
return _mm512_max_epu8(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_max_epu8(__mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_max_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxu.b.512
|
|
return _mm512_maskz_max_epu8(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_max_epu8(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_max_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxu.b.512
|
|
return _mm512_mask_max_epu8(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_max_epu16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_max_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxu.w.512
|
|
return _mm512_max_epu16(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_max_epu16(__mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_max_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxu.w.512
|
|
return _mm512_maskz_max_epu16(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_max_epu16(__m512i __W, __mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_max_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaxu.w.512
|
|
return _mm512_mask_max_epu16(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_min_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_min_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmins.b.512
|
|
return _mm512_min_epi8(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_min_epi8(__mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_min_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmins.b.512
|
|
return _mm512_maskz_min_epi8(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_min_epi8(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_min_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmins.b.512
|
|
return _mm512_mask_min_epi8(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_min_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_min_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmins.w.512
|
|
return _mm512_min_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_min_epi16(__mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_min_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmins.w.512
|
|
return _mm512_maskz_min_epi16(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_min_epi16(__m512i __W, __mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_min_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmins.w.512
|
|
return _mm512_mask_min_epi16(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_min_epu8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_min_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pminu.b.512
|
|
return _mm512_min_epu8(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_min_epu8(__mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_min_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pminu.b.512
|
|
return _mm512_maskz_min_epu8(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_min_epu8(__m512i __W, __mmask64 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_min_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.pminu.b.512
|
|
return _mm512_mask_min_epu8(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_min_epu16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_min_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pminu.w.512
|
|
return _mm512_min_epu16(__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_min_epu16(__mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_min_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pminu.w.512
|
|
return _mm512_maskz_min_epu16(__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_min_epu16(__m512i __W, __mmask32 __M, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_min_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pminu.w.512
|
|
return _mm512_mask_min_epu16(__W,__M,__A,__B);
|
|
}
|
|
__m512i test_mm512_shuffle_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_shuffle_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pshuf.b.512
|
|
return _mm512_shuffle_epi8(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_shuffle_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_shuffle_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pshuf.b.512
|
|
return _mm512_mask_shuffle_epi8(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_shuffle_epi8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_shuffle_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pshuf.b.512
|
|
return _mm512_maskz_shuffle_epi8(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_subs_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_subs_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.psubs.b.512
|
|
return _mm512_subs_epi8(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_subs_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_subs_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.psubs.b.512
|
|
return _mm512_mask_subs_epi8(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_subs_epi8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_subs_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.psubs.b.512
|
|
return _mm512_maskz_subs_epi8(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_subs_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_subs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psubs.w.512
|
|
return _mm512_subs_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_subs_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_subs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psubs.w.512
|
|
return _mm512_mask_subs_epi16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_subs_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_subs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psubs.w.512
|
|
return _mm512_maskz_subs_epi16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_subs_epu8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_subs_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.psubus.b.512
|
|
return _mm512_subs_epu8(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_subs_epu8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_subs_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.psubus.b.512
|
|
return _mm512_mask_subs_epu8(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_subs_epu8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_subs_epu8
|
|
// CHECK: @llvm.x86.avx512.mask.psubus.b.512
|
|
return _mm512_maskz_subs_epu8(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_subs_epu16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_subs_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.psubus.w.512
|
|
return _mm512_subs_epu16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_subs_epu16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_subs_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.psubus.w.512
|
|
return _mm512_mask_subs_epu16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_subs_epu16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_subs_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.psubus.w.512
|
|
return _mm512_maskz_subs_epu16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_mask2_permutex2var_epi16(__m512i __A, __m512i __I, __mmask32 __U, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask2_permutex2var_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.vpermi2var.hi.512
|
|
return _mm512_mask2_permutex2var_epi16(__A,__I,__U,__B);
|
|
}
|
|
__m512i test_mm512_permutex2var_epi16(__m512i __A, __m512i __I, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_permutex2var_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.vpermt2var.hi.512
|
|
return _mm512_permutex2var_epi16(__A,__I,__B);
|
|
}
|
|
__m512i test_mm512_mask_permutex2var_epi16(__m512i __A, __mmask32 __U, __m512i __I, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_permutex2var_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.vpermt2var.hi.512
|
|
return _mm512_mask_permutex2var_epi16(__A,__U,__I,__B);
|
|
}
|
|
__m512i test_mm512_maskz_permutex2var_epi16(__mmask32 __U, __m512i __A, __m512i __I, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_permutex2var_epi16
|
|
// CHECK: @llvm.x86.avx512.maskz.vpermt2var.hi.512
|
|
return _mm512_maskz_permutex2var_epi16(__U,__A,__I,__B);
|
|
}
|
|
|
|
__m512i test_mm512_mulhrs_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mulhrs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmul.hr.sw.512
|
|
return _mm512_mulhrs_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_mulhrs_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_mulhrs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmul.hr.sw.512
|
|
return _mm512_mask_mulhrs_epi16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_mulhrs_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_mulhrs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmul.hr.sw.512
|
|
return _mm512_maskz_mulhrs_epi16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_mulhi_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mulhi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmulh.w.512
|
|
return _mm512_mulhi_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_mulhi_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_mulhi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmulh.w.512
|
|
return _mm512_mask_mulhi_epi16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_mulhi_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_mulhi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmulh.w.512
|
|
return _mm512_maskz_mulhi_epi16(__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_mulhi_epu16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mulhi_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pmulhu.w.512
|
|
return _mm512_mulhi_epu16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_mulhi_epu16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_mulhi_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pmulhu.w.512
|
|
return _mm512_mask_mulhi_epu16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_mulhi_epu16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_mulhi_epu16
|
|
// CHECK: @llvm.x86.avx512.mask.pmulhu.w.512
|
|
return _mm512_maskz_mulhi_epu16(__U,__A,__B);
|
|
}
|
|
|
|
__m512i test_mm512_maddubs_epi16(__m512i __X, __m512i __Y) {
|
|
// CHECK-LABEL: @test_mm512_maddubs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaddubs.w.512
|
|
return _mm512_maddubs_epi16(__X,__Y);
|
|
}
|
|
__m512i test_mm512_mask_maddubs_epi16(__m512i __W, __mmask32 __U, __m512i __X, __m512i __Y) {
|
|
// CHECK-LABEL: @test_mm512_mask_maddubs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaddubs.w.512
|
|
return _mm512_mask_maddubs_epi16(__W,__U,__X,__Y);
|
|
}
|
|
__m512i test_mm512_maskz_maddubs_epi16(__mmask32 __U, __m512i __X, __m512i __Y) {
|
|
// CHECK-LABEL: @test_mm512_maskz_maddubs_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaddubs.w.512
|
|
return _mm512_maskz_maddubs_epi16(__U,__X,__Y);
|
|
}
|
|
__m512i test_mm512_madd_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_madd_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaddw.d.512
|
|
return _mm512_madd_epi16(__A,__B);
|
|
}
|
|
__m512i test_mm512_mask_madd_epi16(__m512i __W, __mmask16 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_madd_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaddw.d.512
|
|
return _mm512_mask_madd_epi16(__W,__U,__A,__B);
|
|
}
|
|
__m512i test_mm512_maskz_madd_epi16(__mmask16 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_madd_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmaddw.d.512
|
|
return _mm512_maskz_madd_epi16(__U,__A,__B);
|
|
}
|
|
|
|
__m256i test_mm512_cvtsepi16_epi8(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_cvtsepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmovs.wb.512
|
|
return _mm512_cvtsepi16_epi8(__A);
|
|
}
|
|
|
|
__m256i test_mm512_mask_cvtsepi16_epi8(__m256i __O, __mmask32 __M, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_cvtsepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmovs.wb.512
|
|
return _mm512_mask_cvtsepi16_epi8(__O, __M, __A);
|
|
}
|
|
|
|
__m256i test_mm512_maskz_cvtsepi16_epi8(__mmask32 __M, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_cvtsepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmovs.wb.512
|
|
return _mm512_maskz_cvtsepi16_epi8(__M, __A);
|
|
}
|
|
|
|
__m256i test_mm512_cvtusepi16_epi8(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_cvtusepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmovus.wb.512
|
|
return _mm512_cvtusepi16_epi8(__A);
|
|
}
|
|
|
|
__m256i test_mm512_mask_cvtusepi16_epi8(__m256i __O, __mmask32 __M, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_cvtusepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmovus.wb.512
|
|
return _mm512_mask_cvtusepi16_epi8(__O, __M, __A);
|
|
}
|
|
|
|
__m256i test_mm512_maskz_cvtusepi16_epi8(__mmask32 __M, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_cvtusepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmovus.wb.512
|
|
return _mm512_maskz_cvtusepi16_epi8(__M, __A);
|
|
}
|
|
|
|
__m256i test_mm512_cvtepi16_epi8(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_cvtepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmov.wb.512
|
|
return _mm512_cvtepi16_epi8(__A);
|
|
}
|
|
|
|
__m256i test_mm512_mask_cvtepi16_epi8(__m256i __O, __mmask32 __M, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_cvtepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmov.wb.512
|
|
return _mm512_mask_cvtepi16_epi8(__O, __M, __A);
|
|
}
|
|
|
|
__m256i test_mm512_maskz_cvtepi16_epi8(__mmask32 __M, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_cvtepi16_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pmov.wb.512
|
|
return _mm512_maskz_cvtepi16_epi8(__M, __A);
|
|
}
|
|
|
|
__m512i test_mm512_unpackhi_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_unpackhi_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.punpckhb.w.512
|
|
return _mm512_unpackhi_epi8(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_unpackhi_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_unpackhi_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.punpckhb.w.512
|
|
return _mm512_mask_unpackhi_epi8(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_unpackhi_epi8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_unpackhi_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.punpckhb.w.512
|
|
return _mm512_maskz_unpackhi_epi8(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_unpackhi_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_unpackhi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.punpckhw.d.512
|
|
return _mm512_unpackhi_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_unpackhi_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_unpackhi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.punpckhw.d.512
|
|
return _mm512_mask_unpackhi_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_unpackhi_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_unpackhi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.punpckhw.d.512
|
|
return _mm512_maskz_unpackhi_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_unpacklo_epi8(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_unpacklo_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.punpcklb.w.512
|
|
return _mm512_unpacklo_epi8(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_unpacklo_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_unpacklo_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.punpcklb.w.512
|
|
return _mm512_mask_unpacklo_epi8(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_unpacklo_epi8(__mmask64 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_unpacklo_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.punpcklb.w.512
|
|
return _mm512_maskz_unpacklo_epi8(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_unpacklo_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_unpacklo_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.punpcklw.d.512
|
|
return _mm512_unpacklo_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_unpacklo_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_unpacklo_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.punpcklw.d.512
|
|
return _mm512_mask_unpacklo_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_unpacklo_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_unpacklo_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.punpcklw.d.512
|
|
return _mm512_maskz_unpacklo_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_cvtepi8_epi16(__m256i __A) {
|
|
// CHECK-LABEL: @test_mm512_cvtepi8_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmovsxb.w.512
|
|
return _mm512_cvtepi8_epi16(__A);
|
|
}
|
|
|
|
__m512i test_mm512_mask_cvtepi8_epi16(__m512i __W, __mmask32 __U, __m256i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_cvtepi8_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmovsxb.w.512
|
|
return _mm512_mask_cvtepi8_epi16(__W, __U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_cvtepi8_epi16(__mmask32 __U, __m256i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_cvtepi8_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmovsxb.w.512
|
|
return _mm512_maskz_cvtepi8_epi16(__U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_cvtepu8_epi16(__m256i __A) {
|
|
// CHECK-LABEL: @test_mm512_cvtepu8_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmovzxb.w.512
|
|
return _mm512_cvtepu8_epi16(__A);
|
|
}
|
|
|
|
__m512i test_mm512_mask_cvtepu8_epi16(__m512i __W, __mmask32 __U, __m256i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_cvtepu8_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmovzxb.w.512
|
|
return _mm512_mask_cvtepu8_epi16(__W, __U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_cvtepu8_epi16(__mmask32 __U, __m256i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_cvtepu8_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pmovzxb.w.512
|
|
return _mm512_maskz_cvtepu8_epi16(__U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_shufflehi_epi16(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_shufflehi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pshufh.w.512
|
|
return _mm512_shufflehi_epi16(__A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_mask_shufflehi_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_shufflehi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pshufh.w.512
|
|
return _mm512_mask_shufflehi_epi16(__W, __U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_shufflehi_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_shufflehi_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pshufh.w.512
|
|
return _mm512_maskz_shufflehi_epi16(__U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_shufflelo_epi16(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_shufflelo_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pshufl.w.512
|
|
return _mm512_shufflelo_epi16(__A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_mask_shufflelo_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_shufflelo_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pshufl.w.512
|
|
return _mm512_mask_shufflelo_epi16(__W, __U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_shufflelo_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_shufflelo_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.pshufl.w.512
|
|
return _mm512_maskz_shufflelo_epi16(__U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_sllv_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_sllv_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psllv
|
|
return _mm512_sllv_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_sllv_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_sllv_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psllv
|
|
return _mm512_mask_sllv_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_sllv_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_sllv_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psllv
|
|
return _mm512_maskz_sllv_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_sll_epi16(__m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_sll_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psll.w.512
|
|
return _mm512_sll_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_sll_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_sll_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psll.w.512
|
|
return _mm512_mask_sll_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_sll_epi16(__mmask32 __U, __m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_sll_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psll.w.512
|
|
return _mm512_maskz_sll_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_slli_epi16(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_slli_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psll.wi.512
|
|
return _mm512_slli_epi16(__A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_mask_slli_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_slli_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psll.wi.512
|
|
return _mm512_mask_slli_epi16(__W, __U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_slli_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_slli_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psll.wi.512
|
|
return _mm512_maskz_slli_epi16(__U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_srlv_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_srlv_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrlv
|
|
return _mm512_srlv_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_srlv_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_srlv_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrlv
|
|
return _mm512_mask_srlv_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_srlv_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_srlv_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrlv
|
|
return _mm512_maskz_srlv_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_srav_epi16(__m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_srav_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrav
|
|
return _mm512_srav_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_srav_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_srav_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrav
|
|
return _mm512_mask_srav_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_srav_epi16(__mmask32 __U, __m512i __A, __m512i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_srav_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrav
|
|
return _mm512_maskz_srav_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_sra_epi16(__m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_sra_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psra.w.512
|
|
return _mm512_sra_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_sra_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_sra_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psra.w.512
|
|
return _mm512_mask_sra_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_sra_epi16(__mmask32 __U, __m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_sra_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psra.w.512
|
|
return _mm512_maskz_sra_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_srai_epi16(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_srai_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psra.wi.512
|
|
return _mm512_srai_epi16(__A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_mask_srai_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_srai_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psra.wi.512
|
|
return _mm512_mask_srai_epi16(__W, __U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_srai_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_srai_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psra.wi.512
|
|
return _mm512_maskz_srai_epi16(__U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_srl_epi16(__m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_srl_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrl.w.512
|
|
return _mm512_srl_epi16(__A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_mask_srl_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_mask_srl_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrl.w.512
|
|
return _mm512_mask_srl_epi16(__W, __U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_srl_epi16(__mmask32 __U, __m512i __A, __m128i __B) {
|
|
// CHECK-LABEL: @test_mm512_maskz_srl_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrl.w.512
|
|
return _mm512_maskz_srl_epi16(__U, __A, __B);
|
|
}
|
|
|
|
__m512i test_mm512_srli_epi16(__m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_srli_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrl.wi.512
|
|
return _mm512_srli_epi16(__A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_mask_srli_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_srli_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrl.wi.512
|
|
return _mm512_mask_srli_epi16(__W, __U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_srli_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_srli_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.psrl.wi.512
|
|
return _mm512_maskz_srli_epi16(__U, __A, 5);
|
|
}
|
|
|
|
__m512i test_mm512_mask_mov_epi16(__m512i __W, __mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_mov_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.movu.w.512
|
|
return _mm512_mask_mov_epi16(__W, __U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_mov_epi16(__mmask32 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_mov_epi16
|
|
// CHECK: @llvm.x86.avx512.mask.movu.w.512
|
|
return _mm512_maskz_mov_epi16(__U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_mask_mov_epi8(__m512i __W, __mmask64 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_mov_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.movu.b.512
|
|
return _mm512_mask_mov_epi8(__W, __U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_mov_epi8(__mmask64 __U, __m512i __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_mov_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.movu.b.512
|
|
return _mm512_maskz_mov_epi8(__U, __A);
|
|
}
|
|
|
|
__m512i test_mm512_mask_set1_epi8(__m512i __O, __mmask64 __M, char __A) {
|
|
// CHECK-LABEL: @test_mm512_mask_set1_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pbroadcast.b.gpr.512
|
|
return _mm512_mask_set1_epi8(__O, __M, __A);
|
|
}
|
|
|
|
__m512i test_mm512_maskz_set1_epi8(__mmask64 __M, char __A) {
|
|
// CHECK-LABEL: @test_mm512_maskz_set1_epi8
|
|
// CHECK: @llvm.x86.avx512.mask.pbroadcast.b.gpr.512
|
|
return _mm512_maskz_set1_epi8(__M, __A);
|
|
}
|
|
|
|
|