003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/include/llvm/DebugInfo/GSYM
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
include
/
llvm
/
DebugInfo
/
GSYM
/
📁
..
📄
DwarfTransformer.h
(3.09 KB)
📄
FileEntry.h
(2.08 KB)
📄
FileWriter.h
(4.41 KB)
📄
FunctionInfo.h
(8.4 KB)
📄
GsymCreator.h
(12.41 KB)
📄
GsymReader.h
(11.86 KB)
📄
Header.h
(5.55 KB)
📄
InlineInfo.h
(8.07 KB)
📄
LineEntry.h
(1.77 KB)
📄
LineTable.h
(9 KB)
📄
LookupResult.h
(2.43 KB)
📄
ObjectFileTransformer.h
(1.53 KB)
📄
Range.h
(4.65 KB)
📄
StringTable.h
(1.58 KB)
Editing: DwarfTransformer.h
//===- DwarfTransformer.h ---------------------------------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #ifndef LLVM_DEBUGINFO_GSYM_DWARFTRANSFORMER_H #define LLVM_DEBUGINFO_GSYM_DWARFTRANSFORMER_H #include "llvm/ADT/StringRef.h" #include "llvm/DebugInfo/GSYM/Range.h" #include "llvm/Support/Error.h" namespace llvm { class raw_ostream; namespace gsym { struct CUInfo; struct FunctionInfo; class GsymCreator; /// A class that transforms the DWARF in a DWARFContext into GSYM information /// by populating the GsymCreator object that it is constructed with. This /// class supports converting all DW_TAG_subprogram DIEs into /// gsym::FunctionInfo objects that includes line table information and inline /// function information. Creating a separate class to transform this data /// allows this class to be unit tested. class DwarfTransformer { public: /// Create a DWARF transformer. /// /// \param D The DWARF to use when converting to GSYM. /// /// \param OS The stream to log warnings and non fatal issues to. /// /// \param G The GSYM creator to populate with the function information /// from the debug info. DwarfTransformer(DWARFContext &D, raw_ostream &OS, GsymCreator &G) : DICtx(D), Log(OS), Gsym(G) {} /// Extract the DWARF from the supplied object file and convert it into the /// Gsym format in the GsymCreator object that is passed in. Returns an /// error if something fatal is encountered. /// /// \returns An error indicating any fatal issues that happen when parsing /// the DWARF, or Error::success() if all goes well. llvm::Error convert(uint32_t NumThreads); llvm::Error verify(StringRef GsymPath); private: /// Parse the DWARF in the object file and convert it into the GsymCreator. Error parse(); /// Handle any DIE (debug info entry) from the DWARF. /// /// This function will find all DW_TAG_subprogram DIEs that convert them into /// GSYM FuntionInfo objects and add them to the GsymCreator supplied during /// construction. The DIE and all its children will be recursively parsed /// with calls to this function. /// /// \param Strm The thread specific log stream for any non fatal errors and /// warnings. Once a thread has finished parsing an entire compile unit, all /// information in this temporary stream will be forwarded to the member /// variable log. This keeps logging thread safe. /// /// \param CUI The compile unit specific information that contains the DWARF /// line table, cached file list, and other compile unit specific /// information. /// /// \param Die The DWARF debug info entry to parse. void handleDie(raw_ostream &Strm, CUInfo &CUI, DWARFDie Die); DWARFContext &DICtx; raw_ostream &Log; GsymCreator &Gsym; friend class DwarfTransformerTest; }; } // namespace gsym } // namespace llvm #endif // #ifndef LLVM_DEBUGINFO_GSYM_DWARFTRANSFORMER_H
Upload File
Create Folder