annotate gcc/testsuite/gcc.dg/builtins-32.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) 2004 Free Software Foundation.
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 Check that constant folding of signbit, signbitf and signbitl math
kono
parents:
diff changeset
4 functions doesn't break anything and produces the expected results.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 Written by Roger Sayle, 28th January 2004. */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 /* { dg-do run } */
kono
parents:
diff changeset
9 /* { dg-options "-O2" } */
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 extern void abort(void);
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 extern int signbit(double);
kono
parents:
diff changeset
14 extern int signbitf(float);
kono
parents:
diff changeset
15 extern int signbitl(long double);
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 int test (double x)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 return signbit(x);
kono
parents:
diff changeset
20 }
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 int testf (float x)
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 return signbitf(x);
kono
parents:
diff changeset
25 }
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 int testl (long double x)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 return signbitl(x);
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 int main()
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 if (test (0.0) != 0)
kono
parents:
diff changeset
36 abort ();
kono
parents:
diff changeset
37 if (test (1.0) != 0)
kono
parents:
diff changeset
38 abort ();
kono
parents:
diff changeset
39 if (test (-2.0) == 0)
kono
parents:
diff changeset
40 abort ();
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 if (testf (0.0f) != 0)
kono
parents:
diff changeset
43 abort ();
kono
parents:
diff changeset
44 if (testf (1.0f) != 0)
kono
parents:
diff changeset
45 abort ();
kono
parents:
diff changeset
46 if (testf (-2.0f) == 0)
kono
parents:
diff changeset
47 abort ();
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 if (testl (0.0l) != 0)
kono
parents:
diff changeset
50 abort ();
kono
parents:
diff changeset
51 if (testl (1.0l) != 0)
kono
parents:
diff changeset
52 abort ();
kono
parents:
diff changeset
53 if (testl (-2.0l) == 0)
kono
parents:
diff changeset
54 abort ();
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 return 0;
kono
parents:
diff changeset
57 }
kono
parents:
diff changeset
58