annotate gcc/testsuite/g++.dg/ext/altivec-cell-4.C @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do run { target { powerpc*-*-* && vmx_hw } } } */
kono
parents:
diff changeset
2 /* { dg-do compile { target { powerpc*-*-* && { ! vmx_hw } } } } */
kono
parents:
diff changeset
3 /* { dg-require-effective-target powerpc_altivec_ok } */
kono
parents:
diff changeset
4 /* { dg-options "-maltivec" } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 /* Test the vec_splats and vec_promote VMX intrinsics. */
kono
parents:
diff changeset
7 #include <altivec.h>
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 extern "C" void abort (void);
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 vector int a[] = {{0, 0, 0, 0}, {1,0,0,0}, {1,2,0,0},{1,2,3,0},{1,2,3,4},{5,2,3,4},{5,6,3,4}};
kono
parents:
diff changeset
12 vector int c = {0,6,3,4};
kono
parents:
diff changeset
13 vector int d = {0,0,3,4};
kono
parents:
diff changeset
14 int main1(int t) __attribute__((noinline));
kono
parents:
diff changeset
15 int main1(int t)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 int i;
kono
parents:
diff changeset
18 vector int b = vec_splats(0);
kono
parents:
diff changeset
19 for(i = 0;i<sizeof(a)/sizeof(a[0])-1;i++)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 if (__builtin_memcmp (&b, &a[i], sizeof(vector int)))
kono
parents:
diff changeset
22 abort ();
kono
parents:
diff changeset
23 b = vec_insert(i+1, b, i);
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25 if (__builtin_memcmp (&b, &a[i], sizeof(vector int)))
kono
parents:
diff changeset
26 abort ();
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 b = vec_insert(0, b, 0);
kono
parents:
diff changeset
29 if (__builtin_memcmp (&b, &c, sizeof(vector int)))
kono
parents:
diff changeset
30 abort ();
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 b = vec_insert(0, b, 1);
kono
parents:
diff changeset
33 if (__builtin_memcmp (&b, &d, sizeof(vector int)))
kono
parents:
diff changeset
34 abort ();
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 return 0;
kono
parents:
diff changeset
37 }
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 int main(void)
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 return main1 (0);
kono
parents:
diff changeset
42 }