annotate gcc/testsuite/gcc.dg/builtins-36.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 sin, sinf, sinl, cos, cosf and cosl built-in functions
kono
parents:
diff changeset
4 eventually compile to sincos, sincosf and sincosl.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 Written by Uros Bizjak, 5th April 2004. */
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 sin(double);
kono
parents:
diff changeset
12 extern float sinf(float);
kono
parents:
diff changeset
13 extern long double sinl(long double);
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 extern double cos(double);
kono
parents:
diff changeset
16 extern float cosf(float);
kono
parents:
diff changeset
17 extern long double cosl(long double);
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 double test1(double x)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 double y1, y2;
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 y1 = sin(x);
kono
parents:
diff changeset
25 y2 = cos(x);
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 return y1 - y2;
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 float test1f(float x)
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 float y1, y2;
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 y1 = sinf(x);
kono
parents:
diff changeset
35 y2 = cosf(x);
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 return y1 - y2;
kono
parents:
diff changeset
38 }
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 long double test1l(long double x)
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 long double y1, y2;
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 y1 = sinl(x);
kono
parents:
diff changeset
45 y2 = cosl(x);
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 return y1 - y2;
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 double test2(double x)
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 return sin(x);
kono
parents:
diff changeset
53 }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 float test2f(float x)
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 return sinf(x);
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 long double test2l(long double x)
kono
parents:
diff changeset
61 {
kono
parents:
diff changeset
62 return sinl(x);
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 double test3(double x)
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 return cos(x);
kono
parents:
diff changeset
68 }
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 float test3f(float x)
kono
parents:
diff changeset
71 {
kono
parents:
diff changeset
72 return cosf(x);
kono
parents:
diff changeset
73 }
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 long double test3l(long double x)
kono
parents:
diff changeset
76 {
kono
parents:
diff changeset
77 return cosl(x);
kono
parents:
diff changeset
78 }
kono
parents:
diff changeset
79