//===- LanaiInstrInfo.h - Lanai Instruction Information ---------*- C++ -*-===// // // 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 Lanai implementation of the TargetInstrInfo class. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_LANAI_LANAIINSTRINFO_H #define LLVM_LIB_TARGET_LANAI_LANAIINSTRINFO_H #include "LanaiRegisterInfo.h" #include "llvm/Target/TargetInstrInfo.h" #define GET_INSTRINFO_HEADER #include "LanaiGenInstrInfo.inc" namespace llvm { class LanaiInstrInfo : public LanaiGenInstrInfo { const LanaiRegisterInfo RegisterInfo; public: LanaiInstrInfo(); // getRegisterInfo - TargetInstrInfo is a superset of MRegister info. As // such, whenever a client has an instance of instruction info, it should // always be able to get register info as well (through this method). virtual const LanaiRegisterInfo &getRegisterInfo() const { return RegisterInfo; } bool areMemAccessesTriviallyDisjoint(MachineInstr *MIa, MachineInstr *MIb, AliasAnalysis *AA) const override; unsigned isLoadFromStackSlot(const MachineInstr *MI, int &FrameIndex) const override; unsigned isLoadFromStackSlotPostFE(const MachineInstr *MI, int &FrameIndex) const override; unsigned isStoreToStackSlot(const MachineInstr *MI, int &FrameIndex) const override; void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator Position, DebugLoc DL, unsigned DestinationRegister, unsigned SourceRegister, bool KillSource) const override; void storeRegToStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator Position, unsigned SourceRegister, bool IsKill, int FrameIndex, const TargetRegisterClass *RegisterClass, const TargetRegisterInfo *RegisterInfo) const override; void loadRegFromStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator Position, unsigned DestinationRegister, int FrameIndex, const TargetRegisterClass *RegisterClass, const TargetRegisterInfo *RegisterInfo) const override; bool expandPostRAPseudo(MachineBasicBlock::iterator MI) const override; bool getMemOpBaseRegImmOfs(MachineInstr *LdSt, unsigned &BaseReg, int64_t &Offset, const TargetRegisterInfo *TRI) const override; bool getMemOpBaseRegImmOfsWidth(MachineInstr *LdSt, unsigned &BaseReg, int64_t &Offset, unsigned &Width, const TargetRegisterInfo *TRI) const; bool AnalyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TrueBlock, MachineBasicBlock *&FalseBlock, SmallVectorImpl &Condition, bool AllowModify) const override; unsigned RemoveBranch(MachineBasicBlock &MBB) const override; bool ReverseBranchCondition( SmallVectorImpl &Condition) const override; unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TrueBlock, MachineBasicBlock *FalseBlock, ArrayRef Condition, DebugLoc DL) const override; }; static inline bool isSPLSOpcode(unsigned Opcode) { switch (Opcode) { case Lanai::LDBs_RI: case Lanai::LDBz_RI: case Lanai::LDHs_RI: case Lanai::LDHz_RI: case Lanai::STB_RI: case Lanai::STH_RI: return true; default: return false; } } static inline bool isRMOpcode(unsigned Opcode) { switch (Opcode) { case Lanai::LDW_RI: case Lanai::SW_RI: return true; default: return false; } } static inline bool isRRMOpcode(unsigned Opcode) { switch (Opcode) { case Lanai::LDBs_RR: case Lanai::LDBz_RR: case Lanai::LDHs_RR: case Lanai::LDHz_RR: case Lanai::LDWz_RR: case Lanai::LDW_RR: case Lanai::STB_RR: case Lanai::STH_RR: case Lanai::SW_RR: return true; default: return false; } } } // namespace llvm #endif // LLVM_LIB_TARGET_LANAI_LANAIINSTRINFO_H