@inproceedings{23695bc20df144ee807e6767f636aa05,
title = "Kernel assisted collective intra-node MPI communication among multi-core and many-core CPUs",
abstract = "Shared memory is among the most common approaches to implementing message passing within multi-core nodes. However, current shared memory techniques do not scale with increasing numbers of cores and expanding memory hierarchies - most notably when handling large data transfers and collective communication. Neglecting the underlying hardware topology, using copy-in/copy-out memory transfer operations, and overloading the memory subsystem using one-to-many types of operations are some of the most common mistakes in today's shared memory implementations. Unfortunately, they all negatively impact the performance and scalability of MPI libraries - and therefore applications. In this paper, we present several kernel-assisted intra-node collective communication techniques that address these three issues on many-core systems. We also present a new Open MPI collective communication component that uses the KNEM Linux module for direct inter-process memory copying. Our Open MPI component implements several novel strategies to decrease the number of intermediate memory copies and improve data locality in order to diminish both cache pollution and memory pressure. Experimental results show that our KNEM-enabled Open MPI collective component can outperform state-of-art MPI libraries (Open MPI and MPICH2) on synthetic benchmarks, resulting in a significant improvement for a typical graph application.",
keywords = "Collective communication, Kernel, MPI, Many-core, Multi-core, NUMA, Shared memory",
author = "Teng Ma and George Bosilca and Aurelien Bouteiller and Brice Goglin and Squyres, {Jeffrey M.} and Dongarra, {Jack J.}",
year = "2011",
doi = "10.1109/ICPP.2011.29",
language = "English",
isbn = "9780769545103",
series = "Proceedings of the International Conference on Parallel Processing",
pages = "532--541",
booktitle = "Proceedings - 2011 International Conference on Parallel Processing, ICPP 2011",
note = "40th International Conference on Parallel Processing, ICPP 2011 ; Conference date: 13-09-2011 Through 16-09-2011",
}