From a9a0b0275ef84e8bad542b623b69e4488058886b Mon Sep 17 00:00:00 2001 From: Zhang Zhuo Date: Thu, 31 Oct 2024 15:49:28 +0800 Subject: [PATCH] update zkevm-circuits (#349) * update * done * test * update * done * done * clean * develop * lint --- Cargo.lock | 615 +++++++++++----------------- Cargo.toml | 4 +- bin/src/chain_prover.rs | 4 - integration/Cargo.toml | 1 - integration/src/capacity_checker.rs | 36 +- integration/src/evm.rs | 59 --- integration/src/lib.rs | 1 - integration/src/verifier.rs | 5 +- integration/tests/e2e_tests.rs | 4 +- integration/tests/unit_tests.rs | 25 +- 10 files changed, 274 insertions(+), 480 deletions(-) delete mode 100644 integration/src/evm.rs diff --git a/Cargo.lock b/Cargo.lock index 597bb987..a84d43a9 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -30,12 +30,12 @@ dependencies = [ [[package]] name = "aggregator" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "ark-std 0.3.0", "bitstream-io", - "c-kzg 1.0.2", + "c-kzg", "ctor", "encoder", "env_logger", @@ -51,12 +51,12 @@ dependencies = [ "num-bigint", "once_cell", "rand", - "revm-precompile 7.0.0", - "revm-primitives 4.0.0", + "revm-precompile 9.2.0", + "revm-primitives 7.1.0", "serde", "serde_json", - "snark-verifier 0.1.0 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", - "snark-verifier-sdk 0.0.1 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", + "snark-verifier", + "snark-verifier-sdk", "strum 0.25.0", "strum_macros 0.25.3", "zkevm-circuits", @@ -89,42 +89,91 @@ version = "0.2.16" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0942ffc6dcaadf03badf6e6a2d0228460359d5e34b57ccdc720b7382dfbd5ec5" +[[package]] +name = "alloy-eip2930" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0069cf0642457f87a01a014f6dc29d5d893cd4fd8fddf0c3cdfad1bb3ebafc41" +dependencies = [ + "alloy-primitives 0.8.10", + "alloy-rlp", + "serde", +] + +[[package]] +name = "alloy-eip7702" +version = "0.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "64ffc577390ce50234e02d841214b3dc0bea6aaaae8e04bbf3cb82e9a45da9eb" +dependencies = [ + "alloy-primitives 0.8.10", + "alloy-rlp", + "derive_more 1.0.0", + "k256", + "serde", +] + +[[package]] +name = "alloy-eips" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d9431c99a3b3fe606ede4b3d4043bdfbcb780c45b8d8d226c3804e2b75cfbe68" +dependencies = [ + "alloy-primitives 0.7.7", + "alloy-rlp", + "c-kzg", + "k256", + "once_cell", + "serde", +] + [[package]] name = "alloy-primitives" -version = "0.4.2" +version = "0.7.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a0628ec0ba5b98b3370bb6be17b12f23bfce8ee4ad83823325a20546d9b03b78" +checksum = "ccb3ead547f4532bc8af961649942f0b9c16ee9226e26caa3f38420651cc0bf4" dependencies = [ "alloy-rlp", "bytes", "cfg-if 1.0.0", "const-hex", - "derive_more", + "derive_more 0.99.17", "hex-literal", "itoa", + "k256", + "keccak-asm", + "proptest", + "rand", "ruint", + "serde", "tiny-keccak", ] [[package]] name = "alloy-primitives" -version = "0.7.7" +version = "0.8.10" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ccb3ead547f4532bc8af961649942f0b9c16ee9226e26caa3f38420651cc0bf4" +checksum = "8edae627382349b56cd6a7a2106f4fd69b243a9233e560c55c2e03cabb7e1d3c" dependencies = [ "alloy-rlp", "bytes", "cfg-if 1.0.0", "const-hex", - "derive_more", + "derive_more 1.0.0", + "foldhash", + "hashbrown 0.15.0", "hex-literal", + "indexmap 2.6.0", "itoa", "k256", "keccak-asm", + "paste", "proptest", "rand", "ruint", + "rustc-hash 2.0.0", "serde", + "sha3 0.10.8", "tiny-keccak", ] @@ -408,9 +457,9 @@ checksum = "a4a4ddaa51a5bc52a6948f74c06d20aaaddb71924eab79b8c97a8c556e942d6a" [[package]] name = "base64ct" -version = "1.0.1" +version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a32fd6af2b5827bce66c29053ba0e7c42b9dcab01835835058558c10851a46b" +checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b" [[package]] name = "bech32" @@ -420,7 +469,7 @@ checksum = "d86b93f97252c47b41663388e6d155714a9d0c398b99f1005cbc5f978b29f445" [[package]] name = "bin" -version = "0.13.0" +version = "0.14.0" dependencies = [ "anyhow", "clap", @@ -448,29 +497,6 @@ dependencies = [ "serde", ] -[[package]] -name = "bindgen" -version = "0.66.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f2b84e06fc203107bfbad243f4aba2af864eb7db3b1cf46ea0a023b0b433d2a7" -dependencies = [ - "bitflags 2.6.0", - "cexpr", - "clang-sys", - "lazy_static", - "lazycell", - "log", - "peeking_take_while", - "prettyplease", - "proc-macro2", - "quote", - "regex", - "rustc-hash", - "shlex", - "syn 2.0.66", - "which", -] - [[package]] name = "bit-set" version = "0.5.3" @@ -604,8 +630,8 @@ checksum = "0d261e256854913907f67ed06efbc3338dfe6179796deefc1ff763fc1aee5535" [[package]] name = "bus-mapping" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "eth-types", "ethers-core", @@ -620,7 +646,7 @@ dependencies = [ "mpt-zktrie", "num", "poseidon-circuit", - "revm-precompile 7.0.0", + "revm-precompile 9.2.0", "serde", "serde_json", "strum 0.25.0", @@ -650,30 +676,16 @@ dependencies = [ [[package]] name = "c-kzg" -version = "0.1.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ac926d808fb72fe09ebf471a091d6d72918876ccf0b4989766093d2d0d24a0ef" -dependencies = [ - "bindgen", - "blst", - "cc", - "glob", - "hex", - "libc", - "serde", -] - -[[package]] -name = "c-kzg" -version = "1.0.2" +version = "1.0.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cdf100c4cea8f207e883ff91ca886d621d8a166cb04971dfaa9bb8fd99ed95df" +checksum = "f0307f72feab3300336fb803a57134159f6e20139af1357f36c54cb90d8e8928" dependencies = [ "blst", "cc", "glob", "hex", "libc", + "once_cell", "serde", ] @@ -687,15 +699,6 @@ dependencies = [ "libc", ] -[[package]] -name = "cexpr" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6fac387a98bb7c37292057cffc56d62ecb629900026402633ae9160df93a8766" -dependencies = [ - "nom", -] - [[package]] name = "cfg-if" version = "0.1.10" @@ -733,17 +736,6 @@ dependencies = [ "inout", ] -[[package]] -name = "clang-sys" -version = "1.8.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b023947811758c97c59bf9d1c188fd619ad4718dcaa767947df1cadb14f39f4" -dependencies = [ - "glob", - "libc", - "libloading", -] - [[package]] name = "clap" version = "3.2.23" @@ -754,7 +746,7 @@ dependencies = [ "bitflags 1.3.2", "clap_derive", "clap_lex", - "indexmap", + "indexmap 1.9.3", "once_cell", "strsim", "termcolor", @@ -841,7 +833,7 @@ dependencies = [ "serde", "serde_derive", "sha2", - "sha3 0.10.6", + "sha3 0.10.8", "thiserror", ] @@ -1097,6 +1089,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fffa369a668c8af7dbf8b5e56c9f744fbd399949ed171606040001947de40b1c" dependencies = [ "const-oid", + "pem-rfc7468", "zeroize", ] @@ -1124,6 +1117,27 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "derive_more" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4a9b99b9cbbe49445b21764dc0625032a89b145a2642e67603e1c936f5458d05" +dependencies = [ + "derive_more-impl", +] + +[[package]] +name = "derive_more-impl" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cb7330aeadfbe296029522e6c40f315320aba36fc43a5b3632f3795348f3bd22" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.66", + "unicode-xid", +] + [[package]] name = "digest" version = "0.9.0" @@ -1189,6 +1203,7 @@ dependencies = [ "ff", "generic-array", "group", + "pem-rfc7468", "pkcs8", "rand_core", "sec1", @@ -1227,7 +1242,7 @@ dependencies = [ "rand", "rlp", "serde", - "sha3 0.10.6", + "sha3 0.10.8", "zeroize", ] @@ -1255,6 +1270,12 @@ dependencies = [ "termcolor", ] +[[package]] +name = "equivalent" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" + [[package]] name = "errno" version = "0.3.3" @@ -1293,15 +1314,15 @@ dependencies = [ "serde", "serde_json", "sha2", - "sha3 0.10.6", + "sha3 0.10.8", "thiserror", "uuid", ] [[package]] name = "eth-types" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "base64 0.13.1", "ethers-core", @@ -1314,12 +1335,12 @@ dependencies = [ "num-bigint", "poseidon-base", "regex", - "revm-precompile 7.0.0", - "revm-primitives 4.0.0", + "revm-precompile 9.2.0", + "revm-primitives 7.1.0", "serde", "serde_json", "serde_with", - "sha3 0.10.6", + "sha3 0.10.8", "strum 0.25.0", "strum_macros 0.25.3", "subtle", @@ -1338,7 +1359,7 @@ dependencies = [ "regex", "serde", "serde_json", - "sha3 0.10.6", + "sha3 0.10.8", "thiserror", "uint", ] @@ -1456,8 +1477,8 @@ dependencies = [ [[package]] name = "external-tracer" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "eth-types", "geth-utils", @@ -1513,6 +1534,12 @@ version = "1.0.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" +[[package]] +name = "foldhash" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f81ec6369c545a7d40e4589b5597581fa1c441fe1cce96dd1de43159910a36a2" + [[package]] name = "form_urlencoded" version = "1.1.0" @@ -1638,13 +1665,13 @@ dependencies = [ [[package]] name = "gadgets" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "eth-types", "halo2_proofs", "poseidon-base", - "sha3 0.10.6", + "sha3 0.10.8", "strum 0.25.0", ] @@ -1661,8 +1688,8 @@ dependencies = [ [[package]] name = "geth-utils" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "env_logger", "gobuild", @@ -1757,7 +1784,7 @@ dependencies = [ "futures-sink", "futures-util", "http", - "indexmap", + "indexmap 1.9.3", "slab", "tokio", "tokio-util", @@ -1767,7 +1794,7 @@ dependencies = [ [[package]] name = "halo2-base" version = "0.2.2" -source = "git+https://github.com/scroll-tech/halo2-lib?branch=develop#817cace374a9f4b2eca682b1cc36f143255ea25f" +source = "git+https://github.com/scroll-tech/halo2-lib?branch=develop#b236b88f2baa0f359cd30ffe1354644e7022c272" dependencies = [ "ff", "halo2_proofs", @@ -1776,13 +1803,13 @@ dependencies = [ "num-integer", "num-traits", "rand_chacha", - "rustc-hash", + "rustc-hash 1.1.0", ] [[package]] name = "halo2-ecc" version = "0.2.2" -source = "git+https://github.com/scroll-tech/halo2-lib?branch=develop#817cace374a9f4b2eca682b1cc36f143255ea25f" +source = "git+https://github.com/scroll-tech/halo2-lib?branch=develop#b236b88f2baa0f359cd30ffe1354644e7022c272" dependencies = [ "ff", "group", @@ -1927,6 +1954,15 @@ dependencies = [ "allocator-api2", ] +[[package]] +name = "hashbrown" +version = "0.15.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e087f84d4f86bf4b218b927129862374b72199ae7d8657835f1e89000eea4fb" +dependencies = [ + "foldhash", +] + [[package]] name = "hashers" version = "1.0.1" @@ -1987,15 +2023,6 @@ dependencies = [ "digest 0.10.7", ] -[[package]] -name = "home" -version = "0.5.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e3d1354bf6b7235cb4a0576c2619fd4ed18183f689b12b006a0ee7329eeff9a5" -dependencies = [ - "windows-sys 0.52.0", -] - [[package]] name = "http" version = "0.2.9" @@ -2162,6 +2189,16 @@ dependencies = [ "hashbrown 0.12.3", ] +[[package]] +name = "indexmap" +version = "2.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "707907fe3c25f5424cce2cb7e1cbcafee6bdbe735ca90ef77c29e84591e5b9da" +dependencies = [ + "equivalent", + "hashbrown 0.15.0", +] + [[package]] name = "inout" version = "0.1.3" @@ -2182,7 +2219,7 @@ dependencies = [ [[package]] name = "integration" -version = "0.13.0" +version = "0.14.0" dependencies = [ "anyhow", "ethers-providers", @@ -2193,12 +2230,11 @@ dependencies = [ "log4rs", "prover", "rand", - "revm 3.5.0", "serde", "serde_derive", "serde_json", - "snark-verifier 0.1.0 (git+https://github.com/scroll-tech/snark-verifier?branch=develop)", - "snark-verifier-sdk 0.0.1 (git+https://github.com/scroll-tech/snark-verifier?branch=develop)", + "snark-verifier", + "snark-verifier-sdk", "tokio", ] @@ -2298,9 +2334,9 @@ dependencies = [ [[package]] name = "keccak" -version = "0.1.3" +version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3afef3b6eff9ce9d8ff9b3601125eec7f0c8cbac7abd14f355d053fa56c98768" +checksum = "ecc2af9a1119c51f12a14607e783cb977bde58bc069ff0c3da1095e635d70654" dependencies = [ "cpufeatures", ] @@ -2324,28 +2360,12 @@ dependencies = [ "spin", ] -[[package]] -name = "lazycell" -version = "1.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "830d08ce1d1d941e6b30645f1a0eb5643013d835ce3779a5fc208261dbe10f55" - [[package]] name = "libc" version = "0.2.147" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b4668fb0ea861c1df094127ac5f1da3409a82116a4ba74fca2e58ef927159bb3" -[[package]] -name = "libloading" -version = "0.8.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c2a198fb6b0eada2a8df47933734e6d35d350665a33a3593d7164fa52c75c19" -dependencies = [ - "cfg-if 1.0.0", - "windows-targets 0.52.5", -] - [[package]] name = "libm" version = "0.2.8" @@ -2449,12 +2469,6 @@ version = "0.3.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6877bb514081ee2a7ff5ef9de3281f14a4dd4bceac4c09388074a6b5df8a139a" -[[package]] -name = "minimal-lexical" -version = "0.2.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" - [[package]] name = "miniz_oxide" version = "0.7.1" @@ -2494,8 +2508,8 @@ dependencies = [ [[package]] name = "mock" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "eth-types", "ethers-core", @@ -2509,8 +2523,8 @@ dependencies = [ [[package]] name = "mpt-zktrie" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "eth-types", "halo2curves", @@ -2521,16 +2535,6 @@ dependencies = [ "zktrie", ] -[[package]] -name = "nom" -version = "7.1.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d273983c5a657a70a3e8f2a01329822f3b8c8172b73826411a55751e404a0a4a" -dependencies = [ - "memchr", - "minimal-lexical", -] - [[package]] name = "num" version = "0.4.0" @@ -2724,6 +2728,18 @@ version = "6.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ceedf44fb00f2d1984b0bc98102627ce622e083e49a5bacdb3e514fa4238e267" +[[package]] +name = "p256" +version = "0.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c9863ad85fa8f4460f9c48cb909d38a0d689dba1f6f6988a5e3e0d31071bcd4b" +dependencies = [ + "ecdsa", + "elliptic-curve", + "primeorder", + "sha2", +] + [[package]] name = "pairing" version = "0.23.0" @@ -2823,10 +2839,13 @@ dependencies = [ ] [[package]] -name = "peeking_take_while" -version = "0.1.2" +name = "pem-rfc7468" +version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "19b17cddbe7ec3f8bc800887bab5e717348c95ea2ca0b1bf0837fb964dc67099" +checksum = "88b39c9bfcfc231068454382784bb460aae594343fb030d46e9f50a645418412" +dependencies = [ + "base64ct", +] [[package]] name = "percent-encoding" @@ -2915,7 +2934,7 @@ dependencies = [ [[package]] name = "poseidon-base" version = "0.1.0" -source = "git+https://github.com/scroll-tech/poseidon-circuit.git?branch=main#d52fa404e8f03b5c3f85c090ccb8b08c112e2f4d" +source = "git+https://github.com/scroll-tech/poseidon-circuit.git?branch=main#b978cee00aae1e0a1e79e0d74c4683b137f5ea2d" dependencies = [ "bitvec", "halo2curves", @@ -2926,7 +2945,7 @@ dependencies = [ [[package]] name = "poseidon-circuit" version = "0.1.0" -source = "git+https://github.com/scroll-tech/poseidon-circuit.git?branch=main#d52fa404e8f03b5c3f85c090ccb8b08c112e2f4d" +source = "git+https://github.com/scroll-tech/poseidon-circuit.git?branch=main#b978cee00aae1e0a1e79e0d74c4683b137f5ea2d" dependencies = [ "ff", "halo2_proofs", @@ -2944,13 +2963,12 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de" [[package]] -name = "prettyplease" -version = "0.2.20" +name = "primeorder" +version = "0.13.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f12335488a2f3b0a83b14edad48dca9879ce89b2edd10e80237e4e852dd645e" +checksum = "353e1ca18966c16d9deb1c69278edbc5f194139612772bd9537af60ac231e1e6" dependencies = [ - "proc-macro2", - "syn 2.0.66", + "elliptic-curve", ] [[package]] @@ -3038,8 +3056,8 @@ dependencies = [ [[package]] name = "prover" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "aggregator", "anyhow", @@ -3060,13 +3078,14 @@ dependencies = [ "num-bigint", "rand", "rand_xorshift", + "revm 17.1.0", "serde", "serde_derive", "serde_json", "serde_stacker", "sha2", - "snark-verifier 0.1.0 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", - "snark-verifier-sdk 0.0.1 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", + "snark-verifier", + "snark-verifier-sdk", "zkevm-circuits", ] @@ -3255,56 +3274,63 @@ dependencies = [ "primitive-types", "revm_precompiles", "rlp", - "sha3 0.10.6", + "sha3 0.10.8", ] [[package]] name = "revm" -version = "3.5.0" +version = "17.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68f4ca8ae0345104523b4af1a8a7ea97cfa1865cdb7a7c25d23c1a18d9b48598" +checksum = "055bee6a81aaeee8c2389ae31f0d4de87f44df24f4444a1116f9755fd87a76ad" dependencies = [ "auto_impl", + "cfg-if 1.0.0", + "dyn-clone", "revm-interpreter", - "revm-precompile 2.2.0", + "revm-precompile 14.0.0", + "serde", + "serde_json", ] [[package]] name = "revm-interpreter" -version = "1.3.0" +version = "13.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f959cafdf64a7f89b014fa73dc2325001cf654b3d9400260b212d19a2ebe3da0" +checksum = "fac2034454f8bc69dc7d3c94cdb1b57559e27f5ef0518771f1787de543d7d6a1" dependencies = [ - "revm-primitives 1.3.0", + "revm-primitives 13.0.0", + "serde", ] [[package]] name = "revm-precompile" -version = "2.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4d360a88223d85709d2e95d4609eb1e19c649c47e28954bfabae5e92bb37e83e" +version = "9.2.0" +source = "git+https://github.com/scroll-tech/revm?branch=scroll-evm-executor/v40#5e215742c4d9d771f73d74fcba39628b1a2e3452" dependencies = [ - "c-kzg 0.1.1", + "aurora-engine-modexp", + "c-kzg", + "cfg-if 1.0.0", "k256", - "num", "once_cell", - "revm-primitives 1.3.0", + "revm-primitives 7.1.0", "ripemd", - "secp256k1 0.27.0", + "secp256k1 0.29.0", "sha2", "substrate-bn", ] [[package]] name = "revm-precompile" -version = "7.0.0" -source = "git+https://github.com/scroll-tech/revm?branch=scroll-evm-executor/v36#36c304d9e9ba4e4b2d5468d91a6bd27210133b6a" +version = "14.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a88c8c7c5f9b988a9e65fc0990c6ce859cdb74114db705bd118a96d22d08027" dependencies = [ "aurora-engine-modexp", - "c-kzg 1.0.2", + "c-kzg", + "cfg-if 1.0.0", "k256", "once_cell", - "revm-primitives 4.0.0", + "revm-primitives 13.0.0", "ripemd", "secp256k1 0.29.0", "sha2", @@ -3313,39 +3339,41 @@ dependencies = [ [[package]] name = "revm-primitives" -version = "1.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "51187b852d9e458816a2e19c81f1dd6c924077e1a8fccd16e4f044f865f299d7" +version = "7.1.0" +source = "git+https://github.com/scroll-tech/revm?branch=scroll-evm-executor/v40#5e215742c4d9d771f73d74fcba39628b1a2e3452" dependencies = [ - "alloy-primitives 0.4.2", - "alloy-rlp", + "alloy-eips", + "alloy-primitives 0.7.7", "auto_impl", "bitflags 2.6.0", "bitvec", + "c-kzg", + "cfg-if 1.0.0", + "derive_more 0.99.17", + "dyn-clone", "enumn", "hashbrown 0.14.3", "hex", + "once_cell", + "serde", ] [[package]] name = "revm-primitives" -version = "4.0.0" -source = "git+https://github.com/scroll-tech/revm?branch=scroll-evm-executor/v36#36c304d9e9ba4e4b2d5468d91a6bd27210133b6a" +version = "13.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0d11fa1e195b0bebaf3fb18596f314a13ba3a4cb1fdd16d3465934d812fd921e" dependencies = [ - "alloy-primitives 0.7.7", + "alloy-eip2930", + "alloy-eip7702", + "alloy-primitives 0.8.10", "auto_impl", "bitflags 2.6.0", "bitvec", - "c-kzg 1.0.2", "cfg-if 1.0.0", - "derive_more", "dyn-clone", "enumn", - "halo2curves", - "hashbrown 0.14.3", "hex", - "once_cell", - "poseidon-base", "serde", ] @@ -3363,7 +3391,7 @@ dependencies = [ "ripemd", "secp256k1 0.24.3", "sha2", - "sha3 0.10.6", + "sha3 0.10.8", "substrate-bn", ] @@ -3465,6 +3493,12 @@ version = "1.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2" +[[package]] +name = "rustc-hash" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "583034fd73374156e66797ed8e5b0d5690409c9226b22d87cb7f19821c05d152" + [[package]] name = "rustc-hex" version = "2.1.0" @@ -3597,7 +3631,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0cfdffd972d76b22f3d7f81c8be34b2296afd3a25e0a547bd9abe340a4dbbe97" dependencies = [ "cfg-if 1.0.0", - "derive_more", + "derive_more 0.99.17", "parity-scale-codec", "scale-info-derive", ] @@ -3671,15 +3705,6 @@ dependencies = [ "secp256k1-sys 0.6.1", ] -[[package]] -name = "secp256k1" -version = "0.27.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25996b82292a7a57ed3508f052cfff8640d38d32018784acd714758b43da9c8f" -dependencies = [ - "secp256k1-sys 0.8.1", -] - [[package]] name = "secp256k1" version = "0.29.0" @@ -3699,15 +3724,6 @@ dependencies = [ "cc", ] -[[package]] -name = "secp256k1-sys" -version = "0.8.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "70a129b9e9efbfb223753b9163c4ab3b13cff7fd9c7f010fbac25ab4099fa07e" -dependencies = [ - "cc", -] - [[package]] name = "secp256k1-sys" version = "0.10.0" @@ -3788,6 +3804,7 @@ version = "1.0.95" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d721eca97ac802aa7777b701877c8004d950fc142651367300d21c1cc0194744" dependencies = [ + "indexmap 1.9.3", "itoa", "ryu", "serde", @@ -3873,9 +3890,9 @@ dependencies = [ [[package]] name = "sha3" -version = "0.10.6" +version = "0.10.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bdf0c33fae925bdc080598b84bc15c55e7b9a4a43b3c704da051f977469691c9" +checksum = "75872d278a8f37ef87fa0ddbda7802605cb18344497949862c0d4dcb291eba60" dependencies = [ "digest 0.10.7", "keccak", @@ -3891,12 +3908,6 @@ dependencies = [ "cfg-if 1.0.0", ] -[[package]] -name = "shlex" -version = "1.3.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0fda2ff0d084019ba4d7c6f371c95d8fd75ce3524c3cb8fb653a3023f6323e64" - [[package]] name = "signal-hook-registry" version = "1.4.1" @@ -3934,7 +3945,7 @@ checksum = "a507befe795404456341dfab10cef66ead4c041f62b8b11bbb92bffe5d0953e0" [[package]] name = "snark-verifier" version = "0.1.0" -source = "git+https://github.com/scroll-tech/snark-verifier?branch=develop#58c46b74c73156b9e09dc27617369d2acfb4461b" +source = "git+https://github.com/scroll-tech/snark-verifier?branch=develop#572ef69d1595fca82213d3b05e859eaf355a5fa1" dependencies = [ "bytes", "ethereum-types", @@ -3949,65 +3960,21 @@ dependencies = [ "rand", "revm 2.3.1", "rlp", - "rustc-hash", + "rustc-hash 1.1.0", "serde", - "sha3 0.10.6", -] - -[[package]] -name = "snark-verifier" -version = "0.1.0" -source = "git+https://github.com/scroll-tech/snark-verifier?branch=v0.1#58c46b74c73156b9e09dc27617369d2acfb4461b" -dependencies = [ - "bytes", - "ethereum-types", - "halo2-base", - "halo2-ecc", - "hex", - "itertools 0.12.1", - "num-bigint", - "num-integer", - "num-traits", - "poseidon", - "rand", - "revm 2.3.1", - "rlp", - "rustc-hash", - "serde", - "sha3 0.10.6", -] - -[[package]] -name = "snark-verifier-sdk" -version = "0.0.1" -source = "git+https://github.com/scroll-tech/snark-verifier?branch=develop#58c46b74c73156b9e09dc27617369d2acfb4461b" -dependencies = [ - "bincode", - "ethereum-types", - "ff", - "halo2-base", - "hex", - "itertools 0.12.1", - "log", - "num-bigint", - "num-integer", - "num-traits", - "rand", - "rand_chacha", - "serde", - "serde_json", - "snark-verifier 0.1.0 (git+https://github.com/scroll-tech/snark-verifier?branch=develop)", + "sha3 0.10.8", ] [[package]] name = "snark-verifier-sdk" version = "0.0.1" -source = "git+https://github.com/scroll-tech/snark-verifier?branch=v0.1#58c46b74c73156b9e09dc27617369d2acfb4461b" +source = "git+https://github.com/scroll-tech/snark-verifier?branch=develop#572ef69d1595fca82213d3b05e859eaf355a5fa1" dependencies = [ "bincode", "ethereum-types", "ff", "halo2-base", + "halo2_proofs", "hex", "itertools 0.12.1", "log", @@ -4018,7 +3985,7 @@ dependencies = [ "rand_chacha", "serde", "serde_json", - "snark-verifier 0.1.0 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", + "snark-verifier", ] [[package]] @@ -4354,7 +4321,7 @@ version = "0.19.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "239410c8609e8125456927e6707163a3b1fdb40561e4b803bc041f466ccfdc13" dependencies = [ - "indexmap", + "indexmap 1.9.3", "toml_datetime", "winnow", ] @@ -4675,18 +4642,6 @@ version = "0.25.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "14247bb57be4f377dfb94c72830b8ce8fc6beac03cf4bf7b9732eadd414123fc" -[[package]] -name = "which" -version = "4.4.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "87ba24419a2078cd2b0f2ede2691b6c66d8e47836da3b6db8265ebad47afbfc7" -dependencies = [ - "either", - "home", - "once_cell", - "rustix 0.38.13", -] - [[package]] name = "winapi" version = "0.3.9" @@ -4745,15 +4700,6 @@ dependencies = [ "windows-targets 0.48.0", ] -[[package]] -name = "windows-sys" -version = "0.52.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" -dependencies = [ - "windows-targets 0.52.5", -] - [[package]] name = "windows-targets" version = "0.42.2" @@ -4784,22 +4730,6 @@ dependencies = [ "windows_x86_64_msvc 0.48.0", ] -[[package]] -name = "windows-targets" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6f0713a46559409d202e70e28227288446bf7841d3211583a4b53e3f6d96e7eb" -dependencies = [ - "windows_aarch64_gnullvm 0.52.5", - "windows_aarch64_msvc 0.52.5", - "windows_i686_gnu 0.52.5", - "windows_i686_gnullvm", - "windows_i686_msvc 0.52.5", - "windows_x86_64_gnu 0.52.5", - "windows_x86_64_gnullvm 0.52.5", - "windows_x86_64_msvc 0.52.5", -] - [[package]] name = "windows_aarch64_gnullvm" version = "0.42.2" @@ -4812,12 +4742,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7088eed71e8b8dda258ecc8bac5fb1153c5cffaf2578fc8ff5d61e23578d3263" - [[package]] name = "windows_aarch64_msvc" version = "0.42.2" @@ -4830,12 +4754,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" -[[package]] -name = "windows_aarch64_msvc" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9985fd1504e250c615ca5f281c3f7a6da76213ebd5ccc9561496568a2752afb6" - [[package]] name = "windows_i686_gnu" version = "0.42.2" @@ -4848,18 +4766,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" -[[package]] -name = "windows_i686_gnu" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "88ba073cf16d5372720ec942a8ccbf61626074c6d4dd2e745299726ce8b89670" - -[[package]] -name = "windows_i686_gnullvm" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "87f4261229030a858f36b459e748ae97545d6f1ec60e5e0d6a3d32e0dc232ee9" - [[package]] name = "windows_i686_msvc" version = "0.42.2" @@ -4872,12 +4778,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" -[[package]] -name = "windows_i686_msvc" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "db3c2bf3d13d5b658be73463284eaf12830ac9a26a90c717b7f771dfe97487bf" - [[package]] name = "windows_x86_64_gnu" version = "0.42.2" @@ -4890,12 +4790,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" -[[package]] -name = "windows_x86_64_gnu" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4e4246f76bdeff09eb48875a0fd3e2af6aada79d409d33011886d3e1581517d9" - [[package]] name = "windows_x86_64_gnullvm" version = "0.42.2" @@ -4908,12 +4802,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "852298e482cd67c356ddd9570386e2862b5673c85bd5f88df9ab6802b334c596" - [[package]] name = "windows_x86_64_msvc" version = "0.42.2" @@ -4926,12 +4814,6 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" -[[package]] -name = "windows_x86_64_msvc" -version = "0.52.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bec47e5bfd1bff0eeaf6d8b485cc1074891a197ab4225d504cb7a1ab88b02bf0" - [[package]] name = "winnow" version = "0.4.1" @@ -5021,8 +4903,8 @@ dependencies = [ [[package]] name = "zkevm-circuits" -version = "0.13.0" -source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=v0.13#6ac8a73c799f0006263ce438b3c582f98d98fc25" +version = "0.14.0" +source = "git+https://github.com/scroll-tech/zkevm-circuits.git?branch=develop#72bb2a80a21b954642f02315d64292c7b8ec657f" dependencies = [ "array-init", "bus-mapping", @@ -5046,6 +4928,7 @@ dependencies = [ "mpt-zktrie", "num", "num-bigint", + "p256", "poseidon-circuit", "rand", "rand_chacha", @@ -5053,9 +4936,9 @@ dependencies = [ "rayon", "serde", "serde_json", - "sha3 0.10.6", - "snark-verifier 0.1.0 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", - "snark-verifier-sdk 0.0.1 (git+https://github.com/scroll-tech/snark-verifier?branch=v0.1)", + "sha3 0.10.8", + "snark-verifier", + "snark-verifier-sdk", "strum 0.25.0", "strum_macros 0.25.3", "subtle", diff --git a/Cargo.toml b/Cargo.toml index aca52f9b..8d1c7793 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -6,7 +6,7 @@ members = [ ] [workspace.package] -version = "0.13.0" +version = "0.14.0" edition = "2021" license = "MIT OR Apache-2.0" @@ -27,7 +27,7 @@ serde_json = "1.0" tokio = { version = "1.32", features = ["full"] } halo2_proofs = { git = "https://github.com/scroll-tech/halo2.git", branch = "v1.1" } -prover = { git = "https://github.com/scroll-tech/zkevm-circuits.git", branch = "v0.13", default-features = false, features = ["parallel_syn", "scroll"] } +prover = { git = "https://github.com/scroll-tech/zkevm-circuits.git", branch = "develop", default-features = false, features = ["parallel_syn", "scroll"] } integration = { path = "integration" } [patch.crates-io] diff --git a/bin/src/chain_prover.rs b/bin/src/chain_prover.rs index dd5a4069..4ecdeec7 100644 --- a/bin/src/chain_prover.rs +++ b/bin/src/chain_prover.rs @@ -141,7 +141,6 @@ impl ChunkBuilder { // Condition2: ccc let ccc_result = { let mut checker = CircuitCapacityChecker::new(); - checker.set_light_mode(false); checker.estimate_circuit_capacity(trace.clone()).unwrap() }; self.acc_row_usage_normalized.add(&ccc_result); @@ -320,8 +319,6 @@ async fn prove_by_batch( } } -// Make sure tx-by-tx light_mode=false row usage >= real row usage - async fn txtx_ccc(l2geth: &l2geth::Client, begin_block: i64, end_block: i64) { let (begin_block, end_block) = if begin_block == 0 && end_block == 0 { // Blocks within last 24 hours @@ -354,7 +351,6 @@ async fn txtx_ccc(l2geth: &l2geth::Client, begin_block: i64, end_block: i64) { // part2: tx by tx row usage let tx_num = tx_traces.len(); let mut checker = CircuitCapacityChecker::new(); - checker.light_mode = false; let start_time = std::time::Instant::now(); for tx in tx_traces { checker.estimate_circuit_capacity(tx).unwrap(); diff --git a/integration/Cargo.toml b/integration/Cargo.toml index 50b80afa..c969975f 100644 --- a/integration/Cargo.toml +++ b/integration/Cargo.toml @@ -17,7 +17,6 @@ serde_json.workspace = true serde_derive.workspace = true tokio.workspace = true -revm = { version = "3.5.0", default-features = false, features = ["std"] } snark-verifier = { git = "https://github.com/scroll-tech/snark-verifier", branch = "develop" } snark-verifier-sdk = { git = "https://github.com/scroll-tech/snark-verifier", branch = "develop", default-features = false, features = ["loader_halo2", "loader_evm", "halo2-pse"] } diff --git a/integration/src/capacity_checker.rs b/integration/src/capacity_checker.rs index c2f9e56e..2b37b81c 100644 --- a/integration/src/capacity_checker.rs +++ b/integration/src/capacity_checker.rs @@ -13,7 +13,6 @@ use std::time::Duration; pub enum CCCMode { Optimal, Siger, - FollowerLight, FollowerFull, } @@ -39,7 +38,6 @@ pub fn run_circuit_capacity_checker( match mode { CCCMode::Optimal => ccc_by_chunk(batch_id, chunk_id, block_traces), CCCMode::Siger => ccc_as_signer(chunk_id, block_traces), - CCCMode::FollowerLight => ccc_as_follower_light(chunk_id, block_traces), CCCMode::FollowerFull => ccc_as_follower_full(chunk_id, block_traces), }, ) @@ -155,7 +153,6 @@ fn get_ccc_result_of_chunk( blocks: &[BlockTrace], by_block: bool, // by block instead of by tx norm: bool, - light_mode: bool, tag: &str, ) -> (RowUsage, Duration) { log::info!( @@ -167,11 +164,6 @@ fn get_ccc_result_of_chunk( ); let mut checker = CircuitCapacityChecker::new(); - checker.light_mode = light_mode; - - if !checker.light_mode && !by_block { - unimplemented!("!checker.light_mode && !by_block") - } let start_time = std::time::Instant::now(); @@ -221,29 +213,14 @@ fn get_ccc_result_of_chunk( } #[allow(dead_code)] -fn get_ccc_result_by_whole_block( - chunk_id: u64, - light_mode: bool, - blocks: &[BlockTrace], -) -> RowUsage { - log::info!("estimating circuit rows whole block, light_mode {light_mode}"); +fn get_ccc_result_by_whole_block(chunk_id: u64, blocks: &[BlockTrace]) -> RowUsage { let mut checker = CircuitCapacityChecker::new(); - checker.light_mode = light_mode; for block in blocks { checker.estimate_circuit_capacity(block.clone()).unwrap(); } let ccc_result = checker.get_acc_row_usage(false); - pretty_print_row_usage( - &ccc_result, - blocks, - chunk_id, - if light_mode { - "block-light" - } else { - "block-full" - }, - ); + pretty_print_row_usage(&ccc_result, blocks, chunk_id, "block-full"); ccc_result } @@ -298,14 +275,9 @@ pub fn ccc_by_chunk( } pub fn ccc_as_signer(chunk_id: u64, blocks: &[BlockTrace]) -> (RowUsage, Duration) { - get_ccc_result_of_chunk(chunk_id, blocks, false, false, true, "chunk-signer") -} - -/// current stats inside db -pub fn ccc_as_follower_light(chunk_id: u64, blocks: &[BlockTrace]) -> (RowUsage, Duration) { - get_ccc_result_of_chunk(chunk_id, blocks, true, false, true, "chunk-f-l") + get_ccc_result_of_chunk(chunk_id, blocks, false, false, "chunk-signer") } pub fn ccc_as_follower_full(chunk_id: u64, blocks: &[BlockTrace]) -> (RowUsage, Duration) { - get_ccc_result_of_chunk(chunk_id, blocks, true, false, false, "chunk-f-f") + get_ccc_result_of_chunk(chunk_id, blocks, true, false, "chunk-f-f") } diff --git a/integration/src/evm.rs b/integration/src/evm.rs deleted file mode 100644 index e2c5bb2c..00000000 --- a/integration/src/evm.rs +++ /dev/null @@ -1,59 +0,0 @@ -use revm::{ - primitives::{CreateScheme, ExecutionResult, Output, TransactTo, TxEnv}, - InMemoryDB, EVM, -}; - -/// Deploy contract and then call with calldata. -/// Returns gas_used of call to deployed contract if both transactions are successful. -pub fn deploy_and_call(deployment_code: Vec, calldata: Vec) -> Result { - let mut evm = EVM { - env: Default::default(), - db: Some(InMemoryDB::default()), - }; - - evm.env.tx = TxEnv { - gas_limit: u64::MAX, - transact_to: TransactTo::Create(CreateScheme::Create), - data: deployment_code.into(), - ..Default::default() - }; - - let result = evm.transact_commit().unwrap(); - let contract = match result { - ExecutionResult::Success { - output: Output::Create(_, Some(contract)), - .. - } => contract, - ExecutionResult::Revert { gas_used, output } => { - return Err(format!( - "Contract deployment transaction reverts with gas_used {gas_used} and output {:#x}", - output - )) - } - ExecutionResult::Halt { reason, gas_used } => return Err(format!( - "Contract deployment transaction halts unexpectedly with gas_used {gas_used} and reason {:?}", - reason - )), - _ => unreachable!(), - }; - - evm.env.tx = TxEnv { - gas_limit: u64::MAX, - transact_to: TransactTo::Call(contract), - data: calldata.into(), - ..Default::default() - }; - - let result = evm.transact_commit().unwrap(); - match result { - ExecutionResult::Success { gas_used, .. } => Ok(gas_used), - ExecutionResult::Revert { gas_used, output } => Err(format!( - "Contract call transaction reverts with gas_used {gas_used} and output {:#x}", - output - )), - ExecutionResult::Halt { reason, gas_used } => Err(format!( - "Contract call transaction halts unexpectedly with gas_used {gas_used} and reason {:?}", - reason - )), - } -} diff --git a/integration/src/lib.rs b/integration/src/lib.rs index 8501cf68..34e4e2ce 100644 --- a/integration/src/lib.rs +++ b/integration/src/lib.rs @@ -1,5 +1,4 @@ pub mod capacity_checker; -pub mod evm; pub mod l2geth; pub mod prove; pub mod test_util; diff --git a/integration/src/verifier.rs b/integration/src/verifier.rs index b365f4af..18a01244 100644 --- a/integration/src/verifier.rs +++ b/integration/src/verifier.rs @@ -1,6 +1,5 @@ use halo2_proofs::{halo2curves::bn256::Bn256, poly::kzg::commitment::ParamsKZG}; use prover::{common::Verifier, config, consts, io::force_to_read, CompressionCircuit}; -use snark_verifier_sdk::verify_evm_calldata; use std::{collections::BTreeMap, env}; type SnarkVerifier<'a> = Verifier<'a, CompressionCircuit>; @@ -57,6 +56,8 @@ impl EVMVerifier { } pub fn verify_evm_proof(&self, call_data: Vec) -> bool { - verify_evm_calldata(self.0.clone(), call_data) + let res = prover::deploy_and_call(self.0.clone(), call_data); + log::debug!("verify_evm_proof result {:?}", res); + res.is_ok() } } diff --git a/integration/tests/e2e_tests.rs b/integration/tests/e2e_tests.rs index 148e39ac..897519ad 100644 --- a/integration/tests/e2e_tests.rs +++ b/integration/tests/e2e_tests.rs @@ -105,9 +105,9 @@ fn test_batch_bundle_verify() -> anyhow::Result<()> { &AGG_DEGREES.iter().copied().collect_vec(), ); let batch_tasks_paths = read_dir("./tests/test_data/batch_tasks")?; - let batch_tasks = batch_tasks_paths + let batch_tasks: Vec = batch_tasks_paths .iter() - .map(|path| from_json_file::(&path.as_path().to_string_lossy())) + .map(from_json_file::<_, BatchProvingTask>) .collect::>>()?; log::info!("num batch tasks = {}", batch_tasks.len()); diff --git a/integration/tests/unit_tests.rs b/integration/tests/unit_tests.rs index df234683..ae06c186 100644 --- a/integration/tests/unit_tests.rs +++ b/integration/tests/unit_tests.rs @@ -46,7 +46,7 @@ fn test_evm_verifier() { log::info!("svm use {}", version); let bytecode = compile_yul(&String::from_utf8(yul.clone()).unwrap()); log::info!("bytecode len {}", bytecode.len()); - match integration::evm::deploy_and_call(bytecode, proof.clone()) { + match prover::deploy_and_call(bytecode, proof.clone()) { Ok(gas) => log::info!("gas cost {gas}"), Err(e) => { panic!("test failed {e:#?}"); @@ -57,7 +57,7 @@ fn test_evm_verifier() { log::info!("check released bin"); let bytecode = read_all(&format!("../{version}/evm_verifier.bin")); log::info!("bytecode len {}", bytecode.len()); - match integration::evm::deploy_and_call(bytecode, proof.clone()) { + match prover::deploy_and_call(bytecode, proof.clone()) { Ok(gas) => log::info!("gas cost {gas}"), Err(e) => { panic!("test failed {e:#?}"); @@ -65,29 +65,32 @@ fn test_evm_verifier() { } } -// suppose a "proof.json" has been provided under the 'release' -// directory or the test would fail #[ignore] #[test] fn test_evm_verifier_for_dumped_proof() { - use prover::{io::from_json_file, proof::BundleProof}; + use prover::io::from_json_file; init_env_and_log("test_evm_verifer"); log::info!("cwd {:?}", std::env::current_dir()); - let version = "release-v0.12.0-rc.2"; - let proof: BundleProof = from_json_file(&format!("../{version}/proof.json")).unwrap(); + let search_pattern = "outputs/e2e_tests_*/full_proof_bundle_recursion.json"; - let proof_dump = proof.clone().proof_to_verify(); - log::info!("pi dump {:#?}", proof_dump.instances()); + let paths = glob::glob(search_pattern).expect("Failed to read glob pattern"); + + let mut path = paths.last().unwrap().unwrap(); + log::info!("proof path {}", path.display()); + let proof: prover::BundleProof = from_json_file(&path).unwrap(); let proof = proof.calldata(); log::info!("calldata len {}", proof.len()); log::info!("check released bin"); - let bytecode = read_all(&format!("../{version}/evm_verifier.bin")); + path.pop(); + path.push("evm_verifier.bin"); + let bytecode = read_all(path); log::info!("bytecode len {}", bytecode.len()); - match integration::evm::deploy_and_call(bytecode, proof.clone()) { + + match prover::deploy_and_call(bytecode, proof.clone()) { Ok(gas) => log::info!("gas cost {gas}"), Err(e) => { panic!("test failed {e:#?}");