Apply upstream D97721
This commit is contained in:
parent
17dae9e2ea
commit
25187bd8f5
328
D97721.diff
Normal file
328
D97721.diff
Normal file
@ -0,0 +1,328 @@
|
||||
diff --git lldb-a/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp lldb-b/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp
|
||||
--- lldb-a/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp
|
||||
+++ lldb-b/source/Plugins/SymbolFile/DWARF/DWARFDebugInfoEntry.cpp
|
||||
@@ -173,6 +173,7 @@
|
||||
break;
|
||||
|
||||
case DW_FORM_strp:
|
||||
+ case DW_FORM_line_strp:
|
||||
case DW_FORM_sec_offset:
|
||||
data.GetU32(&offset);
|
||||
break;
|
||||
diff --git lldb-a/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp lldb-b/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp
|
||||
--- lldb-a/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp
|
||||
+++ lldb-b/source/Plugins/SymbolFile/DWARF/DWARFFormValue.cpp
|
||||
@@ -150,40 +150,40 @@
|
||||
uint8_t valid:1, size:7;
|
||||
};
|
||||
static FormSize g_form_sizes[] = {
|
||||
- {0,0}, // 0x00 unused
|
||||
- {0,0}, // 0x01 DW_FORM_addr
|
||||
- {0,0}, // 0x02 unused
|
||||
- {0,0}, // 0x03 DW_FORM_block2
|
||||
- {0,0}, // 0x04 DW_FORM_block4
|
||||
- {1,2}, // 0x05 DW_FORM_data2
|
||||
- {1,4}, // 0x06 DW_FORM_data4
|
||||
- {1,8}, // 0x07 DW_FORM_data8
|
||||
- {0,0}, // 0x08 DW_FORM_string
|
||||
- {0,0}, // 0x09 DW_FORM_block
|
||||
- {0,0}, // 0x0a DW_FORM_block1
|
||||
- {1,1}, // 0x0b DW_FORM_data1
|
||||
- {1,1}, // 0x0c DW_FORM_flag
|
||||
- {0,0}, // 0x0d DW_FORM_sdata
|
||||
- {1,4}, // 0x0e DW_FORM_strp
|
||||
- {0,0}, // 0x0f DW_FORM_udata
|
||||
- {0,0}, // 0x10 DW_FORM_ref_addr (addr size for DWARF2 and earlier, 4 bytes for
|
||||
- // DWARF32, 8 bytes for DWARF32 in DWARF 3 and later
|
||||
- {1,1}, // 0x11 DW_FORM_ref1
|
||||
- {1,2}, // 0x12 DW_FORM_ref2
|
||||
- {1,4}, // 0x13 DW_FORM_ref4
|
||||
- {1,8}, // 0x14 DW_FORM_ref8
|
||||
- {0,0}, // 0x15 DW_FORM_ref_udata
|
||||
- {0,0}, // 0x16 DW_FORM_indirect
|
||||
- {1,4}, // 0x17 DW_FORM_sec_offset
|
||||
- {0,0}, // 0x18 DW_FORM_exprloc
|
||||
- {1,0}, // 0x19 DW_FORM_flag_present
|
||||
- {0,0}, // 0x1a
|
||||
- {0,0}, // 0x1b
|
||||
- {0,0}, // 0x1c
|
||||
- {0,0}, // 0x1d
|
||||
- {0,0}, // 0x1e
|
||||
- {0,0}, // 0x1f
|
||||
- {1,8}, // 0x20 DW_FORM_ref_sig8
|
||||
+ {0, 0}, // 0x00 unused
|
||||
+ {0, 0}, // 0x01 DW_FORM_addr
|
||||
+ {0, 0}, // 0x02 unused
|
||||
+ {0, 0}, // 0x03 DW_FORM_block2
|
||||
+ {0, 0}, // 0x04 DW_FORM_block4
|
||||
+ {1, 2}, // 0x05 DW_FORM_data2
|
||||
+ {1, 4}, // 0x06 DW_FORM_data4
|
||||
+ {1, 8}, // 0x07 DW_FORM_data8
|
||||
+ {0, 0}, // 0x08 DW_FORM_string
|
||||
+ {0, 0}, // 0x09 DW_FORM_block
|
||||
+ {0, 0}, // 0x0a DW_FORM_block1
|
||||
+ {1, 1}, // 0x0b DW_FORM_data1
|
||||
+ {1, 1}, // 0x0c DW_FORM_flag
|
||||
+ {0, 0}, // 0x0d DW_FORM_sdata
|
||||
+ {1, 4}, // 0x0e DW_FORM_strp
|
||||
+ {0, 0}, // 0x0f DW_FORM_udata
|
||||
+ {0, 0}, // 0x10 DW_FORM_ref_addr (addr size for DWARF2 and earlier, 4 bytes
|
||||
+ // for DWARF32, 8 bytes for DWARF32 in DWARF 3 and later
|
||||
+ {1, 1}, // 0x11 DW_FORM_ref1
|
||||
+ {1, 2}, // 0x12 DW_FORM_ref2
|
||||
+ {1, 4}, // 0x13 DW_FORM_ref4
|
||||
+ {1, 8}, // 0x14 DW_FORM_ref8
|
||||
+ {0, 0}, // 0x15 DW_FORM_ref_udata
|
||||
+ {0, 0}, // 0x16 DW_FORM_indirect
|
||||
+ {1, 4}, // 0x17 DW_FORM_sec_offset
|
||||
+ {0, 0}, // 0x18 DW_FORM_exprloc
|
||||
+ {1, 0}, // 0x19 DW_FORM_flag_present
|
||||
+ {0, 0}, // 0x1a DW_FORM_strx (ULEB128)
|
||||
+ {0, 0}, // 0x1b DW_FORM_addrx (ULEB128)
|
||||
+ {1, 4}, // 0x1c DW_FORM_ref_sup4
|
||||
+ {0, 0}, // 0x1d DW_FORM_strp_sup (4 bytes for DWARF32, 8 bytes for DWARF64)
|
||||
+ {1, 16}, // 0x1e DW_FORM_data16
|
||||
+ {1, 4}, // 0x1f DW_FORM_line_strp
|
||||
+ {1, 8}, // 0x20 DW_FORM_ref_sig8
|
||||
};
|
||||
|
||||
llvm::Optional<uint8_t>
|
||||
@@ -286,6 +286,7 @@
|
||||
// 32 bit for DWARF 32, 64 for DWARF 64
|
||||
case DW_FORM_sec_offset:
|
||||
case DW_FORM_strp:
|
||||
+ case DW_FORM_line_strp:
|
||||
*offset_ptr += 4;
|
||||
return true;
|
||||
|
||||
@@ -398,7 +399,8 @@
|
||||
case DW_FORM_udata:
|
||||
s.PutULEB128(uvalue);
|
||||
break;
|
||||
- case DW_FORM_strp: {
|
||||
+ case DW_FORM_strp:
|
||||
+ case DW_FORM_line_strp: {
|
||||
const char *dbg_str = AsCString();
|
||||
if (dbg_str) {
|
||||
s.QuotedCString(dbg_str);
|
||||
@@ -606,6 +608,7 @@
|
||||
case DW_FORM_flag:
|
||||
case DW_FORM_sdata:
|
||||
case DW_FORM_strp:
|
||||
+ case DW_FORM_line_strp:
|
||||
case DW_FORM_strx:
|
||||
case DW_FORM_strx1:
|
||||
case DW_FORM_strx2:
|
||||
diff --git lldb-a/test/Shell/SymbolFile/DWARF/dwarf5-line-strp.s lldb-b/test/Shell/SymbolFile/DWARF/dwarf5-line-strp.s
|
||||
new file mode 100755
|
||||
--- /dev/null
|
||||
+++ lldb-b/test/Shell/SymbolFile/DWARF/dwarf5-line-strp.s
|
||||
@@ -0,0 +1,207 @@
|
||||
+# Test handling of DWARF5 DW_FORM_line_strp from .debug_info as used by GCC.
|
||||
+
|
||||
+# REQUIRES: x86
|
||||
+
|
||||
+# RUN: llvm-mc -filetype=obj -o %t -triple x86_64-pc-linux %s
|
||||
+# RUN: %lldb %t -o "p main" \
|
||||
+# RUN: -o exit | FileCheck %s
|
||||
+
|
||||
+# CHECK: (int (*)()) $0 = 0x0000000000000000
|
||||
+
|
||||
+ .text
|
||||
+.Ltext0:
|
||||
+ .globl main
|
||||
+ .type main, @function
|
||||
+main:
|
||||
+.LFB0:
|
||||
+.LM1:
|
||||
+ .long 0
|
||||
+.LM2:
|
||||
+ .long 0
|
||||
+.LFE0:
|
||||
+ .size main, .-main
|
||||
+.Letext0:
|
||||
+ .section .debug_info,"",@progbits
|
||||
+.Ldebug_info0:
|
||||
+ .long 0x50 # Length of Compilation Unit Info
|
||||
+ .value 0x5 # DWARF version number
|
||||
+ .byte 0x1 # DW_UT_compile
|
||||
+ .byte 0x8 # Pointer Size (in bytes)
|
||||
+ .long .Ldebug_abbrev0 # Offset Into Abbrev. Section
|
||||
+ .uleb128 0x1 # (DIE (0xc) DW_TAG_compile_unit)
|
||||
+ .long .LASF2 # DW_AT_producer: "GNU C17 11.0.0 20210210 (Red Hat 11.0.0-0) -mtune=generic -march=x86-64 -gdwarf-5 -gno-as-loc-support"
|
||||
+ .byte 0x1d # DW_AT_language
|
||||
+ .long .LASF0 # DW_AT_name: "main.c"
|
||||
+ .long .LASF1 # DW_AT_comp_dir: ""
|
||||
+ .quad .Ltext0 # DW_AT_low_pc
|
||||
+ .quad .Letext0-.Ltext0 # DW_AT_high_pc
|
||||
+ .long .Ldebug_line0 # DW_AT_stmt_list
|
||||
+ .uleb128 0x2 # (DIE (0x2e) DW_TAG_subprogram)
|
||||
+ # DW_AT_external
|
||||
+ .long .LASF3 # DW_AT_name: "main"
|
||||
+ .byte 0x1 # DW_AT_decl_file (main.c)
|
||||
+ .byte 0x1 # DW_AT_decl_line
|
||||
+ .byte 0x5 # DW_AT_decl_column
|
||||
+ .long 0x4c # DW_AT_type
|
||||
+ .quad .LFB0 # DW_AT_low_pc
|
||||
+ .quad .LFE0-.LFB0 # DW_AT_high_pc
|
||||
+ .uleb128 0x1 # DW_AT_frame_base
|
||||
+ .byte 0x9c # DW_OP_call_frame_cfa
|
||||
+ # DW_AT_call_all_calls
|
||||
+ .uleb128 0x3 # (DIE (0x4c) DW_TAG_base_type)
|
||||
+ .byte 0x4 # DW_AT_byte_size
|
||||
+ .byte 0x5 # DW_AT_encoding
|
||||
+ .ascii "int\0" # DW_AT_name
|
||||
+ .byte 0 # end of children of DIE 0xc
|
||||
+ .section .debug_abbrev,"",@progbits
|
||||
+.Ldebug_abbrev0:
|
||||
+ .uleb128 0x1 # (abbrev code)
|
||||
+ .uleb128 0x11 # (TAG: DW_TAG_compile_unit)
|
||||
+ .byte 0x1 # DW_children_yes
|
||||
+ .uleb128 0x25 # (DW_AT_producer)
|
||||
+ .uleb128 0xe # (DW_FORM_strp)
|
||||
+ .uleb128 0x13 # (DW_AT_language)
|
||||
+ .uleb128 0xb # (DW_FORM_data1)
|
||||
+ .uleb128 0x3 # (DW_AT_name)
|
||||
+ .uleb128 0x1f # (DW_FORM_line_strp)
|
||||
+ .uleb128 0x1b # (DW_AT_comp_dir)
|
||||
+ .uleb128 0x1f # (DW_FORM_line_strp)
|
||||
+ .uleb128 0x11 # (DW_AT_low_pc)
|
||||
+ .uleb128 0x1 # (DW_FORM_addr)
|
||||
+ .uleb128 0x12 # (DW_AT_high_pc)
|
||||
+ .uleb128 0x7 # (DW_FORM_data8)
|
||||
+ .uleb128 0x10 # (DW_AT_stmt_list)
|
||||
+ .uleb128 0x17 # (DW_FORM_sec_offset)
|
||||
+ .byte 0
|
||||
+ .byte 0
|
||||
+ .uleb128 0x2 # (abbrev code)
|
||||
+ .uleb128 0x2e # (TAG: DW_TAG_subprogram)
|
||||
+ .byte 0 # DW_children_no
|
||||
+ .uleb128 0x3f # (DW_AT_external)
|
||||
+ .uleb128 0x19 # (DW_FORM_flag_present)
|
||||
+ .uleb128 0x3 # (DW_AT_name)
|
||||
+ .uleb128 0xe # (DW_FORM_strp)
|
||||
+ .uleb128 0x3a # (DW_AT_decl_file)
|
||||
+ .uleb128 0xb # (DW_FORM_data1)
|
||||
+ .uleb128 0x3b # (DW_AT_decl_line)
|
||||
+ .uleb128 0xb # (DW_FORM_data1)
|
||||
+ .uleb128 0x39 # (DW_AT_decl_column)
|
||||
+ .uleb128 0xb # (DW_FORM_data1)
|
||||
+ .uleb128 0x49 # (DW_AT_type)
|
||||
+ .uleb128 0x13 # (DW_FORM_ref4)
|
||||
+ .uleb128 0x11 # (DW_AT_low_pc)
|
||||
+ .uleb128 0x1 # (DW_FORM_addr)
|
||||
+ .uleb128 0x12 # (DW_AT_high_pc)
|
||||
+ .uleb128 0x7 # (DW_FORM_data8)
|
||||
+ .uleb128 0x40 # (DW_AT_frame_base)
|
||||
+ .uleb128 0x18 # (DW_FORM_exprloc)
|
||||
+ .uleb128 0x7a # (DW_AT_call_all_calls)
|
||||
+ .uleb128 0x19 # (DW_FORM_flag_present)
|
||||
+ .byte 0
|
||||
+ .byte 0
|
||||
+ .uleb128 0x3 # (abbrev code)
|
||||
+ .uleb128 0x24 # (TAG: DW_TAG_base_type)
|
||||
+ .byte 0 # DW_children_no
|
||||
+ .uleb128 0xb # (DW_AT_byte_size)
|
||||
+ .uleb128 0xb # (DW_FORM_data1)
|
||||
+ .uleb128 0x3e # (DW_AT_encoding)
|
||||
+ .uleb128 0xb # (DW_FORM_data1)
|
||||
+ .uleb128 0x3 # (DW_AT_name)
|
||||
+ .uleb128 0x8 # (DW_FORM_string)
|
||||
+ .byte 0
|
||||
+ .byte 0
|
||||
+ .byte 0
|
||||
+ .section .debug_aranges,"",@progbits
|
||||
+ .long 0x2c # Length of Address Ranges Info
|
||||
+ .value 0x2 # DWARF aranges version
|
||||
+ .long .Ldebug_info0 # Offset of Compilation Unit Info
|
||||
+ .byte 0x8 # Size of Address
|
||||
+ .byte 0 # Size of Segment Descriptor
|
||||
+ .value 0 # Pad to 16 byte boundary
|
||||
+ .value 0
|
||||
+ .quad .Ltext0 # Address
|
||||
+ .quad .Letext0-.Ltext0 # Length
|
||||
+ .quad 0
|
||||
+ .quad 0
|
||||
+ .section .debug_line,"",@progbits
|
||||
+.Ldebug_line0:
|
||||
+ .long .LELT0-.LSLT0 # Length of Source Line Info
|
||||
+.LSLT0:
|
||||
+ .value 0x5 # DWARF version number
|
||||
+ .byte 0x8 # Address Size
|
||||
+ .byte 0 # Segment Size
|
||||
+ .long .LELTP0-.LASLTP0 # Prolog Length
|
||||
+.LASLTP0:
|
||||
+ .byte 0x1 # Minimum Instruction Length
|
||||
+ .byte 0x1 # Maximum Operations Per Instruction
|
||||
+ .byte 0x1 # Default is_stmt_start flag
|
||||
+ .byte 0xf6 # Line Base Value (Special Opcodes)
|
||||
+ .byte 0xf2 # Line Range Value (Special Opcodes)
|
||||
+ .byte 0xd # Special Opcode Base
|
||||
+ .byte 0 # opcode: 0x1 has 0 args
|
||||
+ .byte 0x1 # opcode: 0x2 has 1 args
|
||||
+ .byte 0x1 # opcode: 0x3 has 1 args
|
||||
+ .byte 0x1 # opcode: 0x4 has 1 args
|
||||
+ .byte 0x1 # opcode: 0x5 has 1 args
|
||||
+ .byte 0 # opcode: 0x6 has 0 args
|
||||
+ .byte 0 # opcode: 0x7 has 0 args
|
||||
+ .byte 0 # opcode: 0x8 has 0 args
|
||||
+ .byte 0x1 # opcode: 0x9 has 1 args
|
||||
+ .byte 0 # opcode: 0xa has 0 args
|
||||
+ .byte 0 # opcode: 0xb has 0 args
|
||||
+ .byte 0x1 # opcode: 0xc has 1 args
|
||||
+ .byte 0x1 # Directory entry format count
|
||||
+ .uleb128 0x1 # DW_LNCT_path
|
||||
+ .uleb128 0x1f # DW_FORM_line_strp
|
||||
+ .uleb128 0x2 # Directories count
|
||||
+ .long .LASF1 # Directory Entry: 0: ""
|
||||
+ .long .LASF4 # Directory Entry: 0: ""
|
||||
+ .byte 0x2 # File name entry format count
|
||||
+ .uleb128 0x1 # DW_LNCT_path
|
||||
+ .uleb128 0x1f # DW_FORM_line_strp
|
||||
+ .uleb128 0x2 # DW_LNCT_directory_index
|
||||
+ .uleb128 0xb # DW_FORM_data1
|
||||
+ .uleb128 0x2 # File names count
|
||||
+ .long .LASF0 # File Entry: 0: "main.c"
|
||||
+ .byte 0
|
||||
+ .long .LASF5 # File Entry: 0: "main.c"
|
||||
+ .byte 0x1
|
||||
+.LELTP0:
|
||||
+ .byte 0 # set address *.LM1
|
||||
+ .uleb128 0x9
|
||||
+ .byte 0x2
|
||||
+ .quad .LM1
|
||||
+ .byte 0x1 # copy line 1
|
||||
+ .byte 0x5 # column 12
|
||||
+ .uleb128 0xc # 12
|
||||
+ .byte 0 # set address *.LM2
|
||||
+ .uleb128 0x9
|
||||
+ .byte 0x2
|
||||
+ .quad .LM2
|
||||
+ .byte 0x1 # copy line 1
|
||||
+ .byte 0x5 # column 13
|
||||
+ .uleb128 0xd # 13
|
||||
+ .byte 0 # set address *.Letext0
|
||||
+ .uleb128 0x9
|
||||
+ .byte 0x2
|
||||
+ .quad .Letext0
|
||||
+ .byte 0 # end sequence
|
||||
+ .uleb128 0x1
|
||||
+ .byte 0x1
|
||||
+.LELT0:
|
||||
+ .section .debug_str,"MS",@progbits,1
|
||||
+.LASF2:
|
||||
+ .string "GNU C17 11.0.0 20210210 (Red Hat 11.0.0-0) -mtune=generic -march=x86-64 -gdwarf-5 -gno-as-loc-support"
|
||||
+.LASF3:
|
||||
+ .string "main"
|
||||
+ .section .debug_line_str,"MS",@progbits,1
|
||||
+.LASF1:
|
||||
+ .string ""
|
||||
+.LASF4:
|
||||
+ .string ""
|
||||
+.LASF0:
|
||||
+ .string "main.c"
|
||||
+.LASF5:
|
||||
+ .string "main.c"
|
||||
+ .ident "GCC: (GNU) 11.0.0 20210210 (Red Hat 11.0.0-0)"
|
||||
+ .section .note.GNU-stack,"",@progbits
|
||||
|
Loading…
Reference in New Issue
Block a user