2019-01-07 09:38:19 -07:00
|
|
|
#![feature(test)]
|
|
|
|
|
|
|
|
extern crate test;
|
|
|
|
|
2019-10-25 21:47:16 -07:00
|
|
|
use log::*;
|
2019-04-02 09:35:38 -06:00
|
|
|
use solana_runtime::message_processor::*;
|
2019-10-25 21:47:16 -07:00
|
|
|
use solana_sdk::{account::Account, pubkey::Pubkey};
|
2019-01-07 09:38:19 -07:00
|
|
|
use test::Bencher;
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_has_duplicates(bencher: &mut Bencher) {
|
|
|
|
bencher.iter(|| {
|
|
|
|
let data = test::black_box([1, 2, 3]);
|
|
|
|
assert!(!has_duplicates(&data));
|
|
|
|
})
|
|
|
|
}
|
2019-10-25 21:47:16 -07:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_verify_instruction_data(bencher: &mut Bencher) {
|
|
|
|
solana_logger::setup();
|
|
|
|
|
|
|
|
let owner = Pubkey::new_rand();
|
|
|
|
let non_owner = Pubkey::new_rand();
|
2019-11-05 10:57:32 -08:00
|
|
|
let pre = PreInstructionAccount::new(
|
|
|
|
&Account::new(0, BUFSIZE, &owner),
|
|
|
|
true,
|
|
|
|
need_account_data_checked(&owner, &owner, true),
|
|
|
|
);
|
2019-10-25 21:47:16 -07:00
|
|
|
let post = Account::new(0, BUFSIZE, &owner);
|
2019-11-05 10:57:32 -08:00
|
|
|
assert_eq!(verify_instruction(&owner, &pre, &post), Ok(()));
|
2019-10-25 21:47:16 -07:00
|
|
|
|
|
|
|
// this one should be faster
|
|
|
|
bencher.iter(|| {
|
2019-11-05 10:57:32 -08:00
|
|
|
verify_instruction(&owner, &pre, &post).unwrap();
|
2019-10-25 21:47:16 -07:00
|
|
|
});
|
|
|
|
let summary = bencher.bench(|_bencher| {}).unwrap();
|
|
|
|
info!("data no change by owner: {} ns/iter", summary.median);
|
|
|
|
|
2019-11-05 10:57:32 -08:00
|
|
|
let pre = PreInstructionAccount::new(
|
|
|
|
&Account::new(0, BUFSIZE, &owner),
|
|
|
|
true,
|
|
|
|
need_account_data_checked(&owner, &non_owner, true),
|
|
|
|
);
|
|
|
|
match pre.data {
|
|
|
|
Some(ref data) => bencher.iter(|| *data == post.data),
|
|
|
|
None => panic!("No data!"),
|
|
|
|
}
|
|
|
|
let summary = bencher.bench(|_bencher| {}).unwrap();
|
|
|
|
info!("data compare {} ns/iter", summary.median);
|
2019-10-25 21:47:16 -07:00
|
|
|
bencher.iter(|| {
|
2019-11-05 10:57:32 -08:00
|
|
|
verify_instruction(&non_owner, &pre, &post).unwrap();
|
2019-10-25 21:47:16 -07:00
|
|
|
});
|
|
|
|
let summary = bencher.bench(|_bencher| {}).unwrap();
|
|
|
|
info!("data no change by non owner: {} ns/iter", summary.median);
|
|
|
|
}
|
|
|
|
|
|
|
|
const BUFSIZE: usize = 1024 * 1024 + 127;
|
|
|
|
static BUF0: [u8; BUFSIZE] = [0; BUFSIZE];
|
|
|
|
static BUF1: [u8; BUFSIZE] = [1; BUFSIZE];
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_is_zeroed(bencher: &mut Bencher) {
|
|
|
|
bencher.iter(|| {
|
|
|
|
is_zeroed(&BUF0);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_is_zeroed_not(bencher: &mut Bencher) {
|
|
|
|
bencher.iter(|| {
|
|
|
|
is_zeroed(&BUF1);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_is_zeroed_by_iter(bencher: &mut Bencher) {
|
|
|
|
bencher.iter(|| BUF0.iter().all(|item| *item == 0));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_is_zeroed_not_by_iter(bencher: &mut Bencher) {
|
|
|
|
bencher.iter(|| BUF1.iter().all(|item| *item == 0));
|
|
|
|
}
|