mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
8266df7f7f
For another 1% speedup on the testcase in PR23865, push the `ModuleSlotTracker` through to metadata-related printing in `MachineBasicBlock::print()`. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@240848 91177308-0d34-0410-b5e6-96231b3b80d8
69 lines
2.2 KiB
C++
69 lines
2.2 KiB
C++
//===-- llvm/IR/ModuleSlotTracker.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_IR_MODULESLOTTRACKER_H
|
|
#define LLVM_IR_MODULESLOTTRACKER_H
|
|
|
|
#include <memory>
|
|
|
|
namespace llvm {
|
|
|
|
class Module;
|
|
class Function;
|
|
class SlotTracker;
|
|
|
|
/// Manage lifetime of a slot tracker for printing IR.
|
|
///
|
|
/// Wrapper around the \a SlotTracker used internally by \a AsmWriter. This
|
|
/// class allows callers to share the cost of incorporating the metadata in a
|
|
/// module or a function.
|
|
///
|
|
/// If the IR changes from underneath \a ModuleSlotTracker, strings like
|
|
/// "<badref>" will be printed, or, worse, the wrong slots entirely.
|
|
class ModuleSlotTracker {
|
|
/// Storage for a slot tracker.
|
|
std::unique_ptr<SlotTracker> MachineStorage;
|
|
|
|
const Module *M = nullptr;
|
|
const Function *F = nullptr;
|
|
SlotTracker *Machine = nullptr;
|
|
|
|
public:
|
|
/// Wrap a preinitialized SlotTracker.
|
|
ModuleSlotTracker(SlotTracker &Machine, const Module *M,
|
|
const Function *F = nullptr);
|
|
|
|
/// Construct a slot tracker from a module.
|
|
///
|
|
/// If \a M is \c nullptr, uses a null slot tracker. Otherwise, initializes
|
|
/// a slot tracker, and initializes all metadata slots. \c
|
|
/// ShouldInitializeAllMetadata defaults to true because this is expected to
|
|
/// be shared between multiple callers, and otherwise MDNode references will
|
|
/// not match up.
|
|
explicit ModuleSlotTracker(const Module *M,
|
|
bool ShouldInitializeAllMetadata = true);
|
|
|
|
/// Destructor to clean up storage.
|
|
~ModuleSlotTracker();
|
|
|
|
SlotTracker *getMachine() const { return Machine; }
|
|
const Module *getModule() const { return M; }
|
|
const Function *getCurrentFunction() const { return F; }
|
|
|
|
/// Incorporate the given function.
|
|
///
|
|
/// Purge the currently incorporated function and incorporate \c F. If \c F
|
|
/// is currently incorporated, this is a no-op.
|
|
void incorporateFunction(const Function &F);
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif
|