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: prepare for ontake upgrade #329

Merged
merged 74 commits into from
Sep 13, 2024
Merged
Changes from 1 commit
Commits
Show all changes
74 commits
Select commit Hold shift + click to select a range
3ea44ec
prepare for ontake upgrade
smtmfft Jul 23, 2024
aefd6f6
update Cargo.toml
smtmfft Jul 25, 2024
47e6d60
use forked verifier set together with taiko hard forks
smtmfft Jul 26, 2024
a17bf32
fix hekla path test
smtmfft Jul 31, 2024
760818e
sync with protocol change
smtmfft Aug 8, 2024
17b0292
sync latest protocol
smtmfft Aug 9, 2024
956df7a
rebase main
smtmfft Aug 10, 2024
50debf6
use defaulte l1_inc_block as anchor-1
smtmfft Aug 12, 2024
d261697
refactor(core): [WIP] inital preflight refactor
petarvujovic98 Aug 13, 2024
7206b66
refactor(core): [WIP] continue preflight refactor
petarvujovic98 Aug 13, 2024
94fe6fe
fix(host,tasks): add `l1_inclusive_block_number` field
petarvujovic98 Aug 13, 2024
4e55d71
chore(lib,sgx): run cargo fmt
petarvujovic98 Aug 13, 2024
6080fd3
fix(lib): clippy fixes
petarvujovic98 Aug 13, 2024
aef4c81
chore(core): fix lints
petarvujovic98 Aug 13, 2024
acd9e80
fix(core): fix block conversion for parent block
petarvujovic98 Aug 13, 2024
a1a813b
Merge branch 'main' into ontake-dev
petarvujovic98 Aug 14, 2024
2ad32c4
refactor(core): move preflight to mod and separate into util
petarvujovic98 Aug 14, 2024
70fcc34
Merge branch 'main' into ontake-dev
petarvujovic98 Aug 15, 2024
9c1400b
Merge branch 'main' into ontake-dev
petarvujovic98 Aug 16, 2024
9e68e21
feat(host): [WIP] add integration test skeleton
petarvujovic98 Aug 16, 2024
0f1ff79
switch back to origin reth branch
smtmfft Aug 17, 2024
c5fa313
feat(host): [WIP] improve test description and options
petarvujovic98 Aug 19, 2024
a4364bb
chore(host): hide integration test behind integration feature
petarvujovic98 Aug 19, 2024
dd8b440
Merge branch 'main' into ontake-dev
petarvujovic98 Aug 19, 2024
1e56ba8
feat(host): [WIP] add cancellation and retry to the test flow
petarvujovic98 Aug 19, 2024
68bdc18
chore(ci): [WIP] add integration tests for native
petarvujovic98 Aug 19, 2024
70115b7
fix(host): remove comment from feature flag
petarvujovic98 Aug 20, 2024
dc448d2
feat(host): add test for v1, prunning and reporting
petarvujovic98 Aug 20, 2024
46ff89b
feat(host): support custom config path via env vars for testing
petarvujovic98 Aug 20, 2024
da0aa88
fix(ci): add env var for config path for integration testing
petarvujovic98 Aug 20, 2024
1ae7e7a
fix(host): fix clippy warning
petarvujovic98 Aug 20, 2024
4a8d4f7
fix(ci): remove `@`
petarvujovic98 Aug 20, 2024
c133682
feat(host): separate scenarios and run sequentially
petarvujovic98 Aug 21, 2024
cc237be
fix(host): fix typo in functionality
petarvujovic98 Aug 21, 2024
7e48b94
chore(host): add comment
petarvujovic98 Aug 21, 2024
70156fc
refactor(core): use fork instead of inclusion block
petarvujovic98 Aug 22, 2024
81350f9
Merge branch 'main' into ontake-dev
petarvujovic98 Aug 22, 2024
7908631
feat(ci): add support for testing different proof types
petarvujovic98 Aug 23, 2024
788e7c1
fix(host): pass string instead of type
petarvujovic98 Aug 23, 2024
8a3db48
fix(script): fix typo
petarvujovic98 Aug 23, 2024
1a53b09
chore(core): add detail to transaction execution failure
petarvujovic98 Aug 23, 2024
c36a154
refactor(lib): extract metadata conversion
petarvujovic98 Aug 23, 2024
2900cfb
refactor(lib): clean up preflight utils
petarvujovic98 Aug 26, 2024
a38c046
fix(core): fix clippy issue
petarvujovic98 Aug 26, 2024
ead4e9d
feat(ci): add integration tests for all provers
petarvujovic98 Aug 26, 2024
0ec235c
fix(ci): remove enable feature
petarvujovic98 Aug 26, 2024
8882c66
fix(ci): add prover elf building
petarvujovic98 Aug 27, 2024
b505d94
refactor(host): serialize into status error instead of manual
petarvujovic98 Aug 27, 2024
7406f24
refactor(host): clean up error conversion
petarvujovic98 Aug 27, 2024
b663bf7
Merge remote-tracking branch 'origin/main' into ontake-dev
petarvujovic98 Aug 30, 2024
837df64
Merge branch 'main' into ontake-dev
petarvujovic98 Sep 2, 2024
a05921c
refactor(core): rename l1 inclusion block number field
petarvujovic98 Sep 2, 2024
250aa67
fix(core,host,tasks): save files after rename
petarvujovic98 Sep 2, 2024
fbb4076
Merge branch 'main' into ontake-dev
petarvujovic98 Sep 3, 2024
65d5f3b
feat(core): temporarily use new reth ontake branch (#357)
smtmfft Sep 4, 2024
0942425
chore(core,ci): renaming
petarvujovic98 Sep 4, 2024
70b2211
update pre-compiled image
smtmfft Sep 5, 2024
a0d8a74
update prebuilt image
smtmfft Sep 6, 2024
6b62df4
test prebuilt images
smtmfft Sep 6, 2024
21c97cb
debg CI (#359)
smtmfft Sep 6, 2024
c9a8770
chore(ci): use shorter flag passing
petarvujovic98 Sep 6, 2024
f1a773d
fix(lib): support non taiko forked chains for block proving
petarvujovic98 Sep 6, 2024
4f9204a
fix(ci): building provers for tests (#360)
smtmfft Sep 9, 2024
8d47373
fix(ci): remove comments which broke CI
petarvujovic98 Sep 9, 2024
28d7b0a
fix(ci): add single step
petarvujovic98 Sep 9, 2024
4c51077
refine pipeline stdout message
smtmfft Sep 9, 2024
ec0c038
update to latest ontake taiko-reth
smtmfft Sep 10, 2024
b23db0e
add missing binary
smtmfft Sep 10, 2024
2e0f547
fixing r0 ci (#362)
smtmfft Sep 11, 2024
c2adac0
fix ci
smtmfft Sep 11, 2024
0f0406e
fix ci
smtmfft Sep 11, 2024
e5c7d76
add ci status report script
smtmfft Sep 11, 2024
d2b105a
update to fixed hekla ontake height
smtmfft Sep 11, 2024
fd88ecc
Merge branch 'main' into ontake-dev
petarvujovic98 Sep 12, 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
Prev Previous commit
Next Next commit
feat(core): temporarily use new reth ontake branch (#357)
* temporarily use new reth ontake branch

* Update core/src/preflight/util.rs

Co-authored-by: Petar Vujović <[email protected]>

* chore(lib): run fmt

---------

Co-authored-by: Petar Vujovic <[email protected]>
  • Loading branch information
smtmfft and petarvujovic98 authored Sep 4, 2024

Verified

This commit was signed with the committer’s verified signature.
paring-chan 파링
commit 65d5f3b6f7b6918f6c82b2fc9322eac4916f3500
1,091 changes: 460 additions & 631 deletions Cargo.lock

Large diffs are not rendered by default.

14 changes: 7 additions & 7 deletions Cargo.toml
Original file line number Diff line number Diff line change
@@ -39,18 +39,18 @@ raiko-core = { path = "./core" }
raiko-tasks = { path = "./tasks" }

# reth
reth-primitives = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false, features = [
reth-primitives = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false, features = [
"alloy-compat",
"taiko",
] }
reth-evm-ethereum = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false }
reth-evm = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false }
reth-rpc-types = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false }
reth-revm = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false }
reth-chainspec = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false, features = [
reth-evm-ethereum = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false }
reth-evm = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false }
reth-rpc-types = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false }
reth-revm = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false }
reth-chainspec = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false, features = [
"taiko",
] }
reth-provider = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko", default-features = false }
reth-provider = { git = "https://github.com/taikoxyz/taiko-reth.git", branch = "v1.0.0-rc.2-taiko-ontake", default-features = false }

# risc zero
risc0-zkvm = { version = "1.0.1", features = ["prove", "getrandom"] }
2 changes: 1 addition & 1 deletion core/src/lib.rs
Original file line number Diff line number Diff line change
@@ -65,7 +65,7 @@ impl Raiko {
) -> RaikoResult<GuestInput> {
//TODO: read fork from config
let preflight_data = self.get_preflight_data();
info!("Generating input for HEKLA fork");
info!("Generating input for block {}", self.request.block_number);
preflight(provider, preflight_data)
.await
.map_err(Into::<RaikoError>::into)
29 changes: 21 additions & 8 deletions core/src/preflight/util.rs
Original file line number Diff line number Diff line change
@@ -20,7 +20,7 @@ use raiko_lib::{
},
primitives::eip4844::{self, commitment_to_version_hash, KZG_SETTINGS},
};
use reth_evm_ethereum::taiko::decode_anchor;
use reth_evm_ethereum::taiko::{decode_anchor, decode_anchor_ontake};
use reth_primitives::Block;
use reth_revm::primitives::SpecId;
use serde::{Deserialize, Serialize};
@@ -80,15 +80,28 @@ pub async fn prepare_taiko_chain_input(
.body
.first()
.ok_or_else(|| RaikoError::Preflight("No anchor tx in the block".to_owned()))?;
let anchor_call = decode_anchor(anchor_tx.input())?;
// The L1 blocks we need
let l1_state_block_number = anchor_call.l1BlockId;
let fork = taiko_chain_spec.active_fork(block.number, block.timestamp)?;
let l1_inclusion_block_number = l1_inclusion_block_number.unwrap_or(l1_state_block_number + 1);

let fork = taiko_chain_spec.active_fork(block.number, block.timestamp)?;
info!("current taiko chain fork: {fork:?}");

let (l1_state_block_number, l1_inclusion_block_number) = match fork {
SpecId::ONTAKE => {
let anchor_call = decode_anchor_ontake(anchor_tx.input())?;
(
anchor_call._anchorBlockId,
l1_inclusion_block_number.unwrap_or(anchor_call._anchorBlockId + 1),
smtmfft marked this conversation as resolved.
Show resolved Hide resolved
)
}
_ => {
let anchor_call = decode_anchor(anchor_tx.input())?;
(
anchor_call.l1BlockId,
l1_inclusion_block_number.unwrap_or(anchor_call.l1BlockId + 1),
)
}
};
debug!(
"anchor L1 block id: {:?}\nanchor L1 state root: {:?}",
anchor_call.l1BlockId, anchor_call.l1StateRoot
"anchor L1 block id: {l1_state_block_number:?}, l1 inclusion block id: {l1_inclusion_block_number:?}"
);

// Get the L1 block in which the L2 block was included so we can fetch the DA data.
7 changes: 7 additions & 0 deletions host/config/config.devnet.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"network": "taiko_dev",
"l1_network": "taiko_dev_l1",
"sgx": {
"instance_id": 1
}
}
8 changes: 1 addition & 7 deletions lib/src/builder.rs
Original file line number Diff line number Diff line change
@@ -147,13 +147,7 @@ impl<DB: Database<Error = ProviderError> + DatabaseCommit + OptimisticDatabase>
l1_header: self.input.taiko.l1_header.clone(),
parent_header: self.input.parent_header.clone(),
l2_contract: self.input.chain_spec.l2_contract.unwrap_or_default(),
basefee_ratio: self.input.block.extra_data[0],
basefee_adj_quotient: self
.input
.taiko
.block_proposed
.basefee_adjustment_quotient(),
gas_issue_per_sec: self.input.taiko.block_proposed.gas_issuance_per_second(),
base_fee_config: self.input.taiko.block_proposed.base_fee_config(),
})
.optimistic(optimistic);
let BlockExecutionOutput {
20 changes: 10 additions & 10 deletions lib/src/input.rs
Original file line number Diff line number Diff line change
@@ -2,6 +2,7 @@ use core::{fmt::Debug, str::FromStr};

use anyhow::{anyhow, Error, Result};
use ontake::BlockProposedV2;
use reth_evm_ethereum::taiko::ProtocolBaseFeeConfig;
use reth_primitives::{
revm_primitives::{Address, Bytes, HashMap, B256, U256},
Block, Header, TransactionSigned,
@@ -88,17 +89,16 @@ impl BlockProposedFork {
}
}

pub fn basefee_adjustment_quotient(&self) -> u8 {
pub fn base_fee_config(&self) -> ProtocolBaseFeeConfig {
match self {
BlockProposedFork::Ontake(block) => block.meta.basefeeAdjustmentQuotient,
_ => 0,
}
}

pub fn gas_issuance_per_second(&self) -> u32 {
match self {
BlockProposedFork::Ontake(block) => block.meta.gasIssuancePerSecond,
_ => 0,
BlockProposedFork::Ontake(block) => ProtocolBaseFeeConfig {
adjustment_quotient: block.meta.baseFeeConfig.adjustmentQuotient,
sharing_pctg: block.meta.baseFeeConfig.sharingPctg,
gas_issuance_per_second: block.meta.baseFeeConfig.gasIssuancePerSecond,
min_gas_excess: block.meta.baseFeeConfig.minGasExcess,
max_gas_issuance_per_block: block.meta.baseFeeConfig.maxGasIssuancePerBlock,
},
_ => ProtocolBaseFeeConfig::default(),
}
}
}
12 changes: 10 additions & 2 deletions lib/src/input/ontake.rs
Original file line number Diff line number Diff line change
@@ -3,6 +3,15 @@ use core::fmt::Debug;
use serde::{Deserialize, Serialize};

sol! {
#[derive(Debug, Default, Deserialize, Serialize)]
struct BaseFeeConfig {
uint8 adjustmentQuotient;
uint8 sharingPctg;
uint32 gasIssuancePerSecond;
uint64 minGasExcess;
uint32 maxGasIssuancePerBlock;
}

#[derive(Debug, Default, Deserialize, Serialize)]
struct BlockParamsV2 {
address coinbase;
@@ -37,8 +46,7 @@ sol! {
uint32 blobTxListOffset;
uint32 blobTxListLength;
uint8 blobIndex;
uint8 basefeeAdjustmentQuotient;
uint32 gasIssuancePerSecond;
BaseFeeConfig baseFeeConfig;
}

#[derive(Debug, Default, Deserialize, Serialize)]
3 changes: 1 addition & 2 deletions lib/src/protocol_instance.rs
Original file line number Diff line number Diff line change
@@ -96,8 +96,7 @@ impl From<(&GuestInput, &Header, B256, &BlockProposedV2)> for BlockMetadataV2 {
blobTxListOffset: block_proposed.meta.blobTxListOffset,
blobTxListLength: block_proposed.meta.blobTxListLength,
blobIndex: block_proposed.meta.blobIndex,
basefeeAdjustmentQuotient: block_proposed.meta.basefeeAdjustmentQuotient,
gasIssuancePerSecond: block_proposed.meta.gasIssuancePerSecond,
baseFeeConfig: block_proposed.meta.baseFeeConfig.clone(),
}
}
}
Loading
Loading