Blame SOURCES/0002-PATCH-lldb-Support-DWARF-5-DW_FORM_line_strp-used-by.patch

7f3bad
From 2e94dca0c2cedf0bdbcf8517db2f3750ba95513b Mon Sep 17 00:00:00 2001
7f3bad
From: serge-sans-paille <sguelton@redhat.com>
7f3bad
Date: Tue, 2 Mar 2021 14:08:02 +0100
7f3bad
Subject: [PATCH 2/2] [PATCH][lldb] Support DWARF-5 DW_FORM_line_strp (used by
7f3bad
 GCC)
7f3bad
7f3bad
---
7f3bad
 .../SymbolFile/DWARF/DWARFDebugInfoEntry.cpp       |  1 +
7f3bad
 .../Plugins/SymbolFile/DWARF/DWARFFormValue.cpp    | 73 +++++++++++-----------
7f3bad
 2 files changed, 39 insertions(+), 35 deletions(-)
7f3bad
7f3bad
diff --git a/lldb/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp b/lldb/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp
7f3bad
index 4212988..bce2529 100644
7f3bad
--- a/lldb/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp
7f3bad
+++ b/lldb/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp
7f3bad
@@ -173,6 +173,7 @@ bool DWARFDebugInfoEntry::Extract(const DWARFDataExtractor &data,
7f3bad
             break;
7f3bad
 
7f3bad
           case DW_FORM_strp:
7f3bad
+          case DW_FORM_line_strp:
7f3bad
           case DW_FORM_sec_offset:
7f3bad
             data.GetU32(&offset);
7f3bad
             break;
7f3bad
diff --git a/lldb/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp b/lldb/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp
7f3bad
index 305f1cb..ec78c5b 100644
7f3bad
--- a/lldb/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp
7f3bad
+++ b/lldb/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp
7f3bad
@@ -150,40 +150,40 @@ struct FormSize {
7f3bad
   uint8_t valid:1, size:7;
7f3bad
 };
7f3bad
 static FormSize g_form_sizes[] = {
7f3bad
-  {0,0}, // 0x00 unused
7f3bad
-  {0,0}, // 0x01 DW_FORM_addr
7f3bad
-  {0,0}, // 0x02 unused
7f3bad
-  {0,0}, // 0x03 DW_FORM_block2
7f3bad
-  {0,0}, // 0x04 DW_FORM_block4
7f3bad
-  {1,2}, // 0x05 DW_FORM_data2
7f3bad
-  {1,4}, // 0x06 DW_FORM_data4
7f3bad
-  {1,8}, // 0x07 DW_FORM_data8
7f3bad
-  {0,0}, // 0x08 DW_FORM_string
7f3bad
-  {0,0}, // 0x09 DW_FORM_block
7f3bad
-  {0,0}, // 0x0a DW_FORM_block1
7f3bad
-  {1,1}, // 0x0b DW_FORM_data1
7f3bad
-  {1,1}, // 0x0c DW_FORM_flag
7f3bad
-  {0,0}, // 0x0d DW_FORM_sdata
7f3bad
-  {1,4}, // 0x0e DW_FORM_strp
7f3bad
-  {0,0}, // 0x0f DW_FORM_udata
7f3bad
-  {0,0}, // 0x10 DW_FORM_ref_addr (addr size for DWARF2 and earlier, 4 bytes for
7f3bad
-         // DWARF32, 8 bytes for DWARF32 in DWARF 3 and later
7f3bad
-  {1,1}, // 0x11 DW_FORM_ref1
7f3bad
-  {1,2}, // 0x12 DW_FORM_ref2
7f3bad
-  {1,4}, // 0x13 DW_FORM_ref4
7f3bad
-  {1,8}, // 0x14 DW_FORM_ref8
7f3bad
-  {0,0}, // 0x15 DW_FORM_ref_udata
7f3bad
-  {0,0}, // 0x16 DW_FORM_indirect
7f3bad
-  {1,4}, // 0x17 DW_FORM_sec_offset
7f3bad
-  {0,0}, // 0x18 DW_FORM_exprloc
7f3bad
-  {1,0}, // 0x19 DW_FORM_flag_present
7f3bad
-  {0,0}, // 0x1a
7f3bad
-  {0,0}, // 0x1b
7f3bad
-  {0,0}, // 0x1c
7f3bad
-  {0,0}, // 0x1d
7f3bad
-  {0,0}, // 0x1e
7f3bad
-  {0,0}, // 0x1f
7f3bad
-  {1,8}, // 0x20 DW_FORM_ref_sig8
7f3bad
+    {0, 0}, // 0x00 unused
7f3bad
+    {0, 0}, // 0x01 DW_FORM_addr
7f3bad
+    {0, 0}, // 0x02 unused
7f3bad
+    {0, 0}, // 0x03 DW_FORM_block2
7f3bad
+    {0, 0}, // 0x04 DW_FORM_block4
7f3bad
+    {1, 2}, // 0x05 DW_FORM_data2
7f3bad
+    {1, 4}, // 0x06 DW_FORM_data4
7f3bad
+    {1, 8}, // 0x07 DW_FORM_data8
7f3bad
+    {0, 0}, // 0x08 DW_FORM_string
7f3bad
+    {0, 0}, // 0x09 DW_FORM_block
7f3bad
+    {0, 0}, // 0x0a DW_FORM_block1
7f3bad
+    {1, 1}, // 0x0b DW_FORM_data1
7f3bad
+    {1, 1}, // 0x0c DW_FORM_flag
7f3bad
+    {0, 0}, // 0x0d DW_FORM_sdata
7f3bad
+    {1, 4}, // 0x0e DW_FORM_strp
7f3bad
+    {0, 0}, // 0x0f DW_FORM_udata
7f3bad
+    {0, 0}, // 0x10 DW_FORM_ref_addr (addr size for DWARF2 and earlier, 4 bytes
7f3bad
+            // for DWARF32, 8 bytes for DWARF32 in DWARF 3 and later
7f3bad
+    {1, 1},  // 0x11 DW_FORM_ref1
7f3bad
+    {1, 2},  // 0x12 DW_FORM_ref2
7f3bad
+    {1, 4},  // 0x13 DW_FORM_ref4
7f3bad
+    {1, 8},  // 0x14 DW_FORM_ref8
7f3bad
+    {0, 0},  // 0x15 DW_FORM_ref_udata
7f3bad
+    {0, 0},  // 0x16 DW_FORM_indirect
7f3bad
+    {1, 4},  // 0x17 DW_FORM_sec_offset
7f3bad
+    {0, 0},  // 0x18 DW_FORM_exprloc
7f3bad
+    {1, 0},  // 0x19 DW_FORM_flag_present
7f3bad
+    {0, 0},  // 0x1a DW_FORM_strx (ULEB128)
7f3bad
+    {0, 0},  // 0x1b DW_FORM_addrx (ULEB128)
7f3bad
+    {1, 4},  // 0x1c DW_FORM_ref_sup4
7f3bad
+    {0, 0},  // 0x1d DW_FORM_strp_sup (4 bytes for DWARF32, 8 bytes for DWARF64)
7f3bad
+    {1, 16}, // 0x1e DW_FORM_data16
7f3bad
+    {1, 4},  // 0x1f DW_FORM_line_strp
7f3bad
+    {1, 8},  // 0x20 DW_FORM_ref_sig8
7f3bad
 };
7f3bad
 
7f3bad
 llvm::Optional<uint8_t>
7f3bad
@@ -286,6 +286,7 @@ bool DWARFFormValue::SkipValue(dw_form_t form,
7f3bad
     // 32 bit for DWARF 32, 64 for DWARF 64
7f3bad
     case DW_FORM_sec_offset:
7f3bad
     case DW_FORM_strp:
7f3bad
+    case DW_FORM_line_strp:
7f3bad
       *offset_ptr += 4;
7f3bad
       return true;
7f3bad
 
7f3bad
@@ -398,7 +399,8 @@ void DWARFFormValue::Dump(Stream &s) const {
7f3bad
   case DW_FORM_udata:
7f3bad
     s.PutULEB128(uvalue);
7f3bad
     break;
7f3bad
-  case DW_FORM_strp: {
7f3bad
+  case DW_FORM_strp:
7f3bad
+  case DW_FORM_line_strp: {
7f3bad
     const char *dbg_str = AsCString();
7f3bad
     if (dbg_str) {
7f3bad
       s.QuotedCString(dbg_str);
7f3bad
@@ -606,6 +608,7 @@ bool DWARFFormValue::FormIsSupported(dw_form_t form) {
7f3bad
     case DW_FORM_flag:
7f3bad
     case DW_FORM_sdata:
7f3bad
     case DW_FORM_strp:
7f3bad
+    case DW_FORM_line_strp:
7f3bad
     case DW_FORM_strx:
7f3bad
     case DW_FORM_strx1:
7f3bad
     case DW_FORM_strx2:
7f3bad
-- 
7f3bad
1.8.3.1
7f3bad