annotate clang/test/CodeGen/attr-target-x86-mmx.c @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: %clang_cc1 -triple i386-linux-gnu -emit-llvm %s -o - | FileCheck %s
anatofuz
parents:
diff changeset
2 // Picking a cpu that doesn't have mmx or sse by default so we can enable it later.
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 #define __MM_MALLOC_H
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 #include <x86intrin.h>
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 // Verify that when we turn on sse that we also turn on mmx.
anatofuz
parents:
diff changeset
9 void __attribute__((target("sse"))) shift(__m64 a, __m64 b, int c) {
anatofuz
parents:
diff changeset
10 _mm_slli_pi16(a, c);
anatofuz
parents:
diff changeset
11 _mm_slli_pi32(a, c);
anatofuz
parents:
diff changeset
12 _mm_slli_si64(a, c);
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 _mm_srli_pi16(a, c);
anatofuz
parents:
diff changeset
15 _mm_srli_pi32(a, c);
anatofuz
parents:
diff changeset
16 _mm_srli_si64(a, c);
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 _mm_srai_pi16(a, c);
anatofuz
parents:
diff changeset
19 _mm_srai_pi32(a, c);
anatofuz
parents:
diff changeset
20 }
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22 // CHECK: "target-features"="+cx8,+mmx,+sse,+x87"