Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / CodeGen / X86 / mmx-shift-with-immediate.c
blob83be6b5517c010a397de996318e0bc3599f4f4fc
1 // RUN: %clang_cc1 -emit-llvm -triple i386 -target-feature +mmx %s -o - | FileCheck %s
2 #include <mmintrin.h>
4 void shift(__m64 a, __m64 b, int c) {
5 // CHECK: x86_mmx @llvm.x86.mmx.pslli.w(x86_mmx %{{.*}}, i32 {{.*}})
6 _mm_slli_pi16(a, c);
7 // CHECK: x86_mmx @llvm.x86.mmx.pslli.d(x86_mmx %{{.*}}, i32 {{.*}})
8 _mm_slli_pi32(a, c);
9 // CHECK: x86_mmx @llvm.x86.mmx.pslli.q(x86_mmx %{{.*}}, i32 {{.*}})
10 _mm_slli_si64(a, c);
12 // CHECK: x86_mmx @llvm.x86.mmx.psrli.w(x86_mmx %{{.*}}, i32 {{.*}})
13 _mm_srli_pi16(a, c);
14 // CHECK: x86_mmx @llvm.x86.mmx.psrli.d(x86_mmx %{{.*}}, i32 {{.*}})
15 _mm_srli_pi32(a, c);
16 // CHECK: x86_mmx @llvm.x86.mmx.psrli.q(x86_mmx %{{.*}}, i32 {{.*}})
17 _mm_srli_si64(a, c);
19 // CHECK: x86_mmx @llvm.x86.mmx.psrai.w(x86_mmx %{{.*}}, i32 {{.*}})
20 _mm_srai_pi16(a, c);
21 // CHECK: x86_mmx @llvm.x86.mmx.psrai.d(x86_mmx %{{.*}}, i32 {{.*}})
22 _mm_srai_pi32(a, c);