1//===- CodeGenDataReader.h --------------------------------------*- C++ -*-===//
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
7//===----------------------------------------------------------------------===//
9// This file contains support for reading codegen data.
11//===----------------------------------------------------------------------===//
13#ifndef LLVM_CGDATA_CODEGENDATAREADER_H
14#define LLVM_CGDATA_CODEGENDATAREADER_H
27 std::string LastErrorMsg;
33 /// Read the header. Required before reading first record.
35 /// Return the codegen data version.
37 /// Return the codegen data kind.
39 /// Return true if the data has an outlined hash tree.
41 /// Return true if the data has a stable function map.
43 /// Return the outlined hash tree that is released from the reader.
51 /// Factory method to create an appropriately typed reader for the given
52 /// codegen data file path and file system.
56 /// Factory method to create an appropriately typed reader for the given
59 create(std::unique_ptr<MemoryBuffer> Buffer);
61 /// Extract the cgdata embedded in sections from the given object file and
62 /// merge them into the GlobalOutlineRecord. This is a static helper that
63 /// is used by `llvm-cgdata --merge` or ThinLTO's two-codegen rounds.
64 /// Optionally, \p CombinedHash can be used to compuate the combined hash of
73 /// The outlined hash tree that has been read. When it's released by
74 /// releaseOutlinedHashTree(), it's no longer valid.
77 /// The stable function map that has been read. When it's released by
78 // releaseStableFunctionMap(), it's no longer valid.
81 /// Set the current error and return same.
84 LastErrorMsg = ErrMsg;
92 LastError = IPE.
get();
98 /// Clear the current error and return a successful one.
103 /// The codegen data file contents.
104 std::unique_ptr<MemoryBuffer> DataBuffer;
110 : DataBuffer(
std::
move(DataBuffer)) {}
115 /// Return true if the given buffer is in binary codegen data format.
117 /// Read the contents including the header.
119 /// Return the codegen data version.
121 /// Return the codegen data kind.
123 return static_cast<CGDataKind >(Header.DataKind);
125 /// Return true if the header indicates the data has an outlined hash tree.
126 /// This does not mean that the data is still available.
128 return Header.DataKind &
131 /// Return true if the header indicates the data has a stable function map.
133 return Header.DataKind &
138/// This format is a simple text format that's suitable for test data.
139/// The header is a custom format starting with `:` per line to indicate which
140/// codegen data is recorded. `#` is used to indicate a comment.
141/// The subsequent data is a YAML format per each codegen data in order.
142/// Currently, it only has a function outlined hash tree.
144 /// The codegen data file contents.
145 std::unique_ptr<MemoryBuffer> DataBuffer;
146 /// Iterator over the profile data.
148 /// Describe the kind of the codegen data.
153 : DataBuffer(
std::
move(DataBuffer_)), Line(*DataBuffer,
true,
'#') {}
157 /// Return true if the given buffer is in text codegen data format.
159 /// Read the contents including the header.
161 /// Text format does not have version, so return 0.
163 /// Return the codegen data kind.
165 /// Return true if the header indicates the data has an outlined hash tree.
166 /// This does not mean that the data is still available.
168 return static_cast<uint32_t >(DataKind) &
171 /// Return true if the header indicates the data has a stable function map.
172 /// This does not mean that the data is still available.
174 return static_cast<uint32_t >(DataKind) &
179}
// end namespace llvm
181#endif // LLVM_CGDATA_CODEGENDATAREADER_H
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
Defines the virtual file system interface vfs::FileSystem.
const std::string & getMessage() const
virtual bool hasOutlinedHashTree() const =0
Return true if the data has an outlined hash tree.
Error success()
Clear the current error and return a successful one.
virtual ~CodeGenDataReader()=default
virtual bool hasStableFunctionMap() const =0
Return true if the data has a stable function map.
virtual uint32_t getVersion() const =0
Return the codegen data version.
OutlinedHashTreeRecord HashTreeRecord
The outlined hash tree that has been read.
CodeGenDataReader()=default
static LLVM_ABI Expected< std::unique_ptr< CodeGenDataReader > > create(const Twine &Path, vfs::FileSystem &FS)
Factory method to create an appropriately typed reader for the given codegen data file path and file ...
Error error(cgdata_error Err, const std::string &ErrMsg="")
Set the current error and return same.
std::unique_ptr< StableFunctionMap > releaseStableFunctionMap()
StableFunctionMapRecord FunctionMapRecord
The stable function map that has been read. When it's released by.
virtual CGDataKind getDataKind() const =0
Return the codegen data kind.
virtual Error read()=0
Read the header. Required before reading first record.
static LLVM_ABI Error mergeFromObjectFile(const object::ObjectFile *Obj, OutlinedHashTreeRecord &GlobalOutlineRecord, StableFunctionMapRecord &GlobalFunctionMapRecord, stable_hash *CombinedHash=nullptr)
Extract the cgdata embedded in sections from the given object file and merge them into the GlobalOutl...
std::unique_ptr< OutlinedHashTree > releaseOutlinedHashTree()
Return the outlined hash tree that is released from the reader.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
static bool hasFormat(const MemoryBuffer &Buffer)
Return true if the given buffer is in binary codegen data format.
Error read() override
Read the contents including the header.
bool hasStableFunctionMap() const override
Return true if the header indicates the data has a stable function map.
IndexedCodeGenDataReader(const IndexedCodeGenDataReader &)=delete
bool hasOutlinedHashTree() const override
Return true if the header indicates the data has an outlined hash tree.
IndexedCodeGenDataReader(std::unique_ptr< MemoryBuffer > DataBuffer)
CGDataKind getDataKind() const override
Return the codegen data kind.
IndexedCodeGenDataReader & operator=(const IndexedCodeGenDataReader &)=delete
uint32_t getVersion() const override
Return the codegen data version.
This interface provides simple read-only access to a block of memory, and provides simple methods for...
static bool hasFormat(const MemoryBuffer &Buffer)
Return true if the given buffer is in text codegen data format.
bool hasStableFunctionMap() const override
Return true if the header indicates the data has a stable function map.
bool hasOutlinedHashTree() const override
Return true if the header indicates the data has an outlined hash tree.
Error read() override
Read the contents including the header.
TextCodeGenDataReader & operator=(const TextCodeGenDataReader &)=delete
uint32_t getVersion() const override
Text format does not have version, so return 0.
TextCodeGenDataReader(const TextCodeGenDataReader &)=delete
TextCodeGenDataReader(std::unique_ptr< MemoryBuffer > DataBuffer_)
CGDataKind getDataKind() const override
Return the codegen data kind.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
A forward iterator which reads text lines from a buffer.
This class is the base class for all object file types.
The virtual file system interface.
This is an optimization pass for GlobalISel generic memory operations.
@ StableFunctionMergingMap
@ FunctionOutlinedHashTree
void handleAllErrors(Error E, HandlerTs &&... Handlers)
Behaves the same as handleErrors, except that by contract all errors must be handled by the given han...
uint64_t stable_hash
An opaque object representing a stable hash code.
Error make_error(ArgTs &&... Args)
Make a Error instance representing failure using the given error info type.
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Implement std::hash so that hash_code can be used in STL containers.
The structure of the serialized stable function map is as follows: