Aurore Poirier1 , Erven Rohou2
, and Manuel Serrano3
The Art, Science, and Engineering of Programming, 2025, Vol. 10, Issue 1, Article 6
Submission date: 2024-10-01
Publication date: 2025-02-15
DOI: https://doi.org/10.22152/programming-journal.org/2026/10/6
Full text: t.b.a
Context: Just-in-Time (JIT) compilers are able to specialize the code they generate according to a continuous profiling of the running programs. This gives them an advantage when compared to Ahead-of-Time (AoT) compilers that must choose the code to generate once for all.
Inquiry: Is it possible to improve the performance of AoT compilers by adding Dynamic Binary Modification (DBM) to the executions?
Approach: We added to the Hopc AoT JavaScript compiler a new optimization based on DBM to the inline cache (IC), a classical optimization dynamic languages use to implement object property accesses efficiently.
Knowledge: Reducing the number of memory accesses as the new optimization does, does not shorten execution times on contemporary architectures.
Grounding: The DBM optimization we have implemented is fully operational on x86_64 architectures. We have conducted several experiments to evaluate its impact on performance and to study the reasons of the lack of acceleration.
Importance: The (negative) result we present in this paper sheds new light on the best strategy to be used to implement dynamic languages. It tells that the old days were removing instructions or removing memory reads always yielded to speed up is over. Nowadays, implementing sophisticated compiler optimizations is only worth the effort if the processor is not able by itself to accelerate the code. This result applies to AoT compilers as well as JIT compilers.
University of Rennes - Inria - CNRS - IRISA, France
https://orcid.org/0009-0001-5155-2580
University of Rennes - Inria - CNRS - IRISA, France
https://orcid.org/0000-0002-8060-8360
Inria - University of Côte d’Azur, France
https://orcid.org/0000-0002-5240-1610