mini-llvm 0.1.0
Loading...
Searching...
No Matches
mini_llvm::mir::Load Class Reference

#include <Load.h>

Inheritance diagram for mini_llvm::mir::Load:
Collaboration diagram for mini_llvm::mir::Load:

Public Member Functions

 Load (int width, std::shared_ptr< Register > dst, MemoryOperand src, ExtensionMode extMode=ExtensionMode::kNo)
int width () const
template<typename Self>
auto & dst (this Self &&self)
template<typename Self>
auto & src (this Self &&self)
ExtensionMode extMode () const
std::unordered_set< const RegisterOperand * > regOps () const override
std::unordered_set< const RegisterOperand * > dsts () const override
std::unordered_set< const RegisterOperand * > srcs () const override
std::unordered_set< const ImmediateOperand * > immOps () const override
std::unordered_set< const MemoryOperand * > memOps () const override
bool hasSideEffects () const override
std::string format () const override
std::unique_ptr< Instructionclone () const override
void accept (InstructionVisitor &visitor) override
void accept (InstructionVisitor &visitor) const override
Public Member Functions inherited from mini_llvm::mir::Instruction
virtual ~Instruction ()=default
 Instruction ()=default
 Instruction (const Instruction &)=delete
Instructionoperator= (const Instruction &)=delete
 Instruction (Instruction &&)=delete
Instructionoperator= (Instruction &&)=delete
std::unordered_set< RegisterOperand * > regOps ()
std::unordered_set< RegisterOperand * > dsts ()
std::unordered_set< RegisterOperand * > srcs ()
virtual std::unordered_set< PhysicalRegister * > implicitDsts () const
virtual std::unordered_set< PhysicalRegister * > implicitSrcs () const
std::unordered_set< ImmediateOperand * > immOps ()
std::unordered_set< MemoryOperand * > memOps ()
virtual bool isCoalescent () const
virtual RegistercoalescenceDst () const
virtual RegistercoalescenceSrc () const

Constructor & Destructor Documentation

◆ Load()

mini_llvm::mir::Load::Load ( int width,
std::shared_ptr< Register > dst,
MemoryOperand src,
ExtensionMode extMode = ExtensionMode::kNo )
inline

Member Function Documentation

◆ accept() [1/2]

void mini_llvm::mir::Load::accept ( InstructionVisitor & visitor) const
inlineoverridevirtual

◆ accept() [2/2]

void mini_llvm::mir::Load::accept ( InstructionVisitor & visitor)
inlineoverridevirtual

◆ clone()

std::unique_ptr< Instruction > mini_llvm::mir::Load::clone ( ) const
inlineoverridevirtual

◆ dst()

template<typename Self>
auto & mini_llvm::mir::Load::dst ( this Self && self)
inline

◆ dsts()

std::unordered_set< const RegisterOperand * > mini_llvm::mir::Load::dsts ( ) const
inlineoverridevirtual

◆ extMode()

ExtensionMode mini_llvm::mir::Load::extMode ( ) const
inline

◆ format()

std::string mini_llvm::mir::Load::format ( ) const
overridevirtual

◆ hasSideEffects()

bool mini_llvm::mir::Load::hasSideEffects ( ) const
inlineoverridevirtual

◆ immOps()

std::unordered_set< const ImmediateOperand * > mini_llvm::mir::Load::immOps ( ) const
inlineoverridevirtual

◆ memOps()

std::unordered_set< const MemoryOperand * > mini_llvm::mir::Load::memOps ( ) const
inlineoverridevirtual

◆ regOps()

std::unordered_set< const RegisterOperand * > mini_llvm::mir::Load::regOps ( ) const
inlineoverridevirtual

◆ src()

template<typename Self>
auto & mini_llvm::mir::Load::src ( this Self && self)
inline

◆ srcs()

std::unordered_set< const RegisterOperand * > mini_llvm::mir::Load::srcs ( ) const
inlineoverridevirtual

◆ width()

int mini_llvm::mir::Load::width ( ) const
inline

The documentation for this class was generated from the following file:
  • include/mini-llvm/mir/Instruction/Load.h