mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 02:22:29 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21412 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===- PromoteMemToReg.h - Promote Allocas to Scalars -----------*- C++ -*-===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file was developed by the LLVM research group and is distributed under
 | |
| // the University of Illinois Open Source License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| // This file exposes an interface to promote alloca instructions to SSA
 | |
| // registers, by using the SSA construction algorithm.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #ifndef TRANSFORMS_UTILS_PROMOTEMEMTOREG_H
 | |
| #define TRANSFORMS_UTILS_PROMOTEMEMTOREG_H
 | |
| 
 | |
| #include <vector>
 | |
| 
 | |
| namespace llvm {
 | |
| 
 | |
| class AllocaInst;
 | |
| struct DominatorTree;
 | |
| struct DominanceFrontier;
 | |
| class TargetData;
 | |
| class AliasSetTracker;
 | |
| 
 | |
| /// isAllocaPromotable - Return true if this alloca is legal for promotion.
 | |
| /// This is true if there are only loads and stores to the alloca...
 | |
| ///
 | |
| bool isAllocaPromotable(const AllocaInst *AI, const TargetData &TD);
 | |
| 
 | |
| /// PromoteMemToReg - Promote the specified list of alloca instructions into
 | |
| /// scalar registers, inserting PHI nodes as appropriate.  This function makes
 | |
| /// use of DominanceFrontier information.  This function does not modify the CFG
 | |
| /// of the function at all.  All allocas must be from the same function.
 | |
| ///
 | |
| /// If AST is specified, the specified tracker is updated to reflect changes
 | |
| /// made to the IR.
 | |
| ///
 | |
| void PromoteMemToReg(const std::vector<AllocaInst*> &Allocas,
 | |
|                      DominatorTree &DT, DominanceFrontier &DF,
 | |
|                      const TargetData &TD, AliasSetTracker *AST = 0);
 | |
| 
 | |
| } // End llvm namespace
 | |
| 
 | |
| #endif
 |