Struct sp1_core::syscall::precompiles::sha256::ShaCompressChip
source · pub struct ShaCompressChip;Expand description
Implements the SHA compress operation which loops over 0 = [0, 63] and modifies A-H in each iteration. The inputs to the syscall are a pointer to the 64 word array W and a pointer to the 8 word array H.
In the AIR, each SHA compress syscall takes up 80 rows. The first and last 8 rows are for initialization and finalize respectively. The middle 64 rows are for compression. Each row operates over a single memory word.
Implementations§
Trait Implementations§
source§impl<AB> Air<AB> for ShaCompressChipwhere
AB: SP1AirBuilder,
impl<AB> Air<AB> for ShaCompressChipwhere
AB: SP1AirBuilder,
source§impl<F> BaseAir<F> for ShaCompressChip
impl<F> BaseAir<F> for ShaCompressChip
fn preprocessed_trace(&self) -> Option<DenseMatrix<F>>
source§impl Default for ShaCompressChip
impl Default for ShaCompressChip
source§fn default() -> ShaCompressChip
fn default() -> ShaCompressChip
Returns the “default value” for a type. Read more
source§impl<F: PrimeField32> MachineAir<F> for ShaCompressChip
impl<F: PrimeField32> MachineAir<F> for ShaCompressChip
§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 ShaCompressChip
impl Syscall for ShaCompressChip
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 ShaCompressChip
impl RefUnwindSafe for ShaCompressChip
impl Send for ShaCompressChip
impl Sync for ShaCompressChip
impl Unpin for ShaCompressChip
impl UnwindSafe for ShaCompressChip
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