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

In-memory tree states #5533

Merged
merged 46 commits into from
Apr 24, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
1b4620f
Consensus changes
michaelsproul Apr 8, 2024
bba555d
EF tests
michaelsproul Apr 8, 2024
9d3ff45
lcli
michaelsproul Apr 8, 2024
1f5516a
common and watch
michaelsproul Apr 8, 2024
6b5a37c
account manager
michaelsproul Apr 8, 2024
67a881d
cargo
michaelsproul Apr 8, 2024
19f3020
fork choice
michaelsproul Apr 8, 2024
083cf64
promise cache
michaelsproul Apr 8, 2024
429db72
beacon chain
michaelsproul Apr 8, 2024
eff12d7
interop genesis
michaelsproul Apr 8, 2024
7e66ce1
http api
michaelsproul Apr 8, 2024
c34ccab
lighthouse
michaelsproul Apr 8, 2024
0adb24f
op pool
michaelsproul Apr 8, 2024
3d09bf5
beacon chain misc
michaelsproul Apr 8, 2024
a197ffb
parallel state cache
michaelsproul Apr 8, 2024
4139cbe
store
michaelsproul Apr 8, 2024
2d551c4
fix issues in store
michaelsproul Apr 8, 2024
8fca797
IT COMPILES
michaelsproul Apr 8, 2024
2b3b71a
Remove some unnecessary module qualification
michaelsproul Apr 8, 2024
8fda723
Revert Arced pubkey optimization (#5536)
dapplion Apr 11, 2024
de7ae83
Merge remote-tracking branch 'origin/unstable' into tree-states-memory
michaelsproul Apr 11, 2024
cf341b6
Fix caching, rebasing and some tests
michaelsproul Apr 12, 2024
38b0765
Remove unused deps
michaelsproul Apr 12, 2024
7592355
Merge remote-tracking branch 'origin/unstable' into tree-states-memory
michaelsproul Apr 12, 2024
f4285e5
Small cleanups
michaelsproul Apr 12, 2024
d0d0b37
Revert shuffling cache/promise cache changes
michaelsproul Apr 12, 2024
627cac5
Fix state advance bugs
michaelsproul Apr 12, 2024
e7a8fd7
Fix shuffling tests
michaelsproul Apr 12, 2024
b570e0d
Remove some resolved FIXMEs
michaelsproul Apr 15, 2024
db5f5ea
Remove StateProcessingStrategy
michaelsproul Apr 15, 2024
297cea5
Optimise withdrawals calculation
michaelsproul Apr 15, 2024
3be919d
Don't reorg if state cache is missed
michaelsproul Apr 15, 2024
78d02d5
Remove inconsistent state func
michaelsproul Apr 15, 2024
e0b30ad
Fix beta compiler
michaelsproul Apr 15, 2024
cddbcbf
Rebase early, rebase often
michaelsproul Apr 15, 2024
d2657cc
Fix state caching behaviour
michaelsproul Apr 15, 2024
bca33f1
Update to milhouse release
michaelsproul Apr 16, 2024
3a16649
Fix on-disk consensus context format
michaelsproul Apr 18, 2024
1d715b9
Merge remote-tracking branch 'origin/unstable' into tree-states-memory
michaelsproul Apr 18, 2024
9d3c321
Squashed commit of the following:
michaelsproul Apr 18, 2024
62ebdac
Keep indexed attestations, thanks Sean
michaelsproul Apr 19, 2024
8238c19
Merge branch 'on-disk-consensus-context' into tree-states-memory
michaelsproul Apr 19, 2024
900b880
Merge branch 'unstable' into tree-states-memory
realbigsean Apr 19, 2024
a359c74
Address half of Sean's review
michaelsproul Apr 22, 2024
9bf31a2
More simplifications from Sean's review
michaelsproul Apr 23, 2024
970f3df
Cache state after get_advanced_hot_state
michaelsproul Apr 23, 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
lcli
  • Loading branch information
michaelsproul committed Apr 8, 2024
commit 9d3ff459cb24fa927a907877b8a7628b379a1fa3
29 changes: 16 additions & 13 deletions lcli/src/new_testnet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,14 @@ use std::fs::File;
use std::io::Read;
use std::path::PathBuf;
use std::str::FromStr;
use std::sync::Arc;
use std::time::{SystemTime, UNIX_EPOCH};
use types::ExecutionBlockHash;
use types::{
test_utils::generate_deterministic_keypairs, Address, BeaconState, ChainSpec, Config, Epoch,
Eth1Data, EthSpec, ExecutionPayloadHeader, ExecutionPayloadHeaderCapella,
ExecutionPayloadHeaderDeneb, ExecutionPayloadHeaderElectra, ExecutionPayloadHeaderMerge,
ForkName, Hash256, Keypair, PublicKey, Validator,
ForkName, Hash256, Keypair, PublicKey, Validator, ValidatorMutable,
};

pub fn run<E: EthSpec>(testnet_dir_path: PathBuf, matches: &ArgMatches) -> Result<(), String> {
Expand Down Expand Up @@ -264,7 +265,7 @@ fn initialize_state_with_validators<E: EthSpec>(
let mut state = BeaconState::new(genesis_time, eth1_data, spec);

// Seed RANDAO with Eth1 entropy
state.fill_randao_mixes_with(eth1_block_hash);
state.fill_randao_mixes_with(eth1_block_hash).unwrap();

for keypair in keypairs.iter() {
let withdrawal_credentials = |pubkey: &PublicKey| {
Expand All @@ -275,17 +276,19 @@ fn initialize_state_with_validators<E: EthSpec>(
let amount = spec.max_effective_balance;
// Create a new validator.
let validator = Validator {
pubkey: keypair.0.pk.clone().into(),
withdrawal_credentials: withdrawal_credentials(&keypair.1.pk),
activation_eligibility_epoch: spec.far_future_epoch,
activation_epoch: spec.far_future_epoch,
exit_epoch: spec.far_future_epoch,
withdrawable_epoch: spec.far_future_epoch,
effective_balance: std::cmp::min(
amount - amount % (spec.effective_balance_increment),
spec.max_effective_balance,
),
slashed: false,
pubkey: Arc::new(keypair.0.pk.clone().into()),
mutable: ValidatorMutable {
withdrawal_credentials: withdrawal_credentials(&keypair.1.pk),
activation_eligibility_epoch: spec.far_future_epoch,
activation_epoch: spec.far_future_epoch,
exit_epoch: spec.far_future_epoch,
withdrawable_epoch: spec.far_future_epoch,
effective_balance: std::cmp::min(
amount - amount % (spec.effective_balance_increment),
spec.max_effective_balance,
),
slashed: false,
},
};
state.validators_mut().push(validator).unwrap();
state.balances_mut().push(amount).unwrap();
Expand Down
10 changes: 7 additions & 3 deletions lcli/src/replace_state_pubkeys.rs
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,8 @@ pub fn run<E: EthSpec>(testnet_dir: PathBuf, matches: &ArgMatches) -> Result<(),

let mut deposit_tree = DepositDataTree::create(&[], 0, DEPOSIT_TREE_DEPTH);
let mut deposit_root = Hash256::zero();
for (index, validator) in state.validators_mut().iter_mut().enumerate() {
let validators = state.validators_mut();
for index in 0..validators.len() {
let (secret, _) =
recover_validator_secret_from_mnemonic(seed.as_bytes(), index as u32, KeyType::Voting)
.map_err(|e| format!("Unable to generate validator key: {:?}", e))?;
Expand All @@ -52,11 +53,14 @@ pub fn run<E: EthSpec>(testnet_dir: PathBuf, matches: &ArgMatches) -> Result<(),

eprintln!("{}: {}", index, keypair.pk);

validator.pubkey = keypair.pk.into();
validators
.get_mut(index)
.unwrap()
.replace_pubkey(keypair.pk.into());

// Update the deposit tree.
let mut deposit_data = DepositData {
pubkey: validator.pubkey,
pubkey: *validators.get(index).unwrap().pubkey(),
// Set this to a junk value since it's very time consuming to generate the withdrawal
// keys and it's not useful for the time being.
withdrawal_credentials: Hash256::zero(),
Expand Down
4 changes: 2 additions & 2 deletions lcli/src/skip_slots.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ use std::fs::File;
use std::io::prelude::*;
use std::path::PathBuf;
use std::time::{Duration, Instant};
use types::{BeaconState, CloneConfig, EthSpec, Hash256};
use types::{BeaconState, EthSpec, Hash256};

const HTTP_TIMEOUT: Duration = Duration::from_secs(10);

Expand Down Expand Up @@ -128,7 +128,7 @@ pub fn run<E: EthSpec>(
};

for i in 0..runs {
let mut state = state.clone_with(CloneConfig::all());
let mut state = state.clone();

let start = Instant::now();

Expand Down
11 changes: 7 additions & 4 deletions lcli/src/transition_blocks.rs
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ use std::path::{Path, PathBuf};
use std::sync::Arc;
use std::time::{Duration, Instant};
use store::HotColdDB;
use types::{BeaconState, ChainSpec, CloneConfig, EthSpec, Hash256, SignedBeaconBlock};
use types::{BeaconState, ChainSpec, EthSpec, Hash256, SignedBeaconBlock};

const HTTP_TIMEOUT: Duration = Duration::from_secs(10);

Expand Down Expand Up @@ -201,7 +201,10 @@ pub fn run<E: EthSpec>(
let store = Arc::new(store);

debug!("Building pubkey cache (might take some time)");
let validator_pubkey_cache = ValidatorPubkeyCache::new(&pre_state, store)
let validator_pubkey_cache = store.immutable_validators.clone();
validator_pubkey_cache
.write()
.import_new_pubkeys(&pre_state)
.map_err(|e| format!("Failed to create pubkey cache: {:?}", e))?;

/*
Expand Down Expand Up @@ -234,7 +237,7 @@ pub fn run<E: EthSpec>(
let mut output_post_state = None;
let mut saved_ctxt = None;
for i in 0..runs {
let pre_state = pre_state.clone_with(CloneConfig::all());
let pre_state = pre_state.clone();
let block = block.clone();

let start = Instant::now();
Expand All @@ -245,7 +248,7 @@ pub fn run<E: EthSpec>(
block,
state_root_opt,
&config,
&validator_pubkey_cache,
&*validator_pubkey_cache.read(),
&mut saved_ctxt,
spec,
)?;
Expand Down