mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
ca7680b998
implementation already lived. After this commit, the only IR-library headers in include/llvm/* are ones related to the legacy pass infrastructure that I'm planning to leave there until the new one is farther along. The only other headers at the top level are linking and initialization aids that aren't really libraries but just headers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203069 91177308-0d34-0410-b5e6-96231b3b80d8
63 lines
2.0 KiB
C++
63 lines
2.0 KiB
C++
//===- GVMaterializer.h - Interface for GV materializers --------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file provides an abstract interface for loading a module from some
|
|
// place. This interface allows incremental or random access loading of
|
|
// functions from the file. This is useful for applications like JIT compilers
|
|
// or interprocedural optimizers that do not need the entire program in memory
|
|
// at the same time.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_IR_GVMATERIALIZER_H
|
|
#define LLVM_IR_GVMATERIALIZER_H
|
|
|
|
#include "llvm/Support/system_error.h"
|
|
|
|
namespace llvm {
|
|
|
|
class Function;
|
|
class GlobalValue;
|
|
class Module;
|
|
|
|
class GVMaterializer {
|
|
protected:
|
|
GVMaterializer() {}
|
|
|
|
public:
|
|
virtual ~GVMaterializer();
|
|
|
|
/// isMaterializable - True if GV can be materialized from whatever backing
|
|
/// store this GVMaterializer uses and has not been materialized yet.
|
|
virtual bool isMaterializable(const GlobalValue *GV) const = 0;
|
|
|
|
/// isDematerializable - True if GV has been materialized and can be
|
|
/// dematerialized back to whatever backing store this GVMaterializer uses.
|
|
virtual bool isDematerializable(const GlobalValue *GV) const = 0;
|
|
|
|
/// Materialize - make sure the given GlobalValue is fully read.
|
|
///
|
|
virtual error_code Materialize(GlobalValue *GV) = 0;
|
|
|
|
/// Dematerialize - If the given GlobalValue is read in, and if the
|
|
/// GVMaterializer supports it, release the memory for the GV, and set it up
|
|
/// to be materialized lazily. If the Materializer doesn't support this
|
|
/// capability, this method is a noop.
|
|
///
|
|
virtual void Dematerialize(GlobalValue *) {}
|
|
|
|
/// MaterializeModule - make sure the entire Module has been completely read.
|
|
///
|
|
virtual error_code MaterializeModule(Module *M) = 0;
|
|
};
|
|
|
|
} // End llvm namespace
|
|
|
|
#endif
|