annotate gcc/testsuite/gcc.dg/tree-ssa/pr24627.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 /* { dg-do run } */
kono
parents:
diff changeset
2 /* { dg-options "-O" } */
kono
parents:
diff changeset
3 /* { dg-require-effective-target int32plus } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 extern void abort (void);
kono
parents:
diff changeset
6 typedef unsigned int u_int32;
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 typedef struct {
kono
parents:
diff changeset
9 union {u_int32 Xl_ui;} Ul_i;
kono
parents:
diff changeset
10 union {u_int32 Xl_uf;} Ul_f;
kono
parents:
diff changeset
11 } l_fp;
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 void
kono
parents:
diff changeset
14 dolfptoa (short ndec)
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 l_fp work, ftmp;
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 work.Ul_i.Xl_ui = 0;
kono
parents:
diff changeset
19 work.Ul_f.Xl_uf = 0x535f3d8;
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 while (ndec > 0)
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 u_int32 lo_tmp;
kono
parents:
diff changeset
24 u_int32 hi_tmp;
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 ndec--;
kono
parents:
diff changeset
27 work.Ul_i.Xl_ui = 0;
kono
parents:
diff changeset
28 work.Ul_i.Xl_ui <<= 1;
kono
parents:
diff changeset
29 if ((work.Ul_f.Xl_uf) & 0x80000000)
kono
parents:
diff changeset
30 (work.Ul_i.Xl_ui) |= 0x1;
kono
parents:
diff changeset
31 (work.Ul_f.Xl_uf) <<= 1;
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 ftmp = work;
kono
parents:
diff changeset
34 (work.Ul_i.Xl_ui) <<= 1;
kono
parents:
diff changeset
35 if ((work.Ul_f.Xl_uf) & 0x80000000)
kono
parents:
diff changeset
36 (work.Ul_i.Xl_ui) |= 0x1;
kono
parents:
diff changeset
37 (work.Ul_f.Xl_uf) <<= 1;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 (work.Ul_i.Xl_ui) <<= 1;
kono
parents:
diff changeset
40 if ((work.Ul_f.Xl_uf) & 0x80000000)
kono
parents:
diff changeset
41 (work.Ul_i.Xl_ui) |= 0x1;
kono
parents:
diff changeset
42 (work.Ul_f.Xl_uf) <<= 1;
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 lo_tmp = ((work.Ul_f.Xl_uf) & 0xffff) + ((ftmp.Ul_f.Xl_uf) & 0xffff);
kono
parents:
diff changeset
45 hi_tmp = (((work.Ul_f.Xl_uf) >> 16) & 0xffff)
kono
parents:
diff changeset
46 + (((ftmp.Ul_f.Xl_uf) >> 16) & 0xffff);
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 if (lo_tmp & 0x10000)
kono
parents:
diff changeset
49 hi_tmp++;
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 (work.Ul_f.Xl_uf) = ((hi_tmp & 0xffff) << 16) | (lo_tmp & 0xffff);
kono
parents:
diff changeset
52 (work.Ul_i.Xl_ui) += (ftmp.Ul_i.Xl_ui);
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 if (hi_tmp & 0x10000)
kono
parents:
diff changeset
55 (work.Ul_i.Xl_ui)++;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 if (!(work.Ul_i.Xl_ui < 10))
kono
parents:
diff changeset
59 abort ();
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 int main()
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 dolfptoa(6);
kono
parents:
diff changeset
66 return 0;
kono
parents:
diff changeset
67 }