For future reference it'd be good to include some details in a
recommit including the original commit hash, the revert hash, the
reason for the revert and what's changed in this commit to address
that problem.

For others reading along, according to the phab review this test hit a
bug in lldb and the test has been tweaked to avoid the bug - Pavel
Labath's going to look into the bug in the future.

On Fri, Apr 16, 2021 at 11:13 AM Caroline Tice via lldb-commits
<lldb-commits@lists.llvm.org> wrote:
>
>
> Author: Caroline Tice
> Date: 2021-04-16T11:12:39-07:00
> New Revision: 3dc24bc31edbc01dea085b24a6a6b024d7ae531c
>
> URL: 
> https://github.com/llvm/llvm-project/commit/3dc24bc31edbc01dea085b24a6a6b024d7ae531c
> DIFF: 
> https://github.com/llvm/llvm-project/commit/3dc24bc31edbc01dea085b24a6a6b024d7ae531c.diff
>
> LOG: [LLDB] Re-land: Use path relative to binary for finding .dwo files.
>
> DWARF allows .dwo file paths to be relative rather than absolute. When
> they are relative, DWARF uses DW_AT_comp_dir to find the .dwo
> file. DW_AT_comp_dir can also be relative, making the entire search
> patch for the .dwo file relative. In this case, LLDB currently
> searches relative to its current working directory, i.e. the directory
> from which the debugger was launched. This is not right, as the
> compiler, which generated the relative paths, can have no idea where
> the debugger will be launched. The correct thing is to search relative
> to the location of the executable binary. That is what this patch
> does.
>
> Differential Revision: https://reviews.llvm.org/D97786
>
> Added:
>     lldb/test/Shell/SymbolFile/DWARF/dwo-relative-path.s
>
> Modified:
>     lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp
>
> Removed:
>
>
>
> ################################################################################
> diff  --git a/lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp 
> b/lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp
> index 3a04f429c7c75..da170383405fb 100644
> --- a/lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp
> +++ b/lldb/source/Plugins/SymbolFile/DWARF/SymbolFileDWARF.cpp
> @@ -1651,6 +1651,13 @@ SymbolFileDWARF::GetDwoSymbolFileForCompileUnit(
>        return nullptr;
>
>      dwo_file.SetFile(comp_dir, FileSpec::Style::native);
> +    if (dwo_file.IsRelative()) {
> +      // if DW_AT_comp_dir is relative, it should be relative to the location
> +      // of the executable, not to the location from which the debugger was
> +      // launched.
> +      dwo_file.PrependPathComponent(
> +          m_objfile_sp->GetFileSpec().GetDirectory().GetStringRef());
> +    }
>      FileSystem::Instance().Resolve(dwo_file);
>      dwo_file.AppendPathComponent(dwo_name);
>    }
>
> diff  --git a/lldb/test/Shell/SymbolFile/DWARF/dwo-relative-path.s 
> b/lldb/test/Shell/SymbolFile/DWARF/dwo-relative-path.s
> new file mode 100644
> index 0000000000000..1916461e3ce8b
> --- /dev/null
> +++ b/lldb/test/Shell/SymbolFile/DWARF/dwo-relative-path.s
> @@ -0,0 +1,173 @@
> +# Test to verify LLDB searches for dwos with relative paths relative to the
> +# binary location, not relative to LLDB's launch location.
> +
> +# RUN: llvm-mc --filetype=obj --triple x86_64-pc-linux %s -o %t.o
> +# RUN: llvm-objcopy --split-dwo=%T/dwo-relative-path.dwo %t.o
> +
> +# RUN: cd ../..
> +
> +# RUN: %lldb %t.o -o "target var x" -b 2>&1 | FileCheck %s
> +
> +# CHECK: x = 10
> +
> +       .file   "dwo-relative-path.cpp"
> +       .file   0 "." "dwo-relative-path.cpp" md5 
> 0xadc61d242247514c5d402d62db34b825
> +       .type   x,@object                       # @x
> +       .data
> +       .globl  x
> +       .p2align        2
> +x:
> +       .long   10                              # 0xa
> +       .size   x, 4
> +
> +       .section        .debug_abbrev,"",@progbits
> +       .byte   1                               # Abbreviation Code
> +       .byte   74                              # DW_TAG_skeleton_unit
> +       .byte   0                               # DW_CHILDREN_no
> +       .byte   16                              # DW_AT_stmt_list
> +       .byte   23                              # DW_FORM_sec_offset
> +       .byte   114                             # DW_AT_str_offsets_base
> +       .byte   23                              # DW_FORM_sec_offset
> +       .byte   27                              # DW_AT_comp_dir
> +       .byte   37                              # DW_FORM_strx1
> +       .ascii  "\264B"                         # DW_AT_GNU_pubnames
> +       .byte   25                              # DW_FORM_flag_present
> +       .byte   118                             # DW_AT_dwo_name
> +       .byte   37                              # DW_FORM_strx1
> +       .byte   115                             # DW_AT_addr_base
> +       .byte   23                              # DW_FORM_sec_offset
> +       .byte   0                               # EOM(1)
> +       .byte   0                               # EOM(2)
> +       .byte   0                               # EOM(3)
> +       .section        .debug_info,"",@progbits
> +.Lcu_begin0:
> +       .long   .Ldebug_info_end0-.Ldebug_info_start0 # Length of Unit
> +.Ldebug_info_start0:
> +       .short  5                               # DWARF version number
> +       .byte   4                               # DWARF Unit Type
> +       .byte   8                               # Address Size (in bytes)
> +       .long   .debug_abbrev                   # Offset Into Abbrev. Section
> +       .quad   3752513468363206953
> +       .byte   1                               # Abbrev [1] 0x14:0x14 
> DW_TAG_skeleton_unit
> +       .long   .Lline_table_start0             # DW_AT_stmt_list
> +       .long   .Lstr_offsets_base0             # DW_AT_str_offsets_base
> +       .byte   0                               # DW_AT_comp_dir
> +                                        # DW_AT_GNU_pubnames
> +       .byte   1                               # DW_AT_dwo_name
> +       .long   .Laddr_table_base0              # DW_AT_addr_base
> +.Ldebug_info_end0:
> +       .section        .debug_str_offsets,"",@progbits
> +       .long   12                              # Length of String Offsets Set
> +       .short  5
> +       .short  0
> +.Lstr_offsets_base0:
> +       .section        .debug_str,"MS",@progbits,1
> +.Lskel_string0:
> +       .asciz  "."                             # string offset=0
> +.Lskel_string1:
> +       .asciz  "dwo-relative-path.dwo"         # string offset=2
> +       .section        .debug_str_offsets,"",@progbits
> +       .long   .Lskel_string0
> +       .long   .Lskel_string1
> +       .section        .debug_str_offsets.dwo,"e",@progbits
> +       .long   24                              # Length of String Offsets Set
> +       .short  5
> +       .short  0
> +       .section        .debug_str.dwo,"eMS",@progbits,1
> +.Linfo_string0:
> +       .asciz  "x"
> +.Linfo_string1:
> +       .asciz  "int"
> +.Linfo_string2:
> +       .asciz  "clang version 13.0.0 
> (https://chromium.googlesource.com/external/github.com/llvm/llvm-project 
> 6666e0d7a29c639df7a1652b6d3bf16f28edd45a)"
> +.Linfo_string3:
> +       .asciz  "dwo-relative-path.cpp"
> +.Linfo_string10:
> +       .asciz  "dwo-relative-path.dwo"
> +       .section        .debug_str_offsets.dwo,"e",@progbits
> +       .long   .Linfo_string0-.debug_str.dwo
> +       .long   .Linfo_string1-.debug_str.dwo
> +       .long   .Linfo_string2-.debug_str.dwo
> +       .long   .Linfo_string3-.debug_str.dwo
> +       .section        .debug_info.dwo,"e",@progbits
> +       .long   .Ldebug_info_dwo_end0-.Ldebug_info_dwo_start0 # Length of Unit
> +.Ldebug_info_dwo_start0:
> +       .short  5                               # DWARF version number
> +       .byte   5                               # DWARF Unit Type
> +       .byte   8                               # Address Size (in bytes)
> +       .long   0                               # Offset Into Abbrev. Section
> +       .quad   3752513468363206953
> +       .byte   1                               # Abbrev [1] 0x14:0x65 
> DW_TAG_compile_unit
> +       .byte   8                               # DW_AT_producer
> +       .short  33                              # DW_AT_language
> +       .byte   9                               # DW_AT_name
> +       .byte   10                              # DW_AT_dwo_name
> +       .byte   2                               # Abbrev [2] 0x1a:0xb 
> DW_TAG_variable
> +       .byte   0                               # DW_AT_name
> +       .long   37                              # DW_AT_type
> +                                        # DW_AT_external
> +       .byte   0                               # DW_AT_decl_file
> +       .byte   11                              # DW_AT_decl_line
> +       .byte   2                               # DW_AT_location
> +       .byte   161
> +       .byte   0
> +       .byte   3                               # Abbrev [3] 0x25:0x4 
> DW_TAG_base_type
> +       .byte   1                               # DW_AT_name
> +       .byte   5                               # DW_AT_encoding
> +       .byte   4                               # DW_AT_byte_size
> +       .byte   0                               # End Of Children Mark
> +.Ldebug_info_dwo_end0:
> +       .section        .debug_abbrev.dwo,"e",@progbits
> +       .byte   1                               # Abbreviation Code
> +       .byte   17                              # DW_TAG_compile_unit
> +       .byte   1                               # DW_CHILDREN_yes
> +       .byte   37                              # DW_AT_producer
> +       .byte   37                              # DW_FORM_strx1
> +       .byte   19                              # DW_AT_language
> +       .byte   5                               # DW_FORM_data2
> +       .byte   3                               # DW_AT_name
> +       .byte   37                              # DW_FORM_strx1
> +       .byte   118                             # DW_AT_dwo_name
> +       .byte   37                              # DW_FORM_strx1
> +       .byte   0                               # EOM(1)
> +       .byte   0                               # EOM(2)
> +       .byte   2                               # Abbreviation Code
> +       .byte   52                              # DW_TAG_variable
> +       .byte   0                               # DW_CHILDREN_no
> +       .byte   3                               # DW_AT_name
> +       .byte   37                              # DW_FORM_strx1
> +       .byte   73                              # DW_AT_type
> +       .byte   19                              # DW_FORM_ref4
> +       .byte   63                              # DW_AT_external
> +       .byte   25                              # DW_FORM_flag_present
> +       .byte   58                              # DW_AT_decl_file
> +       .byte   11                              # DW_FORM_data1
> +       .byte   59                              # DW_AT_decl_line
> +       .byte   11                              # DW_FORM_data1
> +       .byte   2                               # DW_AT_location
> +       .byte   24                              # DW_FORM_exprloc
> +       .byte   0                               # EOM(1)
> +       .byte   0                               # EOM(2)
> +       .byte   3                               # Abbreviation Code
> +       .byte   36                              # DW_TAG_base_type
> +       .byte   0                               # DW_CHILDREN_no
> +       .byte   3                               # DW_AT_name
> +       .byte   37                              # DW_FORM_strx1
> +       .byte   62                              # DW_AT_encoding
> +       .byte   11                              # DW_FORM_data1
> +       .byte   11                              # DW_AT_byte_size
> +       .byte   11                              # DW_FORM_data1
> +       .byte   0                               # EOM(1)
> +       .byte   0                               # EOM(2)
> +       .byte   0                               # EOM(3)
> +       .section        .debug_addr,"",@progbits
> +       .long   .Ldebug_addr_end0-.Ldebug_addr_start0 # Length of contribution
> +.Ldebug_addr_start0:
> +       .short  5                               # DWARF version number
> +       .byte   8                               # Address size
> +       .byte   0                               # Segment selector size
> +.Laddr_table_base0:
> +       .quad   x
> +.Ldebug_addr_end0:
> +       .section        .debug_line,"",@progbits
> +.Lline_table_start0:
>
>
>
> _______________________________________________
> lldb-commits mailing list
> lldb-commits@lists.llvm.org
> https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to