LLVM 19.0.0git
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | Friends | List of all members
llvm::sandboxir::Instruction Class Referenceabstract

A sandboxir::User with operands, opcode and linked with previous/next instructions in an instruction list. More...

#include "llvm/SandboxIR/SandboxIR.h"

Inheritance diagram for llvm::sandboxir::Instruction:
Inheritance graph
[legend]

Public Types

enum class  Opcode { DEF_VALUE , DEF_USER , OP , DEF_INSTR }
 
- Public Types inherited from llvm::sandboxir::User
using op_iterator = OperandUseIterator
 
using const_op_iterator = OperandUseIterator
 
using op_range = iterator_range< op_iterator >
 
using const_op_range = iterator_range< const_op_iterator >
 
- Public Types inherited from llvm::sandboxir::Value
enum class  ClassID : unsigned { DEF_VALUE , DEF_USER , DEF_INSTR }
 
using use_iterator = UserUseIterator
 
using const_use_iterator = UserUseIterator
 
using user_iterator = mapped_iterator< sandboxir::UserUseIterator, UseToUser >
 
using const_user_iterator = user_iterator
 

Public Member Functions

virtual unsigned getNumOfIRInstrs () const =0
 This is used by BasicBlock::iterator.
 
BBIterator getIterator () const
 \Returns a BasicBlock::iterator for this Instruction.
 
InstructiongetNextNode () const
 \Returns the next sandboxir::Instruction in the block, or nullptr if at the end of the block.
 
InstructiongetPrevNode () const
 \Returns the previous sandboxir::Instruction in the block, or nullptr if at the beginning of the block.
 
Opcode getOpcode () const
 \Returns this Instruction's opcode.
 
void removeFromParent ()
 Detach this from its parent BasicBlock without deleting it.
 
void eraseFromParent ()
 Detach this Value from its parent and delete it.
 
void insertBefore (Instruction *BeforeI)
 Insert this detached instruction before BeforeI.
 
void insertAfter (Instruction *AfterI)
 Insert this detached instruction after AfterI.
 
void insertInto (BasicBlock *BB, const BBIterator &WhereIt)
 Insert this detached instruction into BB at WhereIt.
 
void moveBefore (BasicBlock &BB, const BBIterator &WhereIt)
 Move this instruction to WhereIt.
 
void moveBefore (Instruction *Before)
 Move this instruction before Before.
 
void moveAfter (Instruction *After)
 Move this instruction after After.
 
BasicBlockgetParent () const
 \Returns the BasicBlock containing this Instruction, or null if it is detached.
 
void dump (raw_ostream &OS) const override
 
LLVM_DUMP_METHOD void dump () const override
 
- Public Member Functions inherited from llvm::sandboxir::User
virtual op_iterator op_begin ()
 
virtual op_iterator op_end ()
 
virtual const_op_iterator op_begin () const
 
virtual const_op_iterator op_end () const
 
op_range operands ()
 
const_op_range operands () const
 
ValuegetOperand (unsigned OpIdx) const
 
Use getOperandUse (unsigned OpIdx) const
 \Returns the operand edge for OpIdx.
 
virtual unsigned getNumOperands () const
 
virtual void setOperand (unsigned OperandIdx, Value *Operand)
 
bool replaceUsesOfWith (Value *FromV, Value *ToV)
 Replaces any operands that match FromV with ToV.
 
void verify () const override
 Should crash if there is something wrong with the instruction.
 
void dumpCommonHeader (raw_ostream &OS) const final
 
void dump (raw_ostream &OS) const override
 
LLVM_DUMP_METHOD void dump () const override
 
- Public Member Functions inherited from llvm::sandboxir::Value
virtual ~Value ()=default
 
ClassID getSubclassID () const
 
use_iterator use_begin ()
 
const_use_iterator use_begin () const
 
use_iterator use_end ()
 
const_use_iterator use_end () const
 
iterator_range< use_iteratoruses ()
 
iterator_range< const_use_iteratoruses () const
 
user_iterator user_begin ()
 
user_iterator user_end ()
 
const_user_iterator user_begin () const
 
const_user_iterator user_end () const
 
iterator_range< user_iteratorusers ()
 
iterator_range< const_user_iteratorusers () const
 
unsigned getNumUses () const
 \Returns the number of user edges (not necessarily to unique users).
 
bool hasNUsesOrMore (unsigned Num) const
 Return true if this value has N uses or more.
 
bool hasNUses (unsigned Num) const
 Return true if this Value has exactly N uses.
 
TypegetType () const
 
ContextgetContext () const
 
void replaceUsesWithIf (Value *OtherV, llvm::function_ref< bool(const Use &)> ShouldReplace)
 
void replaceAllUsesWith (Value *Other)
 
StringRef getName () const
 \Returns the LLVM IR name of the bottom-most LLVM value.
 
virtual void verify () const =0
 Should crash if there is something wrong with the instruction.
 
std::string getUid () const
 Returns the unique id in the form 'SB<number>.' like 'SB1.'.
 
virtual void dumpCommonHeader (raw_ostream &OS) const
 
void dumpCommonFooter (raw_ostream &OS) const
 
void dumpCommonPrefix (raw_ostream &OS) const
 
void dumpCommonSuffix (raw_ostream &OS) const
 
void printAsOperandCommon (raw_ostream &OS) const
 
virtual void dump (raw_ostream &OS) const =0
 
virtual LLVM_DUMP_METHOD void dump () const =0
 

Static Public Member Functions

static const chargetOpcodeName (Opcode Opc)
 
static bool classof (const sandboxir::Value *From)
 For isa/dyn_cast.
 
- Static Public Member Functions inherited from llvm::sandboxir::User
static bool classof (const Value *From)
 For isa/dyn_cast.
 

Protected Member Functions

 Instruction (ClassID ID, Opcode Opc, llvm::Instruction *I, sandboxir::Context &SBCtx)
 
llvm::InstructiongetTopmostLLVMInstruction () const
 A SandboxIR Instruction may map to multiple LLVM IR Instruction.
 
virtual SmallVector< llvm::Instruction *, 1 > getLLVMInstrs () const =0
 \Returns the LLVM IR Instructions that this SandboxIR maps to in program order.
 
- Protected Member Functions inherited from llvm::sandboxir::User
 User (ClassID ID, llvm::Value *V, Context &Ctx)
 
Use getOperandUseDefault (unsigned OpIdx, bool Verify) const
 \Returns the Use edge that corresponds to OpIdx.
 
virtual Use getOperandUseInternal (unsigned OpIdx, bool Verify) const =0
 \Returns the Use for the OpIdx'th operand.
 
unsigned getUseOperandNoDefault (const Use &Use) const
 The default implementation works only for single-LLVMIR-instruction Users and only if they match exactly the LLVM instruction.
 
virtual unsigned getUseOperandNo (const Use &Use) const =0
 \Returns the operand index of Use.
 
void verifyUserOfLLVMUse (const llvm::Use &Use) const
 
- Protected Member Functions inherited from llvm::sandboxir::Value
void clearValue ()
 
 Value (ClassID SubclassID, llvm::Value *Val, Context &Ctx)
 

Protected Attributes

Opcode Opc
 
- Protected Attributes inherited from llvm::sandboxir::Value
ClassID SubclassID
 For isa/dyn_cast.
 
unsigned UID
 A unique ID used for forming the name (used for debugging).
 
llvm::ValueVal = nullptr
 The LLVM Value that corresponds to this SandboxIR Value.
 
ContextCtx
 All values point to the context.
 

Friends

class LoadInst
 
class EraseFromParent
 
raw_ostreamoperator<< (raw_ostream &OS, Opcode Opc)
 
raw_ostreamoperator<< (raw_ostream &OS, const sandboxir::Instruction &SBI)
 

Additional Inherited Members

- Static Protected Member Functions inherited from llvm::sandboxir::Value
static const chargetSubclassIDStr (ClassID ID)
 

Detailed Description

A sandboxir::User with operands, opcode and linked with previous/next instructions in an instruction list.

Definition at line 478 of file SandboxIR.h.

Member Enumeration Documentation

◆ Opcode

Enumerator
DEF_VALUE 
DEF_USER 
OP 
DEF_INSTR 

Definition at line 480 of file SandboxIR.h.

Constructor & Destructor Documentation

◆ Instruction()

llvm::sandboxir::Instruction::Instruction ( ClassID  ID,
Opcode  Opc,
llvm::Instruction I,
sandboxir::Context SBCtx 
)
inlineprotected

Definition at line 489 of file SandboxIR.h.

Member Function Documentation

◆ classof()

bool Instruction::classof ( const sandboxir::Value From)
static

For isa/dyn_cast.

Definition at line 437 of file SandboxIR.cpp.

References From.

◆ dump() [1/2]

void Instruction::dump ( ) const
overridevirtual

Reimplemented from llvm::sandboxir::User.

Reimplemented in llvm::sandboxir::LoadInst, and llvm::sandboxir::OpaqueInst.

Definition at line 452 of file SandboxIR.cpp.

References llvm::dbgs(), and dump().

Referenced by dump().

◆ dump() [2/2]

void Instruction::dump ( raw_ostream OS) const
overridevirtual

Reimplemented from llvm::sandboxir::User.

Reimplemented in llvm::sandboxir::LoadInst, and llvm::sandboxir::OpaqueInst.

Definition at line 449 of file SandboxIR.cpp.

References OS.

◆ eraseFromParent()

void Instruction::eraseFromParent ( )

◆ getIterator()

BBIterator Instruction::getIterator ( ) const

◆ getLLVMInstrs()

virtual SmallVector< llvm::Instruction *, 1 > llvm::sandboxir::Instruction::getLLVMInstrs ( ) const
protectedpure virtual

\Returns the LLVM IR Instructions that this SandboxIR maps to in program order.

Referenced by eraseFromParent(), insertBefore(), insertInto(), moveBefore(), and removeFromParent().

◆ getNextNode()

Instruction * Instruction::getNextNode ( ) const

◆ getNumOfIRInstrs()

virtual unsigned llvm::sandboxir::Instruction::getNumOfIRInstrs ( ) const
pure virtual

◆ getOpcode()

Opcode llvm::sandboxir::Instruction::getOpcode ( ) const
inline

\Returns this Instruction's opcode.

Note that SandboxIR has its own opcode state to allow for new SandboxIR-specific instructions.

Definition at line 525 of file SandboxIR.h.

References Opc.

◆ getOpcodeName()

const char * Instruction::getOpcodeName ( Opcode  Opc)
static

Definition at line 282 of file SandboxIR.cpp.

References llvm_unreachable, and Opc.

◆ getParent()

BasicBlock * Instruction::getParent ( ) const

◆ getPrevNode()

Instruction * Instruction::getPrevNode ( ) const

\Returns the previous sandboxir::Instruction in the block, or nullptr if at the beginning of the block.

Definition at line 327 of file SandboxIR.cpp.

References assert(), getIterator(), and getParent().

Referenced by getTopmostLLVMInstruction().

◆ getTopmostLLVMInstruction()

llvm::Instruction * Instruction::getTopmostLLVMInstruction ( ) const
protected

A SandboxIR Instruction may map to multiple LLVM IR Instruction.

This returns its topmost LLVM IR instruction.

Definition at line 295 of file SandboxIR.cpp.

References llvm::ilist_node_with_parent< NodeTy, ParentTy, Options >::getNextNode(), getParent(), getPrevNode(), and llvm::sandboxir::Value::Val.

Referenced by llvm::sandboxir::LoadInst::create(), insertBefore(), insertInto(), and moveBefore().

◆ insertAfter()

void Instruction::insertAfter ( Instruction AfterI)

Insert this detached instruction after AfterI.

Definition at line 407 of file SandboxIR.cpp.

References getIterator(), getParent(), and insertInto().

◆ insertBefore()

void Instruction::insertBefore ( Instruction BeforeI)

Insert this detached instruction before BeforeI.

Definition at line 396 of file SandboxIR.cpp.

References assert(), getLLVMInstrs(), getTopmostLLVMInstruction(), I, and llvm::is_sorted().

Referenced by llvm::sandboxir::RemoveFromParent::revert().

◆ insertInto()

void Instruction::insertInto ( BasicBlock BB,
const BBIterator WhereIt 
)

◆ moveAfter()

void llvm::sandboxir::Instruction::moveAfter ( Instruction After)
inline

Move this instruction after After.

Definition at line 543 of file SandboxIR.h.

References After, and moveBefore().

◆ moveBefore() [1/2]

void Instruction::moveBefore ( BasicBlock BB,
const BBIterator WhereIt 
)

◆ moveBefore() [2/2]

void llvm::sandboxir::Instruction::moveBefore ( Instruction Before)
inline

Move this instruction before Before.

Definition at line 539 of file SandboxIR.h.

References Before, and moveBefore().

◆ removeFromParent()

void Instruction::removeFromParent ( )

Friends And Related Function Documentation

◆ EraseFromParent

friend class EraseFromParent
friend

Definition at line 503 of file SandboxIR.h.

◆ LoadInst

friend class LoadInst
friend

Definition at line 498 of file SandboxIR.h.

◆ operator<< [1/2]

raw_ostream & operator<< ( raw_ostream OS,
const sandboxir::Instruction SBI 
)
friend

Definition at line 553 of file SandboxIR.h.

◆ operator<< [2/2]

raw_ostream & operator<< ( raw_ostream OS,
Opcode  Opc 
)
friend

Definition at line 508 of file SandboxIR.h.

Member Data Documentation

◆ Opc

Opcode llvm::sandboxir::Instruction::Opc
protected

Definition at line 493 of file SandboxIR.h.

Referenced by getOpcode(), and getOpcodeName().


The documentation for this class was generated from the following files: