+2004-09-10 Richard Sandiford <rsandifo@redhat.com>
+
+ * tree-tailcall.c (process_assignment): Only do accumulator transforms
+ for floating-point types if flag_unsafe_math_optimizations.
+
2004-09-10 Kazu Hirata <kazu@cs.umass.edu>
* config/darwin.c, config/alpha/alpha.h, config/arm/arm.c,
+2004-09-10 Richard Sandiford <rsandifo@redhat.com>
+
+ * gcc.c-torture/execute/ieee/acc1.c: New test.
+ * gcc.c-torture/execute/ieee/acc2.c: New test.
+ * gcc.c-torture/execute/ieee/mzero6.c: New test.
+
2004-09-10 Joseph S. Myers <jsm@polyomino.org.uk>
* gcc.dg/deprecated-2.c: New test.
--- /dev/null
+/* Tail call optimizations would reverse the order of additions in func(). */
+
+double func (const double *array)
+{
+ double d = *array;
+ if (d == 0.0)
+ return d;
+ else
+ return d + func (array + 1);
+}
+
+int main ()
+{
+ double values[] = { 0.1e-100, 1.0, -1.0, 0.0 };
+ if (func (values) != 0.1e-100)
+ abort ();
+ exit (0);
+}
--- /dev/null
+/* Tail call optimizations would reverse the order of multiplications
+ in func(). */
+
+double func (const double *array)
+{
+ double d = *array;
+ if (d == 1.0)
+ return d;
+ else
+ return d * func (array + 1);
+}
+
+int main ()
+{
+ double values[] = { __DBL_MAX__, 2.0, 0.5, 1.0 };
+ if (func (values) != __DBL_MAX__)
+ abort ();
+ exit (0);
+}
--- /dev/null
+/* Tail call optimizations would convert func() into the moral equivalent of:
+
+ double acc = 0.0;
+ for (int i = 0; i <= n; i++)
+ acc += d;
+ return acc;
+
+ which mishandles the case where 'd' is -0. They also initialised 'acc'
+ to a zero int rather than a zero double. */
+
+double func (double d, int n)
+{
+ if (n == 0)
+ return d;
+ else
+ return d + func (d, n - 1);
+}
+
+int main ()
+{
+ if (__builtin_copysign (1.0, func (0.0 / -5.0, 10)) != -1.0)
+ abort ();
+ exit (0);
+}
if (TREE_CODE_CLASS (code) != '2')
return false;
+ /* Accumulator optimizations will reverse the order of operations.
+ We can only do that for floating-point types if we're assuming
+ that addition and multiplication are associative. */
+ if (!flag_unsafe_math_optimizations)
+ if (FLOAT_TYPE_P (TREE_TYPE (DECL_RESULT (current_function_decl))))
+ return false;
+
/* We only handle the code like
x = call ();