TraceMonkey est un compilateur à la volée pour le moteur d'exécution JavaScript SpiderMonkey. TraceMonkey est un moteur d'enregistrement, de compilation à la volée et d'exécution de traces d'exécution de code JavaScript créé par la fondation Mozilla pour le moteur de rendu Gecko. Il a fait son apparition dans Mozilla Firefox 3.5.

TraceMonkey

Informations
Créateur Mozilla FoundationVoir et modifier les données sur Wikidata
Type Compilateur à la voléeVoir et modifier les données sur Wikidata

Il a été créé afin d'améliorer les performances d'exécution JavaScript du moteur SpiderMonkey et de permettre ainsi aux développeurs Web de proposer des applications Web autrefois impossibles à réaliser à cause des performances insuffisantes du JavaScript.

Principe de fonctionnement

modifier

TraceMonkey réalise la compilation à la volée d'arbre de traces. Les arbres de traces sont une structure de données utilisée pour tracer (enregistrer dans une trace) le code exécuté sur les points chauds, et le compiler. Quand les points chauds du code sont à nouveau exécutés, le code compilé est exécuté à la place.

Mise en œuvre

modifier

Dans Firefox, l'interpréteur JavaScript s'appelle SpiderMonkey. Ce dernier a été modifié pour s'interfacer avec TraceMonkey, le moteur de traces. SpiderMonkey interprète le code JavaScript, surveille les exécutions de boucles et compte le nombre d'itérations. Lorsque le seuil du nombre d'exécution d'une itération est atteint, TraceMonkey enregistre les traces, les compile en code natif grâce à nanojit et les exécute [1].

Réussites et limites

modifier

Les développeurs de Mozilla assurent que TraceMonkey est le moteur JavaScript le plus rapide au monde, lorsqu'il parvient à rester sur les traces compilées[2]. Malheureusement un certain nombre de conditions rendent difficile voire impossible l'utilisation de traces [3]:

  • Le code contenant beaucoup de branches de contrôle qui multiplie le nombre de traces,
  • Le code contenant beaucoup de combinaisons de types qui multiplie le nombre de traces,
  • Le code utilisant l'instruction eval qui peut générer tout type de code.

Dans ces cas, l'exécution de code JavaScript se fait alors avec l'interpréteur SpiderMonkey, ce qui la rend beaucoup plus lente. Afin de pallier cela, Mozilla a lancé le projet JägerMonkey qui vise à utiliser un compilateur à la volée pour accélérer l'exécution du code situé hors des traces.

Notes et références

modifier
  1. (en) Tracing JIT sur Mozilla wiki
  2. (en) a quick note on JavaScript engine components, Christopher Blizzard
  3. (en) Starting JägerMonkey, David Mandelin

Voir aussi

modifier

Articles connexes

modifier
  • Tamarin, la machine virtuelle JavaScript devant équiper Mozilla Firefox 3.5 à l'origine, avant que TraceMonkey ne soit choisi à sa place. Cependant, nanojit, le composant de génération de code est utilisé dans TraceMonkey.
  • JägerMonkey le compilateur à la volée alternatif pour le moteur d'exécution JavaScript SpiderMonkey de Firefox.
  • V8, le moteur d'exécution Javascript à haute performance inclus dans Google Chrome, concurrent de TraceMonkey
  • SquirrelFish Extreme, le moteur d'exécution Javascript à haute performance inclus dans WebKit, concurrent de TraceMonkey