Skip to Main content Skip to Navigation
Conference papers

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.
Document type :
Conference papers
Complete list of metadatas
Contributor : Philippe Clauss <>
Submitted on : Wednesday, December 8, 2010 - 11:42:28 AM
Last modification on : Wednesday, November 18, 2020 - 5:18:06 PM


  • HAL Id : inria-00544501, version 1



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⟩



Record views