LLVM 20.0.0git
|
Helper class for constructing bundles of MachineInstrs. More...
#include "llvm/CodeGen/MachineInstrBuilder.h"
Public Member Functions | |
MIBundleBuilder (MachineBasicBlock &BB, MachineBasicBlock::iterator Pos) | |
Create an MIBundleBuilder that inserts instructions into a new bundle in BB above the bundle or instruction at Pos. | |
MIBundleBuilder (MachineBasicBlock &BB, MachineBasicBlock::iterator B, MachineBasicBlock::iterator E) | |
Create a bundle from the sequence of instructions between B and E. | |
MIBundleBuilder (MachineInstr *MI) | |
Create an MIBundleBuilder representing an existing instruction or bundle that has MI as its head. | |
MachineBasicBlock & | getMBB () const |
Return a reference to the basic block containing this bundle. | |
bool | empty () const |
Return true if no instructions have been inserted in this bundle yet. | |
MachineBasicBlock::instr_iterator | begin () const |
Return an iterator to the first bundled instruction. | |
MachineBasicBlock::instr_iterator | end () const |
Return an iterator beyond the last bundled instruction. | |
MIBundleBuilder & | insert (MachineBasicBlock::instr_iterator I, MachineInstr *MI) |
Insert MI into this bundle before I which must point to an instruction in the bundle, or end(). | |
MIBundleBuilder & | prepend (MachineInstr *MI) |
Insert MI into MBB by prepending it to the instructions in the bundle. | |
MIBundleBuilder & | append (MachineInstr *MI) |
Insert MI into MBB by appending it to the instructions in the bundle. | |
Helper class for constructing bundles of MachineInstrs.
MIBundleBuilder can create a bundle from scratch by inserting new MachineInstrs one at a time, or it can create a bundle from a sequence of existing MachineInstrs in a basic block.
Definition at line 591 of file MachineInstrBuilder.h.
|
inline |
Create an MIBundleBuilder that inserts instructions into a new bundle in BB above the bundle or instruction at Pos.
Definition at line 599 of file MachineInstrBuilder.h.
|
inline |
|
inlineexplicit |
Create an MIBundleBuilder representing an existing instruction or bundle that has MI as its head.
Definition at line 617 of file MachineInstrBuilder.h.
|
inline |
Insert MI into MBB by appending it to the instructions in the bundle.
MI will become the last instruction in the bundle.
Definition at line 664 of file MachineInstrBuilder.h.
References end(), insert(), and MI.
Referenced by llvm::SIInstrInfo::expandPostRAPseudo(), and for().
|
inline |
Return an iterator to the first bundled instruction.
Definition at line 629 of file MachineInstrBuilder.h.
Referenced by llvm::SITargetLowering::bundleInstWithWaitcnt(), llvm::SIInstrInfo::expandPostRAPseudo(), and prepend().
|
inline |
Return true if no instructions have been inserted in this bundle yet.
Empty bundles aren't representable in a MachineBasicBlock.
Definition at line 626 of file MachineInstrBuilder.h.
References End.
Referenced by insert().
|
inline |
Return an iterator beyond the last bundled instruction.
Definition at line 632 of file MachineInstrBuilder.h.
References End.
Referenced by append().
|
inline |
Return a reference to the basic block containing this bundle.
Definition at line 622 of file MachineInstrBuilder.h.
References MBB.
|
inline |
Insert MI into this bundle before I which must point to an instruction in the bundle, or end().
Definition at line 636 of file MachineInstrBuilder.h.
References llvm::MachineInstr::BundledPred, llvm::MachineInstr::BundledSucc, empty(), End, I, MBB, and MI.
|
inline |
Insert MI into MBB by prepending it to the instructions in the bundle.
MI will become the first instruction in the bundle.
Definition at line 658 of file MachineInstrBuilder.h.
References begin(), insert(), and MI.
Referenced by llvm::finalizeBundle().