Enum aluvm::isa::Instr

source ·
#[non_exhaustive]
pub enum Instr<Extension = ReservedOp>where
    Extension: InstructionSet,
{ ControlFlow(ControlFlowOp), Put(PutOp), Move(MoveOp), Cmp(CmpOp), Arithmetic(ArithmeticOp), Bitwise(BitwiseOp), Bytes(BytesOp), Digest(DigestOp), ExtensionCodes(Extension), ReservedInstruction(ReservedOp), Nop, }
Expand description

Full set of instructions

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

ControlFlow(ControlFlowOp)

Control-flow instructions. See ControlFlowOp for the details.

§

Put(PutOp)

Instructions setting register values. See PutOp for the details.

§

Move(MoveOp)

Instructions moving and swapping register values. See PutOp for the details.

§

Cmp(CmpOp)

Instructions comparing register values. See CmpOp for the details.

§

Arithmetic(ArithmeticOp)

Arithmetic instructions. See ArithmeticOp for the details.

§

Bitwise(BitwiseOp)

Bit operations & boolean algebra instructions. See BitwiseOp for the details.

§

Bytes(BytesOp)

Operations on byte strings. See BytesOp for the details.

§

Digest(DigestOp)

Cryptographic hashing functions. See DigestOp for the details.

§

ExtensionCodes(Extension)

Extension operations which can be provided by a host environment provided via generic parameter

§

ReservedInstruction(ReservedOp)

Reserved instruction for fututre use in core ALU ISA.

Currently equal to ControlFlowOp::Fail.

§

Nop

No-operation instruction.

Trait Implementations§

Returns number of bytes which instruction and its argument occupies
Returns range of instruction btecodes covered by a set of operations
Returns byte representing instruction code (without its arguments)
If the instruction call or references any external library, returns the call site in that library.
Writes instruction arguments as bytecode, omitting instruction code byte
Reads the instruction from bytecode
Writes the instruction as bytecode
Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Formats the value using the given formatter. Read more
Feeds this value into the given Hasher. Read more
Feeds a slice of this type into the given Hasher. Read more
ISA Extensions used by the provided instruction set. Read more
Executes given instruction taking all registers as input and output. Read more
ISA Extension IDs represented as a standard string (space-separated) Read more
ISA Extension IDs encoded in a standard way (space-separated) Read more
Checks whether provided ISA extension ID is supported by the current instruction set
Returns computational complexity of the instruction
This method tests for self and other values to be equal, and is used by ==.
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
Converts the given value to a String. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.