From 6681bc1f1027ace1e040e93dd7499bb6529bd36c Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Sat, 28 Jul 2001 19:46:18 -0700 Subject: [PATCH] varasm.c (immed_real_const_1): Don't elide special cases for nested functions. * varasm.c (immed_real_const_1): Don't elide special cases for nested functions. (clear_const_double_mem): Clear const_tiny_rtx too. From-SVN: r44445 --- gcc/ChangeLog | 6 ++++++ gcc/varasm.c | 21 ++++++++++++++------- 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ef77e9e77ef..c47536af777 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2001-07-28 Richard Henderson + + * varasm.c (immed_real_const_1): Don't elide special cases for + nested functions. + (clear_const_double_mem): Clear const_tiny_rtx too. + 2001-07-28 Richard Henderson * dwarf2out.c (dw_val_class_offset): New. diff --git a/gcc/varasm.c b/gcc/varasm.c index e739784cf17..4b9438e2136 100644 --- a/gcc/varasm.c +++ b/gcc/varasm.c @@ -1917,19 +1917,15 @@ immed_real_const_1 (d, mode) u.d = d; - /* Detect special cases. But be careful we don't use a CONST_DOUBLE - that's from a parent function since it may be in its constant pool. */ - if (REAL_VALUES_IDENTICAL (dconst0, d) - && (cfun == 0 || decl_function_context (current_function_decl) == 0)) + /* Detect special cases. */ + if (REAL_VALUES_IDENTICAL (dconst0, d)) return CONST0_RTX (mode); /* Check for NaN first, because some ports (specifically the i386) do not emit correct ieee-fp code by default, and thus will generate a core dump here if we pass a NaN to REAL_VALUES_EQUAL and if REAL_VALUES_EQUAL does a floating point comparison. */ - else if ((! REAL_VALUE_ISNAN (d) && REAL_VALUES_EQUAL (dconst1, d)) - && (cfun == 0 - || decl_function_context (current_function_decl) == 0)) + else if (! REAL_VALUE_ISNAN (d) && REAL_VALUES_EQUAL (dconst1, d)) return CONST1_RTX (mode); if (sizeof u == sizeof (HOST_WIDE_INT)) @@ -1996,6 +1992,8 @@ void clear_const_double_mem () { register rtx r, next; + enum machine_mode mode; + int i; for (r = const_double_chain; r; r = next) { @@ -2004,6 +2002,15 @@ clear_const_double_mem () CONST_DOUBLE_MEM (r) = cc0_rtx; } const_double_chain = 0; + + for (i = 0; i <= 2; i++) + for (mode = GET_CLASS_NARROWEST_MODE (MODE_FLOAT); mode != VOIDmode; + mode = GET_MODE_WIDER_MODE (mode)) + { + r = const_tiny_rtx[i][(int) mode]; + CONST_DOUBLE_CHAIN (r) = 0; + CONST_DOUBLE_MEM (r) = cc0_rtx; + } } /* Given an expression EXP with a constant value,