Skip to content



Folders and files

Last commit message
Last commit date

Latest commit



53 Commits

Repository files navigation

RERAN Reboot Research Project

This repository is forked from the original RERAN repository, aiming to reseach the tool and expand its usability. During our research, we found a lagging issue residing in RERAN that causes the replay to be significantly slower than record. We designed several experiments to identify the issue and proposed several fixes to the original RERAN program.

Structure of the repository

command/ contains bash commands to run the experiments.

data_process/ contains python scripts to process experimental data.

data_set/ contains all of the experimental data. There is a README in each experiment folder that briefly explains the purpose of the experiment. The results could be found in the jupyter notebooks under the folder.

origin/ contains the original RERAN source code.

src/ contains the modified RERAN source code.

Running Experiments

Record a workload

sh command/ <exp_idx> <set_idx>

Please make sure that you have created the appropriate exp and set directories under data_set directory.

Get Latency Values of a workload

sh command/ <exp_idx> <set_idx>

Replay a workload

sh command/ <exp_idx> <set_idx> <algo>

<algo> could be one of original, bruteforce, deficit, sec_deficit, busy_pooling.


Record and Replay for Android

(c) Copyright 2011-2013

The preferred license for RERAN is the BSD License.

Getting Started

Getting started with RERAN is easy. The instructions below assume you have the Android SDK installed on your computer (runs on Linux, Mac, and Windows). We use the adb debugging bridge to push files onto the phone and run the record and replay commands. The ./adb tool is in the /platform-tools folder of the SDK folder you install. The example below performs our standard record and replay. For the selective replay and time-warping features, please see their respective pages.

RERAN Design

First, recording with getevent will create a log of the events used during the run, e.g., recordedEvents.txt. Second, send the recorded log into the Translate program. The Translate program will output a translated log of the original events. Third, push the translated log, e.g., translatedEvents.txt, onto the phone. Fourth, run the Replay program using the adb shell.

ARM Cross-compiler

In order for the replay program to run on Android devices, they must be compiled using a cross-compiler for ARM CPU's. If you already have an ARM cross-compiler on your computer, then you are ready to go. If not, please find one that works with your operating system. The executable contained in our release was compiled on Linux. From our experience, finding and installing an ARM cross-compiler for Mac was difficult; it is possible, but included many hacks to get going, and is not recommended.

We would recommend using Sourcery CodeBench for ARM Lite on Linux.

After the ARM cross-compiler is installed, you can compile the source code using the compiler's version of gcc, shown below.

arm-none-linux-gnueabi-gcc -static -o replay replay.c

Running Example

Push replay tool onto the phone: "/data/local" will be our local directory on the phone for the RERAN files. If it does not exist, it will be created. This step only needs to be done once.

cd /path/to/android-sdk/platform-tools
./adb push ./replay /data/local

Record a trace: The getevent tool is part of the Android SDK. The "-tt" flag is to timestamp each event (used by the Translator in the next step).

./adb shell getevent -tt > recordedEvents.txt

Run the Translate program: The first two arguments of the Translate program are the path to the recorded events and the name of the translated events to output, respectively. There are also extra flags: see selective replay and time-warping.

cd /path/to/translate.jar/

java -jar translate.jar /path/to/recordedEvents.txt /path/to/android-sdk/platform-tools/translatedEvents.txt

Push the translated recorded events onto the phone:

./adb push translatedEvents.txt /data/local

Run the replay program (after your app is setup): See setting up your app for more info.

./adb shell /data/local/./replay /data/local/translatedEvents.txt

Please see the website for more info.


RERAN - Record and Replay for Android







No releases published




  • Jupyter Notebook 79.4%
  • C 7.7%
  • Java 7.0%
  • Python 4.3%
  • Shell 1.6%