Start working on prefetcher reverse engineering experiment

This commit is contained in:
Guillume DIDIER 2021-03-22 16:13:01 +01:00
parent 0bd575f251
commit 4bc389272f
6 changed files with 61 additions and 0 deletions

View File

@ -39,6 +39,7 @@
<sourceFolder url="file://$MODULE_DIR$/basic_timing_cache_channel/src" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/turn_lock/src" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/covert_channels_benchmark/src" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/prefetcher_reverse/src" isTestSource="false" />
<excludeFolder url="file://$MODULE_DIR$/cache_info/target" />
<excludeFolder url="file://$MODULE_DIR$/cache_utils/target" />
<excludeFolder url="file://$MODULE_DIR$/kernel/target" />

7
Cargo.lock generated
View File

@ -335,6 +335,13 @@ version = "0.2.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c36fa947111f5c62a733b652544dd0016a43ce89619538a8ef92724a6f501a20"
[[package]]
name = "prefetcher_reverse"
version = "0.1.0"
dependencies = [
"cache_utils",
]
[[package]]
name = "rand"
version = "0.7.3"

View File

@ -13,6 +13,7 @@ members = [
"flush_flush",
"basic_timing_cache_channel",
"turn_lock",
"prefetcher_reverse",
]
[package]

View File

@ -0,0 +1,2 @@
[build]
target = "x86_64-unknown-linux-gnu"

View File

@ -0,0 +1,10 @@
[package]
name = "prefetcher_reverse"
version = "0.1.0"
authors = ["Guillume DIDIER <guillaume.didier@inria.fr>"]
edition = "2018"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[dependencies]
cache_utils = { path = "../cache_utils"}

View File

@ -0,0 +1,40 @@
use cache_utils::calibration::PAGE_LEN;
pub const CACHE_LINE_LEN: usize = 64;
fn max_stride(len: usize) -> isize {
if len == 0 {
1
} else {
(PAGE_LEN / (len * CACHE_LINE_LEN)) as isize
}
}
fn generate_pattern(len: usize, stride: isize) -> Vec<isize> {
if (stride * len as isize * CACHE_LINE_LEN as isize).abs() as usize > PAGE_LEN {
panic!("This is illegal");
}
let mut res = Vec::with_capacity(len);
for i in 0..len {
res.push(i as isize * stride * CACHE_LINE_LEN as isize);
}
res
}
fn main() {
/*
TODO List :
Calibration & core selection (select one or two cores with optimal error)
Then allocate a bunch of pages, and do accesses on each of them.
(Let's start with stride patterns : for len in 0..16, and then for stride in 1..maxs_stride(len), generate a vac of addresses and get the victim to execute, then dump all the page)
*/
println!("Hello, world!");
println!("{:?}", generate_pattern(5, 2));
println!("{:?}", generate_pattern(5, 1));
println!("{:?}", generate_pattern(0, 1));
println!("{:?}", generate_pattern(5, 5));
println!("{:?}", generate_pattern(16, 16));
}