Skip to content

RecoderChris/Profile-Guided-Software-Prefetching

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Profile-Guided-Software-Prefetching

Description

APT-GET is a novel profile-guided technique that ensures prefetch timeliness by leveraging dynamic execution time information. In this page, we provide the profile guided software prefetching LLVM pass code for indirect memory access patterns that is designed for APT-GET. You can also find scripts and python codes that you need to run the experiments.

Instructions

How to run APT-GET (as an example for CRONO benchmarks)

  1. First you need to clone the APT-GET git-repository.
  2. You should create a "results" folder besides the other folders.
  3. You need to set the required PATHs in "run-CRONO-benchmarks.sh".
  4. You can get CRONO benchmark suite fro "https://github.com/masabahmad/CRONO" and set the path to its "app" folder.
  5. You can get the input graphs from SNAP website: "http://snap.stanford.edu/data/web-Google.html". (You can get the other benchmarks in the paper from "https://github.com/SamAinsworth/reproduce-cgo2017-paper/tree/master/program".)
  6. run "./scripts/run-CRONO-benchmarks.sh".

APT-GET Paper link

Here is the link to the paper: https://dl.acm.org/doi/abs/10.1145/3492321.3519583

Please cite APT-GET Paper if you use our proposed technique:

@inproceedings{jamilan2022apt,
  title={APT-GET: profile-guided timely software prefetching},
  author={Jamilan, Saba and Khan, Tanvir Ahmed and Ayers, Grant and Kasikci, Baris and Litz, Heiner},
  booktitle={Proceedings of the Seventeenth European Conference on Computer Systems},
  pages={747--764},
  year={2022}
}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 42.5%
  • Python 29.6%
  • Shell 27.8%
  • CMake 0.1%