Assessing primitives performance on multi-stage execution - Archive ouverte HAL Accéder directement au contenu
Communication Dans Un Congrès Année : 2018

Assessing primitives performance on multi-stage execution

Résumé

Virtual machines, besides the interpreter and just-in-time compiler optimization facilities, also include a set of primitive operations that the client language can use. Some of these are essential and cannot be performed in any other way. Others are optional: they can be expressed in the client language but are often implemented in the virtual machine to improve performance when the just-in-time compiler is unable to do so (start-up performance, speculative optimizations not implemented or not mature enough, etc.). In a hybrid runtime, where code is executed by an interpreter and a just-in-time compiler, the implementor can choose to implement optional primitives in the client language , in the virtual machine implementation language (typically C or C++), or on top of the just-in-time compiler back-end. This raises the question of the maintenance and performance trade-offs of the different alternatives. As a case study, we implemented the String comparison optional primitive in each case. This paper describes the different implementations , discusses the maintenance cost of each of them and evaluates for different string sizes the execution time in Cog, a Smalltalk virtual machine.
Fichier principal
Vignette du fichier
paper.pdf (248.83 Ko) Télécharger le fichier
Origine : Fichiers produits par l'(les) auteur(s)
Loading...

Dates et versions

hal-01874946 , version 1 (15-09-2018)

Identifiants

  • HAL Id : hal-01874946 , version 1

Citer

Sophie Kaleba, Clément Béra, Stéphane Ducasse. Assessing primitives performance on multi-stage execution. ICOOOLPS 2017 - 12th Workshop on Implementation, Compilation, Optimization of Object-Oriented Languages, Programs and Systems, Jul 2018, Amsterdam, Netherlands. ⟨hal-01874946⟩
181 Consultations
124 Téléchargements

Partager

Gmail Facebook X LinkedIn More