From 1ca2b74198aac9c8c358b623bdb25e292bafb373 Mon Sep 17 00:00:00 2001 From: Brooks Prumo Date: Mon, 4 Oct 2021 14:56:04 -0500 Subject: [PATCH 1/2] Rename CRDS SnapshotHash to SnapshotHashes --- gossip/src/cluster_info.rs | 18 +++++++++--------- gossip/src/crds.rs | 4 ++-- gossip/src/crds_entry.rs | 8 ++++---- gossip/src/crds_value.rs | 20 ++++++++++---------- rpc/src/rpc_service.rs | 8 ++++---- 5 files changed, 29 insertions(+), 29 deletions(-) diff --git a/gossip/src/cluster_info.rs b/gossip/src/cluster_info.rs index f8cc8169a46d5b..b91694d2641f20 100644 --- a/gossip/src/cluster_info.rs +++ b/gossip/src/cluster_info.rs @@ -24,7 +24,7 @@ use { crds_gossip_pull::{CrdsFilter, ProcessPullStats, CRDS_GOSSIP_PULL_CRDS_TIMEOUT_MS}, crds_value::{ self, CrdsData, CrdsValue, CrdsValueLabel, EpochSlotsIndex, LowestSlot, NodeInstance, - SnapshotHash, Version, Vote, MAX_WALLCLOCK, + SnapshotHashes, Version, Vote, MAX_WALLCLOCK, }, epoch_slots::EpochSlots, gossip_error::GossipError, @@ -247,7 +247,7 @@ pub fn make_accounts_hashes_message( keypair: &Keypair, accounts_hashes: Vec<(Slot, Hash)>, ) -> Option { - let message = CrdsData::AccountsHashes(SnapshotHash::new(keypair.pubkey(), accounts_hashes)); + let message = CrdsData::AccountsHashes(SnapshotHashes::new(keypair.pubkey(), accounts_hashes)); Some(CrdsValue::new_signed(message, keypair)) } @@ -932,7 +932,7 @@ impl ClusterInfo { return; } - let message = CrdsData::AccountsHashes(SnapshotHash::new(self.id(), accounts_hashes)); + let message = CrdsData::AccountsHashes(SnapshotHashes::new(self.id(), accounts_hashes)); self.push_message(CrdsValue::new_signed(message, &self.keypair())); } @@ -945,7 +945,7 @@ impl ClusterInfo { return; } - let message = CrdsData::SnapshotHashes(SnapshotHash::new(self.id(), snapshot_hashes)); + let message = CrdsData::SnapshotHashes(SnapshotHashes::new(self.id(), snapshot_hashes)); self.push_message(CrdsValue::new_signed(message, &self.keypair())); } @@ -1111,7 +1111,7 @@ impl ClusterInfo { F: FnOnce(&Vec<(Slot, Hash)>) -> Y, { let gossip_crds = self.gossip.crds.read().unwrap(); - let hashes = &gossip_crds.get::<&SnapshotHash>(*pubkey)?.hashes; + let hashes = &gossip_crds.get::<&SnapshotHashes>(*pubkey)?.hashes; Some(map(hashes)) } @@ -3171,7 +3171,7 @@ mod tests { fn test_max_snapshot_hashes_with_push_messages() { let mut rng = rand::thread_rng(); for _ in 0..256 { - let snapshot_hash = SnapshotHash::new_rand(&mut rng, None); + let snapshot_hash = SnapshotHashes::new_rand(&mut rng, None); let crds_value = CrdsValue::new_signed(CrdsData::SnapshotHashes(snapshot_hash), &Keypair::new()); let message = Protocol::PushMessage(Pubkey::new_unique(), vec![crds_value]); @@ -3184,7 +3184,7 @@ mod tests { fn test_max_snapshot_hashes_with_pull_responses() { let mut rng = rand::thread_rng(); for _ in 0..256 { - let snapshot_hash = SnapshotHash::new_rand(&mut rng, None); + let snapshot_hash = SnapshotHashes::new_rand(&mut rng, None); let crds_value = CrdsValue::new_signed(CrdsData::AccountsHashes(snapshot_hash), &Keypair::new()); let response = Protocol::PullResponse(Pubkey::new_unique(), vec![crds_value]); @@ -3827,7 +3827,7 @@ mod tests { fn test_split_messages_packet_size() { // Test that if a value is smaller than payload size but too large to be wrapped in a vec // that it is still dropped - let mut value = CrdsValue::new_unsigned(CrdsData::SnapshotHashes(SnapshotHash { + let mut value = CrdsValue::new_unsigned(CrdsData::SnapshotHashes(SnapshotHashes { from: Pubkey::default(), hashes: vec![], wallclock: 0, @@ -3835,7 +3835,7 @@ mod tests { let mut i = 0; while value.size() < PUSH_MESSAGE_MAX_PAYLOAD_SIZE as u64 { - value.data = CrdsData::SnapshotHashes(SnapshotHash { + value.data = CrdsData::SnapshotHashes(SnapshotHashes { from: Pubkey::default(), hashes: vec![(0, Hash::default()); i], wallclock: 0, diff --git a/gossip/src/crds.rs b/gossip/src/crds.rs index 71ae737ad25357..ecbdb643ddbef1 100644 --- a/gossip/src/crds.rs +++ b/gossip/src/crds.rs @@ -559,7 +559,7 @@ mod tests { super::*, crate::{ contact_info::ContactInfo, - crds_value::{new_rand_timestamp, NodeInstance, SnapshotHash}, + crds_value::{new_rand_timestamp, NodeInstance, SnapshotHashes}, }, rand::{thread_rng, Rng, SeedableRng}, rand_chacha::ChaChaRng, @@ -1061,7 +1061,7 @@ mod tests { assert_eq!(crds.insert(node, timestamp()), Ok(())); assert_eq!(crds.get_shred_version(&pubkey), Some(8)); // Add other crds values with the same pubkey. - let val = SnapshotHash::new_rand(&mut rng, Some(pubkey)); + let val = SnapshotHashes::new_rand(&mut rng, Some(pubkey)); let val = CrdsData::SnapshotHashes(val); let val = CrdsValue::new_unsigned(val); assert_eq!(crds.insert(val, timestamp()), Ok(())); diff --git a/gossip/src/crds_entry.rs b/gossip/src/crds_entry.rs index 3492af2966d1f4..38b826b52aeaed 100644 --- a/gossip/src/crds_entry.rs +++ b/gossip/src/crds_entry.rs @@ -3,7 +3,7 @@ use { contact_info::ContactInfo, crds::VersionedCrdsValue, crds_value::{ - CrdsData, CrdsValue, CrdsValueLabel, LegacyVersion, LowestSlot, SnapshotHash, Version, + CrdsData, CrdsValue, CrdsValueLabel, LegacyVersion, LowestSlot, SnapshotHashes, Version, }, }, indexmap::IndexMap, @@ -14,7 +14,7 @@ type CrdsTable = IndexMap; /// Represents types which can be looked up from crds table given a key. e.g. /// CrdsValueLabel -> VersionedCrdsValue, CrdsValue, CrdsData -/// Pubkey -> ContactInfo, LowestSlot, SnapshotHash, ... +/// Pubkey -> ContactInfo, LowestSlot, SnapshotHashes, ... pub trait CrdsEntry<'a, 'b>: Sized { type Key; // Lookup key. fn get_entry(table: &'a CrdsTable, key: Self::Key) -> Option; @@ -57,7 +57,7 @@ impl_crds_entry!(LegacyVersion, CrdsData::LegacyVersion(version), version); impl_crds_entry!(LowestSlot, CrdsData::LowestSlot(_, slot), slot); impl_crds_entry!(Version, CrdsData::Version(version), version); -impl<'a, 'b> CrdsEntry<'a, 'b> for &'a SnapshotHash { +impl<'a, 'b> CrdsEntry<'a, 'b> for &'a SnapshotHashes { type Key = Pubkey; fn get_entry(table: &'a CrdsTable, key: Self::Key) -> Option { let key = CrdsValueLabel::SnapshotHashes(key); @@ -112,7 +112,7 @@ mod tests { assert_eq!(crds.get::<&LegacyVersion>(key), Some(version)) } CrdsData::SnapshotHashes(hash) => { - assert_eq!(crds.get::<&SnapshotHash>(key), Some(hash)) + assert_eq!(crds.get::<&SnapshotHashes>(key), Some(hash)) } _ => (), } diff --git a/gossip/src/crds_value.rs b/gossip/src/crds_value.rs index daf653c8aaab86..b2ab4f9f6a5a37 100644 --- a/gossip/src/crds_value.rs +++ b/gossip/src/crds_value.rs @@ -84,8 +84,8 @@ pub enum CrdsData { ContactInfo(ContactInfo), Vote(VoteIndex, Vote), LowestSlot(/*DEPRECATED:*/ u8, LowestSlot), - SnapshotHashes(SnapshotHash), - AccountsHashes(SnapshotHash), + SnapshotHashes(SnapshotHashes), + AccountsHashes(SnapshotHashes), EpochSlots(EpochSlotsIndex, EpochSlots), LegacyVersion(LegacyVersion), Version(Version), @@ -147,8 +147,8 @@ impl CrdsData { match kind { 0 => CrdsData::ContactInfo(ContactInfo::new_rand(rng, pubkey)), 1 => CrdsData::LowestSlot(rng.gen(), LowestSlot::new_rand(rng, pubkey)), - 2 => CrdsData::SnapshotHashes(SnapshotHash::new_rand(rng, pubkey)), - 3 => CrdsData::AccountsHashes(SnapshotHash::new_rand(rng, pubkey)), + 2 => CrdsData::SnapshotHashes(SnapshotHashes::new_rand(rng, pubkey)), + 3 => CrdsData::AccountsHashes(SnapshotHashes::new_rand(rng, pubkey)), 4 => CrdsData::Version(Version::new_rand(rng, pubkey)), 5 => CrdsData::Vote(rng.gen_range(0, MAX_VOTES), Vote::new_rand(rng, pubkey)), _ => CrdsData::EpochSlots( @@ -160,13 +160,13 @@ impl CrdsData { } #[derive(Serialize, Deserialize, Clone, Debug, PartialEq, AbiExample)] -pub struct SnapshotHash { +pub struct SnapshotHashes { pub from: Pubkey, pub hashes: Vec<(Slot, Hash)>, pub wallclock: u64, } -impl Sanitize for SnapshotHash { +impl Sanitize for SnapshotHashes { fn sanitize(&self) -> Result<(), SanitizeError> { sanitize_wallclock(self.wallclock)?; for (slot, _) in &self.hashes { @@ -178,7 +178,7 @@ impl Sanitize for SnapshotHash { } } -impl SnapshotHash { +impl SnapshotHashes { pub fn new(from: Pubkey, hashes: Vec<(Slot, Hash)>) -> Self { Self { from, @@ -187,7 +187,7 @@ impl SnapshotHash { } } - /// New random SnapshotHash for tests and benchmarks. + /// New random SnapshotHashes for tests and benchmarks. pub(crate) fn new_rand(rng: &mut R, pubkey: Option) -> Self { let num_hashes = rng.gen_range(0, MAX_SNAPSHOT_HASHES) + 1; let hashes = std::iter::repeat_with(|| { @@ -475,7 +475,7 @@ impl fmt::Display for CrdsValueLabel { CrdsValueLabel::ContactInfo(_) => write!(f, "ContactInfo({})", self.pubkey()), CrdsValueLabel::Vote(ix, _) => write!(f, "Vote({}, {})", ix, self.pubkey()), CrdsValueLabel::LowestSlot(_) => write!(f, "LowestSlot({})", self.pubkey()), - CrdsValueLabel::SnapshotHashes(_) => write!(f, "SnapshotHash({})", self.pubkey()), + CrdsValueLabel::SnapshotHashes(_) => write!(f, "SnapshotHashes({})", self.pubkey()), CrdsValueLabel::EpochSlots(ix, _) => write!(f, "EpochSlots({}, {})", ix, self.pubkey()), CrdsValueLabel::AccountsHashes(_) => write!(f, "AccountsHashes({})", self.pubkey()), CrdsValueLabel::LegacyVersion(_) => write!(f, "LegacyVersion({})", self.pubkey()), @@ -584,7 +584,7 @@ impl CrdsValue { } } - pub(crate) fn accounts_hash(&self) -> Option<&SnapshotHash> { + pub(crate) fn accounts_hash(&self) -> Option<&SnapshotHashes> { match &self.data { CrdsData::AccountsHashes(slots) => Some(slots), _ => None, diff --git a/rpc/src/rpc_service.rs b/rpc/src/rpc_service.rs index 68747590229294..256d5cb8452c3b 100644 --- a/rpc/src/rpc_service.rs +++ b/rpc/src/rpc_service.rs @@ -496,7 +496,7 @@ mod tests { crate::rpc::create_validator_exit, solana_gossip::{ contact_info::ContactInfo, - crds_value::{CrdsData, CrdsValue, SnapshotHash}, + crds_value::{CrdsData, CrdsValue, SnapshotHashes}, }, solana_ledger::{ genesis_utils::{create_genesis_config, GenesisConfigInfo}, @@ -784,7 +784,7 @@ mod tests { .write() .unwrap() .insert( - CrdsValue::new_unsigned(CrdsData::AccountsHashes(SnapshotHash::new( + CrdsValue::new_unsigned(CrdsData::AccountsHashes(SnapshotHashes::new( trusted_validators[0], vec![ (1, Hash::default()), @@ -804,7 +804,7 @@ mod tests { .write() .unwrap() .insert( - CrdsValue::new_unsigned(CrdsData::AccountsHashes(SnapshotHash::new( + CrdsValue::new_unsigned(CrdsData::AccountsHashes(SnapshotHashes::new( trusted_validators[1], vec![(1000 + health_check_slot_distance - 1, Hash::default())], ))), @@ -820,7 +820,7 @@ mod tests { .write() .unwrap() .insert( - CrdsValue::new_unsigned(CrdsData::AccountsHashes(SnapshotHash::new( + CrdsValue::new_unsigned(CrdsData::AccountsHashes(SnapshotHashes::new( trusted_validators[2], vec![(1000 + health_check_slot_distance, Hash::default())], ))), From 804c9e8d704d928253ebe03027e35c47578793b3 Mon Sep 17 00:00:00 2001 From: Brooks Prumo Date: Mon, 4 Oct 2021 16:01:17 -0500 Subject: [PATCH 2/2] fix: update frozen abi digest --- gossip/src/cluster_info.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gossip/src/cluster_info.rs b/gossip/src/cluster_info.rs index b91694d2641f20..44664ac99bcfb9 100644 --- a/gossip/src/cluster_info.rs +++ b/gossip/src/cluster_info.rs @@ -254,7 +254,7 @@ pub fn make_accounts_hashes_message( pub(crate) type Ping = ping_pong::Ping<[u8; GOSSIP_PING_TOKEN_SIZE]>; // TODO These messages should go through the gpu pipeline for spam filtering -#[frozen_abi(digest = "AqKhoLDkFr85WPiZnXG4bcRwHU4qSSyDZ3MQZLk3cnJf")] +#[frozen_abi(digest = "F2XvJ1e5qdQdtUcRhMNYAJFbMBJyFi3NRbfdfghzBajW")] #[derive(Serialize, Deserialize, Debug, AbiEnumVisitor, AbiExample)] #[allow(clippy::large_enum_variant)] pub(crate) enum Protocol {