diff options
Diffstat (limited to 'contrib/llvm-project/llvm/lib/Target/LoongArch/LoongArchInstrInfo.h')
-rw-r--r-- | contrib/llvm-project/llvm/lib/Target/LoongArch/LoongArchInstrInfo.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/contrib/llvm-project/llvm/lib/Target/LoongArch/LoongArchInstrInfo.h b/contrib/llvm-project/llvm/lib/Target/LoongArch/LoongArchInstrInfo.h new file mode 100644 index 000000000000..f31943b85a51 --- /dev/null +++ b/contrib/llvm-project/llvm/lib/Target/LoongArch/LoongArchInstrInfo.h @@ -0,0 +1,36 @@ +//=- LoongArchInstrInfo.h - LoongArch 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 LoongArch implementation of the TargetInstrInfo class. +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_LIB_TARGET_LOONGARCH_LOONGARCHINSTRINFO_H +#define LLVM_LIB_TARGET_LOONGARCH_LOONGARCHINSTRINFO_H + +#include "LoongArchRegisterInfo.h" +#include "llvm/CodeGen/TargetInstrInfo.h" + +#define GET_INSTRINFO_HEADER +#include "LoongArchGenInstrInfo.inc" + +namespace llvm { + +class LoongArchSubtarget; + +class LoongArchInstrInfo : public LoongArchGenInstrInfo { +public: + explicit LoongArchInstrInfo(LoongArchSubtarget &STI); + + void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, + const DebugLoc &DL, MCRegister DstReg, MCRegister SrcReg, + bool KillSrc) const override; +}; + +} // end namespace llvm +#endif // LLVM_LIB_TARGET_LOONGARCH_LOONGARCHINSTRINFO_H |