@inproceedings{db530c6dd7c2498a91ffa6a69fa789f0,
title = "Exploiting bank locality in multi-bank memories",
abstract = "Bank locality can be defined as localizing the number of load/store accesses to a small set of memory banks at a given time. An optimizing compiler can modify a given input code to improve its bank locality. There are several practical advantages of enhancing bank locality, the most important of which is reduced memory energy consumption. Recent trends indicate that energy consumption is fast becoming a first-order design parameter as processor-based systems continue to become more complex and multi-functional. Off-chip memory energy consumption in particular can be a limiting factor in many embedded system designs. This paper presents a novel compiler-based strategy for maximizing the benefits of low-power operating modes available in some recent DRAM-based multi-bank memory systems. In this strategy, the compiler uses linear algebra to represent and optimize bank locality in a mathematical framework. We discuss that exploiting bank locality can be cast as loop (iteration space) and array layout (data space) transformations. We also present experimental data showing the effectiveness of our optimization strategy. Our results show that exploiting bank locality can result in large energy savings.",
author = "U. Sezer and G. Chen and M. Kandemir and H. Saputra and Irwin, {M. J.}",
year = "2003",
month = dec,
day = "1",
language = "English (US)",
isbn = "1581136765",
series = "CASES 2003: International Conference on Compilers, Architecture, and Synthesis for Embedded Systems",
pages = "287--297",
booktitle = "CASES 2003",
note = "CASES 2003: International Conference on Compilers, Architecture, and Synthesis for Embedded Systems ; Conference date: 30-10-2003 Through 01-11-2003",
}