2019-01-07 11:33:07 +01:00
|
|
|
// Copyright 2015-2019 Parity Technologies (UK) Ltd.
|
|
|
|
// This file is part of Parity Ethereum.
|
2018-11-06 14:22:44 +01:00
|
|
|
|
2019-01-07 11:33:07 +01:00
|
|
|
// Parity Ethereum is free software: you can redistribute it and/or modify
|
2018-11-06 14:22:44 +01:00
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
|
2019-01-07 11:33:07 +01:00
|
|
|
// Parity Ethereum is distributed in the hope that it will be useful,
|
2018-11-06 14:22:44 +01:00
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU General Public License
|
2019-01-07 11:33:07 +01:00
|
|
|
// along with Parity Ethereum. If not, see <http://www.gnu.org/licenses/>.
|
2018-11-06 14:22:44 +01:00
|
|
|
|
|
|
|
#[macro_use]
|
|
|
|
extern crate criterion;
|
|
|
|
extern crate ethash;
|
2019-08-23 15:32:58 +02:00
|
|
|
extern crate common_types;
|
2018-11-06 14:22:44 +01:00
|
|
|
|
|
|
|
use criterion::Criterion;
|
2019-09-24 11:45:28 +02:00
|
|
|
use ethash::{NodeCacheBuilder, keccak};
|
2019-08-23 15:32:58 +02:00
|
|
|
use common_types::engines::OptimizeFor;
|
2018-11-06 14:22:44 +01:00
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
const HASH: [u8; 32] = [
|
|
|
|
0xf5, 0x7e, 0x6f, 0x3a, 0xcf, 0xc0, 0xdd, 0x4b,
|
|
|
|
0x5b, 0xf2, 0xbe, 0xe4, 0x0a, 0xb3, 0x35, 0x8a,
|
|
|
|
0xa6, 0x87, 0x73, 0xa8, 0xd0, 0x9f, 0x5e, 0x59,
|
|
|
|
0x5e, 0xab, 0x55, 0x94, 0x05, 0x52, 0x7d, 0x72,
|
|
|
|
];
|
|
|
|
const MIX_HASH: [u8; 32] = [
|
|
|
|
0x1f, 0xff, 0x04, 0xce, 0xc9, 0x41, 0x73, 0xfd,
|
|
|
|
0x59, 0x1e, 0x3d, 0x89, 0x60, 0xce, 0x6b, 0xdf,
|
|
|
|
0x8b, 0x19, 0x71, 0x04, 0x8c, 0x71, 0xff, 0x93,
|
|
|
|
0x7b, 0xb2, 0xd3, 0x2a, 0x64, 0x31, 0xab, 0x6d,
|
|
|
|
];
|
2018-11-06 14:22:44 +01:00
|
|
|
const NONCE: u64 = 0xd7b3ac70a301a249;
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
criterion_group! {
|
|
|
|
name = basic;
|
|
|
|
config = dont_take_an_eternity_to_run();
|
2019-09-24 11:45:28 +02:00
|
|
|
targets = bench_keccak_512_inplace,
|
|
|
|
bench_light_compute_memmap,
|
2019-07-12 10:04:41 +02:00
|
|
|
bench_light_compute_memory,
|
|
|
|
bench_light_new_round_trip_memmap,
|
|
|
|
bench_light_new_round_trip_memory,
|
|
|
|
bench_light_from_file_round_trip_memory,
|
|
|
|
bench_light_from_file_round_trip_memmap,
|
|
|
|
bench_quick_get_difficulty,
|
|
|
|
}
|
2018-11-06 14:22:44 +01:00
|
|
|
criterion_main!(basic);
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
fn dont_take_an_eternity_to_run() -> Criterion {
|
|
|
|
Criterion::default().nresamples(1_000)
|
|
|
|
.without_plots()
|
|
|
|
.sample_size(10)
|
|
|
|
}
|
|
|
|
|
2019-09-24 11:45:28 +02:00
|
|
|
fn bench_keccak_512_inplace(b: &mut Criterion) {
|
|
|
|
b.bench_function("bench_keccak_512_inplace", move |b| b.iter(|| {
|
|
|
|
let mut data = [4u8; 64];
|
|
|
|
keccak::keccak_512::inplace(&mut data);
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
2018-11-06 14:22:44 +01:00
|
|
|
fn bench_light_compute_memmap(b: &mut Criterion) {
|
|
|
|
use std::env;
|
|
|
|
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Memory, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let light = builder.light(&env::temp_dir(), 486382);
|
|
|
|
|
2019-02-20 10:05:11 +01:00
|
|
|
b.bench_function("bench_light_compute_memmap", move |b| b.iter(|| light.compute(&HASH, NONCE, u64::max_value())));
|
2018-11-06 14:22:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
fn bench_light_compute_memory(b: &mut Criterion) {
|
|
|
|
use std::env;
|
|
|
|
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Cpu, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let light = builder.light(&env::temp_dir(), 486382);
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
b.bench_function("bench_light_compute_memory", move |b| b.iter(|| light.compute(&HASH, NONCE, u64::max_value())));
|
2018-11-06 14:22:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
fn bench_light_new_round_trip_memmap(b: &mut Criterion) {
|
|
|
|
use std::env;
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
b.bench_function("bench_light_new_round_trip_memmap", move |b| b.iter(|| {
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Memory, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let light = builder.light(&env::temp_dir(), 486382);
|
2019-02-20 10:05:11 +01:00
|
|
|
light.compute(&HASH, NONCE, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn bench_light_new_round_trip_memory(b: &mut Criterion) {
|
|
|
|
use std::env;
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
b.bench_function("bench_light_new_round_trip_memory", move |b| b.iter(|| {
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Cpu, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let light = builder.light(&env::temp_dir(), 486382);
|
2019-02-20 10:05:11 +01:00
|
|
|
light.compute(&HASH, NONCE, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn bench_light_from_file_round_trip_memory(b: &mut Criterion) {
|
|
|
|
use std::env;
|
|
|
|
|
|
|
|
let dir = env::temp_dir();
|
|
|
|
let height = 486382;
|
|
|
|
{
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Cpu, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let mut dummy = builder.light(&dir, height);
|
|
|
|
dummy.to_file().unwrap();
|
|
|
|
}
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
b.bench_function("bench_light_from_file_round_trip_memory", move |b| b.iter(|| {
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Cpu, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let light = builder.light_from_file(&dir, 486382).unwrap();
|
2019-02-20 10:05:11 +01:00
|
|
|
light.compute(&HASH, NONCE, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
fn bench_light_from_file_round_trip_memmap(b: &mut Criterion) {
|
|
|
|
use std::env;
|
|
|
|
|
|
|
|
let dir = env::temp_dir();
|
|
|
|
let height = 486382;
|
|
|
|
|
|
|
|
{
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Memory, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let mut dummy = builder.light(&dir, height);
|
|
|
|
dummy.to_file().unwrap();
|
|
|
|
}
|
|
|
|
|
2019-07-12 10:04:41 +02:00
|
|
|
b.bench_function("bench_light_from_file_round_trip_memmap", move |b| b.iter(|| {
|
2019-02-20 10:05:11 +01:00
|
|
|
let builder = NodeCacheBuilder::new(OptimizeFor::Memory, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
let light = builder.light_from_file(&dir, 486382).unwrap();
|
2019-02-20 10:05:11 +01:00
|
|
|
light.compute(&HASH, NONCE, u64::max_value());
|
2018-11-06 14:22:44 +01:00
|
|
|
}));
|
|
|
|
}
|
2019-07-12 10:04:41 +02:00
|
|
|
|
|
|
|
fn bench_quick_get_difficulty(b: &mut Criterion) {
|
|
|
|
b.bench_function("bench_quick_get_difficulty", move |b| b.iter(|| {
|
|
|
|
let d = ethash::quick_get_difficulty(&HASH, NONCE, &MIX_HASH, false);
|
|
|
|
let boundary_good = [
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x3e, 0x9b, 0x6c, 0x69, 0xbc, 0x2c, 0xe2, 0xa2,
|
|
|
|
0x4a, 0x8e, 0x95, 0x69, 0xef, 0xc7, 0xd7, 0x1b, 0x33, 0x35, 0xdf, 0x36, 0x8c, 0x9a,
|
|
|
|
0xe9, 0x7e, 0x53, 0x84,
|
|
|
|
];
|
|
|
|
assert_eq!(d[..], boundary_good[..]);
|
|
|
|
}));
|
|
|
|
}
|