From 4fb95d06d1062e1779f24d4cda23a89c4f9a6f9f Mon Sep 17 00:00:00 2001 From: Age Manning Date: Sun, 31 Mar 2019 00:08:55 +1100 Subject: [PATCH] Correct cache race condition --- beacon_node/rpc/src/beacon_chain.rs | 8 +++++++- beacon_node/rpc/src/validator.rs | 18 ++++++++++++++---- .../test_utils/testing_beacon_state_builder.rs | 2 +- 3 files changed, 22 insertions(+), 6 deletions(-) diff --git a/beacon_node/rpc/src/beacon_chain.rs b/beacon_node/rpc/src/beacon_chain.rs index 7de48efa1..ddc91b73c 100644 --- a/beacon_node/rpc/src/beacon_chain.rs +++ b/beacon_node/rpc/src/beacon_chain.rs @@ -2,7 +2,7 @@ use beacon_chain::BeaconChain as RawBeaconChain; use beacon_chain::{ db::ClientDB, fork_choice::ForkChoice, - parking_lot::RwLockReadGuard, + parking_lot::{RwLockReadGuard, RwLockWriteGuard}, slot_clock::SlotClock, types::{BeaconState, ChainSpec, Signature}, AttestationValidationError, BlockProductionError, @@ -16,6 +16,8 @@ pub trait BeaconChain: Send + Sync { fn get_state(&self) -> RwLockReadGuard; + fn get_mut_state(&self) -> RwLockWriteGuard; + fn process_block(&self, block: BeaconBlock) -> Result; @@ -46,6 +48,10 @@ where self.state.read() } + fn get_mut_state(&self) -> RwLockWriteGuard { + self.state.write() + } + fn process_block( &self, block: BeaconBlock, diff --git a/beacon_node/rpc/src/validator.rs b/beacon_node/rpc/src/validator.rs index 936c95f52..a60cb4394 100644 --- a/beacon_node/rpc/src/validator.rs +++ b/beacon_node/rpc/src/validator.rs @@ -4,7 +4,7 @@ use futures::Future; use grpcio::{RpcContext, RpcStatus, RpcStatusCode, UnarySink}; use protos::services::{ActiveValidator, GetDutiesRequest, GetDutiesResponse, ValidatorDuty}; use protos::services_grpc::ValidatorService; -use slog::{debug, info, warn, Logger}; +use slog::{trace, warn}; use ssz::Decodable; use std::sync::Arc; use types::{Epoch, RelativeEpoch}; @@ -12,7 +12,7 @@ use types::{Epoch, RelativeEpoch}; #[derive(Clone)] pub struct ValidatorServiceInstance { pub chain: Arc, - pub log: Logger, + pub log: slog::Logger, } //TODO: Refactor Errors @@ -27,13 +27,23 @@ impl ValidatorService for ValidatorServiceInstance { sink: UnarySink, ) { let validators = req.get_validators(); - debug!(self.log, "RPC request"; "endpoint" => "GetValidatorDuties", "epoch" => req.get_epoch()); + trace!(self.log, "RPC request"; "endpoint" => "GetValidatorDuties", "epoch" => req.get_epoch()); + + let spec = self.chain.get_spec(); + // update the caches if necessary + { + let mut mut_state = self.chain.get_mut_state(); + + let _ = mut_state.build_epoch_cache(RelativeEpoch::NextWithoutRegistryChange, spec); + + let _ = mut_state.build_epoch_cache(RelativeEpoch::NextWithRegistryChange, spec); + let _ = mut_state.update_pubkey_cache(); + } let epoch = Epoch::from(req.get_epoch()); let mut resp = GetDutiesResponse::new(); let resp_validators = resp.mut_active_validators(); - let spec = self.chain.get_spec(); let state = self.chain.get_state(); let relative_epoch = diff --git a/eth2/types/src/test_utils/testing_beacon_state_builder.rs b/eth2/types/src/test_utils/testing_beacon_state_builder.rs index 8d0aa6af6..c04188920 100644 --- a/eth2/types/src/test_utils/testing_beacon_state_builder.rs +++ b/eth2/types/src/test_utils/testing_beacon_state_builder.rs @@ -120,7 +120,7 @@ impl TestingBeaconStateBuilder { }) .collect(); - let genesis_time = 1553932445; // arbitrary + let genesis_time = 1553950542; // arbitrary let mut state = BeaconState::genesis( genesis_time,