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

28 lines
662 B
Rust

use libc::pid_t;
use perf_event::Builder;
use perf_event::events::Hardware;
use std::thread::sleep;
use std::time::Duration;
fn main() -> std::io::Result<()> {
let pid: pid_t = std::env::args()
.nth(1)
.expect("Usage: insns-for-pid PID")
.parse()
.expect("Usage: insns-for-pid PID");
let mut insns = Builder::new()
.observe_pid(pid)
.kind(Hardware::BRANCH_INSTRUCTIONS)
.build()?;
// Count instructions in PID for five seconds.
insns.enable()?;
sleep(Duration::from_secs(5));
insns.disable()?;
println!("instructions in last five seconds: {}", insns.read()?);
Ok(())
}