Some more optimizations by avoiding coping

This commit is contained in:
Godmode Galactus 2024-11-26 09:28:17 +01:00
parent e28a3101c9
commit bc1c8c75ec
No known key found for this signature in database
GPG Key ID: A6B75566742EA987
4 changed files with 25 additions and 16 deletions

View File

@ -65,9 +65,7 @@ impl AccountDataByCommitment {
Commitment::Finalized => self.finalized_account.as_ref(), Commitment::Finalized => self.finalized_account.as_ref(),
}; };
let Some(account_data) = account_data else { let account_data = account_data?;
return None;
};
// check size filter first before decompressing // check size filter first before decompressing
for filter in filters { for filter in filters {

View File

@ -313,13 +313,13 @@ impl AccountStorageInterface for InmemoryAccountStore {
let mut return_vec = vec![]; let mut return_vec = vec![];
let store_read_lk = self.accounts_store.read().unwrap(); let store_read_lk = self.accounts_store.read().unwrap();
let mut retry_list = BTreeSet::new(); let mut retry_list = Vec::with_capacity(128);
// optimization to avoid locking for each account // optimization to avoid locking for each account
for program_account_index in lk.read().unwrap().iter() { for program_account_index in lk.read().unwrap().iter() {
let lk_on_account = match store_read_lk[*program_account_index].try_read() { let lk_on_account = match store_read_lk[*program_account_index].try_read() {
Ok(lk) => lk, Ok(lk) => lk,
Err(_) => { Err(_) => {
retry_list.insert(*program_account_index); retry_list.push(*program_account_index);
continue; continue;
} }
}; };
@ -331,7 +331,6 @@ impl AccountStorageInterface for InmemoryAccountStore {
&account_filters, &account_filters,
); );
} }
// retry for the accounts which were locked // retry for the accounts which were locked
for retry_account_index in retry_list { for retry_account_index in retry_list {
let lk_on_account = store_read_lk[retry_account_index].read().unwrap(); let lk_on_account = store_read_lk[retry_account_index].read().unwrap();

View File

@ -34,15 +34,27 @@ impl MemcmpFilter {
} }
pub fn bytes_match(&self, data: &[u8]) -> bool { pub fn bytes_match(&self, data: &[u8]) -> bool {
let bytes = self.bytes(); // optimize for bytes / avoid copying
let offset = self.offset as usize; if let MemcmpFilterData::Bytes(bytes) = &self.data {
if offset > data.len() { let offset = self.offset as usize;
return false; if offset > data.len() {
return false;
}
if data[offset..].len() < bytes.len() {
return false;
}
data[offset..offset + bytes.len()] == bytes[..]
} else {
let bytes = self.bytes();
let offset = self.offset as usize;
if offset > data.len() {
return false;
}
if data[offset..].len() < bytes.len() {
return false;
}
data[offset..offset + bytes.len()] == bytes[..]
} }
if data[offset..].len() < bytes.len() {
return false;
}
data[offset..offset + bytes.len()] == bytes[..]
} }
} }

View File

@ -1,2 +1,2 @@
cargo +nightly-2023-10-05 fmt --all cargo +1.78.0 fmt --all
cargo +nightly-2023-10-05 clippy --locked --workspace --all-targets -- -D warnings cargo +1.78.0 clippy --locked --workspace --all-targets -- -D warnings