Add pico-inflation feature

This commit is contained in:
Michael Vines
2020-09-25 16:19:03 -07:00
parent 718f33260b
commit aa5c008fa8
8 changed files with 59 additions and 32 deletions

View File

@@ -11,7 +11,7 @@ use solana_sdk::{
pubkey::Pubkey, pubkey::Pubkey,
rent, rent,
sysvar::{ sysvar::{
self, clock::Clock, fees::Fees, rent::Rent, rewards::Rewards, slot_hashes::SlotHashes, self, clock::Clock, fees::Fees, rent::Rent, slot_hashes::SlotHashes,
stake_history::StakeHistory, Sysvar, stake_history::StakeHistory, Sysvar,
}, },
}; };
@@ -35,24 +35,19 @@ fn process_instruction(
let fee_calculator = fees.fee_calculator; let fee_calculator = fees.fee_calculator;
assert_eq!(fee_calculator.lamports_per_signature, 0); assert_eq!(fee_calculator.lamports_per_signature, 0);
// Rewards
info!("Rewards identifier:");
sysvar::rewards::id().log();
let _rewards = Rewards::from_account_info(&accounts[4]).expect("rewards");
// Slot Hashes // Slot Hashes
info!("SlotHashes identifier:"); info!("SlotHashes identifier:");
sysvar::slot_hashes::id().log(); sysvar::slot_hashes::id().log();
let slot_hashes = SlotHashes::from_account_info(&accounts[5]).expect("slot_hashes"); let slot_hashes = SlotHashes::from_account_info(&accounts[4]).expect("slot_hashes");
assert!(slot_hashes.len() >= 1); assert!(slot_hashes.len() >= 1);
// Stake History // Stake History
info!("StakeHistory identifier:"); info!("StakeHistory identifier:");
sysvar::stake_history::id().log(); sysvar::stake_history::id().log();
let stake_history = StakeHistory::from_account_info(&accounts[6]).expect("stake_history"); let stake_history = StakeHistory::from_account_info(&accounts[5]).expect("stake_history");
assert!(stake_history.len() >= 1); assert!(stake_history.len() >= 1);
let rent = Rent::from_account_info(&accounts[7]).unwrap(); let rent = Rent::from_account_info(&accounts[6]).unwrap();
assert_eq!( assert_eq!(
rent.due( rent.due(
rent::DEFAULT_LAMPORTS_PER_BYTE_YEAR * rent::DEFAULT_EXEMPTION_THRESHOLD as u64, rent::DEFAULT_LAMPORTS_PER_BYTE_YEAR * rent::DEFAULT_EXEMPTION_THRESHOLD as u64,

View File

@@ -27,7 +27,7 @@ use solana_sdk::{
message::Message, message::Message,
pubkey::Pubkey, pubkey::Pubkey,
signature::{Keypair, Signer}, signature::{Keypair, Signer},
sysvar::{clock, fees, rent, rewards, slot_hashes, stake_history}, sysvar::{clock, fees, rent, slot_hashes, stake_history},
transaction::{Transaction, TransactionError}, transaction::{Transaction, TransactionError},
}; };
use std::{cell::RefCell, env, fs::File, io::Read, path::PathBuf, rc::Rc, sync::Arc}; use std::{cell::RefCell, env, fs::File, io::Read, path::PathBuf, rc::Rc, sync::Arc};
@@ -182,7 +182,6 @@ fn test_program_bpf_sanity() {
AccountMeta::new(Keypair::new().pubkey(), false), AccountMeta::new(Keypair::new().pubkey(), false),
AccountMeta::new(clock::id(), false), AccountMeta::new(clock::id(), false),
AccountMeta::new(fees::id(), false), AccountMeta::new(fees::id(), false),
AccountMeta::new(rewards::id(), false),
AccountMeta::new(slot_hashes::id(), false), AccountMeta::new(slot_hashes::id(), false),
AccountMeta::new(stake_history::id(), false), AccountMeta::new(stake_history::id(), false),
AccountMeta::new(rent::id(), false), AccountMeta::new(rent::id(), false),

View File

@@ -1097,13 +1097,18 @@ impl Bank {
let validator_point_value = self.pay_validator_rewards(validator_rewards); let validator_point_value = self.pay_validator_rewards(validator_rewards);
// this sysvar could be retired... if !self
self.update_sysvar_account(&sysvar::rewards::id(), |account| { .feature_set
sysvar::rewards::create_account( .is_active(&feature_set::pico_inflation::id())
self.inherit_sysvar_account_balance(account), {
validator_point_value, // this sysvar can be retired once `pico_inflation` is enabled on all clusters
) self.update_sysvar_account(&sysvar::rewards::id(), |account| {
}); sysvar::rewards::create_account(
self.inherit_sysvar_account_balance(account),
validator_point_value,
)
});
}
let validator_rewards_paid = let validator_rewards_paid =
self.stakes.read().unwrap().vote_balance_and_staked() - vote_balance_and_staked; self.stakes.read().unwrap().vote_balance_and_staked() - vote_balance_and_staked;
@@ -3555,6 +3560,13 @@ impl Bank {
// The entire code path herein must be idempotent // The entire code path herein must be idempotent
fn apply_feature_activations(&mut self, init_finish_or_warp: bool, initiate_callback: bool) { fn apply_feature_activations(&mut self, init_finish_or_warp: bool, initiate_callback: bool) {
let new_feature_activations = self.compute_active_feature_set(!init_finish_or_warp); let new_feature_activations = self.compute_active_feature_set(!init_finish_or_warp);
if new_feature_activations.contains(&feature_set::pico_inflation::id()) {
*self.inflation.write().unwrap() = Inflation::new_fixed(0.0001); // 0.01% inflation
self.fee_rate_governor.burn_percent = 50; // 50% fee burn
self.rent_collector.rent.burn_percent = 50; // 50% rent burn
}
self.ensure_builtins(init_finish_or_warp, &new_feature_activations); self.ensure_builtins(init_finish_or_warp, &new_feature_activations);
self.reinvoke_entered_epoch_callback(initiate_callback); self.reinvoke_entered_epoch_callback(initiate_callback);
self.recheck_cross_program_support(); self.recheck_cross_program_support();

View File

@@ -17,12 +17,17 @@ pub mod consistent_recent_blockhashes_sysvar {
solana_sdk::declare_id!("3h1BQWPDS5veRsq6mDBWruEpgPxRJkfwGexg5iiQ9mYg"); solana_sdk::declare_id!("3h1BQWPDS5veRsq6mDBWruEpgPxRJkfwGexg5iiQ9mYg");
} }
pub mod pico_inflation {
solana_sdk::declare_id!("GaBtBJvmS4Arjj5W1NmFcyvPjsHN38UGYDq2MDwbs9Qu");
}
lazy_static! { lazy_static! {
/// Map of feature identifiers to user-visible description /// Map of feature identifiers to user-visible description
pub static ref FEATURE_NAMES: HashMap<Pubkey, &'static str> = [ pub static ref FEATURE_NAMES: HashMap<Pubkey, &'static str> = [
(instructions_sysvar_enabled::id(), "instructions sysvar"), (instructions_sysvar_enabled::id(), "instructions sysvar"),
(secp256k1_program_enabled::id(), "secp256k1 program"), (secp256k1_program_enabled::id(), "secp256k1 program"),
(consistent_recent_blockhashes_sysvar::id(), "consistent recentblockhashes sysvar"), (consistent_recent_blockhashes_sysvar::id(), "consistent recentblockhashes sysvar"),
(pico_inflation::id(), "pico-inflation"),
/*************** ADD NEW FEATURES HERE ***************/ /*************** ADD NEW FEATURES HERE ***************/
] ]
.iter() .iter()

View File

@@ -261,7 +261,7 @@ mod test_bank_serialize {
// These some what long test harness is required to freeze the ABI of // These some what long test harness is required to freeze the ABI of
// Bank's serialization due to versioned nature // Bank's serialization due to versioned nature
#[frozen_abi(digest = "FaZaic5p7bvdsKDxGJmaPVyp12AbAmURyYoGiUdx1Ksu")] #[frozen_abi(digest = "5rd8RyVSLH3hm12xJDVCJWgc1gyqb4Ukt2hJLJNfsB5v")]
#[derive(Serialize, AbiExample)] #[derive(Serialize, AbiExample)]
pub struct BankAbiTestWrapperFuture { pub struct BankAbiTestWrapperFuture {
#[serde(serialize_with = "wrapper_future")] #[serde(serialize_with = "wrapper_future")]

View File

@@ -59,7 +59,7 @@ impl FromStr for ClusterType {
} }
} }
#[frozen_abi(digest = "AM75NxYJj5s45rtkFV5S1RCHg2kNMgACjTu5HPfEt4Fp")] #[frozen_abi(digest = "DEg4N5ps9EdEBL2H2ahU54SCcw3QphtPjh48H413fvNq")]
#[derive(Serialize, Deserialize, Debug, Clone, AbiExample)] #[derive(Serialize, Deserialize, Debug, Clone, AbiExample)]
pub struct GenesisConfig { pub struct GenesisConfig {
/// when the network (bootstrap validator) was started relative to the UNIX Epoch /// when the network (bootstrap validator) was started relative to the UNIX Epoch

View File

@@ -19,7 +19,7 @@ pub struct Inflation {
pub foundation_term: f64, pub foundation_term: f64,
/// DEPRECATED, this field is currently unused /// DEPRECATED, this field is currently unused
pub storage: f64, __unused: f64,
} }
const DEFAULT_INITIAL: f64 = 0.15; const DEFAULT_INITIAL: f64 = 0.15;
@@ -27,7 +27,6 @@ const DEFAULT_TERMINAL: f64 = 0.015;
const DEFAULT_TAPER: f64 = 0.15; const DEFAULT_TAPER: f64 = 0.15;
const DEFAULT_FOUNDATION: f64 = 0.05; const DEFAULT_FOUNDATION: f64 = 0.05;
const DEFAULT_FOUNDATION_TERM: f64 = 7.0; const DEFAULT_FOUNDATION_TERM: f64 = 7.0;
const DEFAULT_STORAGE: f64 = 0.0;
impl Default for Inflation { impl Default for Inflation {
fn default() -> Self { fn default() -> Self {
@@ -37,7 +36,7 @@ impl Default for Inflation {
taper: DEFAULT_TAPER, taper: DEFAULT_TAPER,
foundation: DEFAULT_FOUNDATION, foundation: DEFAULT_FOUNDATION,
foundation_term: DEFAULT_FOUNDATION_TERM, foundation_term: DEFAULT_FOUNDATION_TERM,
storage: DEFAULT_STORAGE, __unused: 0.0,
} }
} }
} }
@@ -50,9 +49,22 @@ impl Inflation {
taper: 0.0, taper: 0.0,
foundation: 0.0, foundation: 0.0,
foundation_term: 0.0, foundation_term: 0.0,
storage: 0.0, __unused: 0.0,
} }
} }
// fixed inflation rate at `validator` percentage for staking rewards, and none for foundation
pub fn new_fixed(validator: f64) -> Self {
Self {
initial: validator,
terminal: validator,
taper: 1.0,
foundation: 0.0,
foundation_term: 0.0,
__unused: 0.0,
}
}
/// inflation rate at year /// inflation rate at year
pub fn total(&self, year: f64) -> f64 { pub fn total(&self, year: f64) -> f64 {
assert!(year >= 0.0); assert!(year >= 0.0);
@@ -67,12 +79,7 @@ impl Inflation {
/// portion of total that goes to validators /// portion of total that goes to validators
pub fn validator(&self, year: f64) -> f64 { pub fn validator(&self, year: f64) -> f64 {
self.total(year) - self.storage(year) - self.foundation(year) self.total(year) - self.foundation(year)
}
/// DEPRECATED
fn storage(&self, year: f64) -> f64 {
self.total(year) * self.storage
} }
/// portion of total that goes to foundation /// portion of total that goes to foundation
@@ -100,7 +107,7 @@ mod tests {
let total = inflation.total(*year); let total = inflation.total(*year);
assert_eq!( assert_eq!(
total, total,
inflation.validator(*year) + inflation.storage(*year) + inflation.foundation(*year) inflation.validator(*year) + inflation.foundation(*year)
); );
assert!(total < last); assert!(total < last);
assert!(total >= inflation.terminal); assert!(total >= inflation.terminal);
@@ -108,4 +115,13 @@ mod tests {
} }
assert_eq!(last, inflation.terminal); assert_eq!(last, inflation.terminal);
} }
#[test]
#[allow(clippy::float_cmp)]
fn test_inflation_fixed() {
let inflation = Inflation::new_fixed(0.001);
for year in &[0.1, 0.5, 1.0, DEFAULT_FOUNDATION_TERM, 100.0] {
assert_eq!(inflation.total(*year), 0.001);
}
}
} }

View File

@@ -1,4 +1,4 @@
//! This account contains the current cluster rewards point values //! DEPRECATED: This sysvar can be removed once the pico-inflation feature is enabled
//! //!
use crate::{account::Account, sysvar::Sysvar}; use crate::{account::Account, sysvar::Sysvar};