Chris Lattner | d077288 | 2009-10-17 20:37:18 +0000 | [diff] [blame] | 1 | // RUN: clang-cc -triple i386-apple-darwin9 -mcpu=pentium4 -g -emit-llvm %s -o - |
Anders Carlsson | 79b67f3 | 2008-02-01 23:17:55 +0000 | [diff] [blame] | 2 | typedef short __v4hi __attribute__ ((__vector_size__ (8))); |
| 3 | |
Chris Lattner | d077288 | 2009-10-17 20:37:18 +0000 | [diff] [blame] | 4 | void test1() { |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 5 | __v4hi A = (__v4hi)0LL; |
Anders Carlsson | 2cec15f | 2008-02-01 23:27:51 +0000 | [diff] [blame] | 6 | } |
Eli Friedman | cfb313b | 2008-05-30 12:02:14 +0000 | [diff] [blame] | 7 | |
| 8 | __v4hi x = {1,2,3}; |
| 9 | __v4hi y = {1,2,3,4}; |
Eli Friedman | daa24a2 | 2009-03-28 02:45:41 +0000 | [diff] [blame] | 10 | |
Eli Friedman | 3ded200 | 2009-03-28 03:14:28 +0000 | [diff] [blame] | 11 | typedef int vty __attribute((vector_size(16))); |
Chris Lattner | d077288 | 2009-10-17 20:37:18 +0000 | [diff] [blame] | 12 | int test2() { vty b; return b[2LL]; } |
Eli Friedman | 61d004a | 2009-06-06 19:09:26 +0000 | [diff] [blame] | 13 | |
| 14 | // PR4339 |
| 15 | typedef float vec4 __attribute__((vector_size(16))); |
| 16 | |
Chris Lattner | d077288 | 2009-10-17 20:37:18 +0000 | [diff] [blame] | 17 | void test3 ( vec4* a, char b, float c ) { |
Mike Stump | 1eb4433 | 2009-09-09 15:08:12 +0000 | [diff] [blame] | 18 | (*a)[b] = c; |
Eli Friedman | 61d004a | 2009-06-06 19:09:26 +0000 | [diff] [blame] | 19 | } |
Chris Lattner | d077288 | 2009-10-17 20:37:18 +0000 | [diff] [blame] | 20 | |
| 21 | |
| 22 | |
| 23 | |
| 24 | #include <mmintrin.h> |
| 25 | |
| 26 | int 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 | } |