Skip to content

Commit

Permalink
Cleanup - require_static_program_ids_in_transaction (#31767)
Browse files Browse the repository at this point in the history
require_static_program_ids_in_transaction
  • Loading branch information
Lichtso authored Jun 7, 2023
1 parent 989e613 commit ee2c2ef
Show file tree
Hide file tree
Showing 17 changed files with 33 additions and 120 deletions.
2 changes: 0 additions & 2 deletions banks-server/src/banks_server.rs
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,6 @@ fn simulate_transaction(
MessageHash::Compute,
Some(false), // is_simple_vote_tx
bank,
true, // require_static_program_ids
) {
Err(err) => {
return BanksTransactionResultWithSimulation {
Expand Down Expand Up @@ -330,7 +329,6 @@ impl Banks for BanksServer {
MessageHash::Compute,
Some(false), // is_simple_vote_tx
bank.as_ref(),
true, // require_static_program_ids
) {
Ok(tx) => tx,
Err(err) => return Some(Err(err)),
Expand Down
1 change: 0 additions & 1 deletion core/src/banking_stage/consumer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1697,7 +1697,6 @@ mod tests {
MessageHash::Compute,
Some(false),
bank.as_ref(),
true, // require_static_program_ids
)
.unwrap();

Expand Down
1 change: 0 additions & 1 deletion core/src/read_write_account_set.rs
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,6 @@ mod tests {
MessageHash::Compute,
Some(false),
bank,
true, // require_static_program_ids
)
.unwrap()
}
Expand Down
2 changes: 0 additions & 2 deletions entry/benches/entry_sigverify.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,6 @@ fn bench_gpusigverify(bencher: &mut Bencher) {
message_hash,
None,
SimpleAddressLoader::Disabled,
true, // require_static_program_ids
)
}?;

Expand Down Expand Up @@ -82,7 +81,6 @@ fn bench_cpusigverify(bencher: &mut Bencher) {
message_hash,
None,
SimpleAddressLoader::Disabled,
true, // require_static_program_ids
)
}?;

Expand Down
1 change: 0 additions & 1 deletion entry/src/entry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1041,7 +1041,6 @@ mod tests {
message_hash,
None,
SimpleAddressLoader::Disabled,
true, // require_static_program_ids
)
}?;

Expand Down
1 change: 0 additions & 1 deletion ledger-tool/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -922,7 +922,6 @@ fn compute_slot_cost(blockstore: &Blockstore, slot: Slot) -> Result<(), String>
MessageHash::Compute,
None,
SimpleAddressLoader::Disabled,
true, // require_static_program_ids
)
.map_err(|err| {
warn!("Failed to compute cost of transaction: {:?}", err);
Expand Down
11 changes: 2 additions & 9 deletions ledger/src/blockstore.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1984,12 +1984,7 @@ impl Blockstore {
.into_iter()
.flat_map(|entry| entry.transactions)
.map(|transaction| {
if let Err(err) = transaction.sanitize(
// Don't enable additional sanitization checks until
// all clusters have activated the static program id
// feature gate so that bigtable upload isn't affected
false, // require_static_program_ids
) {
if let Err(err) = transaction.sanitize() {
warn!(
"Blockstore::get_block sanitize failed: {:?}, \
slot: {:?}, \
Expand Down Expand Up @@ -2376,9 +2371,7 @@ impl Blockstore {
.cloned()
.flat_map(|entry| entry.transactions)
.map(|transaction| {
if let Err(err) = transaction.sanitize(
true, // require_static_program_ids
) {
if let Err(err) = transaction.sanitize() {
warn!(
"Blockstore::find_transaction_in_slot sanitize failed: {:?}, \
slot: {:?}, \
Expand Down
10 changes: 2 additions & 8 deletions rpc/src/rpc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4516,14 +4516,8 @@ fn sanitize_transaction(
transaction: VersionedTransaction,
address_loader: impl AddressLoader,
) -> Result<SanitizedTransaction> {
SanitizedTransaction::try_create(
transaction,
MessageHash::Compute,
None,
address_loader,
true, // require_static_program_ids
)
.map_err(|err| Error::invalid_params(format!("invalid transaction: {err}")))
SanitizedTransaction::try_create(transaction, MessageHash::Compute, None, address_loader)
.map_err(|err| Error::invalid_params(format!("invalid transaction: {err}")))
}

pub fn create_validator_exit(exit: Arc<AtomicBool>) -> Arc<RwLock<Exit>> {
Expand Down
1 change: 0 additions & 1 deletion rpc/src/transaction_status_service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -349,7 +349,6 @@ pub(crate) mod tests {
MessageHash::Compute,
None,
SimpleAddressLoader::Disabled,
true, // require_static_program_ids
)
.unwrap();

Expand Down
20 changes: 2 additions & 18 deletions runtime/src/bank.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3763,16 +3763,7 @@ impl Bank {
pub fn prepare_entry_batch(&self, txs: Vec<VersionedTransaction>) -> Result<TransactionBatch> {
let sanitized_txs = txs
.into_iter()
.map(|tx| {
SanitizedTransaction::try_create(
tx,
MessageHash::Compute,
None,
self,
self.feature_set
.is_active(&feature_set::require_static_program_ids_in_transaction::ID),
)
})
.map(|tx| SanitizedTransaction::try_create(tx, MessageHash::Compute, None, self))
.collect::<Result<Vec<_>>>()?;
let tx_account_lock_limit = self.get_transaction_account_lock_limit();
let lock_results = self
Expand Down Expand Up @@ -6852,14 +6843,7 @@ impl Bank {
tx.message.hash()
};

SanitizedTransaction::try_create(
tx,
message_hash,
None,
self,
self.feature_set
.is_active(&feature_set::require_static_program_ids_in_transaction::ID),
)
SanitizedTransaction::try_create(tx, message_hash, None, self)
}?;

if verification_mode == TransactionVerificationMode::HashAndVerifyPrecompiles
Expand Down
1 change: 0 additions & 1 deletion runtime/src/cost_tracker.rs
Original file line number Diff line number Diff line change
Expand Up @@ -367,7 +367,6 @@ mod tests {
MessageHash::Compute,
Some(true),
SimpleAddressLoader::Disabled,
true, // require_static_program_ids
)
.unwrap();
let mut tx_cost = TransactionCost::new_with_capacity(1);
Expand Down
4 changes: 2 additions & 2 deletions sdk/program/src/message/versions/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,10 +39,10 @@ pub enum VersionedMessage {
}

impl VersionedMessage {
pub fn sanitize(&self, require_static_program_ids: bool) -> Result<(), SanitizeError> {
pub fn sanitize(&self) -> Result<(), SanitizeError> {
match self {
Self::Legacy(message) => message.sanitize(),
Self::V0(message) => message.sanitize(require_static_program_ids),
Self::V0(message) => message.sanitize(),
}
}

Expand Down
2 changes: 1 addition & 1 deletion sdk/program/src/message/versions/sanitized.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ impl TryFrom<VersionedMessage> for SanitizedVersionedMessage {

impl SanitizedVersionedMessage {
pub fn try_new(message: VersionedMessage) -> Result<Self, SanitizeError> {
message.sanitize(true /* require_static_program_ids */)?;
message.sanitize()?;
Ok(Self { message })
}

Expand Down
78 changes: 20 additions & 58 deletions sdk/program/src/message/versions/v0/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ pub struct Message {

impl Message {
/// Sanitize message fields and compiled instruction indexes
pub fn sanitize(&self, reject_dynamic_program_ids: bool) -> Result<(), SanitizeError> {
pub fn sanitize(&self) -> Result<(), SanitizeError> {
let num_static_account_keys = self.account_keys.len();
if usize::from(self.header.num_required_signatures)
.saturating_add(usize::from(self.header.num_readonly_unsigned_accounts))
Expand Down Expand Up @@ -143,18 +143,15 @@ impl Message {
.checked_sub(1)
.expect("message doesn't contain any account keys");

// switch to rejecting program ids loaded from lookup tables so that
// static analysis on program instructions can be performed without
// loading on-chain data from a bank
let max_program_id_ix = if reject_dynamic_program_ids {
// reject program ids loaded from lookup tables so that
// static analysis on program instructions can be performed
// without loading on-chain data from a bank
let max_program_id_ix =
// `expect` is safe because of earlier check that
// `num_static_account_keys` is non-zero
num_static_account_keys
.checked_sub(1)
.expect("message doesn't contain any static account keys")
} else {
max_account_ix
};
.expect("message doesn't contain any static account keys");

for ci in &self.instructions {
if usize::from(ci.program_id_index) > max_program_id_ix {
Expand Down Expand Up @@ -375,9 +372,7 @@ mod tests {
account_keys: vec![Pubkey::new_unique()],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_ok());
}

Expand All @@ -396,9 +391,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_ok());
}

Expand All @@ -417,9 +410,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_ok());
}

Expand All @@ -444,13 +435,7 @@ mod tests {
..Message::default()
};

assert!(message.sanitize(
false, // require_static_program_ids
).is_ok());

assert!(message.sanitize(
true, // require_static_program_ids
).is_err());
assert!(message.sanitize().is_err());
}

#[test]
Expand All @@ -473,9 +458,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_ok());
}

Expand All @@ -486,9 +469,7 @@ mod tests {
account_keys: vec![Pubkey::new_unique()],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_err());
}

Expand All @@ -503,9 +484,7 @@ mod tests {
account_keys: vec![Pubkey::new_unique()],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_err());
}

Expand All @@ -524,9 +503,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_err());
}

Expand All @@ -540,9 +517,7 @@ mod tests {
account_keys: (0..=u8::MAX).map(|_| Pubkey::new_unique()).collect(),
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_ok());
}

Expand All @@ -556,9 +531,7 @@ mod tests {
account_keys: (0..=256).map(|_| Pubkey::new_unique()).collect(),
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_err());
}

Expand All @@ -577,9 +550,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_ok());
}

Expand All @@ -598,9 +569,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_err());
}

Expand All @@ -625,12 +594,7 @@ mod tests {
..Message::default()
};

assert!(message
.sanitize(true /* require_static_program_ids */)
.is_err());
assert!(message
.sanitize(false /* require_static_program_ids */)
.is_err());
assert!(message.sanitize().is_err());
}

#[test]
Expand All @@ -653,9 +617,7 @@ mod tests {
}],
..Message::default()
}
.sanitize(
true, // require_static_program_ids
)
.sanitize()
.is_err());
}

Expand Down
3 changes: 1 addition & 2 deletions sdk/src/transaction/sanitized.rs
Original file line number Diff line number Diff line change
Expand Up @@ -95,9 +95,8 @@ impl SanitizedTransaction {
message_hash: impl Into<MessageHash>,
is_simple_vote_tx: Option<bool>,
address_loader: impl AddressLoader,
require_static_program_ids: bool,
) -> Result<Self> {
tx.sanitize(require_static_program_ids)?;
tx.sanitize()?;

let message_hash = match message_hash.into() {
MessageHash::Compute => tx.message.hash(),
Expand Down
7 changes: 2 additions & 5 deletions sdk/src/transaction/versioned/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -115,11 +115,8 @@ impl VersionedTransaction {
})
}

pub fn sanitize(
&self,
require_static_program_ids: bool,
) -> std::result::Result<(), SanitizeError> {
self.message.sanitize(require_static_program_ids)?;
pub fn sanitize(&self) -> std::result::Result<(), SanitizeError> {
self.message.sanitize()?;
self.sanitize_signatures()?;
Ok(())
}
Expand Down
Loading

0 comments on commit ee2c2ef

Please sign in to comment.