LLVM 23.0.0git
CodeViewYAMLSymbols.cpp
Go to the documentation of this file.
1//===- CodeViewYAMLSymbols.cpp - CodeView YAMLIO Symbol implementation ----===//
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//
9// This file defines classes for handling the YAML representation of CodeView
10// Debug Info.
11//
12//===----------------------------------------------------------------------===//
13
15#include "llvm/ADT/ArrayRef.h"
16#include "llvm/ADT/StringRef.h"
27#include "llvm/Support/Error.h"
30#include <algorithm>
31#include <cstdint>
32#include <cstring>
33#include <optional>
34#include <string>
35#include <vector>
36
37using namespace llvm;
38using namespace llvm::codeview;
39using namespace llvm::CodeViewYAML;
40using namespace llvm::CodeViewYAML::detail;
41using namespace llvm::yaml;
42
45
46// We only need to declare these, the definitions are in CodeViewYAMLTypes.cpp
49
52
65
67
69
71 return ScalarTraits<StringRef>::input(S, V, T.value);
72}
73
74void ScalarTraits<TypeName>::output(const TypeName &T, void *V,
75 raw_ostream &R) {
77}
78
81 auto SymbolNames = getSymbolTypeNames();
82 for (const auto &E : SymbolNames)
83 io.enumCase(Value, E.name(), E.value());
84 io.enumFallback<yaml::Hex16>(Value);
85}
86
88 CompileSym2Flags &Flags) {
89 auto FlagNames = getCompileSym2FlagNames();
90 for (const auto &E : FlagNames) {
91 io.bitSetCase(Flags, E.name(), static_cast<CompileSym2Flags>(E.value()));
92 }
93}
94
96 CompileSym3Flags &Flags) {
97 auto FlagNames = getCompileSym3FlagNames();
98 for (const auto &E : FlagNames) {
99 io.bitSetCase(Flags, E.name(), static_cast<CompileSym3Flags>(E.value()));
100 }
101}
102
104 auto FlagNames = getExportSymFlagNames();
105 for (const auto &E : FlagNames) {
106 io.bitSetCase(Flags, E.name(), static_cast<ExportFlags>(E.value()));
107 }
108}
109
111 auto FlagNames = getPublicSymFlagNames();
112 for (const auto &E : FlagNames) {
113 io.bitSetCase(Flags, E.name(), static_cast<PublicSymFlags>(E.value()));
114 }
115}
116
118 auto FlagNames = getLocalFlagNames();
119 for (const auto &E : FlagNames) {
120 io.bitSetCase(Flags, E.name(), static_cast<LocalSymFlags>(E.value()));
121 }
122}
123
125 auto FlagNames = getProcSymFlagNames();
126 for (const auto &E : FlagNames) {
127 io.bitSetCase(Flags, E.name(), static_cast<ProcSymFlags>(E.value()));
128 }
129}
130
132 IO &io, FrameProcedureOptions &Flags) {
133 auto FlagNames = getFrameProcSymFlagNames();
134 for (const auto &E : FlagNames) {
135 io.bitSetCase(Flags, E.name(),
136 static_cast<FrameProcedureOptions>(E.value()));
137 }
138}
139
141 auto CpuNames = getCPUTypeNames();
142 for (const auto &E : CpuNames) {
143 io.enumCase(Cpu, E.name(), static_cast<CPUType>(E.value()));
144 }
145}
146
148 const auto *Header = static_cast<COFF::header *>(io.getContext());
149 assert(Header && "The IO context is not initialized");
150
151 std::optional<CPUType> CpuType;
152
153 switch (Header->Machine) {
155 CpuType = CPUType::Pentium3;
156 break;
158 CpuType = CPUType::X64;
159 break;
161 CpuType = CPUType::ARMNT;
162 break;
166 CpuType = CPUType::ARM64;
167 break;
168 }
169
170 if (CpuType)
171 for (const auto &E : getRegisterNames(*CpuType))
172 io.enumCase(Reg, E.name(), static_cast<RegisterId>(E.value()));
173
174 io.enumFallback<Hex16>(Reg);
175}
176
178 IO &io, TrampolineType &Tramp) {
179 auto TrampNames = getTrampolineNames();
180 for (const auto &E : TrampNames) {
181 io.enumCase(Tramp, E.name(), static_cast<TrampolineType>(E.value()));
182 }
183}
184
186 ThunkOrdinal &Ord) {
187 auto ThunkNames = getThunkOrdinalNames();
188 for (const auto &E : ThunkNames) {
189 io.enumCase(Ord, E.name(), static_cast<ThunkOrdinal>(E.value()));
190 }
191}
192
194 IO &io, FrameCookieKind &FC) {
195 auto ThunkNames = getFrameCookieKindNames();
196 for (const auto &E : ThunkNames) {
197 io.enumCase(FC, E.name(), static_cast<FrameCookieKind>(E.value()));
198 }
199}
200
202 IO &io, JumpTableEntrySize &FC) {
203 auto ThunkNames = getJumpTableEntrySizeNames();
204 for (const auto &E : ThunkNames) {
205 io.enumCase(FC, E.name(), static_cast<JumpTableEntrySize>(E.value()));
206 }
207}
208
209namespace llvm {
210namespace yaml {
213 io.mapRequired("OffsetStart", Range.OffsetStart);
214 io.mapRequired("ISectStart", Range.ISectStart);
215 io.mapRequired("Range", Range.Range);
216 }
217};
219 static void mapping(IO &io, LocalVariableAddrGap &Gap) {
220 io.mapRequired("GapStartOffset", Gap.GapStartOffset);
221 io.mapRequired("Range", Gap.Range);
222 }
223};
224} // namespace yaml
225} // namespace llvm
226
227namespace llvm {
228namespace CodeViewYAML {
229namespace detail {
230
233
235 virtual ~SymbolRecordBase() = default;
236
237 virtual void map(yaml::IO &io) = 0;
238 virtual codeview::CVSymbol
240 CodeViewContainer Container) const = 0;
242};
243
244template <typename T> struct SymbolRecordImpl : public SymbolRecordBase {
247
248 void map(yaml::IO &io) override;
249
252 CodeViewContainer Container) const override {
253 return SymbolSerializer::writeOneSymbol(Symbol, Allocator, Container);
254 }
255
259
260 mutable T Symbol;
261};
262
265
266 void map(yaml::IO &io) override;
267
269 CodeViewContainer Container) const override {
270 RecordPrefix Prefix;
271 uint32_t TotalLen = sizeof(RecordPrefix) + Data.size();
272 Prefix.RecordKind = Kind;
273 Prefix.RecordLen = TotalLen - 2;
274 uint8_t *Buffer = Allocator.Allocate<uint8_t>(TotalLen);
275 ::memcpy(Buffer, &Prefix, sizeof(RecordPrefix));
276 ::memcpy(Buffer + sizeof(RecordPrefix), Data.data(), Data.size());
277 return CVSymbol(ArrayRef<uint8_t>(Buffer, TotalLen));
278 }
279
281 this->Kind = CVS.kind();
282 Data = CVS.RecordData.drop_front(sizeof(RecordPrefix));
283 return Error::success();
284 }
285
286 std::vector<uint8_t> Data;
287};
288
290
292 yaml::BinaryRef Binary;
293 if (io.outputting())
294 Binary = yaml::BinaryRef(Data);
295 io.mapRequired("Data", Binary);
296 if (!io.outputting()) {
297 std::string Str;
298 raw_string_ostream OS(Str);
299 Binary.writeAsBinary(OS);
300 Data.assign(Str.begin(), Str.end());
301 }
302}
303
305 IO.mapRequired("Parent", Symbol.Parent);
306 IO.mapRequired("End", Symbol.End);
307 IO.mapRequired("Next", Symbol.Next);
308 IO.mapRequired("Off", Symbol.Offset);
309 IO.mapRequired("Seg", Symbol.Segment);
310 IO.mapRequired("Len", Symbol.Length);
311 IO.mapRequired("Ordinal", Symbol.Thunk);
312}
313
315 IO.mapRequired("Type", Symbol.Type);
316 IO.mapRequired("Size", Symbol.Size);
317 IO.mapRequired("ThunkOff", Symbol.ThunkOffset);
318 IO.mapRequired("TargetOff", Symbol.TargetOffset);
319 IO.mapRequired("ThunkSection", Symbol.ThunkSection);
320 IO.mapRequired("TargetSection", Symbol.TargetSection);
321}
322
324 IO.mapRequired("SectionNumber", Symbol.SectionNumber);
325 IO.mapRequired("Alignment", Symbol.Alignment);
326 IO.mapRequired("Rva", Symbol.Rva);
327 IO.mapRequired("Length", Symbol.Length);
328 IO.mapRequired("Characteristics", Symbol.Characteristics);
329 IO.mapRequired("Name", Symbol.Name);
330}
331
333 IO.mapRequired("Size", Symbol.Size);
334 IO.mapRequired("Characteristics", Symbol.Characteristics);
335 IO.mapRequired("Offset", Symbol.Offset);
336 IO.mapRequired("Segment", Symbol.Segment);
337 IO.mapRequired("Name", Symbol.Name);
338}
339
341 IO.mapRequired("Ordinal", Symbol.Ordinal);
342 IO.mapRequired("Flags", Symbol.Flags);
343 IO.mapRequired("Name", Symbol.Name);
344}
345
347 IO.mapOptional("PtrParent", Symbol.Parent, 0U);
348 IO.mapOptional("PtrEnd", Symbol.End, 0U);
349 IO.mapOptional("PtrNext", Symbol.Next, 0U);
350 IO.mapRequired("CodeSize", Symbol.CodeSize);
351 IO.mapRequired("DbgStart", Symbol.DbgStart);
352 IO.mapRequired("DbgEnd", Symbol.DbgEnd);
353 IO.mapRequired("FunctionType", Symbol.FunctionType);
354 IO.mapOptional("Offset", Symbol.CodeOffset, 0U);
355 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
356 IO.mapRequired("Flags", Symbol.Flags);
357 IO.mapRequired("DisplayName", Symbol.Name);
358}
359
361 IO.mapRequired("Type", Symbol.Index);
362 IO.mapRequired("Seg", Symbol.Register);
363 IO.mapRequired("Name", Symbol.Name);
364}
365
367 IO.mapRequired("Flags", Symbol.Flags);
368 IO.mapOptional("Offset", Symbol.Offset, 0U);
369 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
370 IO.mapRequired("Name", Symbol.Name);
371}
372
374 IO.mapRequired("SumName", Symbol.SumName);
375 IO.mapRequired("SymOffset", Symbol.SymOffset);
376 IO.mapRequired("Mod", Symbol.Module);
377 IO.mapRequired("Name", Symbol.Name);
378}
379
381 IO.mapRequired("Entries", Symbol.Fields);
382}
383
385 IO.mapOptional("PtrParent", Symbol.Parent, 0U);
386 IO.mapOptional("PtrEnd", Symbol.End, 0U);
387 IO.mapRequired("Inlinee", Symbol.Inlinee);
388 IO.mapOptional("AnnotationData", Symbol.AnnotationData);
389}
390
392 IO.mapRequired("Type", Symbol.Type);
393 IO.mapRequired("Flags", Symbol.Flags);
394
395 IO.mapRequired("VarName", Symbol.Name);
396}
397
399 IO.mapRequired("Program", Symbol.Program);
400 IO.mapRequired("Range", Symbol.Range);
401 IO.mapRequired("Gaps", Symbol.Gaps);
402}
403
405 IO.mapRequired("Program", Symbol.Program);
406 IO.mapRequired("OffsetInParent", Symbol.OffsetInParent);
407 IO.mapRequired("Range", Symbol.Range);
408 IO.mapRequired("Gaps", Symbol.Gaps);
409}
410
412 IO.mapRequired("Register", Symbol.Hdr.Register);
413 IO.mapRequired("MayHaveNoName", Symbol.Hdr.MayHaveNoName);
414 IO.mapRequired("Range", Symbol.Range);
415 IO.mapRequired("Gaps", Symbol.Gaps);
416}
417
419 IO.mapRequired("Offset", Symbol.Hdr.Offset);
420 IO.mapRequired("Range", Symbol.Range);
421 IO.mapRequired("Gaps", Symbol.Gaps);
422}
423
425 IO.mapRequired("Register", Symbol.Hdr.Register);
426 IO.mapRequired("MayHaveNoName", Symbol.Hdr.MayHaveNoName);
427 IO.mapRequired("OffsetInParent", Symbol.Hdr.OffsetInParent);
428 IO.mapRequired("Range", Symbol.Range);
429 IO.mapRequired("Gaps", Symbol.Gaps);
430}
431
432template <>
436
438 IO.mapRequired("Register", Symbol.Hdr.Register);
439 IO.mapRequired("Flags", Symbol.Hdr.Flags);
440 IO.mapRequired("BasePointerOffset", Symbol.Hdr.BasePointerOffset);
441 IO.mapRequired("Range", Symbol.Range);
442 IO.mapRequired("Gaps", Symbol.Gaps);
443}
444
446 IO.mapRequired("Register", Symbol.Hdr.Register);
447 IO.mapRequired("Flags", Symbol.Hdr.Flags);
448 IO.mapRequired("BasePointerOffset", Symbol.Hdr.BasePointerOffset);
449 IO.mapRequired("OffsetInUdt", Symbol.Hdr.OffsetInUdt);
450 IO.mapRequired("Range", Symbol.Range);
451 IO.mapRequired("Gaps", Symbol.Gaps);
452}
453
455 IO.mapOptional("PtrParent", Symbol.Parent, 0U);
456 IO.mapOptional("PtrEnd", Symbol.End, 0U);
457 IO.mapRequired("CodeSize", Symbol.CodeSize);
458 IO.mapOptional("Offset", Symbol.CodeOffset, 0U);
459 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
460 IO.mapRequired("BlockName", Symbol.Name);
461}
462
464 IO.mapOptional("Offset", Symbol.CodeOffset, 0U);
465 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
466 IO.mapRequired("Flags", Symbol.Flags);
467 IO.mapRequired("DisplayName", Symbol.Name);
468}
469
471 IO.mapRequired("Signature", Symbol.Signature);
472 IO.mapRequired("ObjectName", Symbol.Name);
473}
474
476 IO.mapRequired("Flags", Symbol.Flags);
477 IO.mapRequired("Machine", Symbol.Machine);
478 IO.mapRequired("FrontendMajor", Symbol.VersionFrontendMajor);
479 IO.mapRequired("FrontendMinor", Symbol.VersionFrontendMinor);
480 IO.mapRequired("FrontendBuild", Symbol.VersionFrontendBuild);
481 IO.mapRequired("BackendMajor", Symbol.VersionBackendMajor);
482 IO.mapRequired("BackendMinor", Symbol.VersionBackendMinor);
483 IO.mapRequired("BackendBuild", Symbol.VersionBackendBuild);
484 IO.mapRequired("Version", Symbol.Version);
485}
486
488 IO.mapRequired("Flags", Symbol.Flags);
489 IO.mapRequired("Machine", Symbol.Machine);
490 IO.mapRequired("FrontendMajor", Symbol.VersionFrontendMajor);
491 IO.mapRequired("FrontendMinor", Symbol.VersionFrontendMinor);
492 IO.mapRequired("FrontendBuild", Symbol.VersionFrontendBuild);
493 IO.mapRequired("FrontendQFE", Symbol.VersionFrontendQFE);
494 IO.mapRequired("BackendMajor", Symbol.VersionBackendMajor);
495 IO.mapRequired("BackendMinor", Symbol.VersionBackendMinor);
496 IO.mapRequired("BackendBuild", Symbol.VersionBackendBuild);
497 IO.mapRequired("BackendQFE", Symbol.VersionBackendQFE);
498 IO.mapRequired("Version", Symbol.Version);
499}
500
502 IO.mapRequired("TotalFrameBytes", Symbol.TotalFrameBytes);
503 IO.mapRequired("PaddingFrameBytes", Symbol.PaddingFrameBytes);
504 IO.mapRequired("OffsetToPadding", Symbol.OffsetToPadding);
505 IO.mapRequired("BytesOfCalleeSavedRegisters",
506 Symbol.BytesOfCalleeSavedRegisters);
507 IO.mapRequired("OffsetOfExceptionHandler", Symbol.OffsetOfExceptionHandler);
508 IO.mapRequired("SectionIdOfExceptionHandler",
509 Symbol.SectionIdOfExceptionHandler);
510 IO.mapRequired("Flags", Symbol.Flags);
511}
512
514 IO.mapOptional("Offset", Symbol.CodeOffset, 0U);
515 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
516 IO.mapRequired("Type", Symbol.Type);
517}
518
520 IO.mapRequired("Index", Symbol.Index);
521 IO.mapRequired("ModFilenameOffset", Symbol.ModFilenameOffset);
522 IO.mapRequired("Flags", Symbol.Flags);
523 IO.mapRequired("Name", Symbol.Name);
524}
525
527 IO.mapOptional("Offset", Symbol.CodeOffset, 0U);
528 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
529 IO.mapRequired("CallInstructionSize", Symbol.CallInstructionSize);
530 IO.mapRequired("Type", Symbol.Type);
531}
532
534 IO.mapRequired("Register", Symbol.Register);
535 IO.mapRequired("CookieKind", Symbol.CookieKind);
536 IO.mapRequired("Flags", Symbol.Flags);
537}
538
540 IO.mapRequired("FuncID", Symbol.Indices);
541}
542
544 IO.mapRequired("Type", Symbol.Type);
545 IO.mapRequired("UDTName", Symbol.Name);
546}
547
549 IO.mapRequired("BuildId", Symbol.BuildId);
550}
551
553 IO.mapRequired("Offset", Symbol.Offset);
554 IO.mapRequired("Type", Symbol.Type);
555 IO.mapRequired("VarName", Symbol.Name);
556}
557
559 IO.mapRequired("Offset", Symbol.Offset);
560 IO.mapRequired("Type", Symbol.Type);
561 IO.mapRequired("Register", Symbol.Register);
562 IO.mapRequired("VarName", Symbol.Name);
563}
564
566 IO.mapRequired("Offset", Symbol.Offset);
567 IO.mapRequired("Type", Symbol.Type);
568 IO.mapRequired("Register", Symbol.Register);
569 IO.mapRequired("OffsetInUdt", Symbol.OffsetInUdt);
570 IO.mapRequired("VarName", Symbol.Name);
571}
572
574 IO.mapRequired("Type", Symbol.Type);
575 IO.mapRequired("Value", Symbol.Value);
576 IO.mapRequired("Name", Symbol.Name);
577}
578
580 IO.mapRequired("Type", Symbol.Type);
581 IO.mapOptional("Offset", Symbol.DataOffset, 0U);
582 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
583 IO.mapRequired("DisplayName", Symbol.Name);
584}
585
587 IO.mapRequired("Type", Symbol.Type);
588 IO.mapOptional("Offset", Symbol.DataOffset, 0U);
589 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
590 IO.mapRequired("DisplayName", Symbol.Name);
591}
592
594 IO.mapRequired("Namespace", Symbol.Name);
595}
596
598 IO.mapOptional("Offset", Symbol.CodeOffset, 0U);
599 IO.mapOptional("Segment", Symbol.Segment, uint16_t(0));
600 IO.mapRequired("Strings", Symbol.Strings);
601}
602
604 IO.mapRequired("BaseOffset", Symbol.BaseOffset);
605 IO.mapRequired("BaseSegment", Symbol.BaseSegment);
606 IO.mapRequired("SwitchType", Symbol.SwitchType);
607 IO.mapRequired("BranchOffset", Symbol.BranchOffset);
608 IO.mapRequired("TableOffset", Symbol.TableOffset);
609 IO.mapRequired("BranchSegment", Symbol.BranchSegment);
610 IO.mapRequired("TableSegment", Symbol.TableSegment);
611 IO.mapRequired("EntriesCount", Symbol.EntriesCount);
612}
613
615 IO.mapRequired("Function", Symbol.Function);
616 IO.mapRequired("Name", Symbol.Name);
617}
618
619} // end namespace detail
620} // end namespace CodeViewYAML
621} // end namespace llvm
622
624 BumpPtrAllocator &Allocator, CodeViewContainer Container) const {
625 return Symbol->toCodeViewSymbol(Allocator, Container);
626}
627
628namespace llvm {
629namespace yaml {
630
631template <> struct MappingTraits<SymbolRecordBase> {
632 static void mapping(IO &io, SymbolRecordBase &Record) { Record.map(io); }
633};
634
635} // end namespace yaml
636} // end namespace llvm
637
638template <typename SymbolType>
639static inline Expected<CodeViewYAML::SymbolRecord>
642
643 auto Impl = std::make_shared<SymbolType>(Symbol.kind());
644 if (auto EC = Impl->fromCodeViewSymbol(Symbol))
645 return std::move(EC);
646 Result.Symbol = std::move(Impl);
647 return Result;
648}
649
650Expected<CodeViewYAML::SymbolRecord>
652#define SYMBOL_RECORD(EnumName, EnumVal, ClassName) \
653 case EnumName: \
654 return fromCodeViewSymbolImpl<SymbolRecordImpl<ClassName>>(Symbol);
655#define SYMBOL_RECORD_ALIAS(EnumName, EnumVal, AliasName, ClassName) \
656 SYMBOL_RECORD(EnumName, EnumVal, ClassName)
657 switch (Symbol.kind()) {
658#include "llvm/DebugInfo/CodeView/CodeViewSymbols.def"
659 default:
661 }
663}
664
665template <typename ConcreteType>
666static void mapSymbolRecordImpl(IO &IO, const char *Class, SymbolKind Kind,
668 if (!IO.outputting())
669 Obj.Symbol = std::make_shared<ConcreteType>(Kind);
670
671 IO.mapRequired(Class, *Obj.Symbol);
672}
673
674void MappingTraits<CodeViewYAML::SymbolRecord>::mapping(
675 IO &IO, CodeViewYAML::SymbolRecord &Obj) {
677 if (IO.outputting())
678 Kind = Obj.Symbol->Kind;
679 IO.mapRequired("Kind", Kind);
680
681#define SYMBOL_RECORD(EnumName, EnumVal, ClassName) \
682 case EnumName: \
683 mapSymbolRecordImpl<SymbolRecordImpl<ClassName>>(IO, #ClassName, Kind, \
684 Obj); \
685 break;
686#define SYMBOL_RECORD_ALIAS(EnumName, EnumVal, AliasName, ClassName) \
687 SYMBOL_RECORD(EnumName, EnumVal, ClassName)
688 switch (Kind) {
689#include "llvm/DebugInfo/CodeView/CodeViewSymbols.def"
690 default:
691 mapSymbolRecordImpl<UnknownSymbolRecord>(IO, "UnknownSym", Kind, Obj);
692 }
693}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file defines the BumpPtrAllocator interface.
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static void mapSymbolRecordImpl(IO &IO, const char *Class, SymbolKind Kind, CodeViewYAML::SymbolRecord &Obj)
static Expected< CodeViewYAML::SymbolRecord > fromCodeViewSymbolImpl(CVSymbol Symbol)
Register Reg
#define T
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
#define LLVM_YAML_DECLARE_BITSET_TRAITS(Type)
#define LLVM_YAML_IS_SEQUENCE_VECTOR(type)
Utility for declaring that a std::vector of a particular type should be considered a YAML sequence.
#define LLVM_YAML_DECLARE_SCALAR_TRAITS(Type, MustQuote)
#define LLVM_YAML_IS_FLOW_SEQUENCE_VECTOR(type)
Utility for declaring that a std::vector of a particular type should be considered a YAML flow sequen...
#define LLVM_YAML_STRONG_TYPEDEF(_base, _type)
YAML I/O does conversion based on types. But often native data types are just a typedef of built in i...
#define LLVM_YAML_DECLARE_ENUM_TRAITS(Type)
An arbitrary precision integer that knows its signedness.
Definition APSInt.h:24
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
ArrayRef< T > drop_front(size_t N=1) const
Drop the first N elements of the array.
Definition ArrayRef.h:194
Lightweight error class with error context and mandatory checking.
Definition Error.h:159
static ErrorSuccess success()
Create a success value.
Definition Error.h:336
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
LLVM Value Representation.
Definition Value.h:75
ArrayRef< uint8_t > RecordData
Definition CVRecord.h:60
static Error deserializeAs(CVSymbol Symbol, T &Record)
static CVSymbol writeOneSymbol(SymType &Sym, BumpPtrAllocator &Storage, CodeViewContainer Container)
A 32-bit type reference.
Definition TypeIndex.h:97
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:54
A raw_ostream that writes to an std::string.
Specialized YAMLIO scalar type for representing a binary blob.
Definition YAML.h:64
void bitSetCase(T &Val, StringRef Str, const T ConstVal)
Definition YAMLTraits.h:760
virtual bool outputting() const =0
void enumCase(T &Val, StringRef Str, const T ConstVal)
Definition YAMLTraits.h:735
void mapOptional(StringRef Key, T &Val)
Definition YAMLTraits.h:800
void * getContext() const
void enumFallback(T &Val)
Definition YAMLTraits.h:749
void mapRequired(StringRef Key, T &Val)
Definition YAMLTraits.h:790
@ IMAGE_FILE_MACHINE_ARM64
Definition COFF.h:101
@ IMAGE_FILE_MACHINE_AMD64
Definition COFF.h:98
@ IMAGE_FILE_MACHINE_ARM64EC
Definition COFF.h:102
@ IMAGE_FILE_MACHINE_I386
Definition COFF.h:105
@ IMAGE_FILE_MACHINE_ARM64X
Definition COFF.h:103
@ IMAGE_FILE_MACHINE_ARMNT
Definition COFF.h:100
ProcSymFlags
Corresponds to the CV_PROCFLAGS bitfield.
Definition CodeView.h:415
LocalSymFlags
Corresponds to CV_LVARFLAGS bitfield.
Definition CodeView.h:388
LLVM_ABI EnumStrings< uint32_t, 1 > getFrameProcSymFlagNames()
CompileSym2Flags
Corresponds to COMPILESYM2::Flags bitfield.
Definition CodeView.h:429
LLVM_ABI EnumStrings< uint32_t, 1 > getCompileSym2FlagNames()
CPUType
These values correspond to the CV_CPU_TYPE_e enumeration, and are documented here: https://msdn....
Definition CodeView.h:76
LLVM_ABI EnumStrings< uint8_t, 1 > getThunkOrdinalNames()
CompileSym3Flags
Corresponds to COMPILESYM3::Flags bitfield.
Definition CodeView.h:445
LLVM_ABI EnumStrings< unsigned, 1 > getCPUTypeNames()
LLVM_ABI EnumStrings< uint16_t, 1 > getJumpTableEntrySizeNames()
CVRecord< SymbolKind > CVSymbol
Definition CVRecord.h:65
LLVM_ABI EnumStrings< uint16_t, 1 > getLocalFlagNames()
LLVM_ABI EnumStrings< uint32_t, 1 > getPublicSymFlagNames()
SymbolRecordKind
Distinguishes individual records in the Symbols subsection of a .debug$S section.
Definition CodeView.h:41
LLVM_ABI EnumStrings< uint16_t, 1 > getTrampolineNames()
LLVM_ABI EnumStrings< uint32_t, 1 > getCompileSym3FlagNames()
ThunkOrdinal
These values correspond to the THUNK_ORDINAL enumeration.
Definition CodeView.h:536
LLVM_ABI EnumStrings< SymbolKind, 1 > getSymbolTypeNames()
LLVM_ABI EnumStrings< uint16_t, 1 > getRegisterNames(CPUType Cpu)
LLVM_ABI EnumStrings< uint8_t, 1 > getFrameCookieKindNames()
SymbolKind
Duplicate copy of the above enum, but using the official CV names.
Definition CodeView.h:48
LLVM_ABI EnumStrings< uint8_t, 1 > getProcSymFlagNames()
LLVM_ABI EnumStrings< uint16_t, 1 > getExportSymFlagNames()
PublicSymFlags
Corresponds to the CV_PUBSYMFLAGS bitfield.
Definition CodeView.h:405
This is an optimization pass for GlobalISel generic memory operations.
Error make_error(ArgTs &&... Args)
Make a Error instance representing failure using the given error info type.
Definition Error.h:340
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition Allocator.h:390
LLVM_ABI codeview::CVSymbol toCodeViewSymbol(BumpPtrAllocator &Allocator, codeview::CodeViewContainer Container) const
std::shared_ptr< detail::SymbolRecordBase > Symbol
static LLVM_ABI Expected< SymbolRecord > fromCodeViewSymbol(codeview::CVSymbol Symbol)
virtual codeview::CVSymbol toCodeViewSymbol(BumpPtrAllocator &Allocator, CodeViewContainer Container) const =0
virtual Error fromCodeViewSymbol(codeview::CVSymbol Type)=0
codeview::CVSymbol toCodeViewSymbol(BumpPtrAllocator &Allocator, CodeViewContainer Container) const override
Error fromCodeViewSymbol(codeview::CVSymbol CVS) override
CVSymbol toCodeViewSymbol(BumpPtrAllocator &Allocator, CodeViewContainer Container) const override
static void mapping(IO &io, LocalVariableAddrGap &Gap)
static void mapping(IO &io, LocalVariableAddrRange &Range)
static void mapping(IO &io, SymbolRecordBase &Record)
This class should be specialized by any type that needs to be converted to/from a YAML mapping.
Definition YAMLTraits.h:63
This class should be specialized by any integer type that is a union of bit values and the YAML repre...
Definition YAMLTraits.h:124
This class should be specialized by any integral type that converts to/from a YAML scalar where there...
Definition YAMLTraits.h:108
This class should be specialized by type that requires custom conversion to/from a yaml scalar.
Definition YAMLTraits.h:150