LLVM 20.0.0git
ModuleDebugStream.cpp
Go to the documentation of this file.
1//===- ModuleDebugStream.cpp - PDB Module Info Stream Access --------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
21#include "llvm/Support/Error.h"
22#include <cstdint>
23
24using namespace llvm;
25using namespace llvm::codeview;
26using namespace llvm::msf;
27using namespace llvm::pdb;
28
31 std::unique_ptr<MappedBlockStream> Stream)
32 : Mod(Module), Stream(std::move(Stream)) {}
33
35
37 BinaryStreamReader Reader(*Stream);
38
40 if (Error E = reloadSerialize(Reader))
41 return E;
42 }
43 if (Reader.bytesRemaining() > 0)
44 return make_error<RawError>(raw_error_code::corrupt_file,
45 "Unexpected bytes in module stream.");
46 return Error::success();
47}
48
49Error ModuleDebugStreamRef::reloadSerialize(BinaryStreamReader &Reader) {
50 uint32_t SymbolSize = Mod.getSymbolDebugInfoByteSize();
51 uint32_t C11Size = Mod.getC11LineInfoByteSize();
52 uint32_t C13Size = Mod.getC13LineInfoByteSize();
53
54 if (C11Size > 0 && C13Size > 0)
55 return make_error<RawError>(raw_error_code::corrupt_file,
56 "Module has both C11 and C13 line info");
57
59
60 if (auto EC = Reader.readInteger(Signature))
61 return EC;
62 Reader.setOffset(0);
63 if (auto EC = Reader.readSubstream(SymbolsSubstream, SymbolSize))
64 return EC;
65 if (auto EC = Reader.readSubstream(C11LinesSubstream, C11Size))
66 return EC;
67 if (auto EC = Reader.readSubstream(C13LinesSubstream, C13Size))
68 return EC;
69
70 BinaryStreamReader SymbolReader(SymbolsSubstream.StreamData);
71 if (auto EC = SymbolReader.readArray(
72 SymbolArray, SymbolReader.bytesRemaining(), sizeof(uint32_t)))
73 return EC;
74
75 BinaryStreamReader SubsectionsReader(C13LinesSubstream.StreamData);
76 if (auto EC = SubsectionsReader.readArray(Subsections,
77 SubsectionsReader.bytesRemaining()))
78 return EC;
79
80 uint32_t GlobalRefsSize;
81 if (auto EC = Reader.readInteger(GlobalRefsSize))
82 return EC;
83 if (auto EC = Reader.readSubstream(GlobalRefsSubstream, GlobalRefsSize))
84 return EC;
85 return Error::success();
86}
87
90 return limitSymbolArrayToScope(SymbolArray, ScopeBegin);
91}
92
94 return SymbolsSubstream;
95}
96
98 return C11LinesSubstream;
99}
100
102 return C13LinesSubstream;
103}
104
106 return GlobalRefsSubstream;
107}
108
110ModuleDebugStreamRef::symbols(bool *HadError) const {
111 return make_range(SymbolArray.begin(HadError), SymbolArray.end());
112}
113
115 auto Iter = SymbolArray.at(Offset);
116 assert(Iter != SymbolArray.end());
117 return *Iter;
118}
119
122 return make_range(Subsections.begin(), Subsections.end());
123}
124
126 return !C13LinesSubstream.empty();
127}
128
130
134 for (const auto &SS : subsections()) {
135 if (SS.kind() != DebugSubsectionKind::FileChecksums)
136 continue;
137
138 if (auto EC = Result.initialize(SS.getRecordData()))
139 return std::move(EC);
140 return Result;
141 }
142 return Result;
143}
Lightweight arrays that are backed by an arbitrary BinaryStream.
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
Provides read only access to a subclass of BinaryStream.
Error readSubstream(BinarySubstreamRef &Ref, uint32_t Length)
Read Length bytes from the underlying stream into Ref.
Error readInteger(T &Dest)
Read an integer of the specified endianness into Dest and update the stream's offset.
uint64_t bytesRemaining() const
void setOffset(uint64_t Off)
BinaryStreamRef is to BinaryStream what ArrayRef is to an Array.
Lightweight error class with error context and mandatory checking.
Definition: Error.h:160
static ErrorSuccess success()
Create a success value.
Definition: Error.h:337
Tagged union holding either a T or a Error.
Definition: Error.h:481
A Module instance is used to store all the information related to an LLVM module.
Definition: Module.h:65
Iterator at(uint32_t Offset) const
given an offset into the array's underlying stream, return an iterator to the record at that offset.
Iterator end() const
Iterator begin(bool *HadError=nullptr) const
CVRecord is a fat pointer (base + size pair) to a symbol or type record.
Definition: CVRecord.h:29
A range adaptor for a pair of iterators.
iterator_range< codeview::CVSymbolArray::Iterator > symbols(bool *HadError) const
codeview::CVSymbol readSymbolAtOffset(uint32_t Offset) const
BinarySubstreamRef getSymbolsSubstream() const
BinarySubstreamRef getGlobalRefsSubstream() const
Expected< codeview::DebugChecksumsSubsectionRef > findChecksumsSubsection() const
ModuleDebugStreamRef(const DbiModuleDescriptor &Module, std::unique_ptr< msf::MappedBlockStream > Stream)
BinarySubstreamRef getC11LinesSubstream() const
BinarySubstreamRef getC13LinesSubstream() const
const codeview::CVSymbolArray getSymbolArrayForScope(uint32_t ScopeBegin) const
iterator_range< DebugSubsectionIterator > subsections() const
This provides a very simple, boring adaptor for a begin and end iterator into a range type.
CVSymbolArray limitSymbolArrayToScope(const CVSymbolArray &Symbols, uint32_t ScopeBegin)
const uint16_t kInvalidStreamIndex
Definition: RawConstants.h:19
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
iterator_range< T > make_range(T x, T y)
Convenience function for iterating over sub-ranges.
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Definition: STLExtras.h:1873
Implement std::hash so that hash_code can be used in STL containers.
Definition: BitVector.h:858
BinaryStreamRef StreamData