Skip to content

Commit

Permalink
fix remaining issues
Browse files Browse the repository at this point in the history
  • Loading branch information
itegulov committed Jun 3, 2024
1 parent f8fe977 commit fa59185
Show file tree
Hide file tree
Showing 6 changed files with 19 additions and 6 deletions.
3 changes: 3 additions & 0 deletions core/lib/zksync_core_leftovers/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -192,6 +192,9 @@ impl FromStr for Components {
"proof_data_handler" => Ok(Components(vec![Component::ProofDataHandler])),
"consensus" => Ok(Components(vec![Component::Consensus])),
"commitment_generator" => Ok(Components(vec![Component::CommitmentGenerator])),
"vm_runner_protective_reads" => {
Ok(Components(vec![Component::VmRunnerProtectiveReads]))
}
other => Err(format!("{} is not a valid component name", other)),
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ impl WiringLayer for ProtectiveReadsWriterLayer {
let master_pool = context.get_resource::<PoolResource<MasterPool>>().await?;

let (protective_reads_writer, tasks) = ProtectiveReadsWriter::new(
master_pool.get_singleton().await?, // TODO: check pool size
master_pool.get_custom(3).await?,
self.protective_reads_writer_config.protective_reads_db_path,
self.zksync_network_id,
self.protective_reads_writer_config
Expand Down
2 changes: 1 addition & 1 deletion core/node/state_keeper/src/updates/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,7 @@ impl UpdatesManager {
);
}

pub(crate) fn finish_batch(&mut self, finished_batch: FinishedL1Batch) {
pub fn finish_batch(&mut self, finished_batch: FinishedL1Batch) {
assert!(
self.l1_batch.finished.is_none(),
"Cannot finish already finished batch"
Expand Down
3 changes: 2 additions & 1 deletion core/node/vm_runner/src/process.rs
Original file line number Diff line number Diff line change
Expand Up @@ -109,10 +109,11 @@ impl VmRunner {
.await
.context("VM runner failed to handle L2 block")?;
}
batch_executor
let finished_batch = batch_executor
.finish_batch()
.await
.context("failed finishing L1 batch in executor")?;
updates_manager.finish_batch(finished_batch);
output_handler
.handle_l1_batch(Arc::new(updates_manager))
.await
Expand Down
6 changes: 3 additions & 3 deletions core/node/vm_runner/src/storage.rs
Original file line number Diff line number Diff line change
Expand Up @@ -300,10 +300,10 @@ impl<Io: VmRunnerIo> StorageSyncTask<Io> {
if rocksdb_builder.l1_batch_number().await == Some(latest_processed_batch + 1) {
// RocksDB is already caught up, we might not need to do anything.
// Just need to check that the memory diff is up-to-date in case this is a fresh start.
let last_ready_batch = self.io.last_ready_to_be_loaded_batch(&mut conn).await?;
let state = self.state.read().await;
if state
.storage
.contains_key(&self.io.last_ready_to_be_loaded_batch(&mut conn).await?)
if last_ready_batch == latest_processed_batch
|| state.storage.contains_key(&last_ready_batch)
{
// No need to do anything, killing time until last processed batch is updated.
drop(conn);
Expand Down
9 changes: 9 additions & 0 deletions etc/env/base/vm_runner.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
# Configuration for the VM runner crate

[vm_runner]

[vm_runner.protective_reads]
# Path to the directory that contains RocksDB with protective reads writer cache.
protective_reads_db_path = "./db/main/protective_reads"
# Amount of batches that can be processed in parallel.
protective_reads_window_size = 3

0 comments on commit fa59185

Please sign in to comment.