Reproduce the pattern from the other paper

This commit is contained in:
Guillume DIDIER 2021-07-25 10:01:41 +02:00
parent 3f0f12d118
commit 84cf28f21c
3 changed files with 66 additions and 2 deletions

View File

@ -149,7 +149,7 @@ impl<T: TimingChannelPrimitives> NaiveTimingChannel<T> {
addresses: &mut Vec<&mut NaiveTimingChannelHandle>, addresses: &mut Vec<&mut NaiveTimingChannelHandle>,
limit: u32, limit: u32,
) -> Result<(), SideChannelError> { ) -> Result<(), SideChannelError> {
// Iterate on addresse prparig them, error early exit // Iterate on addresses preparing them, error early exit
let mut i = 0; let mut i = 0;
for handle in addresses { for handle in addresses {
match unsafe { self.prepare_one_impl(handle) } { match unsafe { self.prepare_one_impl(handle) } {

View File

@ -0,0 +1,37 @@
#![deny(unsafe_op_in_unsafe_fn)]
use basic_timing_cache_channel::TopologyAwareError;
use cache_side_channel::CacheStatus::Hit;
use cache_side_channel::{
set_affinity, ChannelHandle, CoreSpec, MultipleAddrCacheSideChannel, SingleAddrCacheSideChannel,
};
use cache_utils::calibration::PAGE_LEN;
use cache_utils::maccess;
use cache_utils::mmap;
use cache_utils::mmap::MMappedMemory;
use flush_flush::{FFHandle, FFPrimitives, FlushAndFlush};
use nix::Error;
use prefetcher_reverse::{reference_patterns, Prober, CACHE_LINE_LEN, PAGE_CACHELINE_LEN};
use rand::seq::SliceRandom;
use std::iter::Cycle;
use std::ops::Range;
pub const NUM_ITERATION: usize = 1 << 10;
pub const NUM_PAGES: usize = 256;
fn exp(delay: u64) {
for (name, pattern) in reference_patterns() {
let mut prober = Prober::new(63).unwrap();
prober.set_delay(delay);
println!("{}", name);
let result = prober.full_page_probe(pattern, NUM_ITERATION as u32, 100);
println!("{}", result);
}
}
fn main() {
for delay in [0, 5, 10, 50] {
println!("Delay after each access: {} us", delay);
exp(delay);
}
}

View File

@ -16,6 +16,7 @@ use rand::seq::SliceRandom;
use std::fmt::{Display, Error, Formatter}; use std::fmt::{Display, Error, Formatter};
use std::iter::{Cycle, Peekable}; use std::iter::{Cycle, Peekable};
use std::ops::Range; use std::ops::Range;
use std::{thread, time};
// NB these may need to be changed / dynamically measured. // NB these may need to be changed / dynamically measured.
pub const CACHE_LINE_LEN: usize = 64; pub const CACHE_LINE_LEN: usize = 64;
@ -30,6 +31,7 @@ pub struct Prober {
ff_channel: FlushAndFlush, ff_channel: FlushAndFlush,
fr_channel: FlushAndReload, fr_channel: FlushAndReload,
//fr_channel: NaiveFlushAndReload, //fr_channel: NaiveFlushAndReload,
delay: u64,
} }
#[derive(Debug, Clone, Copy, PartialEq, Eq)] #[derive(Debug, Clone, Copy, PartialEq, Eq)]
@ -133,6 +135,9 @@ fn max_stride(offset: usize, len: usize) -> (isize, isize) {
} }
impl Prober { impl Prober {
// turn page into page groups, which can vary in size.
// calibrate on all pages in a group with offsets within the groups.
// keep track of the max offset
pub fn new(num_pages: usize) -> Result<Prober, ProberError> { pub fn new(num_pages: usize) -> Result<Prober, ProberError> {
let mut vec = Vec::new(); let mut vec = Vec::new();
let mut handles = Vec::new(); let mut handles = Vec::new();
@ -195,9 +200,14 @@ impl Prober {
page_indexes, page_indexes,
ff_channel, ff_channel,
fr_channel, fr_channel,
delay: 0,
}) })
} }
pub fn set_delay(&mut self, delay: u64) {
self.delay = delay;
}
/* /*
fn probe(&mut self, probe_type: Probe, offset: usize) -> CacheStatus { fn probe(&mut self, probe_type: Probe, offset: usize) -> CacheStatus {
let page_index = self.page_indexes.peek().unwrap(); let page_index = self.page_indexes.peek().unwrap();
@ -234,7 +244,10 @@ impl Prober {
let mut pattern_res = vec![CacheStatus::Miss; pattern.pattern.len()]; let mut pattern_res = vec![CacheStatus::Miss; pattern.pattern.len()];
for (i, offset) in pattern.pattern.iter().enumerate() { for (i, offset) in pattern.pattern.iter().enumerate() {
let h = &mut self.fr_handles[page_index][*offset]; let h = &mut self.fr_handles[page_index][*offset];
pattern_res[i] = unsafe { self.fr_channel.test_single(h, false) }.unwrap() pattern_res[i] = unsafe { self.fr_channel.test_single(h, false) }.unwrap();
if self.delay > 0 {
thread::sleep(time::Duration::from_nanos(self.delay)); // FIXME parameter magic
}
//pattern_res[i] = unsafe { self.fr_channel.test_single(h, false) }.unwrap() //pattern_res[i] = unsafe { self.fr_channel.test_single(h, false) }.unwrap()
//pattern_res[i] = Miss; //pattern_res[i] = Miss;
//unsafe { only_reload(h.to_const_u8_pointer()) }; //unsafe { only_reload(h.to_const_u8_pointer()) };
@ -500,3 +513,17 @@ impl Display for FullPageDualProbeResults {
write!(f, "Num_iteration: {}", self.num_iteration) write!(f, "Num_iteration: {}", self.num_iteration)
} }
} }
pub fn reference_patterns() -> [(&'static str, Vec<usize>); 9] {
[
("Pattern 1", vec![0, 1, 2, 3]),
("Pattern 2", vec![0, 1]),
("Pattern 3", vec![0, 19]),
("Pattern 4 (I)", vec![0, 1, 2, 44]),
("Pattern 4 (II)", vec![63, 62, 61, 19]),
("Pattern 5 (I)", vec![0, 1, 2, 63, 62, 44]),
("Pattern 5 (II)", vec![63, 62, 61, 0, 1, 2, 19]),
("Pattern 5 (III)", vec![63, 62, 61, 0, 1, 2, 44]),
("Pattern 5 (IV)", vec![0, 1, 2, 63, 62, 61, 19]),
]
}