Journal article
Title:
ShadowVM: Robust and Comprehensive Dynamic Program Analysis for the Java Platform
Authors:
Publication:
ACM SIGPLAN Notices
49
(3)
Year:
2013
Abstract:
Dynamic analysis tools are often implemented using instrumentation, particularly on managed runtimes including the Java Virtual Machine (JVM). Performing instrumentation robustly is especially complex on such runtimes: existing frameworks offer limited coverage and poor isolation, while previous work has shown that apparently innocuous instrumentation can cause deadlocks or crashes in the observed application. This paper describes ShadowVM, a system for instrumentation-based dynamic analyses on the JVM which combines a number of techniques to greatly improve both isolation and coverage. These centre on the offload of analysis to a separate process; we believe our design is the first system to enable genuinely full bytecode coverage on the JVM. We describe a working implementation, and use a case study to demonstrate its improved coverage and to evaluate its runtime overhead.
BibTeX:
@article{marek_shadowvm_2013_journal,
title = {{ShadowVM: Robust and Comprehensive Dynamic Program Analysis for the Java Platform}},
author = {Marek, Lukáš and Kell, Stephen and Zheng, Yudi and Bulej, Lubomír and Binder, Walter and Tůma, Petr and Ansaloni, Danilo and Sarimbekov, Aibek and Sewe, Andreas},
year = {2013},
journal = {{ACM SIGPLAN Notices}},
number = {3},
doi = {10.1145/2637365.2517219},
pages = {105--114},
volume = {49},
shorttitle = {ShadowVM},
}