A highly flexible, parallel virtual machine: Design and experience of ILDJIT

Simone Campanoni*, Giovanni Agosta, Stefano Crespi Reghizzi, Andrea Di Biagio

*Corresponding author for this work

Research output: Contribution to journalArticle

16 Scopus citations

Abstract

ILDJIT, a new-generation dynamic compiler and virtual machine designed to support parallel compilation, is introduced here. Our dynamic compiler targets the increasingly popular ECMA-335 specification. The goal of this project is twofold: On one hand, it aims at exploiting the parallelism exposed by multi-core architectures to hide the dynamic compilation latencies by pipelining compilation and execution tasks; on the other hand, it provides a flexible, modular and adaptive framework for dynamic code optimization. The ILDJIT organization and the compiler design choices are presented and discussed highlighting how adaptability and extensibility can be achieved. Thanks to the compilation latency masking effect of the pipeline organization, our dynamic compiler is able to mask most of the compilation delay, when the underlying hardware exposes sufficient parallelism. Even when running on a single core, the ILDJIT adaptive optimization framework manages to speedup the computation with respect to other open-source implementations of ECMA-335.

Original languageEnglish (US)
Pages (from-to)177-207
Number of pages31
JournalSoftware - Practice and Experience
Volume40
Issue number2
DOIs
StatePublished - Feb 2010

Keywords

  • CIL dynamic compiler
  • Dynamic adaptation
  • Parallel virtual machine

ASJC Scopus subject areas

  • Software

Fingerprint Dive into the research topics of 'A highly flexible, parallel virtual machine: Design and experience of ILDJIT'. Together they form a unique fingerprint.

  • Cite this