From e8f7cc55b1f6f71ecb460713a84297ce8a26880b Mon Sep 17 00:00:00 2001 From: Brooks Date: Tue, 15 Oct 2024 00:09:25 -0400 Subject: [PATCH 01/23] Marks Bank::unfreeze_for_ledger_tool() as dcou (#3160) --- runtime/src/bank.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 6167e603f63e4e..6770010b5d1b84 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -2911,6 +2911,7 @@ impl Bank { } // dangerous; don't use this; this is only needed for ledger-tool's special command + #[cfg(feature = "dev-context-only-utils")] pub fn unfreeze_for_ledger_tool(&self) { self.freeze_started.store(false, Relaxed); } From 5bcf161e096384cf74a1870824f852b467f434ef Mon Sep 17 00:00:00 2001 From: Lijun Wang <83639177+lijunwangs@users.noreply.github.com> Date: Mon, 14 Oct 2024 22:37:48 -0700 Subject: [PATCH 02/23] Support notifying bank created slot status in geyser (#3126) * Support notifying bank created slot status in geyser * Updated comment for CreatedBank slot event --- core/src/replay_stage.rs | 25 +++++++++++++++++++ core/src/tvu.rs | 3 ++- .../src/geyser_plugin_interface.rs | 4 +++ .../src/slot_status_notifier.rs | 4 +++ rpc/src/slot_status_notifier.rs | 3 +++ 5 files changed, 38 insertions(+), 1 deletion(-) diff --git a/core/src/replay_stage.rs b/core/src/replay_stage.rs index db0ee5aff30d53..a10017c3dcd1c6 100644 --- a/core/src/replay_stage.rs +++ b/core/src/replay_stage.rs @@ -54,6 +54,7 @@ use { solana_rpc::{ optimistically_confirmed_bank_tracker::{BankNotification, BankNotificationSenderConfig}, rpc_subscriptions::RpcSubscriptions, + slot_status_notifier::SlotStatusNotifier, }, solana_rpc_client_api::response::SlotUpdate, solana_runtime::{ @@ -251,6 +252,7 @@ pub struct ReplayStageConfig { pub authorized_voter_keypairs: Arc>>>, pub exit: Arc, pub rpc_subscriptions: Arc, + pub slot_status_notifier: Option, pub leader_schedule_cache: Arc, pub accounts_background_request_sender: AbsRequestSender, pub block_commitment_cache: Arc>, @@ -537,6 +539,7 @@ impl ReplayStage { authorized_voter_keypairs, exit, rpc_subscriptions, + slot_status_notifier, leader_schedule_cache, accounts_background_request_sender, block_commitment_cache, @@ -668,6 +671,7 @@ impl ReplayStage { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &slot_status_notifier, &mut progress, &mut replay_timing, ); @@ -1122,6 +1126,7 @@ impl ReplayStage { &poh_recorder, &leader_schedule_cache, &rpc_subscriptions, + &slot_status_notifier, &mut progress, &retransmit_slots_sender, &mut skipped_slots_info, @@ -2052,6 +2057,7 @@ impl ReplayStage { poh_recorder: &Arc>, leader_schedule_cache: &Arc, rpc_subscriptions: &Arc, + slot_status_notifier: &Option, progress_map: &mut ProgressMap, retransmit_slots_sender: &Sender, skipped_slots_info: &mut SkippedSlotsInfo, @@ -2181,6 +2187,7 @@ impl ReplayStage { root_slot, my_pubkey, rpc_subscriptions, + slot_status_notifier, NewBankOptions { vote_only_bank }, ); // make sure parent is frozen for finalized hashes via the above @@ -3960,6 +3967,7 @@ impl ReplayStage { bank_forks: &RwLock, leader_schedule_cache: &Arc, rpc_subscriptions: &Arc, + slot_status_notifier: &Option, progress: &mut ProgressMap, replay_timing: &mut ReplayLoopTiming, ) { @@ -4014,6 +4022,7 @@ impl ReplayStage { forks.root(), &leader, rpc_subscriptions, + slot_status_notifier, NewBankOptions::default(), ); let empty: Vec = vec![]; @@ -4061,9 +4070,16 @@ impl ReplayStage { root_slot: u64, leader: &Pubkey, rpc_subscriptions: &Arc, + slot_status_notifier: &Option, new_bank_options: NewBankOptions, ) -> Bank { rpc_subscriptions.notify_slot(slot, parent.slot(), root_slot); + if let Some(slot_status_notifier) = slot_status_notifier { + slot_status_notifier + .read() + .unwrap() + .notify_created_bank(slot, parent.slot()); + } Bank::new_from_parent_with_options(parent, leader, slot, new_bank_options) } @@ -4410,6 +4426,7 @@ pub(crate) mod tests { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &mut replay_timing, ); @@ -4438,6 +4455,7 @@ pub(crate) mod tests { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &mut replay_timing, ); @@ -6307,6 +6325,7 @@ pub(crate) mod tests { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &mut replay_timing, ); @@ -6336,6 +6355,7 @@ pub(crate) mod tests { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &mut replay_timing, ); @@ -6366,6 +6386,7 @@ pub(crate) mod tests { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &mut replay_timing, ); @@ -6395,6 +6416,7 @@ pub(crate) mod tests { &bank_forks, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &mut replay_timing, ); @@ -8329,6 +8351,7 @@ pub(crate) mod tests { &poh_recorder, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &retransmit_slots_sender, &mut SkippedSlotsInfo::default(), @@ -8997,6 +9020,7 @@ pub(crate) mod tests { &poh_recorder, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &retransmit_slots_sender, &mut SkippedSlotsInfo::default(), @@ -9023,6 +9047,7 @@ pub(crate) mod tests { &poh_recorder, &leader_schedule_cache, &rpc_subscriptions, + &None, &mut progress, &retransmit_slots_sender, &mut SkippedSlotsInfo::default(), diff --git a/core/src/tvu.rs b/core/src/tvu.rs index 23e5d9b6562451..68b7cf38023505 100644 --- a/core/src/tvu.rs +++ b/core/src/tvu.rs @@ -211,7 +211,7 @@ impl Tvu { retransmit_receiver, max_slots.clone(), Some(rpc_subscriptions.clone()), - slot_status_notifier, + slot_status_notifier.clone(), ); let (ancestor_duplicate_slots_sender, ancestor_duplicate_slots_receiver) = unbounded(); @@ -274,6 +274,7 @@ impl Tvu { authorized_voter_keypairs, exit: exit.clone(), rpc_subscriptions: rpc_subscriptions.clone(), + slot_status_notifier, leader_schedule_cache: leader_schedule_cache.clone(), accounts_background_request_sender, block_commitment_cache, diff --git a/geyser-plugin-interface/src/geyser_plugin_interface.rs b/geyser-plugin-interface/src/geyser_plugin_interface.rs index 97271310a99f5f..3f4394a84bae8e 100644 --- a/geyser-plugin-interface/src/geyser_plugin_interface.rs +++ b/geyser-plugin-interface/src/geyser_plugin_interface.rs @@ -325,6 +325,9 @@ pub enum SlotStatus { /// All shreds for the slot have been received. Completed, + + /// A new bank fork is created with the slot + CreatedBank, } impl SlotStatus { @@ -335,6 +338,7 @@ impl SlotStatus { SlotStatus::Rooted => "rooted", SlotStatus::FirstShredReceived => "first_shread_received", SlotStatus::Completed => "completed", + SlotStatus::CreatedBank => "created_bank", } } } diff --git a/geyser-plugin-manager/src/slot_status_notifier.rs b/geyser-plugin-manager/src/slot_status_notifier.rs index 573ed97d7787af..27dcd03dac28f3 100644 --- a/geyser-plugin-manager/src/slot_status_notifier.rs +++ b/geyser-plugin-manager/src/slot_status_notifier.rs @@ -33,6 +33,10 @@ impl SlotStatusNotifierInterface for SlotStatusNotifierImpl { fn notify_completed(&self, slot: Slot) { self.notify_slot_status(slot, None, SlotStatus::Completed); } + + fn notify_created_bank(&self, slot: Slot, parent: Slot) { + self.notify_slot_status(slot, Some(parent), SlotStatus::CreatedBank); + } } impl SlotStatusNotifierImpl { diff --git a/rpc/src/slot_status_notifier.rs b/rpc/src/slot_status_notifier.rs index 97a84da42f33bf..38e9bf60a6e091 100644 --- a/rpc/src/slot_status_notifier.rs +++ b/rpc/src/slot_status_notifier.rs @@ -18,6 +18,9 @@ pub trait SlotStatusNotifierInterface { /// Notified when the slot is completed. fn notify_completed(&self, slot: Slot); + + /// Notified when the slot has bank created. + fn notify_created_bank(&self, slot: Slot, parent: Slot); } pub type SlotStatusNotifier = Arc>; From eaec893942c1da53b99ed90098892d9912dc27e7 Mon Sep 17 00:00:00 2001 From: samkim-crypto Date: Tue, 15 Oct 2024 16:45:25 +0900 Subject: [PATCH 03/23] [zk-sdk] Expose `ElGamalPubkey` and `ElGamalKeypair` as wasm (#2996) * add wasm dependencies * expose `ElGamalPubkey` and `ElGamalKeypair` via `wasm_bindgen` * depend on `wasm-bindgen` only when target is `wasm32` * remove `profile.release` changes * add comments on the reason for specific exclusion of dependencies * re-organize type associated functions depending on target * re-organize type associated functions for grouped elgamal depending on target * Move wasm impl into PodElGamalPubkey --------- Co-authored-by: Jon C --- Cargo.lock | 2 + programs/sbf/Cargo.lock | 2 + zk-sdk/Cargo.toml | 4 + zk-sdk/src/encryption/auth_encryption.rs | 53 +++++--- zk-sdk/src/encryption/elgamal.rs | 155 ++++++++++++++--------- zk-sdk/src/encryption/grouped_elgamal.rs | 63 +++++---- zk-sdk/src/encryption/mod.rs | 2 +- zk-sdk/src/encryption/pod/elgamal.rs | 74 +++++++++++ zk-sdk/src/lib.rs | 1 + 9 files changed, 247 insertions(+), 109 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 8be26642cb791d..a138ada09979c6 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -8740,6 +8740,7 @@ dependencies = [ "bytemuck_derive", "curve25519-dalek 4.1.3", "itertools 0.12.1", + "js-sys", "lazy_static", "merlin", "num-derive", @@ -8755,6 +8756,7 @@ dependencies = [ "subtle", "thiserror", "tiny-bip39", + "wasm-bindgen", "zeroize", ] diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index c77621fa74892a..2b2a17b0978b2f 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -7220,6 +7220,7 @@ dependencies = [ "bytemuck_derive", "curve25519-dalek 4.1.3", "itertools 0.12.1", + "js-sys", "lazy_static", "merlin", "num-derive", @@ -7234,6 +7235,7 @@ dependencies = [ "solana-sdk", "subtle", "thiserror", + "wasm-bindgen", "zeroize", ] diff --git a/zk-sdk/Cargo.toml b/zk-sdk/Cargo.toml index 5a1ff83a620b9c..8dc8ffc18029fe 100644 --- a/zk-sdk/Cargo.toml +++ b/zk-sdk/Cargo.toml @@ -38,6 +38,10 @@ solana-sdk = { workspace = true } subtle = { workspace = true } zeroize = { workspace = true, features = ["zeroize_derive"] } +[target.'cfg(target_arch = "wasm32")'.dependencies] +js-sys = { workspace = true } +wasm-bindgen = { workspace = true } + [lib] crate-type = ["cdylib", "rlib"] diff --git a/zk-sdk/src/encryption/auth_encryption.rs b/zk-sdk/src/encryption/auth_encryption.rs index 14c145decb6736..15ed58069b80ca 100644 --- a/zk-sdk/src/encryption/auth_encryption.rs +++ b/zk-sdk/src/encryption/auth_encryption.rs @@ -13,7 +13,17 @@ use { }, base64::{prelude::BASE64_STANDARD, Engine}, rand::{rngs::OsRng, Rng}, - sha3::{Digest, Sha3_512}, + std::{convert::TryInto, fmt}, + zeroize::Zeroize, +}; +// Currently, `wasm_bindgen` exports types and functions included in the current crate, but all +// types and functions exported for wasm targets in all of its dependencies +// (https://github.com/rustwasm/wasm-bindgen/issues/3759). We specifically exclude some of the +// dependencies that will cause unnecessary bloat to the wasm binary. +#[cfg(not(target_arch = "wasm32"))] +use { + sha3::Digest, + sha3::Sha3_512, solana_derivation_path::DerivationPath, solana_sdk::{ signature::Signature, @@ -23,12 +33,10 @@ use { }, }, std::{ - convert::TryInto, - error, fmt, + error, io::{Read, Write}, }, subtle::ConstantTimeEq, - zeroize::Zeroize, }; /// Byte length of an authenticated encryption nonce component @@ -82,6 +90,25 @@ impl AuthenticatedEncryption { #[derive(Debug, Zeroize, Eq, PartialEq)] pub struct AeKey([u8; AE_KEY_LEN]); +impl AeKey { + /// Generates a random authenticated encryption key. + /// + /// This function is randomized. It internally samples a scalar element using `OsRng`. + pub fn new_rand() -> Self { + AuthenticatedEncryption::keygen() + } + + /// Encrypts an amount under the authenticated encryption key. + pub fn encrypt(&self, amount: u64) -> AeCiphertext { + AuthenticatedEncryption::encrypt(self, amount) + } + + pub fn decrypt(&self, ciphertext: &AeCiphertext) -> Option { + AuthenticatedEncryption::decrypt(self, ciphertext) + } +} + +#[cfg(not(target_arch = "wasm32"))] impl AeKey { /// Deterministically derives an authenticated encryption key from a Solana signer and a public /// seed. @@ -130,24 +157,9 @@ impl AeKey { result.to_vec() } - - /// Generates a random authenticated encryption key. - /// - /// This function is randomized. It internally samples a scalar element using `OsRng`. - pub fn new_rand() -> Self { - AuthenticatedEncryption::keygen() - } - - /// Encrypts an amount under the authenticated encryption key. - pub fn encrypt(&self, amount: u64) -> AeCiphertext { - AuthenticatedEncryption::encrypt(self, amount) - } - - pub fn decrypt(&self, ciphertext: &AeCiphertext) -> Option { - AuthenticatedEncryption::decrypt(self, ciphertext) - } } +#[cfg(not(target_arch = "wasm32"))] impl EncodableKey for AeKey { fn read(reader: &mut R) -> Result> { let bytes: [u8; AE_KEY_LEN] = serde_json::from_reader(reader)?; @@ -162,6 +174,7 @@ impl EncodableKey for AeKey { } } +#[cfg(not(target_arch = "wasm32"))] impl SeedDerivable for AeKey { fn from_seed(seed: &[u8]) -> Result> { const MINIMUM_SEED_LEN: usize = AE_KEY_LEN; diff --git a/zk-sdk/src/encryption/elgamal.rs b/zk-sdk/src/encryption/elgamal.rs index 850db36329c715..9df73d6b199b85 100644 --- a/zk-sdk/src/encryption/elgamal.rs +++ b/zk-sdk/src/encryption/elgamal.rs @@ -14,10 +14,33 @@ //! As the messages are encrypted as scalar elements (a.k.a. in the "exponent"), one must solve the //! discrete log to recover the originally encrypted value. +#[cfg(target_arch = "wasm32")] +use wasm_bindgen::prelude::*; +// Currently, `wasm_bindgen` exports types and functions included in the current crate, but all +// types and functions exported for wasm targets in all of its dependencies +// (https://github.com/rustwasm/wasm-bindgen/issues/3759). We specifically exclude some of the +// dependencies that will cause unnecessary bloat to the wasm binary. +#[cfg(not(target_arch = "wasm32"))] +use { + crate::encryption::discrete_log::DiscreteLog, + sha3::Digest, + solana_derivation_path::DerivationPath, + solana_sdk::{ + signature::Signature, + signer::{ + keypair::generate_seed_from_seed_phrase_and_passphrase, EncodableKey, EncodableKeypair, + SeedDerivable, Signer, SignerError, + }, + }, + std::{ + error, + io::{Read, Write}, + path::Path, + }, +}; use { crate::{ encryption::{ - discrete_log::DiscreteLog, pedersen::{Pedersen, PedersenCommitment, PedersenOpening, G, H}, DECRYPT_HANDLE_LEN, ELGAMAL_CIPHERTEXT_LEN, ELGAMAL_KEYPAIR_LEN, ELGAMAL_PUBKEY_LEN, ELGAMAL_SECRET_KEY_LEN, PEDERSEN_COMMITMENT_LEN, @@ -33,21 +56,8 @@ use { }, rand::rngs::OsRng, serde::{Deserialize, Serialize}, - sha3::{Digest, Sha3_512}, - solana_derivation_path::DerivationPath, - solana_sdk::{ - signature::Signature, - signer::{ - keypair::generate_seed_from_seed_phrase_and_passphrase, EncodableKey, EncodableKeypair, - SeedDerivable, Signer, SignerError, - }, - }, - std::{ - convert::TryInto, - error, fmt, - io::{Read, Write}, - path::Path, - }, + sha3::Sha3_512, + std::{convert::TryInto, fmt}, subtle::{Choice, ConstantTimeEq}, zeroize::Zeroize, }; @@ -116,6 +126,7 @@ impl ElGamal { /// /// The output of this function is of type `DiscreteLog`. To recover, the originally encrypted /// amount, use `DiscreteLog::decode`. + #[cfg(not(target_arch = "wasm32"))] fn decrypt(secret: &ElGamalSecretKey, ciphertext: &ElGamalCiphertext) -> DiscreteLog { DiscreteLog::new( *G, @@ -128,6 +139,7 @@ impl ElGamal { /// /// If the originally encrypted amount is not a positive 32-bit number, then the function /// returns `None`. + #[cfg(not(target_arch = "wasm32"))] fn decrypt_u32(secret: &ElGamalSecretKey, ciphertext: &ElGamalCiphertext) -> Option { let discrete_log_instance = Self::decrypt(secret, ciphertext); discrete_log_instance.decode_u32() @@ -137,6 +149,7 @@ impl ElGamal { /// A (twisted) ElGamal encryption keypair. /// /// The instances of the secret key are zeroized on drop. +#[cfg_attr(target_arch = "wasm32", wasm_bindgen)] #[derive(Clone, Debug, Deserialize, PartialEq, Eq, Serialize, Zeroize)] pub struct ElGamalKeypair { /// The public half of this keypair. @@ -145,6 +158,31 @@ pub struct ElGamalKeypair { secret: ElGamalSecretKey, } +#[cfg_attr(target_arch = "wasm32", wasm_bindgen)] +impl ElGamalKeypair { + /// Generates the public and secret keys for ElGamal encryption. + /// + /// This function is randomized. It internally samples a scalar element using `OsRng`. + pub fn new_rand() -> Self { + ElGamal::keygen() + } + + pub fn pubkey_owned(&self) -> ElGamalPubkey { + self.public + } +} + +impl ElGamalKeypair { + pub fn pubkey(&self) -> &ElGamalPubkey { + &self.public + } + + pub fn secret(&self) -> &ElGamalSecretKey { + &self.secret + } +} + +#[cfg(not(target_arch = "wasm32"))] impl ElGamalKeypair { /// Create an ElGamal keypair from an ElGamal public key and an ElGamal secret key. /// @@ -187,21 +225,6 @@ impl ElGamalKeypair { Ok(Self::new(secret)) } - /// Generates the public and secret keys for ElGamal encryption. - /// - /// This function is randomized. It internally samples a scalar element using `OsRng`. - pub fn new_rand() -> Self { - ElGamal::keygen() - } - - pub fn pubkey(&self) -> &ElGamalPubkey { - &self.public - } - - pub fn secret(&self) -> &ElGamalSecretKey { - &self.secret - } - /// Reads a JSON-encoded keypair from a `Reader` implementor pub fn read_json(reader: &mut R) -> Result> { let bytes: Vec = serde_json::from_reader(reader)?; @@ -232,6 +255,7 @@ impl ElGamalKeypair { } } +#[cfg(not(target_arch = "wasm32"))] impl EncodableKey for ElGamalKeypair { fn read(reader: &mut R) -> Result> { Self::read_json(reader) @@ -276,6 +300,7 @@ impl From<&ElGamalKeypair> for [u8; ELGAMAL_KEYPAIR_LEN] { } } +#[cfg(not(target_arch = "wasm32"))] impl SeedDerivable for ElGamalKeypair { fn from_seed(seed: &[u8]) -> Result> { let secret = ElGamalSecretKey::from_seed(seed)?; @@ -301,6 +326,7 @@ impl SeedDerivable for ElGamalKeypair { } } +#[cfg(not(target_arch = "wasm32"))] impl EncodableKeypair for ElGamalKeypair { type Pubkey = ElGamalPubkey; @@ -310,6 +336,7 @@ impl EncodableKeypair for ElGamalKeypair { } /// Public key for the ElGamal encryption scheme. +#[cfg_attr(target_arch = "wasm32", wasm_bindgen)] #[derive(Clone, Copy, Debug, Default, Deserialize, Eq, PartialEq, Serialize, Zeroize)] pub struct ElGamalPubkey(RistrettoPoint); impl ElGamalPubkey { @@ -348,6 +375,7 @@ impl ElGamalPubkey { } } +#[cfg(not(target_arch = "wasm32"))] impl EncodableKey for ElGamalPubkey { fn read(reader: &mut R) -> Result> { let bytes: Vec = serde_json::from_reader(reader)?; @@ -410,6 +438,38 @@ impl From<&ElGamalPubkey> for [u8; ELGAMAL_PUBKEY_LEN] { #[derive(Clone, Debug, Deserialize, Serialize, Zeroize)] #[zeroize(drop)] pub struct ElGamalSecretKey(Scalar); +impl ElGamalSecretKey { + /// Randomly samples an ElGamal secret key. + /// + /// This function is randomized. It internally samples a scalar element using `OsRng`. + pub fn new_rand() -> Self { + ElGamalSecretKey(Scalar::random(&mut OsRng)) + } + + /// Derive an ElGamal secret key from an entropy seed. + pub fn from_seed(seed: &[u8]) -> Result { + const MINIMUM_SEED_LEN: usize = ELGAMAL_SECRET_KEY_LEN; + const MAXIMUM_SEED_LEN: usize = 65535; + + if seed.len() < MINIMUM_SEED_LEN { + return Err(ElGamalError::SeedLengthTooShort); + } + if seed.len() > MAXIMUM_SEED_LEN { + return Err(ElGamalError::SeedLengthTooLong); + } + Ok(ElGamalSecretKey(Scalar::hash_from_bytes::(seed))) + } + + pub fn get_scalar(&self) -> &Scalar { + &self.0 + } + + pub fn as_bytes(&self) -> &[u8; ELGAMAL_SECRET_KEY_LEN] { + self.0.as_bytes() + } +} + +#[cfg(not(target_arch = "wasm32"))] impl ElGamalSecretKey { /// Deterministically derives an ElGamal secret key from a Solana signer and a public seed. /// @@ -458,31 +518,6 @@ impl ElGamalSecretKey { result.to_vec() } - /// Randomly samples an ElGamal secret key. - /// - /// This function is randomized. It internally samples a scalar element using `OsRng`. - pub fn new_rand() -> Self { - ElGamalSecretKey(Scalar::random(&mut OsRng)) - } - - /// Derive an ElGamal secret key from an entropy seed. - pub fn from_seed(seed: &[u8]) -> Result { - const MINIMUM_SEED_LEN: usize = ELGAMAL_SECRET_KEY_LEN; - const MAXIMUM_SEED_LEN: usize = 65535; - - if seed.len() < MINIMUM_SEED_LEN { - return Err(ElGamalError::SeedLengthTooShort); - } - if seed.len() > MAXIMUM_SEED_LEN { - return Err(ElGamalError::SeedLengthTooLong); - } - Ok(ElGamalSecretKey(Scalar::hash_from_bytes::(seed))) - } - - pub fn get_scalar(&self) -> &Scalar { - &self.0 - } - /// Decrypts a ciphertext using the ElGamal secret key. /// /// The output of this function is of type `DiscreteLog`. To recover, the originally encrypted @@ -495,12 +530,9 @@ impl ElGamalSecretKey { pub fn decrypt_u32(&self, ciphertext: &ElGamalCiphertext) -> Option { ElGamal::decrypt_u32(self, ciphertext) } - - pub fn as_bytes(&self) -> &[u8; ELGAMAL_SECRET_KEY_LEN] { - self.0.as_bytes() - } } +#[cfg(not(target_arch = "wasm32"))] impl EncodableKey for ElGamalSecretKey { fn read(reader: &mut R) -> Result> { let bytes: Vec = serde_json::from_reader(reader)?; @@ -517,6 +549,7 @@ impl EncodableKey for ElGamalSecretKey { } } +#[cfg(not(target_arch = "wasm32"))] impl SeedDerivable for ElGamalSecretKey { fn from_seed(seed: &[u8]) -> Result> { let key = Self::from_seed(seed)?; @@ -633,6 +666,7 @@ impl ElGamalCiphertext { /// /// The output of this function is of type `DiscreteLog`. To recover, the originally encrypted /// amount, use `DiscreteLog::decode`. + #[cfg(not(target_arch = "wasm32"))] pub fn decrypt(&self, secret: &ElGamalSecretKey) -> DiscreteLog { ElGamal::decrypt(secret, self) } @@ -642,6 +676,7 @@ impl ElGamalCiphertext { /// /// If the originally encrypted amount is not a positive 32-bit number, then the function /// returns `None`. + #[cfg(not(target_arch = "wasm32"))] pub fn decrypt_u32(&self, secret: &ElGamalSecretKey) -> Option { ElGamal::decrypt_u32(secret, self) } diff --git a/zk-sdk/src/encryption/grouped_elgamal.rs b/zk-sdk/src/encryption/grouped_elgamal.rs index b786d251973c38..e1eee744f98540 100644 --- a/zk-sdk/src/encryption/grouped_elgamal.rs +++ b/zk-sdk/src/encryption/grouped_elgamal.rs @@ -12,11 +12,12 @@ //! ElGamal ciphertext. //! +#[cfg(not(target_arch = "wasm32"))] +use crate::encryption::{discrete_log::DiscreteLog, elgamal::ElGamalSecretKey}; use { crate::{ encryption::{ - discrete_log::DiscreteLog, - elgamal::{DecryptHandle, ElGamalCiphertext, ElGamalPubkey, ElGamalSecretKey}, + elgamal::{DecryptHandle, ElGamalCiphertext, ElGamalPubkey}, pedersen::{Pedersen, PedersenCommitment, PedersenOpening}, }, RISTRETTO_POINT_LEN, @@ -92,7 +93,10 @@ impl GroupedElGamal { handle: *handle, }) } +} +#[cfg(not(target_arch = "wasm32"))] +impl GroupedElGamal { /// Decrypts a grouped ElGamal ciphertext using an ElGamal secret key pertaining to a /// decryption handle at a specified index. /// @@ -142,32 +146,6 @@ impl GroupedElGamalCiphertext { GroupedElGamal::to_elgamal_ciphertext(self, index) } - /// Decrypts the grouped ElGamal ciphertext using an ElGamal secret key pertaining to a - /// specified index. - /// - /// The output of this function is of type `DiscreteLog`. To recover the originally encrypted - /// amount, use `DiscreteLog::decode`. - pub fn decrypt( - &self, - secret: &ElGamalSecretKey, - index: usize, - ) -> Result { - GroupedElGamal::decrypt(self, secret, index) - } - - /// Decrypts the grouped ElGamal ciphertext to a number that is interpreted as a positive 32-bit - /// number (but still of type `u64`). - /// - /// If the originally encrypted amount is not a positive 32-bit number, then the function - /// returns `None`. - pub fn decrypt_u32( - &self, - secret: &ElGamalSecretKey, - index: usize, - ) -> Result, GroupedElGamalError> { - GroupedElGamal::decrypt_u32(self, secret, index) - } - /// The expected length of a serialized grouped ElGamal ciphertext. /// /// A grouped ElGamal ciphertext consists of a Pedersen commitment and an array of decryption @@ -209,6 +187,35 @@ impl GroupedElGamalCiphertext { } } +#[cfg(not(target_arch = "wasm32"))] +impl GroupedElGamalCiphertext { + /// Decrypts the grouped ElGamal ciphertext using an ElGamal secret key pertaining to a + /// specified index. + /// + /// The output of this function is of type `DiscreteLog`. To recover the originally encrypted + /// amount, use `DiscreteLog::decode`. + pub fn decrypt( + &self, + secret: &ElGamalSecretKey, + index: usize, + ) -> Result { + GroupedElGamal::decrypt(self, secret, index) + } + + /// Decrypts the grouped ElGamal ciphertext to a number that is interpreted as a positive 32-bit + /// number (but still of type `u64`). + /// + /// If the originally encrypted amount is not a positive 32-bit number, then the function + /// returns `None`. + pub fn decrypt_u32( + &self, + secret: &ElGamalSecretKey, + index: usize, + ) -> Result, GroupedElGamalError> { + GroupedElGamal::decrypt_u32(self, secret, index) + } +} + #[cfg(test)] mod tests { use {super::*, crate::encryption::elgamal::ElGamalKeypair}; diff --git a/zk-sdk/src/encryption/mod.rs b/zk-sdk/src/encryption/mod.rs index 8cad6217fc4c68..28a9ae6bf7fded 100644 --- a/zk-sdk/src/encryption/mod.rs +++ b/zk-sdk/src/encryption/mod.rs @@ -17,7 +17,7 @@ use crate::{RISTRETTO_POINT_LEN, SCALAR_LEN}; pub(crate) mod macros; #[cfg(not(target_os = "solana"))] pub mod auth_encryption; -#[cfg(not(target_os = "solana"))] +#[cfg(all(not(target_os = "solana"), not(target_arch = "wasm32")))] pub mod discrete_log; #[cfg(not(target_os = "solana"))] pub mod elgamal; diff --git a/zk-sdk/src/encryption/pod/elgamal.rs b/zk-sdk/src/encryption/pod/elgamal.rs index 6b30f27a127e3a..1dac45378b588c 100644 --- a/zk-sdk/src/encryption/pod/elgamal.rs +++ b/zk-sdk/src/encryption/pod/elgamal.rs @@ -17,6 +17,11 @@ use { bytemuck::Zeroable, std::fmt, }; +#[cfg(target_arch = "wasm32")] +use { + js_sys::{Array, Uint8Array}, + wasm_bindgen::prelude::*, +}; /// Maximum length of a base64 encoded ElGamal public key const ELGAMAL_PUBKEY_MAX_BASE64_LEN: usize = 44; @@ -80,8 +85,77 @@ impl TryFrom for ElGamalCiphertext { /// The `ElGamalPubkey` type as a `Pod`. #[derive(Clone, Copy, Default, bytemuck_derive::Pod, bytemuck_derive::Zeroable, PartialEq, Eq)] #[repr(transparent)] +#[cfg_attr(target_arch = "wasm32", wasm_bindgen)] pub struct PodElGamalPubkey(pub(crate) [u8; ELGAMAL_PUBKEY_LEN]); +#[cfg(target_arch = "wasm32")] +#[allow(non_snake_case)] +#[cfg_attr(target_arch = "wasm32", wasm_bindgen)] +impl PodElGamalPubkey { + /// Create a new `PodElGamalPubkey` object + /// + /// * `value` - optional public key as a base64 encoded string, `Uint8Array`, `[number]` + #[wasm_bindgen(constructor)] + pub fn constructor(value: JsValue) -> Result { + if let Some(base64_str) = value.as_string() { + base64_str + .parse::() + .map_err(|e| e.to_string().into()) + } else if let Some(uint8_array) = value.dyn_ref::() { + bytemuck::try_from_bytes(&uint8_array.to_vec()) + .map_err(|err| JsValue::from(format!("Invalid Uint8Array ElGamalPubkey: {err:?}"))) + .map(|pubkey| *pubkey) + } else if let Some(array) = value.dyn_ref::() { + let mut bytes = vec![]; + let iterator = js_sys::try_iter(&array.values())?.expect("array to be iterable"); + for x in iterator { + let x = x?; + + if let Some(n) = x.as_f64() { + if (0. ..=255.).contains(&n) { + bytes.push(n as u8); + continue; + } + } + return Err(format!("Invalid array argument: {:?}", x).into()); + } + + bytemuck::try_from_bytes(&bytes) + .map_err(|err| JsValue::from(format!("Invalid Array pubkey: {err:?}"))) + .map(|pubkey| *pubkey) + } else if value.is_undefined() { + Ok(PodElGamalPubkey::default()) + } else { + Err("Unsupported argument".into()) + } + } + + /// Return the base64 string representation of the public key + pub fn toString(&self) -> String { + self.to_string() + } + + /// Checks if two `ElGamalPubkey`s are equal + pub fn equals(&self, other: &PodElGamalPubkey) -> bool { + self == other + } + + /// Return the `Uint8Array` representation of the public key + pub fn toBytes(&self) -> Box<[u8]> { + self.0.into() + } + + pub fn compressed(decoded: &ElGamalPubkey) -> PodElGamalPubkey { + (*decoded).into() + } + + pub fn decompressed(&self) -> Result { + (*self) + .try_into() + .map_err(|err| JsValue::from(format!("Invalid ElGamalPubkey: {err:?}"))) + } +} + impl fmt::Debug for PodElGamalPubkey { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { write!(f, "{:?}", self.0) diff --git a/zk-sdk/src/lib.rs b/zk-sdk/src/lib.rs index 824a4718f14c5c..8d7388475f2f36 100644 --- a/zk-sdk/src/lib.rs +++ b/zk-sdk/src/lib.rs @@ -25,6 +25,7 @@ pub mod pod; mod range_proof; mod sigma_proofs; mod transcript; +#[cfg(not(target_arch = "wasm32"))] pub mod zk_elgamal_proof_program; /// Byte length of a compressed Ristretto point or scalar in Curve255519 From e05f75455e2372f8341c21ed8d21d1f9a5146de3 Mon Sep 17 00:00:00 2001 From: Jon C Date: Tue, 15 Oct 2024 11:52:53 +0200 Subject: [PATCH 04/23] package-metadata: Add macro to define program id from Cargo.toml (#1806) * package-metadata: Add package and macro * Use the macro in a program as a test * Move test to cargo-build-sbf, update version * Add changelog entry * Revert simulation change --- CHANGELOG.md | 13 +++ Cargo.lock | 8 ++ Cargo.toml | 2 + .../tests/crates/package-metadata/Cargo.toml | 2 + .../tests/crates/package-metadata/src/lib.rs | 1 + sdk/package-metadata/Cargo.toml | 17 ++++ sdk/package-metadata/src/lib.rs | 90 +++++++++++++++++++ 7 files changed, 133 insertions(+) create mode 100644 sdk/package-metadata/Cargo.toml create mode 100644 sdk/package-metadata/src/lib.rs diff --git a/CHANGELOG.md b/CHANGELOG.md index 8b70c0927dbe14..916d801e4ae443 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -37,6 +37,19 @@ or tools-version = "1.43" ``` The order of precedence for the chosen tools version goes: `--tools-version` argument, package version, workspace version, and finally default version. + * `package-metadata`: specify a program's id in Cargo.toml for easy consumption by downstream users and tools using `solana-package-metadata` (#1806). For example: +```toml +[package.metadata.solana] +program-id = "MyProgram1111111111111111111111111111111111" +``` +Can be consumed in the program crate: +```rust +solana_package_metadata::declare_id_with_package_metadata!("solana.program-id"); +``` +This is equivalent to writing: +```rust +solana_pubkey::declare_id!("MyProgram1111111111111111111111111111111111"); +``` * `agave-validator`: Update PoH speed check to compare against current hash rate from a Bank (#2447) * `solana-test-validator`: Add `--clone-feature-set` flag to mimic features from a target cluster (#2480) * `solana-genesis`: the `--cluster-type` parameter now clones the feature set from the target cluster (#2587) diff --git a/Cargo.lock b/Cargo.lock index a138ada09979c6..a610aaaca948f4 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -7160,6 +7160,14 @@ dependencies = [ "solana-sdk", ] +[[package]] +name = "solana-package-metadata" +version = "2.1.0" +dependencies = [ + "solana-package-metadata-macro", + "solana-pubkey", +] + [[package]] name = "solana-package-metadata-macro" version = "2.1.0" diff --git a/Cargo.toml b/Cargo.toml index db33afda423e7f..5ec30da8b2c460 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -117,6 +117,7 @@ members = [ "sdk/instruction", "sdk/macro", "sdk/msg", + "sdk/package-metadata", "sdk/package-metadata-macro", "sdk/program", "sdk/program-error", @@ -434,6 +435,7 @@ solana-msg = { path = "sdk/msg", version = "=2.1.0" } solana-net-utils = { path = "net-utils", version = "=2.1.0" } solana-nohash-hasher = "0.2.1" solana-notifier = { path = "notifier", version = "=2.1.0" } +solana-package-metadata = { path = "sdk/package-metadata", version = "=2.1.0" } solana-package-metadata-macro = { path = "sdk/package-metadata-macro", version = "=2.1.0" } solana-perf = { path = "perf", version = "=2.1.0" } solana-poh = { path = "poh", version = "=2.1.0" } diff --git a/sdk/cargo-build-sbf/tests/crates/package-metadata/Cargo.toml b/sdk/cargo-build-sbf/tests/crates/package-metadata/Cargo.toml index 4de95889d4bf4d..b4ff4139640939 100644 --- a/sdk/cargo-build-sbf/tests/crates/package-metadata/Cargo.toml +++ b/sdk/cargo-build-sbf/tests/crates/package-metadata/Cargo.toml @@ -11,8 +11,10 @@ publish = false [package.metadata.solana] tools-version = "v1.43" +program-id = "MyProgram1111111111111111111111111111111111" [dependencies] +solana-package-metadata = { path = "../../../../package-metadata", version = "=2.1.0" } solana-program = { path = "../../../../program", version = "=2.1.0" } [lib] diff --git a/sdk/cargo-build-sbf/tests/crates/package-metadata/src/lib.rs b/sdk/cargo-build-sbf/tests/crates/package-metadata/src/lib.rs index a6f2c05b770881..ee364d392441a8 100644 --- a/sdk/cargo-build-sbf/tests/crates/package-metadata/src/lib.rs +++ b/sdk/cargo-build-sbf/tests/crates/package-metadata/src/lib.rs @@ -2,6 +2,7 @@ use solana_program::{account_info::AccountInfo, entrypoint::ProgramResult, pubkey::Pubkey}; +solana_package_metadata::declare_id_with_package_metadata!("solana.program-id"); solana_program::entrypoint!(process_instruction); fn process_instruction( _program_id: &Pubkey, diff --git a/sdk/package-metadata/Cargo.toml b/sdk/package-metadata/Cargo.toml new file mode 100644 index 00000000000000..8f73e50055f7d4 --- /dev/null +++ b/sdk/package-metadata/Cargo.toml @@ -0,0 +1,17 @@ +[package] +name = "solana-package-metadata" +description = "Solana Package Metadata" +documentation = "https://docs.rs/solana-package-metadata" +version = { workspace = true } +authors = { workspace = true } +repository = { workspace = true } +homepage = { workspace = true } +license = { workspace = true } +edition = { workspace = true } + +[dependencies] +solana-package-metadata-macro = { workspace = true } +solana-pubkey = { workspace = true } + +[package.metadata.docs.rs] +targets = ["x86_64-unknown-linux-gnu"] diff --git a/sdk/package-metadata/src/lib.rs b/sdk/package-metadata/src/lib.rs new file mode 100644 index 00000000000000..28fdf08cca35ff --- /dev/null +++ b/sdk/package-metadata/src/lib.rs @@ -0,0 +1,90 @@ +/// Macro for accessing data from the `package.metadata` section of the Cargo manifest +/// +/// # Arguments +/// * `key` - A string slice of a dot-separated path to the TOML key of interest +/// +/// # Example +/// Given the following `Cargo.toml`: +/// ```ignore +/// [package] +/// name = "MyApp" +/// version = "0.1.0" +/// +/// [package.metadata] +/// copyright = "Copyright (c) 2024 ACME Inc." +/// ``` +/// +/// You can fetch the copyright with the following: +/// ```ignore +/// use solana_package_metadata::package_metadata; +/// +/// pub fn main() { +/// let copyright = package_metadata!("copyright"); +/// assert_eq!(copyright, "Copyright (c) 2024 ACME Inc."); +/// } +/// ``` +/// +/// ## TOML Support +/// This macro only supports static data: +/// * Strings +/// * Integers +/// * Floating-point numbers +/// * Booleans +/// * Datetimes +/// * Arrays +/// +/// ## Array Example +/// Given the following Cargo manifest: +/// ```ignore +/// [package.metadata.arrays] +/// some_array = [ 1, 2, 3 ] +/// ``` +/// +/// This is legal: +/// ```ignore +/// static ARR: [i64; 3] = package_metadata!("arrays.some_array"); +/// ``` +/// +/// It does *not* currently support accessing TOML array elements directly. +/// TOML tables are not supported. +pub use solana_package_metadata_macro::package_metadata; +/// Re-export solana_pubkey::declare_id for easy usage within the macro +pub use solana_pubkey::declare_id; + +/// Convenience macro for declaring a program id from Cargo.toml package metadata. +/// +/// # Arguments +/// * `key` - A string slice of a dot-separated path to the TOML key of interest +/// +/// # Example +/// Given the following `Cargo.toml`: +/// ```ignore +/// [package] +/// name = "my-solana-program" +/// version = "0.1.0" +/// +/// [package.metadata.solana] +/// program-id = "MyProgram1111111111111111111111111111111111" +/// ``` +/// +/// A program can use the program id declared in its `Cargo.toml` as the program +/// id in code: +/// +/// ```ignore +/// declare_id_with_package_metadata!("solana.program-id"); +/// ``` +/// +/// This program id behaves exactly as if the developer had written: +/// +/// ``` +/// solana_pubkey::declare_id!("MyProgram1111111111111111111111111111111111"); +/// ``` +/// +/// Meaning that it's possible to refer to the program id using `crate::id()`, +/// without needing to specify the program id in multiple places. +#[macro_export] +macro_rules! declare_id_with_package_metadata { + ($key:literal) => { + $crate::declare_id!($crate::package_metadata!($key)); + }; +} From 96955661f72941bb772a0f514fe2a31029cf9c87 Mon Sep 17 00:00:00 2001 From: Jon C Date: Tue, 15 Oct 2024 11:55:39 +0200 Subject: [PATCH 05/23] token-2022: Use mainnet-beta binary in all tools (#3165) #### Problem The binary of token-2022 bundled in program-test and fetch-spl.sh is very out of date with what's currently running on mainnet. #### Summary of changes Update the shared object and version to fetch. --- fetch-spl.sh | 2 +- program-test/src/programs.rs | 2 +- .../src/programs/spl_token_2022-1.0.0.so | Bin 535256 -> 0 bytes .../src/programs/spl_token_2022-5.0.2.so | Bin 0 -> 541936 bytes 4 files changed, 2 insertions(+), 2 deletions(-) delete mode 100755 program-test/src/programs/spl_token_2022-1.0.0.so create mode 100755 program-test/src/programs/spl_token_2022-5.0.2.so diff --git a/fetch-spl.sh b/fetch-spl.sh index 97fb1c50aa52eb..17f3c68a86df78 100755 --- a/fetch-spl.sh +++ b/fetch-spl.sh @@ -45,7 +45,7 @@ fetch_program() { } fetch_program token 3.5.0 TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA BPFLoader2111111111111111111111111111111111 -fetch_program token-2022 1.0.0 TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb BPFLoaderUpgradeab1e11111111111111111111111 +fetch_program token-2022 5.0.2 TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb BPFLoaderUpgradeab1e11111111111111111111111 fetch_program memo 1.0.0 Memo1UhkJRfHyvLMcVucJwxXeuD728EqVDDwQDxFMNo BPFLoader1111111111111111111111111111111111 fetch_program memo 3.0.0 MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr BPFLoader2111111111111111111111111111111111 fetch_program associated-token-account 1.1.2 ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL BPFLoader2111111111111111111111111111111111 diff --git a/program-test/src/programs.rs b/program-test/src/programs.rs index e839b2c090097a..f4d773fbdeffb0 100644 --- a/program-test/src/programs.rs +++ b/program-test/src/programs.rs @@ -21,7 +21,7 @@ static SPL_PROGRAMS: &[(Pubkey, Pubkey, &[u8])] = &[ ( solana_inline_spl::token_2022::ID, solana_sdk::bpf_loader_upgradeable::ID, - include_bytes!("programs/spl_token_2022-1.0.0.so"), + include_bytes!("programs/spl_token_2022-5.0.2.so"), ), ( spl_memo_1_0::ID, diff --git a/program-test/src/programs/spl_token_2022-1.0.0.so b/program-test/src/programs/spl_token_2022-1.0.0.so deleted file mode 100755 index 796fafc4cc13ab3b2e1b00551f2e0c5cb4107fe4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 535256 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 literal 0 HcmV?d00001 From c234605ae3fa9a1d0957a14e1889a620a56573b6 Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 15:56:19 +0400 Subject: [PATCH 06/23] move sanitize crate to sdk dir (#3073) --- Cargo.toml | 4 ++-- {sanitize => sdk/sanitize}/Cargo.toml | 0 {sanitize => sdk/sanitize}/src/lib.rs | 0 3 files changed, 2 insertions(+), 2 deletions(-) rename {sanitize => sdk/sanitize}/Cargo.toml (100%) rename {sanitize => sdk/sanitize}/src/lib.rs (100%) diff --git a/Cargo.toml b/Cargo.toml index 5ec30da8b2c460..cdecc0af7dcfe4 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -99,7 +99,6 @@ members = [ "rpc-test", "runtime", "runtime-transaction", - "sanitize", "sdk", "sdk/account", "sdk/account-info", @@ -126,6 +125,7 @@ members = [ "sdk/program-pack", "sdk/pubkey", "sdk/rent", + "sdk/sanitize", "sdk/serde-varint", "sdk/serialize-utils", "sdk/sha256-hasher", @@ -453,7 +453,7 @@ solana-quic-client = { path = "quic-client", version = "=2.1.0" } solana-rayon-threadlimit = { path = "rayon-threadlimit", version = "=2.1.0" } solana-remote-wallet = { path = "remote-wallet", version = "=2.1.0", default-features = false } solana-rent = { path = "sdk/rent", version = "=2.1.0", default-features = false } -solana-sanitize = { path = "sanitize", version = "=2.1.0" } +solana-sanitize = { path = "sdk/sanitize", version = "=2.1.0" } solana-serde-varint = { path = "sdk/serde-varint", version = "=2.1.0" } solana-serialize-utils = { path = "sdk/serialize-utils", version = "=2.1.0" } solana-sha256-hasher = { path = "sdk/sha256-hasher", version = "=2.1.0" } diff --git a/sanitize/Cargo.toml b/sdk/sanitize/Cargo.toml similarity index 100% rename from sanitize/Cargo.toml rename to sdk/sanitize/Cargo.toml diff --git a/sanitize/src/lib.rs b/sdk/sanitize/src/lib.rs similarity index 100% rename from sanitize/src/lib.rs rename to sdk/sanitize/src/lib.rs From cc1873f60630569f000ff922754ec89c8afa62ff Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 16:21:56 +0400 Subject: [PATCH 07/23] remove solana-program from solana-feature-set (#3140) * remove solana-program from solana-feature-set * fix log-analyzer deps which this PR somehow breaks * add back Slot and Epoch aliases --- Cargo.lock | 7 +- log-analyzer/Cargo.toml | 1 + log-analyzer/src/main.rs | 2 +- programs/sbf/Cargo.lock | 6 +- sdk/feature-set/Cargo.toml | 6 +- sdk/feature-set/src/lib.rs | 434 ++++++++++++++++++------------------- 6 files changed, 234 insertions(+), 222 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index a610aaaca948f4..d9fc78c2b7ca74 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -6658,9 +6658,13 @@ name = "solana-feature-set" version = "2.1.0" dependencies = [ "lazy_static", + "solana-clock", + "solana-epoch-schedule", "solana-frozen-abi", "solana-frozen-abi-macro", - "solana-program", + "solana-hash", + "solana-pubkey", + "solana-sha256-hasher", ] [[package]] @@ -7037,6 +7041,7 @@ dependencies = [ "byte-unit", "clap 3.2.23", "serde", + "serde_derive", "serde_json", "solana-logger", "solana-version", diff --git a/log-analyzer/Cargo.toml b/log-analyzer/Cargo.toml index 21df3661ddd0ea..fff8c9c2d3c745 100644 --- a/log-analyzer/Cargo.toml +++ b/log-analyzer/Cargo.toml @@ -13,6 +13,7 @@ edition = { workspace = true } byte-unit = { workspace = true } clap = { version = "3.1.5", features = ["cargo"] } serde = { workspace = true } +serde_derive = { workspace = true } serde_json = { workspace = true } solana-logger = { workspace = true } solana-version = { workspace = true } diff --git a/log-analyzer/src/main.rs b/log-analyzer/src/main.rs index fcedd7c0dc46cf..32ce3fbb5a27fc 100644 --- a/log-analyzer/src/main.rs +++ b/log-analyzer/src/main.rs @@ -4,7 +4,7 @@ extern crate byte_unit; use { byte_unit::Byte, clap::{crate_description, crate_name, Arg, ArgMatches, Command}, - serde::{Deserialize, Serialize}, + serde_derive::{Deserialize, Serialize}, std::{collections::HashMap, fs, ops::Sub, path::PathBuf}, }; diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index 2b2a17b0978b2f..a6a832fbbd3621 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -5299,7 +5299,11 @@ name = "solana-feature-set" version = "2.1.0" dependencies = [ "lazy_static", - "solana-program", + "solana-clock", + "solana-epoch-schedule", + "solana-hash", + "solana-pubkey", + "solana-sha256-hasher", ] [[package]] diff --git a/sdk/feature-set/Cargo.toml b/sdk/feature-set/Cargo.toml index d6f2824b08982e..7352ff37a9680f 100644 --- a/sdk/feature-set/Cargo.toml +++ b/sdk/feature-set/Cargo.toml @@ -11,13 +11,17 @@ edition = { workspace = true } [dependencies] lazy_static = { workspace = true } +solana-clock = { workspace = true } +solana-epoch-schedule = { workspace = true } solana-frozen-abi = { workspace = true, optional = true, features = [ "frozen-abi", ] } solana-frozen-abi-macro = { workspace = true, optional = true, features = [ "frozen-abi", ] } -solana-program = { workspace = true } +solana-hash = { workspace = true } +solana-pubkey = { workspace = true } +solana-sha256-hasher = { workspace = true } [features] frozen-abi = [ diff --git a/sdk/feature-set/src/lib.rs b/sdk/feature-set/src/lib.rs index 6567404a947db5..83d59749758067 100644 --- a/sdk/feature-set/src/lib.rs +++ b/sdk/feature-set/src/lib.rs @@ -12,7 +12,7 @@ //! through these steps, the PR process will facilitate a keypair holder being picked. That //! person will generate the keypair, provide pubkey for PR, and ultimately enable the feature. //! 2. Add a public module for the feature, specifying keypair pubkey as the id with -//! `solana_program::declare_id!()` within the module. +//! `solana_pubkey::declare_id!()` within the module. //! Additionally, add an entry to `FEATURE_NAMES` map. //! 3. Add desired logic to check for and switch on feature availability. //! @@ -21,854 +21,852 @@ use { lazy_static::lazy_static, - solana_program::{ - clock::Slot, - epoch_schedule::EpochSchedule, - hash::{Hash, Hasher}, - pubkey::Pubkey, - stake_history::Epoch, - }, + solana_clock::{Epoch, Slot}, + solana_epoch_schedule::EpochSchedule, + solana_hash::Hash, + solana_pubkey::Pubkey, + solana_sha256_hasher::Hasher, std::collections::{HashMap, HashSet}, }; pub mod deprecate_rewards_sysvar { - solana_program::declare_id!("GaBtBJvmS4Arjj5W1NmFcyvPjsHN38UGYDq2MDwbs9Qu"); + solana_pubkey::declare_id!("GaBtBJvmS4Arjj5W1NmFcyvPjsHN38UGYDq2MDwbs9Qu"); } pub mod pico_inflation { - solana_program::declare_id!("4RWNif6C2WCNiKVW7otP4G7dkmkHGyKQWRpuZ1pxKU5m"); + solana_pubkey::declare_id!("4RWNif6C2WCNiKVW7otP4G7dkmkHGyKQWRpuZ1pxKU5m"); } pub mod full_inflation { pub mod devnet_and_testnet { - solana_program::declare_id!("DT4n6ABDqs6w4bnfwrXT9rsprcPf6cdDga1egctaPkLC"); + solana_pubkey::declare_id!("DT4n6ABDqs6w4bnfwrXT9rsprcPf6cdDga1egctaPkLC"); } pub mod mainnet { pub mod certusone { pub mod vote { - solana_program::declare_id!("BzBBveUDymEYoYzcMWNQCx3cd4jQs7puaVFHLtsbB6fm"); + solana_pubkey::declare_id!("BzBBveUDymEYoYzcMWNQCx3cd4jQs7puaVFHLtsbB6fm"); } pub mod enable { - solana_program::declare_id!("7XRJcS5Ud5vxGB54JbK9N2vBZVwnwdBNeJW1ibRgD9gx"); + solana_pubkey::declare_id!("7XRJcS5Ud5vxGB54JbK9N2vBZVwnwdBNeJW1ibRgD9gx"); } } } } pub mod secp256k1_program_enabled { - solana_program::declare_id!("E3PHP7w8kB7np3CTQ1qQ2tW3KCtjRSXBQgW9vM2mWv2Y"); + solana_pubkey::declare_id!("E3PHP7w8kB7np3CTQ1qQ2tW3KCtjRSXBQgW9vM2mWv2Y"); } pub mod spl_token_v2_multisig_fix { - solana_program::declare_id!("E5JiFDQCwyC6QfT9REFyMpfK2mHcmv1GUDySU1Ue7TYv"); + solana_pubkey::declare_id!("E5JiFDQCwyC6QfT9REFyMpfK2mHcmv1GUDySU1Ue7TYv"); } pub mod no_overflow_rent_distribution { - solana_program::declare_id!("4kpdyrcj5jS47CZb2oJGfVxjYbsMm2Kx97gFyZrxxwXz"); + solana_pubkey::declare_id!("4kpdyrcj5jS47CZb2oJGfVxjYbsMm2Kx97gFyZrxxwXz"); } pub mod filter_stake_delegation_accounts { - solana_program::declare_id!("GE7fRxmW46K6EmCD9AMZSbnaJ2e3LfqCZzdHi9hmYAgi"); + solana_pubkey::declare_id!("GE7fRxmW46K6EmCD9AMZSbnaJ2e3LfqCZzdHi9hmYAgi"); } pub mod require_custodian_for_locked_stake_authorize { - solana_program::declare_id!("D4jsDcXaqdW8tDAWn8H4R25Cdns2YwLneujSL1zvjW6R"); + solana_pubkey::declare_id!("D4jsDcXaqdW8tDAWn8H4R25Cdns2YwLneujSL1zvjW6R"); } pub mod spl_token_v2_self_transfer_fix { - solana_program::declare_id!("BL99GYhdjjcv6ys22C9wPgn2aTVERDbPHHo4NbS3hgp7"); + solana_pubkey::declare_id!("BL99GYhdjjcv6ys22C9wPgn2aTVERDbPHHo4NbS3hgp7"); } pub mod warp_timestamp_again { - solana_program::declare_id!("GvDsGDkH5gyzwpDhxNixx8vtx1kwYHH13RiNAPw27zXb"); + solana_pubkey::declare_id!("GvDsGDkH5gyzwpDhxNixx8vtx1kwYHH13RiNAPw27zXb"); } pub mod check_init_vote_data { - solana_program::declare_id!("3ccR6QpxGYsAbWyfevEtBNGfWV4xBffxRj2tD6A9i39F"); + solana_pubkey::declare_id!("3ccR6QpxGYsAbWyfevEtBNGfWV4xBffxRj2tD6A9i39F"); } pub mod secp256k1_recover_syscall_enabled { - solana_program::declare_id!("6RvdSWHh8oh72Dp7wMTS2DBkf3fRPtChfNrAo3cZZoXJ"); + solana_pubkey::declare_id!("6RvdSWHh8oh72Dp7wMTS2DBkf3fRPtChfNrAo3cZZoXJ"); } pub mod system_transfer_zero_check { - solana_program::declare_id!("BrTR9hzw4WBGFP65AJMbpAo64DcA3U6jdPSga9fMV5cS"); + solana_pubkey::declare_id!("BrTR9hzw4WBGFP65AJMbpAo64DcA3U6jdPSga9fMV5cS"); } pub mod blake3_syscall_enabled { - solana_program::declare_id!("HTW2pSyErTj4BV6KBM9NZ9VBUJVxt7sacNWcf76wtzb3"); + solana_pubkey::declare_id!("HTW2pSyErTj4BV6KBM9NZ9VBUJVxt7sacNWcf76wtzb3"); } pub mod dedupe_config_program_signers { - solana_program::declare_id!("8kEuAshXLsgkUEdcFVLqrjCGGHVWFW99ZZpxvAzzMtBp"); + solana_pubkey::declare_id!("8kEuAshXLsgkUEdcFVLqrjCGGHVWFW99ZZpxvAzzMtBp"); } pub mod verify_tx_signatures_len { - solana_program::declare_id!("EVW9B5xD9FFK7vw1SBARwMA4s5eRo5eKJdKpsBikzKBz"); + solana_pubkey::declare_id!("EVW9B5xD9FFK7vw1SBARwMA4s5eRo5eKJdKpsBikzKBz"); } pub mod vote_stake_checked_instructions { - solana_program::declare_id!("BcWknVcgvonN8sL4HE4XFuEVgfcee5MwxWPAgP6ZV89X"); + solana_pubkey::declare_id!("BcWknVcgvonN8sL4HE4XFuEVgfcee5MwxWPAgP6ZV89X"); } pub mod rent_for_sysvars { - solana_program::declare_id!("BKCPBQQBZqggVnFso5nQ8rQ4RwwogYwjuUt9biBjxwNF"); + solana_pubkey::declare_id!("BKCPBQQBZqggVnFso5nQ8rQ4RwwogYwjuUt9biBjxwNF"); } pub mod libsecp256k1_0_5_upgrade_enabled { - solana_program::declare_id!("DhsYfRjxfnh2g7HKJYSzT79r74Afa1wbHkAgHndrA1oy"); + solana_pubkey::declare_id!("DhsYfRjxfnh2g7HKJYSzT79r74Afa1wbHkAgHndrA1oy"); } pub mod tx_wide_compute_cap { - solana_program::declare_id!("5ekBxc8itEnPv4NzGJtr8BVVQLNMQuLMNQQj7pHoLNZ9"); + solana_pubkey::declare_id!("5ekBxc8itEnPv4NzGJtr8BVVQLNMQuLMNQQj7pHoLNZ9"); } pub mod spl_token_v2_set_authority_fix { - solana_program::declare_id!("FToKNBYyiF4ky9s8WsmLBXHCht17Ek7RXaLZGHzzQhJ1"); + solana_pubkey::declare_id!("FToKNBYyiF4ky9s8WsmLBXHCht17Ek7RXaLZGHzzQhJ1"); } pub mod merge_nonce_error_into_system_error { - solana_program::declare_id!("21AWDosvp3pBamFW91KB35pNoaoZVTM7ess8nr2nt53B"); + solana_pubkey::declare_id!("21AWDosvp3pBamFW91KB35pNoaoZVTM7ess8nr2nt53B"); } pub mod disable_fees_sysvar { - solana_program::declare_id!("JAN1trEUEtZjgXYzNBYHU9DYd7GnThhXfFP7SzPXkPsG"); + solana_pubkey::declare_id!("JAN1trEUEtZjgXYzNBYHU9DYd7GnThhXfFP7SzPXkPsG"); } pub mod stake_merge_with_unmatched_credits_observed { - solana_program::declare_id!("meRgp4ArRPhD3KtCY9c5yAf2med7mBLsjKTPeVUHqBL"); + solana_pubkey::declare_id!("meRgp4ArRPhD3KtCY9c5yAf2med7mBLsjKTPeVUHqBL"); } pub mod zk_token_sdk_enabled { - solana_program::declare_id!("zk1snxsc6Fh3wsGNbbHAJNHiJoYgF29mMnTSusGx5EJ"); + solana_pubkey::declare_id!("zk1snxsc6Fh3wsGNbbHAJNHiJoYgF29mMnTSusGx5EJ"); } pub mod curve25519_syscall_enabled { - solana_program::declare_id!("7rcw5UtqgDTBBv2EcynNfYckgdAaH1MAsCjKgXMkN7Ri"); + solana_pubkey::declare_id!("7rcw5UtqgDTBBv2EcynNfYckgdAaH1MAsCjKgXMkN7Ri"); } pub mod curve25519_restrict_msm_length { - solana_program::declare_id!("eca6zf6JJRjQsYYPkBHF3N32MTzur4n2WL4QiiacPCL"); + solana_pubkey::declare_id!("eca6zf6JJRjQsYYPkBHF3N32MTzur4n2WL4QiiacPCL"); } pub mod versioned_tx_message_enabled { - solana_program::declare_id!("3KZZ6Ks1885aGBQ45fwRcPXVBCtzUvxhUTkwKMR41Tca"); + solana_pubkey::declare_id!("3KZZ6Ks1885aGBQ45fwRcPXVBCtzUvxhUTkwKMR41Tca"); } pub mod libsecp256k1_fail_on_bad_count { - solana_program::declare_id!("8aXvSuopd1PUj7UhehfXJRg6619RHp8ZvwTyyJHdUYsj"); + solana_pubkey::declare_id!("8aXvSuopd1PUj7UhehfXJRg6619RHp8ZvwTyyJHdUYsj"); } pub mod libsecp256k1_fail_on_bad_count2 { - solana_program::declare_id!("54KAoNiUERNoWWUhTWWwXgym94gzoXFVnHyQwPA18V9A"); + solana_pubkey::declare_id!("54KAoNiUERNoWWUhTWWwXgym94gzoXFVnHyQwPA18V9A"); } pub mod instructions_sysvar_owned_by_sysvar { - solana_program::declare_id!("H3kBSaKdeiUsyHmeHqjJYNc27jesXZ6zWj3zWkowQbkV"); + solana_pubkey::declare_id!("H3kBSaKdeiUsyHmeHqjJYNc27jesXZ6zWj3zWkowQbkV"); } pub mod stake_program_advance_activating_credits_observed { - solana_program::declare_id!("SAdVFw3RZvzbo6DvySbSdBnHN4gkzSTH9dSxesyKKPj"); + solana_pubkey::declare_id!("SAdVFw3RZvzbo6DvySbSdBnHN4gkzSTH9dSxesyKKPj"); } pub mod credits_auto_rewind { - solana_program::declare_id!("BUS12ciZ5gCoFafUHWW8qaFMMtwFQGVxjsDheWLdqBE2"); + solana_pubkey::declare_id!("BUS12ciZ5gCoFafUHWW8qaFMMtwFQGVxjsDheWLdqBE2"); } pub mod demote_program_write_locks { - solana_program::declare_id!("3E3jV7v9VcdJL8iYZUMax9DiDno8j7EWUVbhm9RtShj2"); + solana_pubkey::declare_id!("3E3jV7v9VcdJL8iYZUMax9DiDno8j7EWUVbhm9RtShj2"); } pub mod ed25519_program_enabled { - solana_program::declare_id!("6ppMXNYLhVd7GcsZ5uV11wQEW7spppiMVfqQv5SXhDpX"); + solana_pubkey::declare_id!("6ppMXNYLhVd7GcsZ5uV11wQEW7spppiMVfqQv5SXhDpX"); } pub mod return_data_syscall_enabled { - solana_program::declare_id!("DwScAzPUjuv65TMbDnFY7AgwmotzWy3xpEJMXM3hZFaB"); + solana_pubkey::declare_id!("DwScAzPUjuv65TMbDnFY7AgwmotzWy3xpEJMXM3hZFaB"); } pub mod reduce_required_deploy_balance { - solana_program::declare_id!("EBeznQDjcPG8491sFsKZYBi5S5jTVXMpAKNDJMQPS2kq"); + solana_pubkey::declare_id!("EBeznQDjcPG8491sFsKZYBi5S5jTVXMpAKNDJMQPS2kq"); } pub mod sol_log_data_syscall_enabled { - solana_program::declare_id!("6uaHcKPGUy4J7emLBgUTeufhJdiwhngW6a1R9B7c2ob9"); + solana_pubkey::declare_id!("6uaHcKPGUy4J7emLBgUTeufhJdiwhngW6a1R9B7c2ob9"); } pub mod stakes_remove_delegation_if_inactive { - solana_program::declare_id!("HFpdDDNQjvcXnXKec697HDDsyk6tFoWS2o8fkxuhQZpL"); + solana_pubkey::declare_id!("HFpdDDNQjvcXnXKec697HDDsyk6tFoWS2o8fkxuhQZpL"); } pub mod do_support_realloc { - solana_program::declare_id!("75m6ysz33AfLA5DDEzWM1obBrnPQRSsdVQ2nRmc8Vuu1"); + solana_pubkey::declare_id!("75m6ysz33AfLA5DDEzWM1obBrnPQRSsdVQ2nRmc8Vuu1"); } pub mod prevent_calling_precompiles_as_programs { - solana_program::declare_id!("4ApgRX3ud6p7LNMJmsuaAcZY5HWctGPr5obAsjB3A54d"); + solana_pubkey::declare_id!("4ApgRX3ud6p7LNMJmsuaAcZY5HWctGPr5obAsjB3A54d"); } pub mod optimize_epoch_boundary_updates { - solana_program::declare_id!("265hPS8k8xJ37ot82KEgjRunsUp5w4n4Q4VwwiN9i9ps"); + solana_pubkey::declare_id!("265hPS8k8xJ37ot82KEgjRunsUp5w4n4Q4VwwiN9i9ps"); } pub mod remove_native_loader { - solana_program::declare_id!("HTTgmruMYRZEntyL3EdCDdnS6e4D5wRq1FA7kQsb66qq"); + solana_pubkey::declare_id!("HTTgmruMYRZEntyL3EdCDdnS6e4D5wRq1FA7kQsb66qq"); } pub mod send_to_tpu_vote_port { - solana_program::declare_id!("C5fh68nJ7uyKAuYZg2x9sEQ5YrVf3dkW6oojNBSc3Jvo"); + solana_pubkey::declare_id!("C5fh68nJ7uyKAuYZg2x9sEQ5YrVf3dkW6oojNBSc3Jvo"); } pub mod requestable_heap_size { - solana_program::declare_id!("CCu4boMmfLuqcmfTLPHQiUo22ZdUsXjgzPAURYaWt1Bw"); + solana_pubkey::declare_id!("CCu4boMmfLuqcmfTLPHQiUo22ZdUsXjgzPAURYaWt1Bw"); } pub mod disable_fee_calculator { - solana_program::declare_id!("2jXx2yDmGysmBKfKYNgLj2DQyAQv6mMk2BPh4eSbyB4H"); + solana_pubkey::declare_id!("2jXx2yDmGysmBKfKYNgLj2DQyAQv6mMk2BPh4eSbyB4H"); } pub mod add_compute_budget_program { - solana_program::declare_id!("4d5AKtxoh93Dwm1vHXUU3iRATuMndx1c431KgT2td52r"); + solana_pubkey::declare_id!("4d5AKtxoh93Dwm1vHXUU3iRATuMndx1c431KgT2td52r"); } pub mod nonce_must_be_writable { - solana_program::declare_id!("BiCU7M5w8ZCMykVSyhZ7Q3m2SWoR2qrEQ86ERcDX77ME"); + solana_pubkey::declare_id!("BiCU7M5w8ZCMykVSyhZ7Q3m2SWoR2qrEQ86ERcDX77ME"); } pub mod spl_token_v3_3_0_release { - solana_program::declare_id!("Ftok2jhqAqxUWEiCVRrfRs9DPppWP8cgTB7NQNKL88mS"); + solana_pubkey::declare_id!("Ftok2jhqAqxUWEiCVRrfRs9DPppWP8cgTB7NQNKL88mS"); } pub mod leave_nonce_on_success { - solana_program::declare_id!("E8MkiWZNNPGU6n55jkGzyj8ghUmjCHRmDFdYYFYHxWhQ"); + solana_pubkey::declare_id!("E8MkiWZNNPGU6n55jkGzyj8ghUmjCHRmDFdYYFYHxWhQ"); } pub mod reject_empty_instruction_without_program { - solana_program::declare_id!("9kdtFSrXHQg3hKkbXkQ6trJ3Ja1xpJ22CTFSNAciEwmL"); + solana_pubkey::declare_id!("9kdtFSrXHQg3hKkbXkQ6trJ3Ja1xpJ22CTFSNAciEwmL"); } pub mod fixed_memcpy_nonoverlapping_check { - solana_program::declare_id!("36PRUK2Dz6HWYdG9SpjeAsF5F3KxnFCakA2BZMbtMhSb"); + solana_pubkey::declare_id!("36PRUK2Dz6HWYdG9SpjeAsF5F3KxnFCakA2BZMbtMhSb"); } pub mod reject_non_rent_exempt_vote_withdraws { - solana_program::declare_id!("7txXZZD6Um59YoLMF7XUNimbMjsqsWhc7g2EniiTrmp1"); + solana_pubkey::declare_id!("7txXZZD6Um59YoLMF7XUNimbMjsqsWhc7g2EniiTrmp1"); } pub mod evict_invalid_stakes_cache_entries { - solana_program::declare_id!("EMX9Q7TVFAmQ9V1CggAkhMzhXSg8ECp7fHrWQX2G1chf"); + solana_pubkey::declare_id!("EMX9Q7TVFAmQ9V1CggAkhMzhXSg8ECp7fHrWQX2G1chf"); } pub mod allow_votes_to_directly_update_vote_state { - solana_program::declare_id!("Ff8b1fBeB86q8cjq47ZhsQLgv5EkHu3G1C99zjUfAzrq"); + solana_pubkey::declare_id!("Ff8b1fBeB86q8cjq47ZhsQLgv5EkHu3G1C99zjUfAzrq"); } pub mod max_tx_account_locks { - solana_program::declare_id!("CBkDroRDqm8HwHe6ak9cguPjUomrASEkfmxEaZ5CNNxz"); + solana_pubkey::declare_id!("CBkDroRDqm8HwHe6ak9cguPjUomrASEkfmxEaZ5CNNxz"); } pub mod require_rent_exempt_accounts { - solana_program::declare_id!("BkFDxiJQWZXGTZaJQxH7wVEHkAmwCgSEVkrvswFfRJPD"); + solana_pubkey::declare_id!("BkFDxiJQWZXGTZaJQxH7wVEHkAmwCgSEVkrvswFfRJPD"); } pub mod filter_votes_outside_slot_hashes { - solana_program::declare_id!("3gtZPqvPpsbXZVCx6hceMfWxtsmrjMzmg8C7PLKSxS2d"); + solana_pubkey::declare_id!("3gtZPqvPpsbXZVCx6hceMfWxtsmrjMzmg8C7PLKSxS2d"); } pub mod update_syscall_base_costs { - solana_program::declare_id!("2h63t332mGCCsWK2nqqqHhN4U9ayyqhLVFvczznHDoTZ"); + solana_pubkey::declare_id!("2h63t332mGCCsWK2nqqqHhN4U9ayyqhLVFvczznHDoTZ"); } pub mod stake_deactivate_delinquent_instruction { - solana_program::declare_id!("437r62HoAdUb63amq3D7ENnBLDhHT2xY8eFkLJYVKK4x"); + solana_pubkey::declare_id!("437r62HoAdUb63amq3D7ENnBLDhHT2xY8eFkLJYVKK4x"); } pub mod vote_withdraw_authority_may_change_authorized_voter { - solana_program::declare_id!("AVZS3ZsN4gi6Rkx2QUibYuSJG3S6QHib7xCYhG6vGJxU"); + solana_pubkey::declare_id!("AVZS3ZsN4gi6Rkx2QUibYuSJG3S6QHib7xCYhG6vGJxU"); } pub mod spl_associated_token_account_v1_0_4 { - solana_program::declare_id!("FaTa4SpiaSNH44PGC4z8bnGVTkSRYaWvrBs3KTu8XQQq"); + solana_pubkey::declare_id!("FaTa4SpiaSNH44PGC4z8bnGVTkSRYaWvrBs3KTu8XQQq"); } pub mod reject_vote_account_close_unless_zero_credit_epoch { - solana_program::declare_id!("ALBk3EWdeAg2WAGf6GPDUf1nynyNqCdEVmgouG7rpuCj"); + solana_pubkey::declare_id!("ALBk3EWdeAg2WAGf6GPDUf1nynyNqCdEVmgouG7rpuCj"); } pub mod add_get_processed_sibling_instruction_syscall { - solana_program::declare_id!("CFK1hRCNy8JJuAAY8Pb2GjLFNdCThS2qwZNe3izzBMgn"); + solana_pubkey::declare_id!("CFK1hRCNy8JJuAAY8Pb2GjLFNdCThS2qwZNe3izzBMgn"); } pub mod bank_transaction_count_fix { - solana_program::declare_id!("Vo5siZ442SaZBKPXNocthiXysNviW4UYPwRFggmbgAp"); + solana_pubkey::declare_id!("Vo5siZ442SaZBKPXNocthiXysNviW4UYPwRFggmbgAp"); } pub mod disable_bpf_deprecated_load_instructions { - solana_program::declare_id!("3XgNukcZWf9o3HdA3fpJbm94XFc4qpvTXc8h1wxYwiPi"); + solana_pubkey::declare_id!("3XgNukcZWf9o3HdA3fpJbm94XFc4qpvTXc8h1wxYwiPi"); } pub mod disable_bpf_unresolved_symbols_at_runtime { - solana_program::declare_id!("4yuaYAj2jGMGTh1sSmi4G2eFscsDq8qjugJXZoBN6YEa"); + solana_pubkey::declare_id!("4yuaYAj2jGMGTh1sSmi4G2eFscsDq8qjugJXZoBN6YEa"); } pub mod record_instruction_in_transaction_context_push { - solana_program::declare_id!("3aJdcZqxoLpSBxgeYGjPwaYS1zzcByxUDqJkbzWAH1Zb"); + solana_pubkey::declare_id!("3aJdcZqxoLpSBxgeYGjPwaYS1zzcByxUDqJkbzWAH1Zb"); } pub mod syscall_saturated_math { - solana_program::declare_id!("HyrbKftCdJ5CrUfEti6x26Cj7rZLNe32weugk7tLcWb8"); + solana_pubkey::declare_id!("HyrbKftCdJ5CrUfEti6x26Cj7rZLNe32weugk7tLcWb8"); } pub mod check_physical_overlapping { - solana_program::declare_id!("nWBqjr3gpETbiaVj3CBJ3HFC5TMdnJDGt21hnvSTvVZ"); + solana_pubkey::declare_id!("nWBqjr3gpETbiaVj3CBJ3HFC5TMdnJDGt21hnvSTvVZ"); } pub mod limit_secp256k1_recovery_id { - solana_program::declare_id!("7g9EUwj4j7CS21Yx1wvgWLjSZeh5aPq8x9kpoPwXM8n8"); + solana_pubkey::declare_id!("7g9EUwj4j7CS21Yx1wvgWLjSZeh5aPq8x9kpoPwXM8n8"); } pub mod disable_deprecated_loader { - solana_program::declare_id!("GTUMCZ8LTNxVfxdrw7ZsDFTxXb7TutYkzJnFwinpE6dg"); + solana_pubkey::declare_id!("GTUMCZ8LTNxVfxdrw7ZsDFTxXb7TutYkzJnFwinpE6dg"); } pub mod check_slice_translation_size { - solana_program::declare_id!("GmC19j9qLn2RFk5NduX6QXaDhVpGncVVBzyM8e9WMz2F"); + solana_pubkey::declare_id!("GmC19j9qLn2RFk5NduX6QXaDhVpGncVVBzyM8e9WMz2F"); } pub mod stake_split_uses_rent_sysvar { - solana_program::declare_id!("FQnc7U4koHqWgRvFaBJjZnV8VPg6L6wWK33yJeDp4yvV"); + solana_pubkey::declare_id!("FQnc7U4koHqWgRvFaBJjZnV8VPg6L6wWK33yJeDp4yvV"); } pub mod add_get_minimum_delegation_instruction_to_stake_program { - solana_program::declare_id!("St8k9dVXP97xT6faW24YmRSYConLbhsMJA4TJTBLmMT"); + solana_pubkey::declare_id!("St8k9dVXP97xT6faW24YmRSYConLbhsMJA4TJTBLmMT"); } pub mod error_on_syscall_bpf_function_hash_collisions { - solana_program::declare_id!("8199Q2gMD2kwgfopK5qqVWuDbegLgpuFUFHCcUJQDN8b"); + solana_pubkey::declare_id!("8199Q2gMD2kwgfopK5qqVWuDbegLgpuFUFHCcUJQDN8b"); } pub mod reject_callx_r10 { - solana_program::declare_id!("3NKRSwpySNwD3TvP5pHnRmkAQRsdkXWRr1WaQh8p4PWX"); + solana_pubkey::declare_id!("3NKRSwpySNwD3TvP5pHnRmkAQRsdkXWRr1WaQh8p4PWX"); } pub mod drop_redundant_turbine_path { - solana_program::declare_id!("4Di3y24QFLt5QEUPZtbnjyfQKfm6ZMTfa6Dw1psfoMKU"); + solana_pubkey::declare_id!("4Di3y24QFLt5QEUPZtbnjyfQKfm6ZMTfa6Dw1psfoMKU"); } pub mod executables_incur_cpi_data_cost { - solana_program::declare_id!("7GUcYgq4tVtaqNCKT3dho9r4665Qp5TxCZ27Qgjx3829"); + solana_pubkey::declare_id!("7GUcYgq4tVtaqNCKT3dho9r4665Qp5TxCZ27Qgjx3829"); } pub mod fix_recent_blockhashes { - solana_program::declare_id!("6iyggb5MTcsvdcugX7bEKbHV8c6jdLbpHwkncrgLMhfo"); + solana_pubkey::declare_id!("6iyggb5MTcsvdcugX7bEKbHV8c6jdLbpHwkncrgLMhfo"); } pub mod update_rewards_from_cached_accounts { - solana_program::declare_id!("28s7i3htzhahXQKqmS2ExzbEoUypg9krwvtK2M9UWXh9"); + solana_pubkey::declare_id!("28s7i3htzhahXQKqmS2ExzbEoUypg9krwvtK2M9UWXh9"); } pub mod enable_partitioned_epoch_reward { - solana_program::declare_id!("9bn2vTJUsUcnpiZWbu2woSKtTGW3ErZC9ERv88SDqQjK"); + solana_pubkey::declare_id!("9bn2vTJUsUcnpiZWbu2woSKtTGW3ErZC9ERv88SDqQjK"); } pub mod partitioned_epoch_rewards_superfeature { - solana_program::declare_id!("PERzQrt5gBD1XEe2c9XdFWqwgHY3mr7cYWbm5V772V8"); + solana_pubkey::declare_id!("PERzQrt5gBD1XEe2c9XdFWqwgHY3mr7cYWbm5V772V8"); } pub mod spl_token_v3_4_0 { - solana_program::declare_id!("Ftok4njE8b7tDffYkC5bAbCaQv5sL6jispYrprzatUwN"); + solana_pubkey::declare_id!("Ftok4njE8b7tDffYkC5bAbCaQv5sL6jispYrprzatUwN"); } pub mod spl_associated_token_account_v1_1_0 { - solana_program::declare_id!("FaTa17gVKoqbh38HcfiQonPsAaQViyDCCSg71AubYZw8"); + solana_pubkey::declare_id!("FaTa17gVKoqbh38HcfiQonPsAaQViyDCCSg71AubYZw8"); } pub mod default_units_per_instruction { - solana_program::declare_id!("J2QdYx8crLbTVK8nur1jeLsmc3krDbfjoxoea2V1Uy5Q"); + solana_pubkey::declare_id!("J2QdYx8crLbTVK8nur1jeLsmc3krDbfjoxoea2V1Uy5Q"); } pub mod stake_allow_zero_undelegated_amount { - solana_program::declare_id!("sTKz343FM8mqtyGvYWvbLpTThw3ixRM4Xk8QvZ985mw"); + solana_pubkey::declare_id!("sTKz343FM8mqtyGvYWvbLpTThw3ixRM4Xk8QvZ985mw"); } pub mod require_static_program_ids_in_transaction { - solana_program::declare_id!("8FdwgyHFEjhAdjWfV2vfqk7wA1g9X3fQpKH7SBpEv3kC"); + solana_pubkey::declare_id!("8FdwgyHFEjhAdjWfV2vfqk7wA1g9X3fQpKH7SBpEv3kC"); } pub mod stake_raise_minimum_delegation_to_1_sol { // This is a feature-proposal *feature id*. The feature keypair address is `GQXzC7YiSNkje6FFUk6sc2p53XRvKoaZ9VMktYzUMnpL`. - solana_program::declare_id!("9onWzzvCzNC2jfhxxeqRgs5q7nFAAKpCUvkj6T6GJK9i"); + solana_pubkey::declare_id!("9onWzzvCzNC2jfhxxeqRgs5q7nFAAKpCUvkj6T6GJK9i"); } pub mod stake_minimum_delegation_for_rewards { - solana_program::declare_id!("G6ANXD6ptCSyNd9znZm7j4dEczAJCfx7Cy43oBx3rKHJ"); + solana_pubkey::declare_id!("G6ANXD6ptCSyNd9znZm7j4dEczAJCfx7Cy43oBx3rKHJ"); } pub mod add_set_compute_unit_price_ix { - solana_program::declare_id!("98std1NSHqXi9WYvFShfVepRdCoq1qvsp8fsR2XZtG8g"); + solana_pubkey::declare_id!("98std1NSHqXi9WYvFShfVepRdCoq1qvsp8fsR2XZtG8g"); } pub mod disable_deploy_of_alloc_free_syscall { - solana_program::declare_id!("79HWsX9rpnnJBPcdNURVqygpMAfxdrAirzAGAVmf92im"); + solana_pubkey::declare_id!("79HWsX9rpnnJBPcdNURVqygpMAfxdrAirzAGAVmf92im"); } pub mod include_account_index_in_rent_error { - solana_program::declare_id!("2R72wpcQ7qV7aTJWUumdn8u5wmmTyXbK7qzEy7YSAgyY"); + solana_pubkey::declare_id!("2R72wpcQ7qV7aTJWUumdn8u5wmmTyXbK7qzEy7YSAgyY"); } pub mod add_shred_type_to_shred_seed { - solana_program::declare_id!("Ds87KVeqhbv7Jw8W6avsS1mqz3Mw5J3pRTpPoDQ2QdiJ"); + solana_pubkey::declare_id!("Ds87KVeqhbv7Jw8W6avsS1mqz3Mw5J3pRTpPoDQ2QdiJ"); } pub mod warp_timestamp_with_a_vengeance { - solana_program::declare_id!("3BX6SBeEBibHaVQXywdkcgyUk6evfYZkHdztXiDtEpFS"); + solana_pubkey::declare_id!("3BX6SBeEBibHaVQXywdkcgyUk6evfYZkHdztXiDtEpFS"); } pub mod separate_nonce_from_blockhash { - solana_program::declare_id!("Gea3ZkK2N4pHuVZVxWcnAtS6UEDdyumdYt4pFcKjA3ar"); + solana_pubkey::declare_id!("Gea3ZkK2N4pHuVZVxWcnAtS6UEDdyumdYt4pFcKjA3ar"); } pub mod enable_durable_nonce { - solana_program::declare_id!("4EJQtF2pkRyawwcTVfQutzq4Sa5hRhibF6QAK1QXhtEX"); + solana_pubkey::declare_id!("4EJQtF2pkRyawwcTVfQutzq4Sa5hRhibF6QAK1QXhtEX"); } pub mod vote_state_update_credit_per_dequeue { - solana_program::declare_id!("CveezY6FDLVBToHDcvJRmtMouqzsmj4UXYh5ths5G5Uv"); + solana_pubkey::declare_id!("CveezY6FDLVBToHDcvJRmtMouqzsmj4UXYh5ths5G5Uv"); } pub mod quick_bail_on_panic { - solana_program::declare_id!("DpJREPyuMZ5nDfU6H3WTqSqUFSXAfw8u7xqmWtEwJDcP"); + solana_pubkey::declare_id!("DpJREPyuMZ5nDfU6H3WTqSqUFSXAfw8u7xqmWtEwJDcP"); } pub mod nonce_must_be_authorized { - solana_program::declare_id!("HxrEu1gXuH7iD3Puua1ohd5n4iUKJyFNtNxk9DVJkvgr"); + solana_pubkey::declare_id!("HxrEu1gXuH7iD3Puua1ohd5n4iUKJyFNtNxk9DVJkvgr"); } pub mod nonce_must_be_advanceable { - solana_program::declare_id!("3u3Er5Vc2jVcwz4xr2GJeSAXT3fAj6ADHZ4BJMZiScFd"); + solana_pubkey::declare_id!("3u3Er5Vc2jVcwz4xr2GJeSAXT3fAj6ADHZ4BJMZiScFd"); } pub mod vote_authorize_with_seed { - solana_program::declare_id!("6tRxEYKuy2L5nnv5bgn7iT28MxUbYxp5h7F3Ncf1exrT"); + solana_pubkey::declare_id!("6tRxEYKuy2L5nnv5bgn7iT28MxUbYxp5h7F3Ncf1exrT"); } pub mod preserve_rent_epoch_for_rent_exempt_accounts { - solana_program::declare_id!("HH3MUYReL2BvqqA3oEcAa7txju5GY6G4nxJ51zvsEjEZ"); + solana_pubkey::declare_id!("HH3MUYReL2BvqqA3oEcAa7txju5GY6G4nxJ51zvsEjEZ"); } pub mod enable_bpf_loader_extend_program_ix { - solana_program::declare_id!("8Zs9W7D9MpSEtUWSQdGniZk2cNmV22y6FLJwCx53asme"); + solana_pubkey::declare_id!("8Zs9W7D9MpSEtUWSQdGniZk2cNmV22y6FLJwCx53asme"); } pub mod enable_early_verification_of_account_modifications { - solana_program::declare_id!("7Vced912WrRnfjaiKRiNBcbuFw7RrnLv3E3z95Y4GTNc"); + solana_pubkey::declare_id!("7Vced912WrRnfjaiKRiNBcbuFw7RrnLv3E3z95Y4GTNc"); } pub mod skip_rent_rewrites { - solana_program::declare_id!("CGB2jM8pwZkeeiXQ66kBMyBR6Np61mggL7XUsmLjVcrw"); + solana_pubkey::declare_id!("CGB2jM8pwZkeeiXQ66kBMyBR6Np61mggL7XUsmLjVcrw"); } pub mod prevent_crediting_accounts_that_end_rent_paying { - solana_program::declare_id!("812kqX67odAp5NFwM8D2N24cku7WTm9CHUTFUXaDkWPn"); + solana_pubkey::declare_id!("812kqX67odAp5NFwM8D2N24cku7WTm9CHUTFUXaDkWPn"); } pub mod cap_bpf_program_instruction_accounts { - solana_program::declare_id!("9k5ijzTbYPtjzu8wj2ErH9v45xecHzQ1x4PMYMMxFgdM"); + solana_pubkey::declare_id!("9k5ijzTbYPtjzu8wj2ErH9v45xecHzQ1x4PMYMMxFgdM"); } pub mod loosen_cpi_size_restriction { - solana_program::declare_id!("GDH5TVdbTPUpRnXaRyQqiKUa7uZAbZ28Q2N9bhbKoMLm"); + solana_pubkey::declare_id!("GDH5TVdbTPUpRnXaRyQqiKUa7uZAbZ28Q2N9bhbKoMLm"); } pub mod use_default_units_in_fee_calculation { - solana_program::declare_id!("8sKQrMQoUHtQSUP83SPG4ta2JDjSAiWs7t5aJ9uEd6To"); + solana_pubkey::declare_id!("8sKQrMQoUHtQSUP83SPG4ta2JDjSAiWs7t5aJ9uEd6To"); } pub mod compact_vote_state_updates { - solana_program::declare_id!("86HpNqzutEZwLcPxS6EHDcMNYWk6ikhteg9un7Y2PBKE"); + solana_pubkey::declare_id!("86HpNqzutEZwLcPxS6EHDcMNYWk6ikhteg9un7Y2PBKE"); } pub mod incremental_snapshot_only_incremental_hash_calculation { - solana_program::declare_id!("25vqsfjk7Nv1prsQJmA4Xu1bN61s8LXCBGUPp8Rfy1UF"); + solana_pubkey::declare_id!("25vqsfjk7Nv1prsQJmA4Xu1bN61s8LXCBGUPp8Rfy1UF"); } pub mod disable_cpi_setting_executable_and_rent_epoch { - solana_program::declare_id!("B9cdB55u4jQsDNsdTK525yE9dmSc5Ga7YBaBrDFvEhM9"); + solana_pubkey::declare_id!("B9cdB55u4jQsDNsdTK525yE9dmSc5Ga7YBaBrDFvEhM9"); } pub mod on_load_preserve_rent_epoch_for_rent_exempt_accounts { - solana_program::declare_id!("CpkdQmspsaZZ8FVAouQTtTWZkc8eeQ7V3uj7dWz543rZ"); + solana_pubkey::declare_id!("CpkdQmspsaZZ8FVAouQTtTWZkc8eeQ7V3uj7dWz543rZ"); } pub mod account_hash_ignore_slot { - solana_program::declare_id!("SVn36yVApPLYsa8koK3qUcy14zXDnqkNYWyUh1f4oK1"); + solana_pubkey::declare_id!("SVn36yVApPLYsa8koK3qUcy14zXDnqkNYWyUh1f4oK1"); } pub mod set_exempt_rent_epoch_max { - solana_program::declare_id!("5wAGiy15X1Jb2hkHnPDCM8oB9V42VNA9ftNVFK84dEgv"); + solana_pubkey::declare_id!("5wAGiy15X1Jb2hkHnPDCM8oB9V42VNA9ftNVFK84dEgv"); } pub mod relax_authority_signer_check_for_lookup_table_creation { - solana_program::declare_id!("FKAcEvNgSY79RpqsPNUV5gDyumopH4cEHqUxyfm8b8Ap"); + solana_pubkey::declare_id!("FKAcEvNgSY79RpqsPNUV5gDyumopH4cEHqUxyfm8b8Ap"); } pub mod stop_sibling_instruction_search_at_parent { - solana_program::declare_id!("EYVpEP7uzH1CoXzbD6PubGhYmnxRXPeq3PPsm1ba3gpo"); + solana_pubkey::declare_id!("EYVpEP7uzH1CoXzbD6PubGhYmnxRXPeq3PPsm1ba3gpo"); } pub mod vote_state_update_root_fix { - solana_program::declare_id!("G74BkWBzmsByZ1kxHy44H3wjwp5hp7JbrGRuDpco22tY"); + solana_pubkey::declare_id!("G74BkWBzmsByZ1kxHy44H3wjwp5hp7JbrGRuDpco22tY"); } pub mod cap_accounts_data_allocations_per_transaction { - solana_program::declare_id!("9gxu85LYRAcZL38We8MYJ4A9AwgBBPtVBAqebMcT1241"); + solana_pubkey::declare_id!("9gxu85LYRAcZL38We8MYJ4A9AwgBBPtVBAqebMcT1241"); } pub mod epoch_accounts_hash { - solana_program::declare_id!("5GpmAKxaGsWWbPp4bNXFLJxZVvG92ctxf7jQnzTQjF3n"); + solana_pubkey::declare_id!("5GpmAKxaGsWWbPp4bNXFLJxZVvG92ctxf7jQnzTQjF3n"); } pub mod remove_deprecated_request_unit_ix { - solana_program::declare_id!("EfhYd3SafzGT472tYQDUc4dPd2xdEfKs5fwkowUgVt4W"); + solana_pubkey::declare_id!("EfhYd3SafzGT472tYQDUc4dPd2xdEfKs5fwkowUgVt4W"); } pub mod disable_rehash_for_rent_epoch { - solana_program::declare_id!("DTVTkmw3JSofd8CJVJte8PXEbxNQ2yZijvVr3pe2APPj"); + solana_pubkey::declare_id!("DTVTkmw3JSofd8CJVJte8PXEbxNQ2yZijvVr3pe2APPj"); } pub mod increase_tx_account_lock_limit { - solana_program::declare_id!("9LZdXeKGeBV6hRLdxS1rHbHoEUsKqesCC2ZAPTPKJAbK"); + solana_pubkey::declare_id!("9LZdXeKGeBV6hRLdxS1rHbHoEUsKqesCC2ZAPTPKJAbK"); } pub mod limit_max_instruction_trace_length { - solana_program::declare_id!("GQALDaC48fEhZGWRj9iL5Q889emJKcj3aCvHF7VCbbF4"); + solana_pubkey::declare_id!("GQALDaC48fEhZGWRj9iL5Q889emJKcj3aCvHF7VCbbF4"); } pub mod check_syscall_outputs_do_not_overlap { - solana_program::declare_id!("3uRVPBpyEJRo1emLCrq38eLRFGcu6uKSpUXqGvU8T7SZ"); + solana_pubkey::declare_id!("3uRVPBpyEJRo1emLCrq38eLRFGcu6uKSpUXqGvU8T7SZ"); } pub mod enable_bpf_loader_set_authority_checked_ix { - solana_program::declare_id!("5x3825XS7M2A3Ekbn5VGGkvFoAg5qrRWkTrY4bARP1GL"); + solana_pubkey::declare_id!("5x3825XS7M2A3Ekbn5VGGkvFoAg5qrRWkTrY4bARP1GL"); } pub mod enable_alt_bn128_syscall { - solana_program::declare_id!("A16q37opZdQMCbe5qJ6xpBB9usykfv8jZaMkxvZQi4GJ"); + solana_pubkey::declare_id!("A16q37opZdQMCbe5qJ6xpBB9usykfv8jZaMkxvZQi4GJ"); } pub mod simplify_alt_bn128_syscall_error_codes { - solana_program::declare_id!("JDn5q3GBeqzvUa7z67BbmVHVdE3EbUAjvFep3weR3jxX"); + solana_pubkey::declare_id!("JDn5q3GBeqzvUa7z67BbmVHVdE3EbUAjvFep3weR3jxX"); } pub mod enable_alt_bn128_compression_syscall { - solana_program::declare_id!("EJJewYSddEEtSZHiqugnvhQHiWyZKjkFDQASd7oKSagn"); + solana_pubkey::declare_id!("EJJewYSddEEtSZHiqugnvhQHiWyZKjkFDQASd7oKSagn"); } pub mod enable_program_redeployment_cooldown { - solana_program::declare_id!("J4HFT8usBxpcF63y46t1upYobJgChmKyZPm5uTBRg25Z"); + solana_pubkey::declare_id!("J4HFT8usBxpcF63y46t1upYobJgChmKyZPm5uTBRg25Z"); } pub mod commission_updates_only_allowed_in_first_half_of_epoch { - solana_program::declare_id!("noRuG2kzACwgaY7TVmLRnUNPLKNVQE1fb7X55YWBehp"); + solana_pubkey::declare_id!("noRuG2kzACwgaY7TVmLRnUNPLKNVQE1fb7X55YWBehp"); } pub mod enable_turbine_fanout_experiments { - solana_program::declare_id!("D31EFnLgdiysi84Woo3of4JMu7VmasUS3Z7j9HYXCeLY"); + solana_pubkey::declare_id!("D31EFnLgdiysi84Woo3of4JMu7VmasUS3Z7j9HYXCeLY"); } pub mod disable_turbine_fanout_experiments { - solana_program::declare_id!("Gz1aLrbeQ4Q6PTSafCZcGWZXz91yVRi7ASFzFEr1U4sa"); + solana_pubkey::declare_id!("Gz1aLrbeQ4Q6PTSafCZcGWZXz91yVRi7ASFzFEr1U4sa"); } pub mod move_serialized_len_ptr_in_cpi { - solana_program::declare_id!("74CoWuBmt3rUVUrCb2JiSTvh6nXyBWUsK4SaMj3CtE3T"); + solana_pubkey::declare_id!("74CoWuBmt3rUVUrCb2JiSTvh6nXyBWUsK4SaMj3CtE3T"); } pub mod update_hashes_per_tick { - solana_program::declare_id!("3uFHb9oKdGfgZGJK9EHaAXN4USvnQtAFC13Fh5gGFS5B"); + solana_pubkey::declare_id!("3uFHb9oKdGfgZGJK9EHaAXN4USvnQtAFC13Fh5gGFS5B"); } pub mod enable_big_mod_exp_syscall { - solana_program::declare_id!("EBq48m8irRKuE7ZnMTLvLg2UuGSqhe8s8oMqnmja1fJw"); + solana_pubkey::declare_id!("EBq48m8irRKuE7ZnMTLvLg2UuGSqhe8s8oMqnmja1fJw"); } pub mod disable_builtin_loader_ownership_chains { - solana_program::declare_id!("4UDcAfQ6EcA6bdcadkeHpkarkhZGJ7Bpq7wTAiRMjkoi"); + solana_pubkey::declare_id!("4UDcAfQ6EcA6bdcadkeHpkarkhZGJ7Bpq7wTAiRMjkoi"); } pub mod cap_transaction_accounts_data_size { - solana_program::declare_id!("DdLwVYuvDz26JohmgSbA7mjpJFgX5zP2dkp8qsF2C33V"); + solana_pubkey::declare_id!("DdLwVYuvDz26JohmgSbA7mjpJFgX5zP2dkp8qsF2C33V"); } pub mod remove_congestion_multiplier_from_fee_calculation { - solana_program::declare_id!("A8xyMHZovGXFkorFqEmVH2PKGLiBip5JD7jt4zsUWo4H"); + solana_pubkey::declare_id!("A8xyMHZovGXFkorFqEmVH2PKGLiBip5JD7jt4zsUWo4H"); } pub mod enable_request_heap_frame_ix { - solana_program::declare_id!("Hr1nUA9b7NJ6eChS26o7Vi8gYYDDwWD3YeBfzJkTbU86"); + solana_pubkey::declare_id!("Hr1nUA9b7NJ6eChS26o7Vi8gYYDDwWD3YeBfzJkTbU86"); } pub mod prevent_rent_paying_rent_recipients { - solana_program::declare_id!("Fab5oP3DmsLYCiQZXdjyqT3ukFFPrsmqhXU4WU1AWVVF"); + solana_pubkey::declare_id!("Fab5oP3DmsLYCiQZXdjyqT3ukFFPrsmqhXU4WU1AWVVF"); } pub mod delay_visibility_of_program_deployment { - solana_program::declare_id!("GmuBvtFb2aHfSfMXpuFeWZGHyDeCLPS79s48fmCWCfM5"); + solana_pubkey::declare_id!("GmuBvtFb2aHfSfMXpuFeWZGHyDeCLPS79s48fmCWCfM5"); } pub mod apply_cost_tracker_during_replay { - solana_program::declare_id!("2ry7ygxiYURULZCrypHhveanvP5tzZ4toRwVp89oCNSj"); + solana_pubkey::declare_id!("2ry7ygxiYURULZCrypHhveanvP5tzZ4toRwVp89oCNSj"); } pub mod bpf_account_data_direct_mapping { - solana_program::declare_id!("EenyoWx9UMXYKpR8mW5Jmfmy2fRjzUtM7NduYMY8bx33"); + solana_pubkey::declare_id!("EenyoWx9UMXYKpR8mW5Jmfmy2fRjzUtM7NduYMY8bx33"); } pub mod add_set_tx_loaded_accounts_data_size_instruction { - solana_program::declare_id!("G6vbf1UBok8MWb8m25ex86aoQHeKTzDKzuZADHkShqm6"); + solana_pubkey::declare_id!("G6vbf1UBok8MWb8m25ex86aoQHeKTzDKzuZADHkShqm6"); } pub mod switch_to_new_elf_parser { - solana_program::declare_id!("Cdkc8PPTeTNUPoZEfCY5AyetUrEdkZtNPMgz58nqyaHD"); + solana_pubkey::declare_id!("Cdkc8PPTeTNUPoZEfCY5AyetUrEdkZtNPMgz58nqyaHD"); } pub mod round_up_heap_size { - solana_program::declare_id!("CE2et8pqgyQMP2mQRg3CgvX8nJBKUArMu3wfiQiQKY1y"); + solana_pubkey::declare_id!("CE2et8pqgyQMP2mQRg3CgvX8nJBKUArMu3wfiQiQKY1y"); } pub mod remove_bpf_loader_incorrect_program_id { - solana_program::declare_id!("2HmTkCj9tXuPE4ueHzdD7jPeMf9JGCoZh5AsyoATiWEe"); + solana_pubkey::declare_id!("2HmTkCj9tXuPE4ueHzdD7jPeMf9JGCoZh5AsyoATiWEe"); } pub mod include_loaded_accounts_data_size_in_fee_calculation { - solana_program::declare_id!("EaQpmC6GtRssaZ3PCUM5YksGqUdMLeZ46BQXYtHYakDS"); + solana_pubkey::declare_id!("EaQpmC6GtRssaZ3PCUM5YksGqUdMLeZ46BQXYtHYakDS"); } pub mod native_programs_consume_cu { - solana_program::declare_id!("8pgXCMNXC8qyEFypuwpXyRxLXZdpM4Qo72gJ6k87A6wL"); + solana_pubkey::declare_id!("8pgXCMNXC8qyEFypuwpXyRxLXZdpM4Qo72gJ6k87A6wL"); } pub mod simplify_writable_program_account_check { - solana_program::declare_id!("5ZCcFAzJ1zsFKe1KSZa9K92jhx7gkcKj97ci2DBo1vwj"); + solana_pubkey::declare_id!("5ZCcFAzJ1zsFKe1KSZa9K92jhx7gkcKj97ci2DBo1vwj"); } pub mod stop_truncating_strings_in_syscalls { - solana_program::declare_id!("16FMCmgLzCNNz6eTwGanbyN2ZxvTBSLuQ6DZhgeMshg"); + solana_pubkey::declare_id!("16FMCmgLzCNNz6eTwGanbyN2ZxvTBSLuQ6DZhgeMshg"); } pub mod clean_up_delegation_errors { - solana_program::declare_id!("Bj2jmUsM2iRhfdLLDSTkhM5UQRQvQHm57HSmPibPtEyu"); + solana_pubkey::declare_id!("Bj2jmUsM2iRhfdLLDSTkhM5UQRQvQHm57HSmPibPtEyu"); } pub mod vote_state_add_vote_latency { - solana_program::declare_id!("7axKe5BTYBDD87ftzWbk5DfzWMGyRvqmWTduuo22Yaqy"); + solana_pubkey::declare_id!("7axKe5BTYBDD87ftzWbk5DfzWMGyRvqmWTduuo22Yaqy"); } pub mod checked_arithmetic_in_fee_validation { - solana_program::declare_id!("5Pecy6ie6XGm22pc9d4P9W5c31BugcFBuy6hsP2zkETv"); + solana_pubkey::declare_id!("5Pecy6ie6XGm22pc9d4P9W5c31BugcFBuy6hsP2zkETv"); } pub mod last_restart_slot_sysvar { - solana_program::declare_id!("HooKD5NC9QNxk25QuzCssB8ecrEzGt6eXEPBUxWp1LaR"); + solana_pubkey::declare_id!("HooKD5NC9QNxk25QuzCssB8ecrEzGt6eXEPBUxWp1LaR"); } pub mod reduce_stake_warmup_cooldown { - solana_program::declare_id!("GwtDQBghCTBgmX2cpEGNPxTEBUTQRaDMGTr5qychdGMj"); + solana_pubkey::declare_id!("GwtDQBghCTBgmX2cpEGNPxTEBUTQRaDMGTr5qychdGMj"); } mod revise_turbine_epoch_stakes { - solana_program::declare_id!("BTWmtJC8U5ZLMbBUUA1k6As62sYjPEjAiNAT55xYGdJU"); + solana_pubkey::declare_id!("BTWmtJC8U5ZLMbBUUA1k6As62sYjPEjAiNAT55xYGdJU"); } pub mod enable_poseidon_syscall { - solana_program::declare_id!("FL9RsQA6TVUoh5xJQ9d936RHSebA1NLQqe3Zv9sXZRpr"); + solana_pubkey::declare_id!("FL9RsQA6TVUoh5xJQ9d936RHSebA1NLQqe3Zv9sXZRpr"); } pub mod timely_vote_credits { - solana_program::declare_id!("tvcF6b1TRz353zKuhBjinZkKzjmihXmBAHJdjNYw1sQ"); + solana_pubkey::declare_id!("tvcF6b1TRz353zKuhBjinZkKzjmihXmBAHJdjNYw1sQ"); } pub mod remaining_compute_units_syscall_enabled { - solana_program::declare_id!("5TuppMutoyzhUSfuYdhgzD47F92GL1g89KpCZQKqedxP"); + solana_pubkey::declare_id!("5TuppMutoyzhUSfuYdhgzD47F92GL1g89KpCZQKqedxP"); } pub mod enable_program_runtime_v2_and_loader_v4 { - solana_program::declare_id!("8oBxsYqnCvUTGzgEpxPcnVf7MLbWWPYddE33PftFeBBd"); + solana_pubkey::declare_id!("8oBxsYqnCvUTGzgEpxPcnVf7MLbWWPYddE33PftFeBBd"); } pub mod require_rent_exempt_split_destination { - solana_program::declare_id!("D2aip4BBr8NPWtU9vLrwrBvbuaQ8w1zV38zFLxx4pfBV"); + solana_pubkey::declare_id!("D2aip4BBr8NPWtU9vLrwrBvbuaQ8w1zV38zFLxx4pfBV"); } pub mod better_error_codes_for_tx_lamport_check { - solana_program::declare_id!("Ffswd3egL3tccB6Rv3XY6oqfdzn913vUcjCSnpvCKpfx"); + solana_pubkey::declare_id!("Ffswd3egL3tccB6Rv3XY6oqfdzn913vUcjCSnpvCKpfx"); } pub mod update_hashes_per_tick2 { - solana_program::declare_id!("EWme9uFqfy1ikK1jhJs8fM5hxWnK336QJpbscNtizkTU"); + solana_pubkey::declare_id!("EWme9uFqfy1ikK1jhJs8fM5hxWnK336QJpbscNtizkTU"); } pub mod update_hashes_per_tick3 { - solana_program::declare_id!("8C8MCtsab5SsfammbzvYz65HHauuUYdbY2DZ4sznH6h5"); + solana_pubkey::declare_id!("8C8MCtsab5SsfammbzvYz65HHauuUYdbY2DZ4sznH6h5"); } pub mod update_hashes_per_tick4 { - solana_program::declare_id!("8We4E7DPwF2WfAN8tRTtWQNhi98B99Qpuj7JoZ3Aikgg"); + solana_pubkey::declare_id!("8We4E7DPwF2WfAN8tRTtWQNhi98B99Qpuj7JoZ3Aikgg"); } pub mod update_hashes_per_tick5 { - solana_program::declare_id!("BsKLKAn1WM4HVhPRDsjosmqSg2J8Tq5xP2s2daDS6Ni4"); + solana_pubkey::declare_id!("BsKLKAn1WM4HVhPRDsjosmqSg2J8Tq5xP2s2daDS6Ni4"); } pub mod update_hashes_per_tick6 { - solana_program::declare_id!("FKu1qYwLQSiehz644H6Si65U5ZQ2cp9GxsyFUfYcuADv"); + solana_pubkey::declare_id!("FKu1qYwLQSiehz644H6Si65U5ZQ2cp9GxsyFUfYcuADv"); } pub mod validate_fee_collector_account { - solana_program::declare_id!("prpFrMtgNmzaNzkPJg9o753fVvbHKqNrNTm76foJ2wm"); + solana_pubkey::declare_id!("prpFrMtgNmzaNzkPJg9o753fVvbHKqNrNTm76foJ2wm"); } pub mod disable_rent_fees_collection { - solana_program::declare_id!("CJzY83ggJHqPGDq8VisV3U91jDJLuEaALZooBrXtnnLU"); + solana_pubkey::declare_id!("CJzY83ggJHqPGDq8VisV3U91jDJLuEaALZooBrXtnnLU"); } pub mod enable_zk_transfer_with_fee { - solana_program::declare_id!("zkNLP7EQALfC1TYeB3biDU7akDckj8iPkvh9y2Mt2K3"); + solana_pubkey::declare_id!("zkNLP7EQALfC1TYeB3biDU7akDckj8iPkvh9y2Mt2K3"); } pub mod drop_legacy_shreds { - solana_program::declare_id!("GV49KKQdBNaiv2pgqhS2Dy3GWYJGXMTVYbYkdk91orRy"); + solana_pubkey::declare_id!("GV49KKQdBNaiv2pgqhS2Dy3GWYJGXMTVYbYkdk91orRy"); } pub mod allow_commission_decrease_at_any_time { - solana_program::declare_id!("decoMktMcnmiq6t3u7g5BfgcQu91nKZr6RvMYf9z1Jb"); + solana_pubkey::declare_id!("decoMktMcnmiq6t3u7g5BfgcQu91nKZr6RvMYf9z1Jb"); } pub mod add_new_reserved_account_keys { - solana_program::declare_id!("8U4skmMVnF6k2kMvrWbQuRUT3qQSiTYpSjqmhmgfthZu"); + solana_pubkey::declare_id!("8U4skmMVnF6k2kMvrWbQuRUT3qQSiTYpSjqmhmgfthZu"); } pub mod consume_blockstore_duplicate_proofs { - solana_program::declare_id!("6YsBCejwK96GZCkJ6mkZ4b68oP63z2PLoQmWjC7ggTqZ"); + solana_pubkey::declare_id!("6YsBCejwK96GZCkJ6mkZ4b68oP63z2PLoQmWjC7ggTqZ"); } pub mod index_erasure_conflict_duplicate_proofs { - solana_program::declare_id!("dupPajaLy2SSn8ko42aZz4mHANDNrLe8Nw8VQgFecLa"); + solana_pubkey::declare_id!("dupPajaLy2SSn8ko42aZz4mHANDNrLe8Nw8VQgFecLa"); } pub mod merkle_conflict_duplicate_proofs { - solana_program::declare_id!("mrkPjRg79B2oK2ZLgd7S3AfEJaX9B6gAF3H9aEykRUS"); + solana_pubkey::declare_id!("mrkPjRg79B2oK2ZLgd7S3AfEJaX9B6gAF3H9aEykRUS"); } pub mod disable_bpf_loader_instructions { - solana_program::declare_id!("7WeS1vfPRgeeoXArLh7879YcB9mgE9ktjPDtajXeWfXn"); + solana_pubkey::declare_id!("7WeS1vfPRgeeoXArLh7879YcB9mgE9ktjPDtajXeWfXn"); } pub mod enable_zk_proof_from_account { - solana_program::declare_id!("zkiTNuzBKxrCLMKehzuQeKZyLtX2yvFcEKMML8nExU8"); + solana_pubkey::declare_id!("zkiTNuzBKxrCLMKehzuQeKZyLtX2yvFcEKMML8nExU8"); } pub mod cost_model_requested_write_lock_cost { - solana_program::declare_id!("wLckV1a64ngtcKPRGU4S4grVTestXjmNjxBjaKZrAcn"); + solana_pubkey::declare_id!("wLckV1a64ngtcKPRGU4S4grVTestXjmNjxBjaKZrAcn"); } pub mod enable_gossip_duplicate_proof_ingestion { - solana_program::declare_id!("FNKCMBzYUdjhHyPdsKG2LSmdzH8TCHXn3ytj8RNBS4nG"); + solana_pubkey::declare_id!("FNKCMBzYUdjhHyPdsKG2LSmdzH8TCHXn3ytj8RNBS4nG"); } pub mod chained_merkle_conflict_duplicate_proofs { - solana_program::declare_id!("chaie9S2zVfuxJKNRGkyTDokLwWxx6kD2ZLsqQHaDD8"); + solana_pubkey::declare_id!("chaie9S2zVfuxJKNRGkyTDokLwWxx6kD2ZLsqQHaDD8"); } pub mod enable_chained_merkle_shreds { - solana_program::declare_id!("7uZBkJXJ1HkuP6R3MJfZs7mLwymBcDbKdqbF51ZWLier"); + solana_pubkey::declare_id!("7uZBkJXJ1HkuP6R3MJfZs7mLwymBcDbKdqbF51ZWLier"); } pub mod remove_rounding_in_fee_calculation { - solana_program::declare_id!("BtVN7YjDzNE6Dk7kTT7YTDgMNUZTNgiSJgsdzAeTg2jF"); + solana_pubkey::declare_id!("BtVN7YjDzNE6Dk7kTT7YTDgMNUZTNgiSJgsdzAeTg2jF"); } pub mod enable_tower_sync_ix { - solana_program::declare_id!("tSynMCspg4xFiCj1v3TDb4c7crMR5tSBhLz4sF7rrNA"); + solana_pubkey::declare_id!("tSynMCspg4xFiCj1v3TDb4c7crMR5tSBhLz4sF7rrNA"); } pub mod deprecate_unused_legacy_vote_plumbing { - solana_program::declare_id!("6Uf8S75PVh91MYgPQSHnjRAPQq6an5BDv9vomrCwDqLe"); + solana_pubkey::declare_id!("6Uf8S75PVh91MYgPQSHnjRAPQq6an5BDv9vomrCwDqLe"); } pub mod reward_full_priority_fee { - solana_program::declare_id!("3opE3EzAKnUftUDURkzMgwpNgimBAypW1mNDYH4x4Zg7"); + solana_pubkey::declare_id!("3opE3EzAKnUftUDURkzMgwpNgimBAypW1mNDYH4x4Zg7"); } pub mod get_sysvar_syscall_enabled { - solana_program::declare_id!("CLCoTADvV64PSrnR6QXty6Fwrt9Xc6EdxSJE4wLRePjq"); + solana_pubkey::declare_id!("CLCoTADvV64PSrnR6QXty6Fwrt9Xc6EdxSJE4wLRePjq"); } pub mod abort_on_invalid_curve { - solana_program::declare_id!("FuS3FPfJDKSNot99ECLXtp3rueq36hMNStJkPJwWodLh"); + solana_pubkey::declare_id!("FuS3FPfJDKSNot99ECLXtp3rueq36hMNStJkPJwWodLh"); } pub mod migrate_feature_gate_program_to_core_bpf { - solana_program::declare_id!("4eohviozzEeivk1y9UbrnekbAFMDQyJz5JjA9Y6gyvky"); + solana_pubkey::declare_id!("4eohviozzEeivk1y9UbrnekbAFMDQyJz5JjA9Y6gyvky"); } pub mod vote_only_full_fec_sets { - solana_program::declare_id!("ffecLRhhakKSGhMuc6Fz2Lnfq4uT9q3iu9ZsNaPLxPc"); + solana_pubkey::declare_id!("ffecLRhhakKSGhMuc6Fz2Lnfq4uT9q3iu9ZsNaPLxPc"); } pub mod migrate_config_program_to_core_bpf { - solana_program::declare_id!("2Fr57nzzkLYXW695UdDxDeR5fhnZWSttZeZYemrnpGFV"); + solana_pubkey::declare_id!("2Fr57nzzkLYXW695UdDxDeR5fhnZWSttZeZYemrnpGFV"); } pub mod enable_get_epoch_stake_syscall { - solana_program::declare_id!("7mScTYkJXsbdrcwTQRs7oeCSXoJm4WjzBsRyf8bCU3Np"); + solana_pubkey::declare_id!("7mScTYkJXsbdrcwTQRs7oeCSXoJm4WjzBsRyf8bCU3Np"); } pub mod migrate_address_lookup_table_program_to_core_bpf { - solana_program::declare_id!("C97eKZygrkU4JxJsZdjgbUY7iQR7rKTr4NyDWo2E5pRm"); + solana_pubkey::declare_id!("C97eKZygrkU4JxJsZdjgbUY7iQR7rKTr4NyDWo2E5pRm"); } pub mod zk_elgamal_proof_program_enabled { - solana_program::declare_id!("zkhiy5oLowR7HY4zogXjCjeMXyruLqBwSWH21qcFtnv"); + solana_pubkey::declare_id!("zkhiy5oLowR7HY4zogXjCjeMXyruLqBwSWH21qcFtnv"); } pub mod verify_retransmitter_signature { - solana_program::declare_id!("BZ5g4hRbu5hLQQBdPyo2z9icGyJ8Khiyj3QS6dhWijTb"); + solana_pubkey::declare_id!("BZ5g4hRbu5hLQQBdPyo2z9icGyJ8Khiyj3QS6dhWijTb"); } pub mod move_stake_and_move_lamports_ixs { - solana_program::declare_id!("7bTK6Jis8Xpfrs8ZoUfiMDPazTcdPcTWheZFJTA5Z6X4"); + solana_pubkey::declare_id!("7bTK6Jis8Xpfrs8ZoUfiMDPazTcdPcTWheZFJTA5Z6X4"); } pub mod ed25519_precompile_verify_strict { - solana_program::declare_id!("ed9tNscbWLYBooxWA7FE2B5KHWs8A6sxfY8EzezEcoo"); + solana_pubkey::declare_id!("ed9tNscbWLYBooxWA7FE2B5KHWs8A6sxfY8EzezEcoo"); } pub mod vote_only_retransmitter_signed_fec_sets { - solana_program::declare_id!("RfEcA95xnhuwooVAhUUksEJLZBF7xKCLuqrJoqk4Zph"); + solana_pubkey::declare_id!("RfEcA95xnhuwooVAhUUksEJLZBF7xKCLuqrJoqk4Zph"); } pub mod move_precompile_verification_to_svm { - solana_program::declare_id!("9ypxGLzkMxi89eDerRKXWDXe44UY2z4hBig4mDhNq5Dp"); + solana_pubkey::declare_id!("9ypxGLzkMxi89eDerRKXWDXe44UY2z4hBig4mDhNq5Dp"); } pub mod enable_transaction_loading_failure_fees { - solana_program::declare_id!("PaymEPK2oqwT9TXAVfadjztH2H6KfLEB9Hhd5Q5frvP"); + solana_pubkey::declare_id!("PaymEPK2oqwT9TXAVfadjztH2H6KfLEB9Hhd5Q5frvP"); } pub mod enable_turbine_extended_fanout_experiments { - solana_program::declare_id!("BZn14Liea52wtBwrXUxTv6vojuTTmfc7XGEDTXrvMD7b"); + solana_pubkey::declare_id!("BZn14Liea52wtBwrXUxTv6vojuTTmfc7XGEDTXrvMD7b"); } pub mod deprecate_legacy_vote_ixs { - solana_program::declare_id!("depVvnQ2UysGrhwdiwU42tCadZL8GcBb1i2GYhMopQv"); + solana_pubkey::declare_id!("depVvnQ2UysGrhwdiwU42tCadZL8GcBb1i2GYhMopQv"); } pub mod disable_sbpf_v1_execution { - solana_program::declare_id!("TestFeature11111111111111111111111111111111"); + solana_pubkey::declare_id!("TestFeature11111111111111111111111111111111"); } pub mod reenable_sbpf_v1_execution { - solana_program::declare_id!("TestFeature21111111111111111111111111111111"); + solana_pubkey::declare_id!("TestFeature21111111111111111111111111111111"); } lazy_static! { @@ -1173,7 +1171,7 @@ impl FeatureSet { } /// Activate a feature - pub fn activate(&mut self, feature_id: &Pubkey, slot: u64) { + pub fn activate(&mut self, feature_id: &Pubkey, slot: Slot) { self.inactive.remove(feature_id); self.active.insert(*feature_id, slot); } From d08ef44fd8d04f7b293304f96317860e83b8e32a Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 16:27:09 +0400 Subject: [PATCH 08/23] Move `solana_sdk::pubkey` functions to solana-pubkey (#2980) * move functions from solana_sdk::pubkey to solana_pubkey * fix test * remove serde_json from write_pubkey_file * remove serde_json * fix import * put new_rand behind a separate feature * lint * fix imports * fmt * deprecate sdk::pubkey::{read_pubkey_file, write_pubkey_file} and duplicate in solana-keygen * lint --- Cargo.lock | 1 + keygen/Cargo.toml | 1 + keygen/src/keygen.rs | 42 +++++++++++++++++++++++++++++++++++++---- programs/sbf/Cargo.lock | 1 + sdk/Cargo.toml | 3 ++- sdk/pubkey/Cargo.toml | 5 +++-- sdk/pubkey/src/lib.rs | 6 ++++++ sdk/src/pubkey.rs | 35 ++++++++++------------------------ 8 files changed, 62 insertions(+), 32 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index d9fc78c2b7ca74..7492ea20dc02f3 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -6876,6 +6876,7 @@ dependencies = [ "clap 3.2.23", "dirs-next", "num_cpus", + "serde_json", "solana-clap-v3-utils", "solana-cli-config", "solana-derivation-path", diff --git a/keygen/Cargo.toml b/keygen/Cargo.toml index 4dd74305996883..93c5e4f2e4f064 100644 --- a/keygen/Cargo.toml +++ b/keygen/Cargo.toml @@ -14,6 +14,7 @@ bs58 = { workspace = true } clap = { version = "3.1.5", features = ["cargo"] } dirs-next = { workspace = true } num_cpus = { workspace = true } +serde_json = { workspace = true } solana-clap-v3-utils = { workspace = true } solana-cli-config = { workspace = true } solana-derivation-path = { workspace = true } diff --git a/keygen/src/keygen.rs b/keygen/src/keygen.rs index cbccb33e9a9095..6f0b9ff93adc18 100644 --- a/keygen/src/keygen.rs +++ b/keygen/src/keygen.rs @@ -30,7 +30,7 @@ use { solana_sdk::{ instruction::{AccountMeta, Instruction}, message::Message, - pubkey::{write_pubkey_file, Pubkey}, + pubkey::Pubkey, signature::{ keypair_from_seed, keypair_from_seed_and_derivation_path, write_keypair, write_keypair_file, Keypair, Signer, @@ -424,6 +424,21 @@ fn app<'a>(num_threads: &'a str, crate_version: &'a str) -> Command<'a> { ) } +fn write_pubkey_file(outfile: &str, pubkey: Pubkey) -> Result<(), Box> { + use std::io::Write; + + let printable = format!("{pubkey}"); + let serialized = serde_json::to_string(&printable)?; + + if let Some(outdir) = std::path::Path::new(&outfile).parent() { + std::fs::create_dir_all(outdir)?; + } + let mut f = std::fs::File::create(outfile)?; + f.write_all(&serialized.into_bytes())?; + + Ok(()) +} + fn main() -> Result<(), Box> { let default_num_threads = num_cpus::get().to_string(); let matches = app(&default_num_threads, solana_version::version!()) @@ -768,6 +783,14 @@ mod tests { tempfile::{tempdir, TempDir}, }; + fn read_pubkey_file(infile: &str) -> Result> { + let f = std::fs::File::open(infile)?; + let printable: String = serde_json::from_reader(f)?; + + use std::str::FromStr; + Ok(Pubkey::from_str(&printable)?) + } + fn process_test_command(args: &[&str]) -> Result<(), Box> { let default_num_threads = num_cpus::get().to_string(); let solana_version = solana_version::version!(); @@ -919,7 +942,7 @@ mod tests { ]) .unwrap(); - let result_pubkey = solana_sdk::pubkey::read_pubkey_file(&outfile_path).unwrap(); + let result_pubkey = read_pubkey_file(&outfile_path).unwrap(); assert_eq!(result_pubkey, expected_pubkey); } @@ -938,7 +961,7 @@ mod tests { ]) .unwrap(); - let result_pubkey = solana_sdk::pubkey::read_pubkey_file(&outfile_path).unwrap(); + let result_pubkey = read_pubkey_file(&outfile_path).unwrap(); assert_eq!(result_pubkey, expected_pubkey); } @@ -962,7 +985,7 @@ mod tests { ]) .unwrap(); - let result_pubkey = solana_sdk::pubkey::read_pubkey_file(&outfile_path).unwrap(); + let result_pubkey = read_pubkey_file(&outfile_path).unwrap(); assert_eq!(result_pubkey, expected_pubkey); } @@ -1129,4 +1152,15 @@ mod tests { ]) .unwrap(); } + + #[test] + fn test_read_write_pubkey() -> Result<(), std::boxed::Box> { + let filename = "test_pubkey.json"; + let pubkey = solana_sdk::pubkey::new_rand(); + write_pubkey_file(filename, pubkey)?; + let read = read_pubkey_file(filename)?; + assert_eq!(read, pubkey); + std::fs::remove_file(filename)?; + Ok(()) + } } diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index a6a832fbbd3621..e16c7d4a3a926c 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -5828,6 +5828,7 @@ dependencies = [ "getrandom 0.2.10", "js-sys", "num-traits", + "rand 0.8.5", "serde", "serde_derive", "solana-atomic-u64", diff --git a/sdk/Cargo.toml b/sdk/Cargo.toml index 10eb2b0f8a6c8a..938e21a2aed8c0 100644 --- a/sdk/Cargo.toml +++ b/sdk/Cargo.toml @@ -33,6 +33,7 @@ full = [ "libsecp256k1", "sha3", "digest", + "solana-pubkey/rand", ] borsh = ["dep:borsh", "solana-program/borsh", "solana-secp256k1-recover/borsh"] dev-context-only-utils = ["qualifier_attr", "solana-account/dev-context-only-utils"] @@ -97,7 +98,7 @@ solana-frozen-abi-macro = { workspace = true, optional = true, features = [ ] } solana-program = { workspace = true } solana-program-memory = { workspace = true } -solana-pubkey = { workspace = true } +solana-pubkey = { workspace = true, default-features = false, features = ["std"] } solana-sanitize = { workspace = true } solana-sdk-macro = { workspace = true } solana-secp256k1-recover = { workspace = true } diff --git a/sdk/pubkey/Cargo.toml b/sdk/pubkey/Cargo.toml index 50d7a5ed6bdef7..cdafef8a939f15 100644 --- a/sdk/pubkey/Cargo.toml +++ b/sdk/pubkey/Cargo.toml @@ -18,6 +18,7 @@ bytemuck = { workspace = true, optional = true } bytemuck_derive = { workspace = true, optional = true } five8_const = { workspace = true } num-traits = { workspace = true } +rand = { workspace = true, optional = true } serde = { workspace = true, optional = true } serde_derive = { workspace = true, optional = true } solana-atomic-u64 = { workspace = true } @@ -47,7 +48,6 @@ wasm-bindgen = { workspace = true } anyhow = { workspace = true } arbitrary = { workspace = true, features = ["derive"] } bs58 = { workspace = true, features = ["alloc"] } -rand = { workspace = true } # circular dev deps need to be path deps for `cargo publish` to be happy, # and for now the doc tests need solana-program solana-program = { path = "../program" } @@ -65,11 +65,12 @@ borsh = ["dep:borsh", "dep:borsh0-10", "std"] bytemuck = ["dep:bytemuck", "dep:bytemuck_derive"] curve25519 = ["dep:curve25519-dalek", "sha2"] default = ["std"] -dev-context-only-utils = ["dep:arbitrary", "std"] +dev-context-only-utils = ["dep:arbitrary", "rand"] frozen-abi = [ "dep:solana-frozen-abi", "dep:solana-frozen-abi-macro" ] +rand = ["dep:rand", "std"] serde = ["dep:serde", "dep:serde_derive"] sha2 = ["dep:solana-sha256-hasher", "solana-sha256-hasher/sha2"] std = [] diff --git a/sdk/pubkey/src/lib.rs b/sdk/pubkey/src/lib.rs index e378c44caf3f06..d603d6a97b3b9b 100644 --- a/sdk/pubkey/src/lib.rs +++ b/sdk/pubkey/src/lib.rs @@ -1114,6 +1114,12 @@ macro_rules! pubkey { }; } +/// New random Pubkey for tests and benchmarks. +#[cfg(all(feature = "rand", not(target_os = "solana")))] +pub fn new_rand() -> Pubkey { + Pubkey::from(rand::random::<[u8; PUBKEY_BYTES]>()) +} + #[cfg(test)] mod tests { use {super::*, strum::IntoEnumIterator}; diff --git a/sdk/src/pubkey.rs b/sdk/src/pubkey.rs index 92d1365d03c5bf..344f0698444cb2 100644 --- a/sdk/src/pubkey.rs +++ b/sdk/src/pubkey.rs @@ -1,13 +1,13 @@ -//! Solana account addresses. - -pub use solana_program::pubkey::*; - -/// New random Pubkey for tests and benchmarks. #[cfg(feature = "full")] -pub fn new_rand() -> Pubkey { - Pubkey::from(rand::random::<[u8; PUBKEY_BYTES]>()) -} - +pub use solana_pubkey::new_rand; +#[cfg(target_os = "solana")] +pub use solana_pubkey::syscalls; +pub use solana_pubkey::{ + bytes_are_curve_point, ParsePubkeyError, Pubkey, PubkeyError, MAX_SEEDS, MAX_SEED_LEN, + PUBKEY_BYTES, +}; + +#[deprecated(since = "2.1.0")] #[cfg(feature = "full")] pub fn write_pubkey_file(outfile: &str, pubkey: Pubkey) -> Result<(), Box> { use std::io::Write; @@ -24,6 +24,7 @@ pub fn write_pubkey_file(outfile: &str, pubkey: Pubkey) -> Result<(), Box Result> { let f = std::fs::File::open(infile)?; @@ -32,19 +33,3 @@ pub fn read_pubkey_file(infile: &str) -> Result Result<(), Box> { - let filename = "test_pubkey.json"; - let pubkey = solana_sdk::pubkey::new_rand(); - write_pubkey_file(filename, pubkey)?; - let read = read_pubkey_file(filename)?; - assert_eq!(read, pubkey); - remove_file(filename)?; - Ok(()) - } -} From 19c1e1be709fdd96ff441dd46fcd02bda1eafe01 Mon Sep 17 00:00:00 2001 From: Joe C Date: Tue, 15 Oct 2024 20:38:16 +0700 Subject: [PATCH 09/23] SVM: paytube: update cache prep for token program (#3168) --- svm/examples/paytube/src/processor.rs | 48 +++++++++++---------------- 1 file changed, 20 insertions(+), 28 deletions(-) diff --git a/svm/examples/paytube/src/processor.rs b/svm/examples/paytube/src/processor.rs index 71eaccc956826b..03a8336209ca29 100644 --- a/svm/examples/paytube/src/processor.rs +++ b/svm/examples/paytube/src/processor.rs @@ -3,17 +3,18 @@ use { solana_bpf_loader_program::syscalls::create_program_runtime_environment_v1, solana_compute_budget::compute_budget::ComputeBudget, - solana_program_runtime::loaded_programs::{ - BlockRelation, ForkGraph, LoadProgramMetrics, ProgramCacheEntry, - }, - solana_sdk::{account::ReadableAccount, clock::Slot, feature_set::FeatureSet, transaction}, + solana_program_runtime::loaded_programs::{BlockRelation, ForkGraph, ProgramCacheEntry}, + solana_sdk::{clock::Slot, feature_set::FeatureSet, transaction}, solana_svm::{ account_loader::CheckedTransactionDetails, transaction_processing_callback::TransactionProcessingCallback, transaction_processor::TransactionBatchProcessor, }, solana_system_program::system_processor, - std::sync::{Arc, RwLock}, + std::{ + collections::HashSet, + sync::{Arc, RwLock}, + }, }; /// In order to use the `TransactionBatchProcessor`, another trait - Solana @@ -40,13 +41,25 @@ pub(crate) fn create_transaction_batch_processor>, ) -> TransactionBatchProcessor { - let processor = TransactionBatchProcessor::::default(); + // Create a new transaction batch processor. + // + // We're going to use slot 1 specifically because any programs we add will + // be deployed in slot 0, and they are delayed visibility until the next + // slot (1). + // This includes programs owned by BPF Loader v2, which are automatically + // marked as "depoyed" in slot 0. + // See `solana_svm::program_loader::load_program_with_pubkey` for more + // details. + let processor = TransactionBatchProcessor::::new( + /* slot */ 1, + /* epoch */ 1, + /* builtin_program_ids */ HashSet::new(), + ); { let mut cache = processor.program_cache.write().unwrap(); // Initialize the mocked fork graph. - // let fork_graph = Arc::new(RwLock::new(PayTubeForkGraph {})); cache.fork_graph = Some(Arc::downgrade(&fork_graph)); // Initialize a proper cache environment. @@ -55,27 +68,6 @@ pub(crate) fn create_transaction_batch_processor Date: Tue, 15 Oct 2024 07:22:53 -0700 Subject: [PATCH 10/23] svm: clear read-only non-signers for test txns (#3157) --- svm/tests/transaction_builder.rs | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/svm/tests/transaction_builder.rs b/svm/tests/transaction_builder.rs index 803487773a63ec..664ea6237120cb 100644 --- a/svm/tests/transaction_builder.rs +++ b/svm/tests/transaction_builder.rs @@ -26,7 +26,7 @@ pub struct SanitizedTransactionBuilder { signed_readonly_accounts: Vec<(Pubkey, Signature)>, signed_mutable_accounts: Vec<(Pubkey, Signature)>, unsigned_readonly_accounts: Vec, - unsigned_mutable_account: Vec, + unsigned_mutable_accounts: Vec, } #[derive(PartialEq, Eq, Hash, Clone)] @@ -91,7 +91,7 @@ impl SanitizedTransactionBuilder { AccountType::SignerReadonly } (false, true) => { - self.unsigned_mutable_account.push(item.pubkey); + self.unsigned_mutable_accounts.push(item.pubkey); AccountType::Writable } (false, false) => { @@ -117,7 +117,7 @@ impl SanitizedTransactionBuilder { self.signed_mutable_accounts .len() .saturating_add(self.signed_readonly_accounts.len()) - .saturating_add(self.unsigned_mutable_account.len()) + .saturating_add(self.unsigned_mutable_accounts.len()) .saturating_add(self.unsigned_readonly_accounts.len()) .saturating_add(1), ); @@ -159,7 +159,7 @@ impl SanitizedTransactionBuilder { positions_lambda(key, AccountType::SignerReadonly); signatures.push(*signature); }); - self.unsigned_mutable_account + self.unsigned_mutable_accounts .iter() .for_each(|key| positions_lambda(key, AccountType::Writable)); self.unsigned_readonly_accounts @@ -232,8 +232,8 @@ impl SanitizedTransactionBuilder { self.num_readonly_unsigned_accounts = 0; self.signed_mutable_accounts.clear(); self.signed_readonly_accounts.clear(); - self.unsigned_mutable_account.clear(); - self.unsigned_mutable_account.clear(); + self.unsigned_mutable_accounts.clear(); + self.unsigned_readonly_accounts.clear(); instructions } From a018567931bebd6b71b818eedb37c1b62c63c889 Mon Sep 17 00:00:00 2001 From: Brooks Date: Tue, 15 Oct 2024 10:58:03 -0400 Subject: [PATCH 11/23] Supports accounts lt hash in ledger-tool (#3173) --- ledger-tool/src/args.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/ledger-tool/src/args.rs b/ledger-tool/src/args.rs index e9149f7b9cab4b..61d3208fe848aa 100644 --- a/ledger-tool/src/args.rs +++ b/ledger-tool/src/args.rs @@ -345,6 +345,8 @@ pub fn get_accounts_db_config( create_ancient_storage, storage_access, scan_filter_for_shrinking, + enable_experimental_accumulator_hash: arg_matches + .is_present("accounts_db_experimental_accumulator_hash"), ..AccountsDbConfig::default() } } From 7b0a57316d0626312a704ee5b50603123d959f7c Mon Sep 17 00:00:00 2001 From: Andrew Fitzgerald Date: Tue, 15 Oct 2024 10:25:36 -0500 Subject: [PATCH 12/23] Scheduler: Improve TTL (#3161) Co-authored-by: Justin Starry --- accounts-db/src/accounts.rs | 42 ++-- core/src/banking_stage/consume_worker.rs | 223 ++++++++++++++++-- core/src/banking_stage/consumer.rs | 32 ++- .../immutable_deserialized_packet.rs | 42 +++- .../banking_stage/latest_unprocessed_votes.rs | 2 +- core/src/banking_stage/scheduler_messages.rs | 8 +- .../prio_graph_scheduler.rs | 46 ++-- .../scheduler_controller.rs | 127 ++++++++-- .../transaction_state.rs | 46 +++- .../transaction_state_container.rs | 6 +- .../unprocessed_packet_batches.rs | 16 +- .../unprocessed_transaction_storage.rs | 8 +- runtime/src/bank/address_lookup_table.rs | 18 +- sdk/program/src/address_lookup_table/state.rs | 14 ++ 14 files changed, 505 insertions(+), 125 deletions(-) diff --git a/accounts-db/src/accounts.rs b/accounts-db/src/accounts.rs index 2584f900edbc49..cce35988aff69d 100644 --- a/accounts-db/src/accounts.rs +++ b/accounts-db/src/accounts.rs @@ -81,12 +81,14 @@ impl Accounts { } } + /// Return loaded addresses and the deactivation slot. + /// If the table hasn't been deactivated, the deactivation slot is `u64::MAX`. pub fn load_lookup_table_addresses( &self, ancestors: &Ancestors, address_table_lookup: SVMMessageAddressTableLookup, slot_hashes: &SlotHashes, - ) -> std::result::Result { + ) -> std::result::Result<(LoadedAddresses, Slot), AddressLookupError> { let table_account = self .accounts_db .load_with_fixed_root(ancestors, address_table_lookup.account_key) @@ -98,18 +100,21 @@ impl Accounts { let lookup_table = AddressLookupTable::deserialize(table_account.data()) .map_err(|_ix_err| AddressLookupError::InvalidAccountData)?; - Ok(LoadedAddresses { - writable: lookup_table.lookup( - current_slot, - address_table_lookup.writable_indexes, - slot_hashes, - )?, - readonly: lookup_table.lookup( - current_slot, - address_table_lookup.readonly_indexes, - slot_hashes, - )?, - }) + Ok(( + LoadedAddresses { + writable: lookup_table.lookup( + current_slot, + address_table_lookup.writable_indexes, + slot_hashes, + )?, + readonly: lookup_table.lookup( + current_slot, + address_table_lookup.readonly_indexes, + slot_hashes, + )?, + }, + lookup_table.meta.deactivation_slot, + )) } else { Err(AddressLookupError::InvalidAccountOwner) } @@ -806,10 +811,13 @@ mod tests { SVMMessageAddressTableLookup::from(&address_table_lookup), &SlotHashes::default(), ), - Ok(LoadedAddresses { - writable: vec![table_addresses[0]], - readonly: vec![table_addresses[1]], - }), + Ok(( + LoadedAddresses { + writable: vec![table_addresses[0]], + readonly: vec![table_addresses[1]], + }, + u64::MAX + )), ); } diff --git a/core/src/banking_stage/consume_worker.rs b/core/src/banking_stage/consume_worker.rs index b676168bb04d4d..787901ffa521f8 100644 --- a/core/src/banking_stage/consume_worker.rs +++ b/core/src/banking_stage/consume_worker.rs @@ -107,7 +107,7 @@ impl ConsumeWorker { let output = self.consumer.process_and_record_aged_transactions( bank, &work.transactions, - &work.max_age_slots, + &work.max_ages, ); self.metrics.update_for_consume(&output); @@ -694,7 +694,7 @@ mod tests { crate::banking_stage::{ committer::Committer, qos_service::QosService, - scheduler_messages::{TransactionBatchId, TransactionId}, + scheduler_messages::{MaxAge, TransactionBatchId, TransactionId}, tests::{create_slow_genesis_config, sanitize_transactions, simulate_poh}, }, crossbeam_channel::unbounded, @@ -708,10 +708,25 @@ mod tests { vote_sender_types::ReplayVoteReceiver, }, solana_sdk::{ - genesis_config::GenesisConfig, poh_config::PohConfig, pubkey::Pubkey, - signature::Keypair, system_transaction, + address_lookup_table::AddressLookupTableAccount, + clock::{Slot, MAX_PROCESSING_AGE}, + genesis_config::GenesisConfig, + message::{ + v0::{self, LoadedAddresses}, + SimpleAddressLoader, VersionedMessage, + }, + poh_config::PohConfig, + pubkey::Pubkey, + signature::Keypair, + signer::Signer, + system_instruction, system_transaction, + transaction::{ + MessageHash, SanitizedTransaction, TransactionError, VersionedTransaction, + }, }, + solana_svm_transaction::svm_message::SVMMessage, std::{ + collections::HashSet, sync::{atomic::AtomicBool, RwLock}, thread::JoinHandle, }, @@ -742,6 +757,7 @@ mod tests { .. } = create_slow_genesis_config(10_000); let (bank, bank_forks) = Bank::new_no_wallclock_throttle_for_tests(&genesis_config); + let bank = Arc::new(Bank::new_from_parent(bank, &Pubkey::new_unique(), 1)); let ledger_path = get_tmp_ledger_path_auto_delete!(); let blockstore = Blockstore::open(ledger_path.path()) @@ -820,17 +836,21 @@ mod tests { )]); let bid = TransactionBatchId::new(0); let id = TransactionId::new(0); + let max_age = MaxAge { + epoch_invalidation_slot: bank.slot(), + alt_invalidation_slot: bank.slot(), + }; let work = ConsumeWork { batch_id: bid, ids: vec![id], transactions, - max_age_slots: vec![bank.slot()], + max_ages: vec![max_age], }; consume_sender.send(work).unwrap(); let consumed = consumed_receiver.recv().unwrap(); assert_eq!(consumed.work.batch_id, bid); assert_eq!(consumed.work.ids, vec![id]); - assert_eq!(consumed.work.max_age_slots, vec![bank.slot()]); + assert_eq!(consumed.work.max_ages, vec![max_age]); assert_eq!(consumed.retryable_indexes, vec![0]); drop(test_frame); @@ -865,17 +885,21 @@ mod tests { )]); let bid = TransactionBatchId::new(0); let id = TransactionId::new(0); + let max_age = MaxAge { + epoch_invalidation_slot: bank.slot(), + alt_invalidation_slot: bank.slot(), + }; let work = ConsumeWork { batch_id: bid, ids: vec![id], transactions, - max_age_slots: vec![bank.slot()], + max_ages: vec![max_age], }; consume_sender.send(work).unwrap(); let consumed = consumed_receiver.recv().unwrap(); assert_eq!(consumed.work.batch_id, bid); assert_eq!(consumed.work.ids, vec![id]); - assert_eq!(consumed.work.max_age_slots, vec![bank.slot()]); + assert_eq!(consumed.work.max_ages, vec![max_age]); assert_eq!(consumed.retryable_indexes, Vec::::new()); drop(test_frame); @@ -911,19 +935,23 @@ mod tests { let bid = TransactionBatchId::new(0); let id1 = TransactionId::new(1); let id2 = TransactionId::new(0); + let max_age = MaxAge { + epoch_invalidation_slot: bank.slot(), + alt_invalidation_slot: bank.slot(), + }; consume_sender .send(ConsumeWork { batch_id: bid, ids: vec![id1, id2], transactions: txs, - max_age_slots: vec![bank.slot(), bank.slot()], + max_ages: vec![max_age, max_age], }) .unwrap(); let consumed = consumed_receiver.recv().unwrap(); assert_eq!(consumed.work.batch_id, bid); assert_eq!(consumed.work.ids, vec![id1, id2]); - assert_eq!(consumed.work.max_age_slots, vec![bank.slot(), bank.slot()]); + assert_eq!(consumed.work.max_ages, vec![max_age, max_age]); assert_eq!(consumed.retryable_indexes, vec![1]); // id2 is retryable since lock conflict drop(test_frame); @@ -968,12 +996,16 @@ mod tests { let bid2 = TransactionBatchId::new(1); let id1 = TransactionId::new(1); let id2 = TransactionId::new(0); + let max_age = MaxAge { + epoch_invalidation_slot: bank.slot(), + alt_invalidation_slot: bank.slot(), + }; consume_sender .send(ConsumeWork { batch_id: bid1, ids: vec![id1], transactions: txs1, - max_age_slots: vec![bank.slot()], + max_ages: vec![max_age], }) .unwrap(); @@ -982,22 +1014,185 @@ mod tests { batch_id: bid2, ids: vec![id2], transactions: txs2, - max_age_slots: vec![bank.slot()], + max_ages: vec![max_age], }) .unwrap(); let consumed = consumed_receiver.recv().unwrap(); assert_eq!(consumed.work.batch_id, bid1); assert_eq!(consumed.work.ids, vec![id1]); - assert_eq!(consumed.work.max_age_slots, vec![bank.slot()]); + assert_eq!(consumed.work.max_ages, vec![max_age]); assert_eq!(consumed.retryable_indexes, Vec::::new()); let consumed = consumed_receiver.recv().unwrap(); assert_eq!(consumed.work.batch_id, bid2); assert_eq!(consumed.work.ids, vec![id2]); - assert_eq!(consumed.work.max_age_slots, vec![bank.slot()]); + assert_eq!(consumed.work.max_ages, vec![max_age]); assert_eq!(consumed.retryable_indexes, Vec::::new()); drop(test_frame); let _ = worker_thread.join().unwrap(); } + + #[test] + fn test_worker_ttl() { + let (test_frame, worker) = setup_test_frame(); + let TestFrame { + mint_keypair, + genesis_config, + bank, + poh_recorder, + consume_sender, + consumed_receiver, + .. + } = &test_frame; + let worker_thread = std::thread::spawn(move || worker.run()); + poh_recorder + .write() + .unwrap() + .set_bank_for_test(bank.clone()); + assert!(bank.slot() > 0); + + // No conflicts between transactions. Test 6 cases. + // 1. Epoch expiration, before slot => still succeeds due to resanitizing + // 2. Epoch expiration, on slot => succeeds normally + // 3. Epoch expiration, after slot => succeeds normally + // 4. ALT expiration, before slot => fails + // 5. ALT expiration, on slot => succeeds normally + // 6. ALT expiration, after slot => succeeds normally + let simple_transfer = || { + system_transaction::transfer( + &Keypair::new(), + &Pubkey::new_unique(), + 1, + genesis_config.hash(), + ) + }; + let simple_v0_transfer = || { + let payer = Keypair::new(); + let to_pubkey = Pubkey::new_unique(); + let loaded_addresses = LoadedAddresses { + writable: vec![to_pubkey], + readonly: vec![], + }; + let loader = SimpleAddressLoader::Enabled(loaded_addresses); + SanitizedTransaction::try_create( + VersionedTransaction::try_new( + VersionedMessage::V0( + v0::Message::try_compile( + &payer.pubkey(), + &[system_instruction::transfer(&payer.pubkey(), &to_pubkey, 1)], + &[AddressLookupTableAccount { + key: Pubkey::new_unique(), // will fail if using **bank** to lookup + addresses: vec![to_pubkey], + }], + genesis_config.hash(), + ) + .unwrap(), + ), + &[&payer], + ) + .unwrap(), + MessageHash::Compute, + None, + loader, + &HashSet::default(), + ) + .unwrap() + }; + + let mut txs = sanitize_transactions(vec![ + simple_transfer(), + simple_transfer(), + simple_transfer(), + ]); + txs.push(simple_v0_transfer()); + txs.push(simple_v0_transfer()); + txs.push(simple_v0_transfer()); + let sanitized_txs = txs.clone(); + + // Fund the keypairs. + for tx in &txs { + bank.process_transaction(&system_transaction::transfer( + mint_keypair, + &tx.account_keys()[0], + 2, + genesis_config.hash(), + )) + .unwrap(); + } + + consume_sender + .send(ConsumeWork { + batch_id: TransactionBatchId::new(1), + ids: vec![ + TransactionId::new(0), + TransactionId::new(1), + TransactionId::new(2), + TransactionId::new(3), + TransactionId::new(4), + TransactionId::new(5), + ], + transactions: txs, + max_ages: vec![ + MaxAge { + epoch_invalidation_slot: bank.slot() - 1, + alt_invalidation_slot: Slot::MAX, + }, + MaxAge { + epoch_invalidation_slot: bank.slot(), + alt_invalidation_slot: Slot::MAX, + }, + MaxAge { + epoch_invalidation_slot: bank.slot() + 1, + alt_invalidation_slot: Slot::MAX, + }, + MaxAge { + epoch_invalidation_slot: u64::MAX, + alt_invalidation_slot: bank.slot() - 1, + }, + MaxAge { + epoch_invalidation_slot: u64::MAX, + alt_invalidation_slot: bank.slot(), + }, + MaxAge { + epoch_invalidation_slot: u64::MAX, + alt_invalidation_slot: bank.slot() + 1, + }, + ], + }) + .unwrap(); + + let consumed = consumed_receiver.recv().unwrap(); + assert_eq!(consumed.retryable_indexes, Vec::::new()); + // all but one succeed. 6 for initial funding + assert_eq!(bank.transaction_count(), 6 + 5); + + let already_processed_results = bank + .check_transactions( + &sanitized_txs, + &vec![Ok(()); sanitized_txs.len()], + MAX_PROCESSING_AGE, + &mut TransactionErrorMetrics::default(), + ) + .into_iter() + .map(|r| match r { + Ok(_) => Ok(()), + Err(err) => Err(err), + }) + .collect::>(); + assert_eq!( + already_processed_results, + vec![ + Err(TransactionError::AlreadyProcessed), + Err(TransactionError::AlreadyProcessed), + Err(TransactionError::AlreadyProcessed), + Ok(()), // <--- this transaction was not processed + Err(TransactionError::AlreadyProcessed), + Err(TransactionError::AlreadyProcessed) + ] + ); + + drop(test_frame); + let _ = worker_thread.join().unwrap(); + } } diff --git a/core/src/banking_stage/consumer.rs b/core/src/banking_stage/consumer.rs index 57f1b1958b152c..ae04cc30ff0167 100644 --- a/core/src/banking_stage/consumer.rs +++ b/core/src/banking_stage/consumer.rs @@ -7,6 +7,7 @@ use { }, leader_slot_timing_metrics::LeaderExecuteAndCommitTimings, qos_service::QosService, + scheduler_messages::MaxAge, unprocessed_transaction_storage::{ConsumeScannerPayload, UnprocessedTransactionStorage}, BankingStageStats, }, @@ -25,12 +26,12 @@ use { }, solana_runtime_transaction::instructions_processor::process_compute_budget_instructions, solana_sdk::{ - clock::{Slot, FORWARD_TRANSACTIONS_TO_LEADER_AT_SLOT_OFFSET, MAX_PROCESSING_AGE}, + clock::{FORWARD_TRANSACTIONS_TO_LEADER_AT_SLOT_OFFSET, MAX_PROCESSING_AGE}, fee::FeeBudgetLimits, message::SanitizedMessage, saturating_add_assign, timing::timestamp, - transaction::{self, AddressLoader, SanitizedTransaction, TransactionError}, + transaction::{self, SanitizedTransaction, TransactionError}, }, solana_svm::{ account_loader::{validate_fee_payer, TransactionCheckResult}, @@ -429,7 +430,7 @@ impl Consumer { &self, bank: &Arc, txs: &[SanitizedTransaction], - max_slot_ages: &[Slot], + max_ages: &[MaxAge], ) -> ProcessTransactionBatchOutput { let move_precompile_verification_to_svm = bank .feature_set @@ -438,8 +439,9 @@ impl Consumer { // Need to filter out transactions since they were sanitized earlier. // This means that the transaction may cross and epoch boundary (not allowed), // or account lookup tables may have been closed. - let pre_results = txs.iter().zip(max_slot_ages).map(|(tx, max_slot_age)| { - if *max_slot_age < bank.slot() { + let pre_results = txs.iter().zip(max_ages).map(|(tx, max_age)| { + if bank.slot() > max_age.epoch_invalidation_slot { + // Epoch has rolled over. Need to fully re-verify the transaction. // Pre-compiles are verified here. // Attempt re-sanitization after epoch-cross. // Re-sanitized transaction should be equal to the original transaction, @@ -451,18 +453,24 @@ impl Consumer { return Err(TransactionError::ResanitizationNeeded); } } else { + if bank.slot() > max_age.alt_invalidation_slot { + // The address table lookup **may** have expired, but the + // expiration is not guaranteed since there may have been + // skipped slot. + // If the addresses still resolve here, then the transaction is still + // valid, and we can continue with processing. + // If they do not, then the ATL has expired and the transaction + // can be dropped. + let (_addresses, _deactivation_slot) = + bank.load_addresses_from_ref(tx.message_address_table_lookups())?; + } + // Verify pre-compiles. if !move_precompile_verification_to_svm { verify_precompiles(tx, &bank.feature_set)?; } - - // Any transaction executed between sanitization time and now may have closed the lookup table(s). - // Above re-sanitization already loads addresses, so don't need to re-check in that case. - let lookup_tables = tx.message().message_address_table_lookups(); - if !lookup_tables.is_empty() { - bank.load_addresses(lookup_tables)?; - } } + Ok(()) }); self.process_and_record_transactions_with_pre_results(bank, txs, 0, pre_results) diff --git a/core/src/banking_stage/immutable_deserialized_packet.rs b/core/src/banking_stage/immutable_deserialized_packet.rs index b03f3d5d64d4e8..978e4f9b935c7e 100644 --- a/core/src/banking_stage/immutable_deserialized_packet.rs +++ b/core/src/banking_stage/immutable_deserialized_packet.rs @@ -2,20 +2,21 @@ use { super::packet_filter::PacketFilterFailure, solana_compute_budget::compute_budget_limits::ComputeBudgetLimits, solana_perf::packet::Packet, + solana_runtime::bank::Bank, solana_runtime_transaction::instructions_processor::process_compute_budget_instructions, solana_sanitize::SanitizeError, solana_sdk::{ + clock::Slot, hash::Hash, - message::Message, + message::{v0::LoadedAddresses, AddressLoaderError, Message, SimpleAddressLoader}, pubkey::Pubkey, signature::Signature, - transaction::{ - AddressLoader, SanitizedTransaction, SanitizedVersionedTransaction, - VersionedTransaction, - }, + transaction::{SanitizedTransaction, SanitizedVersionedTransaction, VersionedTransaction}, }, solana_short_vec::decode_shortu16_len, - solana_svm_transaction::instruction::SVMInstruction, + solana_svm_transaction::{ + instruction::SVMInstruction, message_address_table_lookup::SVMMessageAddressTableLookup, + }, std::{cmp::Ordering, collections::HashSet, mem::size_of}, thiserror::Error, }; @@ -111,15 +112,22 @@ impl ImmutableDeserializedPacket { // This function deserializes packets into transactions, computes the blake3 hash of transaction // messages. + // Additionally, this returns the minimum deactivation slot of the resolved addresses. pub fn build_sanitized_transaction( &self, votes_only: bool, - address_loader: impl AddressLoader, + bank: &Bank, reserved_account_keys: &HashSet, - ) -> Option { + ) -> Option<(SanitizedTransaction, Slot)> { if votes_only && !self.is_simple_vote() { return None; } + + // Resolve the lookup addresses and retrieve the min deactivation slot + let (loaded_addresses, deactivation_slot) = + Self::resolve_addresses_with_deactivation(self.transaction(), bank).ok()?; + let address_loader = SimpleAddressLoader::Enabled(loaded_addresses); + let tx = SanitizedTransaction::try_new( self.transaction().clone(), *self.message_hash(), @@ -128,7 +136,23 @@ impl ImmutableDeserializedPacket { reserved_account_keys, ) .ok()?; - Some(tx) + Some((tx, deactivation_slot)) + } + + fn resolve_addresses_with_deactivation( + transaction: &SanitizedVersionedTransaction, + bank: &Bank, + ) -> Result<(LoadedAddresses, Slot), AddressLoaderError> { + let Some(address_table_lookups) = transaction.get_message().message.address_table_lookups() + else { + return Ok((LoadedAddresses::default(), Slot::MAX)); + }; + + bank.load_addresses_from_ref( + address_table_lookups + .iter() + .map(SVMMessageAddressTableLookup::from), + ) } } diff --git a/core/src/banking_stage/latest_unprocessed_votes.rs b/core/src/banking_stage/latest_unprocessed_votes.rs index bb97142bda5e81..ae13c37caa5a0e 100644 --- a/core/src/banking_stage/latest_unprocessed_votes.rs +++ b/core/src/banking_stage/latest_unprocessed_votes.rs @@ -420,7 +420,7 @@ impl LatestUnprocessedVotes { } let deserialized_vote_packet = vote.vote.as_ref().unwrap().clone(); - let Some(sanitized_vote_transaction) = deserialized_vote_packet + let Some((sanitized_vote_transaction, _deactivation_slot)) = deserialized_vote_packet .build_sanitized_transaction( bank.vote_only_bank(), bank.as_ref(), diff --git a/core/src/banking_stage/scheduler_messages.rs b/core/src/banking_stage/scheduler_messages.rs index d93d2d6dbb6c52..29e9b99f50588a 100644 --- a/core/src/banking_stage/scheduler_messages.rs +++ b/core/src/banking_stage/scheduler_messages.rs @@ -35,13 +35,19 @@ impl Display for TransactionId { } } +#[derive(Copy, Clone, Debug, PartialEq, Eq)] +pub struct MaxAge { + pub epoch_invalidation_slot: Slot, + pub alt_invalidation_slot: Slot, +} + /// Message: [Scheduler -> Worker] /// Transactions to be consumed (i.e. executed, recorded, and committed) pub struct ConsumeWork { pub batch_id: TransactionBatchId, pub ids: Vec, pub transactions: Vec, - pub max_age_slots: Vec, + pub max_ages: Vec, } /// Message: [Worker -> Scheduler] diff --git a/core/src/banking_stage/transaction_scheduler/prio_graph_scheduler.rs b/core/src/banking_stage/transaction_scheduler/prio_graph_scheduler.rs index 59ce92173ed26e..9f6fcc8388a364 100644 --- a/core/src/banking_stage/transaction_scheduler/prio_graph_scheduler.rs +++ b/core/src/banking_stage/transaction_scheduler/prio_graph_scheduler.rs @@ -9,7 +9,9 @@ use { crate::banking_stage::{ consumer::TARGET_NUM_TRANSACTIONS_PER_BATCH, read_write_account_set::ReadWriteAccountSet, - scheduler_messages::{ConsumeWork, FinishedConsumeWork, TransactionBatchId, TransactionId}, + scheduler_messages::{ + ConsumeWork, FinishedConsumeWork, MaxAge, TransactionBatchId, TransactionId, + }, transaction_scheduler::{ transaction_priority_id::TransactionPriorityId, transaction_state::TransactionState, }, @@ -19,10 +21,7 @@ use { prio_graph::{AccessKind, PrioGraph}, solana_cost_model::block_cost_limits::MAX_BLOCK_UNITS, solana_measure::measure_us, - solana_sdk::{ - pubkey::Pubkey, saturating_add_assign, slot_history::Slot, - transaction::SanitizedTransaction, - }, + solana_sdk::{pubkey::Pubkey, saturating_add_assign, transaction::SanitizedTransaction}, }; pub(crate) struct PrioGraphScheduler { @@ -202,13 +201,13 @@ impl PrioGraphScheduler { Ok(TransactionSchedulingInfo { thread_id, transaction, - max_age_slot, + max_age, cost, }) => { saturating_add_assign!(num_scheduled, 1); batches.transactions[thread_id].push(transaction); batches.ids[thread_id].push(id.id); - batches.max_age_slots[thread_id].push(max_age_slot); + batches.max_ages[thread_id].push(max_age); saturating_add_assign!(batches.total_cus[thread_id], cost); // If target batch size is reached, send only this batch. @@ -309,7 +308,7 @@ impl PrioGraphScheduler { batch_id, ids, transactions, - max_age_slots, + max_ages, }, retryable_indexes, }) => { @@ -321,8 +320,8 @@ impl PrioGraphScheduler { // Retryable transactions should be inserted back into the container let mut retryable_iter = retryable_indexes.into_iter().peekable(); - for (index, (id, transaction, max_age_slot)) in - izip!(ids, transactions, max_age_slots).enumerate() + for (index, (id, transaction, max_age)) in + izip!(ids, transactions, max_ages).enumerate() { if let Some(retryable_index) = retryable_iter.peek() { if *retryable_index == index { @@ -330,7 +329,7 @@ impl PrioGraphScheduler { id, SanitizedTransactionTTL { transaction, - max_age_slot, + max_age, }, ); retryable_iter.next(); @@ -392,7 +391,7 @@ impl PrioGraphScheduler { return Ok(0); } - let (ids, transactions, max_age_slots, total_cus) = batches.take_batch(thread_index); + let (ids, transactions, max_ages, total_cus) = batches.take_batch(thread_index); let batch_id = self .in_flight_tracker @@ -403,7 +402,7 @@ impl PrioGraphScheduler { batch_id, ids, transactions, - max_age_slots, + max_ages, }; self.consume_work_senders[thread_index] .send(work) @@ -477,7 +476,7 @@ pub(crate) struct SchedulingSummary { struct Batches { ids: Vec>, transactions: Vec>, - max_age_slots: Vec>, + max_ages: Vec>, total_cus: Vec, } @@ -486,7 +485,7 @@ impl Batches { Self { ids: vec![Vec::with_capacity(TARGET_NUM_TRANSACTIONS_PER_BATCH); num_threads], transactions: vec![Vec::with_capacity(TARGET_NUM_TRANSACTIONS_PER_BATCH); num_threads], - max_age_slots: vec![Vec::with_capacity(TARGET_NUM_TRANSACTIONS_PER_BATCH); num_threads], + max_ages: vec![Vec::with_capacity(TARGET_NUM_TRANSACTIONS_PER_BATCH); num_threads], total_cus: vec![0; num_threads], } } @@ -497,7 +496,7 @@ impl Batches { ) -> ( Vec, Vec, - Vec, + Vec, u64, ) { ( @@ -510,7 +509,7 @@ impl Batches { Vec::with_capacity(TARGET_NUM_TRANSACTIONS_PER_BATCH), ), core::mem::replace( - &mut self.max_age_slots[thread_id], + &mut self.max_ages[thread_id], Vec::with_capacity(TARGET_NUM_TRANSACTIONS_PER_BATCH), ), core::mem::replace(&mut self.total_cus[thread_id], 0), @@ -522,7 +521,7 @@ impl Batches { struct TransactionSchedulingInfo { thread_id: ThreadId, transaction: SanitizedTransaction, - max_age_slot: Slot, + max_age: MaxAge, cost: u64, } @@ -583,7 +582,7 @@ fn try_schedule_transaction( Ok(TransactionSchedulingInfo { thread_id, transaction: sanitized_transaction_ttl.transaction, - max_age_slot: sanitized_transaction_ttl.max_age_slot, + max_age: sanitized_transaction_ttl.max_age, cost, }) } @@ -599,8 +598,8 @@ mod tests { crossbeam_channel::{unbounded, Receiver}, itertools::Itertools, solana_sdk::{ - compute_budget::ComputeBudgetInstruction, hash::Hash, message::Message, packet::Packet, - pubkey::Pubkey, signature::Keypair, signer::Signer, system_instruction, + clock::Slot, compute_budget::ComputeBudgetInstruction, hash::Hash, message::Message, + packet::Packet, pubkey::Pubkey, signature::Keypair, signer::Signer, system_instruction, transaction::Transaction, }, std::{borrow::Borrow, sync::Arc}, @@ -686,7 +685,10 @@ mod tests { ); let transaction_ttl = SanitizedTransactionTTL { transaction, - max_age_slot: Slot::MAX, + max_age: MaxAge { + epoch_invalidation_slot: Slot::MAX, + alt_invalidation_slot: Slot::MAX, + }, }; const TEST_TRANSACTION_COST: u64 = 5000; container.insert_new_transaction( diff --git a/core/src/banking_stage/transaction_scheduler/scheduler_controller.rs b/core/src/banking_stage/transaction_scheduler/scheduler_controller.rs index 995b1a5782702b..ddec4ec90711c8 100644 --- a/core/src/banking_stage/transaction_scheduler/scheduler_controller.rs +++ b/core/src/banking_stage/transaction_scheduler/scheduler_controller.rs @@ -19,6 +19,7 @@ use { forwarder::Forwarder, immutable_deserialized_packet::ImmutableDeserializedPacket, packet_deserializer::PacketDeserializer, + scheduler_messages::MaxAge, ForwardOption, LikeClusterInfo, TOTAL_BUFFERED_PACKETS, }, arrayvec::ArrayVec, @@ -30,7 +31,8 @@ use { solana_runtime_transaction::instructions_processor::process_compute_budget_instructions, solana_sdk::{ self, - clock::{FORWARD_TRANSACTIONS_TO_LEADER_AT_SLOT_OFFSET, MAX_PROCESSING_AGE}, + address_lookup_table::state::estimate_last_valid_slot, + clock::{Slot, FORWARD_TRANSACTIONS_TO_LEADER_AT_SLOT_OFFSET, MAX_PROCESSING_AGE}, fee::FeeBudgetLimits, saturating_add_assign, transaction::SanitizedTransaction, @@ -500,16 +502,25 @@ impl SchedulerController { // Convert to Arcs let packets: Vec<_> = packets.into_iter().map(Arc::new).collect(); // Sanitize packets, generate IDs, and insert into the container. - let bank = self.bank_forks.read().unwrap().working_bank(); - let last_slot_in_epoch = bank.epoch_schedule().get_last_slot_in_epoch(bank.epoch()); - let transaction_account_lock_limit = bank.get_transaction_account_lock_limit(); - let vote_only = bank.vote_only_bank(); + let (root_bank, working_bank) = { + let bank_forks = self.bank_forks.read().unwrap(); + let root_bank = bank_forks.root_bank(); + let working_bank = bank_forks.working_bank(); + (root_bank, working_bank) + }; + let alt_resolved_slot = root_bank.slot(); + let last_slot_in_epoch = working_bank + .epoch_schedule() + .get_last_slot_in_epoch(working_bank.epoch()); + let transaction_account_lock_limit = working_bank.get_transaction_account_lock_limit(); + let vote_only = working_bank.vote_only_bank(); const CHUNK_SIZE: usize = 128; let lock_results: [_; CHUNK_SIZE] = core::array::from_fn(|_| Ok(())); let mut arc_packets = ArrayVec::<_, CHUNK_SIZE>::new(); let mut transactions = ArrayVec::<_, CHUNK_SIZE>::new(); + let mut max_ages = ArrayVec::<_, CHUNK_SIZE>::new(); let mut fee_budget_limits_vec = ArrayVec::<_, CHUNK_SIZE>::new(); let mut error_counts = TransactionErrorMetrics::default(); @@ -521,31 +532,43 @@ impl SchedulerController { packet .build_sanitized_transaction( vote_only, - bank.as_ref(), - bank.get_reserved_account_keys(), + root_bank.as_ref(), + working_bank.get_reserved_account_keys(), ) - .map(|tx| (packet.clone(), tx)) + .map(|(tx, deactivation_slot)| (packet.clone(), tx, deactivation_slot)) }) .inspect(|_| saturating_add_assign!(post_sanitization_count, 1)) - .filter(|(_packet, tx)| { + .filter(|(_packet, tx, _deactivation_slot)| { validate_account_locks( tx.message().account_keys(), transaction_account_lock_limit, ) .is_ok() }) - .filter_map(|(packet, tx)| { + .filter_map(|(packet, tx, deactivation_slot)| { process_compute_budget_instructions(SVMMessage::program_instructions_iter(&tx)) - .map(|compute_budget| (packet, tx, compute_budget.into())) + .map(|compute_budget| { + (packet, tx, deactivation_slot, compute_budget.into()) + }) .ok() }) - .for_each(|(packet, tx, fee_budget_limits)| { + .for_each(|(packet, tx, deactivation_slot, fee_budget_limits)| { arc_packets.push(packet); transactions.push(tx); + max_ages.push(calculate_max_age( + last_slot_in_epoch, + deactivation_slot, + alt_resolved_slot, + )); fee_budget_limits_vec.push(fee_budget_limits); }); - let check_results = bank.check_transactions( + let check_results: Vec< + Result< + solana_svm::account_loader::CheckedTransactionDetails, + solana_sdk::transaction::TransactionError, + >, + > = working_bank.check_transactions( &transactions, &lock_results[..transactions.len()], MAX_PROCESSING_AGE, @@ -556,21 +579,26 @@ impl SchedulerController { let mut post_transaction_check_count: usize = 0; let mut num_dropped_on_capacity: usize = 0; let mut num_buffered: usize = 0; - for (((packet, transaction), fee_budget_limits), _check_result) in arc_packets - .drain(..) - .zip(transactions.drain(..)) - .zip(fee_budget_limits_vec.drain(..)) - .zip(check_results) - .filter(|(_, check_result)| check_result.is_ok()) + for ((((packet, transaction), max_age), fee_budget_limits), _check_result) in + arc_packets + .drain(..) + .zip(transactions.drain(..)) + .zip(max_ages.drain(..)) + .zip(fee_budget_limits_vec.drain(..)) + .zip(check_results) + .filter(|(_, check_result)| check_result.is_ok()) { saturating_add_assign!(post_transaction_check_count, 1); let transaction_id = self.transaction_id_generator.next(); - let (priority, cost) = - Self::calculate_priority_and_cost(&transaction, &fee_budget_limits, &bank); + let (priority, cost) = Self::calculate_priority_and_cost( + &transaction, + &fee_budget_limits, + &working_bank, + ); let transaction_ttl = SanitizedTransactionTTL { transaction, - max_age_slot: last_slot_in_epoch, + max_age, }; if self.container.insert_new_transaction( @@ -655,6 +683,34 @@ impl SchedulerController { } } +/// Given the last slot in the epoch, the minimum deactivation slot, +/// and the current slot, return the `MaxAge` that should be used for +/// the transaction. This is used to determine the maximum slot that a +/// transaction will be considered valid for, without re-resolving addresses +/// or resanitizing. +/// +/// This function considers the deactivation period of Address Table +/// accounts. If the deactivation period runs past the end of the epoch, +/// then the transaction is considered valid until the end of the epoch. +/// Otherwise, the transaction is considered valid until the deactivation +/// period. +/// +/// Since the deactivation period technically uses blocks rather than +/// slots, the value used here is the lower-bound on the deactivation +/// period, i.e. the transaction's address lookups are valid until +/// AT LEAST this slot. +fn calculate_max_age( + last_slot_in_epoch: Slot, + deactivation_slot: Slot, + current_slot: Slot, +) -> MaxAge { + let alt_min_expire_slot = estimate_last_valid_slot(deactivation_slot.min(current_slot)); + MaxAge { + epoch_invalidation_slot: last_slot_in_epoch, + alt_invalidation_slot: alt_min_expire_slot, + } +} + #[cfg(test)] mod tests { use { @@ -827,7 +883,7 @@ mod tests { batch_id: TransactionBatchId::new(0), ids: vec![], transactions: vec![], - max_age_slots: vec![], + max_ages: vec![], }, retryable_indexes: vec![], }) @@ -1158,4 +1214,29 @@ mod tests { .collect_vec(); assert_eq!(message_hashes, vec![&tx1_hash]); } + + #[test] + fn test_calculate_max_age() { + let current_slot = 100; + let last_slot_in_epoch = 1000; + + // ALT deactivation slot is delayed + assert_eq!( + calculate_max_age(last_slot_in_epoch, current_slot - 1, current_slot), + MaxAge { + epoch_invalidation_slot: last_slot_in_epoch, + alt_invalidation_slot: current_slot - 1 + + solana_sdk::slot_hashes::get_entries() as u64, + } + ); + + // no deactivation slot + assert_eq!( + calculate_max_age(last_slot_in_epoch, u64::MAX, current_slot), + MaxAge { + epoch_invalidation_slot: last_slot_in_epoch, + alt_invalidation_slot: current_slot + solana_sdk::slot_hashes::get_entries() as u64, + } + ); + } } diff --git a/core/src/banking_stage/transaction_scheduler/transaction_state.rs b/core/src/banking_stage/transaction_scheduler/transaction_state.rs index 85af8217309e93..efb59be1b8b5b5 100644 --- a/core/src/banking_stage/transaction_scheduler/transaction_state.rs +++ b/core/src/banking_stage/transaction_scheduler/transaction_state.rs @@ -1,13 +1,15 @@ use { - crate::banking_stage::immutable_deserialized_packet::ImmutableDeserializedPacket, - solana_sdk::{clock::Slot, transaction::SanitizedTransaction}, + crate::banking_stage::{ + immutable_deserialized_packet::ImmutableDeserializedPacket, scheduler_messages::MaxAge, + }, + solana_sdk::transaction::SanitizedTransaction, std::sync::Arc, }; /// Simple wrapper type to tie a sanitized transaction to max age slot. pub(crate) struct SanitizedTransactionTTL { pub(crate) transaction: SanitizedTransaction, - pub(crate) max_age_slot: Slot, + pub(crate) max_age: MaxAge, } /// TransactionState is used to track the state of a transaction in the transaction scheduler @@ -207,8 +209,9 @@ mod tests { use { super::*, solana_sdk::{ - compute_budget::ComputeBudgetInstruction, hash::Hash, message::Message, packet::Packet, - signature::Keypair, signer::Signer, system_instruction, transaction::Transaction, + clock::Slot, compute_budget::ComputeBudgetInstruction, hash::Hash, message::Message, + packet::Packet, signature::Keypair, signer::Signer, system_instruction, + transaction::Transaction, }, }; @@ -230,7 +233,10 @@ mod tests { ); let transaction_ttl = SanitizedTransactionTTL { transaction: SanitizedTransaction::from_transaction_for_tests(tx), - max_age_slot: Slot::MAX, + max_age: MaxAge { + epoch_invalidation_slot: Slot::MAX, + alt_invalidation_slot: Slot::MAX, + }, }; const TEST_TRANSACTION_COST: u64 = 5000; TransactionState::new( @@ -271,11 +277,11 @@ mod tests { // Manually clone `SanitizedTransactionTTL` let SanitizedTransactionTTL { transaction, - max_age_slot, + max_age, } = transaction_state.transaction_ttl(); let transaction_ttl = SanitizedTransactionTTL { transaction: transaction.clone(), - max_age_slot: *max_age_slot, + max_age: *max_age, }; transaction_state.transition_to_unprocessed(transaction_ttl); // invalid transition } @@ -321,7 +327,13 @@ mod tests { transaction_state, TransactionState::Unprocessed { .. } )); - assert_eq!(transaction_ttl.max_age_slot, Slot::MAX); + assert_eq!( + transaction_ttl.max_age, + MaxAge { + epoch_invalidation_slot: Slot::MAX, + alt_invalidation_slot: Slot::MAX, + } + ); let _ = transaction_state.transition_to_pending(); assert!(matches!( @@ -339,7 +351,13 @@ mod tests { transaction_state, TransactionState::Unprocessed { .. } )); - assert_eq!(transaction_ttl.max_age_slot, Slot::MAX); + assert_eq!( + transaction_ttl.max_age, + MaxAge { + epoch_invalidation_slot: Slot::MAX, + alt_invalidation_slot: Slot::MAX, + } + ); // ensure transaction_ttl is not lost through state transitions let transaction_ttl = transaction_state.transition_to_pending(); @@ -354,6 +372,12 @@ mod tests { transaction_state, TransactionState::Unprocessed { .. } )); - assert_eq!(transaction_ttl.max_age_slot, Slot::MAX); + assert_eq!( + transaction_ttl.max_age, + MaxAge { + epoch_invalidation_slot: Slot::MAX, + alt_invalidation_slot: Slot::MAX, + } + ); } } diff --git a/core/src/banking_stage/transaction_scheduler/transaction_state_container.rs b/core/src/banking_stage/transaction_scheduler/transaction_state_container.rs index ed78b41983fa2a..7d40c66ec1b673 100644 --- a/core/src/banking_stage/transaction_scheduler/transaction_state_container.rs +++ b/core/src/banking_stage/transaction_scheduler/transaction_state_container.rs @@ -153,6 +153,7 @@ impl TransactionStateContainer { mod tests { use { super::*, + crate::banking_stage::scheduler_messages::MaxAge, solana_sdk::{ compute_budget::ComputeBudgetInstruction, hash::Hash, @@ -198,7 +199,10 @@ mod tests { ); let transaction_ttl = SanitizedTransactionTTL { transaction: tx, - max_age_slot: Slot::MAX, + max_age: MaxAge { + epoch_invalidation_slot: Slot::MAX, + alt_invalidation_slot: Slot::MAX, + }, }; const TEST_TRANSACTION_COST: u64 = 5000; (transaction_ttl, packet, priority, TEST_TRANSACTION_COST) diff --git a/core/src/banking_stage/unprocessed_packet_batches.rs b/core/src/banking_stage/unprocessed_packet_batches.rs index f92eeb09c57b54..3c4e0f66664dd2 100644 --- a/core/src/banking_stage/unprocessed_packet_batches.rs +++ b/core/src/banking_stage/unprocessed_packet_batches.rs @@ -307,13 +307,14 @@ mod tests { use { super::*, solana_perf::packet::PacketFlags, + solana_runtime::bank::Bank, solana_sdk::{ compute_budget::ComputeBudgetInstruction, message::Message, reserved_account_keys::ReservedAccountKeys, signature::{Keypair, Signer}, system_instruction, system_transaction, - transaction::{SimpleAddressLoader, Transaction}, + transaction::Transaction, }, solana_vote_program::{vote_state::TowerSync, vote_transaction}, }; @@ -475,6 +476,7 @@ mod tests { &keypair, None, ); + let bank = Bank::default_for_tests(); // packets with no votes { @@ -486,7 +488,7 @@ mod tests { let txs = packet_vector.iter().filter_map(|tx| { tx.immutable_section().build_sanitized_transaction( votes_only, - SimpleAddressLoader::Disabled, + &bank, &ReservedAccountKeys::empty_key_set(), ) }); @@ -496,7 +498,7 @@ mod tests { let txs = packet_vector.iter().filter_map(|tx| { tx.immutable_section().build_sanitized_transaction( votes_only, - SimpleAddressLoader::Disabled, + &bank, &ReservedAccountKeys::empty_key_set(), ) }); @@ -515,7 +517,7 @@ mod tests { let txs = packet_vector.iter().filter_map(|tx| { tx.immutable_section().build_sanitized_transaction( votes_only, - SimpleAddressLoader::Disabled, + &bank, &ReservedAccountKeys::empty_key_set(), ) }); @@ -525,7 +527,7 @@ mod tests { let txs = packet_vector.iter().filter_map(|tx| { tx.immutable_section().build_sanitized_transaction( votes_only, - SimpleAddressLoader::Disabled, + &bank, &ReservedAccountKeys::empty_key_set(), ) }); @@ -544,7 +546,7 @@ mod tests { let txs = packet_vector.iter().filter_map(|tx| { tx.immutable_section().build_sanitized_transaction( votes_only, - SimpleAddressLoader::Disabled, + &bank, &ReservedAccountKeys::empty_key_set(), ) }); @@ -554,7 +556,7 @@ mod tests { let txs = packet_vector.iter().filter_map(|tx| { tx.immutable_section().build_sanitized_transaction( votes_only, - SimpleAddressLoader::Disabled, + &bank, &ReservedAccountKeys::empty_key_set(), ) }); diff --git a/core/src/banking_stage/unprocessed_transaction_storage.rs b/core/src/banking_stage/unprocessed_transaction_storage.rs index f612f5eaf08b11..56e814acea9219 100644 --- a/core/src/banking_stage/unprocessed_transaction_storage.rs +++ b/core/src/banking_stage/unprocessed_transaction_storage.rs @@ -154,13 +154,15 @@ fn consume_scan_should_process_packet( return ProcessingDecision::Now; } - // Try to sanitize the packet + // Try to sanitize the packet. Ignore deactivation slot since we are + // immediately attempting to process the transaction. let (maybe_sanitized_transaction, sanitization_time_us) = measure_us!(packet .build_sanitized_transaction( bank.vote_only_bank(), bank, bank.get_reserved_account_keys(), - )); + ) + .map(|(tx, _deactivation_slot)| tx)); payload .slot_metrics_tracker @@ -799,7 +801,7 @@ impl ThreadLocalUnprocessedPackets { bank, bank.get_reserved_account_keys(), ) - .map(|transaction| (transaction, packet_index)) + .map(|(transaction, _deactivation_slot)| (transaction, packet_index)) }) .unzip(); diff --git a/runtime/src/bank/address_lookup_table.rs b/runtime/src/bank/address_lookup_table.rs index 4fa4e2bc0f570a..cb195202c9ddac 100644 --- a/runtime/src/bank/address_lookup_table.rs +++ b/runtime/src/bank/address_lookup_table.rs @@ -2,6 +2,7 @@ use { super::Bank, solana_sdk::{ address_lookup_table::error::AddressLookupError, + clock::Slot, message::{ v0::{LoadedAddresses, MessageAddressTableLookup}, AddressLoaderError, @@ -32,22 +33,25 @@ impl AddressLoader for &Bank { .iter() .map(SVMMessageAddressTableLookup::from), ) + .map(|(loaded_addresses, _deactivation_slot)| loaded_addresses) } } impl Bank { - /// Load addresses from an iterator of `SVMMessageAddressTableLookup`. + /// Load addresses from an iterator of `SVMMessageAddressTableLookup`, + /// additionally returning the minimum deactivation slot across all referenced ALTs pub fn load_addresses_from_ref<'a>( &self, address_table_lookups: impl Iterator>, - ) -> Result { + ) -> Result<(LoadedAddresses, Slot), AddressLoaderError> { let slot_hashes = self .transaction_processor .sysvar_cache() .get_slot_hashes() .map_err(|_| AddressLoaderError::SlotHashesSysvarNotFound)?; - address_table_lookups + let mut deactivation_slot = u64::MAX; + let loaded_addresses = address_table_lookups .map(|address_table_lookup| { self.rc .accounts @@ -56,8 +60,14 @@ impl Bank { address_table_lookup, &slot_hashes, ) + .map(|(loaded_addresses, table_deactivation_slot)| { + deactivation_slot = deactivation_slot.min(table_deactivation_slot); + loaded_addresses + }) .map_err(into_address_loader_error) }) - .collect::>() + .collect::>()?; + + Ok((loaded_addresses, deactivation_slot)) } } diff --git a/sdk/program/src/address_lookup_table/state.rs b/sdk/program/src/address_lookup_table/state.rs index 13a66637faa919..3136dd063f85da 100644 --- a/sdk/program/src/address_lookup_table/state.rs +++ b/sdk/program/src/address_lookup_table/state.rs @@ -1,6 +1,7 @@ #[cfg(feature = "frozen-abi")] use solana_frozen_abi_macro::{AbiEnumVisitor, AbiExample}; use { + crate::slot_hashes::get_entries, serde_derive::{Deserialize, Serialize}, solana_clock::Slot, solana_program::{ @@ -12,6 +13,19 @@ use { std::borrow::Cow, }; +/// The lookup table may be in a deactivating state until +/// the `deactivation_slot`` is no longer "recent". +/// This function returns a conservative estimate for the +/// last block that the table may be used for lookups. +/// This estimate may be incorrect due to skipped blocks, +/// however, if the current slot is lower than the returned +/// value, the table is guaranteed to still be in the +/// deactivating state. +#[inline] +pub fn estimate_last_valid_slot(deactivation_slot: Slot) -> Slot { + deactivation_slot.saturating_add(get_entries() as Slot) +} + /// The maximum number of addresses that a lookup table can hold pub const LOOKUP_TABLE_MAX_ADDRESSES: usize = 256; From a3b2c786e35f6bbc9087f8f458d55ef7cc961e1b Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 19:38:00 +0400 Subject: [PATCH 13/23] extract native-token crate (#3072) * extract solana-native-token crate * fix import after rebase * add back llink --- Cargo.lock | 6 ++++++ Cargo.toml | 2 ++ programs/sbf/Cargo.lock | 6 ++++++ sdk/Cargo.toml | 1 + sdk/native-token/Cargo.toml | 13 +++++++++++++ .../src/native_token.rs => native-token/src/lib.rs} | 0 sdk/program/Cargo.toml | 1 + sdk/program/src/lib.rs | 4 ++-- sdk/src/fee.rs | 2 +- sdk/src/genesis_config.rs | 2 +- 10 files changed, 33 insertions(+), 4 deletions(-) create mode 100644 sdk/native-token/Cargo.toml rename sdk/{program/src/native_token.rs => native-token/src/lib.rs} (100%) diff --git a/Cargo.lock b/Cargo.lock index 7492ea20dc02f3..057209c5eb032f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -7118,6 +7118,10 @@ dependencies = [ "solana-define-syscall", ] +[[package]] +name = "solana-native-token" +version = "2.1.0" + [[package]] name = "solana-net-shaper" version = "2.1.0" @@ -7318,6 +7322,7 @@ dependencies = [ "solana-instruction", "solana-logger", "solana-msg", + "solana-native-token", "solana-program-error", "solana-program-memory", "solana-program-option", @@ -7897,6 +7902,7 @@ dependencies = [ "solana-frozen-abi", "solana-frozen-abi-macro", "solana-logger", + "solana-native-token", "solana-program", "solana-program-memory", "solana-pubkey", diff --git a/Cargo.toml b/Cargo.toml index cdecc0af7dcfe4..8339070f9bbf39 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -116,6 +116,7 @@ members = [ "sdk/instruction", "sdk/macro", "sdk/msg", + "sdk/native-token", "sdk/package-metadata", "sdk/package-metadata-macro", "sdk/program", @@ -432,6 +433,7 @@ solana-measure = { path = "measure", version = "=2.1.0" } solana-merkle-tree = { path = "merkle-tree", version = "=2.1.0" } solana-metrics = { path = "metrics", version = "=2.1.0" } solana-msg = { path = "sdk/msg", version = "=2.1.0" } +solana-native-token = { path = "sdk/native-token", version = "=2.1.0" } solana-net-utils = { path = "net-utils", version = "=2.1.0" } solana-nohash-hasher = "0.2.1" solana-notifier = { path = "notifier", version = "=2.1.0" } diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index e16c7d4a3a926c..78eca1fe59da24 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -5584,6 +5584,10 @@ dependencies = [ "solana-define-syscall", ] +[[package]] +name = "solana-native-token" +version = "2.1.0" + [[package]] name = "solana-net-utils" version = "2.1.0" @@ -5701,6 +5705,7 @@ dependencies = [ "solana-hash", "solana-instruction", "solana-msg", + "solana-native-token", "solana-program-error", "solana-program-memory", "solana-program-option", @@ -6658,6 +6663,7 @@ dependencies = [ "solana-decode-error", "solana-derivation-path", "solana-feature-set", + "solana-native-token", "solana-program", "solana-program-memory", "solana-pubkey", diff --git a/sdk/Cargo.toml b/sdk/Cargo.toml index 938e21a2aed8c0..2ab85402d1c3b1 100644 --- a/sdk/Cargo.toml +++ b/sdk/Cargo.toml @@ -96,6 +96,7 @@ solana-frozen-abi = { workspace = true, optional = true, features = [ solana-frozen-abi-macro = { workspace = true, optional = true, features = [ "frozen-abi", ] } +solana-native-token = { workspace = true } solana-program = { workspace = true } solana-program-memory = { workspace = true } solana-pubkey = { workspace = true, default-features = false, features = ["std"] } diff --git a/sdk/native-token/Cargo.toml b/sdk/native-token/Cargo.toml new file mode 100644 index 00000000000000..cac63f3e88597f --- /dev/null +++ b/sdk/native-token/Cargo.toml @@ -0,0 +1,13 @@ +[package] +name = "solana-native-token" +description = "Definitions for the native SOL token and its fractional lamports." +documentation = "https://docs.rs/solana-native-token" +version = { workspace = true } +authors = { workspace = true } +repository = { workspace = true } +homepage = { workspace = true } +license = { workspace = true } +edition = { workspace = true } + +[package.metadata.docs.rs] +targets = ["x86_64-unknown-linux-gnu"] diff --git a/sdk/program/src/native_token.rs b/sdk/native-token/src/lib.rs similarity index 100% rename from sdk/program/src/native_token.rs rename to sdk/native-token/src/lib.rs diff --git a/sdk/program/Cargo.toml b/sdk/program/Cargo.toml index 391e5e148f11ec..c3d373fb3f7835 100644 --- a/sdk/program/Cargo.toml +++ b/sdk/program/Cargo.toml @@ -51,6 +51,7 @@ solana-instruction = { workspace = true, default-features = false, features = [ "std", ] } solana-msg = { workspace = true } +solana-native-token = { workspace = true } solana-program-error = { workspace = true, features = ["serde"] } solana-program-memory = { workspace = true } solana-program-option = { workspace = true } diff --git a/sdk/program/src/lib.rs b/sdk/program/src/lib.rs index 11a2ccaab2f9d5..ae339c371fdde3 100644 --- a/sdk/program/src/lib.rs +++ b/sdk/program/src/lib.rs @@ -502,7 +502,6 @@ pub mod loader_v4; pub mod loader_v4_instruction; pub mod log; pub mod message; -pub mod native_token; pub mod nonce; pub mod program; pub mod program_error; @@ -541,7 +540,8 @@ pub use { solana_account_info::{self as account_info, debug_account_data}, solana_clock as clock, solana_msg::msg, - solana_program_option as program_option, solana_pubkey as pubkey, solana_rent as rent, + solana_native_token as native_token, solana_program_option as program_option, + solana_pubkey as pubkey, solana_rent as rent, }; /// The [config native program][np]. diff --git a/sdk/src/fee.rs b/sdk/src/fee.rs index 22d04812fa0d76..08a825cd1ba2a2 100644 --- a/sdk/src/fee.rs +++ b/sdk/src/fee.rs @@ -2,7 +2,7 @@ #[cfg(not(target_os = "solana"))] use solana_program::message::SanitizedMessage; -use {crate::native_token::sol_to_lamports, std::num::NonZeroU32}; +use {solana_native_token::sol_to_lamports, std::num::NonZeroU32}; /// A fee and its associated compute unit limit #[derive(Debug, Default, Clone, Eq, PartialEq)] diff --git a/sdk/src/genesis_config.rs b/sdk/src/genesis_config.rs index 6b48f8fd1e7645..ba82ee531e5ccc 100644 --- a/sdk/src/genesis_config.rs +++ b/sdk/src/genesis_config.rs @@ -9,7 +9,6 @@ use { fee_calculator::FeeRateGovernor, hash::{hash, Hash}, inflation::Inflation, - native_token::lamports_to_sol, poh_config::PohConfig, pubkey::Pubkey, rent::Rent, @@ -22,6 +21,7 @@ use { chrono::{TimeZone, Utc}, memmap2::Mmap, solana_account::{Account, AccountSharedData}, + solana_native_token::lamports_to_sol, std::{ collections::BTreeMap, fmt, From 75450a6542164ee4f64cadc7a97a24d25ff37e2a Mon Sep 17 00:00:00 2001 From: Joe C Date: Tue, 15 Oct 2024 23:15:03 +0700 Subject: [PATCH 14/23] SVM: API: rename `new` to `new_uninitialized` (#3170) --- runtime/src/bank.rs | 4 ++-- .../json-rpc/server/src/rpc_process.rs | 2 +- svm/examples/paytube/src/processor.rs | 2 +- svm/src/transaction_processor.rs | 21 ++++++++++++++++++- svm/tests/concurrent_tests.rs | 11 +++++----- svm/tests/conformance.rs | 3 ++- svm/tests/integration_test.rs | 4 ++-- 7 files changed, 33 insertions(+), 14 deletions(-) diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 6770010b5d1b84..0975a6dbccde23 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -1048,7 +1048,7 @@ impl Bank { }; bank.transaction_processor = - TransactionBatchProcessor::new(bank.slot, bank.epoch, HashSet::default()); + TransactionBatchProcessor::new_uninitialized(bank.slot, bank.epoch, HashSet::default()); let accounts_data_size_initial = bank.get_total_accounts_stats().unwrap().data_len as u64; bank.accounts_data_size_initial = accounts_data_size_initial; @@ -1702,7 +1702,7 @@ impl Bank { }; bank.transaction_processor = - TransactionBatchProcessor::new(bank.slot, bank.epoch, HashSet::default()); + TransactionBatchProcessor::new_uninitialized(bank.slot, bank.epoch, HashSet::default()); let thread_pool = ThreadPoolBuilder::new() .thread_name(|i| format!("solBnkNewFlds{i:02}")) diff --git a/svm/examples/json-rpc/server/src/rpc_process.rs b/svm/examples/json-rpc/server/src/rpc_process.rs index ed239323b462b4..f0721783c9d38d 100644 --- a/svm/examples/json-rpc/server/src/rpc_process.rs +++ b/svm/examples/json-rpc/server/src/rpc_process.rs @@ -208,7 +208,7 @@ impl JsonRpcRequestProcessor { (pubkey, acc_data) }) .collect(); - let batch_processor = TransactionBatchProcessor::::new( + let batch_processor = TransactionBatchProcessor::::new_uninitialized( EXECUTION_SLOT, EXECUTION_EPOCH, HashSet::new(), diff --git a/svm/examples/paytube/src/processor.rs b/svm/examples/paytube/src/processor.rs index 03a8336209ca29..663c1b5044665e 100644 --- a/svm/examples/paytube/src/processor.rs +++ b/svm/examples/paytube/src/processor.rs @@ -50,7 +50,7 @@ pub(crate) fn create_transaction_batch_processor::new( + let processor = TransactionBatchProcessor::::new_uninitialized( /* slot */ 1, /* epoch */ 1, /* builtin_program_ids */ HashSet::new(), diff --git a/svm/src/transaction_processor.rs b/svm/src/transaction_processor.rs index 92706997471c52..91f79952254095 100644 --- a/svm/src/transaction_processor.rs +++ b/svm/src/transaction_processor.rs @@ -189,7 +189,20 @@ impl Default for TransactionBatchProcessor { } impl TransactionBatchProcessor { - pub fn new(slot: Slot, epoch: Epoch, builtin_program_ids: HashSet) -> Self { + /// Create a new, uninitialized `TransactionBatchProcessor`. + /// + /// In this context, uninitialized means that the `TransactionBatchProcessor` + /// has been initialized with an empty program cache. The cache contains no + /// programs (including builtins) and has not been configured with a valid + /// fork graph. + /// + /// When using this method, it's advisable to call `set_fork_graph_in_program_cache` + /// as well as `add_builtin` to configure the cache before using the processor. + pub fn new_uninitialized( + slot: Slot, + epoch: Epoch, + builtin_program_ids: HashSet, + ) -> Self { Self { slot, epoch, @@ -199,6 +212,12 @@ impl TransactionBatchProcessor { } } + /// Create a new `TransactionBatchProcessor` from the current instance, but + /// with the provided slot and epoch. + /// + /// * Inherits the program cache and builtin program ids from the current + /// instance. + /// * Resets the sysvar cache. pub fn new_from(&self, slot: Slot, epoch: Epoch) -> Self { Self { slot, diff --git a/svm/tests/concurrent_tests.rs b/svm/tests/concurrent_tests.rs index 2e84fbba243663..4c547675784577 100644 --- a/svm/tests/concurrent_tests.rs +++ b/svm/tests/concurrent_tests.rs @@ -40,7 +40,8 @@ mod transaction_builder; fn program_cache_execution(threads: usize) { let mut mock_bank = MockBankCallback::default(); - let batch_processor = TransactionBatchProcessor::::new(5, 5, HashSet::new()); + let batch_processor = + TransactionBatchProcessor::::new_uninitialized(5, 5, HashSet::new()); let fork_graph = Arc::new(RwLock::new(MockForkGraph {})); batch_processor.program_cache.write().unwrap().fork_graph = Some(Arc::downgrade(&fork_graph)); @@ -126,11 +127,9 @@ fn test_program_cache_with_exhaustive_scheduler() { // correctly. fn svm_concurrent() { let mock_bank = Arc::new(MockBankCallback::default()); - let batch_processor = Arc::new(TransactionBatchProcessor::::new( - 5, - 2, - HashSet::new(), - )); + let batch_processor = Arc::new( + TransactionBatchProcessor::::new_uninitialized(5, 2, HashSet::new()), + ); let fork_graph = Arc::new(RwLock::new(MockForkGraph {})); create_executable_environment( diff --git a/svm/tests/conformance.rs b/svm/tests/conformance.rs index dc521bc36eee15..7bc9ee5184b2c6 100644 --- a/svm/tests/conformance.rs +++ b/svm/tests/conformance.rs @@ -244,7 +244,8 @@ fn run_fixture(fixture: InstrFixture, filename: OsString, execute_as_instr: bool create_program_runtime_environment_v1(&feature_set, &compute_budget, false, false).unwrap(); mock_bank.override_feature_set(feature_set); - let batch_processor = TransactionBatchProcessor::::new(42, 2, HashSet::new()); + let batch_processor = + TransactionBatchProcessor::::new_uninitialized(42, 2, HashSet::new()); let fork_graph = Arc::new(RwLock::new(MockForkGraph {})); { diff --git a/svm/tests/integration_test.rs b/svm/tests/integration_test.rs index 6b1325a643d2f0..9f781607aa3112 100644 --- a/svm/tests/integration_test.rs +++ b/svm/tests/integration_test.rs @@ -872,7 +872,7 @@ fn execute_test_entry(test_entry: SvmTestEntry) { .insert(*pubkey, account.clone()); } - let batch_processor = TransactionBatchProcessor::::new( + let batch_processor = TransactionBatchProcessor::::new_uninitialized( EXECUTION_SLOT, EXECUTION_EPOCH, HashSet::new(), @@ -1059,7 +1059,7 @@ fn svm_inspect_account() { // Load and execute the transaction - let batch_processor = TransactionBatchProcessor::::new( + let batch_processor = TransactionBatchProcessor::::new_uninitialized( EXECUTION_SLOT, EXECUTION_EPOCH, HashSet::new(), From c32d0df3f7c98d9190780d5019ab0cc45bca1dca Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 21:14:16 +0400 Subject: [PATCH 15/23] avoid solana-program in inline-spl (#3178) --- Cargo.lock | 2 +- inline-spl/Cargo.toml | 4 +++- inline-spl/src/associated_token_account.rs | 4 ++-- inline-spl/src/token.rs | 8 ++++---- inline-spl/src/token_2022.rs | 2 +- programs/sbf/Cargo.lock | 2 +- 6 files changed, 12 insertions(+), 10 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 057209c5eb032f..73bd1a01af5205 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -6846,7 +6846,7 @@ name = "solana-inline-spl" version = "2.1.0" dependencies = [ "bytemuck", - "solana-program", + "solana-pubkey", ] [[package]] diff --git a/inline-spl/Cargo.toml b/inline-spl/Cargo.toml index 82aa5907ce0aa2..132e10f07ab533 100644 --- a/inline-spl/Cargo.toml +++ b/inline-spl/Cargo.toml @@ -11,7 +11,9 @@ edition = { workspace = true } [dependencies] bytemuck = { workspace = true } -solana-program = { workspace = true, default-features = false } +solana-pubkey = { workspace = true, default-features = false, features = [ + "bytemuck", +] } [lib] crate-type = ["lib"] diff --git a/inline-spl/src/associated_token_account.rs b/inline-spl/src/associated_token_account.rs index 2048c5b743d222..289dc0f8555e47 100644 --- a/inline-spl/src/associated_token_account.rs +++ b/inline-spl/src/associated_token_account.rs @@ -1,6 +1,6 @@ // Partial SPL Associated Token Account declarations inlined to avoid an external dependency on the spl-associated-token-account crate -solana_program::declare_id!("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"); +solana_pubkey::declare_id!("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"); pub mod program_v1_1_0 { - solana_program::declare_id!("NatA1Zyo48dJ7yuwR7cGURwhskKA8ywUyxb9GvG7mTC"); + solana_pubkey::declare_id!("NatA1Zyo48dJ7yuwR7cGURwhskKA8ywUyxb9GvG7mTC"); } diff --git a/inline-spl/src/token.rs b/inline-spl/src/token.rs index 1a495d8ca3a241..af456c3b6242a7 100644 --- a/inline-spl/src/token.rs +++ b/inline-spl/src/token.rs @@ -1,10 +1,10 @@ /// Partial SPL Token declarations inlined to avoid an external dependency on the spl-token crate -use solana_program::pubkey::{Pubkey, PUBKEY_BYTES}; +use solana_pubkey::{Pubkey, PUBKEY_BYTES}; -solana_program::declare_id!("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"); +solana_pubkey::declare_id!("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"); pub mod program_v3_4_0 { - solana_program::declare_id!("NToK4t5AQzxPNpUA84DkxgfXaVDbDQQjpHKCqsbY46B"); + solana_pubkey::declare_id!("NToK4t5AQzxPNpUA84DkxgfXaVDbDQQjpHKCqsbY46B"); } /* @@ -72,7 +72,7 @@ impl GenericTokenAccount for Account { } pub mod native_mint { - solana_program::declare_id!("So11111111111111111111111111111111111111112"); + solana_pubkey::declare_id!("So11111111111111111111111111111111111111112"); /* Mint { diff --git a/inline-spl/src/token_2022.rs b/inline-spl/src/token_2022.rs index 4b0e0d1b3c05db..fafa2b4cfce68a 100644 --- a/inline-spl/src/token_2022.rs +++ b/inline-spl/src/token_2022.rs @@ -1,7 +1,7 @@ /// Partial SPL Token declarations inlined to avoid an external dependency on the spl-token-2022 crate use crate::token::{self, GenericTokenAccount}; -solana_program::declare_id!("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb"); +solana_pubkey::declare_id!("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb"); // `spl_token_program_2022::extension::AccountType::Account` ordinal value pub const ACCOUNTTYPE_ACCOUNT: u8 = 2; diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index 78eca1fe59da24..8d7a199fc4fa6b 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -5420,7 +5420,7 @@ name = "solana-inline-spl" version = "2.1.0" dependencies = [ "bytemuck", - "solana-program", + "solana-pubkey", ] [[package]] From 72963e1469031fbc72d3d87a1f5e568e98f734ce Mon Sep 17 00:00:00 2001 From: Brooks Date: Tue, 15 Oct 2024 13:49:27 -0400 Subject: [PATCH 16/23] Advises kernel to use random access for disk bucket mmaps (#2140) --- bucket_map/src/bucket_storage.rs | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/bucket_map/src/bucket_storage.rs b/bucket_map/src/bucket_storage.rs index a55923c142d850..95f05cfdfaa679 100644 --- a/bucket_map/src/bucket_storage.rs +++ b/bucket_map/src/bucket_storage.rs @@ -433,6 +433,10 @@ impl BucketStorage { std::env::current_dir(), ); }); + // Access to the disk bucket files are random (excluding the linear search on collisions), + // so advise the kernel to treat the mmaps as such. + #[cfg(unix)] + mmap.advise(memmap2::Advice::Random).unwrap(); measure_mmap.stop(); stats .new_file_us From 1e800b1e0b5b699813d835d35595a03fa70326a4 Mon Sep 17 00:00:00 2001 From: dmakarov Date: Tue, 15 Oct 2024 14:35:04 -0400 Subject: [PATCH 17/23] Aggressively shrink ancient storages when shrink isn't too busy. (#2946) * Tweak ancient packing algorithm * Minor change * Feedback * Remove redundancy * Correction * Revert correction * Loop * Add test * Fix clippy * Comments * Comment * Comments * Pop ancients * Revert * Checks * Move reverse * Typo * Popped * Sort * Format * Revert sort, back to reverse * Fix comment --- accounts-db/src/accounts_db.rs | 125 ++++++++++++++++++++++++- accounts-db/src/ancient_append_vecs.rs | 19 +++- 2 files changed, 141 insertions(+), 3 deletions(-) diff --git a/accounts-db/src/accounts_db.rs b/accounts-db/src/accounts_db.rs index 29582ab7e1ff7f..e2353b99fce81d 100644 --- a/accounts-db/src/accounts_db.rs +++ b/accounts-db/src/accounts_db.rs @@ -141,6 +141,11 @@ const MAX_ITEMS_PER_CHUNK: Slot = 2_500; // This allows us to split up accounts index accesses across multiple threads. const SHRINK_COLLECT_CHUNK_SIZE: usize = 50; +/// The number of shrink candidate slots that is small enough so that +/// additional storages from ancient slots can be added to the +/// candidates for shrinking. +const SHRINK_INSERT_ANCIENT_THRESHOLD: usize = 10; + #[derive(Debug, Default, Clone, Copy, PartialEq, Eq)] pub enum CreateAncientStorage { /// ancient storages are created by appending @@ -1501,6 +1506,14 @@ pub struct AccountsDb { /// Flag to indicate if the experimental accounts lattice hash is enabled. /// (For R&D only; a feature-gate also exists to turn this on and make it a part of consensus.) pub is_experimental_accumulator_hash_enabled: AtomicBool, + + /// These are the ancient storages that could be valuable to + /// shrink, sorted by amount of dead bytes. The elements + /// are popped from the end of the vector, hence the sorting is + /// expected to be from the smallest dead bytes to the largest. + /// Members are Slot and capacity. If capacity is smaller, then + /// that means the storage was already shrunk. + pub(crate) best_ancient_slots_to_shrink: RwLock>, } /// results from 'split_storages_ancient' @@ -1860,6 +1873,7 @@ impl AccountsDb { is_experimental_accumulator_hash_enabled: default_accounts_db_config .enable_experimental_accumulator_hash .into(), + best_ancient_slots_to_shrink: RwLock::default(), } } @@ -4401,8 +4415,12 @@ impl AccountsDb { let shrink_candidates_slots = std::mem::take(&mut *self.shrink_candidate_slots.lock().unwrap()); + self.shrink_stats + .initial_candidates_count + .store(shrink_candidates_slots.len() as u64, Ordering::Relaxed); + let candidates_count = shrink_candidates_slots.len(); - let ((shrink_slots, shrink_slots_next_batch), select_time_us) = measure_us!({ + let ((mut shrink_slots, shrink_slots_next_batch), select_time_us) = measure_us!({ if let AccountShrinkThreshold::TotalSpace { shrink_ratio } = self.shrink_ratio { let (shrink_slots, shrink_slots_next_batch) = self.select_candidates_by_total_usage(&shrink_candidates_slots, shrink_ratio); @@ -4423,6 +4441,30 @@ impl AccountsDb { } }); + // If there are too few slots to shrink, add an ancient slot + // for shrinking. The best ancient slots to shrink are + // assumed to be in reverse order. + if shrink_slots.len() < SHRINK_INSERT_ANCIENT_THRESHOLD { + let mut ancients = self.best_ancient_slots_to_shrink.write().unwrap(); + while let Some((slot, capacity)) = ancients.pop() { + if let Some(store) = self.storage.get_slot_storage_entry(slot) { + if !shrink_slots.contains(&slot) + && capacity == store.capacity() + && Self::is_candidate_for_shrink(self, &store) + { + let ancient_bytes_added_to_shrink = store.alive_bytes() as u64; + shrink_slots.insert(slot, store); + self.shrink_stats + .ancient_bytes_added_to_shrink + .fetch_add(ancient_bytes_added_to_shrink, Ordering::Relaxed); + self.shrink_stats + .ancient_slots_added_to_shrink + .fetch_add(1, Ordering::Relaxed); + break; + } + } + } + } if shrink_slots.is_empty() && shrink_slots_next_batch .as_ref() @@ -9252,7 +9294,9 @@ pub mod tests { accounts_hash::MERKLE_FANOUT, accounts_index::{tests::*, AccountSecondaryIndexesIncludeExclude}, ancient_append_vecs, - append_vec::{test_utils::TempFile, AppendVec, AppendVecStoredAccountMeta}, + append_vec::{ + aligned_stored_size, test_utils::TempFile, AppendVec, AppendVecStoredAccountMeta, + }, storable_accounts::AccountForStorage, }, assert_matches::assert_matches, @@ -12154,6 +12198,83 @@ pub mod tests { ); } + /// This test creates an ancient storage with three alive accounts + /// of various sizes. It then simulates killing one of the + /// accounts in a more recent (non-ancient) slot by overwriting + /// the account that has the smallest data size. The dead account + /// is expected to be deleted from its ancient storage in the + /// process of shrinking candidate slots. The capacity of the + /// storage after shrinking is expected to be the sum of alive + /// bytes of the two remaining alive ancient accounts. + #[test] + fn test_shrink_candidate_slots_with_dead_ancient_account() { + solana_logger::setup(); + let epoch_schedule = EpochSchedule::default(); + let num_ancient_slots = 3; + // Prepare 3 append vecs to combine [medium, big, small] + let account_data_sizes = vec![1000, 2000, 150]; + let (db, starting_ancient_slot) = + create_db_with_storages_and_index_with_customized_account_size_per_slot( + true, + num_ancient_slots, + account_data_sizes, + ); + db.add_root(starting_ancient_slot); + let slots_to_combine: Vec = + (starting_ancient_slot..starting_ancient_slot + num_ancient_slots as Slot).collect(); + db.combine_ancient_slots(slots_to_combine, CAN_RANDOMLY_SHRINK_FALSE); + let storage = db.get_storage_for_slot(starting_ancient_slot).unwrap(); + let ancient_accounts = db.get_unique_accounts_from_storage(&storage); + // Check that three accounts are indeed present in the combined storage. + assert_eq!(ancient_accounts.stored_accounts.len(), 3); + // Find an ancient account with smallest data length. + // This will be a dead account, overwritten in the current slot. + let modified_account_pubkey = ancient_accounts + .stored_accounts + .iter() + .min_by(|a, b| a.data_len.cmp(&b.data_len)) + .unwrap() + .pubkey; + let modified_account_owner = *AccountSharedData::default().owner(); + let modified_account = AccountSharedData::new(223, 0, &modified_account_owner); + let ancient_append_vec_offset = db.ancient_append_vec_offset.unwrap().abs(); + let current_slot = epoch_schedule.slots_per_epoch + ancient_append_vec_offset as u64 + 1; + // Simulate killing of the ancient account by overwriting it in the current slot. + db.store_for_tests( + current_slot, + &[(&modified_account_pubkey, &modified_account)], + ); + db.calculate_accounts_delta_hash(current_slot); + db.add_root_and_flush_write_cache(current_slot); + // This should remove the dead ancient account from the index. + db.clean_accounts_for_tests(); + db.shrink_ancient_slots(&epoch_schedule); + let storage = db.get_storage_for_slot(starting_ancient_slot).unwrap(); + let created_accounts = db.get_unique_accounts_from_storage(&storage); + // The dead account should still be in the ancient storage, + // because the storage wouldn't be shrunk with normal alive to + // capacity ratio. + assert_eq!(created_accounts.stored_accounts.len(), 3); + db.shrink_candidate_slots(&epoch_schedule); + let storage = db.get_storage_for_slot(starting_ancient_slot).unwrap(); + let created_accounts = db.get_unique_accounts_from_storage(&storage); + // At this point the dead ancient account should be removed + // and storage capacity shrunk to the sum of alive bytes of + // accounts it holds. This is the data lengths of the + // accounts plus the length of their metadata. + assert_eq!( + created_accounts.capacity as usize, + aligned_stored_size(1000) + aligned_stored_size(2000) + ); + // The above check works only when the AppendVec storage is + // used. More generally the pubkey of the smallest account + // shouldn't be present in the shrunk storage, which is + // validated by the following scan of the storage accounts. + storage.accounts.scan_pubkeys(|pubkey| { + assert_ne!(pubkey, &modified_account_pubkey); + }); + } + #[test] fn test_select_candidates_by_total_usage_no_candidates() { // no input candidates -- none should be selected diff --git a/accounts-db/src/ancient_append_vecs.rs b/accounts-db/src/ancient_append_vecs.rs index 9c788c8e668917..5d645c9560cc39 100644 --- a/accounts-db/src/ancient_append_vecs.rs +++ b/accounts-db/src/ancient_append_vecs.rs @@ -79,6 +79,9 @@ struct AncientSlotInfos { total_alive_bytes_shrink: Saturating, /// total alive bytes across all slots total_alive_bytes: Saturating, + /// slots that have dead accounts and thus the corresponding slot + /// storages can be shrunk + best_slots_to_shrink: Vec<(Slot, u64)>, } impl AncientSlotInfos { @@ -177,8 +180,13 @@ impl AncientSlotInfos { * tuning.percent_of_alive_shrunk_data / 100, ); + // At this point self.shrink_indexes have been sorted by the + // largest amount of dead bytes first in the corresponding + // storages. + self.best_slots_to_shrink = Vec::with_capacity(self.shrink_indexes.len()); for info_index in &self.shrink_indexes { let info = &mut self.all_infos[*info_index]; + self.best_slots_to_shrink.push((info.slot, info.capacity)); if bytes_to_shrink_due_to_ratio.0 >= threshold_bytes { // we exceeded the amount to shrink due to alive ratio, so don't shrink this one just due to 'should_shrink' // It MAY be shrunk based on total capacity still. @@ -188,6 +196,10 @@ impl AncientSlotInfos { bytes_to_shrink_due_to_ratio += info.alive_bytes; } } + // Reverse the vector so that the elements with the largest + // dead bytes are popped first when used to extend the + // shrinking candidates. + self.best_slots_to_shrink.reverse(); } /// after this function, only slots that were chosen to shrink are marked with @@ -396,7 +408,12 @@ impl AccountsDb { self.shrink_ancient_stats .slots_considered .fetch_add(sorted_slots.len() as u64, Ordering::Relaxed); - let ancient_slot_infos = self.collect_sort_filter_ancient_slots(sorted_slots, &tuning); + let mut ancient_slot_infos = self.collect_sort_filter_ancient_slots(sorted_slots, &tuning); + + std::mem::swap( + &mut *self.best_ancient_slots_to_shrink.write().unwrap(), + &mut ancient_slot_infos.best_slots_to_shrink, + ); if ancient_slot_infos.all_infos.is_empty() { return; // nothing to do From 598f7aedf98bf6be2d5f6afd5f14e8c6070ab20a Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 23:02:46 +0400 Subject: [PATCH 18/23] Extract entrypoint crate (#2430) * extract entrypoint crate * missing re-export * fix path * fmt * rename to solana-program-entrypoint * move to program-entrypoint dir * update lock files --- Cargo.lock | 11 ++++++ Cargo.toml | 2 + programs/sbf/Cargo.lock | 11 ++++++ sdk/program-entrypoint/Cargo.toml | 19 ++++++++++ .../src/lib.rs} | 38 ++++++++++--------- sdk/program/Cargo.toml | 1 + sdk/program/src/lib.rs | 10 +++-- 7 files changed, 70 insertions(+), 22 deletions(-) create mode 100644 sdk/program-entrypoint/Cargo.toml rename sdk/{program/src/entrypoint.rs => program-entrypoint/src/lib.rs} (95%) diff --git a/Cargo.lock b/Cargo.lock index 73bd1a01af5205..ab43b132ce8135 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -7323,6 +7323,7 @@ dependencies = [ "solana-logger", "solana-msg", "solana-native-token", + "solana-program-entrypoint", "solana-program-error", "solana-program-memory", "solana-program-option", @@ -7343,6 +7344,16 @@ dependencies = [ "wasm-bindgen", ] +[[package]] +name = "solana-program-entrypoint" +version = "2.1.0" +dependencies = [ + "solana-account-info", + "solana-msg", + "solana-program-error", + "solana-pubkey", +] + [[package]] name = "solana-program-error" version = "2.1.0" diff --git a/Cargo.toml b/Cargo.toml index 8339070f9bbf39..21d9b16dbd069c 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -120,6 +120,7 @@ members = [ "sdk/package-metadata", "sdk/package-metadata-macro", "sdk/program", + "sdk/program-entrypoint", "sdk/program-error", "sdk/program-memory", "sdk/program-option", @@ -408,6 +409,7 @@ solana-define-syscall = { path = "define-syscall", version = "=2.1.0" } solana-derivation-path = { path = "sdk/derivation-path", version = "=2.1.0" } solana-download-utils = { path = "download-utils", version = "=2.1.0" } solana-entry = { path = "entry", version = "=2.1.0" } +solana-program-entrypoint = { path = "sdk/program-entrypoint", version = "=2.1.0" } solana-epoch-schedule = { path = "sdk/epoch-schedule", version = "=2.1.0" } solana-faucet = { path = "faucet", version = "=2.1.0" } solana-feature-set = { path = "sdk/feature-set", version = "=2.1.0" } diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index 8d7a199fc4fa6b..b3fac0dc9df73e 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -5706,6 +5706,7 @@ dependencies = [ "solana-instruction", "solana-msg", "solana-native-token", + "solana-program-entrypoint", "solana-program-error", "solana-program-memory", "solana-program-option", @@ -5724,6 +5725,16 @@ dependencies = [ "wasm-bindgen", ] +[[package]] +name = "solana-program-entrypoint" +version = "2.1.0" +dependencies = [ + "solana-account-info", + "solana-msg", + "solana-program-error", + "solana-pubkey", +] + [[package]] name = "solana-program-error" version = "2.1.0" diff --git a/sdk/program-entrypoint/Cargo.toml b/sdk/program-entrypoint/Cargo.toml new file mode 100644 index 00000000000000..80f4760b4ad174 --- /dev/null +++ b/sdk/program-entrypoint/Cargo.toml @@ -0,0 +1,19 @@ +[package] +name = "solana-program-entrypoint" +description = "The Solana BPF program entrypoint supported by the latest BPF loader." +documentation = "https://docs.rs/solana-program-entrypoint" +version = { workspace = true } +authors = { workspace = true } +repository = { workspace = true } +homepage = { workspace = true } +license = { workspace = true } +edition = { workspace = true } + +[dependencies] +solana-account-info = { workspace = true } +solana-msg = { workspace = true } +solana-program-error = { workspace = true } +solana-pubkey = { workspace = true, default-features = false } + +[package.metadata.docs.rs] +targets = ["x86_64-unknown-linux-gnu"] diff --git a/sdk/program/src/entrypoint.rs b/sdk/program-entrypoint/src/lib.rs similarity index 95% rename from sdk/program/src/entrypoint.rs rename to sdk/program-entrypoint/src/lib.rs index f360d5ef2b2ece..1893b79b4a527a 100644 --- a/sdk/program/src/entrypoint.rs +++ b/sdk/program-entrypoint/src/lib.rs @@ -6,8 +6,9 @@ extern crate alloc; use { - crate::{account_info::AccountInfo, pubkey::Pubkey}, alloc::vec::Vec, + solana_account_info::AccountInfo, + solana_pubkey::Pubkey, std::{ alloc::Layout, cell::RefCell, @@ -17,7 +18,11 @@ use { slice::{from_raw_parts, from_raw_parts_mut}, }, }; -pub use {solana_account_info::MAX_PERMITTED_DATA_INCREASE, solana_program_error::ProgramResult}; +// need to re-export msg for custom_heap_default macro +pub use { + solana_account_info::MAX_PERMITTED_DATA_INCREASE, solana_msg::msg as __msg, + solana_program_error::ProgramResult, +}; /// User implemented function to process an instruction /// @@ -97,13 +102,11 @@ pub const NON_DUP_MARKER: u8 = u8::MAX; /// #[cfg(not(feature = "no-entrypoint"))] /// pub mod entrypoint { /// -/// use solana_program::{ -/// account_info::AccountInfo, -/// entrypoint, -/// entrypoint::ProgramResult, -/// msg, -/// pubkey::Pubkey, -/// }; +/// use solana_account_info::AccountInfo; +/// use solana_program_entrypoint::entrypoint; +/// use solana_program_entrypoint::ProgramResult; +/// use solana_msg::msg; +/// use solana_pubkey::Pubkey; /// /// entrypoint!(process_instruction); /// @@ -125,10 +128,9 @@ macro_rules! entrypoint { /// # Safety #[no_mangle] pub unsafe extern "C" fn entrypoint(input: *mut u8) -> u64 { - let (program_id, accounts, instruction_data) = - unsafe { $crate::entrypoint::deserialize(input) }; + let (program_id, accounts, instruction_data) = unsafe { $crate::deserialize(input) }; match $process_instruction(program_id, &accounts, instruction_data) { - Ok(()) => $crate::entrypoint::SUCCESS, + Ok(()) => $crate::SUCCESS, Err(error) => error.into(), } } @@ -170,7 +172,7 @@ macro_rules! entrypoint_no_alloc { const MAX_ACCOUNT_INFOS: usize = 64; let mut accounts = [UNINIT_ACCOUNT_INFO; MAX_ACCOUNT_INFOS]; let (program_id, num_accounts, instruction_data) = - unsafe { $crate::entrypoint::deserialize_into(input, &mut accounts) }; + unsafe { $crate::deserialize_into(input, &mut accounts) }; // Use `slice_assume_init_ref` once it's stabilized let accounts = &*(&accounts[..num_accounts] as *const [MaybeUninit>] as *const [AccountInfo<'_>]); @@ -178,7 +180,7 @@ macro_rules! entrypoint_no_alloc { #[inline(never)] fn call_program(program_id: &Pubkey, accounts: &[AccountInfo], data: &[u8]) -> u64 { match $process_instruction(program_id, accounts, data) { - Ok(()) => $crate::entrypoint::SUCCESS, + Ok(()) => $crate::SUCCESS, Err(error) => error.into(), } } @@ -214,9 +216,9 @@ macro_rules! custom_heap_default { () => { #[cfg(all(not(feature = "custom-heap"), target_os = "solana"))] #[global_allocator] - static A: $crate::entrypoint::BumpAllocator = $crate::entrypoint::BumpAllocator { - start: $crate::entrypoint::HEAP_START_ADDRESS as usize, - len: $crate::entrypoint::HEAP_LENGTH, + static A: $crate::BumpAllocator = $crate::BumpAllocator { + start: $crate::HEAP_START_ADDRESS as usize, + len: $crate::HEAP_LENGTH, }; }; } @@ -272,7 +274,7 @@ macro_rules! custom_panic_default { #[no_mangle] fn custom_panic(info: &core::panic::PanicInfo<'_>) { // Full panic reporting - $crate::msg!("{}", info); + $crate::__msg!("{}", info); } }; } diff --git a/sdk/program/Cargo.toml b/sdk/program/Cargo.toml index c3d373fb3f7835..8d15f64d2a22a1 100644 --- a/sdk/program/Cargo.toml +++ b/sdk/program/Cargo.toml @@ -52,6 +52,7 @@ solana-instruction = { workspace = true, default-features = false, features = [ ] } solana-msg = { workspace = true } solana-native-token = { workspace = true } +solana-program-entrypoint = { workspace = true } solana-program-error = { workspace = true, features = ["serde"] } solana-program-memory = { workspace = true } solana-program-option = { workspace = true } diff --git a/sdk/program/src/lib.rs b/sdk/program/src/lib.rs index ae339c371fdde3..e029208fa26639 100644 --- a/sdk/program/src/lib.rs +++ b/sdk/program/src/lib.rs @@ -483,7 +483,6 @@ pub mod bpf_loader_deprecated; pub mod bpf_loader_upgradeable; pub mod compute_units; pub mod ed25519_program; -pub mod entrypoint; pub mod entrypoint_deprecated; pub mod epoch_rewards; pub mod epoch_schedule; @@ -540,10 +539,13 @@ pub use { solana_account_info::{self as account_info, debug_account_data}, solana_clock as clock, solana_msg::msg, - solana_native_token as native_token, solana_program_option as program_option, - solana_pubkey as pubkey, solana_rent as rent, + solana_native_token as native_token, + solana_program_entrypoint::{ + self as entrypoint, custom_heap_default, custom_panic_default, entrypoint, + entrypoint_no_alloc, + }, + solana_program_option as program_option, solana_pubkey as pubkey, solana_rent as rent, }; - /// The [config native program][np]. /// /// [np]: https://docs.solanalabs.com/runtime/programs#config-program From 1740ea2f2cc757e88a7964c0edae43c8ffa654b8 Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Tue, 15 Oct 2024 23:55:39 +0400 Subject: [PATCH 19/23] move account_utils to account crate (#3174) * move account_utils to account crate * remove superfluous import --- Cargo.lock | 2 ++ programs/sbf/Cargo.lock | 1 + sdk/account/Cargo.toml | 4 +++- sdk/account/src/lib.rs | 2 ++ sdk/{src/account_utils.rs => account/src/state_traits.rs} | 6 +++--- sdk/src/lib.rs | 6 +++++- 6 files changed, 16 insertions(+), 5 deletions(-) rename sdk/{src/account_utils.rs => account/src/state_traits.rs} (93%) diff --git a/Cargo.lock b/Cargo.lock index ab43b132ce8135..2c94a4d9d482e5 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5652,8 +5652,10 @@ dependencies = [ "solana-account", "solana-frozen-abi", "solana-frozen-abi-macro", + "solana-instruction", "solana-logger", "solana-program", + "solana-pubkey", ] [[package]] diff --git a/programs/sbf/Cargo.lock b/programs/sbf/Cargo.lock index b3fac0dc9df73e..da726ceaeca3a8 100644 --- a/programs/sbf/Cargo.lock +++ b/programs/sbf/Cargo.lock @@ -4712,6 +4712,7 @@ dependencies = [ "serde", "serde_bytes", "serde_derive", + "solana-instruction", "solana-program", ] diff --git a/sdk/account/Cargo.toml b/sdk/account/Cargo.toml index 015736eebe08c4..62d35391142d64 100644 --- a/sdk/account/Cargo.toml +++ b/sdk/account/Cargo.toml @@ -17,14 +17,16 @@ serde_bytes = { workspace = true, optional = true } serde_derive = { workspace = true, optional = true } solana-frozen-abi = { workspace = true, optional = true } solana-frozen-abi-macro = { workspace = true, optional = true } +solana-instruction = { workspace = true, optional = true } solana-logger = { workspace = true, optional = true } solana-program = { workspace = true } [dev-dependencies] solana-account = { path = ".", features = ["dev-context-only-utils"] } +solana-pubkey = { workspace = true } [features] -bincode = ["dep:bincode", "serde"] +bincode = ["dep:bincode", "dep:solana-instruction", "serde"] dev-context-only-utils = ["bincode", "dep:qualifier_attr"] frozen-abi = [ "dep:solana-frozen-abi", diff --git a/sdk/account/src/lib.rs b/sdk/account/src/lib.rs index 762e41a5dd5abf..0d6df6ac6d8da4 100644 --- a/sdk/account/src/lib.rs +++ b/sdk/account/src/lib.rs @@ -29,6 +29,8 @@ use { sync::Arc, }, }; +#[cfg(feature = "bincode")] +pub mod state_traits; /// An Account with data that is stored on chain #[repr(C)] diff --git a/sdk/src/account_utils.rs b/sdk/account/src/state_traits.rs similarity index 93% rename from sdk/src/account_utils.rs rename to sdk/account/src/state_traits.rs index 7338d64cc33498..9b44e43eab159e 100644 --- a/sdk/src/account_utils.rs +++ b/sdk/account/src/state_traits.rs @@ -1,9 +1,9 @@ //! Useful extras for `Account` state. use { - crate::instruction::InstructionError, + crate::{Account, AccountSharedData}, bincode::ErrorKind, - solana_account::{Account, AccountSharedData}, + solana_instruction::error::InstructionError, std::cell::Ref, }; @@ -64,7 +64,7 @@ where #[cfg(test)] mod tests { - use {super::*, crate::pubkey::Pubkey, solana_account::AccountSharedData}; + use {super::*, solana_pubkey::Pubkey}; #[test] fn test_account_state() { diff --git a/sdk/src/lib.rs b/sdk/src/lib.rs index ed07e8c7806b57..e1d9503a75de20 100644 --- a/sdk/src/lib.rs +++ b/sdk/src/lib.rs @@ -58,7 +58,6 @@ pub use solana_program::{ }; #[cfg(feature = "borsh")] pub use solana_program::{borsh, borsh0_10, borsh1}; -pub mod account_utils; pub mod client; pub mod commitment_config; pub mod compute_budget; @@ -108,6 +107,11 @@ pub mod wasm; #[deprecated(since = "2.1.0", note = "Use `solana-account` crate instead")] pub use solana_account as account; +#[deprecated( + since = "2.1.0", + note = "Use `solana_account::state_traits` crate instead" +)] +pub use solana_account::state_traits as account_utils; #[deprecated(since = "2.1.0", note = "Use `solana-bn254` crate instead")] pub use solana_bn254 as alt_bn128; #[deprecated(since = "2.1.0", note = "Use `solana-decode-error` crate instead")] From 20460f5fef86da47781f9006afb7c6759b310f6b Mon Sep 17 00:00:00 2001 From: Kevin Heavey Date: Wed, 16 Oct 2024 00:04:30 +0400 Subject: [PATCH 20/23] fix doc link in solana-epoch-schedule (#3175) * fix doc link in solana-epoch-schedule * fmt --- sdk/epoch-schedule/src/lib.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/sdk/epoch-schedule/src/lib.rs b/sdk/epoch-schedule/src/lib.rs index e0d9d1c24e3b30..3ee21acdb9a12e 100644 --- a/sdk/epoch-schedule/src/lib.rs +++ b/sdk/epoch-schedule/src/lib.rs @@ -10,6 +10,8 @@ //! though the length of an epoch does — during the initial launch of //! the chain there is a "warmup" period, where epochs are short, with subsequent //! epochs increasing in slots until they last for [`DEFAULT_SLOTS_PER_EPOCH`]. +//! +//! [`DEFAULT_SLOTS_PER_EPOCH`]: https://docs.rs/solana-clock/latest/solana_clock/constant.DEFAULT_SLOTS_PER_EPOCH.html #![cfg_attr(feature = "frozen-abi", feature(min_specialization))] #![no_std] #[cfg(feature = "frozen-abi")] From 20aa3be7d7c04c55c82d222788b6d509124dc6fc Mon Sep 17 00:00:00 2001 From: Brooks Date: Tue, 15 Oct 2024 16:08:13 -0400 Subject: [PATCH 21/23] Rehashing is not allowed to change accounts (#3180) --- runtime/src/bank.rs | 25 +++++++++++++++++++++- runtime/src/bank/tests.rs | 45 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 69 insertions(+), 1 deletion(-) diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 0975a6dbccde23..0a4cb785f2c091 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -2869,11 +2869,34 @@ impl Bank { stake_weighted_timestamp } + /// Recalculates the bank hash + /// + /// This is used by ledger-tool when creating a snapshot, which + /// recalcuates the bank hash. + /// + /// Note that the account state is *not* allowed to change by rehashing. + /// If it does, this function will panic. + /// If modifying accounts in ledger-tool is needed, create a new bank. pub fn rehash(&self) { + let get_delta_hash = || { + self.rc + .accounts + .accounts_db + .get_accounts_delta_hash(self.slot()) + }; + let mut hash = self.hash.write().unwrap(); + let curr_accounts_delta_hash = get_delta_hash(); let new = self.hash_internal_state(); + if let Some(curr_accounts_delta_hash) = curr_accounts_delta_hash { + let new_accounts_delta_hash = get_delta_hash().unwrap(); + assert_eq!( + new_accounts_delta_hash, curr_accounts_delta_hash, + "rehashing is not allowed to change the account state", + ); + } if new != *hash { - warn!("Updating bank hash to {}", new); + warn!("Updating bank hash to {new}"); *hash = new; } } diff --git a/runtime/src/bank/tests.rs b/runtime/src/bank/tests.rs index 454aa32215de11..9a8324d58a0165 100644 --- a/runtime/src/bank/tests.rs +++ b/runtime/src/bank/tests.rs @@ -13252,3 +13252,48 @@ fn test_bank_epoch_stakes() { ); } } + +#[test] +fn test_rehash_good() { + let ten_sol = 10 * LAMPORTS_PER_SOL; + let (genesis_config, _mint) = create_genesis_config(ten_sol); + let bank = Bank::new_for_tests(&genesis_config); + + let lamports = 123_456_789; + let account = AccountSharedData::new(lamports, 0, &Pubkey::default()); + let pubkey = Pubkey::new_unique(); + bank.store_account_and_update_capitalization(&pubkey, &account); + + // freeze the bank to trigger hash calculation + bank.freeze(); + + // ensure the bank hash is the same before and after rehashing + let prev_bank_hash = bank.hash(); + bank.rehash(); + let post_bank_hash = bank.hash(); + assert_eq!(post_bank_hash, prev_bank_hash); +} + +#[test] +#[should_panic(expected = "rehashing is not allowed to change the account state")] +fn test_rehash_bad() { + let ten_sol = 10 * LAMPORTS_PER_SOL; + let (genesis_config, _mint) = create_genesis_config(ten_sol); + let bank = Bank::new_for_tests(&genesis_config); + + let mut account = AccountSharedData::new(ten_sol, 0, &Pubkey::default()); + let pubkey = Pubkey::new_unique(); + bank.store_account_and_update_capitalization(&pubkey, &account); + + // freeze the bank to trigger hash calculation + bank.freeze(); + + // change an account, which will cause rehashing to panic + account.checked_add_lamports(ten_sol).unwrap(); + bank.rc + .accounts + .store_accounts_cached((bank.slot(), [(&pubkey, &account)].as_slice())); + + // let the show begin + bank.rehash(); +} From 54887936ce2484127d02d0a624b705c4b4fe6678 Mon Sep 17 00:00:00 2001 From: hana <81144685+2501babe@users.noreply.github.com> Date: Tue, 15 Oct 2024 14:52:19 -0700 Subject: [PATCH 22/23] svm: test account loader edge cases (#3045) tests intended to ensure account loader v2 conforms to existing behavior --- svm/src/account_loader.rs | 487 +++++++++++++++++++++++++++++++++++++- 1 file changed, 483 insertions(+), 4 deletions(-) diff --git a/svm/src/account_loader.rs b/svm/src/account_loader.rs index be4014fa69c4a4..2e47957d7f31dd 100644 --- a/svm/src/account_loader.rs +++ b/svm/src/account_loader.rs @@ -571,19 +571,21 @@ mod tests { nonce::state::Versions as NonceVersions, solana_compute_budget::{compute_budget::ComputeBudget, compute_budget_limits}, solana_feature_set::FeatureSet, - solana_program_runtime::loaded_programs::{ProgramCacheEntry, ProgramCacheForTxBatch}, + solana_program_runtime::loaded_programs::{ + ProgramCacheEntry, ProgramCacheEntryOwner, ProgramCacheForTxBatch, + }, solana_sdk::{ account::{Account, AccountSharedData, ReadableAccount, WritableAccount}, - bpf_loader_upgradeable, + bpf_loader, bpf_loader_upgradeable, epoch_schedule::EpochSchedule, hash::Hash, - instruction::CompiledInstruction, + instruction::{AccountMeta, CompiledInstruction, Instruction}, message::{ v0::{LoadedAddresses, LoadedMessage}, LegacyMessage, Message, MessageHeader, SanitizedMessage, }, native_loader, - native_token::sol_to_lamports, + native_token::{sol_to_lamports, LAMPORTS_PER_SOL}, nonce, pubkey::Pubkey, rent::Rent, @@ -686,6 +688,28 @@ mod tests { )) } + fn new_unchecked_sanitized_transaction_with_writable_program( + program_id: Pubkey, + fee_payer: Pubkey, + ) -> SanitizedTransaction { + let mut message = Message::new( + &[Instruction::new_with_bytes(program_id, &[], vec![])], + Some(&fee_payer), + ); + message.header.num_readonly_unsigned_accounts = 0; + + let legacy_message = LegacyMessage { + message: Cow::Owned(message), + is_writable_account_cache: vec![true, true], + }; + + SanitizedTransaction::new_for_tests( + SanitizedMessage::Legacy(legacy_message), + vec![Signature::default()], + false, + ) + } + fn load_accounts_aux_test( tx: Transaction, accounts: &[TransactionAccount], @@ -1378,6 +1402,178 @@ mod tests { assert_eq!(result.err(), Some(TransactionError::AccountNotFound)); } + #[test] + fn test_load_transaction_accounts_program_account_executable_bypass() { + // currently, the account loader retrieves read-only non-instruction accounts from the program cache + // it creates a mock AccountSharedData with the executable flag set to true + // however, it does not check whether these accounts are actually executable before doing so + // this affects consensus: a transaction that uses a cached non-executable program executes and fails + // but if the transaction gets the program from accounts-db, it will be dropped during account loading + // this test enforces the current behavior, so that future account loader changes do not break consensus + + let mut mock_bank = TestCallbacks::default(); + let account_keypair = Keypair::new(); + let program_keypair = Keypair::new(); + + let mut account_data = AccountSharedData::default(); + account_data.set_lamports(200); + mock_bank + .accounts_map + .insert(account_keypair.pubkey(), account_data.clone()); + + let mut program_data = AccountSharedData::default(); + program_data.set_lamports(200); + program_data.set_owner(bpf_loader::id()); + mock_bank + .accounts_map + .insert(program_keypair.pubkey(), program_data); + + let mut loader_data = AccountSharedData::default(); + loader_data.set_lamports(200); + loader_data.set_executable(true); + loader_data.set_owner(native_loader::id()); + mock_bank + .accounts_map + .insert(bpf_loader::id(), loader_data.clone()); + mock_bank + .accounts_map + .insert(native_loader::id(), loader_data); + + let mut error_metrics = TransactionErrorMetrics::default(); + let mut loaded_programs = ProgramCacheForTxBatch::default(); + + let transaction = + SanitizedTransaction::from_transaction_for_tests(Transaction::new_signed_with_payer( + &[Instruction::new_with_bytes( + program_keypair.pubkey(), + &[], + vec![], + )], + Some(&account_keypair.pubkey()), + &[&account_keypair], + Hash::default(), + )); + + let result = load_transaction_accounts( + &mock_bank, + transaction.message(), + LoadedTransactionAccount { + account: account_data.clone(), + ..LoadedTransactionAccount::default() + }, + &ComputeBudgetLimits::default(), + &mut error_metrics, + None, + &FeatureSet::default(), + &RentCollector::default(), + &loaded_programs, + ); + + // without cache, program is invalid + assert_eq!( + result.err(), + Some(TransactionError::InvalidProgramForExecution) + ); + + loaded_programs.replenish( + program_keypair.pubkey(), + Arc::new(ProgramCacheEntry::default()), + ); + + let result = load_transaction_accounts( + &mock_bank, + transaction.message(), + LoadedTransactionAccount { + account: account_data.clone(), + ..LoadedTransactionAccount::default() + }, + &ComputeBudgetLimits::default(), + &mut error_metrics, + None, + &FeatureSet::default(), + &RentCollector::default(), + &loaded_programs, + ); + + // with cache, executable flag is bypassed + let mut cached_program = AccountSharedData::default(); + cached_program.set_owner(native_loader::id()); + cached_program.set_executable(true); + + assert_eq!( + result.unwrap(), + LoadedTransactionAccounts { + accounts: vec![ + (account_keypair.pubkey(), account_data.clone()), + (program_keypair.pubkey(), cached_program), + ], + program_indices: vec![vec![1]], + rent: 0, + rent_debits: RentDebits::default(), + loaded_accounts_data_size: 0, + } + ); + + let transaction = + SanitizedTransaction::from_transaction_for_tests(Transaction::new_signed_with_payer( + &[Instruction::new_with_bytes( + program_keypair.pubkey(), + &[], + vec![AccountMeta::new_readonly(program_keypair.pubkey(), false)], + )], + Some(&account_keypair.pubkey()), + &[&account_keypair], + Hash::default(), + )); + + let result = load_transaction_accounts( + &mock_bank, + transaction.message(), + LoadedTransactionAccount { + account: account_data.clone(), + ..LoadedTransactionAccount::default() + }, + &ComputeBudgetLimits::default(), + &mut error_metrics, + None, + &FeatureSet::default(), + &RentCollector::default(), + &loaded_programs, + ); + + // including program as instruction account bypasses executable bypass + assert_eq!( + result.err(), + Some(TransactionError::InvalidProgramForExecution) + ); + + let transaction = new_unchecked_sanitized_transaction_with_writable_program( + program_keypair.pubkey(), + account_keypair.pubkey(), + ); + + let result = load_transaction_accounts( + &mock_bank, + transaction.message(), + LoadedTransactionAccount { + account: account_data.clone(), + ..LoadedTransactionAccount::default() + }, + &ComputeBudgetLimits::default(), + &mut error_metrics, + None, + &FeatureSet::default(), + &RentCollector::default(), + &loaded_programs, + ); + + // including program as writable bypasses executable bypass + assert_eq!( + result.err(), + Some(TransactionError::InvalidProgramForExecution) + ); + } + #[test] fn test_load_transaction_accounts_program_account_no_data() { let key1 = Keypair::new(); @@ -2214,4 +2410,287 @@ mod tests { assert_eq!(actual_inspected_accounts, expected_inspected_accounts,); } + + #[test] + fn test_load_transaction_accounts_data_sizes() { + let mut mock_bank = TestCallbacks::default(); + + let mut next_size = 1; + let mut make_account = |pubkey, owner, executable| { + let size = next_size; + let account = AccountSharedData::create( + LAMPORTS_PER_SOL, + vec![0; size], + owner, + executable, + u64::MAX, + ); + + mock_bank.accounts_map.insert(pubkey, account.clone()); + + // accounts are counted at most twice + // by multiplying account size by 4, we ensure all totals are unique + next_size *= 4; + + (size as u32, account) + }; + + let (native_loader_size, _) = make_account(native_loader::id(), native_loader::id(), true); + let (bpf_loader_size, _) = make_account(bpf_loader::id(), native_loader::id(), true); + let (upgradeable_loader_size, _) = + make_account(bpf_loader_upgradeable::id(), native_loader::id(), true); + + let program1_keypair = Keypair::new(); + let program1 = program1_keypair.pubkey(); + let (program1_size, _) = make_account(program1, bpf_loader::id(), true); + + let program2 = Pubkey::new_unique(); + let (program2_size, _) = make_account(program2, bpf_loader_upgradeable::id(), true); + + let programdata2 = Pubkey::new_unique(); + let (programdata2_size, _) = + make_account(programdata2, bpf_loader_upgradeable::id(), false); + + let fee_payer_keypair = Keypair::new(); + let fee_payer = fee_payer_keypair.pubkey(); + let (fee_payer_size, fee_payer_account) = + make_account(fee_payer, system_program::id(), false); + + let account1 = Pubkey::new_unique(); + let (account1_size, _) = make_account(account1, program1, false); + + let account2 = Pubkey::new_unique(); + let (account2_size, _) = make_account(account2, program2, false); + + let test_transaction_data_size_with_cache = |transaction, cache, expected_size| { + let loaded_transaction_accounts = load_transaction_accounts( + &mock_bank, + &transaction, + LoadedTransactionAccount { + account: fee_payer_account.clone(), + loaded_size: fee_payer_size as usize, + rent_collected: 0, + }, + &ComputeBudgetLimits::default(), + &mut TransactionErrorMetrics::default(), + None, + &FeatureSet::default(), + &RentCollector::default(), + &cache, + ) + .unwrap(); + + assert_eq!( + loaded_transaction_accounts.loaded_accounts_data_size, + expected_size + ); + }; + + let test_data_size_with_cache = |instructions: Vec<_>, cache, expected_size| { + let transaction = SanitizedTransaction::from_transaction_for_tests( + Transaction::new_signed_with_payer( + &instructions, + Some(&fee_payer), + &[&fee_payer_keypair], + Hash::default(), + ), + ); + + test_transaction_data_size_with_cache(transaction, cache, expected_size) + }; + + for account_meta in [AccountMeta::new, AccountMeta::new_readonly] { + let test_data_size = |instructions, expected_size| { + test_data_size_with_cache( + instructions, + ProgramCacheForTxBatch::default(), + expected_size, + ) + }; + + // one program plus loader + let ixns = vec![Instruction::new_with_bytes(program1, &[], vec![])]; + test_data_size(ixns, program1_size + bpf_loader_size + fee_payer_size); + + // two programs, two loaders, two accounts + let ixns = vec![ + Instruction::new_with_bytes(program1, &[], vec![account_meta(account1, false)]), + Instruction::new_with_bytes(program2, &[], vec![account_meta(account2, false)]), + ]; + test_data_size( + ixns, + account1_size + + account2_size + + program1_size + + program2_size + + bpf_loader_size + + upgradeable_loader_size + + fee_payer_size, + ); + + // ordinary owners not counted + let ixns = vec![Instruction::new_with_bytes( + program1, + &[], + vec![account_meta(account2, false)], + )]; + test_data_size( + ixns, + account2_size + program1_size + bpf_loader_size + fee_payer_size, + ); + + // program and loader counted once + let ixns = vec![ + Instruction::new_with_bytes(program1, &[], vec![]), + Instruction::new_with_bytes(program1, &[], vec![]), + ]; + test_data_size(ixns, program1_size + bpf_loader_size + fee_payer_size); + + // native loader not counted if loader + let ixns = vec![Instruction::new_with_bytes(bpf_loader::id(), &[], vec![])]; + test_data_size(ixns, bpf_loader_size + fee_payer_size); + + // native loader counted if instruction + let ixns = vec![Instruction::new_with_bytes( + bpf_loader::id(), + &[], + vec![account_meta(native_loader::id(), false)], + )]; + test_data_size(ixns, bpf_loader_size + native_loader_size + fee_payer_size); + + // native loader counted if invoked + let ixns = vec![Instruction::new_with_bytes( + native_loader::id(), + &[], + vec![], + )]; + test_data_size(ixns, native_loader_size + fee_payer_size); + + // native loader counted once if invoked and instruction + let ixns = vec![Instruction::new_with_bytes( + native_loader::id(), + &[], + vec![account_meta(native_loader::id(), false)], + )]; + test_data_size(ixns, native_loader_size + fee_payer_size); + + // loader counted twice if included in instruction + let ixns = vec![Instruction::new_with_bytes( + program1, + &[], + vec![account_meta(bpf_loader::id(), false)], + )]; + test_data_size(ixns, program1_size + bpf_loader_size * 2 + fee_payer_size); + + // cover that case with multiple loaders to be sure + let ixns = vec![ + Instruction::new_with_bytes( + program1, + &[], + vec![ + account_meta(bpf_loader::id(), false), + account_meta(bpf_loader_upgradeable::id(), false), + ], + ), + Instruction::new_with_bytes(program2, &[], vec![account_meta(account1, false)]), + Instruction::new_with_bytes( + bpf_loader_upgradeable::id(), + &[], + vec![account_meta(account1, false)], + ), + ]; + test_data_size( + ixns, + account1_size + + program1_size + + program2_size + + bpf_loader_size * 2 + + upgradeable_loader_size * 2 + + fee_payer_size, + ); + + // loader counted twice even if included first + let ixns = vec![ + Instruction::new_with_bytes(bpf_loader::id(), &[], vec![]), + Instruction::new_with_bytes(program1, &[], vec![]), + ]; + test_data_size(ixns, program1_size + bpf_loader_size * 2 + fee_payer_size); + + // fee-payer counted once + let ixns = vec![Instruction::new_with_bytes( + program1, + &[], + vec![account_meta(fee_payer, false)], + )]; + test_data_size(ixns, program1_size + bpf_loader_size + fee_payer_size); + + // edge cases involving program cache + let mut program_cache = ProgramCacheForTxBatch::default(); + + let program2_entry = ProgramCacheEntry { + account_size: (program2_size + programdata2_size) as usize, + account_owner: ProgramCacheEntryOwner::LoaderV3, + ..ProgramCacheEntry::default() + }; + program_cache.replenish(program2, Arc::new(program2_entry)); + + // normal function call uses the combined cache size + let ixns = vec![Instruction::new_with_bytes(program2, &[], vec![])]; + test_data_size_with_cache( + ixns, + program_cache.clone(), + program2_size + programdata2_size + upgradeable_loader_size + fee_payer_size, + ); + + // program as instruction account bypasses the cache + let ixns = vec![Instruction::new_with_bytes( + program2, + &[], + vec![account_meta(program2, false)], + )]; + test_data_size_with_cache( + ixns, + program_cache.clone(), + program2_size + upgradeable_loader_size + fee_payer_size, + ); + + // programdata as instruction account double-counts it + let ixns = vec![Instruction::new_with_bytes( + program2, + &[], + vec![account_meta(programdata2, false)], + )]; + test_data_size_with_cache( + ixns, + program_cache.clone(), + program2_size + programdata2_size * 2 + upgradeable_loader_size + fee_payer_size, + ); + + // both as instruction accounts, for completeness + let ixns = vec![Instruction::new_with_bytes( + program2, + &[], + vec![ + account_meta(program2, false), + account_meta(programdata2, false), + ], + )]; + test_data_size_with_cache( + ixns, + program_cache.clone(), + program2_size + programdata2_size + upgradeable_loader_size + fee_payer_size, + ); + + // writable program bypasses the cache + let tx = new_unchecked_sanitized_transaction_with_writable_program(program2, fee_payer); + test_transaction_data_size_with_cache( + tx, + program_cache.clone(), + program2_size + upgradeable_loader_size + fee_payer_size, + ); + + // NOTE for the new loader we *must* also test arbitrary permutations of the cache transactions + // to ensure that the batched loading is overridden on a tx-per-tx basis + } + } } From a458839ff1114c614ca416f17c4bf2c2da9c9af6 Mon Sep 17 00:00:00 2001 From: dmakarov Date: Tue, 15 Oct 2024 19:33:54 -0400 Subject: [PATCH 23/23] Use VecDeque for best_ancient_slots_to_shrink to avoid vec reversing (#3187) --- accounts-db/src/accounts_db.rs | 14 ++++++-------- accounts-db/src/ancient_append_vecs.rs | 13 +++++-------- 2 files changed, 11 insertions(+), 16 deletions(-) diff --git a/accounts-db/src/accounts_db.rs b/accounts-db/src/accounts_db.rs index e2353b99fce81d..b16d5700157609 100644 --- a/accounts-db/src/accounts_db.rs +++ b/accounts-db/src/accounts_db.rs @@ -97,7 +97,7 @@ use { std::{ borrow::Cow, boxed::Box, - collections::{BTreeSet, HashMap, HashSet}, + collections::{BTreeSet, HashMap, HashSet, VecDeque}, fs, hash::{Hash as StdHash, Hasher as StdHasher}, io::Result as IoResult, @@ -1508,12 +1508,11 @@ pub struct AccountsDb { pub is_experimental_accumulator_hash_enabled: AtomicBool, /// These are the ancient storages that could be valuable to - /// shrink, sorted by amount of dead bytes. The elements - /// are popped from the end of the vector, hence the sorting is - /// expected to be from the smallest dead bytes to the largest. + /// shrink, sorted by amount of dead bytes. The elements + /// are sorted from the largest dead bytes to the smallest. /// Members are Slot and capacity. If capacity is smaller, then /// that means the storage was already shrunk. - pub(crate) best_ancient_slots_to_shrink: RwLock>, + pub(crate) best_ancient_slots_to_shrink: RwLock>, } /// results from 'split_storages_ancient' @@ -4442,11 +4441,10 @@ impl AccountsDb { }); // If there are too few slots to shrink, add an ancient slot - // for shrinking. The best ancient slots to shrink are - // assumed to be in reverse order. + // for shrinking. if shrink_slots.len() < SHRINK_INSERT_ANCIENT_THRESHOLD { let mut ancients = self.best_ancient_slots_to_shrink.write().unwrap(); - while let Some((slot, capacity)) = ancients.pop() { + while let Some((slot, capacity)) = ancients.pop_front() { if let Some(store) = self.storage.get_slot_storage_entry(slot) { if !shrink_slots.contains(&slot) && capacity == store.capacity() diff --git a/accounts-db/src/ancient_append_vecs.rs b/accounts-db/src/ancient_append_vecs.rs index 5d645c9560cc39..148c543b4c6302 100644 --- a/accounts-db/src/ancient_append_vecs.rs +++ b/accounts-db/src/ancient_append_vecs.rs @@ -21,7 +21,7 @@ use { solana_measure::measure_us, solana_sdk::clock::Slot, std::{ - collections::HashMap, + collections::{HashMap, VecDeque}, num::{NonZeroU64, Saturating}, sync::{atomic::Ordering, Arc, Mutex}, }, @@ -81,7 +81,7 @@ struct AncientSlotInfos { total_alive_bytes: Saturating, /// slots that have dead accounts and thus the corresponding slot /// storages can be shrunk - best_slots_to_shrink: Vec<(Slot, u64)>, + best_slots_to_shrink: VecDeque<(Slot, u64)>, } impl AncientSlotInfos { @@ -183,10 +183,11 @@ impl AncientSlotInfos { // At this point self.shrink_indexes have been sorted by the // largest amount of dead bytes first in the corresponding // storages. - self.best_slots_to_shrink = Vec::with_capacity(self.shrink_indexes.len()); + self.best_slots_to_shrink = VecDeque::with_capacity(self.shrink_indexes.len()); for info_index in &self.shrink_indexes { let info = &mut self.all_infos[*info_index]; - self.best_slots_to_shrink.push((info.slot, info.capacity)); + self.best_slots_to_shrink + .push_back((info.slot, info.capacity)); if bytes_to_shrink_due_to_ratio.0 >= threshold_bytes { // we exceeded the amount to shrink due to alive ratio, so don't shrink this one just due to 'should_shrink' // It MAY be shrunk based on total capacity still. @@ -196,10 +197,6 @@ impl AncientSlotInfos { bytes_to_shrink_due_to_ratio += info.alive_bytes; } } - // Reverse the vector so that the elements with the largest - // dead bytes are popped first when used to extend the - // shrinking candidates. - self.best_slots_to_shrink.reverse(); } /// after this function, only slots that were chosen to shrink are marked with

re=z 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 z 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�-4xt>M5$z!DFCSNnG+W@`7x8`V(o3y8JsrO~ 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%0DgRT+z@^+&Av|@ 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