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

Upgrade revm in Optimism execution #76

Merged
merged 8 commits into from
Jan 22, 2024
Merged

Conversation

Wollac
Copy link
Contributor

@Wollac Wollac commented Jan 17, 2024

This PR rebases #75 on feat/revm-optimism that already requires a revm version more recent than the latest release.

This PR is blocked by:

@Wollac Wollac changed the title Upgrade revm Upgrade revm in Optimism execution Jan 17, 2024
@Wollac Wollac mentioned this pull request Jan 17, 2024
@@ -101,6 +102,7 @@ impl TxExecStrategy<OptimismTxEssence> for OpTxExecStrategy {
blk_env.gas_limit = block_builder.input.gas_limit;
})
.with_db(block_builder.db.take().unwrap())
.append_handler_register(optimism::optimism_handle_register)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So, in the newest revm, we must register handler ourself?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's a new for other chains too.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So, in the newest revm, we must register handler ourself?

I have no idea, and have asked the revm developers the same question. My current guess is that (at least for OP) this should happen automatically when the feature is enabled.
However, if support for other chains is developed outside the revm repo, this is the new way to register them.

@Wollac
Copy link
Contributor Author

Wollac commented Jan 18, 2024

The PRs bluealloy/revm#988 and bluealloy/revm#989 should fix the mentioned OP issues.

@dyxushuai
Copy link
Contributor

dyxushuai commented Jan 22, 2024

The PRs bluealloy/revm#988 and bluealloy/revm#989 should fix the mentioned OP issues.

I discovered that the two issues were merged. Then, I updated to the latest commit on my local machine and tested CI using act locally. Everything passed successfully.

$ act -j "test"
 test evm::path_2576_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2577_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2578_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2579_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2580_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2581_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2582_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2583_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2586_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2584_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2585_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2588_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2587_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2589_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2590_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2591_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2592_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2594_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2593_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2597_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2595_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2596_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2598_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2599_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2601_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2600_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2602_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2603_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2605_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2604_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge2_ecmu ... ok
| test evm::path_2471_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge_pairi ... ok
| test evm::path_1877_testdata_BlockchainTests_GeneralStateTests_stStaticCall_static_C ... ok
| test evm::path_2475_testdata_BlockchainTests_GeneralStateTests_stZeroKnowledge_point ... ok
| test evm::path_1853_testdata_BlockchainTests_GeneralStateTests_stStackTests_underflo ... ok
| test evm::path_0060_testdata_BlockchainTests_GeneralStateTests_VMTests_vmPerformance ... ok
| 
| test result: ok. 2605 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 43.35s
| 
|      Running tests/executor.rs (target/debug/deps/executor-efc11e943c2104bd)
| 
| running 3 tests
| test executor::path_2_testdata_BlockchainTests_GeneralStateTests_stDelegatecallTestHom ... ok
| test executor::path_1_testdata_BlockchainTests_GeneralStateTests_stCallCreateCallCodeT ... ok
| test executor::path_3_testdata_BlockchainTests_GeneralStateTests_stStaticCall_static_C ... ok
| 
| test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 4.89s
| 
[CI/test]   ✅  Success - Main cargo test --workspace --all-targets --all-features

@Wollac Wollac marked this pull request as ready for review January 22, 2024 19:23
@Wollac Wollac merged commit 3995cf1 into feat/revm-optimism Jan 22, 2024
4 checks passed
@Wollac Wollac deleted the feat/update-revm branch January 22, 2024 19:34
Wollac added a commit that referenced this pull request Jan 22, 2024
* do not default source_hash and mint

* use revm optimism execution

* update testdata

* add optimism tests

* upgrade revm to latest commit

* upgrade revm with latest op changes

* Upgrade `revm` in Optimism execution (#76)

* Update dependencies versions

* fix revm commit

* use correct tags

* use EVM in comments

* update copyright

* register optimism revm handle

* update revm

* update k256

---------

Co-authored-by: john xu <dyxushuai@gmail.com>

---------

Co-authored-by: john xu <dyxushuai@gmail.com>
@dyxushuai
Copy link
Contributor

fixes #52

CeciliaZ030 referenced this pull request in CeciliaZ030/zeth Feb 5, 2024
* do not default source_hash and mint

* use revm optimism execution

* update testdata

* add optimism tests

* upgrade revm to latest commit

* upgrade revm with latest op changes

* Upgrade `revm` in Optimism execution (taikoxyz#76)

* Update dependencies versions

* fix revm commit

* use correct tags

* use EVM in comments

* update copyright

* register optimism revm handle

* update revm

* update k256

---------

Co-authored-by: john xu <dyxushuai@gmail.com>

---------

Co-authored-by: john xu <dyxushuai@gmail.com>
CeciliaZ030 referenced this pull request in CeciliaZ030/zeth Feb 12, 2024
commit 0aa4be1
Author: ceciliaz030 <zhangyixin319@gmail.com>
Date:   Mon Feb 12 18:42:01 2024 +0800

    feature taiko compile

commit f3b6a0f
Author: ceciliaz030 <zhangyixin319@gmail.com>
Date:   Mon Feb 12 01:31:59 2024 +0800

    TaikoProvider, TaikoSystemInfo, preflight

commit 1e9ffe2
Author: ceciliaz030 <zhangyixin319@gmail.com>
Date:   Mon Feb 12 01:31:15 2024 +0800

    host refactor

commit 851b817
Author: ceciliaz030 <zhangyixin319@gmail.com>
Date:   Sat Feb 10 02:51:09 2024 +0800

    fix

commit 39d8654
Author: ceciliaz030 <zhangyixin319@gmail.com>
Date:   Sat Feb 10 02:35:08 2024 +0800

    fix lib/hosts

commit f87ffd7
Author: Cecilia Zhang <zhangyixin319@gmail.com>
Date:   Sat Feb 10 01:39:55 2024 +0800

    refactor host Taiko API

commit ef4172f
Author: ceciliaz030 <zhangyixin319@gmail.com>
Date:   Wed Feb 7 21:54:13 2024 +0800

    wip

commit 6867af4
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Tue Jan 23 11:43:23 2024 +0100

    Fix OP block header validation (taikoxyz#74)

    * verify op block loaded from DB

    * improve errors

    * Simplify BatcherDb (taikoxyz#81)

    * fix warnings

    ---------

    Co-authored-by: Tim Carstens <intoverflow@gmail.com>

commit 3a99983
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Mon Jan 22 22:10:46 2024 +0100

    Fix batch queue handling in Optimism derivation  (taikoxyz#73)

    * sort batches in a multimap

    * update copyright

commit 7280614
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Mon Jan 22 21:21:48 2024 +0100

    feat: Use revm Optimism execution (taikoxyz#44)

    * do not default source_hash and mint

    * use revm optimism execution

    * update testdata

    * add optimism tests

    * upgrade revm to latest commit

    * upgrade revm with latest op changes

    * Upgrade `revm` in Optimism execution (taikoxyz#76)

    * Update dependencies versions

    * fix revm commit

    * use correct tags

    * use EVM in comments

    * update copyright

    * register optimism revm handle

    * update revm

    * update k256

    ---------

    Co-authored-by: john xu <dyxushuai@gmail.com>

    ---------

    Co-authored-by: john xu <dyxushuai@gmail.com>

commit fbe4255
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Fri Dec 22 15:52:52 2023 +0100

    Fix channel bank handling in Optimism derivation (taikoxyz#71)

    * fix channel bank

    * channel_index is not mut

commit 0b2efed
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Tue Dec 19 13:06:40 2023 +0100

    Fix frame parsing and loading in Optimism derivation (taikoxyz#68)

    * cleanup frame parsing

    * fix frame loading

    * move byte wrapping into RLP encoding

    * improve documentation

    * fmt

    * use an actual Batch for the tests

    * log batcher transaction

    * add unit tests

commit 4c0496c
Author: Tim Carstens <intoverflow@gmail.com>
Date:   Mon Dec 18 04:25:01 2023 -0800

    Optimism L1 -> L2 derivation (taikoxyz#51)

    * transactions module

    * TxEssence trait

    * Generic Transaction struct

    * tx essence as a generic parameter

    * OptimismTxEssence

    * op chain spec

    * OpTxExecStrategy

    * redundant block builder type params

    * strategy bundles

    * host binary parameters

    * profiling flag

    * optimism

    * new derivation binary skeleton, copy over libs

    * providers and conversion utils

    * epoch transitioning

    * basic derive flow

    * host-side derivation

    * read metadata from op head

    * op-derive guest

    * disable guest memory leaks

    * heapless batch derivation

    * Add missing import

    * Remove heapless BinaryHeap

    * Remove heapless

    * Introduce op-derive tool

    * Remove ethers types from BatcherDb trait

    * Verify new op block has correct transaction list

    * Move derive logic into library

    * Fix bug in transaction trie reconstruction

    * Introduce get_op_header() to BatcherDb

    * Clippy warning

    * Default Serde value for FileProvider::receipts

    * Disable bloom filter checks

    * Clippy

    * Clippy

    * Fix parsing of from and to fields for deposits

    * Reintroduce filtering by log bloom

    * fmt

    * Add support for local exec to op-derive

    * Enforce block_number is correct in MemDb

    * Split derive() into multiple functions

    * Remove redundant check for batch parent hash

    * Remove redundant copy of system config

    * Remove redundant block number check

    * Cleanup

    * Remove redundant vector of eth blocks

    * Add base_fee_per_gas to Epoch

    * Store deposits in Epoch

    * Add Eth tail to DeriveOutput

    * Cleanup

    * Move deque_next_epoch_if_none to State

    * Move eth block processing to Batches

    * Reorg and cleanup

    * More cleanup

    * run cargo fmt --all

    * fix clippy warnings

    * remove unused imports

    * format guest code

    * add op-derive cmd test

    * add cmd tests

    * cleanup optimism/mod

    * Rename command line args

    * Fix test arguments

    * Rename config field to max_channel_bank_size

    * Enforce decompression limit of MAX_RLP_BYTES_PER_CHANNEL

    * Use constant OPTIMISM_DEPOSITED_TX_TYPE when checking batch validity

    * Import from std instead of alloc/core

    * Re-enable core::mem::forget() optimization

    * Replace asserts with ensures; enforce absence of receipts for Op blocks

    * Simplfy iteration through derived transactions

    * Add Bonsai support to op-derive. Also add Bonsai session status to output when polling

    * More println

    * Rework Batcher initialization

    * More logging

    * More log output if Bonsai workflow fails

    ---------

    Co-authored-by: Rami Khalil <the.rami.khalil@gmail.com>
    Co-authored-by: Wolfgang Welz <welzwo@gmail.com>

commit 916f8c5
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Tue Dec 12 19:39:39 2023 +0100

    Update CI (taikoxyz#60)

    * Update and fix CI

    * fix cargo-install version

    * try without cache

    * Revert "try without cache"

    This reverts commit d91547ab1697989050cfdfce35229e8899b0b27f.

    * add GITHUB_TOKEN

    * review suggestions

    * make version env

commit c24c7b8
Author: John Smith <dyxushuai@gmail.com>
Date:   Tue Dec 12 22:02:16 2023 +0800

    fix: use PathBuf instead of String to compatible different platforms and non-Unicode sequences in filepath  (taikoxyz#65)

    * fix: use PathBuf and Path for compatibility

    * fix: use PathBuf as cache path type

commit ee88f6d
Author: John Smith <dyxushuai@gmail.com>
Date:   Tue Dec 12 00:11:27 2023 +0800

    fix: clippy complain (taikoxyz#64)

commit 3e70593
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Mon Nov 27 09:43:01 2023 +0100

    Pre-flight and block building improvements (taikoxyz#55)

    * cleanup host crate

    * minor cleanups

    * fix trie creation

    * separate node maps

    * fix tests

    * fix proof generation

    * fix integration test

    * add documentation

    * inline public mpt methods

    * move mpt functions

    * fix verification of zero RPC accounts

commit 59c23fd
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Tue Nov 21 17:23:03 2023 +0100

    chore: MPT cleanups (taikoxyz#56)

    * MPT cleanups

    * avoid clone when calling hash

    * fix clippy

commit 71135b7
Author: Tim Carstens <intoverflow@gmail.com>
Date:   Tue Nov 21 07:09:20 2023 -0800

    Reintroduce data() on TxEssence (taikoxyz#57)

commit 2290e8b
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Sat Nov 18 10:24:53 2023 +0100

    cleanup transaction code (taikoxyz#53)

commit 2dc0bc6
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Sat Nov 18 10:23:30 2023 +0100

    chore(deps): bump risc0 to v0.19.1 (taikoxyz#54)

    * upgrade dependencies

    * upgrade dependencies

commit eed232b
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Wed Nov 1 19:05:41 2023 +0100

    upgrade risc0 to v0.19 (taikoxyz#50)

commit 69402de
Author: Tim Carstens <intoverflow@gmail.com>
Date:   Thu Oct 26 13:07:33 2023 -0700

    Introduce op-info tool (taikoxyz#48)

    * Introduce op-info tool

    * Whitespace

    * Update host/Cargo.toml

    Co-authored-by: Wolfgang Welz <welzwo@gmail.com>

    * Update Cargo.lock

    ---------

    Co-authored-by: Wolfgang Welz <welzwo@gmail.com>

commit 2f12782
Author: Wolfgang Welz <welzwo@gmail.com>
Date:   Thu Oct 19 23:10:56 2023 +0200

    fix clippy (taikoxyz#45)

commit 4db793c
Author: John Smith <dyxushuai@gmail.com>
Date:   Thu Oct 19 21:14:19 2023 +0800

    fix: extra data can equal to MAX_EXTRA_DATA_BYTES (taikoxyz#43)

commit ddb349b
Author: Tim Carstens <intoverflow@gmail.com>
Date:   Thu Oct 19 04:35:16 2023 -0700

    Enable RPC retries (taikoxyz#42)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants