26#define RISCV_EXPAND_PSEUDO_NAME "RISC-V pseudo instruction expansion pass"
27#define RISCV_PRERA_EXPAND_PSEUDO_NAME "RISC-V Pre-RA pseudo instruction expansion pass"
70char RISCVExpandPseudo::ID = 0;
74 TII = STI->getInstrInfo();
86 assert(OldSize >= NewSize);
110 switch (
MBBI->getOpcode()) {
111 case RISCV::PseudoMV_FPR16INX:
112 return expandMV_FPR16INX(
MBB,
MBBI);
113 case RISCV::PseudoMV_FPR32INX:
114 return expandMV_FPR32INX(
MBB,
MBBI);
115 case RISCV::PseudoRV32ZdinxSD:
116 return expandRV32ZdinxStore(
MBB,
MBBI);
117 case RISCV::PseudoRV32ZdinxLD:
118 return expandRV32ZdinxLoad(
MBB,
MBBI);
119 case RISCV::PseudoCCMOVGPRNoX0:
120 case RISCV::PseudoCCMOVGPR:
121 case RISCV::PseudoCCADD:
122 case RISCV::PseudoCCSUB:
123 case RISCV::PseudoCCAND:
124 case RISCV::PseudoCCOR:
125 case RISCV::PseudoCCXOR:
126 case RISCV::PseudoCCADDW:
127 case RISCV::PseudoCCSUBW:
128 case RISCV::PseudoCCSLL:
129 case RISCV::PseudoCCSRL:
130 case RISCV::PseudoCCSRA:
131 case RISCV::PseudoCCADDI:
132 case RISCV::PseudoCCSLLI:
133 case RISCV::PseudoCCSRLI:
134 case RISCV::PseudoCCSRAI:
135 case RISCV::PseudoCCANDI:
136 case RISCV::PseudoCCORI:
137 case RISCV::PseudoCCXORI:
138 case RISCV::PseudoCCSLLW:
139 case RISCV::PseudoCCSRLW:
140 case RISCV::PseudoCCSRAW:
141 case RISCV::PseudoCCADDIW:
142 case RISCV::PseudoCCSLLIW:
143 case RISCV::PseudoCCSRLIW:
144 case RISCV::PseudoCCSRAIW:
145 case RISCV::PseudoCCANDN:
146 case RISCV::PseudoCCORN:
147 case RISCV::PseudoCCXNOR:
148 return expandCCOp(
MBB,
MBBI, NextMBBI);
149 case RISCV::PseudoVMCLR_M_B1:
150 case RISCV::PseudoVMCLR_M_B2:
151 case RISCV::PseudoVMCLR_M_B4:
152 case RISCV::PseudoVMCLR_M_B8:
153 case RISCV::PseudoVMCLR_M_B16:
154 case RISCV::PseudoVMCLR_M_B32:
155 case RISCV::PseudoVMCLR_M_B64:
157 return expandVMSET_VMCLR(
MBB,
MBBI, RISCV::VMXOR_MM);
158 case RISCV::PseudoVMSET_M_B1:
159 case RISCV::PseudoVMSET_M_B2:
160 case RISCV::PseudoVMSET_M_B4:
161 case RISCV::PseudoVMSET_M_B8:
162 case RISCV::PseudoVMSET_M_B16:
163 case RISCV::PseudoVMSET_M_B32:
164 case RISCV::PseudoVMSET_M_B64:
166 return expandVMSET_VMCLR(
MBB,
MBBI, RISCV::VMXNOR_MM);
199 assert(
MI.getOperand(4).getReg() == DestReg);
201 if (
MI.getOpcode() == RISCV::PseudoCCMOVGPR ||
202 MI.getOpcode() == RISCV::PseudoCCMOVGPRNoX0) {
205 .
add(
MI.getOperand(5))
209 switch (
MI.getOpcode()) {
212 case RISCV::PseudoCCADD: NewOpc = RISCV::ADD;
break;
213 case RISCV::PseudoCCSUB: NewOpc = RISCV::SUB;
break;
214 case RISCV::PseudoCCSLL: NewOpc = RISCV::SLL;
break;
215 case RISCV::PseudoCCSRL: NewOpc = RISCV::SRL;
break;
216 case RISCV::PseudoCCSRA: NewOpc = RISCV::SRA;
break;
217 case RISCV::PseudoCCAND: NewOpc = RISCV::AND;
break;
218 case RISCV::PseudoCCOR: NewOpc = RISCV::OR;
break;
219 case RISCV::PseudoCCXOR: NewOpc = RISCV::XOR;
break;
220 case RISCV::PseudoCCADDI: NewOpc = RISCV::ADDI;
break;
221 case RISCV::PseudoCCSLLI: NewOpc = RISCV::SLLI;
break;
222 case RISCV::PseudoCCSRLI: NewOpc = RISCV::SRLI;
break;
223 case RISCV::PseudoCCSRAI: NewOpc = RISCV::SRAI;
break;
224 case RISCV::PseudoCCANDI: NewOpc = RISCV::ANDI;
break;
225 case RISCV::PseudoCCORI: NewOpc = RISCV::ORI;
break;
226 case RISCV::PseudoCCXORI: NewOpc = RISCV::XORI;
break;
227 case RISCV::PseudoCCADDW: NewOpc = RISCV::ADDW;
break;
228 case RISCV::PseudoCCSUBW: NewOpc = RISCV::SUBW;
break;
229 case RISCV::PseudoCCSLLW: NewOpc = RISCV::SLLW;
break;
230 case RISCV::PseudoCCSRLW: NewOpc = RISCV::SRLW;
break;
231 case RISCV::PseudoCCSRAW: NewOpc = RISCV::SRAW;
break;
232 case RISCV::PseudoCCADDIW: NewOpc = RISCV::ADDIW;
break;
233 case RISCV::PseudoCCSLLIW: NewOpc = RISCV::SLLIW;
break;
234 case RISCV::PseudoCCSRLIW: NewOpc = RISCV::SRLIW;
break;
235 case RISCV::PseudoCCSRAIW: NewOpc = RISCV::SRAIW;
break;
236 case RISCV::PseudoCCANDN: NewOpc = RISCV::ANDN;
break;
237 case RISCV::PseudoCCORN: NewOpc = RISCV::ORN;
break;
238 case RISCV::PseudoCCXNOR: NewOpc = RISCV::XNOR;
break;
241 .
add(
MI.getOperand(5))
242 .
add(
MI.getOperand(6));
254 MI.eraseFromParent();
282 MBBI->getOperand(0).getReg(), RISCV::sub_16, &RISCV::GPRRegClass);
284 MBBI->getOperand(1).getReg(), RISCV::sub_16, &RISCV::GPRRegClass);
299 MBBI->getOperand(0).getReg(), RISCV::sub_32, &RISCV::GPRRegClass);
301 MBBI->getOperand(1).getReg(), RISCV::sub_32, &RISCV::GPRRegClass);
319 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_even);
321 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_odd);
329 if (
MBBI->getOperand(2).isGlobal() ||
MBBI->getOperand(2).isCPI()) {
330 assert(
MBBI->getOperand(2).getOffset() % 8 == 0);
331 MBBI->getOperand(2).setOffset(
MBBI->getOperand(2).getOffset() + 4);
337 assert(isInt<12>(
MBBI->getOperand(2).getImm() + 4));
344 if (!
MBBI->memoperands_empty()) {
345 assert(
MBBI->hasOneMemOperand() &&
"Expected mem operand");
350 MIBLo.setMemRefs(MMOLo);
366 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_even);
368 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_odd);
374 bool IsOp1EqualToLo =
Lo ==
MBBI->getOperand(1).getReg();
376 if (!IsOp1EqualToLo) {
382 if (
MBBI->getOperand(2).isGlobal() ||
MBBI->getOperand(2).isCPI()) {
383 auto Offset =
MBBI->getOperand(2).getOffset();
391 assert(isInt<12>(
MBBI->getOperand(2).getImm() + 4));
398 if (IsOp1EqualToLo) {
404 if (!
MBBI->memoperands_empty()) {
405 assert(
MBBI->hasOneMemOperand() &&
"Expected mem operand");
443 unsigned FlagsHi,
unsigned SecondOpcode);
471char RISCVPreRAExpandPseudo::ID = 0;
473bool RISCVPreRAExpandPseudo::runOnMachineFunction(
MachineFunction &MF) {
475 TII = STI->getInstrInfo();
487 assert(OldSize >= NewSize);
509 switch (
MBBI->getOpcode()) {
510 case RISCV::PseudoLLA:
511 return expandLoadLocalAddress(
MBB,
MBBI, NextMBBI);
512 case RISCV::PseudoLGA:
513 return expandLoadGlobalAddress(
MBB,
MBBI, NextMBBI);
514 case RISCV::PseudoLA_TLS_IE:
515 return expandLoadTLSIEAddress(
MBB,
MBBI, NextMBBI);
516 case RISCV::PseudoLA_TLS_GD:
517 return expandLoadTLSGDAddress(
MBB,
MBBI, NextMBBI);
518 case RISCV::PseudoLA_TLSDESC:
519 return expandLoadTLSDescAddress(
MBB,
MBBI, NextMBBI);
524bool RISCVPreRAExpandPseudo::expandAuipcInstPair(
527 unsigned SecondOpcode) {
537 Symbol.setTargetFlags(FlagsHi);
549 if (
MI.hasOneMemOperand())
552 MI.eraseFromParent();
556bool RISCVPreRAExpandPseudo::expandLoadLocalAddress(
563bool RISCVPreRAExpandPseudo::expandLoadGlobalAddress(
566 unsigned SecondOpcode = STI->is64Bit() ? RISCV::LD : RISCV::LW;
571bool RISCVPreRAExpandPseudo::expandLoadTLSIEAddress(
574 unsigned SecondOpcode = STI->is64Bit() ? RISCV::LD : RISCV::LW;
579bool RISCVPreRAExpandPseudo::expandLoadTLSGDAddress(
586bool RISCVPreRAExpandPseudo::expandLoadTLSDescAddress(
594 unsigned SecondOpcode = STI.is64Bit() ? RISCV::LD : RISCV::LW;
596 Register FinalReg =
MI.getOperand(0).getReg();
627 MI.eraseFromParent();
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
static Expected< BitVector > expand(StringRef S, StringRef Original)
const HexagonInstrInfo * TII
This file implements the LivePhysRegs utility for tracking liveness of physical registers.
unsigned const TargetRegisterInfo * TRI
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
#define RISCV_PRERA_EXPAND_PSEUDO_NAME
#define RISCV_EXPAND_PSEUDO_NAME
riscv prera expand pseudo
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
static unsigned getInstSizeInBytes(const MachineInstr &MI, const SystemZInstrInfo *TII)
support::ulittle16_t & Lo
support::ulittle16_t & Hi
Represent the analysis usage information of a pass.
void setPreservesCFG()
This function should be called by the pass, iff they do not:
FunctionPass class - This class is used to implement most global optimizations.
A set of physical registers with utility functions to track liveness when walking backward/forward th...
MCSymbol * createNamedTempSymbol()
Create a temporary symbol with a unique name whose name cannot be omitted in the symbol table.
Describe properties that are true of each instruction in the target description file.
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
void transferSuccessors(MachineBasicBlock *FromMBB)
Transfers all the successors from MBB to this machine basic block (i.e., copies all the successors Fr...
const BasicBlock * getBasicBlock() const
Return the LLVM basic block that this instance corresponded to originally.
void addSuccessor(MachineBasicBlock *Succ, BranchProbability Prob=BranchProbability::getUnknown())
Add Succ as a successor of this MachineBasicBlock.
void eraseFromParent()
This method unlinks 'this' from the containing function and deletes it.
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
void splice(iterator Where, MachineBasicBlock *Other, iterator From)
Take an instruction from MBB 'Other' at the position From, and insert it into this MBB right before '...
MachineFunctionPass - This class adapts the FunctionPass interface to allow convenient creation of pa...
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - Subclasses that override getAnalysisUsage must call this.
virtual bool runOnMachineFunction(MachineFunction &MF)=0
runOnMachineFunction - This method must be overloaded to perform the desired machine code transformat...
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
MachineMemOperand * getMachineMemOperand(MachinePointerInfo PtrInfo, MachineMemOperand::Flags f, LLT MemTy, Align base_alignment, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr, SyncScope::ID SSID=SyncScope::System, AtomicOrdering Ordering=AtomicOrdering::NotAtomic, AtomicOrdering FailureOrdering=AtomicOrdering::NotAtomic)
getMachineMemOperand - Allocate a new MachineMemOperand.
MCContext & getContext() const
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
MachineBasicBlock * CreateMachineBasicBlock(const BasicBlock *BB=nullptr, std::optional< UniqueBBID > BBID=std::nullopt)
CreateMachineBasicBlock - Allocate a new MachineBasicBlock.
void insert(iterator MBBI, MachineBasicBlock *MBB)
const MachineInstrBuilder & setMemRefs(ArrayRef< MachineMemOperand * > MMOs) const
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
const MachineInstrBuilder & add(const MachineOperand &MO) const
const MachineInstrBuilder & addSym(MCSymbol *Sym, unsigned char TargetFlags=0) const
const MachineInstrBuilder & addReg(Register RegNo, unsigned flags=0, unsigned SubReg=0) const
Add a new virtual register operand.
const MachineInstrBuilder & addMBB(MachineBasicBlock *MBB, unsigned TargetFlags=0) const
Representation of each machine instruction.
void setPreInstrSymbol(MachineFunction &MF, MCSymbol *Symbol)
Set a symbol that will be emitted just prior to the instruction itself.
void addMemOperand(MachineFunction &MF, MachineMemOperand *MO)
Add a MachineMemOperand to the machine instruction.
A description of a memory reference used in the backend.
MachineOperand class - Representation of each machine instruction operand.
Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
virtual StringRef getPassName() const
getPassName - Return a nice clean name for a pass.
Wrapper class representing virtual and physical registers.
StringRef - Represent a constant reference to a string, i.e.
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
self_iterator getIterator()
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
CondCode getOppositeBranchCondition(CondCode)
@ Undef
Value of the register doesn't matter.
This is an optimization pass for GlobalISel generic memory operations.
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
unsigned getKillRegState(bool B)
void computeAndAddLiveIns(LivePhysRegs &LiveRegs, MachineBasicBlock &MBB)
Convenience function combining computeLiveIns() and addLiveIns().
FunctionPass * createRISCVExpandPseudoPass()
FunctionPass * createRISCVPreRAExpandPseudoPass()
Description of the encoding of one expression Op.