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"
66char RISCVExpandPseudo::ID = 0;
70 TII = STI->getInstrInfo();
82 assert(OldSize >= NewSize);
106 switch (
MBBI->getOpcode()) {
107 case RISCV::PseudoRV32ZdinxSD:
108 return expandRV32ZdinxStore(
MBB,
MBBI);
109 case RISCV::PseudoRV32ZdinxLD:
110 return expandRV32ZdinxLoad(
MBB,
MBBI);
111 case RISCV::PseudoCCMOVGPRNoX0:
112 case RISCV::PseudoCCMOVGPR:
113 case RISCV::PseudoCCADD:
114 case RISCV::PseudoCCSUB:
115 case RISCV::PseudoCCAND:
116 case RISCV::PseudoCCOR:
117 case RISCV::PseudoCCXOR:
118 case RISCV::PseudoCCADDW:
119 case RISCV::PseudoCCSUBW:
120 case RISCV::PseudoCCSLL:
121 case RISCV::PseudoCCSRL:
122 case RISCV::PseudoCCSRA:
123 case RISCV::PseudoCCADDI:
124 case RISCV::PseudoCCSLLI:
125 case RISCV::PseudoCCSRLI:
126 case RISCV::PseudoCCSRAI:
127 case RISCV::PseudoCCANDI:
128 case RISCV::PseudoCCORI:
129 case RISCV::PseudoCCXORI:
130 case RISCV::PseudoCCSLLW:
131 case RISCV::PseudoCCSRLW:
132 case RISCV::PseudoCCSRAW:
133 case RISCV::PseudoCCADDIW:
134 case RISCV::PseudoCCSLLIW:
135 case RISCV::PseudoCCSRLIW:
136 case RISCV::PseudoCCSRAIW:
137 case RISCV::PseudoCCANDN:
138 case RISCV::PseudoCCORN:
139 case RISCV::PseudoCCXNOR:
140 return expandCCOp(
MBB,
MBBI, NextMBBI);
141 case RISCV::PseudoVMCLR_M_B1:
142 case RISCV::PseudoVMCLR_M_B2:
143 case RISCV::PseudoVMCLR_M_B4:
144 case RISCV::PseudoVMCLR_M_B8:
145 case RISCV::PseudoVMCLR_M_B16:
146 case RISCV::PseudoVMCLR_M_B32:
147 case RISCV::PseudoVMCLR_M_B64:
149 return expandVMSET_VMCLR(
MBB,
MBBI, RISCV::VMXOR_MM);
150 case RISCV::PseudoVMSET_M_B1:
151 case RISCV::PseudoVMSET_M_B2:
152 case RISCV::PseudoVMSET_M_B4:
153 case RISCV::PseudoVMSET_M_B8:
154 case RISCV::PseudoVMSET_M_B16:
155 case RISCV::PseudoVMSET_M_B32:
156 case RISCV::PseudoVMSET_M_B64:
158 return expandVMSET_VMCLR(
MBB,
MBBI, RISCV::VMXNOR_MM);
191 assert(
MI.getOperand(4).getReg() == DestReg);
193 if (
MI.getOpcode() == RISCV::PseudoCCMOVGPR ||
194 MI.getOpcode() == RISCV::PseudoCCMOVGPRNoX0) {
197 .
add(
MI.getOperand(5))
201 switch (
MI.getOpcode()) {
204 case RISCV::PseudoCCADD: NewOpc = RISCV::ADD;
break;
205 case RISCV::PseudoCCSUB: NewOpc = RISCV::SUB;
break;
206 case RISCV::PseudoCCSLL: NewOpc = RISCV::SLL;
break;
207 case RISCV::PseudoCCSRL: NewOpc = RISCV::SRL;
break;
208 case RISCV::PseudoCCSRA: NewOpc = RISCV::SRA;
break;
209 case RISCV::PseudoCCAND: NewOpc = RISCV::AND;
break;
210 case RISCV::PseudoCCOR: NewOpc = RISCV::OR;
break;
211 case RISCV::PseudoCCXOR: NewOpc = RISCV::XOR;
break;
212 case RISCV::PseudoCCADDI: NewOpc = RISCV::ADDI;
break;
213 case RISCV::PseudoCCSLLI: NewOpc = RISCV::SLLI;
break;
214 case RISCV::PseudoCCSRLI: NewOpc = RISCV::SRLI;
break;
215 case RISCV::PseudoCCSRAI: NewOpc = RISCV::SRAI;
break;
216 case RISCV::PseudoCCANDI: NewOpc = RISCV::ANDI;
break;
217 case RISCV::PseudoCCORI: NewOpc = RISCV::ORI;
break;
218 case RISCV::PseudoCCXORI: NewOpc = RISCV::XORI;
break;
219 case RISCV::PseudoCCADDW: NewOpc = RISCV::ADDW;
break;
220 case RISCV::PseudoCCSUBW: NewOpc = RISCV::SUBW;
break;
221 case RISCV::PseudoCCSLLW: NewOpc = RISCV::SLLW;
break;
222 case RISCV::PseudoCCSRLW: NewOpc = RISCV::SRLW;
break;
223 case RISCV::PseudoCCSRAW: NewOpc = RISCV::SRAW;
break;
224 case RISCV::PseudoCCADDIW: NewOpc = RISCV::ADDIW;
break;
225 case RISCV::PseudoCCSLLIW: NewOpc = RISCV::SLLIW;
break;
226 case RISCV::PseudoCCSRLIW: NewOpc = RISCV::SRLIW;
break;
227 case RISCV::PseudoCCSRAIW: NewOpc = RISCV::SRAIW;
break;
228 case RISCV::PseudoCCANDN: NewOpc = RISCV::ANDN;
break;
229 case RISCV::PseudoCCORN: NewOpc = RISCV::ORN;
break;
230 case RISCV::PseudoCCXNOR: NewOpc = RISCV::XNOR;
break;
233 .
add(
MI.getOperand(5))
234 .
add(
MI.getOperand(6));
246 MI.eraseFromParent();
277 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_even);
279 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_odd);
281 assert(
MBBI->hasOneMemOperand() &&
"Expected mem operand");
293 if (
MBBI->getOperand(2).isGlobal() ||
MBBI->getOperand(2).isCPI()) {
295 assert(!STI->enableUnalignedScalarMem());
297 assert(
MBBI->getOperand(2).getOffset() % 8 == 0);
298 MBBI->getOperand(2).setOffset(
MBBI->getOperand(2).getOffset() + 4);
305 assert(isInt<12>(
MBBI->getOperand(2).getImm() + 4));
324 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_even);
326 TRI->getSubReg(
MBBI->getOperand(0).getReg(), RISCV::sub_gpr_odd);
328 assert(
MBBI->hasOneMemOperand() &&
"Expected mem operand");
336 bool IsOp1EqualToLo =
Lo ==
MBBI->getOperand(1).getReg();
338 if (!IsOp1EqualToLo) {
345 if (
MBBI->getOperand(2).isGlobal() ||
MBBI->getOperand(2).isCPI()) {
346 auto Offset =
MBBI->getOperand(2).getOffset();
347 assert(
MBBI->getOperand(2).getOffset() % 8 == 0);
355 assert(isInt<12>(
MBBI->getOperand(2).getImm() + 4));
363 if (IsOp1EqualToLo) {
399 unsigned FlagsHi,
unsigned SecondOpcode);
427char RISCVPreRAExpandPseudo::ID = 0;
429bool RISCVPreRAExpandPseudo::runOnMachineFunction(
MachineFunction &MF) {
431 TII = STI->getInstrInfo();
443 assert(OldSize >= NewSize);
465 switch (
MBBI->getOpcode()) {
466 case RISCV::PseudoLLA:
467 return expandLoadLocalAddress(
MBB,
MBBI, NextMBBI);
468 case RISCV::PseudoLGA:
469 return expandLoadGlobalAddress(
MBB,
MBBI, NextMBBI);
470 case RISCV::PseudoLA_TLS_IE:
471 return expandLoadTLSIEAddress(
MBB,
MBBI, NextMBBI);
472 case RISCV::PseudoLA_TLS_GD:
473 return expandLoadTLSGDAddress(
MBB,
MBBI, NextMBBI);
474 case RISCV::PseudoLA_TLSDESC:
475 return expandLoadTLSDescAddress(
MBB,
MBBI, NextMBBI);
480bool RISCVPreRAExpandPseudo::expandAuipcInstPair(
483 unsigned SecondOpcode) {
493 Symbol.setTargetFlags(FlagsHi);
505 if (
MI.hasOneMemOperand())
508 MI.eraseFromParent();
512bool RISCVPreRAExpandPseudo::expandLoadLocalAddress(
519bool RISCVPreRAExpandPseudo::expandLoadGlobalAddress(
522 unsigned SecondOpcode = STI->is64Bit() ? RISCV::LD : RISCV::LW;
527bool RISCVPreRAExpandPseudo::expandLoadTLSIEAddress(
530 unsigned SecondOpcode = STI->is64Bit() ? RISCV::LD : RISCV::LW;
535bool RISCVPreRAExpandPseudo::expandLoadTLSGDAddress(
542bool RISCVPreRAExpandPseudo::expandLoadTLSDescAddress(
550 unsigned SecondOpcode = STI.is64Bit() ? RISCV::LD : RISCV::LW;
552 Register FinalReg =
MI.getOperand(0).getReg();
583 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.