summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Blaikie <dblaikie@gmail.com>2017-08-02 20:16:22 +0000
committerDavid Blaikie <dblaikie@gmail.com>2017-08-02 20:16:22 +0000
commit22dc4474a6d9f7337098a017f4eb094b4d0adde2 (patch)
treeece5b2e53c2e07319ad2af03dcb2f44f15216db3
parenta195576118c97c4af34b66e45b3694906eda1ba2 (diff)
downloadbcm5719-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.h2
-rw-r--r--llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp13
-rw-r--r--llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp24
-rw-r--r--llvm/test/DebugInfo/Inputs/split-dwarf-dwp.obin2744 -> 4474 bytes
-rw-r--r--llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwpbin1256 -> 1600 bytes
-rw-r--r--llvm/test/DebugInfo/llvm-symbolizer.test6
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
index 614c62040de..2bf4fe3e494 100644
--- a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o
+++ b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o
Binary files differ
diff --git a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp
index 16a0af8c062..20eff18217f 100644
--- a/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp
+++ b/llvm/test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp
Binary files differ
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
OpenPOWER on IntegriCloud