pub struct EthBlockHeaderChip<'chip, F: Field> {
pub rlp: RlpChip<'chip, F>,
pub max_extra_data_bytes: usize,
}Fields§
§rlp: RlpChip<'chip, F>§max_extra_data_bytes: usizeImplementations§
Source§impl<'chip, F: Field> EthBlockHeaderChip<'chip, F>
impl<'chip, F: Field> EthBlockHeaderChip<'chip, F>
pub fn new(rlp: RlpChip<'chip, F>, max_extra_data_bytes: usize) -> Self
pub fn new_from_network(rlp: RlpChip<'chip, F>, chain: Chain) -> Self
pub fn gate(&self) -> &GateChip<F>
pub fn range(&self) -> &RangeChip<F>
pub fn rlc(&self) -> &RlcChip<F>
pub fn rlp(&self) -> &RlpChip<'_, F>
Sourcepub fn decompose_block_header_phase0(
&self,
ctx: &mut Context<F>,
keccak: &KeccakChip<F>,
block_header: &[AssignedValue<F>],
) -> EthBlockHeaderWitness<F>
pub fn decompose_block_header_phase0( &self, ctx: &mut Context<F>, keccak: &KeccakChip<F>, block_header: &[AssignedValue<F>], ) -> EthBlockHeaderWitness<F>
Takes the variable length RLP encoded block header, padded with 0s to the maximum possible block header RLP length, and outputs the decomposition into block header fields.
This function will range check that block_header consists of bytes (8 bits).
In addition, the keccak block hash of the block is calculated.
This is the preparation step that computes the witnesses. This MUST be done in FirstPhase.
The accompanying decompose_block_header_phase1 must be called in SecondPhase to constrain the RLCs associated to the RLP decoding.
Sourcepub fn decompose_block_header_phase1(
&self,
ctx: RlcContextPair<'_, F>,
witness: EthBlockHeaderWitness<F>,
) -> EthBlockHeaderTrace<F>
pub fn decompose_block_header_phase1( &self, ctx: RlcContextPair<'_, F>, witness: EthBlockHeaderWitness<F>, ) -> EthBlockHeaderTrace<F>
Takes the variable length RLP encoded block header, padded with 0s to the maximum possible block header RLP length, and outputs the decomposition into block header fields.
In addition, the keccak block hash of the block is calculated.
This is the finalization step that constrains RLC concatenations.
This should be called after decompose_block_header_phase0.
This MUST be done in SecondPhase.
Sourcepub fn decompose_block_headers_phase0(
&self,
builder: &mut RlcCircuitBuilder<F>,
keccak: &KeccakChip<F>,
block_headers: Vec<Vec<AssignedValue<F>>>,
) -> Vec<EthBlockHeaderWitness<F>>
pub fn decompose_block_headers_phase0( &self, builder: &mut RlcCircuitBuilder<F>, keccak: &KeccakChip<F>, block_headers: Vec<Vec<AssignedValue<F>>>, ) -> Vec<EthBlockHeaderWitness<F>>
Makes multiple calls to decompose_block_header_phase0 in parallel threads. Should be called in FirstPhase.
Sourcepub fn decompose_block_headers_phase1(
&self,
builder: &mut RlcCircuitBuilder<F>,
witnesses: Vec<EthBlockHeaderWitness<F>>,
) -> Vec<EthBlockHeaderTrace<F>>
pub fn decompose_block_headers_phase1( &self, builder: &mut RlcCircuitBuilder<F>, witnesses: Vec<EthBlockHeaderWitness<F>>, ) -> Vec<EthBlockHeaderTrace<F>>
Makes multiple calls to decompose_block_header_phase1 in parallel threads. Should be called in SecondPhase.
Sourcepub fn decompose_block_header_chain_phase0(
&self,
builder: &mut RlcCircuitBuilder<F>,
keccak: &KeccakChip<F>,
block_headers: Vec<Vec<AssignedValue<F>>>,
) -> Vec<EthBlockHeaderWitness<F>>
pub fn decompose_block_header_chain_phase0( &self, builder: &mut RlcCircuitBuilder<F>, keccak: &KeccakChip<F>, block_headers: Vec<Vec<AssignedValue<F>>>, ) -> Vec<EthBlockHeaderWitness<F>>
Takes a list of (purported) RLP encoded block headers and
decomposes each header into it’s fields.
headers[0] is the earliest block.
This is the preparation step that computes the witnesses. This MUST be done in FirstPhase.
The accompanying decompose_block_header_chain_phase1 must be called in SecondPhase to constrain the RLCs associated to the RLP decoding.
Sourcepub fn decompose_block_header_chain_phase1(
&self,
builder: &mut RlcCircuitBuilder<F>,
witnesses: Vec<EthBlockHeaderWitness<F>>,
num_blocks_minus_one: Option<(AssignedValue<F>, Vec<AssignedValue<F>>)>,
) -> Vec<EthBlockHeaderTrace<F>>
pub fn decompose_block_header_chain_phase1( &self, builder: &mut RlcCircuitBuilder<F>, witnesses: Vec<EthBlockHeaderWitness<F>>, num_blocks_minus_one: Option<(AssignedValue<F>, Vec<AssignedValue<F>>)>, ) -> Vec<EthBlockHeaderTrace<F>>
Takes a list of 2^max_depth (purported) RLP encoded block headers.
Decomposes each header into it’s fields.
headers[0] is the earliest block
- If
num_blocks_minus_one = (num_blocks_minus_one, indicator)is not None, then the circuit checks that the firstnum_blocks := num_blocks_minus_one + 1block headers form a chain: meaning that the parent hash of block i + 1 equals the hash of block i. indicatoris a vector with indexiequal toi == num_blocks - 1 ? 1 : 0.- Otherwise if
num_blocksis None, the circuit checks that allheadersform a hash chain.
Assumes that 0 <= num_blocks_minus_one < 2^max_depth.
This is the finalization step that constrains RLC concatenations. In this step the hash chain is actually constrained.
This should be called after decompose_block_header_chain_phase0.
This MUST be done in SecondPhase.
Auto Trait Implementations§
impl<'chip, F> Freeze for EthBlockHeaderChip<'chip, F>
impl<'chip, F> RefUnwindSafe for EthBlockHeaderChip<'chip, F>where
F: RefUnwindSafe,
impl<'chip, F> Send for EthBlockHeaderChip<'chip, F>
impl<'chip, F> Sync for EthBlockHeaderChip<'chip, F>
impl<'chip, F> Unpin for EthBlockHeaderChip<'chip, F>
impl<'chip, F> UnsafeUnpin for EthBlockHeaderChip<'chip, F>
impl<'chip, F> UnwindSafe for EthBlockHeaderChip<'chip, F>where
F: RefUnwindSafe,
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
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<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> 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 moreimpl<T> JsonSchemaMaybe for T
Source§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
impl<T> Read<Exclusive, BecauseExclusive> for Twhere
T: ?Sized,
Source§impl<F, Fp, Pt, FC> Selectable<F, Reduced<Pt, Fp>> for FC
impl<F, Fp, Pt, FC> Selectable<F, Reduced<Pt, Fp>> for FC
impl<T> SyncDeps 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.