From d2d07566e7b9089d7cfc553ce2bc67616474e851 Mon Sep 17 00:00:00 2001 From: Steven Date: Tue, 5 Sep 2023 21:41:56 +0800 Subject: [PATCH 1/2] fix: replace to use `serde_json::to_writer` for performance (#258) Fix to use `serde_json::to_writer`. --- prover/src/io.rs | 2 +- prover/src/proof.rs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/prover/src/io.rs b/prover/src/io.rs index c75402311..01d45925e 100644 --- a/prover/src/io.rs +++ b/prover/src/io.rs @@ -157,7 +157,7 @@ pub fn serialize_verify_circuit_final_pair(pair: &(G1Affine, G1Affine, Vec)) pub fn write_snark(file_path: &str, snark: &Snark) { let mut fd = std::fs::File::create(file_path).unwrap(); - serde_json::to_writer_pretty(&mut fd, snark).unwrap() + serde_json::to_writer(&mut fd, snark).unwrap() } pub fn load_snark(file_path: &str) -> anyhow::Result> { diff --git a/prover/src/proof.rs b/prover/src/proof.rs index e7aee459a..8212c8118 100644 --- a/prover/src/proof.rs +++ b/prover/src/proof.rs @@ -118,7 +118,7 @@ impl Proof { pub fn dump_as_json(dir: &str, filename: &str, proof: &P) -> Result<()> { // Write full proof as json. let mut fd = File::create(dump_proof_path(dir, filename))?; - serde_json::to_writer_pretty(&mut fd, proof)?; + serde_json::to_writer(&mut fd, proof)?; Ok(()) } From cde2eda22429bf7de444140f4326b90a6db93714 Mon Sep 17 00:00:00 2001 From: Steven Date: Wed, 6 Sep 2023 08:49:13 +0800 Subject: [PATCH 2/2] fix: check chunk-hashes with values in chunk-proofs when generates batch-proof (#257) Check chunk-hashes with values in chunk-proofs when generates batch-proof. --- prover/src/aggregator/prover.rs | 79 +++++++++++++++++++++++++++++++++ prover/src/proof.rs | 2 +- prover/src/proof/chunk.rs | 2 +- 3 files changed, 81 insertions(+), 2 deletions(-) diff --git a/prover/src/aggregator/prover.rs b/prover/src/aggregator/prover.rs index 52a9c77e6..f0917d175 100644 --- a/prover/src/aggregator/prover.rs +++ b/prover/src/aggregator/prover.rs @@ -118,6 +118,7 @@ impl Prover { let real_chunk_count = chunk_hashes_proofs.len(); assert!((1..=MAX_AGG_SNARKS).contains(&real_chunk_count)); + check_chunk_hashes(name, &chunk_hashes_proofs)?; let (mut chunk_hashes, chunk_proofs): (Vec<_>, Vec<_>) = chunk_hashes_proofs.into_iter().unzip(); @@ -167,3 +168,81 @@ impl Prover { } } } + +macro_rules! compare_field { + ($name:expr, $idx:expr, $field:ident, $lhs:ident, $rhs:ident) => { + if $lhs.$field != $rhs.$field { + bail!( + "{} chunk-no-{}, different {}: {} != {}", + $name, + $idx, + stringify!($field), + $lhs.$field, + $rhs.$field + ); + } + }; +} + +fn check_chunk_hashes(name: &str, chunk_hashes_proofs: &[(ChunkHash, ChunkProof)]) -> Result<()> { + for (idx, (in_arg, chunk_proof)) in chunk_hashes_proofs.iter().enumerate() { + if let Some(in_proof) = chunk_proof.chunk_hash { + compare_field!(name, idx, chain_id, in_arg, in_proof); + compare_field!(name, idx, prev_state_root, in_arg, in_proof); + compare_field!(name, idx, post_state_root, in_arg, in_proof); + compare_field!(name, idx, withdraw_root, in_arg, in_proof); + compare_field!(name, idx, data_hash, in_arg, in_proof); + } + } + + Ok(()) +} + +#[cfg(test)] +mod tests { + use super::*; + use eth_types::H256; + + #[test] + fn test_check_chunk_hashes() { + let chunk_hashes_proofs = vec![ + (ChunkHash::default(), ChunkProof::default()), + ( + ChunkHash { + chain_id: 1, + prev_state_root: H256::zero(), + data_hash: [100; 32].into(), + ..Default::default() + }, + ChunkProof { + chunk_hash: Some(ChunkHash { + chain_id: 1, + prev_state_root: [0; 32].into(), + data_hash: [100; 32].into(), + ..Default::default() + }), + ..Default::default() + }, + ), + ( + ChunkHash { + post_state_root: H256::zero(), + ..Default::default() + }, + ChunkProof { + chunk_hash: Some(ChunkHash { + post_state_root: [1; 32].into(), + ..Default::default() + }), + ..Default::default() + }, + ), + ]; + + let result = check_chunk_hashes("test-batch", &chunk_hashes_proofs); + assert_eq!( + result.unwrap_err().downcast_ref::().unwrap(), + "test-batch chunk-no-2, different post_state_root: 0x0000…0000 != 0x0101…0101" + ); + } +} diff --git a/prover/src/proof.rs b/prover/src/proof.rs index 8212c8118..d32b39eed 100644 --- a/prover/src/proof.rs +++ b/prover/src/proof.rs @@ -30,7 +30,7 @@ pub use batch::BatchProof; pub use chunk::ChunkProof; pub use evm::EvmProof; -#[derive(Clone, Debug, Deserialize, Serialize)] +#[derive(Clone, Debug, Default, Deserialize, Serialize)] pub struct Proof { #[serde(with = "base64")] proof: Vec, diff --git a/prover/src/proof/chunk.rs b/prover/src/proof/chunk.rs index 6a3d26296..7c1c6aa68 100644 --- a/prover/src/proof/chunk.rs +++ b/prover/src/proof/chunk.rs @@ -7,7 +7,7 @@ use snark_verifier::Protocol; use snark_verifier_sdk::Snark; use types::{base64, eth::StorageTrace}; -#[derive(Clone, Debug, Deserialize, Serialize)] +#[derive(Clone, Debug, Default, Deserialize, Serialize)] pub struct ChunkProof { #[serde(with = "base64")] pub storage_trace: Vec,