Authors
Joel Auslander, Matthai Philipose, Craig Chambers, Susan J Eggers, Brian N Bershad
Publication date
1996/5/1
Journal
ACM SIGPLAN Notices
Volume
31
Issue
5
Pages
149-159
Publisher
ACM
Description
Dynamic compilation enables optimization based on the values of invariant data computed at run-time. Using the values of these run-time constants, a dynamic compiler can eliminate their memory loads, perform constant propagation and folding, remove branches they determine, and fully unroll loops they bound. However, the performance benefits of the more efficient, dynamically-compiled code are offset by the run-time cost of the dynamic compile. Our approach to dynamic compilation strives for both fast dynamic compilation and high-quality dynamically-compiled code: the programmer annotates regions of the programs that should be compiled dynamically; a static, optimizing compiler automatically produces pre-optimized machine-code templates, using a pair of dataflow analyses that identify which variables will be constant at run-time; and a simple, dynamic compiler copies the templates, patching in the …
Total citations
19961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024927253425161216141271055863454531523642
Scholar articles
J Auslander, M Philipose, C Chambers, SJ Eggers… - ACM SIGPLAN Notices, 1996