Skip to content

Commit

Permalink
make protective reads writer shadow state keeper
Browse files Browse the repository at this point in the history
  • Loading branch information
itegulov committed Jun 3, 2024
1 parent 910da89 commit e9464ba
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 5 deletions.
2 changes: 1 addition & 1 deletion core/node/vm_runner/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ zksync_contracts.workspace = true
zksync_state.workspace = true
zksync_storage.workspace = true
zksync_state_keeper.workspace = true
zksync_utils.workspace = true
vm_utils.workspace = true

tokio = { workspace = true, features = ["time"] }
Expand All @@ -30,7 +31,6 @@ dashmap.workspace = true
zksync_node_test_utils.workspace = true
zksync_node_genesis.workspace = true
zksync_test_account.workspace = true
zksync_utils.workspace = true
backon.workspace = true
futures = { workspace = true, features = ["compat"] }
rand.workspace = true
Expand Down
31 changes: 27 additions & 4 deletions core/node/vm_runner/src/impls/protective_reads.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@ use async_trait::async_trait;
use tokio::sync::watch;
use zksync_dal::{Connection, ConnectionPool, Core, CoreDal};
use zksync_state_keeper::{MainBatchExecutor, StateKeeperOutputHandler, UpdatesManager};
use zksync_types::{L1BatchNumber, L2ChainId};
use zksync_types::{zk_evm_types::LogQuery, AccountTreeId, L1BatchNumber, L2ChainId, StorageKey};
use zksync_utils::u256_to_h256;

use crate::{
storage::StorageSyncTask, ConcurrentOutputHandlerFactory, ConcurrentOutputHandlerFactoryTask,
Expand Down Expand Up @@ -134,7 +135,7 @@ impl StateKeeperOutputHandler for ProtectiveReadsOutputHandler {
.finished
.as_ref()
.context("L1 batch is not actually finished")?;
let (_, protective_reads): (Vec<_>, Vec<_>) = finished_batch
let (_, protective_reads): (Vec<LogQuery>, Vec<LogQuery>) = finished_batch
.final_execution_state
.deduplicated_storage_log_queries
.iter()
Expand All @@ -144,10 +145,32 @@ impl StateKeeperOutputHandler for ProtectiveReadsOutputHandler {
.pool
.connection_tagged("protective_reads_writer")
.await?;
connection
let mut expected_protective_reads = connection
.storage_logs_dedup_dal()
.insert_protective_reads(updates_manager.l1_batch.number, &protective_reads)
.get_protective_reads_for_l1_batch(updates_manager.l1_batch.number)
.await?;

for protective_read in protective_reads {
let address = AccountTreeId::new(protective_read.address);
let key = u256_to_h256(protective_read.key);
if !expected_protective_reads.remove(&StorageKey::new(address, key)) {
tracing::error!(
l1_batch_number = %updates_manager.l1_batch.number,
address = %protective_read.address,
key = %key,
"VM runner produced a protective read that did not happen in state keeper"
);
}
}
for remaining_read in expected_protective_reads {
tracing::error!(
l1_batch_number = %updates_manager.l1_batch.number,
address = %remaining_read.address(),
key = %remaining_read.key(),
"State keeper produced a protective read that did not happen in VM runner"
);
}

Ok(())
}
}
Expand Down

0 comments on commit e9464ba

Please sign in to comment.