VMAD: a Virtual Machine for Advanced Dynamic Analysis of Programs - Archive ouverte HAL Accéder directement au contenu
Communication Dans Un Congrès Année : 2011

VMAD: a Virtual Machine for Advanced Dynamic Analysis of Programs

Résumé

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.
Fichier non déposé

Dates et versions

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

Identifiants

  • HAL Id : inria-00544501 , version 1

Citer

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 Consultations
0 Téléchargements

Partager

Gmail Facebook X LinkedIn More