12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- //===- NVPTXInstrInfo.h - NVPTX Instruction Information----------*- C++ -*-===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- //
- // This file contains the NVPTX implementation of the TargetInstrInfo class.
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_LIB_TARGET_NVPTX_NVPTXINSTRINFO_H
- #define LLVM_LIB_TARGET_NVPTX_NVPTXINSTRINFO_H
- #include "NVPTX.h"
- #include "NVPTXRegisterInfo.h"
- #include "llvm/CodeGen/TargetInstrInfo.h"
- #define GET_INSTRINFO_HEADER
- #include "NVPTXGenInstrInfo.inc"
- namespace llvm {
- class NVPTXInstrInfo : public NVPTXGenInstrInfo {
- const NVPTXRegisterInfo RegInfo;
- virtual void anchor();
- public:
- explicit NVPTXInstrInfo();
- const NVPTXRegisterInfo &getRegisterInfo() const { return RegInfo; }
- /* The following virtual functions are used in register allocation.
- * They are not implemented because the existing interface and the logic
- * at the caller side do not work for the elementized vector load and store.
- *
- * virtual unsigned isLoadFromStackSlot(const MachineInstr *MI,
- * int &FrameIndex) const;
- * virtual unsigned isStoreToStackSlot(const MachineInstr *MI,
- * int &FrameIndex) const;
- * virtual void storeRegToStackSlot(MachineBasicBlock &MBB,
- * MachineBasicBlock::iterator MBBI,
- * unsigned SrcReg, bool isKill, int FrameIndex,
- * const TargetRegisterClass *RC) const;
- * virtual void loadRegFromStackSlot(MachineBasicBlock &MBB,
- * MachineBasicBlock::iterator MBBI,
- * unsigned DestReg, int FrameIndex,
- * const TargetRegisterClass *RC) const;
- */
- void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator I,
- const DebugLoc &DL, MCRegister DestReg, MCRegister SrcReg,
- bool KillSrc) const override;
- // Branch analysis.
- bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB,
- MachineBasicBlock *&FBB,
- SmallVectorImpl<MachineOperand> &Cond,
- bool AllowModify) const override;
- unsigned removeBranch(MachineBasicBlock &MBB,
- int *BytesRemoved = nullptr) const override;
- unsigned insertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB,
- MachineBasicBlock *FBB, ArrayRef<MachineOperand> Cond,
- const DebugLoc &DL,
- int *BytesAdded = nullptr) const override;
- };
- } // namespace llvm
- #endif
|