//===-- 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; } void Nios2InstrInfo::copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator I, const DebugLoc &DL, unsigned DestReg, unsigned SrcReg, bool KillSrc) const { unsigned opc = Subtarget.hasNios2r2() ? Nios2::ADD_R2 : Nios2::ADD_R1; BuildMI(MBB, I, DL, get(opc)) .addReg(DestReg, RegState::Define) .addReg(Nios2::ZERO) .addReg(SrcReg, getKillRegState(KillSrc)); }