#[repr(C)]pub struct Instruction {
pub opcode: Opcode,
pub op_a: u8,
pub op_b: u64,
pub op_c: u64,
pub imm_b: bool,
pub imm_c: bool,
}Expand description
RISC-V 64IM Instruction.
The structure of the instruction differs from the RISC-V ISA. We do not encode the instructions as 32-bit words, but instead use a custom encoding that is more friendly to decode in the SP1 zkVM.
Fields§
§opcode: OpcodeThe operation to execute.
op_a: u8The first operand.
op_b: u64The second operand.
op_c: u64The third operand.
imm_b: boolWhether the second operand is an immediate value.
imm_c: boolWhether the third operand is an immediate value.
Implementations§
Source§impl Instruction
impl Instruction
Sourcepub const fn from_r_type(opcode: Opcode, dec_insn: &RType) -> Self
pub const fn from_r_type(opcode: Opcode, dec_insn: &RType) -> Self
Create a new Instruction from an R-type instruction.
Sourcepub const fn from_i_type(opcode: Opcode, dec_insn: &IType) -> Self
pub const fn from_i_type(opcode: Opcode, dec_insn: &IType) -> Self
Create a new Instruction from an I-type instruction.
Sourcepub const fn from_i_type_shamt(opcode: Opcode, dec_insn: &ITypeShamt) -> Self
pub const fn from_i_type_shamt(opcode: Opcode, dec_insn: &ITypeShamt) -> Self
Create a new Instruction from an I-type instruction with a shamt.
Sourcepub const fn from_i_type_shamt_w(opcode: Opcode, dec_insn: &ITypeShamtW) -> Self
pub const fn from_i_type_shamt_w(opcode: Opcode, dec_insn: &ITypeShamtW) -> Self
Create a new Instruction from an I-type instruction with a shamt_w.
Sourcepub const fn from_s_type(opcode: Opcode, dec_insn: &SType) -> Self
pub const fn from_s_type(opcode: Opcode, dec_insn: &SType) -> Self
Create a new Instruction from an S-type instruction.
Sourcepub const fn from_b_type(opcode: Opcode, dec_insn: &BType) -> Self
pub const fn from_b_type(opcode: Opcode, dec_insn: &BType) -> Self
Create a new Instruction from a B-type instruction.
Sourcepub const fn from_u_type(opcode: Opcode, dec_insn: &UType) -> Self
pub const fn from_u_type(opcode: Opcode, dec_insn: &UType) -> Self
Create a new Instruction from an U-type instruction.
Sourcepub const fn unimp() -> Self
pub const fn unimp() -> Self
Create a new Instruction that is not implemented.
Sourcepub const fn is_r_type(&self) -> bool
pub const fn is_r_type(&self) -> bool
Returns if the Instruction is an R-type instruction.
Sourcepub const fn is_i_type(&self) -> bool
pub const fn is_i_type(&self) -> bool
Returns whether the Instruction is an I-type instruction.
Sourcepub fn r_type(&self) -> (Register, Register, Register)
pub fn r_type(&self) -> (Register, Register, Register)
Decode the Instruction in the R-type format.
Sourcepub fn j_type(&self) -> (Register, u64)
pub fn j_type(&self) -> (Register, u64)
Decode the Instruction in the J-type format.
Sourcepub fn u_type(&self) -> (Register, u64)
pub fn u_type(&self) -> (Register, u64)
Decode the Instruction in the U-type format.
Source§impl Instruction
impl Instruction
Sourcepub const fn new(
opcode: Opcode,
op_a: u8,
op_b: u64,
op_c: u64,
imm_b: bool,
imm_c: bool,
) -> Self
pub const fn new( opcode: Opcode, op_a: u8, op_b: u64, op_c: u64, imm_b: bool, imm_c: bool, ) -> Self
Create a new [RiscvInstruction].
Sourcepub const fn is_alu_instruction(&self) -> bool
pub const fn is_alu_instruction(&self) -> bool
Returns if the instruction is an ALU instruction.
Sourcepub const fn is_ecall_instruction(&self) -> bool
pub const fn is_ecall_instruction(&self) -> bool
Returns if the instruction is a ecall instruction.
Sourcepub const fn is_memory_load_instruction(&self) -> bool
pub const fn is_memory_load_instruction(&self) -> bool
Returns if the instruction is a memory load instruction.
Sourcepub const fn is_memory_store_instruction(&self) -> bool
pub const fn is_memory_store_instruction(&self) -> bool
Returns if the instruction is a memory store instruction.
Sourcepub const fn is_branch_instruction(&self) -> bool
pub const fn is_branch_instruction(&self) -> bool
Returns if the instruction is a branch instruction.
Sourcepub const fn is_jump_instruction(&self) -> bool
pub const fn is_jump_instruction(&self) -> bool
Returns if the instruction is a jump instruction.
Sourcepub const fn is_jal_instruction(&self) -> bool
pub const fn is_jal_instruction(&self) -> bool
Returns if the instruction is a jal instruction.
Sourcepub const fn is_jalr_instruction(&self) -> bool
pub const fn is_jalr_instruction(&self) -> bool
Returns if the instruction is a jalr instruction.
Sourcepub const fn is_utype_instruction(&self) -> bool
pub const fn is_utype_instruction(&self) -> bool
Returns if the instruction is a utype instruction.
Sourcepub const fn is_with_correct_next_pc(&self) -> bool
pub const fn is_with_correct_next_pc(&self) -> bool
Returns if the instruction guarantees that the next_pc are with correct limbs.
Sourcepub const fn is_divrem_instruction(&self) -> bool
pub const fn is_divrem_instruction(&self) -> bool
Returns if the instruction is a divrem instruction.
Sourcepub const fn is_ebreak_instruction(&self) -> bool
pub const fn is_ebreak_instruction(&self) -> bool
Returns if the instruction is an ebreak instruction.
Sourcepub const fn is_unimp_instruction(&self) -> bool
pub const fn is_unimp_instruction(&self) -> bool
Returns if the instruction is an unimplemented instruction.
Trait Implementations§
Source§impl Clone for Instruction
impl Clone for Instruction
Source§fn clone(&self) -> Instruction
fn clone(&self) -> Instruction
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for Instruction
impl Debug for Instruction
Source§impl DeepSizeOf for Instruction
impl DeepSizeOf for Instruction
Source§fn deep_size_of_children(&self, context: &mut Context) -> usize
fn deep_size_of_children(&self, context: &mut Context) -> usize
Source§fn deep_size_of(&self) -> usize
fn deep_size_of(&self) -> usize
Source§impl<'de> Deserialize<'de> for Instruction
impl<'de> Deserialize<'de> for Instruction
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl Serialize for Instruction
impl Serialize for Instruction
impl Copy for Instruction
Auto Trait Implementations§
impl Freeze for Instruction
impl RefUnwindSafe for Instruction
impl Send for Instruction
impl Sync for Instruction
impl Unpin for Instruction
impl UnsafeUnpin for Instruction
impl UnwindSafe for Instruction
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<Challenger, A> FromChallenger<Challenger, A> for Challengerwhere
Challenger: Clone,
impl<Challenger, A> FromChallenger<Challenger, A> for Challengerwhere
Challenger: Clone,
fn from_challenger(challenger: &Challenger, _backend: &A) -> Challenger
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.