[x86] weaken test checks that shouldn't be here in the first place

This test would fail after the proposed change in:
https://reviews.llvm.org/D34242

llvm-svn: 306433
This commit is contained in:
Sanjay Patel 2017-06-27 17:39:46 +00:00
parent 967669f6c1
commit d53f6a8980
1 changed files with 15 additions and 12 deletions

View File

@ -1,4 +1,7 @@
// RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-apple-darwin -target-feature +avx512f -emit-llvm -o - -Wall -Werror | FileCheck %s // RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-apple-darwin -target-feature +avx512f -emit-llvm -o - -Wall -Werror | FileCheck %s
// FIXME: It's wrong to check LLVM IR transformations from clang. This run should be removed and tests added to the appropriate LLVM pass.
// RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-apple-darwin -target-feature +avx512f -O2 -emit-llvm -o - -Wall -Werror | FileCheck %s -check-prefix=O2 // RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-apple-darwin -target-feature +avx512f -O2 -emit-llvm -o - -Wall -Werror | FileCheck %s -check-prefix=O2
#include <immintrin.h> #include <immintrin.h>
@ -8240,10 +8243,10 @@ __m128 test_mm_mask_move_ss (__m128 __W, __mmask8 __U, __m128 __A, __m128 __B)
{ {
// O2-LABEL: @test_mm_mask_move_ss // O2-LABEL: @test_mm_mask_move_ss
// O2: %[[M:.*]] = and i8 %__U, 1 // O2: %[[M:.*]] = and i8 %__U, 1
// O2: %[[M2:.*]] = icmp ne i8 %[[M]], 0 // O2: %[[M2:.*]] = icmp
// O2: %[[ELM1:.*]] = extractelement <4 x float> %__B, i32 0 // O2: %[[ELM1:.*]] = extractelement <4 x float>
// O2: %[[ELM2:.*]] = extractelement <4 x float> %__W, i32 0 // O2: %[[ELM2:.*]] = extractelement <4 x float>
// O2: %[[SEL:.*]] = select i1 %[[M2]], float %[[ELM1]], float %[[ELM2]] // O2: %[[SEL:.*]] = select i1 %[[M2]]
// O2: %[[RES:.*]] = insertelement <4 x float> %__A, float %[[SEL]], i32 0 // O2: %[[RES:.*]] = insertelement <4 x float> %__A, float %[[SEL]], i32 0
// O2: ret <4 x float> %[[RES]] // O2: ret <4 x float> %[[RES]]
return _mm_mask_move_ss ( __W, __U, __A, __B); return _mm_mask_move_ss ( __W, __U, __A, __B);
@ -8253,9 +8256,9 @@ __m128 test_mm_maskz_move_ss (__mmask8 __U, __m128 __A, __m128 __B)
{ {
// O2-LABEL: @test_mm_maskz_move_ss // O2-LABEL: @test_mm_maskz_move_ss
// O2: %[[M:.*]] = and i8 %__U, 1 // O2: %[[M:.*]] = and i8 %__U, 1
// O2: %[[M2:.*]] = icmp ne i8 %[[M]], 0 // O2: %[[M2:.*]] = icmp
// O2: %[[ELM1:.*]] = extractelement <4 x float> %__B, i32 0 // O2: %[[ELM1:.*]] = extractelement <4 x float> %__B, i32 0
// O2: %[[SEL:.*]] = select i1 %[[M2]], float %[[ELM1]], float 0.0 // O2: %[[SEL:.*]] = select i1 %[[M2]]
// O2: %[[RES:.*]] = insertelement <4 x float> %__A, float %[[SEL]], i32 0 // O2: %[[RES:.*]] = insertelement <4 x float> %__A, float %[[SEL]], i32 0
// O2: ret <4 x float> %[[RES]] // O2: ret <4 x float> %[[RES]]
return _mm_maskz_move_ss (__U, __A, __B); return _mm_maskz_move_ss (__U, __A, __B);
@ -8265,10 +8268,10 @@ __m128d test_mm_mask_move_sd (__m128d __W, __mmask8 __U, __m128d __A, __m128d __
{ {
// O2-LABEL: @test_mm_mask_move_sd // O2-LABEL: @test_mm_mask_move_sd
// O2: %[[M:.*]] = and i8 %__U, 1 // O2: %[[M:.*]] = and i8 %__U, 1
// O2: %[[M2:.*]] = icmp ne i8 %[[M]], 0 // O2: %[[M2:.*]] = icmp
// O2: %[[ELM1:.*]] = extractelement <2 x double> %__B, i32 0 // O2: %[[ELM1:.*]] = extractelement <2 x double>
// O2: %[[ELM2:.*]] = extractelement <2 x double> %__W, i32 0 // O2: %[[ELM2:.*]] = extractelement <2 x double>
// O2: %[[SEL:.*]] = select i1 %[[M2]], double %[[ELM1]], double %[[ELM2]] // O2: %[[SEL:.*]] = select i1 %[[M2]]
// O2: %[[RES:.*]] = insertelement <2 x double> %__A, double %[[SEL]], i32 0 // O2: %[[RES:.*]] = insertelement <2 x double> %__A, double %[[SEL]], i32 0
// O2: ret <2 x double> %[[RES]] // O2: ret <2 x double> %[[RES]]
return _mm_mask_move_sd ( __W, __U, __A, __B); return _mm_mask_move_sd ( __W, __U, __A, __B);
@ -8278,9 +8281,9 @@ __m128d test_mm_maskz_move_sd (__mmask8 __U, __m128d __A, __m128d __B)
{ {
// O2-LABEL: @test_mm_maskz_move_sd // O2-LABEL: @test_mm_maskz_move_sd
// O2: %[[M:.*]] = and i8 %__U, 1 // O2: %[[M:.*]] = and i8 %__U, 1
// O2: %[[M2:.*]] = icmp ne i8 %[[M]], 0 // O2: %[[M2:.*]] = icmp
// O2: %[[ELM1:.*]] = extractelement <2 x double> %__B, i32 0 // O2: %[[ELM1:.*]] = extractelement <2 x double> %__B, i32 0
// O2: %[[SEL:.*]] = select i1 %[[M2]], double %[[ELM1]], double 0.0 // O2: %[[SEL:.*]] = select i1 %[[M2]]
// O2: %[[RES:.*]] = insertelement <2 x double> %__A, double %[[SEL]], i32 0 // O2: %[[RES:.*]] = insertelement <2 x double> %__A, double %[[SEL]], i32 0
// O2: ret <2 x double> %[[RES]] // O2: ret <2 x double> %[[RES]]
return _mm_maskz_move_sd (__U, __A, __B); return _mm_maskz_move_sd (__U, __A, __B);