- Unat, Didem;
- Dubey, Anshu;
- Hoefler, Torsten;
- Shalf, John;
- Abraham, Mark;
- Bianco, Mauro;
- Chamberlain, Bradford L;
- Cledat, Romain;
- Edwards, H Carter;
- Finkel, Hal;
- Fuerlinger, Karl;
- Hannig, Frank;
- Jeannot, Emmanuel;
- Kamil, Amir;
- Keasler, Jeff;
- Kelly, Paul HJ;
- Leung, Vitus;
- Ltaief, Hatem;
- Maruyama, Naoya;
- Newburn, Chris J;
- Pericas, Miquel
The cost of data movement has always been an important concern in high performance computing (HPC) systems. It has now become the dominant factor in terms of both energy consumption and performance. Support for expression of data locality has been explored in the past, but those efforts have had only modest success in being adopted in HPC applications for various reasons. them However, with the increasing complexity of the memory hierarchy and higher parallelism in emerging HPC systems, locality management has acquired a new urgency. Developers can no longer limit themselves to low-level solutions and ignore the potential for productivity and performance portability obtained by using locality abstractions. Fortunately, the trend emerging in recent literature on the topic alleviates many of the concerns that got in the way of their adoption by application developers. Data locality abstractions are available in the forms of libraries, data structures, languages and runtime systems; a common theme is increasing productivity without sacrificing performance. This paper examines these trends and identifies commonalities that can combine various locality concepts to develop a comprehensive approach to expressing and managing data locality on future large-scale high-performance computing systems.