diff options
author | Zachary Turner <zturner@google.com> | 2017-08-09 04:23:59 +0000 |
---|---|---|
committer | Zachary Turner <zturner@google.com> | 2017-08-09 04:23:59 +0000 |
commit | 5448dabbdd956c39af9fbbc424289e1dba00f8e8 (patch) | |
tree | e50fd5246dc00a3adc50dca9a7e79f7b28a4faba /llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp | |
parent | 946204c83e74434568d4fbf6174d2da48215efd4 (diff) | |
download | bcm5719-llvm-5448dabbdd956c39af9fbbc424289e1dba00f8e8.tar.gz bcm5719-llvm-5448dabbdd956c39af9fbbc424289e1dba00f8e8.zip |
[PDB] Fix an issue writing the publics stream.
In the refactor to merge the publics and globals stream, a bug
was introduced that wrote the wrong value for one of the fields
of the PublicsStreamHeader. This caused debugging in WinDbg
to break.
We had no way of dumping any of these fields, so in addition to
fixing the bug I've added dumping support for them along with a
test that verifies the correct value is written.
llvm-svn: 310439
Diffstat (limited to 'llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp')
-rw-r--r-- | llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp | 21 |
1 files changed, 5 insertions, 16 deletions
diff --git a/llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp b/llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp index eb7a0bbcc3d..46951a0b88e 100644 --- a/llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp +++ b/llvm/lib/DebugInfo/PDB/Native/GSIStreamBuilder.cpp @@ -153,7 +153,6 @@ Error GSIStreamBuilder::finalizeMsfLayout() { if (!Idx) return Idx.takeError(); PSH->StreamIndex = *Idx; - Idx = Msf.addStream(calculateGlobalsHashStreamSize()); if (!Idx) return Idx.takeError(); @@ -253,32 +252,22 @@ Error GSIStreamBuilder::commitSymbolRecordStream( Error GSIStreamBuilder::commitPublicsHashStream( WritableBinaryStreamRef Stream) { - // Skip the publics stream header so that we can write the GSH header first. - // Then seek back to the beginning and update the publics stream header with - // the byte offset after the GSH header. BinaryStreamWriter Writer(Stream); - Writer.setOffset(sizeof(PublicsStreamHeader)); - - if (auto EC = PSH->commit(Writer)) - return EC; - uint32_t OffsetAfterGSIHashes = Writer.getOffset(); - - Writer.setOffset(0); - - // FIXME: Fill these in. They are for incremental linking. PublicsStreamHeader Header; - Header.AddrMap = PSH->Records.size() * 4; + // FIXME: Fill these in. They are for incremental linking. Header.NumThunks = 0; Header.SizeOfThunk = 0; Header.ISectThunkTable = 0; Header.OffThunkTable = 0; Header.NumSections = 0; - Header.SymHash = OffsetAfterGSIHashes; + Header.SymHash = PSH->calculateSerializedLength(); + Header.AddrMap = PSH->Records.size() * 4; if (auto EC = Writer.writeObject(Header)) return EC; - Writer.setOffset(OffsetAfterGSIHashes); + if (auto EC = PSH->commit(Writer)) + return EC; std::vector<ulittle32_t> AddrMap = computeAddrMap(PSH->Records); if (auto EC = Writer.writeArray(makeArrayRef(AddrMap))) |