mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	They just propagate out the bitcode reader error, so we don't need a new enum. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194091 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			63 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
//===-- llvm/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_GVMATERIALIZER_H
 | 
						|
#define LLVM_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
 |