1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2025-01-31 20:51:52 +01:00

pdbdump: Fix crash bug.

pdbdump calls DbiStreamBuilder::commit through PDBFileBuilder::commit
without calling DbiStreamBuilder::finalize. Because `finalize` initializes
`Header` member, `Header` remained nullptr which caused a crash bug.

Differential Revision: https://reviews.llvm.org/D23143

llvm-svn: 277681
This commit is contained in:
Rui Ueyama 2016-08-03 23:43:23 +00:00
parent c8c589f243
commit 68a326fe7b
3 changed files with 9 additions and 2 deletions

View File

@ -49,7 +49,7 @@ public:
Expected<std::unique_ptr<DbiStream>> build(PDBFile &File,
const msf::WritableStream &Buffer);
Error commit(const msf::MSFLayout &Layout,
const msf::WritableStream &Buffer) const;
const msf::WritableStream &Buffer);
private:
Error finalize();

View File

@ -249,7 +249,10 @@ DbiStreamBuilder::build(PDBFile &File, const msf::WritableStream &Buffer) {
}
Error DbiStreamBuilder::commit(const msf::MSFLayout &Layout,
const msf::WritableStream &Buffer) const {
const msf::WritableStream &Buffer) {
if (auto EC = finalize())
return EC;
auto InfoS =
WritableMappedBlockStream::createIndexedStream(Layout, Buffer, StreamDBI);

View File

@ -0,0 +1,4 @@
; RUN: llvm-pdbdump pdb2yaml -dbi-module-info -dbi-module-source-info \
; RUN: -dbi-stream -pdb-stream -stream-directory -stream-metadata \
; RUN: %p/Inputs/empty.pdb > %t.1
; RUN: llvm-pdbdump yaml2pdb -pdb=%t.2 %t.1