From 7d5bc597d7909d7e3839c1051f09368b05889fcf Mon Sep 17 00:00:00 2001 From: Xinliang David Li Date: Mon, 18 Jan 2016 06:48:01 +0000 Subject: [PATCH] [Coverage] move a local var to be BinaryCoverageReader's member The symtab is logically referenced beyond the call to the create method. This changes makes sure its lifetime matches that of the reader. llvm-svn: 258036 --- .../llvm/ProfileData/CoverageMappingReader.h | 1 + lib/ProfileData/CoverageMappingReader.cpp | 19 +++++++++++-------- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/include/llvm/ProfileData/CoverageMappingReader.h b/include/llvm/ProfileData/CoverageMappingReader.h index f03090e2921..7dfce5b8c64 100644 --- a/include/llvm/ProfileData/CoverageMappingReader.h +++ b/include/llvm/ProfileData/CoverageMappingReader.h @@ -158,6 +158,7 @@ public: private: std::vector Filenames; std::vector MappingRecords; + InstrProfSymtab ProfileNames; size_t CurrentRecord; std::vector FunctionsFilenames; std::vector Expressions; diff --git a/lib/ProfileData/CoverageMappingReader.cpp b/lib/ProfileData/CoverageMappingReader.cpp index d7169bfdcb2..da14ab23294 100644 --- a/lib/ProfileData/CoverageMappingReader.cpp +++ b/lib/ProfileData/CoverageMappingReader.cpp @@ -546,33 +546,36 @@ BinaryCoverageReader::create(std::unique_ptr &ObjectBuffer, StringRef Arch) { std::unique_ptr Reader(new BinaryCoverageReader()); - InstrProfSymtab ProfileNames; StringRef Coverage; uint8_t BytesInAddress; support::endianness Endian; std::error_code EC; if (ObjectBuffer->getBuffer().startswith(TestingFormatMagic)) // This is a special format used for testing. - EC = loadTestingFormat(ObjectBuffer->getBuffer(), ProfileNames, Coverage, - BytesInAddress, Endian); + EC = loadTestingFormat(ObjectBuffer->getBuffer(), Reader->ProfileNames, + Coverage, BytesInAddress, Endian); else - EC = loadBinaryFormat(ObjectBuffer->getMemBufferRef(), ProfileNames, + EC = loadBinaryFormat(ObjectBuffer->getMemBufferRef(), Reader->ProfileNames, Coverage, BytesInAddress, Endian, Arch); if (EC) return EC; if (BytesInAddress == 4 && Endian == support::endianness::little) EC = readCoverageMappingData( - ProfileNames, Coverage, Reader->MappingRecords, Reader->Filenames); + Reader->ProfileNames, Coverage, Reader->MappingRecords, + Reader->Filenames); else if (BytesInAddress == 4 && Endian == support::endianness::big) EC = readCoverageMappingData( - ProfileNames, Coverage, Reader->MappingRecords, Reader->Filenames); + Reader->ProfileNames, Coverage, Reader->MappingRecords, + Reader->Filenames); else if (BytesInAddress == 8 && Endian == support::endianness::little) EC = readCoverageMappingData( - ProfileNames, Coverage, Reader->MappingRecords, Reader->Filenames); + Reader->ProfileNames, Coverage, Reader->MappingRecords, + Reader->Filenames); else if (BytesInAddress == 8 && Endian == support::endianness::big) EC = readCoverageMappingData( - ProfileNames, Coverage, Reader->MappingRecords, Reader->Filenames); + Reader->ProfileNames, Coverage, Reader->MappingRecords, + Reader->Filenames); else return coveragemap_error::malformed; if (EC)