annotate gcc/testsuite/g++.dg/ext/attribute-test-4.C @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-do run }
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 #define vector __attribute__((vector_size(16)))
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 extern "C" void abort();
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 union U {
kono
parents:
diff changeset
8 float f[4];
kono
parents:
diff changeset
9 vector float v;
kono
parents:
diff changeset
10 } data;
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 class Star
kono
parents:
diff changeset
13 {
kono
parents:
diff changeset
14 public:
kono
parents:
diff changeset
15 static vector float foo();
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 Star()
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 data.f[0] = 1.0; data.f[1] = 2.0; data.f[2] = 3.0, data.f[3] = 4.0;
kono
parents:
diff changeset
20 }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 private:
kono
parents:
diff changeset
23 friend vector float fTest();
kono
parents:
diff changeset
24 };
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 vector float Star::foo()
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 return data.v;
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 vector float fTest()
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 vector float vf = Star::foo();
kono
parents:
diff changeset
34 return vf;
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 int main() {
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 U data;
kono
parents:
diff changeset
40 Star s;
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 data.v = fTest();
kono
parents:
diff changeset
44 for (int i=0 ; i < 4; i++)
kono
parents:
diff changeset
45 if (data.f[i] != (float)(i+1))
kono
parents:
diff changeset
46 abort();
kono
parents:
diff changeset
47 return 0;
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 /* Ignore a warning that is irrelevant to the purpose of this test. */
kono
parents:
diff changeset
51 /* { dg-prune-output ".*GCC vector returned by reference.*" } */
kono
parents:
diff changeset
52 /* { dg-prune-output "changes the ABI" } */