From 073be906da498171acd3a7b94d773cdded2d3b52 Mon Sep 17 00:00:00 2001 From: Paul Hauner Date: Thu, 28 Feb 2019 16:37:12 +1100 Subject: [PATCH] Remove cache operations from epoch processing. - Don't build the next cache at all. - Call `advance_caches()` in per-slot processing. --- eth2/state_processing/src/epoch_processable.rs | 6 ------ eth2/state_processing/src/slot_processable.rs | 1 + 2 files changed, 1 insertion(+), 6 deletions(-) diff --git a/eth2/state_processing/src/epoch_processable.rs b/eth2/state_processing/src/epoch_processable.rs index 2cee455a3..0ecd1bbd1 100644 --- a/eth2/state_processing/src/epoch_processable.rs +++ b/eth2/state_processing/src/epoch_processable.rs @@ -619,12 +619,6 @@ impl EpochProcessable for BeaconState { .cloned() .collect(); - /* - * Manage the beacon state caches - */ - self.advance_caches(); - self.build_epoch_cache(RelativeEpoch::Next, spec)?; - debug!("Epoch transition complete."); Ok(()) diff --git a/eth2/state_processing/src/slot_processable.rs b/eth2/state_processing/src/slot_processable.rs index 0bbc79ab0..6017f4c0a 100644 --- a/eth2/state_processing/src/slot_processable.rs +++ b/eth2/state_processing/src/slot_processable.rs @@ -26,6 +26,7 @@ where ) -> Result<(), Error> { if (self.slot + 1) % spec.epoch_length == 0 { self.per_epoch_processing(spec)?; + self.advance_caches(); } self.slot += 1;