rustc/vendor/perf-event-0.4.7/examples/println-cpi.rs
2024-06-24 14:48:22 +02:00

23 lines
667 B
Rust

fn main() -> std::io::Result<()> {
use perf_event::{Builder, Group};
use perf_event::events::Hardware;
let mut group = Group::new()?;
let cycles = Builder::new().group(&mut group).kind(Hardware::CPU_CYCLES).build()?;
let insns = Builder::new().group(&mut group).kind(Hardware::INSTRUCTIONS).build()?;
let vec = (0..=51).collect::<Vec<_>>();
group.enable()?;
println!("{:?}", vec);
group.disable()?;
let counts = group.read()?;
println!("cycles / instructions: {} / {} ({:.2} cpi)",
counts[&cycles],
counts[&insns],
(counts[&cycles] as f64 / counts[&insns] as f64));
Ok(())
}