annotate gcc/testsuite/gcc.dg/torture/builtin-minmax-1.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) 2006 Free Software Foundation.
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 Verify that built-in math function folding of fmin/fmax is
kono
parents:
diff changeset
4 correctly performed by the compiler.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 Origin: Kaveh R. Ghazi, November 13, 2006. */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 /* { dg-do link } */
kono
parents:
diff changeset
9 /* { dg-options "-fno-math-errno" } */
kono
parents:
diff changeset
10 /* { dg-skip-if "" { *-*-* } { "-O0" } { "" } } */
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 /* All references to link_error should go away at compile-time. */
kono
parents:
diff changeset
13 extern void link_error(int);
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 #define DECLARE(FUNC) \
kono
parents:
diff changeset
16 extern float FUNC##f (float); \
kono
parents:
diff changeset
17 extern double FUNC (double); \
kono
parents:
diff changeset
18 extern long double FUNC##l (long double)
kono
parents:
diff changeset
19 #define DECLARE2(FUNC) \
kono
parents:
diff changeset
20 extern float FUNC##f (float, float); \
kono
parents:
diff changeset
21 extern double FUNC (double, double); \
kono
parents:
diff changeset
22 extern long double FUNC##l (long double, long double)
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 DECLARE2(fmin);
kono
parents:
diff changeset
25 DECLARE2(fmax);
kono
parents:
diff changeset
26 DECLARE(fabs);
kono
parents:
diff changeset
27 extern int pure(int) __attribute__ ((__pure__));
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 /* Test that FUNC(x,x) == x. We cast to (long) so "!=" folds. */
kono
parents:
diff changeset
30 #define TEST_EQ(FUNC) do { \
kono
parents:
diff changeset
31 if ((long)FUNC##f(xf,xf) != (long)xf) \
kono
parents:
diff changeset
32 link_error(__LINE__); \
kono
parents:
diff changeset
33 if ((long)FUNC(x,x) != (long)x) \
kono
parents:
diff changeset
34 link_error(__LINE__); \
kono
parents:
diff changeset
35 if ((long)FUNC##l(xl,xl) != (long)xl) \
kono
parents:
diff changeset
36 link_error(__LINE__); \
kono
parents:
diff changeset
37 } while (0)
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 /* Test that FUNC(purefn,purefn) == purefn. We cast to (long) so "!=" folds. */
kono
parents:
diff changeset
40 #define TEST_EQ_PURE(FUNC) do { \
kono
parents:
diff changeset
41 if ((long)FUNC##f(pure(i),pure(i)) != (long)FUNC##f(pure(i),pure(i))) \
kono
parents:
diff changeset
42 link_error(__LINE__); \
kono
parents:
diff changeset
43 if ((long)FUNC(pure(i),pure(i)) != (long)FUNC(pure(i),pure(i))) \
kono
parents:
diff changeset
44 link_error(__LINE__); \
kono
parents:
diff changeset
45 if ((long)FUNC##l(pure(i),pure(i)) != (long)FUNC##l(pure(i),pure(i))) \
kono
parents:
diff changeset
46 link_error(__LINE__); \
kono
parents:
diff changeset
47 } while (0)
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 /* Test that FIXFUNC(FUNC(int1,int2)) == (TYPE)FUNC(int1,int2),
kono
parents:
diff changeset
50 i.e. FIXFUNC should be folded away and replaced with a cast. */
kono
parents:
diff changeset
51 #define TEST_FIXFUNC(FUNC,FIXFUNC,TYPE) do { \
kono
parents:
diff changeset
52 if (FIXFUNC##f(FUNC##f(i,j)) != (TYPE)FUNC##f(i,j)) \
kono
parents:
diff changeset
53 link_error(__LINE__); \
kono
parents:
diff changeset
54 if (FIXFUNC(FUNC(i,j)) != (TYPE)FUNC(i,j)) \
kono
parents:
diff changeset
55 link_error(__LINE__); \
kono
parents:
diff changeset
56 if (FIXFUNC##l(FUNC##l(i,j)) != (TYPE)FUNC##l(i,j)) \
kono
parents:
diff changeset
57 link_error(__LINE__); \
kono
parents:
diff changeset
58 } while (0)
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 /* Test that FUNC(int1,int2) has an integer return type. */
kono
parents:
diff changeset
61 #define TEST_INT(FUNC) do { \
kono
parents:
diff changeset
62 TEST_FIXFUNC(FUNC,__builtin_lround,long); \
kono
parents:
diff changeset
63 TEST_FIXFUNC(FUNC,__builtin_llround,long long); \
kono
parents:
diff changeset
64 TEST_FIXFUNC(FUNC,__builtin_lrint,long); \
kono
parents:
diff changeset
65 TEST_FIXFUNC(FUNC,__builtin_llrint,long long); \
kono
parents:
diff changeset
66 TEST_FIXFUNC(FUNC,__builtin_lceil,long); \
kono
parents:
diff changeset
67 TEST_FIXFUNC(FUNC,__builtin_llceil,long long); \
kono
parents:
diff changeset
68 TEST_FIXFUNC(FUNC,__builtin_lfloor,long); \
kono
parents:
diff changeset
69 TEST_FIXFUNC(FUNC,__builtin_llfloor,long long); \
kono
parents:
diff changeset
70 } while (0)
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 /* Test that (long)fabs(FUNC(fabs(x),fabs(y))) ==
kono
parents:
diff changeset
73 (long)FUNC(fabs(x),fabs(y)). We cast to (long) so "!=" folds. */
kono
parents:
diff changeset
74 #define TEST_NONNEG(FUNC) do { \
kono
parents:
diff changeset
75 if ((long)fabsf(FUNC##f(fabsf(xf),fabsf(yf))) != (long)FUNC##f(fabsf(xf),fabsf(yf))) \
kono
parents:
diff changeset
76 link_error(__LINE__); \
kono
parents:
diff changeset
77 if ((long)fabs(FUNC(fabs(x),fabs(y))) != (long)FUNC(fabs(x),fabs(y))) \
kono
parents:
diff changeset
78 link_error(__LINE__); \
kono
parents:
diff changeset
79 if ((long)fabsl(FUNC##l(fabsl(xl),fabsl(yl))) != (long)FUNC##l(fabsl(xl),fabsl(yl))) \
kono
parents:
diff changeset
80 link_error(__LINE__); \
kono
parents:
diff changeset
81 } while (0)
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 /* Test that FUNC(NaN,x) == x. We cast to (long) so "!=" folds. Set
kono
parents:
diff changeset
84 parameter SIGNAL to `s' for testing signaling NaN. */
kono
parents:
diff changeset
85 #define TEST_NAN(FUNC,SIGNAL) do { \
kono
parents:
diff changeset
86 if ((long)FUNC##f(__builtin_nan##SIGNAL##f(""),xf) != (long)xf) \
kono
parents:
diff changeset
87 link_error(__LINE__); \
kono
parents:
diff changeset
88 if ((long)FUNC##f(xf,__builtin_nan##SIGNAL##f("")) != (long)xf) \
kono
parents:
diff changeset
89 link_error(__LINE__); \
kono
parents:
diff changeset
90 if ((long)FUNC(__builtin_nan##SIGNAL(""),x) != (long)x) \
kono
parents:
diff changeset
91 link_error(__LINE__); \
kono
parents:
diff changeset
92 if ((long)FUNC(x,__builtin_nan##SIGNAL("")) != (long)x) \
kono
parents:
diff changeset
93 link_error(__LINE__); \
kono
parents:
diff changeset
94 if ((long)FUNC##l(__builtin_nan##SIGNAL##l(""),xl) != (long)xl) \
kono
parents:
diff changeset
95 link_error(__LINE__); \
kono
parents:
diff changeset
96 if ((long)FUNC##l(xl,__builtin_nan##SIGNAL##l("")) != (long)xl) \
kono
parents:
diff changeset
97 link_error(__LINE__); \
kono
parents:
diff changeset
98 } while (0)
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 void __attribute__ ((__noinline__))
kono
parents:
diff changeset
101 foo (float xf, double x, long double xl,
kono
parents:
diff changeset
102 float yf, double y, long double yl,
kono
parents:
diff changeset
103 int i, int j)
kono
parents:
diff changeset
104 {
kono
parents:
diff changeset
105 TEST_EQ(fmin);
kono
parents:
diff changeset
106 TEST_EQ(fmax);
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 #ifdef __OPTIMIZE__
kono
parents:
diff changeset
109 TEST_EQ_PURE(fmin);
kono
parents:
diff changeset
110 TEST_EQ_PURE(fmax);
kono
parents:
diff changeset
111 #endif
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 TEST_INT(fmin);
kono
parents:
diff changeset
114 TEST_INT(fmax);
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 TEST_NONNEG(fmin);
kono
parents:
diff changeset
117 TEST_NONNEG(fmax);
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 TEST_NAN(fmin,);
kono
parents:
diff changeset
120 TEST_NAN(fmax,);
kono
parents:
diff changeset
121 TEST_NAN(fmin,s);
kono
parents:
diff changeset
122 TEST_NAN(fmax,s);
kono
parents:
diff changeset
123 }
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 int main()
kono
parents:
diff changeset
126 {
kono
parents:
diff changeset
127 foo (1,1,1,1,1,1,1,1);
kono
parents:
diff changeset
128 return 0;
kono
parents:
diff changeset
129 }