This paper reviews the general notion of deadlock (and livelock) in parallel systems based upon synchronised message passing and relates them to the much worse problem of undetected data-loss in asynchronous or shared-memory communications. Two design paradigms (I/O-PAR and Client-Server) are presented that guarantee freedom from deadlock for synchronised communication regimes (both continuous and irregular dataow). The paradigms are based upon the notion of `synchronisation classes' for processes that are closed under certain forms of parallel composition. Checking for deadlock-freeness devolves to checking that the base processes belong to the correct classes and that the composition rules are observed. The complexity of this checking is at worst O(n), where n is the number of processes in the system, as opposed to O(sn), where s is the (average) number of states in each process. The latter would be required for an arbitrary parallel design. The automated checking of these design rules is therefore highly practical. High-performance applications (e.g. physical system modelling, embedded realtime systems, ...) generally consist of two components: the computationally intensive part (which is usually logically simple and can exploit the I/O-PAR paradigm) and its controlling apparatus (which can be highly complex but can exploit the ClientServer paradigm). This paper reports on the design rules for hybrid combinations of the two paradigms that preserve their deadlock-free properties. Examples will be presented. The classic `Dining Philsopher' system is shown to illustrate an I/O-PAR Client-Server hybrid that breaks these rules. Finally, the Client-Server paradigm will be looked at from the point of view of the special language support provided by occam3 .
[1]
Peter H. Welch,et al.
Emulating Digital Logic using Transputer Networks (very High Parallelism = Simplicity = Performance)
,
1987,
PARLE.
[2]
C. A. R. Hoare,et al.
Communicating sequential processes
,
1978,
CACM.
[3]
Leslie G. Valiant,et al.
A bridging model for parallel computation
,
1990,
CACM.
[4]
Peter H. Welch,et al.
On the Serialisation of Parallel Programs
,
1991
.
[5]
George R. Ribeiro Justo,et al.
Configuration-oriented development of parallel programs
,
1993
.
[6]
C. A. R. Hoare,et al.
The Laws of Occam Programming
,
1988,
Theor. Comput. Sci..
[7]
Geraint Jones.
Programming in occam
,
1986,
Prentice Hall International Series in Computer Science.