dwarf2out.c (add_const_value_attribute): If long < HOST_WIDE_INT, fall back to add_AT...
authorRichard Henderson <rth@redhat.com>
Thu, 11 Oct 2001 23:20:54 +0000 (16:20 -0700)
committerRichard Henderson <rth@gcc.gnu.org>
Thu, 11 Oct 2001 23:20:54 +0000 (16:20 -0700)
        * dwarf2out.c (add_const_value_attribute): If long < HOST_WIDE_INT,
        fall back to add_AT_long_long for large CONST_INT.

From-SVN: r46204

gcc/ChangeLog
gcc/dwarf2out.c

index 8992aa830010f0cb166fe62e1c9bf01b60d95552..c9753ca6217cc888d2968b7f95fb4774b6406a72 100644 (file)
@@ -1,3 +1,8 @@
+2001-10-11  Richard Henderson  <rth@redhat.com>
+
+       * dwarf2out.c (add_const_value_attribute): If long < HOST_WIDE_INT,
+       fall back to add_AT_long_long for large CONST_INT.
+
 2001-10-11  Richard Henderson  <rth@redhat.com>
 
        * config/i386/i386.md (setcc splitters): Add four splitters to
index 275e5b41fb2ae4f661f7e98c55508658787cd59a..01613d95a51f605fa34a7ef2f4f7e94639e79436 100644 (file)
@@ -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;