2020-03-09 12:10:41 +01:00
|
|
|
// TODO create a nice program that can run on a system and will do the calibration.
|
2020-03-12 14:20:06 +01:00
|
|
|
// Calibration has to be sequential
|
|
|
|
// Will pin on each core one after the other
|
|
|
|
|
|
|
|
//fn execute_on_core(FnOnce)
|
|
|
|
|
|
|
|
#![feature(vec_resize_default)]
|
|
|
|
|
|
|
|
use cache_utils::calibration::calibrate_flush;
|
|
|
|
use cache_utils::calibration::Verbosity;
|
|
|
|
|
|
|
|
use nix::errno::Errno;
|
|
|
|
use nix::sched::{sched_getaffinity, sched_setaffinity, CpuSet};
|
|
|
|
use nix::unistd::Pid;
|
|
|
|
use nix::Error::Sys;
|
|
|
|
|
2020-04-03 11:24:54 +02:00
|
|
|
use cache_utils::mmap::MMappedMemory;
|
2020-03-18 14:30:16 +01:00
|
|
|
|
|
|
|
/* from linux kernel headers.
|
|
|
|
#define HUGETLB_FLAG_ENCODE_SHIFT 26
|
|
|
|
#define HUGETLB_FLAG_ENCODE_MASK 0x3f
|
|
|
|
|
|
|
|
#define HUGETLB_FLAG_ENCODE_64KB (16 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
#define HUGETLB_FLAG_ENCODE_512KB (19 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
#define HUGETLB_FLAG_ENCODE_1MB (20 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
#define HUGETLB_FLAG_ENCODE_2MB (21 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
*/
|
|
|
|
|
|
|
|
const SIZE: usize = 2 << 20;
|
|
|
|
/*
|
2020-03-12 14:20:06 +01:00
|
|
|
#[repr(align(4096))]
|
|
|
|
struct Page {
|
|
|
|
pub mem: [u8; 4096],
|
|
|
|
}
|
2020-03-18 14:30:16 +01:00
|
|
|
*/
|
2020-03-09 14:27:32 +01:00
|
|
|
pub fn main() {
|
2020-04-07 14:25:13 +02:00
|
|
|
let m = MMappedMemory::new(SIZE);
|
2020-04-03 11:24:54 +02:00
|
|
|
let array = m.slice();
|
2020-04-06 11:13:12 +02:00
|
|
|
|
2020-03-12 14:20:06 +01:00
|
|
|
let old = sched_getaffinity(Pid::from_raw(0)).unwrap();
|
|
|
|
|
2020-04-07 10:13:38 +02:00
|
|
|
// Let's grab all the list of CPUS
|
|
|
|
// Then iterate the calibration on each CPU core.
|
2020-05-01 10:24:15 +02:00
|
|
|
eprint!("Warming up...");
|
|
|
|
for i in 0..(CpuSet::count() - 1) {
|
|
|
|
if old.is_set(i).unwrap() {
|
|
|
|
//println!("Iteration {}...", i);
|
|
|
|
let mut core = CpuSet::new();
|
|
|
|
core.set(i).unwrap();
|
|
|
|
|
|
|
|
match sched_setaffinity(Pid::from_raw(0), &core) {
|
|
|
|
Ok(()) => {
|
|
|
|
calibrate_flush(array, 64, Verbosity::NoOutput);
|
|
|
|
sched_setaffinity(Pid::from_raw(0), &old).unwrap();
|
|
|
|
//println!("Iteration {}...ok ", i);
|
|
|
|
eprint!(" {}", i);
|
|
|
|
}
|
|
|
|
Err(Sys(Errno::EINVAL)) => {
|
|
|
|
//println!("skipping");
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
Err(e) => {
|
|
|
|
panic!("Unexpected error while setting affinity: {}", e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
eprintln!();
|
2020-03-12 14:20:06 +01:00
|
|
|
for i in 0..(CpuSet::count() - 1) {
|
|
|
|
if old.is_set(i).unwrap() {
|
|
|
|
println!("Iteration {}...", i);
|
|
|
|
let mut core = CpuSet::new();
|
|
|
|
core.set(i).unwrap();
|
|
|
|
|
|
|
|
match sched_setaffinity(Pid::from_raw(0), &core) {
|
|
|
|
Ok(()) => {
|
2020-04-03 11:24:54 +02:00
|
|
|
calibrate_flush(array, 64, Verbosity::NoOutput);
|
2020-05-01 10:24:15 +02:00
|
|
|
calibrate_flush(array, 64, Verbosity::RawResult);
|
2020-03-12 14:20:06 +01:00
|
|
|
sched_setaffinity(Pid::from_raw(0), &old).unwrap();
|
|
|
|
println!("Iteration {}...ok ", i);
|
2020-03-20 16:09:03 +01:00
|
|
|
eprintln!("Iteration {}...ok ", i);
|
2020-03-12 14:20:06 +01:00
|
|
|
}
|
|
|
|
Err(Sys(Errno::EINVAL)) => {
|
|
|
|
println!("skipping");
|
|
|
|
continue;
|
|
|
|
}
|
2020-04-01 16:31:06 +02:00
|
|
|
Err(e) => {
|
|
|
|
panic!("Unexpected error while setting affinity: {}", e);
|
2020-03-12 14:20:06 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-03-09 14:27:32 +01:00
|
|
|
}
|