* Changes from #580 * fixes USB cancel panic * style fixes * Update src/env/tock/storage.rs Co-authored-by: Zach Halvorsen <zhalvorsen@google.com> --------- Co-authored-by: Zach Halvorsen <zhalvorsen@google.com>
184 lines
5.3 KiB
Rust
184 lines
5.3 KiB
Rust
// Copyright 2019 Google LLC
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
#![no_main]
|
|
#![no_std]
|
|
|
|
extern crate alloc;
|
|
extern crate lang_items;
|
|
|
|
use alloc::format;
|
|
use alloc::vec::Vec;
|
|
use core::fmt::Write;
|
|
use crypto::{aes256, cbc, ecdsa, sha256, Hash256};
|
|
use ctap2::env::tock::TockRng;
|
|
use libtock_console::{Console, ConsoleWriter};
|
|
use libtock_drivers::result::FlexUnwrap;
|
|
use libtock_drivers::timer;
|
|
use libtock_drivers::timer::{Timer, Timestamp};
|
|
use libtock_runtime::{set_main, stack_size, TockSyscalls};
|
|
|
|
stack_size! {0x2000}
|
|
set_main! {main}
|
|
|
|
type Syscalls = TockSyscalls;
|
|
|
|
fn main() {
|
|
let mut console = Console::<Syscalls>::writer();
|
|
// Setup the timer with a dummy callback (we only care about reading the current time, but the
|
|
// API forces us to set an alarm callback too).
|
|
let mut with_callback = timer::with_callback(|_| {});
|
|
let timer = with_callback.init().flex_unwrap();
|
|
|
|
let mut rng = TockRng::<Syscalls>::default();
|
|
|
|
writeln!(console, "****************************************").unwrap();
|
|
writeln!(console, "Clock frequency: {:?} Hz", timer.clock_frequency()).unwrap();
|
|
|
|
// AES
|
|
bench(&mut console, &timer, "aes256::EncryptionKey::new", || {
|
|
aes256::EncryptionKey::new(&[0; 32]);
|
|
});
|
|
let ek = aes256::EncryptionKey::new(&[0; 32]);
|
|
bench(&mut console, &timer, "aes256::DecryptionKey::new", || {
|
|
aes256::DecryptionKey::new(&ek);
|
|
});
|
|
let dk = aes256::DecryptionKey::new(&ek);
|
|
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
"aes256::EncryptionKey::encrypt_block",
|
|
|| {
|
|
ek.encrypt_block(&mut [0; 16]);
|
|
},
|
|
);
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
"aes256::DecryptionKey::decrypt_block",
|
|
|| {
|
|
dk.decrypt_block(&mut [0; 16]);
|
|
},
|
|
);
|
|
|
|
// CBC
|
|
let mut blocks = Vec::new();
|
|
for i in 0..8 {
|
|
blocks.resize(1 << (i + 4), 0);
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
&format!("cbc::cbc_encrypt({} bytes)", blocks.len()),
|
|
|| {
|
|
cbc::cbc_encrypt(&ek, [0; 16], &mut blocks);
|
|
},
|
|
);
|
|
}
|
|
drop(blocks);
|
|
|
|
let mut blocks = Vec::new();
|
|
for i in 0..8 {
|
|
blocks.resize(1 << (i + 4), 0);
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
&format!("cbc::cbc_decrypt({} bytes)", blocks.len()),
|
|
|| {
|
|
cbc::cbc_decrypt(&dk, [0; 16], &mut blocks);
|
|
},
|
|
);
|
|
}
|
|
drop(blocks);
|
|
|
|
// SHA-256
|
|
let mut contents = Vec::new();
|
|
for i in 0..8 {
|
|
contents.resize(16 << i, 0);
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
&format!("sha256::Sha256::update({} bytes)", contents.len()),
|
|
|| {
|
|
let mut sha = sha256::Sha256::new();
|
|
sha.update(&contents);
|
|
let mut dummy_hash = [0; 32];
|
|
sha.finalize(&mut dummy_hash);
|
|
},
|
|
);
|
|
}
|
|
drop(contents);
|
|
|
|
// ECDSA
|
|
bench(&mut console, &timer, "ecdsa::SecKey::gensk", || {
|
|
ecdsa::SecKey::gensk(&mut rng);
|
|
});
|
|
let k = ecdsa::SecKey::gensk(&mut rng);
|
|
bench(&mut console, &timer, "ecdsa::SecKey::genpk", || {
|
|
k.genpk();
|
|
});
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
"ecdsa::SecKey::sign_rng::<sha256::Sha256, _>",
|
|
|| {
|
|
k.sign_rng::<sha256::Sha256, _>(&[], &mut rng);
|
|
},
|
|
);
|
|
bench(
|
|
&mut console,
|
|
&timer,
|
|
"ecdsa::SecKey::sign_rfc6979::<sha256::Sha256>",
|
|
|| {
|
|
k.sign_rfc6979::<sha256::Sha256>(&[]);
|
|
},
|
|
);
|
|
|
|
writeln!(console, "****************************************").unwrap();
|
|
writeln!(console, "All the benchmarks are done.\nHave a nice day!").unwrap();
|
|
writeln!(console, "****************************************").unwrap();
|
|
}
|
|
|
|
fn bench<F>(console: &mut ConsoleWriter<Syscalls>, timer: &Timer<Syscalls>, title: &str, mut f: F)
|
|
where
|
|
F: FnMut(),
|
|
{
|
|
writeln!(console, "****************************************").unwrap();
|
|
writeln!(console, "Benchmarking: {}", title).unwrap();
|
|
writeln!(console, "----------------------------------------").unwrap();
|
|
let mut count = 1;
|
|
for _ in 0..30 {
|
|
let start =
|
|
Timestamp::<f64>::from_clock_value(timer.get_current_counter_ticks().flex_unwrap());
|
|
for _ in 0..count {
|
|
f();
|
|
}
|
|
let end =
|
|
Timestamp::<f64>::from_clock_value(timer.get_current_counter_ticks().flex_unwrap());
|
|
let elapsed = (end - start).ms();
|
|
writeln!(
|
|
console,
|
|
"{} ms elapsed for {} iterations ({} ms/iter)",
|
|
elapsed,
|
|
count,
|
|
elapsed / (count as f64)
|
|
)
|
|
.unwrap();
|
|
if elapsed > 1000.0 {
|
|
break;
|
|
}
|
|
count <<= 1;
|
|
}
|
|
}
|