annotate gcc/testsuite/gcc.dg/builtins-6.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 /* Copyright (C) 2003 Free Software Foundation.
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 Verify that constant folding comparisons against built-in math functions
kono
parents:
diff changeset
4 don't cause any problems for the compiler, and produce expected results.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 Written by Roger Sayle, 15th March 2003. */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 /* { dg-do run } */
kono
parents:
diff changeset
9 /* { dg-options "-O2 -ffast-math" } */
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 #include <float.h>
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 extern void abort (void);
kono
parents:
diff changeset
14 extern double sqrt (double);
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 int test1(double x)
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 return sqrt(x) < -9.0;
kono
parents:
diff changeset
19 }
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 int test2(double x)
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 return sqrt(x) > -9.0;
kono
parents:
diff changeset
24 }
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 int test3(double x)
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 return sqrt(x) < 9.0;
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 int test4(double x)
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 return sqrt(x) > 9.0;
kono
parents:
diff changeset
34 }
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 int test5(double x)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 return sqrt(x) < DBL_MAX;
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 int test6(double x)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 return sqrt(x) > DBL_MAX;
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 int main()
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 double x;
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 x = 80.0;
kono
parents:
diff changeset
51 if (test1 (x))
kono
parents:
diff changeset
52 abort ();
kono
parents:
diff changeset
53 if (! test2 (x))
kono
parents:
diff changeset
54 abort ();
kono
parents:
diff changeset
55 if (! test3 (x))
kono
parents:
diff changeset
56 abort ();
kono
parents:
diff changeset
57 if (test4 (x))
kono
parents:
diff changeset
58 abort ();
kono
parents:
diff changeset
59 if (! test5 (x))
kono
parents:
diff changeset
60 abort ();
kono
parents:
diff changeset
61 if (test6 (x))
kono
parents:
diff changeset
62 abort ();
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 x = 100.0;
kono
parents:
diff changeset
65 if (test1 (x))
kono
parents:
diff changeset
66 abort ();
kono
parents:
diff changeset
67 if (! test2 (x))
kono
parents:
diff changeset
68 abort ();
kono
parents:
diff changeset
69 if (test3 (x))
kono
parents:
diff changeset
70 abort ();
kono
parents:
diff changeset
71 if (! test4 (x))
kono
parents:
diff changeset
72 abort ();
kono
parents:
diff changeset
73 if (! test5 (x))
kono
parents:
diff changeset
74 abort ();
kono
parents:
diff changeset
75 if (test6 (x))
kono
parents:
diff changeset
76 abort ();
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 return 0;
kono
parents:
diff changeset
79 }
kono
parents:
diff changeset
80