mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-06 12:38:04 +00:00
7d735fc8ae
Fixes https://github.com/paritytech/polkadot-sdk/issues/106 Port of cumulus PR https://github.com/paritytech/cumulus/pull/2960 This PR adds the ability to bid for collator slots even after the max number of collators have already registered. This eliminates the first come, first served mechanism that was in place before. Key changes: - added `update_bond` extrinsic to allow registered candidates to adjust their bonds in order to dynamically control their bids - added `take_candidate_slot` extrinsic to try to replace an already existing candidate by bidding more than them - candidates are now kept in a sorted list in the pallet storage, where the top `DesiredCandidates` out of `MaxCandidates` candidates in the list will be selected by the session pallet as collators - if the candidacy bond is increased through a `set_candidacy_bond` call, candidates which don't meet the new bond requirements are kicked # Checklist - [ ] My PR includes a detailed description as outlined in the "Description" section above - [ ] My PR follows the [labeling requirements](https://github.com/paritytech/polkadot-sdk/blob/master/docs/CONTRIBUTING.md#process) of this project (at minimum one label for `T` required) - [ ] I have made corresponding changes to the documentation (if applicable) - [ ] I have added tests that prove my fix is effective or that my feature works (if applicable) - [ ] If this PR alters any external APIs or interfaces used by Polkadot, the corresponding Polkadot PR is ready as well as the corresponding Cumulus PR (optional) --------- Signed-off-by: georgepisaltu <george.pisaltu@parity.io>
244 lines
11 KiB
Rust
244 lines
11 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#![allow(unused_parens)]
|
|
#![allow(unused_imports)]
|
|
|
|
use frame_support::{
|
|
traits::Get,
|
|
weights::{constants::RocksDbWeight, Weight},
|
|
};
|
|
use sp_std::marker::PhantomData;
|
|
|
|
// The weight info trait for `pallet_collator_selection`.
|
|
pub trait WeightInfo {
|
|
fn set_invulnerables(_b: u32) -> Weight;
|
|
fn add_invulnerable(_b: u32, _c: u32) -> Weight;
|
|
fn remove_invulnerable(_b: u32) -> Weight;
|
|
fn set_desired_candidates() -> Weight;
|
|
fn set_candidacy_bond(_c: u32, _k: u32) -> Weight;
|
|
fn register_as_candidate(_c: u32) -> Weight;
|
|
fn leave_intent(_c: u32) -> Weight;
|
|
fn update_bond(_c: u32) -> Weight;
|
|
fn take_candidate_slot(_c: u32) -> Weight;
|
|
fn note_author() -> Weight;
|
|
fn new_session(_c: u32, _r: u32) -> Weight;
|
|
}
|
|
|
|
/// Weights for pallet_collator_selection using the Substrate node and recommended hardware.
|
|
pub struct SubstrateWeight<T>(PhantomData<T>);
|
|
impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
|
|
fn set_invulnerables(b: u32) -> Weight {
|
|
Weight::from_parts(18_563_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(68_000_u64, 0).saturating_mul(b as u64))
|
|
.saturating_add(T::DbWeight::get().writes(1_u64))
|
|
}
|
|
fn set_desired_candidates() -> Weight {
|
|
Weight::from_parts(16_363_000_u64, 0).saturating_add(T::DbWeight::get().writes(1_u64))
|
|
}
|
|
fn set_candidacy_bond(_c: u32, _k: u32) -> Weight {
|
|
Weight::from_parts(16_840_000_u64, 0).saturating_add(T::DbWeight::get().writes(1_u64))
|
|
}
|
|
fn register_as_candidate(c: u32) -> Weight {
|
|
Weight::from_parts(71_196_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(198_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(T::DbWeight::get().reads(4_u64))
|
|
.saturating_add(T::DbWeight::get().writes(2_u64))
|
|
}
|
|
fn leave_intent(c: u32) -> Weight {
|
|
Weight::from_parts(55_336_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(151_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(T::DbWeight::get().reads(1_u64))
|
|
.saturating_add(T::DbWeight::get().writes(2_u64))
|
|
}
|
|
fn update_bond(c: u32) -> Weight {
|
|
Weight::from_parts(55_336_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(151_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(T::DbWeight::get().reads(1_u64))
|
|
.saturating_add(T::DbWeight::get().writes(2_u64))
|
|
}
|
|
fn take_candidate_slot(c: u32) -> Weight {
|
|
Weight::from_parts(71_196_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(198_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(T::DbWeight::get().reads(4_u64))
|
|
.saturating_add(T::DbWeight::get().writes(2_u64))
|
|
}
|
|
fn note_author() -> Weight {
|
|
Weight::from_parts(71_461_000_u64, 0)
|
|
.saturating_add(T::DbWeight::get().reads(3_u64))
|
|
.saturating_add(T::DbWeight::get().writes(4_u64))
|
|
}
|
|
fn new_session(r: u32, c: u32) -> Weight {
|
|
Weight::from_parts(0_u64, 0)
|
|
// Standard Error: 1_010_000
|
|
.saturating_add(Weight::from_parts(109_961_000_u64, 0).saturating_mul(r as u64))
|
|
// Standard Error: 1_010_000
|
|
.saturating_add(Weight::from_parts(151_952_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(T::DbWeight::get().reads(1_u64.saturating_mul(r as u64)))
|
|
.saturating_add(T::DbWeight::get().reads(2_u64.saturating_mul(c as u64)))
|
|
.saturating_add(T::DbWeight::get().writes(2_u64.saturating_mul(r as u64)))
|
|
.saturating_add(T::DbWeight::get().writes(2_u64.saturating_mul(c as u64)))
|
|
}
|
|
/// Storage: Session NextKeys (r:1 w:0)
|
|
/// Proof Skipped: Session NextKeys (max_values: None, max_size: None, mode: Measured)
|
|
/// Storage: CollatorSelection Invulnerables (r:1 w:1)
|
|
/// Proof: CollatorSelection Invulnerables (max_values: Some(1), max_size: Some(641), added:
|
|
/// 1136, mode: MaxEncodedLen) Storage: CollatorSelection Candidates (r:1 w:1)
|
|
/// Proof: CollatorSelection Candidates (max_values: Some(1), max_size: Some(4802), added: 5297,
|
|
/// mode: MaxEncodedLen) Storage: System Account (r:1 w:1)
|
|
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode:
|
|
/// MaxEncodedLen) The range of component `b` is `[1, 19]`.
|
|
/// The range of component `c` is `[1, 99]`.
|
|
fn add_invulnerable(b: u32, c: u32) -> Weight {
|
|
// Proof Size summary in bytes:
|
|
// Measured: `757 + b * (32 ±0) + c * (53 ±0)`
|
|
// Estimated: `6287 + b * (37 ±0) + c * (53 ±0)`
|
|
// Minimum execution time: 52_720_000 picoseconds.
|
|
Weight::from_parts(56_102_459, 0)
|
|
.saturating_add(Weight::from_parts(0, 6287))
|
|
// Standard Error: 12_957
|
|
.saturating_add(Weight::from_parts(26_422, 0).saturating_mul(b.into()))
|
|
// Standard Error: 2_456
|
|
.saturating_add(Weight::from_parts(128_528, 0).saturating_mul(c.into()))
|
|
.saturating_add(T::DbWeight::get().reads(4))
|
|
.saturating_add(T::DbWeight::get().writes(3))
|
|
.saturating_add(Weight::from_parts(0, 37).saturating_mul(b.into()))
|
|
.saturating_add(Weight::from_parts(0, 53).saturating_mul(c.into()))
|
|
}
|
|
/// Storage: CollatorSelection Invulnerables (r:1 w:1)
|
|
/// Proof: CollatorSelection Invulnerables (max_values: Some(1), max_size: Some(3202), added:
|
|
/// 3697, mode: MaxEncodedLen) The range of component `b` is `[1, 100]`.
|
|
fn remove_invulnerable(b: u32) -> Weight {
|
|
// Proof Size summary in bytes:
|
|
// Measured: `119 + b * (32 ±0)`
|
|
// Estimated: `4687`
|
|
// Minimum execution time: 183_054_000 picoseconds.
|
|
Weight::from_parts(197_205_427, 0)
|
|
.saturating_add(Weight::from_parts(0, 4687))
|
|
// Standard Error: 13_533
|
|
.saturating_add(Weight::from_parts(376_231, 0).saturating_mul(b.into()))
|
|
.saturating_add(T::DbWeight::get().reads(1))
|
|
.saturating_add(T::DbWeight::get().writes(1))
|
|
}
|
|
}
|
|
|
|
// For backwards compatibility and tests
|
|
impl WeightInfo for () {
|
|
fn set_invulnerables(b: u32) -> Weight {
|
|
Weight::from_parts(18_563_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(68_000_u64, 0).saturating_mul(b as u64))
|
|
.saturating_add(RocksDbWeight::get().writes(1_u64))
|
|
}
|
|
fn set_desired_candidates() -> Weight {
|
|
Weight::from_parts(16_363_000_u64, 0).saturating_add(RocksDbWeight::get().writes(1_u64))
|
|
}
|
|
fn set_candidacy_bond(_c: u32, _k: u32) -> Weight {
|
|
Weight::from_parts(16_840_000_u64, 0).saturating_add(RocksDbWeight::get().writes(1_u64))
|
|
}
|
|
fn register_as_candidate(c: u32) -> Weight {
|
|
Weight::from_parts(71_196_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(198_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(RocksDbWeight::get().reads(4_u64))
|
|
.saturating_add(RocksDbWeight::get().writes(2_u64))
|
|
}
|
|
fn leave_intent(c: u32) -> Weight {
|
|
Weight::from_parts(55_336_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(151_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(RocksDbWeight::get().reads(1_u64))
|
|
.saturating_add(RocksDbWeight::get().writes(2_u64))
|
|
}
|
|
fn note_author() -> Weight {
|
|
Weight::from_parts(71_461_000_u64, 0)
|
|
.saturating_add(RocksDbWeight::get().reads(3_u64))
|
|
.saturating_add(RocksDbWeight::get().writes(4_u64))
|
|
}
|
|
fn update_bond(c: u32) -> Weight {
|
|
Weight::from_parts(55_336_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(151_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(RocksDbWeight::get().reads(3_u64))
|
|
.saturating_add(RocksDbWeight::get().writes(4_u64))
|
|
}
|
|
fn take_candidate_slot(c: u32) -> Weight {
|
|
Weight::from_parts(71_196_000_u64, 0)
|
|
// Standard Error: 0
|
|
.saturating_add(Weight::from_parts(198_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(RocksDbWeight::get().reads(3_u64))
|
|
.saturating_add(RocksDbWeight::get().writes(4_u64))
|
|
}
|
|
fn new_session(r: u32, c: u32) -> Weight {
|
|
Weight::from_parts(0_u64, 0)
|
|
// Standard Error: 1_010_000
|
|
.saturating_add(Weight::from_parts(109_961_000_u64, 0).saturating_mul(r as u64))
|
|
// Standard Error: 1_010_000
|
|
.saturating_add(Weight::from_parts(151_952_000_u64, 0).saturating_mul(c as u64))
|
|
.saturating_add(RocksDbWeight::get().reads(1_u64.saturating_mul(r as u64)))
|
|
.saturating_add(RocksDbWeight::get().reads(2_u64.saturating_mul(c as u64)))
|
|
.saturating_add(RocksDbWeight::get().writes(2_u64.saturating_mul(r as u64)))
|
|
.saturating_add(RocksDbWeight::get().writes(2_u64.saturating_mul(c as u64)))
|
|
}
|
|
/// Storage: Session NextKeys (r:1 w:0)
|
|
/// Proof Skipped: Session NextKeys (max_values: None, max_size: None, mode: Measured)
|
|
/// Storage: CollatorSelection Invulnerables (r:1 w:1)
|
|
/// Proof: CollatorSelection Invulnerables (max_values: Some(1), max_size: Some(641), added:
|
|
/// 1136, mode: MaxEncodedLen) Storage: CollatorSelection Candidates (r:1 w:1)
|
|
/// Proof: CollatorSelection Candidates (max_values: Some(1), max_size: Some(4802), added: 5297,
|
|
/// mode: MaxEncodedLen) Storage: System Account (r:1 w:1)
|
|
/// Proof: System Account (max_values: None, max_size: Some(128), added: 2603, mode:
|
|
/// MaxEncodedLen) The range of component `b` is `[1, 19]`.
|
|
/// The range of component `c` is `[1, 99]`.
|
|
fn add_invulnerable(b: u32, c: u32) -> Weight {
|
|
// Proof Size summary in bytes:
|
|
// Measured: `757 + b * (32 ±0) + c * (53 ±0)`
|
|
// Estimated: `6287 + b * (37 ±0) + c * (53 ±0)`
|
|
// Minimum execution time: 52_720_000 picoseconds.
|
|
Weight::from_parts(56_102_459, 0)
|
|
.saturating_add(Weight::from_parts(0, 6287))
|
|
// Standard Error: 12_957
|
|
.saturating_add(Weight::from_parts(26_422, 0).saturating_mul(b.into()))
|
|
// Standard Error: 2_456
|
|
.saturating_add(Weight::from_parts(128_528, 0).saturating_mul(c.into()))
|
|
.saturating_add(RocksDbWeight::get().reads(4))
|
|
.saturating_add(RocksDbWeight::get().writes(3))
|
|
.saturating_add(Weight::from_parts(0, 37).saturating_mul(b.into()))
|
|
.saturating_add(Weight::from_parts(0, 53).saturating_mul(c.into()))
|
|
}
|
|
/// Storage: CollatorSelection Invulnerables (r:1 w:1)
|
|
/// Proof: CollatorSelection Invulnerables (max_values: Some(1), max_size: Some(3202), added:
|
|
/// 3697, mode: MaxEncodedLen) The range of component `b` is `[1, 100]`.
|
|
fn remove_invulnerable(b: u32) -> Weight {
|
|
// Proof Size summary in bytes:
|
|
// Measured: `119 + b * (32 ±0)`
|
|
// Estimated: `4687`
|
|
// Minimum execution time: 183_054_000 picoseconds.
|
|
Weight::from_parts(197_205_427, 0)
|
|
.saturating_add(Weight::from_parts(0, 4687))
|
|
// Standard Error: 13_533
|
|
.saturating_add(Weight::from_parts(376_231, 0).saturating_mul(b.into()))
|
|
.saturating_add(RocksDbWeight::get().reads(1))
|
|
.saturating_add(RocksDbWeight::get().writes(1))
|
|
}
|
|
}
|