The instruction cache is a popular target for optimizations of microprocessor-based systems because of the cache's high impact on system performance and power, and because of the cache's predictable temporal and spatial locality. Optimization techniques can be designed based on this predictability. We explore for the first time the interplay of two popular instruction cache optimization techniques: the long-known technique of code reordering and the relatively-new technique of cache configuration. We address the question of whether those two optimizations complement each other or if one optimization dominates the other. Through experiments using embedded system benchmarks, we show that cache configuration dominates a particular ca...
Abstract—Code repositioning is a well-known method of reducing inefficient off-chip memory accesses ...
Caches may consume half of a microprocessor’s total power and cache misses incur accessing off-chip ...
A dynamic optimizer is a software-based system that performs code modifications at runtime, and seve...
In the embedded domain, the gap between memory and processor performance and the increase in applica...
In the embedded domain, the gap between memory and processor performance and the increase in applica...
Instruction cache performance is critical to instruction fetch efficiency and overall processor perf...
We prove theorems that show that if we can reorder a program's memory refer-ence stream such th...
Truly incremental development is a holy grail of verification-intensive software industry. All facto...
We explore the use of compiler optimizations, which optimize the layout of instructions in memory. T...
Obtaining high performance without machine-specific tuning is an important goal of scientific applic...
Managing the energy-performance tradeoff has become a major challenge on embedded systems. The cache...
Embedded systems are getting popular in today’s world. They are usually small and thus have a limite...
Cache memories in embedded systems play an important role in reducing the execution time of the appl...
Commercial link : http://www.springerlink.de/ ALCHEMY/http://www.springer.comCache memories were inv...
When applying optimizations, a number of decisions are made using fixed strategies, such as always a...
Abstract—Code repositioning is a well-known method of reducing inefficient off-chip memory accesses ...
Caches may consume half of a microprocessor’s total power and cache misses incur accessing off-chip ...
A dynamic optimizer is a software-based system that performs code modifications at runtime, and seve...
In the embedded domain, the gap between memory and processor performance and the increase in applica...
In the embedded domain, the gap between memory and processor performance and the increase in applica...
Instruction cache performance is critical to instruction fetch efficiency and overall processor perf...
We prove theorems that show that if we can reorder a program's memory refer-ence stream such th...
Truly incremental development is a holy grail of verification-intensive software industry. All facto...
We explore the use of compiler optimizations, which optimize the layout of instructions in memory. T...
Obtaining high performance without machine-specific tuning is an important goal of scientific applic...
Managing the energy-performance tradeoff has become a major challenge on embedded systems. The cache...
Embedded systems are getting popular in today’s world. They are usually small and thus have a limite...
Cache memories in embedded systems play an important role in reducing the execution time of the appl...
Commercial link : http://www.springerlink.de/ ALCHEMY/http://www.springer.comCache memories were inv...
When applying optimizations, a number of decisions are made using fixed strategies, such as always a...
Abstract—Code repositioning is a well-known method of reducing inefficient off-chip memory accesses ...
Caches may consume half of a microprocessor’s total power and cache misses incur accessing off-chip ...
A dynamic optimizer is a software-based system that performs code modifications at runtime, and seve...