A parallel programming paradigm dictates the way in which an application is to be expressed. It also restricts the algorithms that may be used in the application. Unfortunately, runtime systems for parallel computing often impose a particular programming paradigm. For a wider choice of algorithms, it is desirable to support more than one paradigm. In this paper we consider SilkRoad II, a variant of the Cilk runtime system for cluster computing. What is unique about SilkRoad II is its memory model which supports multiple paradigms with the underlying software distributed shared memory. The RC-dag memory consistency model of SilkRoad II is introduced. Our experimental results show that the stronger RC-dag can achieve performance comparable to LC of Cilk while supporting a bigger set of paradigms with rather good performance.
[1]
Matteo Frigo,et al.
Portable high-performance programs
,
1999
.
[2]
Matteo Frigo,et al.
The weakest reasonable memory model
,
1998
.
[3]
Weng-Fai Wong,et al.
SilkRoad: a multithreaded runtime system with software distributed shared memory for SMP clusters
,
2000,
Proceedings IEEE International Conference on Cluster Computing. CLUSTER 2000.
[4]
Proceedings. IEEE International Conference on Cluster Computing
,
2003,
2003 Proceedings IEEE International Conference on Cluster Computing.
[5]
P. Keleher,et al.
Lazy release consistency for distributed shared memory
,
1996
.