You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			44 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|   | //===-- Nios2InstrInfo.cpp - Nios2 Instruction Information ----------------===//
 | ||
|  | //
 | ||
|  | //                     The LLVM Compiler Infrastructure
 | ||
|  | //
 | ||
|  | // This file is distributed under the University of Illinois Open Source
 | ||
|  | // License. See LICENSE.TXT for details.
 | ||
|  | //
 | ||
|  | //===----------------------------------------------------------------------===//
 | ||
|  | //
 | ||
|  | // This file contains the Nios2 implementation of the TargetInstrInfo class.
 | ||
|  | //
 | ||
|  | //===----------------------------------------------------------------------===//
 | ||
|  | 
 | ||
|  | #include "Nios2InstrInfo.h"
 | ||
|  | #include "Nios2TargetMachine.h"
 | ||
|  | #include "llvm/CodeGen/MachineInstrBuilder.h"
 | ||
|  | 
 | ||
|  | using namespace llvm; | ||
|  | 
 | ||
|  | #define GET_INSTRINFO_CTOR_DTOR
 | ||
|  | #include "Nios2GenInstrInfo.inc"
 | ||
|  | 
 | ||
|  | // Pin the vtable to this file.
 | ||
|  | void Nios2InstrInfo::anchor() {} | ||
|  | 
 | ||
|  | Nios2InstrInfo::Nios2InstrInfo(Nios2Subtarget &ST) | ||
|  |     : Nios2GenInstrInfo(), RI(ST), Subtarget(ST) {} | ||
|  | 
 | ||
|  | /// Expand Pseudo instructions into real backend instructions
 | ||
|  | bool Nios2InstrInfo::expandPostRAPseudo(MachineInstr &MI) const { | ||
|  |   MachineBasicBlock &MBB = *MI.getParent(); | ||
|  | 
 | ||
|  |   switch (MI.getDesc().getOpcode()) { | ||
|  |   default: | ||
|  |     return false; | ||
|  |   case Nios2::RetRA: | ||
|  |     BuildMI(MBB, MI, MI.getDebugLoc(), get(Nios2::RET_R1)).addReg(Nios2::RA); | ||
|  |     break; | ||
|  |   } | ||
|  | 
 | ||
|  |   MBB.erase(MI); | ||
|  |   return true; | ||
|  | } |