use perf_event::events::{Cache, CacheId, CacheOp, CacheResult, Hardware};
use perf_event::{Builder, Group};
fn main() -> std::io::Result<()> {
const ACCESS: Cache = Cache {
which: CacheId::L1D,
operation: CacheOp::READ,
result: CacheResult::ACCESS,
};
const MISS: Cache = Cache {
result: CacheResult::MISS,
..ACCESS
};
let mut group = Group::new()?;
let access_counter = group.add(&Builder::new(ACCESS))?;
let miss_counter = group.add(&Builder::new(MISS))?;
let branches = group.add(&Builder::new(Hardware::BRANCH_INSTRUCTIONS))?;
let missed_branches = group.add(&Builder::new(Hardware::BRANCH_MISSES))?;
let vec = (0..=51).collect::<Vec<_>>();
group.enable()?;
println!("{:?}", vec);
group.disable()?;
let counts = group.read()?;
println!(
"L1D cache misses/references: {} / {} ({:.0}%)",
counts[&miss_counter],
counts[&access_counter],
(counts[&miss_counter] as f64 / counts[&access_counter] as f64) * 100.0
);
println!(
"branch prediction misses/total: {} / {} ({:.0}%)",
counts[&missed_branches],
counts[&branches],
(counts[&missed_branches] as f64 / counts[&branches] as f64) * 100.0
);
for entry in &counts {
println!("Counter id {} has value {}", entry.id(), entry.value());
}
Ok(())
}