annotate gcc/testsuite/gcc.dg/pr65779.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR debug/65779 */
kono
parents:
diff changeset
2 /* { dg-do assemble } */
kono
parents:
diff changeset
3 /* { dg-options "-O2 -fcompare-debug" } */
kono
parents:
diff changeset
4 /* { dg-xfail-if "" { powerpc-ibm-aix* } } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 unsigned long
kono
parents:
diff changeset
7 foo (unsigned long x, unsigned char *y, unsigned int z)
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 unsigned long a = x & 0xffff;
kono
parents:
diff changeset
10 unsigned long b = (x >> 16) & 0xffff;
kono
parents:
diff changeset
11 int k;
kono
parents:
diff changeset
12 if (y == 0) return 1L;
kono
parents:
diff changeset
13 while (z > 0)
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 k = z < 5552 ? z : 5552;
kono
parents:
diff changeset
16 z -= k;
kono
parents:
diff changeset
17 while (k >= 16)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 a += *y++; b += a;
kono
parents:
diff changeset
20 a += *y++; b += a;
kono
parents:
diff changeset
21 a += *y++; b += a;
kono
parents:
diff changeset
22 a += *y++; b += a;
kono
parents:
diff changeset
23 a += *y++; b += a;
kono
parents:
diff changeset
24 a += *y++; b += a;
kono
parents:
diff changeset
25 a += *y++; b += a;
kono
parents:
diff changeset
26 a += *y++; b += a;
kono
parents:
diff changeset
27 a += *y++; b += a;
kono
parents:
diff changeset
28 a += *y++; b += a;
kono
parents:
diff changeset
29 a += *y++; b += a;
kono
parents:
diff changeset
30 a += *y++; b += a;
kono
parents:
diff changeset
31 a += *y++; b += a;
kono
parents:
diff changeset
32 a += *y++; b += a;
kono
parents:
diff changeset
33 a += *y++; b += a;
kono
parents:
diff changeset
34 a += *y++; b += a;
kono
parents:
diff changeset
35 k -= 16;
kono
parents:
diff changeset
36 }
kono
parents:
diff changeset
37 if (k != 0)
kono
parents:
diff changeset
38 do { a += *y++; b += a; } while (--k);
kono
parents:
diff changeset
39 a %= 65521L;
kono
parents:
diff changeset
40 b %= 65521L;
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 return (b << 16) | a;
kono
parents:
diff changeset
43 }