Skip to main content
eScholarship
Open Access Publications from the University of California

UPC++ v1.0 Specification, Revision 2020.10.0

  • Author(s): Bonachea, Dan;
  • Kamil, Amir
  • et al.

Published Web Location

https://doi.org/10.25344/S4CS3F
Abstract

UPC++ is a C++11 library providing classes and functions that support Partitioned Global Address Space (PGAS) programming. The key communication facilities in UPC++ are one-sided Remote Memory Access (RMA) and Remote Procedure Call (RPC). All communication operations are syntactically explicit and default to non-blocking; asynchrony is managed through the use of futures, promises and continuation callbacks, enabling the programmer to construct a graph of operations to execute asynchronously as high-latency dependencies are satisfied. A global pointer abstraction provides system-wide addressability of shared memory, including host and accelerator memories. The parallelism model is primarily process-based, but the interface is thread-safe and designed to allow efficient and expressive use in multi-threaded applications. The interface is designed for extreme scalability throughout, and deliberately avoids design features that could inhibit scalability.

Main Content
For improved accessibility of PDF content, download the file to your device.
Current View