Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: scroll execution strategy #63

Merged
merged 37 commits into from
Dec 10, 2024
Merged
Show file tree
Hide file tree
Changes from 21 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
16d56c8
add l1_fee field to `Receipt`
greged93 Nov 21, 2024
8ac2d23
scroll consensus
greged93 Nov 28, 2024
54c1fd2
feat: scroll execution strategy
greged93 Nov 28, 2024
5183d5a
feat: expose `verify_receipts` from reth-ethereum-consensus
greged93 Nov 28, 2024
36adba4
feat: add `reth-scroll-evm` crate to avoid cyclic dep
greged93 Nov 28, 2024
38569b3
improve curie fork application + test
greged93 Nov 29, 2024
f431ef1
integrate l1 fee
greged93 Nov 29, 2024
86945bd
add `ScrollEvmConfig`
greged93 Nov 30, 2024
63c1986
add tests for `ScrollEvmConfig`
greged93 Nov 30, 2024
f828ab4
add tests for `ScrollExecutionStrategy`
greged93 Nov 30, 2024
9d1c225
add l1 message test for `ScrollExecutionStrategy`
greged93 Dec 1, 2024
5a100be
add legacy tx execution test for `ScrollExecutionStrategy`
greged93 Dec 1, 2024
19a0b73
Merge branch 'scroll' into feat/execution-strategy
greged93 Dec 2, 2024
ed2f736
use revm scroll fork
greged93 Dec 2, 2024
dc30358
introduce `ScrollExecutionStrategyFactory`
greged93 Dec 2, 2024
5c9ec2d
feat: patch revm crate to scroll fork
greged93 Dec 4, 2024
f6293f4
fix: lints
greged93 Dec 4, 2024
d4374f1
Merge branch 'scroll' into feat/execution-strategy
greged93 Dec 4, 2024
178979e
fix: deny
greged93 Dec 4, 2024
e74ca1d
Merge branch 'scroll' into feat/execution-strategy
greged93 Dec 7, 2024
da4631e
answer comments
greged93 Dec 7, 2024
5053bf9
Merge branch 'scroll' into feat/execution-strategy
greged93 Dec 9, 2024
66e61a1
fill `TxEnv.rlp_bytes` only for !is_l1_message
greged93 Dec 9, 2024
1e6724e
lints
greged93 Dec 9, 2024
8b9487b
switch revm to scroll default branch
greged93 Dec 9, 2024
e680a9a
fix: deny
greged93 Dec 9, 2024
1ee6050
fix: remove alloy-sol-types patch
greged93 Dec 9, 2024
d41b561
Merge branch 'scroll' into feat/execution-strategy
greged93 Dec 9, 2024
ca0580f
feat: propagate scroll chain spec in execution
greged93 Dec 9, 2024
1ce370c
fix: scroll ci
greged93 Dec 9, 2024
ca0275b
chore: bump `trust-dns-resolver` to 0.25 alpha4 to fix deny
greged93 Dec 9, 2024
a3204e2
fix: propagate serde feature
greged93 Dec 9, 2024
c3cdac5
fix: docs
greged93 Dec 9, 2024
a411b86
Merge branch 'scroll' into feat/execution-strategy
greged93 Dec 9, 2024
2d78cc4
answer comments
greged93 Dec 10, 2024
108c355
lint
greged93 Dec 10, 2024
05f2a85
answer comments
greged93 Dec 10, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/lint.yml
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@ jobs:
cargo udeps --workspace --lib --examples --tests --benches --all-features --locked \
--exclude "reth-optimism-*" --exclude op-reth --exclude "example-*" --exclude reth \
--exclude reth-e2e-test-utils --exclude reth-ethereum-payload-builder --exclude reth-exex-test-utils \
--exclude reth-node-ethereum
--exclude reth-node-ethereum --exclude reth-scroll-evm

book:
name: book
Expand Down
79 changes: 65 additions & 14 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

12 changes: 12 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,8 @@ members = [
"crates/rpc/rpc-testing-util/",
"crates/rpc/rpc-types-compat/",
"crates/rpc/rpc/",
"crates/scroll/consensus",
"crates/scroll/evm",
"crates/scroll/execution",
"crates/scroll/primitives",
"crates/scroll/revm",
Expand Down Expand Up @@ -407,6 +409,8 @@ reth-rpc-eth-types = { path = "crates/rpc/rpc-eth-types", default-features = fal
reth-rpc-layer = { path = "crates/rpc/rpc-layer" }
reth-rpc-server-types = { path = "crates/rpc/rpc-server-types" }
reth-rpc-types-compat = { path = "crates/rpc/rpc-types-compat" }
reth-scroll-consensus = { path = "crates/scroll/consensus" }
reth-scroll-evm = { path = "crates/scroll/evm" }
reth-scroll-execution = { path = "crates/scroll/execution" }
reth-scroll-primitives = { path = "crates/scroll/primitives" }
reth-scroll-revm = { path = "crates/scroll/revm" }
Expand Down Expand Up @@ -656,3 +660,11 @@ tracy-client = "0.17.3"
#op-alloy-network = { git = "https://github.com/alloy-rs/op-alloy", rev = "6a042e7681b1" }
#op-alloy-rpc-types = { git = "https://github.com/alloy-rs/op-alloy", rev = "6a042e7681b1" }
#op-alloy-rpc-types-engine = { git = "https://github.com/alloy-rs/op-alloy", rev = "6a042e7681b1" }

[patch.crates-io]
revm = { git = "https://github.com/scroll-tech/revm.git", branch = "scroll-evm-executor/reth/v50" }
revm-primitives = { git = "https://github.com/scroll-tech/revm.git", branch = "scroll-evm-executor/reth/v50" }

ff = { git = "https://github.com/scroll-tech/ff", branch = "feat/sp1" }

alloy-eip2930 = { git = "https://github.com/scroll-tech/alloy-eips", branch = "v0.3.2" }
frisitano marked this conversation as resolved.
Show resolved Hide resolved
4 changes: 4 additions & 0 deletions crates/chainspec/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -63,3 +63,7 @@ test-utils = [
"reth-primitives-traits/test-utils",
"reth-trie-common/test-utils"
]
scroll = [
"reth-trie-common/scroll",
"reth-primitives-traits/scroll"
]
2 changes: 2 additions & 0 deletions crates/engine/tree/benches/channel_perf.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
//! Benchmark comparing `std::sync::mpsc` and `crossbeam` channels for `StateRootTask`.

#![allow(missing_docs)]
#![allow(clippy::needless_update)]

use criterion::{criterion_group, criterion_main, BatchSize, BenchmarkId, Criterion};
use revm_primitives::{
Expand All @@ -23,6 +24,7 @@ fn create_bench_state(num_accounts: usize) -> EvmState {
nonce: 10,
code_hash: B256::random(),
code: Default::default(),
..Default::default()
},
storage,
status: AccountStatus::Loaded,
Expand Down
2 changes: 2 additions & 0 deletions crates/engine/tree/src/tree/root.rs
Original file line number Diff line number Diff line change
Expand Up @@ -542,6 +542,7 @@ fn update_sparse_trie(

#[cfg(test)]
mod tests {
#![allow(clippy::needless_update)]
use super::*;
use reth_primitives::{Account as RethAccount, StorageEntry};
use reth_provider::{
Expand Down Expand Up @@ -600,6 +601,7 @@ mod tests {
nonce: rng.gen::<u64>(),
code_hash: KECCAK_EMPTY,
code: Some(Default::default()),
..Default::default()
},
storage,
status: AccountStatus::Touched,
Expand Down
2 changes: 1 addition & 1 deletion crates/ethereum/consensus/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ use std::{fmt::Debug, sync::Arc, time::SystemTime};
pub const GAS_LIMIT_BOUND_DIVISOR: u64 = 1024;

mod validation;
pub use validation::validate_block_post_execution;
pub use validation::{validate_block_post_execution, verify_receipts};

/// Ethereum beacon consensus
///
Expand Down
2 changes: 1 addition & 1 deletion crates/ethereum/consensus/src/validation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ pub fn validate_block_post_execution<ChainSpec: EthereumHardforks>(

/// Calculate the receipts root, and compare it against against the expected receipts root and logs
/// bloom.
fn verify_receipts(
pub fn verify_receipts(
expected_receipts_root: B256,
expected_logs_bloom: Bloom,
receipts: &[Receipt],
Expand Down
2 changes: 2 additions & 0 deletions crates/evm/src/metrics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,7 @@ impl ExecutorMetrics {

#[cfg(test)]
mod tests {
#![allow(clippy::needless_update)]
use super::*;
use alloy_eips::eip7685::Requests;
use metrics_util::debugging::{DebugValue, DebuggingRecorder, Snapshotter};
Expand Down Expand Up @@ -261,6 +262,7 @@ mod tests {
nonce: 10,
code_hash: B256::random(),
code: Default::default(),
..Default::default()
},
storage,
status: AccountStatus::Loaded,
Expand Down
8 changes: 8 additions & 0 deletions crates/primitives-traits/src/account.rs
Original file line number Diff line number Diff line change
Expand Up @@ -246,7 +246,15 @@ impl From<Account> for revm_primitives::shared::AccountInfo {
Self {
balance: reth_acc.balance,
nonce: reth_acc.nonce,
code_size: reth_acc
.account_extension
.map(|acc| acc.code_size as usize)
.unwrap_or_default(),
code_hash: reth_acc.bytecode_hash.unwrap_or(KECCAK_EMPTY),
poseidon_code_hash: reth_acc
.account_extension
.and_then(|acc| acc.poseidon_code_hash)
.unwrap_or(reth_scroll_primitives::POSEIDON_EMPTY),
code: None,
}
}
Expand Down
2 changes: 1 addition & 1 deletion crates/primitives/src/transaction/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -425,7 +425,7 @@ impl Transaction {
/// Returns true if the transaction is a Scroll L1 messaging transaction.
#[cfg(all(feature = "scroll", not(feature = "optimism")))]
#[inline]
pub fn is_l1_message(&self) -> bool {
pub const fn is_l1_message(&self) -> bool {
matches!(self, Self::L1Message(_))
}

Expand Down
2 changes: 1 addition & 1 deletion crates/revm/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -68,5 +68,5 @@ serde = [
scroll = [
"reth-scroll-primitives",
"reth-primitives-traits/scroll",
"reth-trie/scroll"
"reth-trie?/scroll"
]
22 changes: 22 additions & 0 deletions crates/scroll/consensus/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
[package]
name = "reth-scroll-consensus"
version.workspace = true
edition.workspace = true
rust-version.workspace = true
license.workspace = true
homepage.workspace = true
repository.workspace = true
exclude.workspace = true

[lints]
workspace = true

[dependencies]
# revm
revm.workspace = true

[dev-dependencies]
eyre.workspace = true

[features]
scroll = ["revm/scroll"]
Loading
Loading