From b650e17475ea7ceae06cc1a88b22eb16537356ce Mon Sep 17 00:00:00 2001 From: Pankaj Garg Date: Fri, 10 Jan 2025 12:08:05 -0800 Subject: [PATCH] Reduce public visibility of some SVM related structs and APIs (#4378) * reduce public visibility of some SVM related structs * fix test compilation --- Cargo.lock | 1 + builtins-default-costs/src/lib.rs | 8 ++++---- compute-budget-instruction/src/builtin_programs_filter.rs | 2 +- compute-budget/Cargo.toml | 2 ++ compute-budget/src/compute_budget.rs | 5 ++++- program-runtime/Cargo.toml | 1 + svm/Cargo.toml | 1 + 7 files changed, 14 insertions(+), 6 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index dd63ec8741ec35..18882fa21b9e46 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -6756,6 +6756,7 @@ dependencies = [ name = "solana-compute-budget" version = "2.2.0" dependencies = [ + "qualifier_attr", "solana-fee-structure", "solana-frozen-abi", "solana-program-entrypoint", diff --git a/builtins-default-costs/src/lib.rs b/builtins-default-costs/src/lib.rs index a1c4000a75499d..53fed71acaeca8 100644 --- a/builtins-default-costs/src/lib.rs +++ b/builtins-default-costs/src/lib.rs @@ -41,14 +41,14 @@ pub enum BuiltinCost { } impl BuiltinCost { - pub fn native_cost(&self) -> u64 { + fn native_cost(&self) -> u64 { match self { BuiltinCost::Migrating(MigratingBuiltinCost { native_cost, .. }) => *native_cost, BuiltinCost::NotMigrating(NotMigratingBuiltinCost { native_cost }) => *native_cost, } } - pub fn core_bpf_migration_feature(&self) -> Option<&Pubkey> { + fn core_bpf_migration_feature(&self) -> Option<&Pubkey> { match self { BuiltinCost::Migrating(MigratingBuiltinCost { core_bpf_migration_feature, @@ -58,7 +58,7 @@ impl BuiltinCost { } } - pub fn position(&self) -> Option { + fn position(&self) -> Option { match self { BuiltinCost::Migrating(MigratingBuiltinCost { position, .. }) => Some(*position), BuiltinCost::NotMigrating(_) => None, @@ -137,7 +137,7 @@ pub const MIGRATING_BUILTINS_COSTS: &[(Pubkey, BuiltinCost)] = &[ ), ]; -pub const NON_MIGRATING_BUILTINS_COSTS: &[(Pubkey, BuiltinCost)] = &[ +const NON_MIGRATING_BUILTINS_COSTS: &[(Pubkey, BuiltinCost)] = &[ ( vote::id(), BuiltinCost::NotMigrating(NotMigratingBuiltinCost { diff --git a/compute-budget-instruction/src/builtin_programs_filter.rs b/compute-budget-instruction/src/builtin_programs_filter.rs index a8b1058e0102c4..92801d44bcfb4f 100644 --- a/compute-budget-instruction/src/builtin_programs_filter.rs +++ b/compute-budget-instruction/src/builtin_programs_filter.rs @@ -7,7 +7,7 @@ use { }; // The maximum number of pubkeys that a packet can contain. -pub const FILTER_SIZE: u8 = (PACKET_DATA_SIZE / core::mem::size_of::()) as u8; +pub(crate) const FILTER_SIZE: u8 = (PACKET_DATA_SIZE / core::mem::size_of::()) as u8; #[derive(Clone, Copy, Debug, PartialEq)] pub(crate) enum ProgramKind { diff --git a/compute-budget/Cargo.toml b/compute-budget/Cargo.toml index 961ec9fc34aa01..78d4761cdc664b 100644 --- a/compute-budget/Cargo.toml +++ b/compute-budget/Cargo.toml @@ -10,6 +10,7 @@ license = { workspace = true } edition = { workspace = true } [dependencies] +qualifier_attr = { workspace = true, optional = true } solana-fee-structure = { workspace = true } solana-frozen-abi = { workspace = true, optional = true, features = [ "frozen-abi", @@ -17,6 +18,7 @@ solana-frozen-abi = { workspace = true, optional = true, features = [ solana-program-entrypoint = { workspace = true } [features] +dev-context-only-utils = ["dep:qualifier_attr"] frozen-abi = ["dep:solana-frozen-abi", "solana-fee-structure/frozen-abi"] [lints] diff --git a/compute-budget/src/compute_budget.rs b/compute-budget/src/compute_budget.rs index 9d1a351dd3069f..39247062f25c8d 100644 --- a/compute-budget/src/compute_budget.rs +++ b/compute-budget/src/compute_budget.rs @@ -1,4 +1,6 @@ use crate::compute_budget_limits::{self, ComputeBudgetLimits, DEFAULT_HEAP_COST}; +#[cfg(feature = "dev-context-only-utils")] +use qualifier_attr::qualifiers; #[cfg(feature = "frozen-abi")] impl ::solana_frozen_abi::abi_example::AbiExample for ComputeBudget { @@ -146,7 +148,8 @@ impl From for ComputeBudget { } impl ComputeBudget { - pub fn new(compute_unit_limit: u64) -> Self { + #[cfg_attr(feature = "dev-context-only-utils", qualifiers(pub))] + fn new(compute_unit_limit: u64) -> Self { ComputeBudget { compute_unit_limit, log_64_units: 100, diff --git a/program-runtime/Cargo.toml b/program-runtime/Cargo.toml index 704c802fad69f8..484921a50bf754 100644 --- a/program-runtime/Cargo.toml +++ b/program-runtime/Cargo.toml @@ -54,6 +54,7 @@ thiserror = { workspace = true } [dev-dependencies] assert_matches = { workspace = true } +solana-compute-budget = { workspace = true, features = ["dev-context-only-utils"] } solana-instruction = { workspace = true, features = ["bincode"] } solana-pubkey = { workspace = true, features = ["rand"] } solana-transaction-context = { workspace = true, features = [ diff --git a/svm/Cargo.toml b/svm/Cargo.toml index 63378e339f647a..e740889e472964 100644 --- a/svm/Cargo.toml +++ b/svm/Cargo.toml @@ -71,6 +71,7 @@ prost = { workspace = true } rand0-7 = { workspace = true } shuttle = { workspace = true } solana-clock = { workspace = true } +solana-compute-budget = { workspace = true, features = ["dev-context-only-utils"] } solana-compute-budget-interface = { workspace = true } solana-compute-budget-program = { workspace = true } solana-ed25519-program = { workspace = true }