class GsymCreator

Declaration

class GsymCreator { /* full declaration omitted */ };

Description

GsymCreator is used to emit GSYM data to a stand alone file or section within a file. The GsymCreator is designed to be used in 3 stages: - Create FunctionInfo objects and add them - Finalize the GsymCreator object - Save to file or section The first stage involves creating FunctionInfo objects from another source of information like compiler debug info metadata, DWARF or Breakpad files. Any strings in the FunctionInfo or contained information, like InlineInfo or LineTable objects, should get the string table offsets by calling GsymCreator::insertString(...). Any file indexes that are needed should be obtained by calling GsymCreator::insertFile(...). All of the function calls in GsymCreator are thread safe. This allows multiple threads to create and add FunctionInfo objects while parsing debug information. Once all of the FunctionInfo objects have been added, the GsymCreator::finalize(...) must be called prior to saving. This function will sort the FunctionInfo objects, finalize the string table, and do any other passes on the information needed to prepare the information to be saved. Once the object has been finalized, it can be saved to a file or section. ENCODING GSYM files are designed to be memory mapped into a process as shared, read only data, and used as is. The GSYM file format when in a stand alone file consists of: - Header - Address Table - Function Info Offsets - File Table - String Table - Function Info Data HEADER The header is fully described in "llvm/DebugInfo/GSYM/Header.h". ADDRESS TABLE The address table immediately follows the header in the file and consists of Header.NumAddresses address offsets. These offsets are sorted and can be binary searched for efficient lookups. Addresses in the address table are stored as offsets from a 64 bit base address found in Header.BaseAddress. This allows the address table to contain 8, 16, or 32 offsets. This allows the address table to not require full 64 bit addresses for each address. The resulting GSYM size is smaller and causes fewer pages to be touched during address lookups when the address table is smaller. The size of the address offsets in the address table is specified in the header in Header.AddrOffSize. The first offset in the address table is aligned to Header.AddrOffSize alignment to ensure efficient access when loaded into memory. FUNCTION INFO OFFSETS TABLE The function info offsets table immediately follows the address table and consists of Header.NumAddresses 32 bit file offsets: one for each address in the address table. This data is aligned to a 4 byte boundary. The offsets in this table are the relative offsets from the start offset of the GSYM header and point to the function info data for each address in the address table. Keeping this data separate from the address table helps to reduce the number of pages that are touched when address lookups occur on a GSYM file. FILE TABLE The file table immediately follows the function info offsets table. The encoding of the FileTable is: struct FileTable { uint32_t Count; FileEntry Files[]; }; The file table starts with a 32 bit count of the number of files that are used in all of the function info, followed by that number of FileEntry structures. The file table is aligned to a 4 byte boundary, Each file in the file table is represented with a FileEntry structure. See "llvm/DebugInfo/GSYM/FileEntry.h" for details. STRING TABLE The string table follows the file table in stand alone GSYM files and contains all strings for everything contained in the GSYM file. Any string data should be added to the string table and any references to strings inside GSYM information must be stored as 32 bit string table offsets into this string table. The string table always starts with an empty string at offset zero and is followed by any strings needed by the GSYM information. The start of the string table is not aligned to any boundary. FUNCTION INFO DATA The function info data is the payload that contains information about the address that is being looked up. It contains all of the encoded FunctionInfo objects. Each encoded FunctionInfo's data is pointed to by an entry in the Function Info Offsets Table. For details on the exact encoding of FunctionInfo objects, see "llvm/DebugInfo/GSYM/FunctionInfo.h".

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:133

Method Overview

  • public GsymCreator()
  • public void addFunctionInfo(llvm::gsym::FunctionInfo && FI)
  • public llvm::Error encode(llvm::gsym::FileWriter & O) const
  • public llvm::Error finalize(llvm::raw_ostream & OS)
  • public void forEachFunctionInfo(const std::function<bool (FunctionInfo &)> & Callback)
  • public void forEachFunctionInfo(const std::function<bool (const FunctionInfo &)> & Callback) const
  • public uint32_t insertFile(llvm::StringRef Path, sys::path::Style Style = sys::path::Style::native)
  • public uint32_t insertString(llvm::StringRef S)
  • public llvm::Error save(llvm::StringRef Path, llvm::support::endianness ByteOrder) const
  • public void setUUID(llvm::ArrayRef<uint8_t> UUIDBytes)

Methods

GsymCreator()

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:145

void addFunctionInfo(
    llvm::gsym::FunctionInfo&& FI)

Description

Add a function info to this GSYM creator. All information in the FunctionInfo object must use the GsymCreator::insertString(...) function when creating string table offsets for names and other strings.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:190

Parameters

llvm::gsym::FunctionInfo&& FI
The function info object to emplace into our functions list.

llvm::Error encode(
    llvm::gsym::FileWriter& O) const

Description

Encode a GSYM into the file writer stream at the current position.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:158

Parameters

llvm::gsym::FileWriter& O
The stream to save the binary data to

Returns

An error object that indicates success or failure of the save.

llvm::Error finalize(llvm::raw_ostream& OS)

Description

Finalize the data in the GSYM creator prior to saving the data out. Finalize must be called after all FunctionInfo objects have been added and before GsymCreator::save() is called.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:201

Parameters

llvm::raw_ostream& OS
Output stream to report duplicate function infos, overlapping function infos, and function infos that were merged or removed.

Returns

An error object that indicates success or failure of the finalize.

void forEachFunctionInfo(
    const std::function<bool(FunctionInfo&)>&
        Callback)

Description

Thread safe iteration over all function infos.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:214

Parameters

const std::function<bool(FunctionInfo&)>& Callback
A callback function that will get called with each FunctionInfo. If the callback returns false, stop iterating.

void forEachFunctionInfo(
    const std::function<bool(
        const FunctionInfo&)>& Callback) const

Description

Thread safe const iteration over all function infos.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:221

Parameters

const std::function<bool(const FunctionInfo&)>& Callback
A callback function that will get called with each FunctionInfo. If the callback returns false, stop iterating.

uint32_t insertFile(llvm::StringRef Path,
                    sys::path::Style Style =
                        sys::path::Style::native)

Description

Insert a file into this GSYM creator. Inserts a file by adding a FileEntry into the "Files" member variable if the file has not already been added. The file path is split into directory and filename which are both added to the string table. This allows paths to be stored efficiently by reusing the directories that are common between multiple files.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:180

Parameters

llvm::StringRef Path
The path to the file to insert.
sys::path::Style Style = sys::path::Style::native
The path style for the "Path" parameter.

Returns

The unique file index for the inserted file.

uint32_t insertString(llvm::StringRef S)

Description

Insert a string into the GSYM string table. All strings used by GSYM files must be uniqued by adding them to this string pool and using the returned offset for any string values.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:167

Parameters

llvm::StringRef S
The string to insert into the string table.

Returns

The unique 32 bit offset into the string table.

llvm::Error save(
    llvm::StringRef Path,
    llvm::support::endianness ByteOrder) const

Description

Save a GSYM file to a stand alone file.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:152

Parameters

llvm::StringRef Path
The file path to save the GSYM file to.
llvm::support::endianness ByteOrder
The endianness to use when saving the file.

Returns

An error object that indicates success or failure of the save.

void setUUID(llvm::ArrayRef<uint8_t> UUIDBytes)

Description

Set the UUID value.

Declared at: llvm/include/llvm/DebugInfo/GSYM/GsymCreator.h:206

Parameters

llvm::ArrayRef<uint8_t> UUIDBytes
The new UUID bytes.