annotate gcc/testsuite/gcc.dg/vect/vect-bswap16.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-require-effective-target vect_bswap } */
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 #include "tree-vect.h"
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #define N 128
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 volatile int y = 0;
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 static inline void
kono
parents:
diff changeset
10 vfoo16 (unsigned short int* a)
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 int i = 0;
kono
parents:
diff changeset
13 for (i = 0; i < N; ++i)
kono
parents:
diff changeset
14 a[i] = __builtin_bswap16 (a[i]);
kono
parents:
diff changeset
15 }
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 int
kono
parents:
diff changeset
18 main (void)
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 unsigned short arr[N];
kono
parents:
diff changeset
21 unsigned short expect[N];
kono
parents:
diff changeset
22 int i;
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 check_vect ();
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 for (i = 0; i < N; ++i)
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 arr[i] = i;
kono
parents:
diff changeset
29 expect[i] = __builtin_bswap16 (i);
kono
parents:
diff changeset
30 if (y) /* Avoid vectorisation. */
kono
parents:
diff changeset
31 abort ();
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 vfoo16 (arr);
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 for (i = 0; i < N; ++i)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 if (arr[i] != expect[i])
kono
parents:
diff changeset
39 abort ();
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 return 0;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */