mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110460 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===-------------- llvm/CodeGen/ProcessImplicitDefs.h ----------*- C++ -*-===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is distributed under the University of Illinois Open Source
 | |
| // License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| 
 | |
| #ifndef LLVM_CODEGEN_PROCESSIMPLICITDEFS_H
 | |
| #define LLVM_CODEGEN_PROCESSIMPLICITDEFS_H
 | |
| 
 | |
| #include "llvm/CodeGen/MachineFunctionPass.h"
 | |
| #include "llvm/ADT/SmallSet.h"
 | |
| 
 | |
| namespace llvm {
 | |
| 
 | |
|   class MachineInstr;
 | |
|   class TargetInstrInfo;
 | |
| 
 | |
|   /// Process IMPLICIT_DEF instructions and make sure there is one implicit_def
 | |
|   /// for each use. Add isUndef marker to implicit_def defs and their uses.
 | |
|   class ProcessImplicitDefs : public MachineFunctionPass {
 | |
|   private:
 | |
| 
 | |
|     bool CanTurnIntoImplicitDef(MachineInstr *MI, unsigned Reg,
 | |
|                                 unsigned OpIdx, const TargetInstrInfo *tii_,
 | |
|                                 SmallSet<unsigned, 8> &ImpDefRegs);
 | |
| 
 | |
|   public:
 | |
|     static char ID;
 | |
| 
 | |
|     ProcessImplicitDefs() : MachineFunctionPass(ID) {}
 | |
| 
 | |
|     virtual void getAnalysisUsage(AnalysisUsage &au) const;
 | |
| 
 | |
|     virtual bool runOnMachineFunction(MachineFunction &fn);
 | |
|   };
 | |
| 
 | |
| }
 | |
| 
 | |
| #endif // LLVM_CODEGEN_PROCESSIMPLICITDEFS_H
 |