Struct sp1_core::syscall::precompiles::sha256::ShaExtendChip
source · pub struct ShaExtendChip;Expand description
Implements the SHA extension operation which loops over i = [16, 63] and modifies w[i] in each iteration. The only input to the syscall is the 4byte-aligned pointer to the w array.
In the AIR, each SHA extend syscall takes up 48 rows, where each row corresponds to a single iteration of the loop.
Implementations§
source§impl ShaExtendChip
impl ShaExtendChip
pub fn eval_flags<AB: SP1AirBuilder>(&self, builder: &mut AB)
source§impl ShaExtendChip
impl ShaExtendChip
Trait Implementations§
source§impl<AB> Air<AB> for ShaExtendChipwhere
AB: SP1AirBuilder,
impl<AB> Air<AB> for ShaExtendChipwhere
AB: SP1AirBuilder,
source§impl<F> BaseAir<F> for ShaExtendChip
impl<F> BaseAir<F> for ShaExtendChip
fn preprocessed_trace(&self) -> Option<DenseMatrix<F>>
source§impl Default for ShaExtendChip
impl Default for ShaExtendChip
source§fn default() -> ShaExtendChip
fn default() -> ShaExtendChip
Returns the “default value” for a type. Read more
source§impl<F: PrimeField32> MachineAir<F> for ShaExtendChip
impl<F: PrimeField32> MachineAir<F> for ShaExtendChip
§type Record = ExecutionRecord
type Record = ExecutionRecord
The execution record containing events for producing the air trace.
type Program = Program
source§fn generate_trace(
&self,
input: &ExecutionRecord,
_: &mut ExecutionRecord,
) -> RowMajorMatrix<F>
fn generate_trace( &self, input: &ExecutionRecord, _: &mut ExecutionRecord, ) -> RowMajorMatrix<F>
Generate the trace for a given execution record. Read more
source§fn generate_dependencies(&self, input: &Self::Record, output: &mut Self::Record)
fn generate_dependencies(&self, input: &Self::Record, output: &mut Self::Record)
Generate the dependencies for a given execution record.
source§fn included(&self, shard: &Self::Record) -> bool
fn included(&self, shard: &Self::Record) -> bool
Whether this execution record contains events for this air.
source§fn preprocessed_width(&self) -> usize
fn preprocessed_width(&self) -> usize
The width of the preprocessed trace.
source§fn generate_preprocessed_trace(
&self,
_program: &Self::Program,
) -> Option<RowMajorMatrix<F>>
fn generate_preprocessed_trace( &self, _program: &Self::Program, ) -> Option<RowMajorMatrix<F>>
Generate the preprocessed trace given a specific program.
source§impl Syscall for ShaExtendChip
impl Syscall for ShaExtendChip
source§fn num_extra_cycles(&self) -> u32
fn num_extra_cycles(&self) -> u32
The number of extra cycles that the syscall takes to execute. Unless this syscall is complex
and requires many cycles, this should be zero.
source§fn execute(
&self,
rt: &mut SyscallContext<'_, '_>,
arg1: u32,
arg2: u32,
) -> Option<u32>
fn execute( &self, rt: &mut SyscallContext<'_, '_>, arg1: u32, arg2: u32, ) -> Option<u32>
Execute the syscall and return the resulting value of register a0.
arg1 and arg2 are the
values in registers X10 and X11, respectively. While not a hard requirement, the convention
is that the return value is only for system calls such as HALT. Most precompiles use arg1
and arg2 to denote the addresses of the input data, and write the result to the memory at
arg1.Auto Trait Implementations§
impl Freeze for ShaExtendChip
impl RefUnwindSafe for ShaExtendChip
impl Send for ShaExtendChip
impl Sync for ShaExtendChip
impl Unpin for ShaExtendChip
impl UnwindSafe for ShaExtendChip
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
Mutably borrows from an owned value. Read more
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
source§fn into_any(self: Box<T>) -> Box<dyn Any>
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>
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)
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)
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
impl<T> DowncastSync for T
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>
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 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>
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