From: Toon Moene Date: Thu, 10 May 2001 18:52:28 +0000 (+0200) Subject: dwarf2out.c (mem_loc_descriptor): Do not pass constant pool contents for a SYMBOL_REF... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=79cdfa4b2951048126a0c888721b608a8c986d20;p=gcc.git dwarf2out.c (mem_loc_descriptor): Do not pass constant pool contents for a SYMBOL_REF in case of floating point... 2001-05-10 Toon Moene * dwarf2out.c (mem_loc_descriptor): Do not pass constant pool contents for a SYMBOL_REF in case of floating point constants. From-SVN: r41945 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 11bf8a5ad82..1553e0117cb 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2001-05-10 Toon Moene + + * dwarf2out.c (mem_loc_descriptor): Do not pass constant pool + contents for a SYMBOL_REF in case of floating point constants. + 2001-05-10 DJ Delorie * c-common.c (combine_strings): Widen strings in a diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index b709d07ee07..5952936951c 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -7120,8 +7120,14 @@ mem_loc_descriptor (rtl, mode) /* Alternatively, the symbol in the constant pool can be referenced by a different symbol. */ if (GET_CODE (rtl) == SYMBOL_REF - && CONSTANT_POOL_ADDRESS_P (rtl)) - rtl = get_pool_constant (rtl); + && CONSTANT_POOL_ADDRESS_P (rtl)) + { + rtx tmp = get_pool_constant (rtl); + /* Doesn't work for floating point constants. */ + if (! (GET_CODE (tmp) == CONST_DOUBLE && GET_MODE (tmp) != VOIDmode)) + rtl = tmp; + } + mem_loc_result = new_loc_descr (DW_OP_addr, 0, 0); mem_loc_result->dw_loc_oprnd1.val_class = dw_val_class_addr;