blob: bfce0e4e05c06c8209f664be47a214c07f6c1999 [file] [log] [blame]
Chris Lattnerd6b84b92010-08-20 16:08:33 +00001// RUN: %clang_cc1 -triple i386-apple-darwin9 -O1 -target-cpu pentium4 -target-feature +sse4.1 -g -emit-llvm %s -o - | FileCheck %s
Anders Carlsson79b67f32008-02-01 23:17:55 +00002typedef short __v4hi __attribute__ ((__vector_size__ (8)));
3
Chris Lattnerd0772882009-10-17 20:37:18 +00004void test1() {
Mike Stump1eb44332009-09-09 15:08:12 +00005 __v4hi A = (__v4hi)0LL;
Anders Carlsson2cec15f2008-02-01 23:27:51 +00006}
Eli Friedmancfb313b2008-05-30 12:02:14 +00007
8__v4hi x = {1,2,3};
9__v4hi y = {1,2,3,4};
Eli Friedmandaa24a22009-03-28 02:45:41 +000010
Eli Friedman3ded2002009-03-28 03:14:28 +000011typedef int vty __attribute((vector_size(16)));
Chris Lattnerd0772882009-10-17 20:37:18 +000012int test2() { vty b; return b[2LL]; }
Eli Friedman61d004a2009-06-06 19:09:26 +000013
14// PR4339
15typedef float vec4 __attribute__((vector_size(16)));
16
Chris Lattnerd0772882009-10-17 20:37:18 +000017void test3 ( vec4* a, char b, float c ) {
Mike Stump1eb44332009-09-09 15:08:12 +000018 (*a)[b] = c;
Eli Friedman61d004a2009-06-06 19:09:26 +000019}
Chris Lattnerd0772882009-10-17 20:37:18 +000020
21
22
23
24#include <mmintrin.h>
25
26int test4(int argc, char *argv[]) {
27 int array[16] = { 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15 };
28 __m64 *p = (__m64 *)array;
29
30 __m64 accum = _mm_setzero_si64();
31
32 for (int i=0; i<8; ++i)
33 accum = _mm_add_pi32(p[i], accum);
34
35 __m64 accum2 = _mm_unpackhi_pi32(accum, accum);
36 accum = _mm_add_pi32(accum, accum2);
37
38 int result = _mm_cvtsi64_si32(accum);
39 _mm_empty();
40
41 return result;
42}
Chris Lattnerd6b84b92010-08-20 16:08:33 +000043
44#include <smmintrin.h>
45
46unsigned long test_epi8(__m128i x) { return _mm_extract_epi8(x, 4); }
47// CHECK: @test_epi8
48// CHECK: extractelement <16 x i8> {{.*}}, i32 4
49// CHECK: zext i8 {{.*}} to i32
50
51unsigned long test_epi16(__m128i x) { return _mm_extract_epi16(x, 3); }
52
53// CHECK: @test_epi16
54// CHECK: extractelement <8 x i16> {{.*}}, i32 3
55// CHECK: zext i16 {{.*}} to i32