User Manual
HPC FeaturesRev 2.1-1.0.6
Mellanox Technologies
122
Collective communications are isolated from the rest of the traffic in the fabric using a private virtual
network (VLane) eliminating contention with other types of traffic.
After MLNX_OFED installation, FCA can be found at
/opt/mellanox/fca folder.
For further information on configuration instructions, please refer to the FCA User Manual.
5.5 ScalableUPC
Unified Parallel C (UPC) is an extension of the C programming language designed for high per-
formance computing on large-scale parallel machines.The language provides a uniform program-
ming model for both shared and distributed memory hardware. The programmer is presented
with a single shared, partitioned address space, where variables may be directly read and written
by any processor, but each variable is physically associated with a single processor. UPC uses a
Single Program Multiple Data (SPMD) model of computation in which the amount of parallelism
is fixed at program startup time, typically with a single thread of execution per processor.
In order to express parallelism, UPC extends ISO C 99 with the following constructs:
• An explicitly parallel execution model
• A shared address space
• Synchronization primitives and a memory consistency model
• Memory management primitives
The UPC language evolved from experiences with three other earlier languages that proposed
parallel extensions to ISO C 99: AC, Split-C, and Parallel C Preprocessor (PCP). UPC is not a
superset of these three languages, but rather an attempt to distill the best characteristics of each.
UPC combines the programmability advantages of the shared memory programming paradigm
and the control over data layout and performance of the message passing programming para-
digm.
Mellanox ScalableUPC is based on Berkely UPC package (see http://upc.lbl.gov/) and contains
the following enhancements:
• GasNet library used within UPC integrated with Mellanox FCA which off-loads from
UPC collective operations.
For further information on FCA, please refer to the Mellanox website.
• GasNet library contains MXM conduit which offloads from UPC all P2P operations as
well as some synchronization routines. For further information on MXM, please refer to
the Mellanox website.
Mellanox ScalableUPC is distributed as source RPM as well and can be downloaded from the
Mellanox website.
Mellanox OFED 1.8 includes ScalableUPC 2.1, which is installed under:
/opt/mellanox/bupc.
If you have installed OFED 1.8, you do not need to download and install ScalableUPC.