Automatic Restructuring of Linked Data Structures
H.L.A. van der Spek, C.W.M. Holm and H.A.G. Wijshof.
Abstract:
The memory subsystem is one of the major performance bottlenecks in modern computer systems. While much effort is spent on the optimization of codes which access data regularly, not all codes will do so. Programs using pointer linked data structures are notorious for producing such so called irregular memory access patterns. In this paper, we present a compilation and run-time framework that enables fully automatic restructuring of pointer-linked data structures for type-unsafe languages, such as C. The restructuring framework is based on run-time restructuring using run-time trace information. The compiler transformation chain first identifies disjoint data structures that are stored in type-homogeneous memory pools. Access to these pools is traced and from these run-time traces, a permutation vector is derived. The memory pool is restructured at run-time using this permutation, after which all pointers (both stack and heap) that refer to the restructured pool must be updated. While the run-time tracing incurs a considerable overhead, we show that restructuring pointer-linked data structures can yield substantial speedups and that in general, the incurred overhead is compensated for by the performance improvements.
Published:
"Automatic Restructuring of Linked Data Structures"
H.L.A. van der Spek, C.W.M. Holm and H.A.G. Wijshof.
Proceedings of the 22nd International Workshop on Languages and Compilers for Parallel Computing (LCPC'09)
, Newark, DE, October 2009
Download:
Paper: