From 482cf57dd2999980b8d4775f4bbfc8c659e7dd56 Mon Sep 17 00:00:00 2001 From: John Guibas Date: Wed, 30 Oct 2024 11:40:31 -0700 Subject: [PATCH 01/13] fix: remove stdin from SP1ProofWithPublicValues (#1714) --- Cargo.lock | 88 +++++++++++++++++ crates/sdk/src/provers/cpu.rs | 127 +++++++++++++++++++++++++ crates/sdk/src/provers/cuda.rs | 121 ++++++++++++++++++++++++ crates/sdk/src/provers/mock.rs | 166 +++++++++++++++++++++++++++++++++ 4 files changed, 502 insertions(+) create mode 100644 crates/sdk/src/provers/cpu.rs create mode 100644 crates/sdk/src/provers/cuda.rs create mode 100644 crates/sdk/src/provers/mock.rs diff --git a/Cargo.lock b/Cargo.lock index 034824d0bf..20a5830941 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5448,7 +5448,11 @@ dependencies = [ [[package]] name = "sp1-build" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "cargo_metadata", @@ -5459,7 +5463,11 @@ dependencies = [ [[package]] name = "sp1-cli" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anstyle", "anyhow", @@ -5488,7 +5496,11 @@ dependencies = [ [[package]] name = "sp1-core-executor" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "bytemuck", @@ -5527,7 +5539,11 @@ dependencies = [ [[package]] name = "sp1-core-machine" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "cfg-if", @@ -5577,7 +5593,11 @@ dependencies = [ [[package]] name = "sp1-cuda" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "ctrlc", @@ -5595,7 +5615,11 @@ dependencies = [ [[package]] name = "sp1-curves" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "cfg-if", "dashu", @@ -5617,7 +5641,11 @@ dependencies = [ [[package]] name = "sp1-derive" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "quote", "syn 1.0.109", @@ -5625,7 +5653,11 @@ dependencies = [ [[package]] name = "sp1-eval" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "bincode", @@ -5643,13 +5675,18 @@ dependencies = [ [[package]] name = "sp1-helper" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "sp1-build", ] [[package]] name = "sp1-lib" +<<<<<<< HEAD version = "3.2.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1c8744af050832df5ca44fcd63979a83b93ca3010b2d5a5ce2a2b91f7438065c" @@ -5661,6 +5698,9 @@ dependencies = [ [[package]] name = "sp1-lib" version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "serde", @@ -5668,7 +5708,11 @@ dependencies = [ [[package]] name = "sp1-perf" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "clap", @@ -5684,7 +5728,11 @@ dependencies = [ [[package]] name = "sp1-primitives" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "hex", @@ -5700,7 +5748,11 @@ dependencies = [ [[package]] name = "sp1-prover" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "bincode", @@ -5737,7 +5789,11 @@ dependencies = [ [[package]] name = "sp1-recursion-circuit" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "ff 0.13.0", "hashbrown 0.14.5", @@ -5774,7 +5830,11 @@ dependencies = [ [[package]] name = "sp1-recursion-compiler" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "backtrace", "criterion", @@ -5799,7 +5859,11 @@ dependencies = [ [[package]] name = "sp1-recursion-core" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "backtrace", "ff 0.13.0", @@ -5834,7 +5898,11 @@ dependencies = [ [[package]] name = "sp1-recursion-derive" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "quote", "syn 1.0.109", @@ -5842,7 +5910,11 @@ dependencies = [ [[package]] name = "sp1-recursion-gnark-cli" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "clap", @@ -5851,7 +5923,11 @@ dependencies = [ [[package]] name = "sp1-recursion-gnark-ffi" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "bincode", @@ -5875,7 +5951,11 @@ dependencies = [ [[package]] name = "sp1-sdk" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "alloy-primitives", "alloy-signer", @@ -5923,7 +6003,11 @@ dependencies = [ [[package]] name = "sp1-stark" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "arrayref", "hashbrown 0.14.5", @@ -5970,7 +6054,11 @@ dependencies = [ [[package]] name = "sp1-zkvm" +<<<<<<< HEAD version = "3.4.0" +======= +version = "3.1.0" +>>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "cfg-if", "getrandom 0.2.15", diff --git a/crates/sdk/src/provers/cpu.rs b/crates/sdk/src/provers/cpu.rs new file mode 100644 index 0000000000..467cca0c07 --- /dev/null +++ b/crates/sdk/src/provers/cpu.rs @@ -0,0 +1,127 @@ +use anyhow::Result; +use sp1_core_executor::SP1Context; +use sp1_core_machine::io::SP1Stdin; +use sp1_prover::{components::DefaultProverComponents, SP1Prover}; + +use crate::install::try_install_circuit_artifacts; +use crate::{ + provers::ProofOpts, Prover, SP1Proof, SP1ProofKind, SP1ProofWithPublicValues, SP1ProvingKey, + SP1VerifyingKey, +}; + +use super::ProverType; + +/// An implementation of [crate::ProverClient] that can generate end-to-end proofs locally. +pub struct CpuProver { + prover: SP1Prover, +} + +impl CpuProver { + /// Creates a new [LocalProver]. + pub fn new() -> Self { + let prover = SP1Prover::new(); + Self { prover } + } + + /// Creates a new [LocalProver] from an existing [SP1Prover]. + pub fn from_prover(prover: SP1Prover) -> Self { + Self { prover } + } +} + +impl Prover for CpuProver { + fn id(&self) -> ProverType { + ProverType::Cpu + } + + fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey) { + self.prover.setup(elf) + } + + fn sp1_prover(&self) -> &SP1Prover { + &self.prover + } + + fn prove<'a>( + &'a self, + pk: &SP1ProvingKey, + stdin: SP1Stdin, + opts: ProofOpts, + context: SP1Context<'a>, + kind: SP1ProofKind, + ) -> Result { + // Generate the core proof. + let proof: sp1_prover::SP1ProofWithMetadata = + self.prover.prove_core(pk, &stdin, opts.sp1_prover_opts, context)?; + if kind == SP1ProofKind::Core { + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Core(proof.proof.0), + public_values: proof.public_values, + sp1_version: self.version().to_string(), + }); + } + + let deferred_proofs = + stdin.proofs.iter().map(|(reduce_proof, _)| reduce_proof.clone()).collect(); + let public_values = proof.public_values.clone(); + + // Generate the compressed proof. + let reduce_proof = + self.prover.compress(&pk.vk, proof, deferred_proofs, opts.sp1_prover_opts)?; + if kind == SP1ProofKind::Compressed { + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Compressed(Box::new(reduce_proof)), + public_values, + sp1_version: self.version().to_string(), + }); + } + + // Generate the shrink proof. + let compress_proof = self.prover.shrink(reduce_proof, opts.sp1_prover_opts)?; + + // Genenerate the wrap proof. + let outer_proof = self.prover.wrap_bn254(compress_proof, opts.sp1_prover_opts)?; + + if kind == SP1ProofKind::Plonk { + let plonk_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { + sp1_prover::build::try_build_plonk_bn254_artifacts_dev( + &outer_proof.vk, + &outer_proof.proof, + ) + } else { + try_install_circuit_artifacts("plonk") + }; + let proof = self.prover.wrap_plonk_bn254(outer_proof, &plonk_bn254_artifacts); + + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Plonk(proof), + public_values, + sp1_version: self.version().to_string(), + }); + } else if kind == SP1ProofKind::Groth16 { + let groth16_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { + sp1_prover::build::try_build_groth16_bn254_artifacts_dev( + &outer_proof.vk, + &outer_proof.proof, + ) + } else { + try_install_circuit_artifacts("groth16") + }; + + let proof = self.prover.wrap_groth16_bn254(outer_proof, &groth16_bn254_artifacts); + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Groth16(proof), + public_values, + sp1_version: self.version().to_string(), + }); + } + + unreachable!() + } +} + +impl Default for CpuProver { + fn default() -> Self { + Self::new() + } +} diff --git a/crates/sdk/src/provers/cuda.rs b/crates/sdk/src/provers/cuda.rs new file mode 100644 index 0000000000..2cb28b070f --- /dev/null +++ b/crates/sdk/src/provers/cuda.rs @@ -0,0 +1,121 @@ +use anyhow::Result; +use sp1_core_machine::io::SP1Stdin; +use sp1_cuda::SP1CudaProver; +use sp1_prover::{components::DefaultProverComponents, SP1Prover}; + +use super::ProverType; +use crate::install::try_install_circuit_artifacts; +use crate::{ + provers::ProofOpts, Prover, SP1Context, SP1Proof, SP1ProofKind, SP1ProofWithPublicValues, + SP1ProvingKey, SP1VerifyingKey, +}; + +/// An implementation of [crate::ProverClient] that can generate proofs locally using CUDA. +pub struct CudaProver { + prover: SP1Prover, + cuda_prover: SP1CudaProver, +} + +impl CudaProver { + /// Creates a new [CudaProver]. + pub fn new(prover: SP1Prover) -> Self { + let cuda_prover = SP1CudaProver::new(); + Self { prover, cuda_prover: cuda_prover.expect("Failed to initialize CUDA prover") } + } +} + +impl Prover for CudaProver { + fn id(&self) -> ProverType { + ProverType::Cuda + } + + fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey) { + self.prover.setup(elf) + } + + fn sp1_prover(&self) -> &SP1Prover { + &self.prover + } + + fn prove<'a>( + &'a self, + pk: &SP1ProvingKey, + stdin: SP1Stdin, + _opts: ProofOpts, + _context: SP1Context<'a>, + kind: SP1ProofKind, + ) -> Result { + tracing::warn!("opts and context are ignored for the cuda prover"); + + // Generate the core proof. + let proof = self.cuda_prover.prove_core(pk, &stdin)?; + if kind == SP1ProofKind::Core { + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Core(proof.proof.0), + public_values: proof.public_values, + sp1_version: self.version().to_string(), + }); + } + + let deferred_proofs = + stdin.proofs.iter().map(|(reduce_proof, _)| reduce_proof.clone()).collect(); + let public_values = proof.public_values.clone(); + + // Generate the compressed proof. + let reduce_proof = self.cuda_prover.compress(&pk.vk, proof, deferred_proofs)?; + if kind == SP1ProofKind::Compressed { + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Compressed(Box::new(reduce_proof)), + public_values, + sp1_version: self.version().to_string(), + }); + } + + // Generate the shrink proof. + let compress_proof = self.cuda_prover.shrink(reduce_proof)?; + + // Genenerate the wrap proof. + let outer_proof = self.cuda_prover.wrap_bn254(compress_proof)?; + + if kind == SP1ProofKind::Plonk { + let plonk_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { + sp1_prover::build::try_build_plonk_bn254_artifacts_dev( + &outer_proof.vk, + &outer_proof.proof, + ) + } else { + try_install_circuit_artifacts("plonk") + }; + let proof = self.prover.wrap_plonk_bn254(outer_proof, &plonk_bn254_artifacts); + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Plonk(proof), + public_values, + sp1_version: self.version().to_string(), + }); + } else if kind == SP1ProofKind::Groth16 { + let groth16_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { + sp1_prover::build::try_build_groth16_bn254_artifacts_dev( + &outer_proof.vk, + &outer_proof.proof, + ) + } else { + try_install_circuit_artifacts("groth16") + }; + + let proof = self.prover.wrap_groth16_bn254(outer_proof, &groth16_bn254_artifacts); + return Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Groth16(proof), + public_values, + sp1_version: self.version().to_string(), + }); + } + + unreachable!() + } +} + +impl Default for CudaProver { + fn default() -> Self { + Self::new(SP1Prover::new()) + } +} diff --git a/crates/sdk/src/provers/mock.rs b/crates/sdk/src/provers/mock.rs new file mode 100644 index 0000000000..dc1df94681 --- /dev/null +++ b/crates/sdk/src/provers/mock.rs @@ -0,0 +1,166 @@ +#![allow(unused_variables)] +use hashbrown::HashMap; +use sp1_core_executor::{SP1Context, SP1ReduceProof}; +use sp1_core_machine::io::SP1Stdin; +use sp1_stark::{ShardCommitment, ShardOpenedValues, ShardProof, StarkVerifyingKey}; + +use crate::{ + Prover, SP1Proof, SP1ProofKind, SP1ProofWithPublicValues, SP1ProvingKey, SP1VerificationError, + SP1VerifyingKey, +}; +use anyhow::Result; +use p3_baby_bear::BabyBear; +use p3_field::{AbstractField, PrimeField}; +use p3_fri::{FriProof, TwoAdicFriPcsProof}; +use sp1_prover::{ + components::DefaultProverComponents, + verify::{verify_groth16_bn254_public_inputs, verify_plonk_bn254_public_inputs}, + Groth16Bn254Proof, HashableKey, PlonkBn254Proof, SP1Prover, +}; + +use super::{ProofOpts, ProverType}; + +/// An implementation of [crate::ProverClient] that can generate mock proofs. +pub struct MockProver { + pub(crate) prover: SP1Prover, +} + +impl MockProver { + /// Creates a new [MockProver]. + pub fn new() -> Self { + let prover = SP1Prover::new(); + Self { prover } + } +} + +impl Prover for MockProver { + fn id(&self) -> ProverType { + ProverType::Mock + } + + fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey) { + self.prover.setup(elf) + } + + fn sp1_prover(&self) -> &SP1Prover { + &self.prover + } + + fn prove<'a>( + &'a self, + pk: &SP1ProvingKey, + stdin: SP1Stdin, + opts: ProofOpts, + context: SP1Context<'a>, + kind: SP1ProofKind, + ) -> Result { + match kind { + SP1ProofKind::Core => { + let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; + Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Core(vec![]), + public_values, + sp1_version: self.version().to_string(), + }) + } + SP1ProofKind::Compressed => { + let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; + + let shard_proof = ShardProof { + commitment: ShardCommitment { + global_main_commit: [BabyBear::zero(); 8].into(), + local_main_commit: [BabyBear::zero(); 8].into(), + permutation_commit: [BabyBear::zero(); 8].into(), + quotient_commit: [BabyBear::zero(); 8].into(), + }, + opened_values: ShardOpenedValues { chips: vec![] }, + opening_proof: TwoAdicFriPcsProof { + fri_proof: FriProof { + commit_phase_commits: vec![], + query_proofs: vec![], + final_poly: Default::default(), + pow_witness: BabyBear::zero(), + }, + query_openings: vec![], + }, + chip_ordering: HashMap::new(), + public_values: vec![], + }; + + let reduce_vk = StarkVerifyingKey { + commit: [BabyBear::zero(); 8].into(), + pc_start: BabyBear::zero(), + chip_information: vec![], + chip_ordering: HashMap::new(), + }; + + let proof = SP1Proof::Compressed(Box::new(SP1ReduceProof { + vk: reduce_vk, + proof: shard_proof, + })); + + Ok(SP1ProofWithPublicValues { + proof, + public_values, + sp1_version: self.version().to_string(), + }) + } + SP1ProofKind::Plonk => { + let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; + Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Plonk(PlonkBn254Proof { + public_inputs: [ + pk.vk.hash_bn254().as_canonical_biguint().to_string(), + public_values.hash_bn254().to_string(), + ], + encoded_proof: "".to_string(), + raw_proof: "".to_string(), + plonk_vkey_hash: [0; 32], + }), + public_values, + sp1_version: self.version().to_string(), + }) + } + SP1ProofKind::Groth16 => { + let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; + Ok(SP1ProofWithPublicValues { + proof: SP1Proof::Groth16(Groth16Bn254Proof { + public_inputs: [ + pk.vk.hash_bn254().as_canonical_biguint().to_string(), + public_values.hash_bn254().to_string(), + ], + encoded_proof: "".to_string(), + raw_proof: "".to_string(), + groth16_vkey_hash: [0; 32], + }), + public_values, + sp1_version: self.version().to_string(), + }) + } + } + } + + fn verify( + &self, + bundle: &SP1ProofWithPublicValues, + vkey: &SP1VerifyingKey, + ) -> Result<(), SP1VerificationError> { + match &bundle.proof { + SP1Proof::Plonk(PlonkBn254Proof { public_inputs, .. }) => { + verify_plonk_bn254_public_inputs(vkey, &bundle.public_values, public_inputs) + .map_err(SP1VerificationError::Plonk) + } + SP1Proof::Groth16(Groth16Bn254Proof { public_inputs, .. }) => { + verify_groth16_bn254_public_inputs(vkey, &bundle.public_values, public_inputs) + .map_err(SP1VerificationError::Groth16) + } + _ => Ok(()), + } + } +} + +impl Default for MockProver { + fn default() -> Self { + Self::new() + } +} From 19f9113dd384230656dda8dc60fe61df61c20cdb Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 11:45:46 -0700 Subject: [PATCH 02/13] fix: default tag --- crates/build/src/lib.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index 1dbbec1347..413582643a 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -7,7 +7,7 @@ pub use build::{execute_build_program, generate_elf_paths}; use clap::Parser; const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; -const DEFAULT_TAG: &str = "latest"; +const DEFAULT_TAG: &str = "main"; const DEFAULT_OUTPUT_DIR: &str = "elf"; const HELPER_TARGET_SUBDIR: &str = "elf-compilation"; From 4bf7ea6740c95be180d014f84377fcb6e79086e0 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 12:13:44 -0700 Subject: [PATCH 03/13] feat: update book, imports --- Cargo.lock | 2 + book/verification/onchain/getting-started.md | 2 +- .../version-3.4.0/developers/common-issues.md | 2 +- .../generating-proofs/advanced.mdx | 2 +- .../prover-network/versions.md | 4 +- .../writing-programs/compiling.mdx | 2 +- .../writing-programs/cycle-tracking.mdx | 2 +- .../version-3.4.0/writing-programs/setup.md | 2 +- crates/build/src/lib.rs | 12 +- crates/core/machine/src/lib.rs | 7 - crates/prover/Cargo.toml | 1 + crates/prover/src/lib.rs | 2 +- crates/recursion/gnark-ffi/src/ffi/native.rs | 2 +- .../recursion/gnark-ffi/src/groth16_bn254.rs | 2 +- crates/recursion/gnark-ffi/src/plonk_bn254.rs | 2 +- crates/sdk/src/provers/mod.rs | 175 ++++++++++++++++++ 16 files changed, 199 insertions(+), 22 deletions(-) create mode 100644 crates/sdk/src/provers/mod.rs diff --git a/Cargo.lock b/Cargo.lock index 20a5830941..4e7b6b1f05 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5772,6 +5772,7 @@ dependencies = [ "serde", "serde_json", "serial_test", + "sp1-build", "sp1-core-executor", "sp1-core-machine", "sp1-primitives", @@ -5943,6 +5944,7 @@ dependencies = [ "serde", "serde_json", "sha2 0.10.8", + "sp1-build", "sp1-core-machine", "sp1-recursion-compiler", "sp1-stark", diff --git a/book/verification/onchain/getting-started.md b/book/verification/onchain/getting-started.md index 834a23dc18..8519d620a8 100644 --- a/book/verification/onchain/getting-started.md +++ b/book/verification/onchain/getting-started.md @@ -29,5 +29,5 @@ You can run the above script with `RUST_LOG=info cargo run --bin groth16_bn254 - If you would like to run the Groth16 or PLONK prover directly without Docker, you must have Go 1.22 installed and enable the `native-gnark` feature in `sp1-sdk`. This path is not recommended and may require additional native dependencies. ```toml -sp1-sdk = { version = "2.0.0", features = ["native-gnark"] } +sp1-sdk = { version = "3.0.0", features = ["native-gnark"] } ``` diff --git a/book/versioned_docs/version-3.4.0/developers/common-issues.md b/book/versioned_docs/version-3.4.0/developers/common-issues.md index 5d0a50e808..5b06ec3b43 100644 --- a/book/versioned_docs/version-3.4.0/developers/common-issues.md +++ b/book/versioned_docs/version-3.4.0/developers/common-issues.md @@ -51,7 +51,7 @@ This is likely due to two different versions of `alloy_sol_types` being used. To ```toml [dependencies] -sp1-sdk = { version = "2.0.0", default-features = false } +sp1-sdk = { version = "3.0.0", default-features = false } ``` This will configure out the `network` feature which will remove the dependency on `alloy_sol_types` and configure out the `NetworkProver`. diff --git a/book/versioned_docs/version-3.4.0/generating-proofs/advanced.mdx b/book/versioned_docs/version-3.4.0/generating-proofs/advanced.mdx index 192ab3cb92..da9e3548ab 100644 --- a/book/versioned_docs/version-3.4.0/generating-proofs/advanced.mdx +++ b/book/versioned_docs/version-3.4.0/generating-proofs/advanced.mdx @@ -47,7 +47,7 @@ RUSTFLAGS='-C target-cpu=native' cargo run --release Currently there is support for AVX512 and NEON SIMD instructions. For NEON, you must also enable the `sp1-sdk` feature `neon` in your script crate's `Cargo.toml` file. ```toml -sp1-sdk = { version = "2.0.0", features = ["neon"] } +sp1-sdk = { version = "3.0.0", features = ["neon"] } ``` ## Performance diff --git a/book/versioned_docs/version-3.4.0/generating-proofs/prover-network/versions.md b/book/versioned_docs/version-3.4.0/generating-proofs/prover-network/versions.md index 31503adb80..4190b713fe 100644 --- a/book/versioned_docs/version-3.4.0/generating-proofs/prover-network/versions.md +++ b/book/versioned_docs/version-3.4.0/generating-proofs/prover-network/versions.md @@ -17,14 +17,14 @@ You must switch to a supported version before submitting a proof. To do so, repl ```toml [dependencies] -sp1-zkvm = "2.0.0" +sp1-zkvm = "3.0.0" ``` replace the `sp1-sdk` version in your script's `Cargo.toml`: ```toml [dependencies] -sp1-sdk = "2.0.0" +sp1-sdk = "3.0.0" ``` Re-build your program and script, and then try again. diff --git a/book/versioned_docs/version-3.4.0/writing-programs/compiling.mdx b/book/versioned_docs/version-3.4.0/writing-programs/compiling.mdx index 0041ba8fae..54bf018114 100644 --- a/book/versioned_docs/version-3.4.0/writing-programs/compiling.mdx +++ b/book/versioned_docs/version-3.4.0/writing-programs/compiling.mdx @@ -61,7 +61,7 @@ The path passed in to `build_program` should point to the directory containing t ```toml [build-dependencies] -sp1-build = "2.0.0" +sp1-build = "3.0.0" ``` You will see output like the following from the build script if the program has changed, indicating that the program was rebuilt: diff --git a/book/versioned_docs/version-3.4.0/writing-programs/cycle-tracking.mdx b/book/versioned_docs/version-3.4.0/writing-programs/cycle-tracking.mdx index f29c303a08..0281f5fdc7 100644 --- a/book/versioned_docs/version-3.4.0/writing-programs/cycle-tracking.mdx +++ b/book/versioned_docs/version-3.4.0/writing-programs/cycle-tracking.mdx @@ -14,7 +14,7 @@ Note that to use the macro, you must add the `sp1-derive` crate to your dependen ```toml [dependencies] -sp1-derive = "2.0.0" +sp1-derive = "3.0.0" ``` In the script for proof generation, setup the logger with `utils::setup_logger()` and run the script with `RUST_LOG=info cargo run --release`. You should see the following output: diff --git a/book/versioned_docs/version-3.4.0/writing-programs/setup.md b/book/versioned_docs/version-3.4.0/writing-programs/setup.md index 2cd677f4a9..42ab5383bc 100644 --- a/book/versioned_docs/version-3.4.0/writing-programs/setup.md +++ b/book/versioned_docs/version-3.4.0/writing-programs/setup.md @@ -32,7 +32,7 @@ name = "program" edition = "2021" [dependencies] -sp1-zkvm = "2.0.0" +sp1-zkvm = "3.0.0" ``` The `sp1-zkvm` crate includes necessary utilities for your program, including handling inputs and outputs, diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index 413582643a..a5c03a7600 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -6,8 +6,14 @@ pub use build::{execute_build_program, generate_elf_paths}; use clap::Parser; +/// The global version for all components of SP1. +/// +/// This string should be updated whenever any step in verifying an SP1 proof changes, including +/// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark +/// docker image. +pub const SP1_CIRCUIT_VERSION: &str = "v3.0.0"; + const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; -const DEFAULT_TAG: &str = "main"; const DEFAULT_OUTPUT_DIR: &str = "elf"; const HELPER_TARGET_SUBDIR: &str = "elf-compilation"; @@ -27,7 +33,7 @@ pub struct BuildArgs { #[clap( long, help = "The ghcr.io/succinctlabs/sp1 image tag to use when building with Docker.", - default_value = DEFAULT_TAG + default_value = SP1_CIRCUIT_VERSION )] pub tag: String, #[clap( @@ -83,7 +89,7 @@ impl Default for BuildArgs { fn default() -> Self { Self { docker: false, - tag: DEFAULT_TAG.to_string(), + tag: SP1_CIRCUIT_VERSION.to_string(), features: vec![], rustflags: vec![], ignore_rust_version: false, diff --git a/crates/core/machine/src/lib.rs b/crates/core/machine/src/lib.rs index 168be94eac..55dfd4f8f9 100644 --- a/crates/core/machine/src/lib.rs +++ b/crates/core/machine/src/lib.rs @@ -26,13 +26,6 @@ pub mod riscv; pub mod syscall; pub mod utils; -/// The global version for all components of SP1. -/// -/// This string should be updated whenever any step in verifying an SP1 proof changes, including -/// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark -/// docker image. -pub const SP1_CIRCUIT_VERSION: &str = "v3.0.0"; - // Re-export the `SP1ReduceProof` struct from sp1_core_machine. // // This is done to avoid a circular dependency between sp1_core_machine and sp1_core_executor, and diff --git a/crates/prover/Cargo.toml b/crates/prover/Cargo.toml index 226b902c60..604276b3a2 100644 --- a/crates/prover/Cargo.toml +++ b/crates/prover/Cargo.toml @@ -17,6 +17,7 @@ sp1-recursion-circuit = { workspace = true } sp1-recursion-gnark-ffi = { workspace = true } sp1-core-machine = { workspace = true } sp1-stark = { workspace = true } +sp1-build = { workspace = true } p3-symmetric = { workspace = true } sp1-core-executor = { workspace = true } sp1-primitives = { workspace = true } diff --git a/crates/prover/src/lib.rs b/crates/prover/src/lib.rs index f1d517ebd0..fed7228efc 100644 --- a/crates/prover/src/lib.rs +++ b/crates/prover/src/lib.rs @@ -83,7 +83,7 @@ use utils::{sp1_committed_values_digest_bn254, sp1_vkey_digest_bn254, words_to_b use components::{CpuProverComponents, SP1ProverComponents}; -pub use sp1_core_machine::SP1_CIRCUIT_VERSION; +pub use sp1_build::SP1_CIRCUIT_VERSION; /// The configuration for the core prover. pub type CoreSC = BabyBearPoseidon2; diff --git a/crates/recursion/gnark-ffi/src/ffi/native.rs b/crates/recursion/gnark-ffi/src/ffi/native.rs index 46ab4eacb9..ff14100aec 100644 --- a/crates/recursion/gnark-ffi/src/ffi/native.rs +++ b/crates/recursion/gnark-ffi/src/ffi/native.rs @@ -7,7 +7,7 @@ use crate::{Groth16Bn254Proof, PlonkBn254Proof}; use cfg_if::cfg_if; -use sp1_core_machine::SP1_CIRCUIT_VERSION; +use sp1_build::SP1_CIRCUIT_VERSION; use std::{ ffi::{c_char, CStr, CString}, mem::forget, diff --git a/crates/recursion/gnark-ffi/src/groth16_bn254.rs b/crates/recursion/gnark-ffi/src/groth16_bn254.rs index f2864df5bb..ec1695f805 100644 --- a/crates/recursion/gnark-ffi/src/groth16_bn254.rs +++ b/crates/recursion/gnark-ffi/src/groth16_bn254.rs @@ -12,7 +12,7 @@ use crate::{ use num_bigint::BigUint; use sha2::{Digest, Sha256}; -use sp1_core_machine::SP1_CIRCUIT_VERSION; +use sp1_build::SP1_CIRCUIT_VERSION; use sp1_recursion_compiler::{ constraints::Constraint, ir::{Config, Witness}, diff --git a/crates/recursion/gnark-ffi/src/plonk_bn254.rs b/crates/recursion/gnark-ffi/src/plonk_bn254.rs index b901eecc05..dcce60dbd4 100644 --- a/crates/recursion/gnark-ffi/src/plonk_bn254.rs +++ b/crates/recursion/gnark-ffi/src/plonk_bn254.rs @@ -12,7 +12,7 @@ use crate::{ use num_bigint::BigUint; use sha2::{Digest, Sha256}; -use sp1_core_machine::SP1_CIRCUIT_VERSION; +use sp1_build::SP1_CIRCUIT_VERSION; use sp1_recursion_compiler::{ constraints::Constraint, ir::{Config, Witness}, diff --git a/crates/sdk/src/provers/mod.rs b/crates/sdk/src/provers/mod.rs new file mode 100644 index 0000000000..f331841943 --- /dev/null +++ b/crates/sdk/src/provers/mod.rs @@ -0,0 +1,175 @@ +mod cpu; +#[cfg(feature = "cuda")] +mod cuda; +mod mock; + +pub use cpu::CpuProver; +#[cfg(feature = "cuda")] +pub use cuda::CudaProver; +pub use mock::MockProver; + +use itertools::Itertools; +use p3_field::PrimeField32; +use std::borrow::Borrow; +use std::time::Duration; + +use anyhow::Result; +use sp1_core_executor::SP1Context; +use sp1_core_machine::io::SP1Stdin; +use sp1_prover::{ + components::SP1ProverComponents, CoreSC, InnerSC, SP1CoreProofData, SP1Prover, SP1ProvingKey, + SP1VerifyingKey, SP1_CIRCUIT_VERSION, +}; +use sp1_stark::{air::PublicValues, MachineVerificationError, SP1ProverOpts, Word}; +use strum_macros::EnumString; +use thiserror::Error; + +use crate::install::try_install_circuit_artifacts; +use crate::{SP1Proof, SP1ProofKind, SP1ProofWithPublicValues}; + +/// The type of prover. +#[derive(Debug, PartialEq, EnumString)] +pub enum ProverType { + Cpu, + Cuda, + Mock, + Network, +} + +/// Options to configure proof generation. +#[derive(Clone, Default)] +pub struct ProofOpts { + /// Options to configure the SP1 prover. + pub sp1_prover_opts: SP1ProverOpts, + /// Optional timeout duration for proof generation. + pub timeout: Option, +} + +#[derive(Error, Debug)] +pub enum SP1VerificationError { + #[error("Invalid public values")] + InvalidPublicValues, + #[error("Version mismatch")] + VersionMismatch(String), + #[error("Core machine verification error: {0}")] + Core(MachineVerificationError), + #[error("Recursion verification error: {0}")] + Recursion(MachineVerificationError), + #[error("Plonk verification error: {0}")] + Plonk(anyhow::Error), + #[error("Groth16 verification error: {0}")] + Groth16(anyhow::Error), +} + +/// An implementation of [crate::ProverClient]. +pub trait Prover: Send + Sync { + fn id(&self) -> ProverType; + + fn sp1_prover(&self) -> &SP1Prover; + + fn version(&self) -> &str { + SP1_CIRCUIT_VERSION + } + + fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey); + + /// Prove the execution of a RISCV ELF with the given inputs, according to the given proof mode. + fn prove<'a>( + &'a self, + pk: &SP1ProvingKey, + stdin: SP1Stdin, + opts: ProofOpts, + context: SP1Context<'a>, + kind: SP1ProofKind, + ) -> Result; + + /// Verify that an SP1 proof is valid given its vkey and metadata. + /// For Plonk proofs, verifies that the public inputs of the PlonkBn254 proof match + /// the hash of the VK and the committed public values of the SP1ProofWithPublicValues. + fn verify( + &self, + bundle: &SP1ProofWithPublicValues, + vkey: &SP1VerifyingKey, + ) -> Result<(), SP1VerificationError> { + if bundle.sp1_version != self.version() { + return Err(SP1VerificationError::VersionMismatch(bundle.sp1_version.clone())); + } + match &bundle.proof { + SP1Proof::Core(proof) => { + let public_values: &PublicValues, _> = + proof.last().unwrap().public_values.as_slice().borrow(); + + // Get the committed value digest bytes. + let committed_value_digest_bytes = public_values + .committed_value_digest + .iter() + .flat_map(|w| w.0.iter().map(|x| x.as_canonical_u32() as u8)) + .collect_vec(); + + // Make sure the committed value digest matches the public values hash. + for (a, b) in + committed_value_digest_bytes.iter().zip_eq(bundle.public_values.hash()) + { + if *a != b { + return Err(SP1VerificationError::InvalidPublicValues); + } + } + + // Verify the core proof. + self.sp1_prover() + .verify(&SP1CoreProofData(proof.clone()), vkey) + .map_err(SP1VerificationError::Core) + } + SP1Proof::Compressed(proof) => { + let public_values: &PublicValues, _> = + proof.proof.public_values.as_slice().borrow(); + + // Get the committed value digest bytes. + let committed_value_digest_bytes = public_values + .committed_value_digest + .iter() + .flat_map(|w| w.0.iter().map(|x| x.as_canonical_u32() as u8)) + .collect_vec(); + + // Make sure the committed value digest matches the public values hash. + for (a, b) in + committed_value_digest_bytes.iter().zip_eq(bundle.public_values.hash()) + { + if *a != b { + return Err(SP1VerificationError::InvalidPublicValues); + } + } + + self.sp1_prover() + .verify_compressed(proof, vkey) + .map_err(SP1VerificationError::Recursion) + } + SP1Proof::Plonk(proof) => self + .sp1_prover() + .verify_plonk_bn254( + proof, + vkey, + &bundle.public_values, + &if sp1_prover::build::sp1_dev_mode() { + sp1_prover::build::plonk_bn254_artifacts_dev_dir() + } else { + try_install_circuit_artifacts("plonk") + }, + ) + .map_err(SP1VerificationError::Plonk), + SP1Proof::Groth16(proof) => self + .sp1_prover() + .verify_groth16_bn254( + proof, + vkey, + &bundle.public_values, + &if sp1_prover::build::sp1_dev_mode() { + sp1_prover::build::groth16_bn254_artifacts_dev_dir() + } else { + try_install_circuit_artifacts("groth16") + }, + ) + .map_err(SP1VerificationError::Groth16), + } + } +} From a51335f0ba0a66a250c97c7ce597a79d9b093503 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 12:21:28 -0700 Subject: [PATCH 04/13] fix --- crates/recursion/gnark-ffi/src/ffi/docker.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/recursion/gnark-ffi/src/ffi/docker.rs b/crates/recursion/gnark-ffi/src/ffi/docker.rs index bf0f2865bd..af9b66b474 100644 --- a/crates/recursion/gnark-ffi/src/ffi/docker.rs +++ b/crates/recursion/gnark-ffi/src/ffi/docker.rs @@ -1,7 +1,7 @@ use crate::ProofBn254; use crate::{Groth16Bn254Proof, PlonkBn254Proof}; use anyhow::{anyhow, Result}; -use sp1_core_machine::SP1_CIRCUIT_VERSION; +use sp1_build::SP1_CIRCUIT_VERSION; use std::{io::Write, process::Command}; /// Represents the proof system being used From b81c5efd2e02963163f8795e82f642d0f38472d3 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 13:19:26 -0700 Subject: [PATCH 05/13] use SP1_CIRCUIT_VERSION --- Cargo.lock | 2 -- crates/SP1_CIRCUIT_VERSION | 1 + crates/build/src/lib.rs | 2 +- crates/prover/Cargo.toml | 1 - crates/prover/src/lib.rs | 2 +- crates/recursion/gnark-ffi/src/ffi/docker.rs | 3 ++- crates/recursion/gnark-ffi/src/ffi/native.rs | 3 ++- crates/recursion/gnark-ffi/src/groth16_bn254.rs | 3 +-- crates/recursion/gnark-ffi/src/lib.rs | 2 ++ crates/recursion/gnark-ffi/src/plonk_bn254.rs | 3 +-- 10 files changed, 11 insertions(+), 11 deletions(-) create mode 100644 crates/SP1_CIRCUIT_VERSION diff --git a/Cargo.lock b/Cargo.lock index 4e7b6b1f05..20a5830941 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5772,7 +5772,6 @@ dependencies = [ "serde", "serde_json", "serial_test", - "sp1-build", "sp1-core-executor", "sp1-core-machine", "sp1-primitives", @@ -5944,7 +5943,6 @@ dependencies = [ "serde", "serde_json", "sha2 0.10.8", - "sp1-build", "sp1-core-machine", "sp1-recursion-compiler", "sp1-stark", diff --git a/crates/SP1_CIRCUIT_VERSION b/crates/SP1_CIRCUIT_VERSION new file mode 100644 index 0000000000..1c5ae58202 --- /dev/null +++ b/crates/SP1_CIRCUIT_VERSION @@ -0,0 +1 @@ +v3.0.0 \ No newline at end of file diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index a5c03a7600..1cb5950f16 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -11,7 +11,7 @@ use clap::Parser; /// This string should be updated whenever any step in verifying an SP1 proof changes, including /// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark /// docker image. -pub const SP1_CIRCUIT_VERSION: &str = "v3.0.0"; +pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; const DEFAULT_OUTPUT_DIR: &str = "elf"; diff --git a/crates/prover/Cargo.toml b/crates/prover/Cargo.toml index 604276b3a2..226b902c60 100644 --- a/crates/prover/Cargo.toml +++ b/crates/prover/Cargo.toml @@ -17,7 +17,6 @@ sp1-recursion-circuit = { workspace = true } sp1-recursion-gnark-ffi = { workspace = true } sp1-core-machine = { workspace = true } sp1-stark = { workspace = true } -sp1-build = { workspace = true } p3-symmetric = { workspace = true } sp1-core-executor = { workspace = true } sp1-primitives = { workspace = true } diff --git a/crates/prover/src/lib.rs b/crates/prover/src/lib.rs index fed7228efc..2deb5ada41 100644 --- a/crates/prover/src/lib.rs +++ b/crates/prover/src/lib.rs @@ -83,7 +83,7 @@ use utils::{sp1_committed_values_digest_bn254, sp1_vkey_digest_bn254, words_to_b use components::{CpuProverComponents, SP1ProverComponents}; -pub use sp1_build::SP1_CIRCUIT_VERSION; +pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); /// The configuration for the core prover. pub type CoreSC = BabyBearPoseidon2; diff --git a/crates/recursion/gnark-ffi/src/ffi/docker.rs b/crates/recursion/gnark-ffi/src/ffi/docker.rs index af9b66b474..f8d5fecea0 100644 --- a/crates/recursion/gnark-ffi/src/ffi/docker.rs +++ b/crates/recursion/gnark-ffi/src/ffi/docker.rs @@ -1,9 +1,10 @@ use crate::ProofBn254; use crate::{Groth16Bn254Proof, PlonkBn254Proof}; use anyhow::{anyhow, Result}; -use sp1_build::SP1_CIRCUIT_VERSION; use std::{io::Write, process::Command}; +const SP1_CIRCUIT_VERSION: &str = include_str!("../../../../SP1_CIRCUIT_VERSION"); + /// Represents the proof system being used enum ProofSystem { Plonk, diff --git a/crates/recursion/gnark-ffi/src/ffi/native.rs b/crates/recursion/gnark-ffi/src/ffi/native.rs index ff14100aec..fa46de6c81 100644 --- a/crates/recursion/gnark-ffi/src/ffi/native.rs +++ b/crates/recursion/gnark-ffi/src/ffi/native.rs @@ -7,12 +7,13 @@ use crate::{Groth16Bn254Proof, PlonkBn254Proof}; use cfg_if::cfg_if; -use sp1_build::SP1_CIRCUIT_VERSION; use std::{ ffi::{c_char, CStr, CString}, mem::forget, }; +const SP1_CIRCUIT_VERSION: &str = include_str!("../../../../SP1_CIRCUIT_VERSION"); + #[allow(warnings, clippy::all)] mod bind { include!(concat!(env!("OUT_DIR"), "/bindings.rs")); diff --git a/crates/recursion/gnark-ffi/src/groth16_bn254.rs b/crates/recursion/gnark-ffi/src/groth16_bn254.rs index ec1695f805..c3e7ffb9ca 100644 --- a/crates/recursion/gnark-ffi/src/groth16_bn254.rs +++ b/crates/recursion/gnark-ffi/src/groth16_bn254.rs @@ -7,12 +7,11 @@ use std::{ use crate::{ ffi::{build_groth16_bn254, prove_groth16_bn254, test_groth16_bn254, verify_groth16_bn254}, witness::GnarkWitness, - Groth16Bn254Proof, + Groth16Bn254Proof, SP1_CIRCUIT_VERSION, }; use num_bigint::BigUint; use sha2::{Digest, Sha256}; -use sp1_build::SP1_CIRCUIT_VERSION; use sp1_recursion_compiler::{ constraints::Constraint, ir::{Config, Witness}, diff --git a/crates/recursion/gnark-ffi/src/lib.rs b/crates/recursion/gnark-ffi/src/lib.rs index 436739ba83..4709ad15a5 100644 --- a/crates/recursion/gnark-ffi/src/lib.rs +++ b/crates/recursion/gnark-ffi/src/lib.rs @@ -10,3 +10,5 @@ pub use groth16_bn254::*; pub use plonk_bn254::*; pub use proof::*; pub use witness::*; + +const SP1_CIRCUIT_VERSION: &str = include_str!("../../../SP1_CIRCUIT_VERSION"); \ No newline at end of file diff --git a/crates/recursion/gnark-ffi/src/plonk_bn254.rs b/crates/recursion/gnark-ffi/src/plonk_bn254.rs index dcce60dbd4..00bd3485aa 100644 --- a/crates/recursion/gnark-ffi/src/plonk_bn254.rs +++ b/crates/recursion/gnark-ffi/src/plonk_bn254.rs @@ -7,12 +7,11 @@ use std::{ use crate::{ ffi::{build_plonk_bn254, prove_plonk_bn254, test_plonk_bn254, verify_plonk_bn254}, witness::GnarkWitness, - PlonkBn254Proof, + PlonkBn254Proof, SP1_CIRCUIT_VERSION, }; use num_bigint::BigUint; use sha2::{Digest, Sha256}; -use sp1_build::SP1_CIRCUIT_VERSION; use sp1_recursion_compiler::{ constraints::Constraint, ir::{Config, Witness}, From 8b3b98737c51f3daf268463817f5b60c25762bb0 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 13:22:02 -0700 Subject: [PATCH 06/13] docs --- crates/prover/src/lib.rs | 5 +++++ crates/recursion/gnark-ffi/src/ffi/docker.rs | 4 +--- crates/recursion/gnark-ffi/src/ffi/native.rs | 4 +--- crates/recursion/gnark-ffi/src/lib.rs | 7 ++++++- 4 files changed, 13 insertions(+), 7 deletions(-) diff --git a/crates/prover/src/lib.rs b/crates/prover/src/lib.rs index 2deb5ada41..adf78daa35 100644 --- a/crates/prover/src/lib.rs +++ b/crates/prover/src/lib.rs @@ -83,6 +83,11 @@ use utils::{sp1_committed_values_digest_bn254, sp1_vkey_digest_bn254, words_to_b use components::{CpuProverComponents, SP1ProverComponents}; +/// The global version for all components of SP1. +/// +/// This string should be updated whenever any step in verifying an SP1 proof changes, including +/// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark +/// docker image. pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); /// The configuration for the core prover. diff --git a/crates/recursion/gnark-ffi/src/ffi/docker.rs b/crates/recursion/gnark-ffi/src/ffi/docker.rs index f8d5fecea0..402205da43 100644 --- a/crates/recursion/gnark-ffi/src/ffi/docker.rs +++ b/crates/recursion/gnark-ffi/src/ffi/docker.rs @@ -1,10 +1,8 @@ use crate::ProofBn254; -use crate::{Groth16Bn254Proof, PlonkBn254Proof}; +use crate::{Groth16Bn254Proof, PlonkBn254Proof, SP1_CIRCUIT_VERSION}; use anyhow::{anyhow, Result}; use std::{io::Write, process::Command}; -const SP1_CIRCUIT_VERSION: &str = include_str!("../../../../SP1_CIRCUIT_VERSION"); - /// Represents the proof system being used enum ProofSystem { Plonk, diff --git a/crates/recursion/gnark-ffi/src/ffi/native.rs b/crates/recursion/gnark-ffi/src/ffi/native.rs index fa46de6c81..f21b42aa5c 100644 --- a/crates/recursion/gnark-ffi/src/ffi/native.rs +++ b/crates/recursion/gnark-ffi/src/ffi/native.rs @@ -5,15 +5,13 @@ //! Although we cast to *mut c_char because the Go signatures can't be immutable, the Go functions //! should not modify the strings. -use crate::{Groth16Bn254Proof, PlonkBn254Proof}; +use crate::{Groth16Bn254Proof, PlonkBn254Proof, SP1_CIRCUIT_VERSION}; use cfg_if::cfg_if; use std::{ ffi::{c_char, CStr, CString}, mem::forget, }; -const SP1_CIRCUIT_VERSION: &str = include_str!("../../../../SP1_CIRCUIT_VERSION"); - #[allow(warnings, clippy::all)] mod bind { include!(concat!(env!("OUT_DIR"), "/bindings.rs")); diff --git a/crates/recursion/gnark-ffi/src/lib.rs b/crates/recursion/gnark-ffi/src/lib.rs index 4709ad15a5..287596ed91 100644 --- a/crates/recursion/gnark-ffi/src/lib.rs +++ b/crates/recursion/gnark-ffi/src/lib.rs @@ -11,4 +11,9 @@ pub use plonk_bn254::*; pub use proof::*; pub use witness::*; -const SP1_CIRCUIT_VERSION: &str = include_str!("../../../SP1_CIRCUIT_VERSION"); \ No newline at end of file +/// The global version for all components of SP1. +/// +/// This string should be updated whenever any step in verifying an SP1 proof changes, including +/// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark +/// docker image. +const SP1_CIRCUIT_VERSION: &str = include_str!("../../../SP1_CIRCUIT_VERSION"); From 71fa3f299a2a9d658013a1760ff1544e7381d0de Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 13:27:25 -0700 Subject: [PATCH 07/13] fix --- crates/build/src/lib.rs | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index 1cb5950f16..aaeb7d6e90 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -6,12 +6,7 @@ pub use build::{execute_build_program, generate_elf_paths}; use clap::Parser; -/// The global version for all components of SP1. -/// -/// This string should be updated whenever any step in verifying an SP1 proof changes, including -/// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark -/// docker image. -pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); +const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; const DEFAULT_OUTPUT_DIR: &str = "elf"; From cf32515a683e3414c5cb5faabfea1e0ccf6f5d54 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Thu, 24 Oct 2024 13:28:10 -0700 Subject: [PATCH 08/13] fix --- crates/build/src/lib.rs | 1 - 1 file changed, 1 deletion(-) diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index aaeb7d6e90..c5e3eeee80 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -7,7 +7,6 @@ pub use build::{execute_build_program, generate_elf_paths}; use clap::Parser; const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); - const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; const DEFAULT_OUTPUT_DIR: &str = "elf"; const HELPER_TARGET_SUBDIR: &str = "elf-compilation"; From 6e7ebf3ccf182cf140285e8b6073284b8233d5d6 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Wed, 30 Oct 2024 12:04:11 -0700 Subject: [PATCH 09/13] feat: change loc, fix later --- crates/SP1_CIRCUIT_VERSION => SP1_VERSION | 0 crates/build/src/lib.rs | 2 +- crates/prover/src/lib.rs | 2 +- crates/recursion/gnark-ffi/src/lib.rs | 2 +- 4 files changed, 3 insertions(+), 3 deletions(-) rename crates/SP1_CIRCUIT_VERSION => SP1_VERSION (100%) diff --git a/crates/SP1_CIRCUIT_VERSION b/ SP1_VERSION similarity index 100% rename from crates/SP1_CIRCUIT_VERSION rename to SP1_VERSION diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index c5e3eeee80..3814cfdc05 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -6,7 +6,7 @@ pub use build::{execute_build_program, generate_elf_paths}; use clap::Parser; -const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); +const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_VERSION"); const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; const DEFAULT_OUTPUT_DIR: &str = "elf"; const HELPER_TARGET_SUBDIR: &str = "elf-compilation"; diff --git a/crates/prover/src/lib.rs b/crates/prover/src/lib.rs index adf78daa35..c8460a62f4 100644 --- a/crates/prover/src/lib.rs +++ b/crates/prover/src/lib.rs @@ -88,7 +88,7 @@ use components::{CpuProverComponents, SP1ProverComponents}; /// This string should be updated whenever any step in verifying an SP1 proof changes, including /// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark /// docker image. -pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_CIRCUIT_VERSION"); +pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_VERSION"); /// The configuration for the core prover. pub type CoreSC = BabyBearPoseidon2; diff --git a/crates/recursion/gnark-ffi/src/lib.rs b/crates/recursion/gnark-ffi/src/lib.rs index 287596ed91..df02e731df 100644 --- a/crates/recursion/gnark-ffi/src/lib.rs +++ b/crates/recursion/gnark-ffi/src/lib.rs @@ -16,4 +16,4 @@ pub use witness::*; /// This string should be updated whenever any step in verifying an SP1 proof changes, including /// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark /// docker image. -const SP1_CIRCUIT_VERSION: &str = include_str!("../../../SP1_CIRCUIT_VERSION"); +const SP1_CIRCUIT_VERSION: &str = include_str!("../../../../SP1_VERSION"); From c8b58bf3bcaf9c5a1eaaafb505f7b1e31310b196 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Wed, 30 Oct 2024 12:08:57 -0700 Subject: [PATCH 10/13] add --- SP1_VERSION => SP1_VERSION | 0 crates/build/src/lib.rs | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) rename SP1_VERSION => SP1_VERSION (100%) diff --git a/ SP1_VERSION b/SP1_VERSION similarity index 100% rename from SP1_VERSION rename to SP1_VERSION diff --git a/crates/build/src/lib.rs b/crates/build/src/lib.rs index 3814cfdc05..8fa1c9842c 100644 --- a/crates/build/src/lib.rs +++ b/crates/build/src/lib.rs @@ -6,7 +6,7 @@ pub use build::{execute_build_program, generate_elf_paths}; use clap::Parser; -const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_VERSION"); +const SP1_CIRCUIT_VERSION: &str = include_str!("../../../SP1_VERSION"); const BUILD_TARGET: &str = "riscv32im-succinct-zkvm-elf"; const DEFAULT_OUTPUT_DIR: &str = "elf"; const HELPER_TARGET_SUBDIR: &str = "elf-compilation"; From a9e2cf5df5d46b78697c19902a1a1f140c3c4bda Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Fri, 20 Dec 2024 18:09:33 -0800 Subject: [PATCH 11/13] add --- crates/sdk/src/provers/cpu.rs | 127 ------------------------ crates/sdk/src/provers/cuda.rs | 121 ----------------------- crates/sdk/src/provers/mock.rs | 166 ------------------------------- crates/sdk/src/provers/mod.rs | 175 --------------------------------- 4 files changed, 589 deletions(-) delete mode 100644 crates/sdk/src/provers/cpu.rs delete mode 100644 crates/sdk/src/provers/cuda.rs delete mode 100644 crates/sdk/src/provers/mock.rs delete mode 100644 crates/sdk/src/provers/mod.rs diff --git a/crates/sdk/src/provers/cpu.rs b/crates/sdk/src/provers/cpu.rs deleted file mode 100644 index 467cca0c07..0000000000 --- a/crates/sdk/src/provers/cpu.rs +++ /dev/null @@ -1,127 +0,0 @@ -use anyhow::Result; -use sp1_core_executor::SP1Context; -use sp1_core_machine::io::SP1Stdin; -use sp1_prover::{components::DefaultProverComponents, SP1Prover}; - -use crate::install::try_install_circuit_artifacts; -use crate::{ - provers::ProofOpts, Prover, SP1Proof, SP1ProofKind, SP1ProofWithPublicValues, SP1ProvingKey, - SP1VerifyingKey, -}; - -use super::ProverType; - -/// An implementation of [crate::ProverClient] that can generate end-to-end proofs locally. -pub struct CpuProver { - prover: SP1Prover, -} - -impl CpuProver { - /// Creates a new [LocalProver]. - pub fn new() -> Self { - let prover = SP1Prover::new(); - Self { prover } - } - - /// Creates a new [LocalProver] from an existing [SP1Prover]. - pub fn from_prover(prover: SP1Prover) -> Self { - Self { prover } - } -} - -impl Prover for CpuProver { - fn id(&self) -> ProverType { - ProverType::Cpu - } - - fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey) { - self.prover.setup(elf) - } - - fn sp1_prover(&self) -> &SP1Prover { - &self.prover - } - - fn prove<'a>( - &'a self, - pk: &SP1ProvingKey, - stdin: SP1Stdin, - opts: ProofOpts, - context: SP1Context<'a>, - kind: SP1ProofKind, - ) -> Result { - // Generate the core proof. - let proof: sp1_prover::SP1ProofWithMetadata = - self.prover.prove_core(pk, &stdin, opts.sp1_prover_opts, context)?; - if kind == SP1ProofKind::Core { - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Core(proof.proof.0), - public_values: proof.public_values, - sp1_version: self.version().to_string(), - }); - } - - let deferred_proofs = - stdin.proofs.iter().map(|(reduce_proof, _)| reduce_proof.clone()).collect(); - let public_values = proof.public_values.clone(); - - // Generate the compressed proof. - let reduce_proof = - self.prover.compress(&pk.vk, proof, deferred_proofs, opts.sp1_prover_opts)?; - if kind == SP1ProofKind::Compressed { - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Compressed(Box::new(reduce_proof)), - public_values, - sp1_version: self.version().to_string(), - }); - } - - // Generate the shrink proof. - let compress_proof = self.prover.shrink(reduce_proof, opts.sp1_prover_opts)?; - - // Genenerate the wrap proof. - let outer_proof = self.prover.wrap_bn254(compress_proof, opts.sp1_prover_opts)?; - - if kind == SP1ProofKind::Plonk { - let plonk_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { - sp1_prover::build::try_build_plonk_bn254_artifacts_dev( - &outer_proof.vk, - &outer_proof.proof, - ) - } else { - try_install_circuit_artifacts("plonk") - }; - let proof = self.prover.wrap_plonk_bn254(outer_proof, &plonk_bn254_artifacts); - - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Plonk(proof), - public_values, - sp1_version: self.version().to_string(), - }); - } else if kind == SP1ProofKind::Groth16 { - let groth16_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { - sp1_prover::build::try_build_groth16_bn254_artifacts_dev( - &outer_proof.vk, - &outer_proof.proof, - ) - } else { - try_install_circuit_artifacts("groth16") - }; - - let proof = self.prover.wrap_groth16_bn254(outer_proof, &groth16_bn254_artifacts); - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Groth16(proof), - public_values, - sp1_version: self.version().to_string(), - }); - } - - unreachable!() - } -} - -impl Default for CpuProver { - fn default() -> Self { - Self::new() - } -} diff --git a/crates/sdk/src/provers/cuda.rs b/crates/sdk/src/provers/cuda.rs deleted file mode 100644 index 2cb28b070f..0000000000 --- a/crates/sdk/src/provers/cuda.rs +++ /dev/null @@ -1,121 +0,0 @@ -use anyhow::Result; -use sp1_core_machine::io::SP1Stdin; -use sp1_cuda::SP1CudaProver; -use sp1_prover::{components::DefaultProverComponents, SP1Prover}; - -use super::ProverType; -use crate::install::try_install_circuit_artifacts; -use crate::{ - provers::ProofOpts, Prover, SP1Context, SP1Proof, SP1ProofKind, SP1ProofWithPublicValues, - SP1ProvingKey, SP1VerifyingKey, -}; - -/// An implementation of [crate::ProverClient] that can generate proofs locally using CUDA. -pub struct CudaProver { - prover: SP1Prover, - cuda_prover: SP1CudaProver, -} - -impl CudaProver { - /// Creates a new [CudaProver]. - pub fn new(prover: SP1Prover) -> Self { - let cuda_prover = SP1CudaProver::new(); - Self { prover, cuda_prover: cuda_prover.expect("Failed to initialize CUDA prover") } - } -} - -impl Prover for CudaProver { - fn id(&self) -> ProverType { - ProverType::Cuda - } - - fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey) { - self.prover.setup(elf) - } - - fn sp1_prover(&self) -> &SP1Prover { - &self.prover - } - - fn prove<'a>( - &'a self, - pk: &SP1ProvingKey, - stdin: SP1Stdin, - _opts: ProofOpts, - _context: SP1Context<'a>, - kind: SP1ProofKind, - ) -> Result { - tracing::warn!("opts and context are ignored for the cuda prover"); - - // Generate the core proof. - let proof = self.cuda_prover.prove_core(pk, &stdin)?; - if kind == SP1ProofKind::Core { - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Core(proof.proof.0), - public_values: proof.public_values, - sp1_version: self.version().to_string(), - }); - } - - let deferred_proofs = - stdin.proofs.iter().map(|(reduce_proof, _)| reduce_proof.clone()).collect(); - let public_values = proof.public_values.clone(); - - // Generate the compressed proof. - let reduce_proof = self.cuda_prover.compress(&pk.vk, proof, deferred_proofs)?; - if kind == SP1ProofKind::Compressed { - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Compressed(Box::new(reduce_proof)), - public_values, - sp1_version: self.version().to_string(), - }); - } - - // Generate the shrink proof. - let compress_proof = self.cuda_prover.shrink(reduce_proof)?; - - // Genenerate the wrap proof. - let outer_proof = self.cuda_prover.wrap_bn254(compress_proof)?; - - if kind == SP1ProofKind::Plonk { - let plonk_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { - sp1_prover::build::try_build_plonk_bn254_artifacts_dev( - &outer_proof.vk, - &outer_proof.proof, - ) - } else { - try_install_circuit_artifacts("plonk") - }; - let proof = self.prover.wrap_plonk_bn254(outer_proof, &plonk_bn254_artifacts); - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Plonk(proof), - public_values, - sp1_version: self.version().to_string(), - }); - } else if kind == SP1ProofKind::Groth16 { - let groth16_bn254_artifacts = if sp1_prover::build::sp1_dev_mode() { - sp1_prover::build::try_build_groth16_bn254_artifacts_dev( - &outer_proof.vk, - &outer_proof.proof, - ) - } else { - try_install_circuit_artifacts("groth16") - }; - - let proof = self.prover.wrap_groth16_bn254(outer_proof, &groth16_bn254_artifacts); - return Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Groth16(proof), - public_values, - sp1_version: self.version().to_string(), - }); - } - - unreachable!() - } -} - -impl Default for CudaProver { - fn default() -> Self { - Self::new(SP1Prover::new()) - } -} diff --git a/crates/sdk/src/provers/mock.rs b/crates/sdk/src/provers/mock.rs deleted file mode 100644 index dc1df94681..0000000000 --- a/crates/sdk/src/provers/mock.rs +++ /dev/null @@ -1,166 +0,0 @@ -#![allow(unused_variables)] -use hashbrown::HashMap; -use sp1_core_executor::{SP1Context, SP1ReduceProof}; -use sp1_core_machine::io::SP1Stdin; -use sp1_stark::{ShardCommitment, ShardOpenedValues, ShardProof, StarkVerifyingKey}; - -use crate::{ - Prover, SP1Proof, SP1ProofKind, SP1ProofWithPublicValues, SP1ProvingKey, SP1VerificationError, - SP1VerifyingKey, -}; -use anyhow::Result; -use p3_baby_bear::BabyBear; -use p3_field::{AbstractField, PrimeField}; -use p3_fri::{FriProof, TwoAdicFriPcsProof}; -use sp1_prover::{ - components::DefaultProverComponents, - verify::{verify_groth16_bn254_public_inputs, verify_plonk_bn254_public_inputs}, - Groth16Bn254Proof, HashableKey, PlonkBn254Proof, SP1Prover, -}; - -use super::{ProofOpts, ProverType}; - -/// An implementation of [crate::ProverClient] that can generate mock proofs. -pub struct MockProver { - pub(crate) prover: SP1Prover, -} - -impl MockProver { - /// Creates a new [MockProver]. - pub fn new() -> Self { - let prover = SP1Prover::new(); - Self { prover } - } -} - -impl Prover for MockProver { - fn id(&self) -> ProverType { - ProverType::Mock - } - - fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey) { - self.prover.setup(elf) - } - - fn sp1_prover(&self) -> &SP1Prover { - &self.prover - } - - fn prove<'a>( - &'a self, - pk: &SP1ProvingKey, - stdin: SP1Stdin, - opts: ProofOpts, - context: SP1Context<'a>, - kind: SP1ProofKind, - ) -> Result { - match kind { - SP1ProofKind::Core => { - let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; - Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Core(vec![]), - public_values, - sp1_version: self.version().to_string(), - }) - } - SP1ProofKind::Compressed => { - let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; - - let shard_proof = ShardProof { - commitment: ShardCommitment { - global_main_commit: [BabyBear::zero(); 8].into(), - local_main_commit: [BabyBear::zero(); 8].into(), - permutation_commit: [BabyBear::zero(); 8].into(), - quotient_commit: [BabyBear::zero(); 8].into(), - }, - opened_values: ShardOpenedValues { chips: vec![] }, - opening_proof: TwoAdicFriPcsProof { - fri_proof: FriProof { - commit_phase_commits: vec![], - query_proofs: vec![], - final_poly: Default::default(), - pow_witness: BabyBear::zero(), - }, - query_openings: vec![], - }, - chip_ordering: HashMap::new(), - public_values: vec![], - }; - - let reduce_vk = StarkVerifyingKey { - commit: [BabyBear::zero(); 8].into(), - pc_start: BabyBear::zero(), - chip_information: vec![], - chip_ordering: HashMap::new(), - }; - - let proof = SP1Proof::Compressed(Box::new(SP1ReduceProof { - vk: reduce_vk, - proof: shard_proof, - })); - - Ok(SP1ProofWithPublicValues { - proof, - public_values, - sp1_version: self.version().to_string(), - }) - } - SP1ProofKind::Plonk => { - let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; - Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Plonk(PlonkBn254Proof { - public_inputs: [ - pk.vk.hash_bn254().as_canonical_biguint().to_string(), - public_values.hash_bn254().to_string(), - ], - encoded_proof: "".to_string(), - raw_proof: "".to_string(), - plonk_vkey_hash: [0; 32], - }), - public_values, - sp1_version: self.version().to_string(), - }) - } - SP1ProofKind::Groth16 => { - let (public_values, _) = self.prover.execute(&pk.elf, &stdin, context)?; - Ok(SP1ProofWithPublicValues { - proof: SP1Proof::Groth16(Groth16Bn254Proof { - public_inputs: [ - pk.vk.hash_bn254().as_canonical_biguint().to_string(), - public_values.hash_bn254().to_string(), - ], - encoded_proof: "".to_string(), - raw_proof: "".to_string(), - groth16_vkey_hash: [0; 32], - }), - public_values, - sp1_version: self.version().to_string(), - }) - } - } - } - - fn verify( - &self, - bundle: &SP1ProofWithPublicValues, - vkey: &SP1VerifyingKey, - ) -> Result<(), SP1VerificationError> { - match &bundle.proof { - SP1Proof::Plonk(PlonkBn254Proof { public_inputs, .. }) => { - verify_plonk_bn254_public_inputs(vkey, &bundle.public_values, public_inputs) - .map_err(SP1VerificationError::Plonk) - } - SP1Proof::Groth16(Groth16Bn254Proof { public_inputs, .. }) => { - verify_groth16_bn254_public_inputs(vkey, &bundle.public_values, public_inputs) - .map_err(SP1VerificationError::Groth16) - } - _ => Ok(()), - } - } -} - -impl Default for MockProver { - fn default() -> Self { - Self::new() - } -} diff --git a/crates/sdk/src/provers/mod.rs b/crates/sdk/src/provers/mod.rs deleted file mode 100644 index f331841943..0000000000 --- a/crates/sdk/src/provers/mod.rs +++ /dev/null @@ -1,175 +0,0 @@ -mod cpu; -#[cfg(feature = "cuda")] -mod cuda; -mod mock; - -pub use cpu::CpuProver; -#[cfg(feature = "cuda")] -pub use cuda::CudaProver; -pub use mock::MockProver; - -use itertools::Itertools; -use p3_field::PrimeField32; -use std::borrow::Borrow; -use std::time::Duration; - -use anyhow::Result; -use sp1_core_executor::SP1Context; -use sp1_core_machine::io::SP1Stdin; -use sp1_prover::{ - components::SP1ProverComponents, CoreSC, InnerSC, SP1CoreProofData, SP1Prover, SP1ProvingKey, - SP1VerifyingKey, SP1_CIRCUIT_VERSION, -}; -use sp1_stark::{air::PublicValues, MachineVerificationError, SP1ProverOpts, Word}; -use strum_macros::EnumString; -use thiserror::Error; - -use crate::install::try_install_circuit_artifacts; -use crate::{SP1Proof, SP1ProofKind, SP1ProofWithPublicValues}; - -/// The type of prover. -#[derive(Debug, PartialEq, EnumString)] -pub enum ProverType { - Cpu, - Cuda, - Mock, - Network, -} - -/// Options to configure proof generation. -#[derive(Clone, Default)] -pub struct ProofOpts { - /// Options to configure the SP1 prover. - pub sp1_prover_opts: SP1ProverOpts, - /// Optional timeout duration for proof generation. - pub timeout: Option, -} - -#[derive(Error, Debug)] -pub enum SP1VerificationError { - #[error("Invalid public values")] - InvalidPublicValues, - #[error("Version mismatch")] - VersionMismatch(String), - #[error("Core machine verification error: {0}")] - Core(MachineVerificationError), - #[error("Recursion verification error: {0}")] - Recursion(MachineVerificationError), - #[error("Plonk verification error: {0}")] - Plonk(anyhow::Error), - #[error("Groth16 verification error: {0}")] - Groth16(anyhow::Error), -} - -/// An implementation of [crate::ProverClient]. -pub trait Prover: Send + Sync { - fn id(&self) -> ProverType; - - fn sp1_prover(&self) -> &SP1Prover; - - fn version(&self) -> &str { - SP1_CIRCUIT_VERSION - } - - fn setup(&self, elf: &[u8]) -> (SP1ProvingKey, SP1VerifyingKey); - - /// Prove the execution of a RISCV ELF with the given inputs, according to the given proof mode. - fn prove<'a>( - &'a self, - pk: &SP1ProvingKey, - stdin: SP1Stdin, - opts: ProofOpts, - context: SP1Context<'a>, - kind: SP1ProofKind, - ) -> Result; - - /// Verify that an SP1 proof is valid given its vkey and metadata. - /// For Plonk proofs, verifies that the public inputs of the PlonkBn254 proof match - /// the hash of the VK and the committed public values of the SP1ProofWithPublicValues. - fn verify( - &self, - bundle: &SP1ProofWithPublicValues, - vkey: &SP1VerifyingKey, - ) -> Result<(), SP1VerificationError> { - if bundle.sp1_version != self.version() { - return Err(SP1VerificationError::VersionMismatch(bundle.sp1_version.clone())); - } - match &bundle.proof { - SP1Proof::Core(proof) => { - let public_values: &PublicValues, _> = - proof.last().unwrap().public_values.as_slice().borrow(); - - // Get the committed value digest bytes. - let committed_value_digest_bytes = public_values - .committed_value_digest - .iter() - .flat_map(|w| w.0.iter().map(|x| x.as_canonical_u32() as u8)) - .collect_vec(); - - // Make sure the committed value digest matches the public values hash. - for (a, b) in - committed_value_digest_bytes.iter().zip_eq(bundle.public_values.hash()) - { - if *a != b { - return Err(SP1VerificationError::InvalidPublicValues); - } - } - - // Verify the core proof. - self.sp1_prover() - .verify(&SP1CoreProofData(proof.clone()), vkey) - .map_err(SP1VerificationError::Core) - } - SP1Proof::Compressed(proof) => { - let public_values: &PublicValues, _> = - proof.proof.public_values.as_slice().borrow(); - - // Get the committed value digest bytes. - let committed_value_digest_bytes = public_values - .committed_value_digest - .iter() - .flat_map(|w| w.0.iter().map(|x| x.as_canonical_u32() as u8)) - .collect_vec(); - - // Make sure the committed value digest matches the public values hash. - for (a, b) in - committed_value_digest_bytes.iter().zip_eq(bundle.public_values.hash()) - { - if *a != b { - return Err(SP1VerificationError::InvalidPublicValues); - } - } - - self.sp1_prover() - .verify_compressed(proof, vkey) - .map_err(SP1VerificationError::Recursion) - } - SP1Proof::Plonk(proof) => self - .sp1_prover() - .verify_plonk_bn254( - proof, - vkey, - &bundle.public_values, - &if sp1_prover::build::sp1_dev_mode() { - sp1_prover::build::plonk_bn254_artifacts_dev_dir() - } else { - try_install_circuit_artifacts("plonk") - }, - ) - .map_err(SP1VerificationError::Plonk), - SP1Proof::Groth16(proof) => self - .sp1_prover() - .verify_groth16_bn254( - proof, - vkey, - &bundle.public_values, - &if sp1_prover::build::sp1_dev_mode() { - sp1_prover::build::groth16_bn254_artifacts_dev_dir() - } else { - try_install_circuit_artifacts("groth16") - }, - ) - .map_err(SP1VerificationError::Groth16), - } - } -} From 43f5976c2ec299e100c84551b33625ce9678413f Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Fri, 20 Dec 2024 18:12:52 -0800 Subject: [PATCH 12/13] add --- Cargo.lock | 839 +++++++++++++++++++++++++---------------------------- 1 file changed, 390 insertions(+), 449 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 20a5830941..8bcfa75065 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -105,9 +105,9 @@ dependencies = [ [[package]] name = "allocator-api2" -version = "0.2.20" +version = "0.2.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "45862d1c77f2228b9e10bc609d5bc203d86ebc9b87ad8d5d5167a6c9abf739d9" +checksum = "683d7910e743518b0e34f1186f92494becacb047c7b6bf616c96772180fef923" [[package]] name = "alloy-consensus" @@ -252,14 +252,14 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6259a506ab13e1d658796c31e6e39d2e2ee89243bcc505ddc613b35732e0a430" dependencies = [ "alloy-rlp", - "bytes 1.8.0", + "bytes 1.9.0", "cfg-if", "const-hex", "derive_more", "foldhash", - "hashbrown 0.15.1", + "hashbrown 0.15.2", "hex-literal", - "indexmap 2.6.0", + "indexmap 2.7.0", "itoa", "k256", "keccak-asm", @@ -267,7 +267,7 @@ dependencies = [ "proptest", "rand 0.8.5", "ruint", - "rustc-hash 2.0.0", + "rustc-hash 2.1.0", "serde", "sha3", "tiny-keccak", @@ -275,24 +275,24 @@ dependencies = [ [[package]] name = "alloy-rlp" -version = "0.3.9" +version = "0.3.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "da0822426598f95e45dd1ea32a738dac057529a709ee645fcc516ffa4cbde08f" +checksum = "f542548a609dca89fcd72b3b9f355928cf844d4363c5eed9c5273a3dd225e097" dependencies = [ "alloy-rlp-derive", "arrayvec", - "bytes 1.8.0", + "bytes 1.9.0", ] [[package]] name = "alloy-rlp-derive" -version = "0.3.9" +version = "0.3.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2b09cae092c27b6f1bde952653a22708691802e57bfef4a2973b80bea21efd3f" +checksum = "5a833d97bf8a5f0f878daf2c8451fff7de7f9de38baa5a45d936ec718d81255a" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -378,7 +378,7 @@ dependencies = [ "proc-macro-error2", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -390,11 +390,11 @@ dependencies = [ "alloy-sol-macro-input", "const-hex", "heck", - "indexmap 2.6.0", + "indexmap 2.7.0", "proc-macro-error2", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "syn-solidity", "tiny-keccak", ] @@ -410,7 +410,7 @@ dependencies = [ "heck", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "syn-solidity", ] @@ -534,9 +534,9 @@ dependencies = [ [[package]] name = "anyhow" -version = "1.0.93" +version = "1.0.94" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c95c10ba0b00a02636238b814946408b1322d5ac4760326e6fb8ec956d85775" +checksum = "c1fd03a028ef38ba2276dce7e33fcd6369c158a1bca17946c4b1b701891c1ff7" dependencies = [ "backtrace", ] @@ -721,7 +721,7 @@ checksum = "30ca9a001c1e8ba5149f91a74362376cc6bc5b919d92d988668657bd570bdcec" dependencies = [ "async-task", "concurrent-queue", - "fastrand 2.2.0", + "fastrand 2.3.0", "futures-lite 2.5.0", "slab", ] @@ -817,7 +817,7 @@ checksum = "c7c24de15d275a1ecfd47a380fb4d5ec9bfe0933f309ed5e705b775596a3574d" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -847,7 +847,7 @@ checksum = "721cae7de5c34fbb2acd27e21e6d2cf7b886dce0c27388d46c4e6c47ea4318dd" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -877,7 +877,7 @@ checksum = "3c87f3f15e7794432337fc718554eaa4dc8f04c9677a950ffe366f20a162ae42" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -888,15 +888,15 @@ checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26" [[package]] name = "axum" -version = "0.7.7" +version = "0.7.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "504e3947307ac8326a5437504c517c4b56716c9d98fac0028c2acc7ca47d70ae" +checksum = "edca88bc138befd0323b20752846e6587272d3b03b0343c8ea28a6f819e6e71f" dependencies = [ "async-trait", "axum-core", - "bytes 1.8.0", + "bytes 1.9.0", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body", "http-body-util", "hyper", @@ -912,9 +912,9 @@ dependencies = [ "serde_json", "serde_path_to_error", "serde_urlencoded", - "sync_wrapper 1.0.1", + "sync_wrapper", "tokio", - "tower 0.5.1", + "tower 0.5.2", "tower-layer", "tower-service", "tracing", @@ -927,15 +927,15 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "09f2bd6146b97ae3359fa0cc6d6b376d9539582c7b4220f041a33ec24c226199" dependencies = [ "async-trait", - "bytes 1.8.0", + "bytes 1.9.0", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body", "http-body-util", "mime", "pin-project-lite", "rustversion", - "sync_wrapper 1.0.1", + "sync_wrapper", "tower-layer", "tower-service", "tracing", @@ -1033,7 +1033,7 @@ dependencies = [ "regex", "rustc-hash 1.1.0", "shlex", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -1159,22 +1159,22 @@ checksum = "c3ac9f8b63eca6fd385229b3675f6cc0dc5c8a5c8a54a59d4f52ffd670d87b0c" [[package]] name = "bytemuck" -version = "1.19.0" +version = "1.21.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8334215b81e418a0a7bdb8ef0849474f40bb10c8b71f1c4ed315cff49f32494d" +checksum = "ef657dfab802224e671f5818e9a4935f9b1957ed18e58292690cc39e7a4092a3" dependencies = [ "bytemuck_derive", ] [[package]] name = "bytemuck_derive" -version = "1.8.0" +version = "1.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bcfcc3cd946cb52f0bbfdbbcfa2f4e24f75ebb6c0e1002f7c25904fada18b9ec" +checksum = "3fa76293b4f7bb636ab88fd78228235b5248b4d05cc589aed610f954af5d7c7a" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -1191,9 +1191,9 @@ checksum = "0e4cec68f03f32e44924783795810fa50a7035d8c8ebe78580ad7e6c703fba38" [[package]] name = "bytes" -version = "1.8.0" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9ac0150caa2ae65ca5bd83f25c7de183dea78d4d366469f148435e2acfbad0da" +checksum = "325918d6fe32f23b19878fe4b34794ae41fc19ddbe53b10571a4874d44ffd39b" dependencies = [ "serde", ] @@ -1224,9 +1224,9 @@ dependencies = [ [[package]] name = "cargo-platform" -version = "0.1.8" +version = "0.1.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "24b1f0365a6c6bb4020cd05806fd0d33c44d38046b8bd7f0e40814b9763cabfc" +checksum = "e35af189006b9c0f00a064685c727031e3ed2d8020f7ba284d78cc2671bd36ea" dependencies = [ "serde", ] @@ -1239,7 +1239,7 @@ checksum = "2d886547e41f740c616ae73108f6eb70afe6d940c7bc697cb30f13daec073037" dependencies = [ "camino", "cargo-platform", - "semver 1.0.23", + "semver 1.0.24", "serde", "serde_json", "thiserror 1.0.69", @@ -1253,9 +1253,9 @@ checksum = "37b2a672a2cb129a2e41c10b1224bb368f9f37a2b16b612598138befd7b37eb5" [[package]] name = "cc" -version = "1.2.0" +version = "1.2.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1aeb932158bd710538c73702db6945cb68a8fb08c519e6e12706b94263b36db8" +checksum = "c31a0499c1dc64f458ad13872de75c0eb7e3fdb0e67964610c914b034fc5956e" dependencies = [ "jobserver", "libc", @@ -1285,9 +1285,9 @@ checksum = "613afe47fcd5fac7ccf1db93babcb082c5994d996f20b8b159f2ad1658eb5724" [[package]] name = "chrono" -version = "0.4.38" +version = "0.4.39" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a21f936df1771bf62b77f047b726c4625ff2e8aa607c01ec06e5a05bd8463401" +checksum = "7e36cc9d416881d2e24f9a963be5fb1cd90966419ac844274161d10488b3e825" dependencies = [ "android-tzdata", "iana-time-zone", @@ -1344,9 +1344,9 @@ dependencies = [ [[package]] name = "clap" -version = "4.5.20" +version = "4.5.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b97f376d85a664d5837dbae44bf546e6477a679ff6610010f17276f686d867e8" +checksum = "3135e7ec2ef7b10c6ed8950f0f792ed96ee093fa088608f1c76e569722700c84" dependencies = [ "clap_builder", "clap_derive", @@ -1354,9 +1354,9 @@ dependencies = [ [[package]] name = "clap_builder" -version = "4.5.20" +version = "4.5.23" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "19bc80abd44e4bed93ca373a0704ccbd1b710dc5749406201bb018272808dc54" +checksum = "30582fc632330df2bd26877bde0c1f4470d57c582bbc070376afcd04d8cb4838" dependencies = [ "anstream", "anstyle", @@ -1373,14 +1373,14 @@ dependencies = [ "heck", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "clap_lex" -version = "0.7.2" +version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1462739cb27611015575c0c11df5df7601141071f07518d56fcc1be504cbec97" +checksum = "f46ad14479a25103f283c0f10005961cf086d8dc42205bb44c46ac563475dca6" [[package]] name = "colorchoice" @@ -1399,15 +1399,15 @@ dependencies = [ [[package]] name = "console" -version = "0.15.8" +version = "0.15.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0e1f83fc076bd6dd27517eacdf25fef6c4dfe5f1d7448bafaaf3a26f13b5e4eb" +checksum = "ea3c6ecd8059b57859df5c69830340ed3c41d30e3da0c1cbed90a96ac853041b" dependencies = [ - "encode_unicode 0.3.6", - "lazy_static", + "encode_unicode", "libc", - "unicode-width 0.1.14", - "windows-sys 0.52.0", + "once_cell", + "unicode-width 0.2.0", + "windows-sys 0.59.0", ] [[package]] @@ -1468,6 +1468,16 @@ dependencies = [ "libc", ] +[[package]] +name = "core-foundation" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b55271e5c8c478ad3f38ad24ef34923091e0548492a266d19b3c0b4d82574c63" +dependencies = [ + "core-foundation-sys", + "libc", +] + [[package]] name = "core-foundation-sys" version = "0.8.7" @@ -1476,9 +1486,9 @@ checksum = "773648b94d0e5d620f64f280777445740e61fe701025087ec8b57f45c791888b" [[package]] name = "cpufeatures" -version = "0.2.15" +version = "0.2.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0ca741a962e1b0bff6d724a1a0958b686406e853bb14061f218562e1896f95e6" +checksum = "16b80225097f2e5ae4e7179dd2266824648f3e2f49d9134d584b76389d31c4c3" dependencies = [ "libc", ] @@ -1527,18 +1537,18 @@ dependencies = [ [[package]] name = "crossbeam-channel" -version = "0.5.13" +version = "0.5.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "33480d6946193aa8033910124896ca395333cae7e2d1113d1fef6c3272217df2" +checksum = "06ba6d68e24814cb8de6bb986db8222d3a027d15872cabc0d18817bc3c0e4471" dependencies = [ "crossbeam-utils", ] [[package]] name = "crossbeam-deque" -version = "0.8.5" +version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "613f8cc01fe9cf1a3eb3d7f488fd2fa8388403e97039e2f73692932e291a770d" +checksum = "9dd111b7b7f7d55b72c0a6ae361660ee5853c9af73f70c3c2ef6858b950e2e51" dependencies = [ "crossbeam-epoch", "crossbeam-utils", @@ -1555,9 +1565,9 @@ dependencies = [ [[package]] name = "crossbeam-utils" -version = "0.8.20" +version = "0.8.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "22ec99545bb0ed0ea7bb9b8e1e9122ea386ff8a48c0922e43f36d45ab09e0e80" +checksum = "d0a5c400df2834b80a4c3327b3aad3a4c4cd4de0629063962b03235697506a28" [[package]] name = "crunchy" @@ -1838,7 +1848,7 @@ checksum = "cb7330aeadfbe296029522e6c40f315320aba36fc43a5b3632f3795348f3bd22" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "unicode-xid", ] @@ -1919,7 +1929,7 @@ checksum = "97369cbbc041bc366949bc74d34658d6cda5621039731c6310521892a3a20ae0" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -1980,12 +1990,6 @@ dependencies = [ "zeroize", ] -[[package]] -name = "encode_unicode" -version = "0.3.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a357d28ed41a50f9c765dbfe56cbc04a64e53e5fc58ba79fbc34c10ef3df831f" - [[package]] name = "encode_unicode" version = "1.0.0" @@ -2019,7 +2023,7 @@ checksum = "f282cfdfe92516eb26c2af8589c274c7c17681f5ecc03c18255fe741c6aa64eb" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -2030,12 +2034,12 @@ checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" [[package]] name = "errno" -version = "0.3.9" +version = "0.3.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "534c5cf6194dfab3db3242765c03bbe257cf92f22b38f6bc0c58d59108a820ba" +checksum = "33d852cb9b869c2a9b3df2f71a3074817f01e1844f839a144f5fcef059a4eb5d" dependencies = [ "libc", - "windows-sys 0.52.0", + "windows-sys 0.59.0", ] [[package]] @@ -2057,9 +2061,9 @@ dependencies = [ [[package]] name = "event-listener-strategy" -version = "0.5.2" +version = "0.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0f214dc438f977e6d4e3500aaa277f5ad94ca83fbbd9b1a15713ce2344ccc5a1" +checksum = "3c3e4e0dd3673c1139bf041f3008816d9cf2946bbfac2945c09e523b8d7b05b2" dependencies = [ "event-listener 5.3.1", "pin-project-lite", @@ -2086,9 +2090,9 @@ dependencies = [ [[package]] name = "fastrand" -version = "2.2.0" +version = "2.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "486f806e73c5707928240ddc295403b1b93c96a02038563881c4a2fd84b81ac4" +checksum = "37909eebbb50d72f9059c3b6d82c0463f2ff062c9e95845c43a6c9c0355411be" [[package]] name = "fastrlp" @@ -2098,7 +2102,18 @@ checksum = "139834ddba373bbdd213dffe02c8d110508dcf1726c2be27e8d1f7d7e1856418" dependencies = [ "arrayvec", "auto_impl", - "bytes 1.8.0", + "bytes 1.9.0", +] + +[[package]] +name = "fastrlp" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ce8dba4714ef14b8274c371879b175aa55b16b30f269663f19d576f380018dc4" +dependencies = [ + "arrayvec", + "auto_impl", + "bytes 1.9.0", ] [[package]] @@ -2178,9 +2193,9 @@ checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" [[package]] name = "foldhash" -version = "0.1.3" +version = "0.1.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f81ec6369c545a7d40e4589b5597581fa1c441fe1cce96dd1de43159910a36a2" +checksum = "a0d2fde1f7b3d48b8395d5f2de76c18a528bd6a9cdde438df747bfcba3e05d6f" [[package]] name = "foreign-types" @@ -2281,7 +2296,7 @@ version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cef40d21ae2c515b51041df9ed313ed21e572df340ea58a922a0aefe7e8891a1" dependencies = [ - "fastrand 2.2.0", + "fastrand 2.3.0", "futures-core", "futures-io", "parking", @@ -2296,7 +2311,7 @@ checksum = "162ee34ebcb7c64a8abebc059ce0fee27c2262618d7b60ed8faf72fef13c3650" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -2365,9 +2380,9 @@ dependencies = [ [[package]] name = "generic-array" -version = "1.1.0" +version = "1.1.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "96512db27971c2c3eece70a1e106fbe6c87760234e31e8f7e5634912fe52794a" +checksum = "2cb8bc4c28d15ade99c7e90b219f30da4be5c88e586277e8cbe886beeb868ab2" dependencies = [ "serde", "typenum", @@ -2391,8 +2406,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7" dependencies = [ "cfg-if", + "js-sys", "libc", "wasi 0.11.0+wasi-snapshot-preview1", + "wasm-bindgen", ] [[package]] @@ -2499,17 +2516,17 @@ dependencies = [ [[package]] name = "h2" -version = "0.4.6" +version = "0.4.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "524e8ac6999421f49a846c2d4411f337e53497d8ec55d67753beffa43c5d9205" +checksum = "ccae279728d634d083c00f6099cb58f01cc99c145b84b8be2f6c74618d79922e" dependencies = [ "atomic-waker", - "bytes 1.8.0", + "bytes 1.9.0", "fnv", "futures-core", "futures-sink", - "http 1.1.0", - "indexmap 2.6.0", + "http 1.2.0", + "indexmap 2.7.0", "slab", "tokio", "tokio-util", @@ -2568,9 +2585,9 @@ dependencies = [ [[package]] name = "hashbrown" -version = "0.15.1" +version = "0.15.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3a9bfc1af68b1726ea47d3d5109de126281def866b33970e10fbab11b5dafab3" +checksum = "bf151400ff0baff5465007dd2f3e717f3fe502074ca563069ce3a6629d07b289" dependencies = [ "allocator-api2", "equivalent", @@ -2646,18 +2663,18 @@ version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "fnv", "itoa", ] [[package]] name = "http" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258" +checksum = "f16ca2af56261c99fba8bac40a10251ce8188205a4c448fbb745a2e4daa76fea" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "fnv", "itoa", ] @@ -2668,8 +2685,8 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184" dependencies = [ - "bytes 1.8.0", - "http 1.1.0", + "bytes 1.9.0", + "http 1.2.0", ] [[package]] @@ -2678,9 +2695,9 @@ version = "0.1.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "793429d76616a256bcb62c2a2ec2bed781c8307e797e2598c50010f2bee2544f" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body", "pin-project-lite", ] @@ -2735,15 +2752,15 @@ checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9" [[package]] name = "hyper" -version = "1.5.0" +version = "1.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bbbff0a806a4728c99295b254c8838933b5b082d75e3cb70c8dab21fdfbcfa9a" +checksum = "256fb8d4bd6413123cc9d91832d78325c48ff41677595be797d90f42969beae0" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "futures-channel", "futures-util", "h2", - "http 1.1.0", + "http 1.2.0", "http-body", "httparse", "httpdate", @@ -2756,20 +2773,20 @@ dependencies = [ [[package]] name = "hyper-rustls" -version = "0.27.3" +version = "0.27.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "08afdbb5c31130e3034af566421053ab03787c640246a446327f550d11bcb333" +checksum = "2d191583f3da1305256f22463b9bb0471acad48a4e534a5218b9963e9c1f59b2" dependencies = [ "futures-util", - "http 1.1.0", + "http 1.2.0", "hyper", "hyper-util", - "rustls 0.23.16", + "rustls 0.23.20", "rustls-pki-types", "tokio", "tokio-rustls", "tower-service", - "webpki-roots 0.26.6", + "webpki-roots 0.26.7", ] [[package]] @@ -2791,7 +2808,7 @@ version = "0.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "70206fc6890eaca9fde8a0bf71caa2ddfc9fe045ac9e5c70df101a7dbde866e0" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "http-body-util", "hyper", "hyper-util", @@ -2807,10 +2824,10 @@ version = "0.1.10" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "df2dcfbe0677734ab2f3ffa7fa7bfd4706bfdc1ef393f2ee30184aed67e631b4" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "futures-channel", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body", "hyper", "pin-project-lite", @@ -2958,7 +2975,7 @@ checksum = "1ec89e9337638ecdc08744df490b221a7399bf8d164eb52a665454e60e075ad6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -2999,13 +3016,13 @@ dependencies = [ [[package]] name = "impl-trait-for-tuples" -version = "0.2.2" +version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "11d7a9f6330b71fea57921c9b61c47ee6e84f72d394754eff6163ae67e7395eb" +checksum = "a0eb5a3343abf848c0984fe4604b2b105da9539376e24fc0a3b0007411ae4fd9" dependencies = [ "proc-macro2", "quote", - "syn 1.0.109", + "syn 2.0.90", ] [[package]] @@ -3026,12 +3043,12 @@ dependencies = [ [[package]] name = "indexmap" -version = "2.6.0" +version = "2.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "707907fe3c25f5424cce2cb7e1cbcafee6bdbe735ca90ef77c29e84591e5b9da" +checksum = "62f822373a4fe84d4bb149bf54e584a7f4abec90e072ed49cda0edea5b95471f" dependencies = [ "equivalent", - "hashbrown 0.15.1", + "hashbrown 0.15.2", "serde", ] @@ -3138,9 +3155,9 @@ dependencies = [ [[package]] name = "itoa" -version = "1.0.11" +version = "1.0.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "49f1f14873335454500d59611f1cf4a4b0f786f9ac11f4312a78e4cf2566695b" +checksum = "d75a2a4b1b190afb6f5425f10f6a8f959d2ea0b9c2b1d79553551850539e4674" [[package]] name = "jobserver" @@ -3153,10 +3170,11 @@ dependencies = [ [[package]] name = "js-sys" -version = "0.3.72" +version = "0.3.76" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6a88f1bda2bd75b0452a14784937d796722fdebfe50df998aeb3f0b7603019a9" +checksum = "6717b6b5b077764fb5966237269cb3c64edddde4b14ce42647430a78ced9e7b7" dependencies = [ + "once_cell", "wasm-bindgen", ] @@ -3227,9 +3245,9 @@ dependencies = [ [[package]] name = "libc" -version = "0.2.162" +version = "0.2.169" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "18d287de67fe55fd7e1581fe933d965a5a9477b38e949cfa9f8574ef01506398" +checksum = "b5aba8db14291edd000dfcc4d620c7ebfb122c613afb886ca8803fa4e128a20a" [[package]] name = "libgit2-sys" @@ -3245,9 +3263,9 @@ dependencies = [ [[package]] name = "libloading" -version = "0.8.5" +version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4979f22fdb869068da03c9f7528f8297c6fd2606bc3a4affe42e6a823fdb8da4" +checksum = "fc2f4eb4bc735547cfed7c0a4922cbd04a4655978c09b54f1f7b228750664c34" dependencies = [ "cfg-if", "windows-targets 0.52.6", @@ -3299,9 +3317,9 @@ checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89" [[package]] name = "litemap" -version = "0.7.3" +version = "0.7.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "643cb0b8d4fcc284004d5fd0d67ccf61dfffadb7f75e1e71bc420f4688a3a704" +checksum = "4ee93343901ab17bd981295f2cf0026d4ad018c7c31ba84549a4ddbb47a45104" [[package]] name = "lock_api" @@ -3328,7 +3346,7 @@ version = "0.12.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "234cf4f4a04dc1f57e24b96cc0cd600cf2af460d4161ac5ecdd0af8e1f3b2a38" dependencies = [ - "hashbrown 0.15.1", + "hashbrown 0.15.2", ] [[package]] @@ -3354,9 +3372,9 @@ checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3" [[package]] name = "memuse" -version = "0.2.1" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2145869435ace5ea6ea3d35f59be559317ec9a0d04e1812d5f185a87b6d36f1a" +checksum = "3d97bbf43eb4f088f8ca469930cde17fa036207c9a5e02ccc5107c4e8b17c964" [[package]] name = "mime" @@ -3382,20 +3400,19 @@ checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" [[package]] name = "miniz_oxide" -version = "0.8.0" +version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e2d80299ef12ff69b16a84bb182e3b9df68b5a91574d3d4fa6e41b65deec4df1" +checksum = "4ffbe83022cedc1d264172192511ae958937694cd57ce297164951b8b3568394" dependencies = [ "adler2", ] [[package]] name = "mio" -version = "1.0.2" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "80e04d1dcff3aae0704555fe5fee3bcfaf3d1fdf8a7e521d5b9d2b42acb52cec" +checksum = "2886843bf800fba2e3377cff24abf6379b4c4d5c6681eaf9ea5b0d15090450bd" dependencies = [ - "hermit-abi 0.3.9", "libc", "wasi 0.11.0+wasi-snapshot-preview1", "windows-sys 0.52.0", @@ -3419,7 +3436,7 @@ dependencies = [ "openssl-probe", "openssl-sys", "schannel", - "security-framework", + "security-framework 2.11.1", "security-framework-sys", "tempfile", ] @@ -3686,7 +3703,7 @@ checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -3734,7 +3751,7 @@ dependencies = [ [[package]] name = "p3-air" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "p3-field", "p3-matrix", @@ -3743,7 +3760,7 @@ dependencies = [ [[package]] name = "p3-baby-bear" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "num-bigint 0.4.6", "p3-field", @@ -3757,7 +3774,7 @@ dependencies = [ [[package]] name = "p3-bn254-fr" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "ff 0.13.0", "num-bigint 0.4.6", @@ -3771,7 +3788,7 @@ dependencies = [ [[package]] name = "p3-challenger" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "p3-field", "p3-maybe-rayon", @@ -3784,7 +3801,7 @@ dependencies = [ [[package]] name = "p3-commit" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-challenger", @@ -3797,7 +3814,7 @@ dependencies = [ [[package]] name = "p3-dft" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "p3-field", "p3-matrix", @@ -3809,7 +3826,7 @@ dependencies = [ [[package]] name = "p3-field" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "num-bigint 0.4.6", @@ -3822,7 +3839,7 @@ dependencies = [ [[package]] name = "p3-fri" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-challenger", @@ -3840,7 +3857,7 @@ dependencies = [ [[package]] name = "p3-interpolation" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "p3-field", "p3-matrix", @@ -3850,7 +3867,7 @@ dependencies = [ [[package]] name = "p3-keccak-air" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "p3-air", "p3-field", @@ -3863,7 +3880,7 @@ dependencies = [ [[package]] name = "p3-matrix" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-field", @@ -3877,7 +3894,7 @@ dependencies = [ [[package]] name = "p3-maybe-rayon" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "rayon", ] @@ -3885,7 +3902,7 @@ dependencies = [ [[package]] name = "p3-mds" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-dft", @@ -3899,7 +3916,7 @@ dependencies = [ [[package]] name = "p3-merkle-tree" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-commit", @@ -3915,7 +3932,7 @@ dependencies = [ [[package]] name = "p3-poseidon2" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "gcd", "p3-field", @@ -3928,7 +3945,7 @@ dependencies = [ [[package]] name = "p3-symmetric" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-field", @@ -3938,7 +3955,7 @@ dependencies = [ [[package]] name = "p3-uni-stark" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "itertools 0.12.1", "p3-air", @@ -3956,7 +3973,7 @@ dependencies = [ [[package]] name = "p3-util" version = "0.1.0" -source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#d33eaa69b1ef96ad678ebd96ae8e75aef3508b2a" +source = "git+https://github.com/Plonky3/Plonky3?branch=sp1-v4#bba88386261c3eaceb7f922b99bea56c1d6c6c58" dependencies = [ "serde", ] @@ -4078,12 +4095,12 @@ checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" [[package]] name = "pest" -version = "2.7.14" +version = "2.7.15" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "879952a81a83930934cbf1786752d6dedc3b1f29e8f8fb2ad1d0a36f377cf442" +checksum = "8b7cafe60d6cf8e62e1b9b2ea516a089c008945bb5a275416789e7db0bc199dc" dependencies = [ "memchr", - "thiserror 1.0.69", + "thiserror 2.0.8", "ucd-trie", ] @@ -4094,7 +4111,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b4c5cc86750666a3ed20bdaf5ca2a0344f9c67674cae0515bec2da16fbaa47db" dependencies = [ "fixedbitset", - "indexmap 2.6.0", + "indexmap 2.7.0", ] [[package]] @@ -4114,7 +4131,7 @@ checksum = "3c0f5fad0874fc7abcd4d750e76917eaebbecaa2c20bde22e1dbeeba8beb758c" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -4136,7 +4153,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "96c8c490f422ef9a4efd2cb5b42b76c8613d7e7dfc1caf667b8a3350a5acc066" dependencies = [ "atomic-waker", - "fastrand 2.2.0", + "fastrand 2.3.0", "futures-io", ] @@ -4218,9 +4235,9 @@ dependencies = [ [[package]] name = "portable-atomic" -version = "1.9.0" +version = "1.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cc9c68a3f6da06753e9335d63e27f6b9754dd1920d941135b7ea8224f141adb2" +checksum = "280dc24453071f1b63954171985a0b0d30058d287960968b9b2aca264c8d4ee6" [[package]] name = "powerfmt" @@ -4244,7 +4261,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "64d1ec885c64d0457d564db4ec299b2dae3f9c02808b8ad9c3a089c591b18033" dependencies = [ "proc-macro2", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -4254,7 +4271,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "eea25e07510aa6ab6547308ebe3c036016d162b8da920dbb079e3ba8acf3d95a" dependencies = [ "csv", - "encode_unicode 1.0.0", + "encode_unicode", "is-terminal", "lazy_static", "term", @@ -4319,7 +4336,7 @@ dependencies = [ "proc-macro-error-attr2", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -4330,9 +4347,9 @@ checksum = "dc375e1527247fe1a97d8b7156678dfe7c1af2fc075c9a4db3690ecd2a148068" [[package]] name = "proc-macro2" -version = "1.0.89" +version = "1.0.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f139b0662de085916d1fb67d2b4169d1addddda1919e696f3252b740b629986e" +checksum = "37d3544b3f2748c54e147655edb5025752e2303145b5aefb3c3ea2c78b973bb0" dependencies = [ "unicode-ident", ] @@ -4359,21 +4376,20 @@ dependencies = [ [[package]] name = "prost" -version = "0.13.3" +version = "0.13.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b0487d90e047de87f984913713b85c601c05609aad5b0df4b4573fbf69aa13f" +checksum = "2c0fef6c4230e4ccf618a35c59d7ede15dea37de8427500f50aff708806e42ec" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "prost-derive", ] [[package]] name = "prost-build" -version = "0.13.3" +version = "0.13.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c1318b19085f08681016926435853bbf7858f9c082d0999b80550ff5d9abe15" +checksum = "d0f3e5beed80eb580c68e2c600937ac2c4eedabdfd5ef1e5b7ea4f3fba84497b" dependencies = [ - "bytes 1.8.0", "heck", "itertools 0.13.0", "log", @@ -4384,28 +4400,28 @@ dependencies = [ "prost", "prost-types", "regex", - "syn 2.0.87", + "syn 2.0.90", "tempfile", ] [[package]] name = "prost-derive" -version = "0.13.3" +version = "0.13.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e9552f850d5f0964a4e4d0bf306459ac29323ddfbae05e35a7c0d35cb0803cc5" +checksum = "157c5a9d7ea5c2ed2d9fb8f495b64759f7816c7eaea54ba3978f0d63000162e3" dependencies = [ "anyhow", "itertools 0.13.0", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "prost-types" -version = "0.13.3" +version = "0.13.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4759aa0d3a6232fb8dbdb97b61de2c20047c68aca932c7ed76da9d788508d670" +checksum = "cc2f1e56baa61e93533aebc21af4d2134b70f66275e0fcdf3cbe43d77ff7e8fc" dependencies = [ "prost", ] @@ -4418,44 +4434,47 @@ checksum = "a1d01941d82fa2ab50be1e79e6714289dd7cde78eba4c074bc5a4374f650dfe0" [[package]] name = "quinn" -version = "0.11.5" +version = "0.11.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8c7c5fdde3cdae7203427dc4f0a68fe0ed09833edc525a03456b153b79828684" +checksum = "62e96808277ec6f97351a2380e6c25114bc9e67037775464979f3037c92d05ef" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "pin-project-lite", "quinn-proto", "quinn-udp", - "rustc-hash 2.0.0", - "rustls 0.23.16", + "rustc-hash 2.1.0", + "rustls 0.23.20", "socket2", - "thiserror 1.0.69", + "thiserror 2.0.8", "tokio", "tracing", ] [[package]] name = "quinn-proto" -version = "0.11.8" +version = "0.11.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fadfaed2cd7f389d0161bb73eeb07b7b78f8691047a6f3e73caaeae55310a4a6" +checksum = "a2fe5ef3495d7d2e377ff17b1a8ce2ee2ec2a18cde8b6ad6619d65d0701c135d" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", + "getrandom 0.2.15", "rand 0.8.5", "ring 0.17.8", - "rustc-hash 2.0.0", - "rustls 0.23.16", + "rustc-hash 2.1.0", + "rustls 0.23.20", + "rustls-pki-types", "slab", - "thiserror 1.0.69", + "thiserror 2.0.8", "tinyvec", "tracing", + "web-time", ] [[package]] name = "quinn-udp" -version = "0.5.7" +version = "0.5.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7d5a626c6807713b15cac82a6acaccd6043c9a5408c24baae07611fec3f243da" +checksum = "1c40286217b4ba3a71d644d752e6a0b71f13f1b6a2c5311acfcbe0c2418ed904" dependencies = [ "cfg_aliases", "libc", @@ -4592,9 +4611,9 @@ dependencies = [ [[package]] name = "redox_syscall" -version = "0.5.7" +version = "0.5.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b6dfecf2c74bce2466cabf93f6664d6998a69eb21e39f4207930065b27b771f" +checksum = "03a862b389f93e68874fbf580b9de08dd02facb9a788ebadaf4a3fd33cf58834" dependencies = [ "bitflags", ] @@ -4661,12 +4680,12 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a77c62af46e79de0a562e1a9849205ffcb7fc1238876e9bd743357570e04046f" dependencies = [ "base64 0.22.1", - "bytes 1.8.0", + "bytes 1.9.0", "encoding_rs", "futures-core", "futures-util", "h2", - "http 1.1.0", + "http 1.2.0", "http-body", "http-body-util", "hyper", @@ -4682,13 +4701,13 @@ dependencies = [ "percent-encoding", "pin-project-lite", "quinn", - "rustls 0.23.16", + "rustls 0.23.20", "rustls-pemfile", "rustls-pki-types", "serde", "serde_json", "serde_urlencoded", - "sync_wrapper 1.0.1", + "sync_wrapper", "system-configuration", "tokio", "tokio-native-tls", @@ -4700,7 +4719,7 @@ dependencies = [ "wasm-bindgen-futures", "wasm-streams", "web-sys", - "webpki-roots 0.26.6", + "webpki-roots 0.26.7", "windows-registry", ] @@ -4712,7 +4731,7 @@ checksum = "562ceb5a604d3f7c885a792d42c199fd8af239d0a51b2fa6a78aafa092452b04" dependencies = [ "anyhow", "async-trait", - "http 1.1.0", + "http 1.2.0", "reqwest", "serde", "thiserror 1.0.69", @@ -4765,7 +4784,7 @@ version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bb919243f34364b6bd2fc10ef797edbfa75f33c252e7998527479c6d6b47e1ec" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "rustc-hex", ] @@ -4794,16 +4813,18 @@ dependencies = [ [[package]] name = "ruint" -version = "1.12.3" +version = "1.12.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2c3cc4c2511671f327125da14133d0c5c5d137f006a1017a16f557bc85b16286" +checksum = "f5ef8fb1dd8de3870cb8400d51b4c2023854bbafd5431a3ac7e7317243e22d2f" dependencies = [ "alloy-rlp", "ark-ff 0.3.0", "ark-ff 0.4.2", - "bytes 1.8.0", - "fastrlp", + "bytes 1.9.0", + "fastrlp 0.3.1", + "fastrlp 0.4.0", "num-bigint 0.4.6", + "num-integer", "num-traits", "parity-scale-codec", "primitive-types", @@ -4836,9 +4857,9 @@ checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2" [[package]] name = "rustc-hash" -version = "2.0.0" +version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "583034fd73374156e66797ed8e5b0d5690409c9226b22d87cb7f19821c05d152" +checksum = "c7fb8039b3032c191086b10f11f319a6e99e1e82889c5cc6046f515c9db1d497" [[package]] name = "rustc-hex" @@ -4870,20 +4891,20 @@ version = "0.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "cfcb3a22ef46e85b45de6ee7e79d063319ebb6594faafcf1c225ea92ab6e9b92" dependencies = [ - "semver 1.0.23", + "semver 1.0.24", ] [[package]] name = "rustix" -version = "0.38.40" +version = "0.38.42" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "99e4ea3e1cdc4b559b8e5650f9c8e5998e3e5c1343b4eaf034565f32318d63c0" +checksum = "f93dc38ecbab2eb790ff964bb77fa94faf256fd3e73285fd7ba0903b76bedb85" dependencies = [ "bitflags", "errno", "libc", "linux-raw-sys", - "windows-sys 0.52.0", + "windows-sys 0.59.0", ] [[package]] @@ -4901,9 +4922,9 @@ dependencies = [ [[package]] name = "rustls" -version = "0.23.16" +version = "0.23.20" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eee87ff5d9b36712a58574e12e9f0ea80f915a5b0ac518d322b24a465617925e" +checksum = "5065c3f250cbd332cd894be57c40fa52387247659b14a2d6041d121547903b1b" dependencies = [ "log", "once_cell", @@ -4916,15 +4937,14 @@ dependencies = [ [[package]] name = "rustls-native-certs" -version = "0.8.0" +version = "0.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fcaf18a4f2be7326cd874a5fa579fae794320a0f388d365dca7e480e55f83f8a" +checksum = "7fcff2dd52b58a8d98a70243663a0d234c4e2b79235637849d15913394a247d3" dependencies = [ "openssl-probe", - "rustls-pemfile", "rustls-pki-types", "schannel", - "security-framework", + "security-framework 3.1.0", ] [[package]] @@ -4938,9 +4958,12 @@ dependencies = [ [[package]] name = "rustls-pki-types" -version = "1.10.0" +version = "1.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "16f1201b3c9a7ee8039bcadc17b7e605e2945b27eee7631788c1bd2b0643674b" +checksum = "d2bf47e6ff922db3825eb750c4e2ff784c6ff8fb9e13046ef6a1d1c5401b0b37" +dependencies = [ + "web-time", +] [[package]] name = "rustls-webpki" @@ -4988,9 +5011,9 @@ dependencies = [ [[package]] name = "scale-info" -version = "2.11.5" +version = "2.11.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1aa7ffc1c0ef49b0452c6e2986abf2b07743320641ffd5fc63d552458e3b779b" +checksum = "346a3b32eba2640d17a9cb5927056b08f3de90f65b72fe09402c2ad07d684d0b" dependencies = [ "cfg-if", "derive_more", @@ -5000,30 +5023,30 @@ dependencies = [ [[package]] name = "scale-info-derive" -version = "2.11.5" +version = "2.11.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "46385cc24172cf615450267463f937c10072516359b3ff1cb24228a4a08bf951" +checksum = "c6630024bf739e2179b91fb424b28898baf819414262c5d376677dbff1fe7ebf" dependencies = [ "proc-macro-crate 3.2.0", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "scc" -version = "2.2.4" +version = "2.2.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d8d25269dd3a12467afe2e510f69fb0b46b698e5afb296b59f2145259deaf8e8" +checksum = "94b13f8ea6177672c49d12ed964cca44836f59621981b04a3e26b87e675181de" dependencies = [ "sdd", ] [[package]] name = "schannel" -version = "0.1.26" +version = "0.1.27" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "01227be5826fa0690321a2ba6c5cd57a19cf3f6a09e76973b58e61de6ab9d1c1" +checksum = "1f29ebaa345f945cec9fbbc532eb307f0fdad8161f281b6369539c8d84876b3d" dependencies = [ "windows-sys 0.59.0", ] @@ -5051,7 +5074,7 @@ checksum = "7f81c2fde025af7e69b1d1420531c8a8811ca898919db177141a85313b1cb932" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -5066,9 +5089,9 @@ dependencies = [ [[package]] name = "sdd" -version = "3.0.4" +version = "3.0.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "49c1eeaf4b6a87c7479688c6d52b9f1153cedd3c489300564f932b065c6eab95" +checksum = "478f121bb72bbf63c52c93011ea1791dca40140dfe13f8336c4c5ac952c33aa9" [[package]] name = "sec1" @@ -5091,7 +5114,20 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "897b2245f0b511c87893af39b033e5ca9cce68824c4d7e7630b5a1d339658d02" dependencies = [ "bitflags", - "core-foundation", + "core-foundation 0.9.4", + "core-foundation-sys", + "libc", + "security-framework-sys", +] + +[[package]] +name = "security-framework" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "81d3f8c9bfcc3cbb6b0179eb57042d75b1582bdc65c3cb95f3fa999509c03cbc" +dependencies = [ + "bitflags", + "core-foundation 0.10.0", "core-foundation-sys", "libc", "security-framework-sys", @@ -5099,9 +5135,9 @@ dependencies = [ [[package]] name = "security-framework-sys" -version = "2.12.1" +version = "2.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fa39c7303dc58b5543c94d22c1766b0d31f2ee58306363ea622b10bbc075eaa2" +checksum = "1863fd3768cd83c56a7f60faa4dc0d403f1b6df0a38c3c25f44b7894e45370d5" dependencies = [ "core-foundation-sys", "libc", @@ -5122,14 +5158,14 @@ version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f301af10236f6df4160f7c3f04eec6dbc70ace82d23326abad5edee88801c6b6" dependencies = [ - "semver-parser 0.10.2", + "semver-parser 0.10.3", ] [[package]] name = "semver" -version = "1.0.23" +version = "1.0.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61697e0a1c7e512e84a621326239844a24d8207b4669b41bc18b32ea5cbf988b" +checksum = "3cb6eb87a131f756572d7fb904f6e7b68633f09cca868c5df1c4b8d1a694bbba" dependencies = [ "serde", ] @@ -5142,38 +5178,38 @@ checksum = "388a1df253eca08550bef6c72392cfe7c30914bf41df5269b68cbd6ff8f570a3" [[package]] name = "semver-parser" -version = "0.10.2" +version = "0.10.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "00b0bef5b7f9e0df16536d3961cfb6e84331c065b4066afb39768d0e319411f7" +checksum = "9900206b54a3527fdc7b8a938bffd94a568bac4f4aa8113b209df75a09c0dec2" dependencies = [ "pest", ] [[package]] name = "serde" -version = "1.0.215" +version = "1.0.216" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6513c1ad0b11a9376da888e3e0baa0077f1aed55c17f50e7b2397136129fb88f" +checksum = "0b9781016e935a97e8beecf0c933758c97a5520d32930e460142b4cd80c6338e" dependencies = [ "serde_derive", ] [[package]] name = "serde_derive" -version = "1.0.215" +version = "1.0.216" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad1e866f866923f252f05c889987993144fb74e722403468a4ebd70c3cd756c0" +checksum = "46f859dbbf73865c6627ed570e78961cd3ac92407a2d117204c49232485da55e" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "serde_json" -version = "1.0.132" +version = "1.0.133" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d726bfaff4b320266d395898905d0eba0345aae23b54aee3a737e260fd46db03" +checksum = "c7fceb2473b9166b2294ef05efcb65a3db80803f0b03ef86a5fc88a2b85ee377" dependencies = [ "itoa", "memchr", @@ -5258,7 +5294,7 @@ checksum = "5d69265a08751de7844521fd15003ae0a888e035773ba05695c5c759a6f89eef" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -5438,9 +5474,9 @@ dependencies = [ [[package]] name = "socket2" -version = "0.5.7" +version = "0.5.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ce305eb0b4296696835b71df73eb912e0f1ffd2556a501fcede6e0c50349191c" +checksum = "c970269d99b64e60ec3bd6ad27270092a5394c4e309314b18ae3fe575695fbe8" dependencies = [ "libc", "windows-sys 0.52.0", @@ -5448,11 +5484,7 @@ dependencies = [ [[package]] name = "sp1-build" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "cargo_metadata", @@ -5463,11 +5495,7 @@ dependencies = [ [[package]] name = "sp1-cli" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anstyle", "anyhow", @@ -5496,11 +5524,7 @@ dependencies = [ [[package]] name = "sp1-core-executor" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "bytemuck", @@ -5539,17 +5563,13 @@ dependencies = [ [[package]] name = "sp1-core-machine" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "cfg-if", "criterion", "elliptic-curve", - "generic-array 1.1.0", + "generic-array 1.1.1", "hashbrown 0.14.5", "hex", "itertools 0.13.0", @@ -5593,11 +5613,7 @@ dependencies = [ [[package]] name = "sp1-cuda" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "ctrlc", @@ -5615,16 +5631,12 @@ dependencies = [ [[package]] name = "sp1-curves" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "cfg-if", "dashu", "elliptic-curve", - "generic-array 1.1.0", + "generic-array 1.1.1", "itertools 0.13.0", "k256", "num", @@ -5641,11 +5653,7 @@ dependencies = [ [[package]] name = "sp1-derive" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "quote", "syn 1.0.109", @@ -5653,11 +5661,7 @@ dependencies = [ [[package]] name = "sp1-eval" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "bincode", @@ -5669,27 +5673,20 @@ dependencies = [ "sp1-prover", "sp1-sdk", "sp1-stark", - "time 0.3.36", + "time 0.3.37", "tokio", ] [[package]] name = "sp1-helper" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "sp1-build", ] [[package]] name = "sp1-lib" -<<<<<<< HEAD -version = "3.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1c8744af050832df5ca44fcd63979a83b93ca3010b2d5a5ce2a2b91f7438065c" +version = "3.4.0" dependencies = [ "bincode", "serde", @@ -5698,9 +5695,8 @@ dependencies = [ [[package]] name = "sp1-lib" version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a5729da1b05d56c01457e5ecabdc77f1cc941df23f2921163a2f325aec22428" dependencies = [ "bincode", "serde", @@ -5708,11 +5704,7 @@ dependencies = [ [[package]] name = "sp1-perf" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "clap", @@ -5723,16 +5715,12 @@ dependencies = [ "sp1-sdk", "sp1-stark", "test-artifacts", - "time 0.3.36", + "time 0.3.37", ] [[package]] name = "sp1-primitives" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "hex", @@ -5748,11 +5736,7 @@ dependencies = [ [[package]] name = "sp1-prover" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "bincode", @@ -5789,11 +5773,7 @@ dependencies = [ [[package]] name = "sp1-recursion-circuit" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "ff 0.13.0", "hashbrown 0.14.5", @@ -5830,11 +5810,7 @@ dependencies = [ [[package]] name = "sp1-recursion-compiler" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "backtrace", "criterion", @@ -5859,11 +5835,7 @@ dependencies = [ [[package]] name = "sp1-recursion-core" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "backtrace", "ff 0.13.0", @@ -5898,11 +5870,7 @@ dependencies = [ [[package]] name = "sp1-recursion-derive" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "quote", "syn 1.0.109", @@ -5910,11 +5878,7 @@ dependencies = [ [[package]] name = "sp1-recursion-gnark-cli" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "bincode", "clap", @@ -5923,11 +5887,7 @@ dependencies = [ [[package]] name = "sp1-recursion-gnark-ffi" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "anyhow", "bincode", @@ -5951,11 +5911,7 @@ dependencies = [ [[package]] name = "sp1-sdk" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "alloy-primitives", "alloy-signer", @@ -6003,11 +5959,7 @@ dependencies = [ [[package]] name = "sp1-stark" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "arrayref", "hashbrown 0.14.5", @@ -6054,11 +6006,7 @@ dependencies = [ [[package]] name = "sp1-zkvm" -<<<<<<< HEAD version = "3.4.0" -======= -version = "3.1.0" ->>>>>>> 4451903ac (fix: remove stdin from SP1ProofWithPublicValues (#1714)) dependencies = [ "cfg-if", "getrandom 0.2.15", @@ -6204,7 +6152,7 @@ dependencies = [ "proc-macro2", "quote", "rustversion", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -6221,7 +6169,7 @@ dependencies = [ "num-bigint 0.4.6", "rand 0.8.5", "rustc-hex", - "sp1-lib 3.2.1", + "sp1-lib 3.4.0 (registry+https://github.com/rust-lang/crates.io-index)", ] [[package]] @@ -6266,9 +6214,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.87" +version = "2.0.90" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25aa4ce346d03a6dcd68dd8b4010bcb74e54e62c90c573f394c46eae99aba32d" +checksum = "919d3b74a5dd0ccd15aeb8f93e7006bd9e14c295087c9896a110f490752bcf31" dependencies = [ "proc-macro2", "quote", @@ -6284,20 +6232,14 @@ dependencies = [ "paste", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "sync_wrapper" -version = "0.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160" - -[[package]] -name = "sync_wrapper" -version = "1.0.1" +version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a7065abeca94b6a8a577f9bd45aa0867a2238b74e8eb67cf10d492bc39351394" +checksum = "0bf256ce5efdfa370213c1dabab5935a12e49f2c58d15e9eac2870d3b4f27263" dependencies = [ "futures-core", ] @@ -6310,7 +6252,7 @@ checksum = "c8af7666ab7b6390ab78131fb5b0fce11d6b7a6951602017c35fa82800708971" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -6335,7 +6277,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3c879d448e9d986b661742763247d3693ed13609438cf3d006f51f5368a5ba6b" dependencies = [ "bitflags", - "core-foundation", + "core-foundation 0.9.4", "system-configuration-sys", ] @@ -6368,7 +6310,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "28cce251fcbc87fac86a866eeb0d6c2d536fc16d06f184bb61aeae11aa4cee0c" dependencies = [ "cfg-if", - "fastrand 2.2.0", + "fastrand 2.3.0", "once_cell", "rustix", "windows-sys 0.59.0", @@ -6429,7 +6371,7 @@ checksum = "4fee6c4efc90059e10f81e6d42c60a18f76588c3d74cb83a0b242a2b6c7504c1" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -6440,7 +6382,7 @@ checksum = "f2f357fcec90b3caef6623a099691be676d033b40a058ac95d2a6ade6fa0c943" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -6499,9 +6441,9 @@ dependencies = [ [[package]] name = "time" -version = "0.3.36" +version = "0.3.37" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5dfd88e563464686c916c7e46e623e520ddc6d79fa6641390f2e3fa86e83e885" +checksum = "35e7868883861bd0e56d9ac6efcaaca0d6d5d82a2a7ec8209ff492c07cf37b21" dependencies = [ "deranged", "itoa", @@ -6511,7 +6453,7 @@ dependencies = [ "powerfmt", "serde", "time-core", - "time-macros 0.2.18", + "time-macros 0.2.19", ] [[package]] @@ -6532,9 +6474,9 @@ dependencies = [ [[package]] name = "time-macros" -version = "0.2.18" +version = "0.2.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3f252a68540fde3a3877aeea552b832b40ab9a69e318efd078774a01ddee1ccf" +checksum = "2834e6017e3e5e4b9834939793b282bc03b37a3336245fa820e35e233e2a85de" dependencies = [ "num-conv", "time-core", @@ -6584,9 +6526,9 @@ dependencies = [ [[package]] name = "tinyvec" -version = "1.8.0" +version = "1.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "445e881f4f6d382d5f27c034e25eb92edd7c784ceab92a0937db7f2e9471b938" +checksum = "022db8904dfa342efe721985167e9fcd16c29b226db4397ed752a761cfce81e8" dependencies = [ "tinyvec_macros", ] @@ -6599,12 +6541,12 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokio" -version = "1.41.1" +version = "1.42.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "22cfb5bee7a6a52939ca9224d6ac897bb669134078daa8735560897f69de4d33" +checksum = "5cec9b21b0450273377fc97bd4c33a8acffc8c996c987a7c5b319a0083707551" dependencies = [ "backtrace", - "bytes 1.8.0", + "bytes 1.9.0", "libc", "mio", "parking_lot", @@ -6623,7 +6565,7 @@ checksum = "693d596312e88961bc67d7f1f97af8a70227d9f90c31bba5806eec004978d752" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -6638,20 +6580,19 @@ dependencies = [ [[package]] name = "tokio-rustls" -version = "0.26.0" +version = "0.26.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c7bc40d0e5a97695bb96e27995cd3a08538541b0a846f65bba7a359f36700d4" +checksum = "5f6d0975eaace0cf0fcadee4e4aaa5da15b5c079146f2cffb67c113be122bf37" dependencies = [ - "rustls 0.23.16", - "rustls-pki-types", + "rustls 0.23.20", "tokio", ] [[package]] name = "tokio-stream" -version = "0.1.16" +version = "0.1.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4f4e6ce100d0eb49a2734f8c0812bcd324cf357d21810932c5df6b96ef2b86f1" +checksum = "eca58d7bba4a75707817a2c44174253f9236b2d5fbd055602e9d5c07c139a047" dependencies = [ "futures-core", "pin-project-lite", @@ -6665,7 +6606,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2468baabc3311435b55dd935f702f42cd1b8abb7e754fb7dfb16bd36aa88f9f7" dependencies = [ "async-stream", - "bytes 1.8.0", + "bytes 1.9.0", "futures-core", "tokio", "tokio-stream", @@ -6673,11 +6614,11 @@ dependencies = [ [[package]] name = "tokio-util" -version = "0.7.12" +version = "0.7.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a" +checksum = "d7fcaa8d55a2bdd6b83ace262b016eca0d79ee02818c5c1bcdf0305114081078" dependencies = [ - "bytes 1.8.0", + "bytes 1.9.0", "futures-core", "futures-sink", "pin-project-lite", @@ -6696,7 +6637,7 @@ version = "0.19.15" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1b5bb770da30e5cbfde35a2d7b9b8a2c4b8ef89548a7a6aeab5c9a576e3e7421" dependencies = [ - "indexmap 2.6.0", + "indexmap 2.7.0", "toml_datetime", "winnow 0.5.40", ] @@ -6707,7 +6648,7 @@ version = "0.22.22" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4ae48d6208a266e853d946088ed816055e556cc6028c5e8e2b84d9fa5dd7c7f5" dependencies = [ - "indexmap 2.6.0", + "indexmap 2.7.0", "toml_datetime", "winnow 0.6.20", ] @@ -6722,9 +6663,9 @@ dependencies = [ "async-trait", "axum", "base64 0.22.1", - "bytes 1.8.0", + "bytes 1.9.0", "h2", - "http 1.1.0", + "http 1.2.0", "http-body", "http-body-util", "hyper", @@ -6767,14 +6708,14 @@ dependencies = [ [[package]] name = "tower" -version = "0.5.1" +version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2873938d487c3cfb9aed7546dc9f2711d867c9f90c46b889989a2cb84eba6b4f" +checksum = "d039ad9159c98b70ecfd540b2573b97f7f52c3e8d9f8ad57a24b916a536975f9" dependencies = [ "futures-core", "futures-util", "pin-project-lite", - "sync_wrapper 0.1.2", + "sync_wrapper", "tokio", "tower-layer", "tower-service", @@ -6795,9 +6736,9 @@ checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3" [[package]] name = "tracing" -version = "0.1.40" +version = "0.1.41" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef" +checksum = "784e0ac535deb450455cbfa28a6f0df145ea1bb7ae51b821cf5e7927fdcfbdd0" dependencies = [ "log", "pin-project-lite", @@ -6813,26 +6754,26 @@ checksum = "3566e8ce28cc0a3fe42519fc80e6b4c943cc4c8cef275620eb8dac2d3d4e06cf" dependencies = [ "crossbeam-channel", "thiserror 1.0.69", - "time 0.3.36", + "time 0.3.37", "tracing-subscriber", ] [[package]] name = "tracing-attributes" -version = "0.1.27" +version = "0.1.28" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" +checksum = "395ae124c09f9e6918a2310af6038fba074bcf474ac352496d5910dd59a2226d" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "tracing-core" -version = "0.1.32" +version = "0.1.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" +checksum = "e672c95779cf947c5311f83787af4fa8fffd12fb27e4993211a84bdfd9610f9c" dependencies = [ "once_cell", "valuable", @@ -6874,9 +6815,9 @@ dependencies = [ [[package]] name = "tracing-subscriber" -version = "0.3.18" +version = "0.3.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ad0f048c97dbd9faa9b7df56362b8ebcaa52adb06b498c050d2f4e32f90a7a8b" +checksum = "e8189decb5ac0fa7bc8b96b7cb9b2701d60d48805aca84a238004d665fcc4008" dependencies = [ "matchers", "nu-ansi-term", @@ -6904,7 +6845,7 @@ checksum = "30ee6ab729cd4cf0fd55218530c4522ed30b7b6081752839b68fcec8d0960788" dependencies = [ "base64 0.13.1", "byteorder", - "bytes 1.8.0", + "bytes 1.9.0", "http 0.2.12", "httparse", "log", @@ -6933,7 +6874,7 @@ dependencies = [ "async-trait", "axum", "futures", - "http 1.1.0", + "http 1.2.0", "http-body-util", "hyper", "prost", @@ -6942,7 +6883,7 @@ dependencies = [ "serde_json", "thiserror 1.0.69", "tokio", - "tower 0.5.1", + "tower 0.5.2", "url", ] @@ -6984,9 +6925,9 @@ checksum = "7e51b68083f157f853b6379db119d1c1be0e6e4dec98101079dec41f6f5cf6df" [[package]] name = "unicode-ident" -version = "1.0.13" +version = "1.0.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e91b56cd4cadaeb79bbf1a5645f6b4f8dc5bde8834ad5894a8db35fda9efa1fe" +checksum = "adb9e6ca4f869e1180728b7950e35922a7fc6397f7b641499e8f3ef06e50dc83" [[package]] name = "unicode-linebreak" @@ -7036,9 +6977,9 @@ checksum = "8ecb6da28b8a351d773b68d5825ac39017e680750f980f3a1a85cd8dd28a47c1" [[package]] name = "url" -version = "2.5.3" +version = "2.5.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8d157f1b96d14500ffdc1f10ba712e780825526c03d9a49b4d0324b0d9113ada" +checksum = "32f8b686cadd1473f4bd0117a5d28d36b1ade384ea9b5069a1c40aefed7fda60" dependencies = [ "form_urlencoded", "idna", @@ -7113,7 +7054,7 @@ dependencies = [ "cfg-if", "git2", "rustversion", - "time 0.3.36", + "time 0.3.37", ] [[package]] @@ -7170,9 +7111,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.95" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "128d1e363af62632b8eb57219c8fd7877144af57558fb2ef0368d0087bddeb2e" +checksum = "a474f6281d1d70c17ae7aa6a613c87fce69a127e2624002df63dcb39d6cf6396" dependencies = [ "cfg-if", "once_cell", @@ -7181,36 +7122,36 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.95" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cb6dd4d3ca0ddffd1dd1c9c04f94b868c37ff5fac97c30b97cff2d74fce3a358" +checksum = "5f89bb38646b4f81674e8f5c3fb81b562be1fd936d84320f3264486418519c79" dependencies = [ "bumpalo", "log", - "once_cell", "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-futures" -version = "0.4.45" +version = "0.4.49" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cc7ec4f8827a71586374db3e87abdb5a2bb3a15afed140221307c3ec06b1f63b" +checksum = "38176d9b44ea84e9184eff0bc34cc167ed044f816accfe5922e54d84cf48eca2" dependencies = [ "cfg-if", "js-sys", + "once_cell", "wasm-bindgen", "web-sys", ] [[package]] name = "wasm-bindgen-macro" -version = "0.2.95" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e79384be7f8f5a9dd5d7167216f022090cf1f9ec128e6e6a482a2cb5c5422c56" +checksum = "2cc6181fd9a7492eef6fef1f33961e3695e4579b9872a6f7c83aee556666d4fe" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -7218,22 +7159,22 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.95" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26c6ab57572f7a24a4985830b120de1594465e5d500f24afe89e16b4e833ef68" +checksum = "30d7a95b763d3c45903ed6c81f156801839e5ee968bb07e534c44df0fcd330c2" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.95" +version = "0.2.99" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "65fc09f10666a9f147042251e0dda9c18f166ff7de300607007e96bdebc1068d" +checksum = "943aab3fdaaa029a6e0271b35ea10b72b943135afe9bffca82384098ad0e06a6" [[package]] name = "wasm-streams" @@ -7250,9 +7191,9 @@ dependencies = [ [[package]] name = "web-sys" -version = "0.3.72" +version = "0.3.76" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f6488b90108c040df0fe62fa815cbdee25124641df01814dd7282749234c6112" +checksum = "04dd7223427d52553d3702c004d3b2fe07c148165faa56313cb00211e31c12bc" dependencies = [ "js-sys", "wasm-bindgen", @@ -7289,9 +7230,9 @@ dependencies = [ [[package]] name = "webpki-roots" -version = "0.26.6" +version = "0.26.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "841c67bff177718f1d4dfefde8d8f0e78f9b6589319ba88312f567fc5841a958" +checksum = "5d642ff16b7e79272ae451b7322067cdc17cadf68c23264be9d94a32319efe7e" dependencies = [ "rustls-pki-types", ] @@ -7571,9 +7512,9 @@ checksum = "cfe53a6657fd280eaa890a3bc59152892ffa3e30101319d168b781ed6529b049" [[package]] name = "yoke" -version = "0.7.4" +version = "0.7.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6c5b1314b079b0930c31e3af543d8ee1757b1951ae1e1565ec704403a7240ca5" +checksum = "120e6aef9aa629e3d4f52dc8cc43a015c7724194c97dfaf45180d2daf2b77f40" dependencies = [ "serde", "stable_deref_trait", @@ -7583,13 +7524,13 @@ dependencies = [ [[package]] name = "yoke-derive" -version = "0.7.4" +version = "0.7.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "28cc31741b18cb6f1d5ff12f5b7523e3d6eb0852bbbad19d73905511d9849b95" +checksum = "2380878cad4ac9aac1e2435f3eb4020e8374b5f13c296cb75b4620ff8e229154" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "synstructure", ] @@ -7611,27 +7552,27 @@ checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] name = "zerofrom" -version = "0.1.4" +version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "91ec111ce797d0e0784a1116d0ddcdbea84322cd79e5d5ad173daeba4f93ab55" +checksum = "cff3ee08c995dee1859d998dea82f7374f2826091dd9cd47def953cae446cd2e" dependencies = [ "zerofrom-derive", ] [[package]] name = "zerofrom-derive" -version = "0.1.4" +version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0ea7b4a3637ea8669cedf0f1fd5c286a17f3de97b8dd5a70a6c167a1730e63a5" +checksum = "595eed982f7d355beb85837f651fa22e90b3c044842dc7f2c2842c086f295808" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", "synstructure", ] @@ -7652,7 +7593,7 @@ checksum = "ce36e65b0d2999d2aafac989fb249189a141aee1f53c612c1f37d72631959f69" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] @@ -7674,7 +7615,7 @@ checksum = "6eafa6dfb17584ea3e2bd6e76e0cc15ad7af12b09abdd1ca55961bed9b1063c6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.87", + "syn 2.0.90", ] [[package]] From 8740dddb63758ebcb45dfc2d681ec87656b311d8 Mon Sep 17 00:00:00 2001 From: Ratan Kaliani Date: Fri, 20 Dec 2024 18:21:09 -0800 Subject: [PATCH 13/13] fix --- crates/prover/src/lib.rs | 2 +- crates/sdk/src/lib.rs | 4 ++-- crates/sdk/src/prover.rs | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/crates/prover/src/lib.rs b/crates/prover/src/lib.rs index c8460a62f4..3c73d63677 100644 --- a/crates/prover/src/lib.rs +++ b/crates/prover/src/lib.rs @@ -88,7 +88,7 @@ use components::{CpuProverComponents, SP1ProverComponents}; /// This string should be updated whenever any step in verifying an SP1 proof changes, including /// core, recursion, and plonk-bn254. This string is used to download SP1 artifacts and the gnark /// docker image. -pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../SP1_VERSION"); +pub const SP1_CIRCUIT_VERSION: &str = include_str!("../../../SP1_VERSION"); /// The configuration for the core prover. pub type CoreSC = BabyBearPoseidon2; diff --git a/crates/sdk/src/lib.rs b/crates/sdk/src/lib.rs index 08d3ccecbd..830dc95c04 100644 --- a/crates/sdk/src/lib.rs +++ b/crates/sdk/src/lib.rs @@ -57,11 +57,11 @@ pub use sp1_build::include_elf; pub use sp1_core_executor::{ExecutionReport, Executor, HookEnv, SP1Context, SP1ContextBuilder}; // Re-export the machine/prover primitives. -pub use sp1_core_machine::{io::SP1Stdin, riscv::cost::CostEstimator, SP1_CIRCUIT_VERSION}; +pub use sp1_core_machine::{io::SP1Stdin, riscv::cost::CostEstimator}; pub use sp1_primitives::io::SP1PublicValues; pub use sp1_prover::{ CoreSC, HashableKey, InnerSC, OuterSC, PlonkBn254Proof, ProverMode, SP1Prover, SP1ProvingKey, - SP1VerifyingKey, + SP1VerifyingKey, SP1_CIRCUIT_VERSION, }; // Re-export the utilities. diff --git a/crates/sdk/src/prover.rs b/crates/sdk/src/prover.rs index 83f04deb95..6e9deff2d4 100644 --- a/crates/sdk/src/prover.rs +++ b/crates/sdk/src/prover.rs @@ -8,11 +8,11 @@ use anyhow::Result; use itertools::Itertools; use p3_field::PrimeField32; use sp1_core_executor::{ExecutionReport, SP1Context}; -use sp1_core_machine::{io::SP1Stdin, SP1_CIRCUIT_VERSION}; +use sp1_core_machine::io::SP1Stdin; use sp1_primitives::io::SP1PublicValues; use sp1_prover::{ components::SP1ProverComponents, CoreSC, InnerSC, SP1CoreProofData, SP1Prover, SP1ProvingKey, - SP1VerifyingKey, + SP1VerifyingKey, SP1_CIRCUIT_VERSION, }; use sp1_stark::{air::PublicValues, MachineVerificationError, Word}; use thiserror::Error;