annotate gcc/testsuite/gcc.dg/builtins-9.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
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 Check that constant folding of built-in math functions doesn't
kono
parents:
diff changeset
4 break anything.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 Written by Roger Sayle, 2nd April 2003. */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 /* { dg-do compile } */
kono
parents:
diff changeset
9 /* { dg-options "-O2 -ffast-math" } */
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 extern double log(double);
kono
parents:
diff changeset
12 extern double exp(double);
kono
parents:
diff changeset
13 extern double sqrt(double);
kono
parents:
diff changeset
14 extern double pow(double,double);
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 extern float logf(float);
kono
parents:
diff changeset
17 extern float expf(float);
kono
parents:
diff changeset
18 extern float sqrtf(float);
kono
parents:
diff changeset
19 extern float powf(float,float);
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 extern long double logl(long double);
kono
parents:
diff changeset
22 extern long double expl(long double);
kono
parents:
diff changeset
23 extern long double sqrtl(long double);
kono
parents:
diff changeset
24 extern long double powl(long double,long double);
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 double test1(double x, double y)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 return log(pow(x,y));
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 double test2(double x, double y)
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 return sqrt(pow(x,y));
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 double test3(double x, double y)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 return pow(exp(x),y);
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 double test4(double x, double y)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 return pow(sqrt(x),y);
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 double test5(double x, double y, double z)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 return pow(pow(x,y),z);
kono
parents:
diff changeset
50 }
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 float test1f(float x, float y)
kono
parents:
diff changeset
54 {
kono
parents:
diff changeset
55 return logf(powf(x,y));
kono
parents:
diff changeset
56 }
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 float test2f(float x, float y)
kono
parents:
diff changeset
59 {
kono
parents:
diff changeset
60 return sqrtf(powf(x,y));
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 float test3f(float x, float y)
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 return powf(expf(x),y);
kono
parents:
diff changeset
66 }
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 float test4f(float x, float y)
kono
parents:
diff changeset
69 {
kono
parents:
diff changeset
70 return powf(sqrtf(x),y);
kono
parents:
diff changeset
71 }
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 float test5f(float x, float y, float z)
kono
parents:
diff changeset
74 {
kono
parents:
diff changeset
75 return powf(powf(x,y),z);
kono
parents:
diff changeset
76 }
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 long double test1l(long double x, long double y)
kono
parents:
diff changeset
80 {
kono
parents:
diff changeset
81 return logl(powl(x,y));
kono
parents:
diff changeset
82 }
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 long double test2l(long double x, long double y)
kono
parents:
diff changeset
85 {
kono
parents:
diff changeset
86 return sqrtl(powl(x,y));
kono
parents:
diff changeset
87 }
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 long double test3l(long double x, long double y)
kono
parents:
diff changeset
90 {
kono
parents:
diff changeset
91 return powl(expl(x),y);
kono
parents:
diff changeset
92 }
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 long double test4l(long double x, long double y)
kono
parents:
diff changeset
95 {
kono
parents:
diff changeset
96 return powl(sqrtl(x),y);
kono
parents:
diff changeset
97 }
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 long double test5l(long double x, long double y, long double z)
kono
parents:
diff changeset
100 {
kono
parents:
diff changeset
101 return powl(powl(x,y),z);
kono
parents:
diff changeset
102 }
kono
parents:
diff changeset
103