mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +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
 |