LLVM 23.0.0git
LoongArchInstrInfo.h
Go to the documentation of this file.
1//=- LoongArchInstrInfo.h - LoongArch Instruction Information ---*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file contains the LoongArch implementation of the TargetInstrInfo class.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_LIB_TARGET_LOONGARCH_LOONGARCHINSTRINFO_H
14#define LLVM_LIB_TARGET_LOONGARCH_LOONGARCHINSTRINFO_H
15
18
19#define GET_INSTRINFO_HEADER
20#include "LoongArchGenInstrInfo.inc"
21
22namespace llvm {
23
24class LoongArchSubtarget;
25
27 const LoongArchRegisterInfo RegInfo;
28
29public:
31
32 const LoongArchRegisterInfo &getRegisterInfo() const { return RegInfo; }
33
34 MCInst getNop() const override;
35
37 const DebugLoc &DL, Register DstReg, Register SrcReg,
38 bool KillSrc, bool RenamableDest = false,
39 bool RenamableSrc = false) const override;
40
43 bool IsKill, int FrameIndex, const TargetRegisterClass *RC, Register VReg,
44 MachineInstr::MIFlag Flags = MachineInstr::NoFlags) const override;
47 int FrameIndex, const TargetRegisterClass *RC, Register VReg,
48 unsigned SubReg = 0,
49 MachineInstr::MIFlag Flags = MachineInstr::NoFlags) const override;
50
52 int &FrameIndex) const override;
53 Register isLoadFromStackSlot(const MachineInstr &MI, int &FrameIndex,
54 TypeSize &MemBytes) const override;
56 int &FrameIndex) const override;
57 Register isStoreToStackSlot(const MachineInstr &MI, int &FrameIndex,
58 TypeSize &MemBytes) const override;
59
60 // Materializes the given integer Val into DstReg.
62 const DebugLoc &DL, Register DstReg, uint64_t Val,
64
65 unsigned getInstSizeInBytes(const MachineInstr &MI) const override;
66
67 bool isAsCheapAsAMove(const MachineInstr &MI) const override;
68
70
74 bool AllowModify) const override;
75
76 bool isBranchOffsetInRange(unsigned BranchOpc,
77 int64_t BrOffset) const override;
78
80 const MachineFunction &MF) const override;
81
84 const MachineFunction &MF) const override;
85
87 int *BytesRemoved = nullptr) const override;
88
91 const DebugLoc &dl,
92 int *BytesAdded = nullptr) const override;
93
95 MachineBasicBlock &NewDestBB,
96 MachineBasicBlock &RestoreBB, const DebugLoc &DL,
97 int64_t BrOffset, RegScavenger *RS) const override;
98
99 bool
101
102 std::pair<unsigned, unsigned>
103 decomposeMachineOperandsTargetFlags(unsigned TF) const override;
104
107
110
112 const MachineInstr &AddrI,
113 ExtAddrMode &AM) const override;
115 const ExtAddrMode &AM) const override;
116
117protected:
119};
120
121namespace LoongArch {
122
123// Returns true if this is the sext.w pattern, addi.w rd, rs, 0.
124bool isSEXT_W(const MachineInstr &MI);
125
126// Mask assignments for floating-point.
127static constexpr unsigned FClassMaskSignalingNaN = 0x001;
128static constexpr unsigned FClassMaskQuietNaN = 0x002;
129static constexpr unsigned FClassMaskNegativeInfinity = 0x004;
130static constexpr unsigned FClassMaskNegativeNormal = 0x008;
131static constexpr unsigned FClassMaskNegativeSubnormal = 0x010;
132static constexpr unsigned FClassMaskNegativeZero = 0x020;
133static constexpr unsigned FClassMaskPositiveInfinity = 0x040;
134static constexpr unsigned FClassMaskPositiveNormal = 0x080;
135static constexpr unsigned FClassMaskPositiveSubnormal = 0x100;
136static constexpr unsigned FClassMaskPositiveZero = 0x200;
137} // namespace LoongArch
138
139} // end namespace llvm
140#endif // LLVM_LIB_TARGET_LOONGARCH_LOONGARCHINSTRINFO_H
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
IRTranslator LLVM IR MI
Register Reg
const SmallVectorImpl< MachineOperand > MachineBasicBlock * TBB
const SmallVectorImpl< MachineOperand > & Cond
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
A debug info location.
Definition DebugLoc.h:123
void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, const DebugLoc &DL, Register DstReg, Register SrcReg, bool KillSrc, bool RenamableDest=false, bool RenamableSrc=false) const override
ArrayRef< std::pair< unsigned, const char * > > getSerializableBitmaskMachineOperandTargetFlags() const override
const LoongArchSubtarget & STI
bool reverseBranchCondition(SmallVectorImpl< MachineOperand > &Cond) const override
bool isSafeToMove(const MachineInstr &MI, const MachineBasicBlock *MBB, const MachineFunction &MF) const override
bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, MachineBasicBlock *&FBB, SmallVectorImpl< MachineOperand > &Cond, bool AllowModify) const override
const LoongArchRegisterInfo & getRegisterInfo() const
void storeRegToStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, Register SrcReg, bool IsKill, int FrameIndex, const TargetRegisterClass *RC, Register VReg, MachineInstr::MIFlag Flags=MachineInstr::NoFlags) const override
std::pair< unsigned, unsigned > decomposeMachineOperandsTargetFlags(unsigned TF) const override
bool isAsCheapAsAMove(const MachineInstr &MI) const override
MCInst getNop() const override
LoongArchInstrInfo(const LoongArchSubtarget &STI)
ArrayRef< std::pair< unsigned, const char * > > getSerializableDirectMachineOperandTargetFlags() const override
unsigned removeBranch(MachineBasicBlock &MBB, int *BytesRemoved=nullptr) const override
Register isLoadFromStackSlot(const MachineInstr &MI, int &FrameIndex) const override
void movImm(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, const DebugLoc &DL, Register DstReg, uint64_t Val, MachineInstr::MIFlag Flag=MachineInstr::NoFlags) const
unsigned insertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, MachineBasicBlock *FBB, ArrayRef< MachineOperand > Cond, const DebugLoc &dl, int *BytesAdded=nullptr) const override
void insertIndirectBranch(MachineBasicBlock &MBB, MachineBasicBlock &NewDestBB, MachineBasicBlock &RestoreBB, const DebugLoc &DL, int64_t BrOffset, RegScavenger *RS) const override
void loadRegFromStackSlot(MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, Register DstReg, int FrameIndex, const TargetRegisterClass *RC, Register VReg, unsigned SubReg=0, MachineInstr::MIFlag Flags=MachineInstr::NoFlags) const override
Register isStoreToStackSlot(const MachineInstr &MI, int &FrameIndex) const override
bool isSchedulingBoundary(const MachineInstr &MI, const MachineBasicBlock *MBB, const MachineFunction &MF) const override
bool isBranchOffsetInRange(unsigned BranchOpc, int64_t BrOffset) const override
bool canFoldIntoAddrMode(const MachineInstr &MemI, Register Reg, const MachineInstr &AddrI, ExtAddrMode &AM) const override
unsigned getInstSizeInBytes(const MachineInstr &MI) const override
MachineBasicBlock * getBranchDestBlock(const MachineInstr &MI) const override
MachineInstr * emitLdStWithAddr(MachineInstr &MemI, const ExtAddrMode &AM) const override
Instances of this class represent a single low-level machine instruction.
Definition MCInst.h:188
MachineInstrBundleIterator< MachineInstr > iterator
Representation of each machine instruction.
Wrapper class representing virtual and physical registers.
Definition Register.h:20
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
static constexpr unsigned FClassMaskSignalingNaN
static constexpr unsigned FClassMaskNegativeSubnormal
bool isSEXT_W(const MachineInstr &MI)
static constexpr unsigned FClassMaskPositiveInfinity
static constexpr unsigned FClassMaskNegativeZero
static constexpr unsigned FClassMaskNegativeNormal
static constexpr unsigned FClassMaskQuietNaN
static constexpr unsigned FClassMaskNegativeInfinity
static constexpr unsigned FClassMaskPositiveNormal
static constexpr unsigned FClassMaskPositiveZero
static constexpr unsigned FClassMaskPositiveSubnormal
This is an optimization pass for GlobalISel generic memory operations.
Used to describe addressing mode similar to ExtAddrMode in CodeGenPrepare.