diff options
| author | David Blaikie <dblaikie@gmail.com> | 2017-08-02 20:16:22 +0000 |
|---|---|---|
| committer | David Blaikie <dblaikie@gmail.com> | 2017-08-02 20:16:22 +0000 |
| commit | 22dc4474a6d9f7337098a017f4eb094b4d0adde2 (patch) | |
| tree | ece5b2e53c2e07319ad2af03dcb2f44f15216db3 | |
| parent | a195576118c97c4af34b66e45b3694906eda1ba2 (diff) | |
| download | bcm5719-llvm-22dc4474a6d9f7337098a017f4eb094b4d0adde2.tar.gz bcm5719-llvm-22dc4474a6d9f7337098a017f4eb094b4d0adde2.zip | |
DebugInfo: Test & handle (differently) non-zero DW_AT_ranges_base
Followup to r309570, fixing it slightly differently (ranges_base and
addr_base should never be read from a DWO file - so there shouldn't be
any issue with 'overriding' the values - conditionalize the code and
assert that the values aren't being overriden).
llvm-svn: 309879
| -rw-r--r-- | llvm/include/llvm/DebugInfo/DWARF/DWARFUnit.h | 2 | ||||
| -rw-r--r-- | llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp | 13 | ||||
| -rw-r--r-- | llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp | 24 | ||||
| -rw-r--r-- | llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o | bin | 2744 -> 4474 bytes | |||
| -rw-r--r-- | llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp | bin | 1256 -> 1600 bytes | |||
| -rw-r--r-- | llvm/test/DebugInfo/llvm-symbolizer.test | 6 |
6 files changed, 28 insertions, 17 deletions
diff --git a/llvm/include/llvm/DebugInfo/DWARF/DWARFUnit.h b/llvm/include/llvm/DebugInfo/DWARF/DWARFUnit.h index b4e3f008f31..c39fc4c9744 100644 --- a/llvm/include/llvm/DebugInfo/DWARF/DWARFUnit.h +++ b/llvm/include/llvm/DebugInfo/DWARF/DWARFUnit.h @@ -123,7 +123,7 @@ class DWARFUnit { const DWARFSection &StringOffsetSection; uint64_t StringOffsetSectionBase = 0; const DWARFSection *AddrOffsetSection; - uint32_t AddrOffsetSectionBase; + uint32_t AddrOffsetSectionBase = 0; bool isLittleEndian; bool isDWO; const DWARFUnitSectionBase &UnitSection; diff --git a/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp b/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp index 0a12fb2ecaa..5b0b3f65f6c 100644 --- a/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp +++ b/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp @@ -245,12 +245,13 @@ size_t DWARFUnit::extractDIEsIfNeeded(bool CUDieOnly) { auto BaseAddr = toAddress(UnitDie.find({DW_AT_low_pc, DW_AT_entry_pc})); if (BaseAddr) setBaseAddress(*BaseAddr); - Optional<DWARFFormValue> AddrBase = UnitDie.find(DW_AT_GNU_addr_base); - if (AddrBase) - AddrOffsetSectionBase = *toSectionOffset(AddrBase); - Optional<DWARFFormValue> RngListsBase = UnitDie.find(DW_AT_rnglists_base); - if (RngListsBase) - RangeSectionBase = *toSectionOffset(RngListsBase); + if (!isDWO) { + assert(AddrOffsetSectionBase == 0); + assert(RangeSectionBase == 0); + AddrOffsetSectionBase = + toSectionOffset(UnitDie.find(DW_AT_GNU_addr_base), 0); + RangeSectionBase = toSectionOffset(UnitDie.find(DW_AT_rnglists_base), 0); + } // In general, we derive the offset of the unit's contibution to the // debug_str_offsets{.dwo} section from the unit DIE's diff --git a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp index b07a1537d6b..ced32e41008 100644 --- a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp +++ b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp @@ -1,12 +1,22 @@ -void f1(); -__attribute__((always_inline)) void f2() { +__attribute__((optnone)) void f1() {} +inline __attribute__((always_inline)) void f2() { f1(); } -void f3() { +// throw a gap in the address range to force use of DW_AT_ranges, ranges_base, +// range contribution in the .dwo file, etc. +__attribute__((nodebug)) void gap() { +} +int main() { f2(); } -To produce split-dwarf-dwp.o{,dwp}, run: - - $ clang++ split-dwarf-dwp.cpp -gsplit-dwarf -c -Xclang -fdebug-compilation-dir=Output -fno-split-dwarf-inlining - $ llvm-dwp split-dwarf-dwp.dwo -o split-dwarf-dwp.o.dwp +// To produce split-dwarf-dwp.o{,dwp}, Create another file that has ranges, so +// the ranges_base of the CU for split-dwarf-dwp.cpp is non-zero. +// +// $ cat > other.cpp +// void other1() {} +// __attribute__((nodebug)) void other2() {} +// void other3() {} +// $ clang++ other.cpp split-dwarf-dwp.cpp -gsplit-dwarf -c -Xclang -fdebug-compilation-dir -Xclang Output -fno-split-dwarf-inlining +// $ llvm-dwp other.dwo other.dwo split-dwarf-dwp.dwo -o test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp +// $ ld -r other.o split-dwarf-dwp.o -o test/DebugInfo/Inputs/split-dwarf-dwp.o diff --git a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o Binary files differindex 614c62040de..2bf4fe3e494 100644 --- a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o +++ b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o diff --git a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp Binary files differindex 16a0af8c062..20eff18217f 100644 --- a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp +++ b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp diff --git a/llvm/test/DebugInfo/llvm-symbolizer.test b/llvm/test/DebugInfo/llvm-symbolizer.test index 342c1a9e925..a25e251b62c 100644 --- a/llvm/test/DebugInfo/llvm-symbolizer.test +++ b/llvm/test/DebugInfo/llvm-symbolizer.test @@ -51,7 +51,7 @@ RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ RUN: --default-arch=i386 < %t.input | FileCheck --check-prefix=SPLIT --check-prefix=NODWO %s RUN: cp %p/Inputs/split-dwarf-dwp.o %T/split-dwarf-dwp-different-name.o -RUN: echo "%T/split-dwarf-dwp-different-name.o 0x4" > %t.input +RUN: echo "%T/split-dwarf-dwp-different-name.o 0x54" > %t.input RUN: llvm-symbolizer --functions=linkage --inlining --demangle=false \ RUN: --default-arch=i386 --dwp=%p/Inputs/split-dwarf-dwp.o.dwp < %t.input | FileCheck --check-prefix=DWP %s @@ -158,8 +158,8 @@ CHECK-NEXT: split-dwarf-addr-object-relocation.cpp:6:0 DWP: f2 DWP-NEXT: split-dwarf-dwp.cpp:3:3 -DWP-NEXT: f3 -DWP-NEXT: split-dwarf-dwp.cpp:6:0 +DWP-NEXT: main +DWP-NEXT: split-dwarf-dwp.cpp:10:0 RUN: echo "unexisting-file 0x1234" > %t.input2 RUN: llvm-symbolizer < %t.input2 2>&1 | FileCheck %s --check-prefix=MISSING-FILE |

