|
Jlm
|
#include <Store.hpp>


Public Member Functions | |
| ~StoreVolatileOperation () noexcept override | |
| StoreVolatileOperation (std::shared_ptr< const rvsdg::Type > storedType, const size_t numMemoryStates, const size_t alignment) | |
| bool | operator== (const Operation &other) const noexcept override |
| std::string | debug_string () const override |
| std::unique_ptr< Operation > | copy () const override |
Public Member Functions inherited from jlm::llvm::StoreOperation | |
| size_t | GetAlignment () const noexcept |
| const rvsdg::Type & | GetStoredType () const noexcept |
| size_t | NumMemoryStates () const noexcept |
Public Member Functions inherited from jlm::rvsdg::SimpleOperation | |
| ~SimpleOperation () noexcept override | |
| SimpleOperation (std::vector< std::shared_ptr< const jlm::rvsdg::Type >> operands, std::vector< std::shared_ptr< const jlm::rvsdg::Type >> results) | |
| size_t | narguments () const noexcept |
| const std::shared_ptr< const rvsdg::Type > & | argument (size_t index) const noexcept |
| size_t | nresults () const noexcept |
| const std::shared_ptr< const rvsdg::Type > & | result (size_t index) const noexcept |
Public Member Functions inherited from jlm::rvsdg::Operation | |
| virtual | ~Operation () noexcept |
| virtual bool | operator== (const Operation &other) const noexcept=0 |
| bool | operator!= (const Operation &other) const noexcept |
Static Public Member Functions | |
| static rvsdg::Input & | IOStateInput (const rvsdg::Node &node) noexcept |
| static rvsdg::Output & | IOStateOutput (const rvsdg::Node &node) noexcept |
| static std::unique_ptr< llvm::ThreeAddressCode > | Create (const Variable *address, const Variable *value, const Variable *ioState, const Variable *memoryState, size_t alignment) |
| static rvsdg::SimpleNode & | CreateNode (rvsdg::Region ®ion, std::unique_ptr< StoreVolatileOperation > storeOperation, const std::vector< rvsdg::Output * > &operands) |
| static rvsdg::SimpleNode & | CreateNode (rvsdg::Output &address, rvsdg::Output &value, rvsdg::Output &ioState, const std::vector< rvsdg::Output * > &memoryStates, size_t alignment) |
| static std::vector< rvsdg::Output * > | Create (rvsdg::Region ®ion, std::unique_ptr< StoreVolatileOperation > storeOperation, const std::vector< rvsdg::Output * > &operands) |
Static Public Member Functions inherited from jlm::llvm::StoreOperation | |
| static rvsdg::Input & | AddressInput (const rvsdg::Node &node) noexcept |
| static rvsdg::Input & | StoredValueInput (const rvsdg::Node &node) noexcept |
| static rvsdg::Node::OutputIteratorRange | MemoryStateOutputs (const rvsdg::SimpleNode &node) noexcept |
| static rvsdg::Input & | MapMemoryStateOutputToInput (const rvsdg::Output &output) |
Static Private Member Functions | |
| static std::shared_ptr< const rvsdg::Type > | CheckAndExtractStoredType (const std::shared_ptr< const rvsdg::Type > &type) |
| static std::vector< std::shared_ptr< const rvsdg::Type > > | CreateOperandTypes (std::shared_ptr< const rvsdg::Type > storedType, size_t numMemoryStates) |
| static std::vector< std::shared_ptr< const rvsdg::Type > > | CreateResultTypes (size_t numMemoryStates) |
Additional Inherited Members | |
Protected Member Functions inherited from jlm::llvm::StoreOperation | |
| StoreOperation (const std::vector< std::shared_ptr< const rvsdg::Type >> &operandTypes, const std::vector< std::shared_ptr< const rvsdg::Type >> &resultTypes, size_t numMemoryStates, size_t alignment) | |
Represents a volatile LLVM store instruction.
In contrast to LLVM, a volatile store requires in an RVSDG setting an I/O state as it incorporates externally visible side-effects. This I/O state allows the volatile store operation to be sequentialized with respect to other volatile memory accesses and I/O operations. This additional I/O state is the main reason why volatile stores are modeled as its own operation and volatile is not just a flag at the normal StoreNonVolatileOperation.
|
overridedefaultnoexcept |
|
inline |
|
inlinestaticprivate |
|
overridevirtual |
Implements jlm::rvsdg::Operation.
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestaticprivate |
|
inlinestaticprivate |
|
overridevirtual |
Implements jlm::rvsdg::Operation.
|
inlinestaticnoexcept |
|
inlinestaticnoexcept |
|
overridenoexcept |