Enum aluvm::isa::Instr[][src]

#[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

Control-flow instructions. See ControlFlowOp for the details.

Tuple Fields of ControlFlow

0: ControlFlowOp
Put

Instructions setting register values. See PutOp for the details.

Tuple Fields of Put

0: PutOp
Move

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

Tuple Fields of Move

0: MoveOp
Cmp

Instructions comparing register values. See CmpOp for the details.

Tuple Fields of Cmp

0: CmpOp
Arithmetic

Arithmetic instructions. See ArithmeticOp for the details.

Tuple Fields of Arithmetic

0: ArithmeticOp
Bitwise

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

Tuple Fields of Bitwise

0: BitwiseOp
Bytes

Operations on byte strings. See BytesOp for the details.

Tuple Fields of Bytes

0: BytesOp
Digest

Cryptographic hashing functions. See DigestOp for the details.

Tuple Fields of Digest

0: DigestOp
ExtensionCodes

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

Tuple Fields of ExtensionCodes

0: Extension
ReservedInstruction

Reserved instruction for fututre use in core ALU ISA.

Currently equal to ControlFlowOp::Fail.

Tuple Fields of ReservedInstruction

0: ReservedOp
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. Read more

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 ==. Read more

This method tests for !=.

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

Performs the conversion.

Performs the conversion.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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.