annotate gcc/testsuite/gcc.dg/pr63914.c @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +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 compile } */
kono
parents:
diff changeset
2 /* { dg-options "-O2 -ffast-math" } */
kono
parents:
diff changeset
3 /* { dg-prune-output "non-standard ABI extension" } */
kono
parents:
diff changeset
4 /* { dg-additional-options "-fno-common" { target hppa*-*-hpux* } } */
kono
parents:
diff changeset
5 /* { dg-additional-options "-msse" { target { i?86-*-* x86_64-*-* } } } */
kono
parents:
diff changeset
6 /* { dg-require-effective-target int32plus } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 typedef float __m128 __attribute__ ((__vector_size__ (16)));
kono
parents:
diff changeset
9 __m128 a, d, e;
kono
parents:
diff changeset
10 int b;
kono
parents:
diff changeset
11 struct dt_interpolation c;
kono
parents:
diff changeset
12 __m128
kono
parents:
diff changeset
13 fn1 (float p1)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 return (__attribute__ ((__vector_size__ (4 * sizeof 0))) float){ p1 };
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17 __m128
kono
parents:
diff changeset
18 fn2 (float p1)
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 return fn1 (p1);
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22 struct dt_interpolation
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 int width;
kono
parents:
diff changeset
25 };
kono
parents:
diff changeset
26 void
kono
parents:
diff changeset
27 fn3 (struct dt_interpolation *p1, int *p2)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 int i = 0, n = 0;
kono
parents:
diff changeset
30 while (i < 2 * p1->width)
kono
parents:
diff changeset
31 n = i++;
kono
parents:
diff changeset
32 *p2 = n;
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34 void
kono
parents:
diff changeset
35 fn4 ()
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 __m128 f;
kono
parents:
diff changeset
38 fn3 (&c, &b);
kono
parents:
diff changeset
39 __m128 g = fn2 (1.f / b);
kono
parents:
diff changeset
40 e = (__m128){};
kono
parents:
diff changeset
41 __m128 h = e;
kono
parents:
diff changeset
42 for (int i = 0; i < 2 * c.width; i++)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 for (; c.width;)
kono
parents:
diff changeset
45 f = a;
kono
parents:
diff changeset
46 h = f;
kono
parents:
diff changeset
47 }
kono
parents:
diff changeset
48 d = h * g;
kono
parents:
diff changeset
49 }