OSDN Git Service

* gcc.dg/torture/builtin-ldexp-1.c: Use -fno-finite-math-only on
[pf3gnuchains/gcc-fork.git] / gcc / testsuite / gcc.dg / torture / builtin-ldexp-1.c
1 /* Copyright (C) 2007  Free Software Foundation.
2
3    Verify that built-in folding of ldexp et al. is correctly performed
4    by the compiler.
5
6    Origin: Kaveh R. Ghazi,  February 17, 2007.  */
7
8 /* { dg-do link } */
9 /* { dg-options "-fno-finite-math-only" { target sh*-*-* } } */
10
11 extern void link_error(int);
12
13 /* Return TRUE if the sign of X != sign of Y.  This is important when
14    comparing signed zeros.  */
15 #define CKSGN_F(X,Y) \
16   (__builtin_copysignf(1.0F,(X)) != __builtin_copysignf(1.0F,(Y)))
17 #define CKSGN(X,Y) \
18   (__builtin_copysign(1.0,(X)) != __builtin_copysign(1.0,(Y)))
19 #define CKSGN_L(X,Y) \
20   (__builtin_copysignl(1.0L,(X)) != __builtin_copysignl(1.0L,(Y)))
21
22 /* Test that FUNC(ARG1,ARG2) == RES.  Check the sign for -0.0.  */
23 #define TESTIT(FUNC,ARG1,ARG2,RES) do { \
24   if (__builtin_##FUNC##f(ARG1##f,ARG2) != RES##f \
25       || CKSGN_F(__builtin_##FUNC##f(ARG1##f,ARG2),RES##f)) \
26     link_error(__LINE__); \
27   if (__builtin_##FUNC(ARG1,ARG2) != RES \
28       || CKSGN(__builtin_##FUNC(ARG1,ARG2),RES)) \
29     link_error(__LINE__); \
30   if (__builtin_##FUNC##l(ARG1##l,ARG2) != RES##l \
31       || CKSGN_L(__builtin_##FUNC##l(ARG1##l,ARG2),RES##l)) \
32     link_error(__LINE__); \
33   } while (0)
34
35 /* Test that (long)FUNC(ARG1,ARG2) == (long)RES.  The cast is
36    necessary when RES is not a constant.  */
37 #define TESTIT2(FUNC,ARG1,ARG2,RES) do { \
38   if ((long)__builtin_##FUNC##f(ARG1##f,ARG2) != (long)RES##f) \
39     link_error(__LINE__); \
40   if ((long)__builtin_##FUNC(ARG1,ARG2) != (long)RES) \
41     link_error(__LINE__); \
42   if ((long)__builtin_##FUNC##l(ARG1##l,ARG2) != (long)RES##l) \
43     link_error(__LINE__); \
44   } while (0)
45
46 /* Test that FUNCRES(FUNC(NEG FUNCARG(ARGARG),ARG2)) is false.  Check
47    the sign as well.  */
48 #define TESTIT3(FUNC,NEG,FUNCARG,ARGARG,ARG2,FUNCRES) do { \
49   if (!__builtin_##FUNCRES##f(__builtin_##FUNC##f(NEG __builtin_##FUNCARG##f(ARGARG),ARG2)) \
50       || CKSGN_F(__builtin_##FUNC##f(NEG __builtin_##FUNCARG##f(ARGARG),ARG2), NEG __builtin_##FUNCARG##f(ARGARG))) \
51     link_error(__LINE__); \
52   if (!__builtin_##FUNCRES(__builtin_##FUNC(NEG __builtin_##FUNCARG(ARGARG),ARG2)) \
53       || CKSGN(__builtin_##FUNC(NEG __builtin_##FUNCARG(ARGARG),ARG2), NEG __builtin_##FUNCARG(ARGARG))) \
54     link_error(__LINE__); \
55   if (!__builtin_##FUNCRES##l(__builtin_##FUNC##l(NEG __builtin_##FUNCARG##l(ARGARG),ARG2)) \
56       || CKSGN_L(__builtin_##FUNC##l(NEG __builtin_##FUNCARG##l(ARGARG),ARG2), NEG __builtin_##FUNCARG##l(ARGARG))) \
57     link_error(__LINE__); \
58   } while (0)
59
60 /* Using foo==MIN/MAX float values, test that FUNC(foo,EXP) == foo*exp2(EXP),
61    and also that FUNC(foo,-EXP) == foo*exp2(-EXP).  */
62 #define TESTIT4(FUNC,EXP) do { \
63   if (__builtin_##FUNC##f(__FLT_MIN__,EXP) != __FLT_MIN__*__builtin_exp2f(EXP)) \
64     link_error(__LINE__); \
65   if (__builtin_##FUNC##f(-__FLT_MIN__,EXP) != -__FLT_MIN__*__builtin_exp2f(EXP)) \
66     link_error(__LINE__); \
67   if (__builtin_##FUNC(__DBL_MIN__,EXP) != __DBL_MIN__*__builtin_exp2(EXP)) \
68     link_error(__LINE__); \
69   if (__builtin_##FUNC(-__DBL_MIN__,EXP) != -__DBL_MIN__*__builtin_exp2(EXP)) \
70     link_error(__LINE__); \
71   if (__builtin_##FUNC##l(__LDBL_MIN__,EXP) != __LDBL_MIN__*__builtin_exp2l(EXP)) \
72     link_error(__LINE__); \
73   if (__builtin_##FUNC##l(-__LDBL_MIN__,EXP) != -__LDBL_MIN__*__builtin_exp2l(EXP)) \
74     link_error(__LINE__); \
75   if (__builtin_##FUNC##f(__FLT_MAX__,-EXP) != __FLT_MAX__*__builtin_exp2f(-EXP)) \
76     link_error(__LINE__); \
77   if (__builtin_##FUNC##f(-__FLT_MAX__,-EXP) != -__FLT_MAX__*__builtin_exp2f(-EXP)) \
78     link_error(__LINE__); \
79   if (__builtin_##FUNC(__DBL_MAX__,-EXP) != __DBL_MAX__*__builtin_exp2(-EXP)) \
80     link_error(__LINE__); \
81   if (__builtin_##FUNC(-__DBL_MAX__,-EXP) != -__DBL_MAX__*__builtin_exp2(-EXP)) \
82     link_error(__LINE__); \
83   if (__builtin_##FUNC##l(__LDBL_MAX__,-EXP) != __LDBL_MAX__*__builtin_exp2l(-EXP)) \
84     link_error(__LINE__); \
85   if (__builtin_##FUNC##l(-__LDBL_MAX__,-EXP) != -__LDBL_MAX__*__builtin_exp2l(-EXP)) \
86     link_error(__LINE__); \
87   } while (0)
88
89 void __attribute__ ((__noinline__))
90 foo(float xf, double x, long double xl, int i, long l)
91 {
92   /* f(0.0, i) -> 0.0 and f(-0.0, i) -> -0.0.  */
93   TESTIT (ldexp, 0.0, i, 0.0);
94   TESTIT (ldexp, -0.0, i, -0.0);
95   TESTIT (scalbn, 0.0, i, 0.0);
96   TESTIT (scalbn, -0.0, i, -0.0);
97   TESTIT (scalbln, 0.0, l, 0.0);
98   TESTIT (scalbln, -0.0, l, -0.0);
99   
100   /* f(x,0) -> x.  */
101   TESTIT2 (ldexp, x, 0, x);
102   TESTIT2 (scalbn, x, 0, x);
103   TESTIT2 (scalbln, x, 0, x);
104
105   /* f(Inf,i) -> Inf and f(NaN,i) -> NaN.  */
106   TESTIT3 (ldexp, , inf, , i, isinf);
107   TESTIT3 (ldexp, -, inf, , i, isinf);
108   TESTIT3 (ldexp, , nan, "", i, isnan);
109   TESTIT3 (ldexp, -, nan, "", i, isnan);
110
111   TESTIT3 (scalbn, , inf, , i, isinf);
112   TESTIT3 (scalbn, -, inf, , i, isinf);
113   TESTIT3 (scalbn, , nan, "", i, isnan);
114   TESTIT3 (scalbn, -, nan, "", i, isnan);
115
116   TESTIT3 (scalbln, , inf, , i, isinf);
117   TESTIT3 (scalbln, -, inf, , i, isinf);
118   TESTIT3 (scalbln, , nan, "", i, isnan);
119   TESTIT3 (scalbln, -, nan, "", i, isnan);
120
121   /* Evaluate when both arguments are constant.  */
122   TESTIT (ldexp, 5.0, 3, 40.0);
123   TESTIT (ldexp, -5.0, 3, -40.0);
124   TESTIT (ldexp, 5.0, -3, 0.625);
125   TESTIT (ldexp, -5.0, -3, -0.625);
126
127   TESTIT (ldexp, 1000.0, 5, 32000.0);
128   TESTIT (ldexp, -1000.0, 5, -32000.0);
129   TESTIT (ldexp, 1000.0, -5, 31.25);
130   TESTIT (ldexp, -1000.0, -5, -31.25);
131
132   /* f(x,N) -> x*exp2(N), using MIN/MAX constants for x and constant N.  */
133   TESTIT4 (ldexp, 1);
134   TESTIT4 (ldexp, 2);
135   TESTIT4 (ldexp, 3);
136   TESTIT4 (ldexp, 5);
137   TESTIT4 (ldexp, 9);
138   TESTIT4 (ldexp, 10);
139   TESTIT4 (ldexp, 12);
140   TESTIT4 (ldexp, 18);
141   TESTIT4 (ldexp, 25);
142   TESTIT4 (ldexp, 50);
143   TESTIT4 (ldexp, 75);
144   TESTIT4 (ldexp, 100);
145   TESTIT4 (ldexp, 123);
146
147   /* These are folded when float radix is two.  */
148 #if __FLT_RADIX__ == 2
149   TESTIT (scalbn, 5.0, 3, 40.0);
150   TESTIT (scalbn, -5.0, 3, -40.0);
151   TESTIT (scalbn, 5.0, -3, 0.625);
152   TESTIT (scalbn, -5.0, -3, -0.625);
153
154   TESTIT (scalbn, 1000.0, 5, 32000.0);
155   TESTIT (scalbn, -1000.0, 5, -32000.0);
156   TESTIT (scalbn, 1000.0, -5, 31.25);
157   TESTIT (scalbn, -1000.0, -5, -31.25);
158
159   TESTIT4 (scalbn, 1);
160   TESTIT4 (scalbn, 2);
161   TESTIT4 (scalbn, 3);
162   TESTIT4 (scalbn, 5);
163   TESTIT4 (scalbn, 9);
164   TESTIT4 (scalbn, 10);
165   TESTIT4 (scalbn, 12);
166   TESTIT4 (scalbn, 18);
167   TESTIT4 (scalbn, 25);
168   TESTIT4 (scalbn, 50);
169   TESTIT4 (scalbn, 75);
170   TESTIT4 (scalbn, 100);
171   TESTIT4 (scalbn, 123);
172
173   TESTIT (scalbln, 5.0, 3, 40.0);
174   TESTIT (scalbln, -5.0, 3, -40.0);
175   TESTIT (scalbln, 5.0, -3, 0.625);
176   TESTIT (scalbln, -5.0, -3, -0.625);
177
178   TESTIT (scalbln, 1000.0, 5, 32000.0);
179   TESTIT (scalbln, -1000.0, 5, -32000.0);
180   TESTIT (scalbln, 1000.0, -5, 31.25);
181   TESTIT (scalbln, -1000.0, -5, -31.25);
182
183   TESTIT4 (scalbln, 1);
184   TESTIT4 (scalbln, 2);
185   TESTIT4 (scalbln, 3);
186   TESTIT4 (scalbln, 5);
187   TESTIT4 (scalbln, 9);
188   TESTIT4 (scalbln, 10);
189   TESTIT4 (scalbln, 12);
190   TESTIT4 (scalbln, 18);
191   TESTIT4 (scalbln, 25);
192   TESTIT4 (scalbln, 50);
193   TESTIT4 (scalbln, 75);
194   TESTIT4 (scalbln, 100);
195   TESTIT4 (scalbln, 123);
196 #endif
197 }
198
199 int main()
200 {
201   foo (0, 0, 0, 0, 0);
202   
203   return 0;
204 }