sp1_core_machine::cpu::columns

Struct CpuCols

Source
#[repr(C)]
pub struct CpuCols<T: Copy> {
Show 23 fields pub shard: T, pub nonce: T, pub clk: T, pub clk_16bit_limb: T, pub clk_8bit_limb: T, pub pc: T, pub next_pc: T, pub instruction: InstructionCols<T>, pub selectors: OpcodeSelectorCols<T>, pub op_a_access: MemoryReadWriteCols<T>, pub op_b_access: MemoryReadCols<T>, pub op_c_access: MemoryReadCols<T>, pub opcode_specific_columns: OpcodeSpecificCols<T>, pub is_real: T, pub branching: T, pub not_branching: T, pub mem_value_is_neg_not_x0: T, pub mem_value_is_pos_not_x0: T, pub unsigned_mem_val: Word<T>, pub unsigned_mem_val_nonce: T, pub ecall_mul_send_to_table: T, pub ecall_range_check_operand: T, pub is_sequential_instr: T,
}
Expand description

The column layout for the CPU.

Fields§

§shard: T

The current shard.

§nonce: T§clk: T

The clock cycle value. This should be within 24 bits.

§clk_16bit_limb: T

The least significant 16 bit limb of clk.

§clk_8bit_limb: T

The most significant 8 bit limb of clk.

§pc: T

The program counter value.

§next_pc: T

The expected next program counter value.

§instruction: InstructionCols<T>

Columns related to the instruction.

§selectors: OpcodeSelectorCols<T>

Selectors for the opcode.

§op_a_access: MemoryReadWriteCols<T>

Operand values, either from registers or immediate values.

§op_b_access: MemoryReadCols<T>§op_c_access: MemoryReadCols<T>§opcode_specific_columns: OpcodeSpecificCols<T>§is_real: T

Selector to label whether this row is a non padded row.

§branching: T

The branching column is equal to:

is_beq & a_eq_b || is_bne & (a_lt_b | a_gt_b) || (is_blt | is_bltu) & a_lt_b || (is_bge | is_bgeu) & (a_eq_b | a_gt_b)

§not_branching: T

The not branching column is equal to:

is_beq & !a_eq_b || is_bne & !(a_lt_b | a_gt_b) || (is_blt | is_bltu) & !a_lt_b || (is_bge | is_bgeu) & !(a_eq_b | a_gt_b)

§mem_value_is_neg_not_x0: T

Flag for load mem instructions where the value is negative and not writing to x0. More formally, it is

(is_lb | is_lh) & (most_sig_byte_decomp[7] == 1) & (not writing to x0)

§mem_value_is_pos_not_x0: T

Flag for load mem instructions where the value is positive and not writing to x0. More formally, it is

( ((is_lb | is_lh) & (most_sig_byte_decomp[7] == 0)) | is_lbu | is_lhu | is_lw ) & (not writing to x0)

§unsigned_mem_val: Word<T>

The unsigned memory value is the value after the offset logic is applied. Used for the load memory opcodes (i.e. LB, LH, LW, LBU, and LHU).

§unsigned_mem_val_nonce: T§ecall_mul_send_to_table: T

The result of selectors.is_ecall * the send_to_table column for the ECALL opcode.

§ecall_range_check_operand: T

The result of selectors.is_ecall * (is_halt || is_commit_deferred_proofs)

§is_sequential_instr: T

This is true for all instructions that are not jumps, branches, and halt. Those instructions may move the program counter to a non sequential instruction.

Implementations§

Source§

impl<T: Copy> CpuCols<T>

Source

pub fn op_a_val(&self) -> Word<T>

Gets the value of the first operand.

Source

pub fn op_b_val(&self) -> Word<T>

Gets the value of the second operand.

Source

pub fn op_c_val(&self) -> Word<T>

Gets the value of the third operand.

Trait Implementations§

Source§

impl<T: Copy> Borrow<CpuCols<T>> for [T]

Source§

fn borrow(&self) -> &CpuCols<T>

Immutably borrows from an owned value. Read more
Source§

impl<T: Copy> BorrowMut<CpuCols<T>> for [T]

Source§

fn borrow_mut(&mut self) -> &mut CpuCols<T>

Mutably borrows from an owned value. Read more
Source§

impl<T: Clone + Copy> Clone for CpuCols<T>

Source§

fn clone(&self) -> CpuCols<T>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: Debug + Copy> Debug for CpuCols<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: Default + Copy> Default for CpuCols<T>

Source§

fn default() -> CpuCols<T>

Returns the “default value” for a type. Read more
Source§

impl<T: Copy + Copy> Copy for CpuCols<T>

Auto Trait Implementations§

§

impl<T> Freeze for CpuCols<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for CpuCols<T>
where T: RefUnwindSafe,

§

impl<T> Send for CpuCols<T>
where T: Send,

§

impl<T> Sync for CpuCols<T>
where T: Sync,

§

impl<T> Unpin for CpuCols<T>
where T: Unpin,

§

impl<T> UnwindSafe for CpuCols<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> JsonSchemaMaybe for T