SHMEM
SHMEM (from Cray Research's “shared memory” library[1]) is a family of parallel programming libraries, providing one-sided, RDMA, parallel-processing interfaces for low-latency distributed-memory supercomputers. The SHMEM acronym was subsequently reverse engineered to mean "Symmetric Hierarchical MEMory”.[2] Later it was expanded to distributed memory parallel computer clusters, and is used as parallel programming interface or as low-level interface to build partitioned global address space (PGAS) systems and languages.[3] “Libsma”, the first SHMEM library, was created by Richard Smith at Cray Research in 1993 as a set of thin interfaces to access the CRAY T3D's inter-processor-communication hardware. SHMEM has been implemented by Cray Research, SGI, Cray Inc., Quadrics, HP, GSHMEM, IBM, QLogic, Mellanox, Universities of Houston and Florida; there is also open-source OpenSHMEM.[4]
SHMEM laid the foundations for low-latency (sub-microsecond) one-sided communication.[5] After its use on the CRAY T3E,[6] its popularity waned as few machines could deliver the near-microsecond latencies necessary to maintain efficiency for its hallmark individual-word communication. With the advent of popular sub-microsecond interconnects, SHMEM has been used to address the necessity of hyper-efficient, portable, parallel-communication methods for exascale computing.[7]
Programs written using SHMEM can be started on several computers, connected together with some high-performance network, supported by used SHMEM library. Every computer runs a copy of a program (SPMD); each copy is called PE (processing element). PEs can ask the SHMEM library to do remote memory-access operations, like reading ("shmem_get" operation) or writing ("shmem_put" operation) data. Peer-to-peer operations are one-sided, which means that no active cooperation from remote thread is needed to complete the action (but it can poll its local memory for changes using "shmem_wait"). Operations can be done on short types like bytes or words, or on longer datatypes like arrays, sometimes evenly strided or indexed (only some elements of array are sent). For short datatypes, SHMEM can do atomic operations (CAS, fetch and add, atomic increment, etc.) even in remote memory. Also there are two different synchronization methods:[4] task control sync (barriers and locks) and functions to enforce memory fencing and ordering. SHMEM has several collective operations, which should be started by all PEs, like reductions, broadcast, collect.
Every PE has some of its memory declared as "symmetric" segment (or shared memory area) and other memory is private. Only "shared" memory can be accessed in one-sided operation from remote PEs. Programmers can use static-memory constructs or shmalloc/shfree routines to create objects with symmetric address that span the PEs.
Typical SHMEM functions
- start_pes(N) — start N processing elements (PE)
- _my_pe() — ask SHMEM to return the PE identifier of current thread
- shmem_barrier_all() — wait until all PEs run up to barrier; then enable them to go further
- shmem_put(target, source, length, pe) — write data of length "length" to the remote address "target" on PE with id "pe" from local address "source"
- shmem_get(target, source, length, pe) — read data of length "length" from the remote address "source" on PE with id "pe" and save to read values into local address "target"[8]
List of SHMEM implementations
- Cray Research: Original SHMEM for Cray T3D, Cray T3E, and Cray Research PVP supercomputers[9]
- SGI: SGI-SHMEM for systems with NUMAlink and Altix build with InfiniBand network adapters
- Cray Inc.: MP-SHMEM for Unicos MP (X1E supercomputer)
- Cray Inc.: LC-SHMEM for Unicos LC (Cray XT3, XT4, XT5)
- Quadrics: Q-SHMEM[10] for Linux clusters with QsNet interconnect[9]
- Cyclops-64 SHMEM
- HP SHMEM[9]
- IBM SHMEM[9]
- GPSHMEM[9]
- NVSHMEM is based on the OpenSHMEM API and supports GPUs, including both host- and device-initiated communication.
OpenSHMEM implementations
OpenSHMEM is a standard effort by SGI and Open Source Software Solutions, Inc.
- University of Houston: Reference OpenSHMEM[4][9]
- Mellanox ScalableSHMEM[9]
- Portals-SHMEM (on top of Portals interface)
- University of Florida: Gator SHMEM[9]
- Open MPI includes an implementation of OpenSHMEM[11]
- Adapteva Epiphany Coprocessor[12]
- Sandia OpenSHMEM (SOS) supports multiple networking APIs [13]
- OpenSHMEM over MPI (OSHMPI) version 1 is based on MPI one-sided communication and supports the OpenSHMEM 1.2 specification[14]
- OpenSHMEM over MPI (OSHMPI) version 2 is based on MPI one-sided communication and supports the OpenSHMEM 1.4 specification[15]
- MVAPICH2-X includes an OpenSHMEM implementation
- shmem4py provides Python support for the OpenSHMEM 1.5 specification functionality, as a wrapper around a C implementation.[16]
Disadvantages
In first years SHMEM was accessible only on some Cray Research machines (later additionally on SGI)[1] equipped with special networks, limiting library widespread and being vendor lock-in (for example, Cray Research recommended to partially rewrite MPI programs to combine both MPI and shmem calls, which make the program non-portable to other clear-MPI environment).
SHMEM was not defined as standard,[9][1] so there were created several incompatible variants of SHMEM libraries by other vendors. Libraries had different include file names, different management function names for starting PEs or getting current PE id,[9] and some functions were changed or not supported.
Variants of SHMEM libraries can run on top of any MPI library, even when a cluster has only non-RDMA optimized Ethernet, however the performance will be typically worse than other enhanced networking protocols.
Memory in shared region should be allocated using special functions (shmalloc/shfree), not with the system malloc.[9]
Many disadvantages of SHMEM have been overcome with the use of OpenSHMEM on popular sub-microsecond interconnects, driven by exascale development.[7]
See also
- Message Passing Interface (especially one-sided operations of MPI-2)
- Active Messages
- Unified Parallel C (one of PGAS languages, can be implemented on top of SHMEM)
References
- ^ a b c Cray Research (1999). Cray T3E C and C++ Optimization Guide (PDF) (Technical report). pp. 45–83. 004-2178-002. Archived from the original (PDF) on 2014-02-01.
- ^ Introduction to Parallel Computing - 3.11 Related Work // cse590o course, University of Washington, Winter 2002; page 154
- ^ "New Accelerations for Parallel Programming" (PDF). Mellanox. 2012. Retrieved 18 January 2014. SHMEM is being used/proposed as a lower level interface for PGAS implementations 
- ^ a b c Poole, Stephen (2011). "OpenSHMEM - Toward a Unified RMA Model". Encyclopedia of Parallel Computing. pp. 1379–1391. doi:10.1007/978-0-387-09766-4_490. ISBN 978-0-387-09765-7.
- ^ Tools for Benchmarking, Tracing, and Simulating SHMEM Applications // CUG 2012, paper by San Diego Supercomputer center and ORNL
- ^ Recent Advances in Parallel Virtual Machine and Message Passing ..., Volume 11 page 59: "One-sided communication as a programming paradigm was made popular initially by the SHMEM library on the Cray T3D and T3E..."
- ^ a b "OpenSHMEM 2015". www.csm.ornl.gov. Retrieved 2017-04-10.
- ^ SGI TPL. "man shmem_get". Archived from the original on 2014-02-01.
- ^ a b c d e f g h i j k Nanjegowda, Ram; Pophale, Swaroop; Curtis, Tony (2012). "OpenSHMEM Tutorial" (PDF). University of Houston, Texas. Archived from the original (PDF) on 2014-02-01.
- ^ Shmem Programming Manual // Quadrics, 2000-2001
- ^ OpenMPI
- ^ James Ross and David Richie. An OpenSHMEM Implementation for the Adapteva Epiphany Coprocessor. In Proceedings of the Third Workshop on OpenSHMEM and Related Technologies, "OpenSHMEM 2016". www.csm.ornl.gov.. Springer, 2016.
- ^ Sandia OpenSHMEM (SOS) on Github
- ^ Hammond, Jeff R.; Ghosh, Sayan; Chapman, Barbara M. (2014). "Implementing OpenSHMEM Using MPI-3 One-Sided Communication". In Poole, Stephen; Hernandez, Oscar; Shamis, Pavel (eds.). OpenSHMEM and Related Technologies: Experiences, Implementations, and Tools. Lecture Notes in Computer Science. Vol. 8356. Cham: Springer International Publishing. pp. 44–58. doi:10.1007/978-3-319-05215-1_4. ISBN 978-3-319-05215-1.
- ^ Si, Min; Fu, Huansong; Hammond, Jeff R.; Balaji, Pavan (2022). "OpenSHMEM over MPI as a Performance Contender: Thorough Analysis and Optimizations". OpenSHMEM and Related Technologies. OpenSHMEM in the Era of Exascale and Smart Networks. Springer International Publishing. pp. 39–60. doi:10.1007/978-3-031-04888-3_3.
- ^ Rogowski, Marcin; Hammond, Jeff R.; Keyes, David E.; Dalcin, Lisandro (2023). "shmem4py: High-Performance One-Sided Communication for Python Applications". Proceedings of the Platform for Advanced Scientific Computing Conference. pp. 1–10. doi:10.1145/3624062.3624602.
Further reading
- Shared Memory Access (SHMEM) Routines // Cray Research, 1995
External links
- Using SHMEM on the CRAY T3E
- man intro_shmem (SGI TPL) - Introduction to the SHMEM programming model
- OpenSHMEM: an effort to create a specification for a standardized API for parallel programming in the Partitioned Global Address Space.
