mirror of
https://github.com/RPCSX/llvm.git
synced 2026-01-31 01:05:23 +01:00
Type records have a unique type index, but symbol records do not. Instead, symbol records refer to other symbol records by referencing their offset in the symbol stream. In a sense this is the analogue of the TypeIndex, but we are not printing it in the dumper. Printing it not only gives us more useful information when manually investigating the contents of a PDB, but also allows us to write better tests by enabling us to verify that fields that reference other symbol records do so correctly. Differential Revision: https://reviews.llvm.org/D34906 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@306890 91177308-0d34-0410-b5e6-96231b3b80d8
95 lines
3.2 KiB
C++
95 lines
3.2 KiB
C++
//===- SymbolDeserializer.h -------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_DEBUGINFO_CODEVIEW_SYMBOLDESERIALIZER_H
|
|
#define LLVM_DEBUGINFO_CODEVIEW_SYMBOLDESERIALIZER_H
|
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
#include "llvm/DebugInfo/CodeView/SymbolRecord.h"
|
|
#include "llvm/DebugInfo/CodeView/SymbolRecordMapping.h"
|
|
#include "llvm/DebugInfo/CodeView/SymbolVisitorCallbacks.h"
|
|
#include "llvm/DebugInfo/CodeView/SymbolVisitorDelegate.h"
|
|
#include "llvm/Support/BinaryByteStream.h"
|
|
#include "llvm/Support/BinaryStreamReader.h"
|
|
#include "llvm/Support/Error.h"
|
|
|
|
namespace llvm {
|
|
namespace codeview {
|
|
class SymbolVisitorDelegate;
|
|
class SymbolDeserializer : public SymbolVisitorCallbacks {
|
|
struct MappingInfo {
|
|
MappingInfo(ArrayRef<uint8_t> RecordData, CodeViewContainer Container)
|
|
: Stream(RecordData, llvm::support::little), Reader(Stream),
|
|
Mapping(Reader, Container) {}
|
|
|
|
BinaryByteStream Stream;
|
|
BinaryStreamReader Reader;
|
|
SymbolRecordMapping Mapping;
|
|
};
|
|
|
|
public:
|
|
template <typename T> static Error deserializeAs(CVSymbol Symbol, T &Record) {
|
|
// If we're just deserializing one record, then don't worry about alignment
|
|
// as there's nothing that comes after.
|
|
SymbolDeserializer S(nullptr, CodeViewContainer::ObjectFile);
|
|
if (auto EC = S.visitSymbolBegin(Symbol))
|
|
return EC;
|
|
if (auto EC = S.visitKnownRecord(Symbol, Record))
|
|
return EC;
|
|
if (auto EC = S.visitSymbolEnd(Symbol))
|
|
return EC;
|
|
return Error::success();
|
|
}
|
|
|
|
explicit SymbolDeserializer(SymbolVisitorDelegate *Delegate,
|
|
CodeViewContainer Container)
|
|
: Delegate(Delegate), Container(Container) {}
|
|
|
|
Error visitSymbolBegin(CVSymbol &Record, uint32_t Offset) override {
|
|
return visitSymbolBegin(Record);
|
|
}
|
|
|
|
Error visitSymbolBegin(CVSymbol &Record) override {
|
|
assert(!Mapping && "Already in a symbol mapping!");
|
|
Mapping = llvm::make_unique<MappingInfo>(Record.content(), Container);
|
|
return Mapping->Mapping.visitSymbolBegin(Record);
|
|
}
|
|
Error visitSymbolEnd(CVSymbol &Record) override {
|
|
assert(Mapping && "Not in a symbol mapping!");
|
|
auto EC = Mapping->Mapping.visitSymbolEnd(Record);
|
|
Mapping.reset();
|
|
return EC;
|
|
}
|
|
|
|
#define SYMBOL_RECORD(EnumName, EnumVal, Name) \
|
|
Error visitKnownRecord(CVSymbol &CVR, Name &Record) override { \
|
|
return visitKnownRecordImpl(CVR, Record); \
|
|
}
|
|
#define SYMBOL_RECORD_ALIAS(EnumName, EnumVal, Name, AliasName)
|
|
#include "llvm/DebugInfo/CodeView/CodeViewSymbols.def"
|
|
|
|
private:
|
|
template <typename T> Error visitKnownRecordImpl(CVSymbol &CVR, T &Record) {
|
|
|
|
Record.RecordOffset =
|
|
Delegate ? Delegate->getRecordOffset(Mapping->Reader) : 0;
|
|
if (auto EC = Mapping->Mapping.visitKnownRecord(CVR, Record))
|
|
return EC;
|
|
return Error::success();
|
|
}
|
|
|
|
SymbolVisitorDelegate *Delegate;
|
|
CodeViewContainer Container;
|
|
std::unique_ptr<MappingInfo> Mapping;
|
|
};
|
|
}
|
|
}
|
|
|
|
#endif
|