Start working on cache detection using Clementine Maurice's performance counter approach.
Add a new crate for that, getting out of cache_utils no_std / use_std mess.
This commit is contained in:
parent
a20210e5d7
commit
f9217b00c4
4
Cargo.lock
generated
4
Cargo.lock
generated
@ -112,6 +112,10 @@ dependencies = [
|
|||||||
"nix 0.28.0",
|
"nix 0.28.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "cache_slice"
|
||||||
|
version = "0.1.0"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "cache_utils"
|
name = "cache_utils"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
|
@ -15,5 +15,6 @@ members = [
|
|||||||
"basic_timing_cache_channel",
|
"basic_timing_cache_channel",
|
||||||
"turn_lock",
|
"turn_lock",
|
||||||
"CacheObserver",
|
"CacheObserver",
|
||||||
"dendrobates-t-azureus"
|
"dendrobates-t-azureus",
|
||||||
]
|
"cache_slice",
|
||||||
|
]
|
||||||
|
6
cache_slice/Cargo.toml
Normal file
6
cache_slice/Cargo.toml
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
[package]
|
||||||
|
name = "cache_slice"
|
||||||
|
version = "0.1.0"
|
||||||
|
edition = "2021"
|
||||||
|
|
||||||
|
[dependencies]
|
24
cache_slice/src/bin/rdmsr.rs
Normal file
24
cache_slice/src/bin/rdmsr.rs
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
use cache_slice::msr;
|
||||||
|
use std::env;
|
||||||
|
fn main() {
|
||||||
|
let mut args = env::args().into_iter();
|
||||||
|
args.next();
|
||||||
|
for arg in args {
|
||||||
|
match arg.parse::<u32>() {
|
||||||
|
Ok(msr) => {
|
||||||
|
match msr::read_msr_on_cpu(msr, 0) {
|
||||||
|
Ok(result) => {
|
||||||
|
println!("MSR {}: {:x}", msr, result);
|
||||||
|
},
|
||||||
|
Err(e) => {
|
||||||
|
eprintln!("Error, failed to read MSR {}: {}", msr, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Err(e) => {
|
||||||
|
eprintln!("Error: {}", e);
|
||||||
|
eprintln!("{} is not a valid MSR number", arg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
16
cache_slice/src/lib.rs
Normal file
16
cache_slice/src/lib.rs
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
pub mod msr;
|
||||||
|
|
||||||
|
pub fn add(left: u64, right: u64) -> u64 {
|
||||||
|
left + right
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn it_works() {
|
||||||
|
let result = add(2, 2);
|
||||||
|
assert_eq!(result, 4);
|
||||||
|
}
|
||||||
|
}
|
42
cache_slice/src/msr.rs
Normal file
42
cache_slice/src/msr.rs
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
use core::mem::size_of;
|
||||||
|
use std::format;
|
||||||
|
use std::fs::{File, OpenOptions};
|
||||||
|
use std::os::unix::fs::FileExt;
|
||||||
|
use std::io::{Result, Error, ErrorKind};
|
||||||
|
|
||||||
|
pub fn write_msr_on_cpu(msr: u32, cpu: u8, value: u64) -> Result<()> {
|
||||||
|
let path = format!("/dev/cpu/{}/msr", cpu);
|
||||||
|
let file : File = OpenOptions::new().write(true).open(path).expect("Failed to open MSR, are you running as root ?");
|
||||||
|
match file.write_at(&value.to_ne_bytes(), msr as u64) {
|
||||||
|
Ok(size) => {
|
||||||
|
if size == size_of::<u64>() {
|
||||||
|
Ok(())
|
||||||
|
} else {
|
||||||
|
Err(Error::other("Failed to write complete value"))
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Err(e) => Err(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn read_msr_on_cpu(msr: u32, cpu: u8) -> Result<u64> {
|
||||||
|
let path = format!("/dev/cpu/{}/msr", cpu);
|
||||||
|
let file : File = OpenOptions::new().read(true).open(path).expect("Failed to open MSR, are you running as root ?");
|
||||||
|
let mut read_data = [0u8; size_of::<u64>()];
|
||||||
|
match file.read_at(&mut read_data, msr as u64) {
|
||||||
|
Ok(size) => {
|
||||||
|
if size == size_of::<u64>() {
|
||||||
|
Ok(u64::from_ne_bytes(read_data))
|
||||||
|
} else {
|
||||||
|
Err(Error::other("Failed to write complete value"))
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Err(e) => Err(e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
// TODO how can we test model specific register read / write ?
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user