inria-00358172, version 1
Enabling High-Performance Memory Migration for Multithreaded Applications on Linux
Brice Goglin
1, 2Nathalie Furmento
1, 2
MTAAP'09: Workshop on Multithreaded Architectures and Applications, held in conjunction with IPDPS 2009 (2009)
Résumé : As the number of cores per machine increases, memory architectures are being redesigned to avoid bus contention and sustain higher throughput needs. The emergence of Non-Uniform Memory Access (NUMA) constraints has caused affinities between threads and buffers to become an important decision criteria for schedulers. Memory migration enables the dynamically joined distribution of work and data across the machine but requires high-performance data transfers as well as a convenient programming interface. We present the improvement of the Linux migration primitives and the implementation of a Next-Touch policy in the kernel to provide multithreaded applications with an easy way to dynamically maintain thread-data affinity. Microbenchmarks show that our work enables a high-performance, synchronous and lazy memory migration within multithreaded applications. A threaded LU factorization then reveals the large improvement that our Next-Touch policy model may bring in applications with complex access patterns.
- 1 : Laboratoire Bordelais de Recherche en Informatique (LaBRI)
- CNRS : UMR5800 – Université Sciences et Technologies - Bordeaux I – Ecole Nationale Supérieure d'Electronique, Informatique et Radiocommunications de Bordeaux – Université Victor Segalen - Bordeaux II
- 2 : RUNTIME (INRIA Bordeaux - Sud-Ouest)
- INRIA – CNRS : UMR5800 – Université Sciences et Technologies - Bordeaux I – Ecole Nationale Supérieure d'Electronique, Informatique et Radiocommunications de Bordeaux
- Domaine : Informatique/Système d'exploitation
- inria-00358172, version 1
- http://hal.inria.fr/inria-00358172
- oai:hal.inria.fr:inria-00358172
- Contributeur : Brice Goglin
- Soumis le : Mardi 3 Février 2009, 07:37:40
- Dernière modification le : Jeudi 16 Juillet 2009, 13:57:11






Documents associés
Exporter