Hardware-coherent, distributed shared address space systems are increasingly successful at moderate scale. However, it is unclear whether, or with how much difficulty, the performance of a load-store shared address space programming model scales to large processor counts on real applications. We examine this question using an aggressive case-study machine, the SGI Origin2000, up to 128 processors. We show for the first time that scalable performance can indeed be achieved in this programming model on a wide range of applications, including challenging kernels like FFT. However, this does not come easily, even for applications considered to be already highly optimized, and is very often not simply a matter of increasing problem size. Rather, substantial further application restructuring is often needed, which is usually quite algorithmic in nature. We examine how the restructurings compare with those needed for performance portability to shared virtual memory on clusters, and we comment on common programming guidelines for performance portability and scalability as well as on how the programming difficulty compares with that of explicit message passing. We also examine where applications spend their time on this large machine, the impact of special hardware features that the machine provides, and the impact of mapping to the network topology.
[1]
J. Larus,et al.
Tempest and Typhoon: user-level shared memory
,
1994,
Proceedings of 21 International Symposium on Computer Architecture.
[2]
Ricardo Bianchini,et al.
The MIT Alewife machine: architecture and performance
,
1995,
Proceedings 22nd Annual International Symposium on Computer Architecture.
[3]
Anoop Gupta,et al.
The DASH Prototype: Logic Overhead and Performance
,
1993,
IEEE Trans. Parallel Distributed Syst..
[4]
Ramesh Subramonian,et al.
LogP: towards a realistic model of parallel computation
,
1993,
PPOPP '93.
[5]
Anoop Gupta,et al.
The SPLASH-2 programs: characterization and methodological considerations
,
1995,
ISCA.