diff options
author | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-10-11 23:20:54 +0000 |
---|---|---|
committer | rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-10-11 23:20:54 +0000 |
commit | 77c5871b9096e6764b3b3ce3a634540ee88e3b34 (patch) | |
tree | 1d0663f0c60645a502fa1d6edf9b4a6492213598 /gcc/dwarf2out.c | |
parent | 14b58f61f593532f37ecb5274d7fad7989ae12aa (diff) | |
download | gcc-77c5871b9096e6764b3b3ce3a634540ee88e3b34.tar.gz |
* dwarf2out.c (add_const_value_attribute): If long < HOST_WIDE_INT,
fall back to add_AT_long_long for large CONST_INT.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@46204 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/dwarf2out.c')
-rw-r--r-- | gcc/dwarf2out.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index 275e5b41fb2..01613d95a51 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -8329,18 +8329,19 @@ add_const_value_attribute (die, rtl) HOST_WIDE_INT val = INTVAL (rtl); /* ??? We really should be using HOST_WIDE_INT throughout. */ - if (val < 0) + if (val < 0 && (long) val == val) { if ((long) val != val) abort (); add_AT_int (die, DW_AT_const_value, (long) val); } + else if ((unsigned long) val == (unsigned HOST_WIDE_INT) val) + add_AT_unsigned (die, DW_AT_const_value, (unsigned long) val); + else if (2*HOST_BITS_PER_LONG == HOST_BITS_PER_WIDE_INT) + add_AT_long_long (die, DW_AT_const_value, + val >> HOST_BITS_PER_LONG, val); else - { - if ((unsigned long) val != (unsigned HOST_WIDE_INT) val) - abort (); - add_AT_unsigned (die, DW_AT_const_value, (unsigned long) val); - } + abort (); } break; |