VMAD: a Virtual Machine for Advanced Dynamic Analysis of Programs - Inria - Institut national de recherche en sciences et technologies du numérique Access content directly
Conference Papers Year : 2011

VMAD: a Virtual Machine for Advanced Dynamic Analysis of Programs

Abstract

In this paper, we present a virtual machine, VMAD (Virtual Machine for Advanced Dynamic analysis), enabling an efficient implementation of advanced profiling and analysis processes. VMAD is organized as a sequence of basic operations where external modules associated to specific profiling strategies are dynamically loaded when required. The program binary files handled by VMAD are previously instrumented at compile time to include necessary data, instrumentation instructions and callbacks to the VM. Dynamic information, such as memory locations of launched modules, are patched at startup in the binary file. The LLVM compiler has been extended to automatically instrument programs according to both VMAD and the handled profiling strategies. VMAD's potential is illustrated by presenting a profiling strategy dedicated to loop nests. It collects all memory addresses that are accessed during a selected number of successive iterations of each loop. The collected addresses are consumed by an analysis process trying to interpolate addresses successively accessed through each memory reference as a linear function of some "virtual" loop indices. This profiling strategy using VMAD has been tested on the SPEC2006 benchmark suite showing a very low time overhead.
No file

Dates and versions

inria-00544501 , version 1 (08-12-2010)

Identifiers

  • HAL Id : inria-00544501 , version 1

Cite

Alexandra Jimborean, Matthieu Herrmann, Vincent Loechner, Philippe Clauss. VMAD: a Virtual Machine for Advanced Dynamic Analysis of Programs. IEEE International Symposium on Performance Analysis of Systems and Software, ISPASS, Apr 2011, Austin, United States. ⟨inria-00544501⟩

Collections

CNRS INRIA INRIA2
137 View
0 Download

Share

Gmail Facebook X LinkedIn More