mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	creation functions in their public header file, unless they can help it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1816 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			30 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
//===-- MethodInlining.h - Functions that perform Inlining -------*- C++ -*--=//
 | 
						|
//
 | 
						|
// This family of functions is useful for performing method inlining.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#ifndef LLVM_TRANSFORMS_METHOD_INLINING_H
 | 
						|
#define LLVM_TRANSFORMS_METHOD_INLINING_H
 | 
						|
 | 
						|
#include "llvm/BasicBlock.h"
 | 
						|
class CallInst;
 | 
						|
class Pass;
 | 
						|
 | 
						|
Pass *createMethodInliningPass();
 | 
						|
 | 
						|
// InlineMethod - This function forcibly inlines the called method into the
 | 
						|
// basic block of the caller.  This returns true if it is not possible to inline
 | 
						|
// this call.  The program is still in a well defined state if this occurs 
 | 
						|
// though.
 | 
						|
//
 | 
						|
// Note that this only does one level of inlining.  For example, if the 
 | 
						|
// instruction 'call B' is inlined, and 'B' calls 'C', then the call to 'C' now 
 | 
						|
// exists in the instruction stream.  Similiarly this will inline a recursive
 | 
						|
// method by one level.
 | 
						|
//
 | 
						|
bool InlineMethod(CallInst *C);
 | 
						|
bool InlineMethod(BasicBlock::iterator CI);  // *CI must be CallInst
 | 
						|
 | 
						|
#endif
 |