]> git.ipfire.org Git - thirdparty/valgrind.git/commitdiff
Merge from trunk, r11450 (support for DW_ATE_UTF from DWARF4)
authorJulian Seward <jseward@acm.org>
Wed, 20 Oct 2010 21:11:20 +0000 (21:11 +0000)
committerJulian Seward <jseward@acm.org>
Wed, 20 Oct 2010 21:11:20 +0000 (21:11 +0000)
git-svn-id: svn://svn.valgrind.org/valgrind/branches/VALGRIND_3_6_BRANCH@11464

coregrind/m_debuginfo/priv_d3basics.h
coregrind/m_debuginfo/readdwarf3.c

index 75fcb46a46852918bfb40ec4ac3ad9e0242a30ae..b6703e9b31644a6cb760ef907f489b14710df370 100644 (file)
@@ -372,6 +372,8 @@ typedef enum
     DW_ATE_signed_fixed = 0xd,
     DW_ATE_unsigned_fixed = 0xe,
     DW_ATE_decimal_float = 0xf,
+    /* DWARF 4.  */
+    DW_ATE_UTF = 0x10,
     /* HP extensions.  */
     DW_ATE_HP_float80            = 0x80, /* Floating-point (80 bit).  */
     DW_ATE_HP_complex_float80    = 0x81, /* Complex floating-point (80 bit).  */
index b2fb1a74e4277a7002590850082f288b7ef88241..fa046cab507f4f85db212ca1265ea03cf31c4fd4 100644 (file)
@@ -2149,6 +2149,7 @@ static void parse_type_DIE ( /*MOD*/XArray* /* of TyEnt */ tyents,
          if (attr == DW_AT_encoding && ctsSzB > 0) {
             switch (cts) {
                case DW_ATE_unsigned: case DW_ATE_unsigned_char:
+               case DW_ATE_UTF: /* since DWARF4, e.g. char16_t from C++ */
                case DW_ATE_boolean:/* FIXME - is this correct? */
                   typeE.Te.TyBase.enc = 'U'; break;
                case DW_ATE_signed: case DW_ATE_signed_char: