Seventh Workshop on Interaction Between Compilers and Computer Architectures, 2003. INTERACT-7 2003. Proceedings.
Download PDF

Abstract

For call intensive rograms, function calls are major bottlenecks during rogram execution since they usually force register contents to be spilled into memory. Such register to memory spills are much more ronounced in presence of recursion. A function call is usually accompanied by the creation of its activation record at function entry. In this paper, we will deviate from this usual practice; we create an activation record only when we find it necessary. The result is that on many occasions we can execute a function call without actually creating its activation record. We call our strategy lazy activation record strategy (LARS) and show how this strategy is particularly important for call-intensive programs. The LARS subsumes many traditional techniques like leaf-call optimization and tail-recursion optimization, and in addition, it extends Chow?s shrink-wrapping in terms of scope and granularity. We also demonstrate how the LARS can be an effective optimization strategy in case of battery operated embedded systems, since not only it can reduce execution time but also energy consumption.
Like what you’re reading?
Already a member?
Get this article FREE with a new membership!