From 5781e9391fe3d7d3dabec620cb782d38f5f9cb9e Mon Sep 17 00:00:00 2001 From: Brian Cully Date: Fri, 10 May 2019 11:50:53 -0400 Subject: Update to 0.2.0: Add HandlerArray type. * Create HandlerArray as a safe wrapper around Handler. * Add Cargo features for HandlerArray size. * Move Handler into sub-module. * Add CriticalSection sub-module for architecture dependent support of interrupt-free contexts. * Add build rules to pull in cortex-m support for CriticalSection automatically. --- benches/handler-call.rs | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100755 benches/handler-call.rs (limited to 'benches') diff --git a/benches/handler-call.rs b/benches/handler-call.rs new file mode 100755 index 0000000..9a9edec --- /dev/null +++ b/benches/handler-call.rs @@ -0,0 +1,32 @@ +#![feature(test)] + +extern crate test; +use test::Bencher; + +use clint::Handler; + +const ITER_COUNT: usize = 10_000; + +#[bench] +fn bench_bare_fn(b: &mut Bencher) { + static mut X: usize = 0; + #[inline(never)] + fn inc() { + unsafe { X += 1 }; + } + + let n = test::black_box(ITER_COUNT); + b.iter(|| (0..n).for_each(|_| inc())); + assert!(unsafe { X } > 0); +} + +#[bench] +fn bench_handler(b: &mut Bencher) { + static mut X: usize = 0; + let mut handler = Handler::new(); + unsafe { handler.replace(&move || X += 1) }; + + let n = test::black_box(ITER_COUNT); + b.iter(|| (0..n).for_each(|_| unsafe { handler.call() })); + assert!(unsafe { X } > 0); +} -- cgit v1.2.3