Implementation of a serial communication process for a fault tolerant, real time, multitransputer operating system. by Selcuk, Zafer
Calhoun: The NPS Institutional Archive
Theses and Dissertations Thesis Collection
1984
Implementation of a serial communication process













IMPLEMENTATION OF A SERIAL COMMUNICATION
PROCESS FOR A FAULT TOLERANT, REAL TIME,
MULTITRANSPUTER OPERATING SYSTEM
by
Zaf er Se lcuk
December 1984
Thesis Advisor: Uno R . Kodre s




SECURITY CLASSIFICATION OF THIS PAGE (Whan Data iEntered)
REPORT DOCUMENTATION PAGE READ INSTRUCTIONSBEFORE COMPLETING FORM
1. REPORT NUMBER 2. GOVT ACCESSION NO. 3. RECIPIENT'S CATALOG NUMBER
4. TITLE (and Subtitle)
Implementation of a Serial Communication
Process for a Fault Tolerant, Real Time,
Mul t i transput e r Operating System
5. TYPE OF REPORT 4 PERIOD COVERED
Master's thesis
December 1984
6. PERFORMING ORG. REPORT NUMBER
7. AUTHORCs;
Zafer Selcuk
8. CONTRACT OR GRANT NUMBERS)
9. PERFORMING ORGANIZATION NAME AND ADDRESS
Naval Postgraduate School
Monterey, California 93943
10. PROGRAM ELEMENT. PROJECT, TASK
AREA ft WORK UNIT NUMBERS




De cembe r 1984
13. NUMBER OF PAGES
108
14. MONITORING AGENCY NAME & ADDRESSC// different from Controlling Office) 15. SECURITY CLASS, (of thia report)
15a. DECLASSIFICATION/ DOWNGRADING
SCHEDULE
16- DISTRIBUTION STATEMENT (at this Report)
Approved for public release; distribution is unlimited
17. DISTRIBUTION STATEMENT (ot the abstract entered In Block 20, 11 different Irom Report)
18. SUPPLEMENTARY NOTES
19. KEY WORDS (Continue on reverse aide If neceaaary and Identify by block number)
Transputer, Occam, Concurrent Processing,
Multi Computer, Real Time Systems,
Fault Tolerance, Quadruple Modular Redundancy
20. ABSTRACT (Continue on reverse aide If neceaaary and Identify by block number)
The purpose of this thesis is to study a more reliable and
faster microcomputer systems for real time applications. The
new product of VLSI technology, IMS T424 Transputer is used
for the prototype design of this multicomputer system. (cont.)
DD i JAN 73 1473 EDITION OF 1 NOV 65 IS OBSOLETE
5 'N 0102- LF- 014- 6601 ]_
UNCLASSIFIED
SECURITY CLASSIFICATION OF THIS PAGE (When Data Sntarad)
UNCLASSIFIED
SECURITY CLASSIFICATION OF THIS PAGE (Wh»r, Dm Enf»r«<)
ABSTRACT (Continued) # 20
The multicomputer system's design with the fault tolerance
feature, is emphasised in this thesis. Also a serial
communication subsystem has been implemented using the
VAX 11/780 VMS system for the proposed fault tolerant real
time multitransputer operating system.
S-N 0102- LF- ON- 6601
UNCLASSIFIED
SECURITY CLASSIFICATION OF THIS P AGe.(Wh*n Dmlm Ent»,,d)
Approved for public release; distribution is unlimited
Implementation of a Serial Communication Process
for a Fault Tolerant, Real Time,
Multi Transputer Operating System
by
Zafer Selcuk
Lieutenant J.G.', Turkish Navy
B.S., Turkish Naval Academy, 1978
Submitted in partial fulfillment of the
requirements for the degree of





The purpose of this thesis is to study a more reliable
and faster microcomputer system for real time applications.
The new product of VLSI technology, IMS T424 Transputer is
used for the prototype design of this multicomputer system.
The multicomputer system's design with the fault toler-
ance feature, is emphasised in this thesis. Also a serial
communication subsystem has been implemented using the VAX
11/780 VMS system for the proposed fault tolerant real time






D. THESIS STRUCTURE 13
II. HARDWARE FEATURES 14




4. Peripheral Interface 19
B. THE TRANSPUTER SYSTEMS CONCEPT 20
III. SOFTWARE CAPABILITIES 23













IV. SYSTEM STRUCTURE 36
A. FAULT TOLERANT SYSTEM 3 6
1. Objectives 36
2. Fundamental Aspects 37
3. Techniques 38
B. MULTIPROCESSING CONCEPT 42
C. DESIGN METHODOLOGY 44
D. PROPOSED OPERATING SYSTEM 49
E. COMMUNICATION SUBSYSTEM DESIGN 51
1. Design Objectives 51
2. Implementation of the Communication
System 55
V. PERFORMANCE EVALUATION 61
A. SUBPROCESSES EXECUTION TIMES 61
B. SERIAL COMMUNICATION PERFORMANCE 77
1. By-Pass Communication Performance .... 77
2. Internal Distribution Performance .... 77
3. External Distribution Performance .... 78
4. Short-Cut Procedure Performance 78
C. FAULT FREE SYSTEM PERFORMANCE 78
D. SYSTEM WITHOUT SHARED MEMORY 80
E. EXPANDABILITY 81
VI. CONCLUSION 86
A. SUMMARY 8 6
B. FOLLOW- ON WORK 87
APPENDIX A: COMMUNICATION PROCESSES 88
APPENDIX B: UTILITY PROCESSES 99
APPENDIX C: DISTANCE TABLES 102
LIST OF REFERENCES 106
INITIAL DISTRIBUTION LIST 107
LIST OF TABLES
1. HARDWARE CAPABILITY OF THE IMS T424 12
2. IMS T424 INSTRUCTION LIST AND EXECUTION TIMES ... 15
3. OCCAM PRIMITIVES AND THEIR SYNTAX 25
4. SEQUENTIAL CONSTRUCT IMPLEMENTATION 27
5. PARALLEL CONSTRUCT IMPLEMENTATION 28
6. ALTERNATIVE CONSTRUCT IMPLEMENTATION 30
7. REPETITIVE CONSTRUCT IMPLEMENTATION 31
8. REPLICATOR PROCESS IMPLEMENTATION 33
9. CONDITIONAL CONSTRUCT IMPLEMENTATION 34
10. ADVANTAGES AND DISADVANTAGES OF MULTIPROCESSING
SYSTEMS 44
11. CODE AND THE MEANINGS OF THE DIGITS 56
12. RECEIVE PROCESS EXECUTION TIME 64
13. RECEIVER CLOSING PROCESS EXECUTION TIME 65
14. DUPLEXING PROCESS EXECUTION TIME 6 6
15. LISTENING PROCESS EXECUTION TIME 67
16. DECODING TO SEND PROCESS EXECUTION TIME 68
17. DECODING TO XMIT PROCESS EXECUTION TIME 69
18. SENDING BY DECODER PROCESS EXECUTION TIME 70
19. SENDING BY ENCODER PROCESS EXECUTION TIME 71
20. ENCODING FOR SEND PROCESS EXECUTION TIME 72
21. ENCODING FOR XMIT PROCESS EXECUTION TIME ..... 73
22. XMIT PREPARATION BY DECODER PROCESS EXECUTION
TIME 74
23. XMIT PREPARATION BY ENCODER PROCESS EXECUTION
TIME 7 5
24. TRANSMITTING PROCESS EXECUTION TIME 76
25. COMMUNICATION TYPES AND INVOKED PROCESSES 77
LIST OF FIGURES
2.1 Memory Interface Driving Static RAM's 18
2.2 Advances in Technology and System Throughputs ... 21
3.1 Flow Diagram of the Sequential Construct 26
3.2 Flow Diagram of the Parallel Construct 29
3.3 Flow Diagram of Alternative Construct 30
3.4 Flow Diagram of the Repetitive Construct 32
3.5 Flow Diagram of Replicator Construct 33
3.6 Flow Diagram of Conditional Construct 34
4.1 Pipeline / Ring Structure 45
4.2 Tetragonal 3-D Construction ..... 46
4.3 Butterfly Construction . 47
4.4 Matrix Structure ..... 47
4.5 The Structure of the Multitransputer System .... 48
4.6 Prototype Operating System Structure 49
4.7 Communication System I/O Block Presentation .... 52
4.8 Detailed Structure of Communication Subsystem ... 53
5.1 The Receiving Process 62
5.2 Fault Free System Structure 79
5.3 Common Data Transfer 81
5.4 Linear Type Computation Model 83
5.5 Loop Type Computation Model 84
5.6 Star Type Computation Model 85
ACKNOWLEDGEMENT
I would like to dedicate this work to my wife Sibel.
Also I would like to thank Prof. Uno R. Kodres for his
guidance, and Prof. Bruce J. MacLennan and the staff of the




Many terms used in this thesis are registered trademarks
of commercial products. Rather than attempt to cite each
individual occurrence of a trademark, all registered trade-
marks appearing in this thesis will be listed below
following the firm holding the trademark.












With the rapid advances in computer technologies both
hardware and software, computer systems are becoming more
complex. Together with its wide application, increasing
system reliability is of vital importance. [Ref. 1]
Providing fault tolerance is one of the attractive
solutions
.
Specific reasons for the use of fault tolerance exist in
several areas of present applications. Examples are:
1. Safety related failures, such as medical support or
defense systems.








3. Environments where manual maintenance is not possible,
such as space, sea or undersea. [Ref. 2]








The detected error is analyzed to isolate the fault
cause. Recovering from the failure requires at least a
back-up system such as secondary memory, a spare processor
and system's buses in real time systems. As a consequence,
computing machines become larger and more complex. During
normal fault free operation, fault tolerance does not
provide any performance advantages, but it is the insurance




This thesis is intended to focus on the area of imple-
menting a serial bus communication subsystem as a secondary
bus structure of the real time mult itransputer system to
provide for the fault tolerance requirement.
C. MOTIVATION
To explain the motivation of this thesis, it is better
to give some quantitative information about the computing
capacity and the performance of the transputer, IMS T424
[Ref. 4].
TABLE 1
HARDWARE CAPABILITY OF THE IMS T424
processor 32 bits (4.9 * 10 9 integer)
processing speed ... 10 MIPS (950 nanosec. mult.)
memory capacity .... 32 bit address bus 4 GBytes
built in memory .... 4 KBytes RAM. 80 MBytes/sec
serial bus 4 INMOS links 1.5 Mbytes/sec
parallel bus 25 Mbytes/sec max. transfer
peripheral interface . 8 bits bidir. 4 Mbytes/sec.
power dissipation ... 0.9 Watts
physical 45 mm 2 chip mounted in an 84
contact leadless chip carrier
At the first glance the quantities in Table 1 seem very
attractive just to use the transputer as a substitute
processor in an ordinary uniprocessor system.
12
The important hardware feature of the transputer is the
four bidirectional serial communication channels. Therefore
it is possible to obtain multiple communication paths
between two elements of the mult it ransputer system, using
some structures of the transputers. These paths provide the
graceful degradation for redundant multitransputer systems.
In other words, we can simply by-pass the failed element in
the multisystem, and processing continues with other
elements of the system.
Another important feature of the transputer, is that it
provides excellent hardware for concurrent processing. In
other words the transputer has been designed using a reduced
instruction set architecture which implements the OCCAM
concurrent programming language efficiently [Ref. 5].
D. THESIS STRUCTURE
The introduction just presented is designed to provide
the reader with a brief look at fault tolerance and in
particular to the development decisions on which a serial
bus communication structure based.
Chapter II will describe the hardware architecture and
the capabilities of the multitransputer systems. Chapter III
will provide a brief explanation of the OCCAM concurrent
processing language and its features. Chapter IV will
outline the fault tolerant system structure and details of
the serial bus communication process. In Chapter V the
performance of the serial bus communication is evaluated and
compared with fault free system performance.
The final chapter presents conclusions and observations
that resulted from this thesis effort and suggestions for
further research. Eight appendices are also provided that
give detailed descriptions of the subprocesses of the serial
bus communication program and its implementation.
13
II. HARDWARE FEATURES
A. WHAT IS THE TRANSPUTER ?
Transputer, or a transistor computer, is a single chip
computer which provides a direct implementation for the
process model of computing, in which each process is an
independent computation with its own data and program. The
processes are executed in a time shared mode on the
transputer and special instructions are provided to support
the process model of communication.
The term "Transputer" also reflects the device's ability
to be used as a system building block. The word is derived
from 'transistor' and 'computer' since the transputer is
both a computer on a chip and a silicon component like a
transistor. Just as the use of logic gates and Boolean
Algebra provides the design methodology of the present elec-
tronic systems, so the transputer together with formal rules
of OCCAM provides the design methodology for future concur-
rent systems
.
The detailed descriptions of the components of the
transputer: processor, memory, links and peripheral inter-
face will be introduced in next four subsection
respectively
1 . Processor
IMS T424 transputer has a 32 bit processor with an
instruction execution rate of 10 MIPS. Typical instructions
carried out by the processor and their execution times are
given in Table 2 .
The processor is optimized to implement the OCCAM
programming language. It is designed for performance and
14
TABLE 2



































! (output) ? (input) 625
assignment
efficiency, which is achieved by designing the instruction
set to simplify instruction decoding, by having a minimum
number of special registers, by incorporating useful func-
tions into the registers and by the use of an evaluation
stack. This approach simplifies compiler design, since all
the operands are in an uniformly addressed data space and it
also gives a fast process switch time.
The instruction set is compact. This is achieved by
separating data access from manipulation. Most instructions
are one byte long and are divided into two four bit fields:
function and operand. A sequence of bytes can be used to
extend the instruction in units of four bits up to a word
15
length, enabling both functions and operands to be frequency
encoded
.
The processor is designed to execute high level
languages efficiently and will normally be programmed using
OCCAM or an industry standard languages such as C or PASCAL.
a. Concurrent Processing
The processor executes programs sequentially. It
implements parallel processes by sharing its time between
the set of processes which are active at any instant. A
process is active when it is not waiting for input or
output
.
The currently executed process runs until it has
to wait for communication. When this happens, the process is
set inactive and the next process on the active queue starts
to execute. When a communication channel becomes ready, the
message is passed, and the waiting process is linked to the
end of the active process queue. Current process then
continues to execute, whenever its turn in the queue comes
up.
b. Priority Processes
The transputer T424 supports two levels of
priority, high and low priorities. PRIPAR (priority
parallel) process may have two components. A queue of active
processes is maintained for each priority level. A priority
1 (low priority) process is executed whenever there are no
active priority (high priority) processes.
If there are no active priority processes, the
latency (that is, the time from an external channel becoming
ready, to the start of its first instruction of the relevant
waiting priority process) is typically 600 ns . (maximum
2600 ns
.
) . Otherwise, if a priority process is already
executing, the relevant waiting process is linked to the end
of the priority queue.
16
c. Performance
The size of a program is given by the sum of
the sizes of its program elements. All timing averages and
the maximum time to execute the program is given by the sum
of the times to execute the individual program elements.
If the program is held in the external memory,
the external program fetch time must be added to obtain the
program execution time. Because of the instruction lookahaed
and the overlap with internal memory, this overhead will
usually be small.
If data is held in external memory, the external
data access time must also be added to obtain the program
execution time. The processor shares memory cycles with its
input/output interfaces. Each concurrent access by an inter-
face channel delays the processor by an average of 30 ns
.
The maximum reduction in performance is 10% ; under typical
conditions the reduction is negligible.
2 . Memory
4 Kbytes built in static memory provides maximum
data transfer rate of 80 Mbytes/sec. The memory interface is
a 32 bit multiplexed data and address bus. It extends the
internal address capability to a total of 4 GBytes in a
single linear address space.
The non-multiplexed cycle provides timing signals to
drive industry standard RAM's and ROM's. The multiplexed
cycle provides timing signals for RAS 1 and CAS 2 and control
for an external address multiplexer. The interface can also
provide CAS before RAS refresh cycle.
X RAS : Row Address Strobe
2 CAS : Column Address Strobe
17
An asynchronous wait input is provided so that the
memory timing can also be determined externally if required.
MS















Figure 2.1 Memory Interface Driving Static RAM's
Higher performance can be obtained using static
memory. The logic diagram of typical connections to static
memory is shown on Figure 2.1 . The cycle to access that
memory does not require the phases for address multiplexing
and so is completed in 150 nano seconds giving data rate of
25 Mbytes/ second maximum.
3 . Links
The IMS T424 has four standard INMOS links providing
high speed intercommunication between transputer products,
enabling rich variety of networks to be constructed. Each
link operates independently and provides a memory to memory
block message transfer capability between transputers.
18
Each link implements two OCCAM channels. The link
consist of an output and input, both of which are used to
carry data link and link control information. A message is
transmitted as a sequence of bytes.
After Transmitting a data byte, the sending
transputer waits until an acknowledge has been received,
signifying that the receiving transputer is ready to receive
another byte.
The receiving transputer can transmit an acknowledge
as soon as it starts to receive a data byte so that trans-
mission normally continues. This asynchronous protocol
guarantees reliable transmission in spite of possible delays
in either the sending or receiving transputer.
During transmission of a message
,
both sending and
receiving processes will be set inactive, and they will only
be linked to the end of their respective active queues after
the final byte has been acknowledged.
The data rate on each link can be programmed, using
link set configuration channel [Ref. 4]. The highest
frequency is 20 Mbits/sec. giving a maximum data rate of 1.8
MBytes/ s. on a channel.
4 . Peripheral Interface
The peripheral interface provides access to industry
standard devices such as eight bit parallel controllers for
auxiliary memory. The interface controller provides a block
message transfer capability between memory and the periph-
eral interface.
The peripheral interface is an 8 bit bidirectional
bus which may be used to input and output sequences of
bytes. There are two control lines which may be used to
address external devices, and an "Event" input to provide an
interrupt capability.
19
The interface is accessed via four standard output
channels and four standard input channels. All eight chan-
nels use the same 8 bit path and transfer handshake, with
the processor initiating the transfer. The transfers are
synchronized to a separate external clock, which need not
have any fixed relationship with the transputer input clock.
Asynchronous operation is also permitted, but at a lower
speed than for synchronous operation.
Externally addressable devices may be connected via
the peripheral interface. For example, by using one output
channel as the address channel, another as the write data
channel, and one input channel as the read data channel.
Both addresses and data may be arbitrarily long sequences of
bytes
.
The 4 Mbytes/sec. data rate provided by the inter-
face allows the connection of high performance peripheral
chips, without the need for FIFO's or DMA controllers.
The "Event" input may be used to communicate with
waiting processes, and hence cause it to be scheduled. This
provides an input functionally similar to an interrupt, in a
manner consistent with the process model of the transputer.
The typical latency for this interrupt is 600 nanosec. The
"Event" input can also be used to enable the peripheral
interface to respond to being accessed from a standard
microprocessor bus.
B. THE TRANSPUTER SYSTEMS CONCEPT
In the past , system performance has increased regularly
by a factor of ten each decade, Figure 2.2 . This improve-
ment has been achieved by advances in circuit technology and
by increasingly complex systems. For the future, VLSI offers
the potential of much greater circuit complexity but only
modest increases in circuit performance.
20








i hi i mi i rnw) i i ,
ltf io
1








Figure 2.2 Advances in Technology and System Throughputs
The economics of uniprocessor systems are based on the
historical perspective that processing is expensive in
comparison with the memory. This has led to the Von Neuman
bottleneck where a single processor is connected to vast
amounts of memory. The economics of the VLSI are different.
Today
,
a single wafer of silicon can contain 2 Mbytes of
memory or 256 conventional microprocessors.
To exploit this potential, it will be necessary to build
systems with a much higher degree of concurrency than is
currently possible. The transputer is designed as a
programmable component to implement such systems.
In their proposal to achieve intelligent interaction
between people and computers, The Japanese have projected
the need for computers with one thousand times the perform-
ance of present day systems. These will only be possible
using concurrency, and transputer has been designed to make
such fifth generation systems a possibility.
21
Pipelines and arrays of transputers can be used to
provide greatly increased performance by exploiting the
concurrency inherent in many applications. Two examples
which require high performance are signal processing and
database searching. Networks of transputers can provide the
performance needed for both applications.
Signal processing, such as the fast fourier transform
algorithm, maps easly onto a pipeline. The pipeline can
accept the input samples at up to 100 KHz. , which more than
covers the full audio spectrum. A 64 point FFT requires six
transputers in the pipeline, a 256 point FFT requires eight
and 1024 point FFT requires ten transputers. A pair of pipe-
lines, interlinked at each stage, is able to accept input
samples at up to 200 KHz. Higher frequencies can be handled
by using more transputers in parallel. [Ref. 6]
A pipeline or an array can also be used to do searching.
Provided that the search requests can diffuse through the
network, and the answers converge, the shape of the network
does not matter - it can even contain faulty devices. The
full internal memory of each transputer can be searched 1000
times per second. With external memory attached to each
transputer, the search rate is slower, but 64 kbytes per
transputer can be searched at least 30 times per second.
Other applications, such as image processing, finite
element analysis, matrix manipulation, telephone switching
systems
,
fault tolerant systems and artificial intelligence
naturally lend themselves to arrays or networks of
transputers. For example the Array structure has been
proposed for fault tolerant multi transputer systems
,
as
shown in Figure 4.5 .
22
III. SOFTWARE CAPABILITIES
OCCAM is a new programming language. It is designed to
support concurrent applications in which many parts of a
system operate separately and interact. OCCAM is relevant to
many present day applications, particularly those involving
microprocessors and real time applications. OCCAM will be
important for future applications involving the interaction
of many thousands of computing components.
The novelty of OCCAM is in its treatment of concurrency.
OCCAM enables the programmer to express a program in terms
of concurrent processes which communicate by sending
messages through communication channels. This has two impor-
tant consequences. Firstly, it gives the program a clear and
a simple structure as the individual processes operate
largely independently. Secondly, it allows the program to
exploit the performance of many computing components, as
each concurrent process may be executed by an individual
processor
.
OCCAM can capture the hierarchical structure of a system
by allowing an interconnected set of processes to be
regarded from the outside as a single process. At any level
of detail, the programmer is only concerned with a small and
manageable set of processes.
A. OCCAM PROCESSES
A process performs a sequence of actions and then termi-
nates. Each action may be an assignment, an input or an
output action. An assignment changes the value of a vari-
able, an input receives a value from a channel and an output
sends a value to a channel.
23
At any time between start and termination, a process may
be ready and waiting to communicate on one or more of its
channels. Communication is synchronous. When both input
process and an output process are ready to communicate on
the same channel, the value to be transmitted is copied from
the output process to input process. The input and output
processes then continue.
Each channel provides a one-way connection between two
concurrent processes: one of the processes may write to the
channel, and the other may read from it.
A process may be ready and waiting to input from any one
of a number of channels. In this case, the input is read
from the first channel which is used for output by another
process .
OCCAM may be used to program a network of computers.
Each computer with local store executes a process with local
variables, and each connection between two computers imple-
ments a channel between two processes.
OCCAM may be used to program an individual computer. The
computer shares its time between the concurrent processes,
and the channels are implemented by values transmitted in
the main memory. Indeed, a program designed for a network
of connected computers may also be executed unchanged by a
single computer.
B. PRIMITIVES
There are three primitive processes from which all other
processes are constructed, as mentioned in the previous
paragraph.
These three primitive processes given in Table 3 , can
be combined sequentially or concurrently to create more




OCCAM PRIMITIVES AND THEIR SYNTAX
PRIMITIVES SYNTAX
INPUT channel ? variable
OUTPUT channel ! variable




An input process reads a value from the channel into
a variable. The '?' symbol denotes the input process.
This primitive reads a value from the specified
channel. It provides the synchronization with a concurrent
process, which outputs a synchronizing signal on the same
channel
.
An input sets the value of a variable to a value
input from a channel. The input waits until an output using
the same channel is executed in parallel with the input.
A multiple input is equivalent to a sequence of
separate input processes for each variable in turn, in left
to right order. Each input is separately synchronized with
an output process being executed in parallel. Each variable
may be a simple variable, or a word or byte subscripted




An output process writes the value of the expression
to the channel. The symbol '!' denotes the output primitive.
An output waits until an input using the same
channel is executed. It then outputs the value of the
25
expression to the channel and terminates. A multiple output
is equivalent to a sequence of outputs, which writes the
value of each expression in turn, in left to right order.
Each output is separately synchronized with an input process
executed in parallel.
3 . Assignment
An assignment process transfers the value of its
expression to the named variable.
The expression is evaluated and the variable is set
to the resulting value. The assignment process then termi-
nates. The variable may be a simple variable or an element




In many applications it is necessary to do a number
of steps one after another, the flow diagram of this struc-
ture is given in Figure 3.1 .
t t A R T rooass i ppoass ? » proem n nmiNMi
Figure 3.1 Flow Diagram of the Sequential Construct
26
A sequential process takes the form of the keyword
SEQ followed by the component processes, each on a new line,







SEQ ensures that each component process terminates
before the following component process is executed, and
entire process will only terminate after the final component
process has finished.
SEQ is an example of an OCCAM constructor. This
construct (comprising the SEQ and its component processes,
which taken as a whole), can be regarded as a single
process .
2. Parallel
If we require many processes to be running as a
concurrent system, we can construct a parallel process as
seen in Figure 3.2 .
The keyword PAR is followed by a number of component
processes, each starting on a new line and indented, as
shown in Table 5 . The effect is to execute all of the
component processes together, which is achieved by sharing
the processor time between the set of active processes.
27
The parallel construct terminates after all the
component processes are terminated. If there is no component
process the construct terminates immediately.
Two component processes of a parallel construct may
communicate by sending values using a channel. One contains
outputs to the channel, and the other contains the inputs
from the channel. The processes are said to be connected by
the channel. No other component of the parallel construct







Variables are not used for communication between the
component processes of a parallel construct. However, a
variable may be used in two or more component processes,
provided that no component process changes its value by
input or assignment.
In addition to the parallel construct, OCCAM
contains the prioritized parallel construct declared as
PRIPAR. A prioritized parallel construct gives each compo-
nent process a different priority. The first component has
the highest priority and the last component has the lowest
priority. An implementation may restrict the number of
components which a prioritized parallel construct can have.
28
s i * a i
Figure 3.2 Flow Diagram of the Parallel Construct
A prioritized parallel construct ensures that a
higher priority process always proceeds in preference to a
lower priority one. The progress of a higher priority
process is not affected by any lower priority one, except by
communication on connecting channels. If several concurrent
processes at the same priority are able to proceed, each one
is given an opportunity to proceed in turn.
3 . Alternative
Sometimes a process has a number of channels associ-
ated with it and needs to perform one of a number of actions
depending on which channel first sends it a message, Figure
3.3 .
This is achieved using the alternative construct,
which chooses just one of its inputs for execution. The
keyword ALT is followed by a guarded processes, Table 6 .
An alternative process waits until one of guarded
processes is ready to execute. One of the ready guarded
29
INPUTS
_» OUAflO 1 p«oa$s 1
tun
CUAAO 7 pooass f
_4 TIHMIHAH
CUAAO n PftOCZSS n








processes is then selected and executed. The construct then
terminates. A guarded process starting with an input from a
channel is ready if an output process is waiting to output
to the channel. If the guarded process is selected, the
component process is executed. If a guard contains an
expression followed by an input or wait, the guarded process
30
is ready only if both the value of the expression is TRUE
and input or wait is ready. If a guarded process is itself
an alternative construct, then it is ready if one or more
component guarded processes of the alternative construct is
ready. If more than one guarded process becomes ready at
the same time, an arbitrary one is selected, this may occur
if they contain inputs on the same channel.
4 . Repetitive
The repetitive construct takes the form of the
keyword WHILE followed by an expression, followed by a






The component process is executed repeatedly until
the expression evaluates to FALSE, and the construct termi-
nates. If the expression is initially FALSE, the process is
not executed and the construct terminates immediately,
Figure 3.4 .
5 . Replicator
A replicator is used with a constructor to replicate
the component process a number of times, Table 8 . A repli-
cator can be used with a parallel construct to construct an




f »<f WMUE pooass
FAlS£
TERMINATE
Figure 3.4 Flow Diagram of the Repetitive Construct
alternative construct for reading from an array of channels,
and also can be used to provide a conventional loop with
sequential construct.
The replicator declares an identifier to be the
replicator index, giving its base value and a count of the
number of replications required. Its effect is to form a
sequential, parallel, alternative or conditional construct
containing count components by replicating the component
process, substituting successive integer values for the
replicator index (starting at base). The substituted value
for the replicator index in the last component will be
(base + count) - 1.
The replicator index can be used in expressions but
not constant expressions, it may not be changed by assign-
ment or input. An implementation may restrict the values of
base and count to be constants, particularly when a repli-
cator is used to a form a parallel construct. If a count
evaluates less than zero or equal to zero, then an empty
construct is generated. This has the effect of termination














Figure 3.5 Flow Diagram of Replicator Construct
effect of never being ready to execute for alternative
processes. The flow diagram of this construct is shown on
Figure 3.5 .
6 . Conditional
A conditional construct takes the form of an expres-
sion followed by a process, and it is able to execute if the
expression evaluates to TRUE. The syntax form is shown on
Table 9 . A conditional construction takes the form of IF
followed by component conditionals which is able to execute









The conditional process executes the first component
(textually) which is able to execute, and then terminates.
If there is no component able to execute, then the construct
terminates with no other effect . At most one component is
executed, Figure 3.6 .





Figure 3.6 Flow Diagram of Conditional Construct
34
D. CONFIGURATION
Configuration is used to meet speed and response
requirements by distributing programs over separate, inter-
connected computers, and by placing and prioritizing
processes on single computers.
Every computer has local store and a set of numbered
ports. A physical connection between two computers connects
a port on one computer to a port on the other computer. This
implements up to two channels between the computers, one in
each direction.
A parallel construct may be configured for a network of
computers. Each computer executes a component process, and
port allocations are used to allocate channels to ports.
A parallel construct may be configured for an individual
computer. The computer shares its time between the compo-
nent processes, and the channels are implemented by values
in store. Indeed a parallel construct configured for a
network may be reconfigured for an individual computer.
A parallel construct can be used to provide prioritized
component processes, and an alternative construct can be
used to provide the prioritized input primitives.
The allocation of processing resources to the concurrent
processes in a program does not affect the logical behaviour
of the program. Simple implementations may omit or ignore
some or all the configuration facilities.
35
IV. SYSTEM STRUCTURE
A. FAULT TOLERANT SYSTEM
1 . Obj ectives
A designer may have multiple objectives for a redun-
dant system. However, central to the theme of fault toler-
ance are those of,
a. Availability
The average probability that a system is func-
tional at any given time.
b. Error Rate
The average rate at which a system's output
makes a transition to an unacceptable state.
c. Reliability
It is described as a mean time to failure for a
system. The average length of time a system retains some
operational utility without external maintenance.
d. Dependability
It is a statement of system availability through
a specified period of time and is a function of availability
and reliability.
e. Maintainability
The average period required to return the system





The explicit recognition of a system to facili-
tate realization of future changes.
2 . Fundamental Aspects
There are three kind of failures for a system which
produce a anomalous condition or function.
Limited "normal" environmental failures that causes
components to weaken or break over for a long period of
time
.
Abnormal environmental failures, disrupting compo-
nents in a short time or propagating faults introduced from
outside of the system.
Man made, hardware or software design flaws, man-
machine interact ion/ interface disruptions or deliberate
invasion [Ref. 7].
Malfunctions are anomalous conditions resulting from
threats. These include physical malfunctions (component
failure), signal or logic level malfunctions (faults), data
level malfunctions (errors), control breakdown and system
level malfunctions (catastrophic failures).
Fault classification consist of three dimensions:
a. Duration







Temporary failures are the ones most difficult to
detect in real time systems.
37
A transient failure is a nonrecurring temporary
failure usually caused by fleeting phenomena such as radia-
tion, noise and power fluctuations.
An intermittent failure is a recurring failure that
reappears on a regular basis, often caused by critical
tolerances in timing or electrical signal levels. If an
intermittent failure is present in a circuit, it may be
'active' at one instant or 'inactive' at another.
Fault tolerant systems resist threats and surmount
malfunctions in various ways. Active redundant systems
attempt to observe malfunctions and then substitute elements
(hardware or software) as required, with a possible inter-
ruption in service. Passive redundant systems, often using
more resources than active systems, form the correct output
based on a consensus of actively redundant elements, with no
need to observe the malfunction. Hybrid redundancy combines
advantages of active and passive systems by observation and
substitution. Self purging systems take advantage of the
same techniques through observation and deletion of all
failing elements on line. In active redundant systems,
substitute elements require testing, else they may be
useless when needed. In passive systems, consensus mecha-
nisms are a prime candidate for latent faults.
3 . Techniques
The key to successful application of protective











Methods of introducing hardware redundancy may
be divided into two categories, on the basis of terminal
activity of the modules.
Static : This method is also known as "masking",
since components are employed to mask effects of hardware
failures. Three forms of static redundancy have been used in
practice; component replication for individual electronic
components, triple modular redundancy (TMR) with voting for
logic circuits or larger modules of a computer, and quad-
ruple modular redundancy, where four processing elements are
used in place of one element. The four elements are paired
in two elements per board. The results of each processing
step are compared within a board. If the results are found
not to compare, the board is declared "faulty", and its
results are not permitted to propagate in the system. The
board in which the results compare is continuing the opera-
tion alone until the faulty board is replaced and normal
operation resumed.
Dynamic: In this hardware redundancy approach,
fault caused errors are allowed to appear at the terminals
of a module. Fault tolerance is then implemented by two
consecutive actions. First, the presence of a fault is
detected and then a recovery action either eliminates the
fault or corrects the error which was caused. Redundancy
within the operational system is therefore introduced in a
selective rather than massive fashion.
Application of dynamic redundancy requires that
a number of design choices be made in the functional design
stage
.
(1) Modularization . The designer must define
a modular architecture with emphasis on a minimal number of
connections while trading off desired partitioning.
39
(2) Fault Detection . The objective is to
select real time, concurrent fault detection methods. These
methods are error codes, status signals, duplicated opera-
tions, internal monitoring of critical events, completion
signals, watchdog timers, reasonable checks and totally self
checking circuits.
(3) Recovery Actions . Upon detection of the
fault, a recovery procedure must take place. If a program
restart fails to correct the error, a permanent fault is
assumed.
Reconfiguration is a case of replacement
in which if a spare is not available, then the processing
capability of the machine is decreased, and a decision must
be reached concerning: which programs require a lesser
degree of survivability, when graceful degradation of
processing capacity is acceptable, and a minimum processing
capacity is desired prior to entering a safe shutdown mode.
(4) Inter-module Communication Choice . This
is a major tradeoff in dynamic systems. Alternatives are bus
communication and direct module to module paths.
b. Software Redundancy
Software redundancy includes all additional
programs, program segments which may not be included in a
computer with fault free hardware. Major forms of software
redundancy are.
- Multiple storage of critical programs and data
- n-version programming
- test and diagnosis programs
- Fault tolerant features
- recovery mechanism
Compared to hardware redundancy, one advantage
of software redundancy is the ability to superimpose fault
tolerance on "off the shelf items". Another advantage is
40
ease of modification and refinement. The main disadvantage
is difficulty of assuring that software will be able to
function correctly after a fault occurance or that it will




This form of redundancy consist of repeating or
acknowledging machine operation at various levels:
Microoperations , single instructions, program segments or
entire programs. Usually the distinct goals are fault detec-
tion by means of repeated execution and recovery by restart
or operation reentries.
A common use of time redundancy is found in
identification and correction of errors caused by transient
faults, and in program restarts after a hardware reconfigu-
ration. This is accomplished by repetition of single
instructions, program segments or entire programs.
All these methods may be conveniently grouped
according to time of their application with respect to
normal system operation.
(1) Initial Testing . Which takes place prior
to the normal use and serves to identify elements containing
imperfections introduced during production.
(2) Concurrent Detection . Which takes place
simultaneously with normal operations. This is implemented
by variety of error detecting codes.
(3) Scheduled Detection . Which takes place
when the normal operation is temporarily interrupted to test
for faults and may be similar to initial testing with the
main difference being limited time and a "self test"
approach.
41
(4) Redundancy Testing . Which serves to
verify that various forms of redundancy are themselves fault
free and ready to act.
B. MULTIPROCESSING CONCEPT
Multiprocessing systems are being, and will be used in a
large number of applications such as control of electric
power generation, distribution, and consumption, nuclear
power processing facilities, safeguarding and control,
healthcare delivery in hospitals and medical centers,
climate control, security, waste disposal and fire protec-
tion in large buildings, and largely in defense systems.
Why are multiprocessor systems useful in all these
applications? The reason is several; They usually make it
easier for the user to access the system, they generally
provide increased performance through resource sharing, and
they often increase the availability of a system. A network
of microprocessors can quite often duplicate the capability
of one large expensive system at lower cost. Multiprocessing
systems can provide adaptability and rapid reconfiguration
with the system functioning at different times as a very
large and complex problem solver or as a network of smaller
machines each dedicated to a unique task, or as something
between. They can usually also provide increased reliability
since the total system can continue to operate despite indi-
vidual processor failures, albeit with reduced capabilities,
provided that some of the links between the processors
remain intact. Also, since redundancy can be achieved at a
lower cost using processors distributed over a large area,
the survivability of the system, particularly in military
applications can be increased. Furthermore, a distributed
processing system can provide increased, distributed power
and responsiveness because it can be closely tailored to the
42
application. Additional multiprocessor systems can be
provided as needed, to ensure proper response time.
Multiprocessor systems can also be designed to be cost
effective when applied to a wide variety of applications,
where the number of processors can be determined by the
distributed processing requirements. A properly designed
distributed processing system threatened by overload can be
incrementally expanded by simply adding more processors.
The disadvantages may or may not outweigh the advan-
tages, depending on the system-unique requirements. On the
minus side, the designer may be faced with increased soft-
ware complexity. Application software may be more costly to
develop for a distributed than centralized system. In
contrast to a single central processor based system with
only one executive, a distributed system typically requires
each processor to contain its own, individual executive that
must be capable of communicating with all the other execu-
tives in the total system. This, in turn, will require that
each individual executive provides a task handling capa-
bility where task resident in various processors can
communicate with each other, and, in case of local software
or hardware errors, diagnostic capabilities exist to
localize "bugs". This is not to say that diagnostic or error
checking software is not needed or used in large central-
ized, single processor systems; however, the diagnostic
software development for a distributed systems is usually
more difficult and costly.
A distributed processing system, by definition, is also
more dependent on communication technology, particularly
where the computers are widely dispersed and the peak
traffic demands between the computers are high.
Finally, the design and development of a unique distrib-
uted processors system may require expertise both in
hardware and software areas. The advantages and
43
disadvantages of the distributed multiprocessing systems are
given in the Table 10. [Ref. 8]
TABLE 10













The purpose of this implementation is to establish a
multiprocessing system which provides fault tolerance using
a new VLSI product, the T424 transputer microchip. Before
the design, the following techniques and methods are assumed
for the system.
Structural hardware redundancy
- Functional software redundancy
- Operation time redundancy
Using more computing elements will provide for both
multiprocessing capacity and hardware redundancy. The number
of computing elements in the multisystem is chosen as
sixteen. The purpose to choose that number for the proto-
type system is briefly described in the following sections.
Functional software redundancy and operation time redun-
dancy is provided by a fault tolerant operating system
design, which is explained later in this chapter.
44
As described in Chapter II, the hardware provides four
communication channels to use in a system configuration,
therefore possible system constructions may be listed as
following
.
a. Pipeline / Ring Structure
This structure consist of each computing element
connected to each other with two channels, which also
provides redundancy for communication channels between two
computing elements, as in Figure 4.1 .
"
PA 1 Pfl 1 Pfl ) PH f\
Figure 4.1 Pipeline / Ring Structure
b. Tetragonal 3-D Construction
In this structure each computing element is
connected to three elements and they build a new computing
group which still has four available communication channels
for other computing group connections, Figure 4.2 .
This structure is one of the basic structures
that can be found in many kinds higher level of structures
also. For example, the matrix structure in Figure 4.4 can
45
use the tetragonal structure as a computational element
which is connected the four neighboring elements.
Figure 4.2 Tetragonal 3-D Construction
c. Butterfly Construction
This is a special implementation of a pipeline
structure, which is a good solution for the fast fourier
transformation or similar engineering applications, Figure
4.3 .
d. Matrix Construction
This structure consist of the connections of the
computing elements to each neighboring element in two dimen-
sions. There is no further channel redundancy between two
computing element but it provides very large number of
communication rings and multiple communication paths. This
structure will be described later in this chapter in detail.
Basic structure of this type is given in Figure 4.4 .
The matrix structure has been chosen for the
proposed prototype multiprocessing system. The basic reason
46
Figure 4.3 Butterfly Construction
t
n t\ ,i
•* 11 m » U m m 13 « » l« »•
li n n
*— ' » » 7? 23 » » *« —
*
II i W "
Figure 4.4 Matrix Structure
is that, providing multiple communication paths gives many
application orientation possibilities. Many communication
rings can be implemented in this kind of system, or pipeline
type of processing also can be applied.
47
The number of processors is determined by the
number of rows and columns contained in the matrix. To
provide symmetrical structure, the square matrix is a solu-
tion. Hence the probable number of computing elements would
be 4, 9, 16, 25 and so on.
The number 16 is chosen to build an intermediate
prototype multiprocessor. The result of previously
discussed design assumptions lead us to the following













13 14 1! 11
~T T T T
Figure 4.5 The Structure of the Mult itransputer System
48
D PROPOSED OPERATING SYSTEM
In the previous section the mult it ransputer systems have
been described, and in this section the operating system to
be used in the prototype mult it ransputer system will be
described. This operating system includes both multipro-
cessing and fault tolerance features.
Basically the proposed system includes three main parts:
Fault Tolerance Controller, Sequencer and the Link
Controllers. These operating system processes work to
control the user processes to provide the above mentioned
features of the mult itransputer system. The prototype oper-
ating system structure and its internal connections are


















Figure 4.6 Prototype Operating System Structure
a. Fault Tolerance Controller
That subsystem of the operating system includes
self check programs, diagnosis programs, watchdog timers,
hardware fault tolerance interfaces if provided and others.
These processes will be activated by means of fault
49
detection or run time control. The entire fault tolerance
process holds the first priority level among all other
subsystems and processes
.
The fault tolerance system has not been designed
in this thesis, but there will be a high level structural
design, a description of its role in the operating system
and some suggestions in this section.
The main purpose of this system is the diag-
nosing and recovering from the errors, which are found both
in other systems or in self check processes of the fault
tolerance system.
The system inputs come from both link controller
subsystem, sequencer subsystem and the fault tolerance
system timers or hardware interfaces. The diagnosis or
recovery processes must be designed to satisfy the basic
objectives of the fault tolerance which are reliability,
maintainability and dependability. The system outputs
consist of sequencer and link controller outputs, which are
used to reconfigure the multiprocessing system and system
operation.
b . Sequencer
This subsystem of the operating system provides
the multiprocessing system organization. In other words, it
determines which particular transputers execute which user
processes. Most probably inputs will be both fault toler-
ance inputs (hardware reconfiguration for particular
transputers) and link controller inputs. The link
controller provides the communication between other
transputers sequencer systems. Therefore the system reco-
nfigurations will be known to the sequencer subsystem.
Probable processes of this system will be some
communication protocols for other sequencer subsystems and
organization of the processes, such as cancelling some oper-
ations or restarting others.
50
c. Communication Controller
The communication controller subsystem will be
explained next in this chapter in detail. The main task of
this subsystem is to provide inter and intra communication
between processes, systems and transputers. It will also
provide a fault detection feature during communications,
using watchdog timers and acknowledging techniques.
E. COMMUNICATION SUBSYSTEM DESIGN
1 . Design Obj ectives
As described in the previous paragraph, this
subsystem handles the inter and intra communications between
processes. These processes could be either user processes,
sequencer processes, fault tolerance processes or, if we
have, other processes.
"Before we explain the design details, it is better
to give some conceptual ideas about this system. In the
multisystem, Figure 4.5
,
transputers are connected to each
neighbor in two dimensions, therefore we may use delay
insertion loop or token passing type of communication proto-
cols [Ref. 8]. In this design some features of both types
of communication has been used to obtain maximum efficiency
and redundancy for failures.
A second feature of the communication protocol is to
provide error detection, which is achieved using both
acknowledging and watchdog timer techniques.
To explain the communication subsystem design, the
simple process structure of that system will be explained
first. As seen in Figure 4.7
,
the communication process
accepts inputs from both hardware channels (links) and soft-
ware channels. These inputs cause the activation- of the
proper communication process. Execution result will be
51
another output from either hardware channels (links) or from
software channels. This procedure provides the communica-









Figure 4.7 Communication System I/O Block Presentation
The communication subsystem has two input groups and
two output groups, therefore there will be four different
communication types. These are simply described as, from
outer transputer to outer transputer (by-pass), from outer
transputer to inner process (internal distribution), from
inner process to outer transputer (external distribution)
and from inner process to inner process (short-cut).
In this communication protocol the token has been
used to determine receiver process in the system. The token
is the leading byte of the message, which includes the
message type, receiver transputer number and receiver
channel number information. This token is produced by the
communication system itself and also is used by same the
system to determine the communication type. The token has
been named as CODE for implementation. The CODE is a sixteen
bit word two's complement integer in the range -32768 to
32767
52
After a brief explanation of the subsystem, the
design requirements can be listed as follows.
a) Listening to all links and user channels
b) Determination of the communications type
c) Transmission through the proper channel or link
The communication system design is shown in Figure
4.8
,











Figure 4.8 Detailed Structure of Communication Subsystem
a. Receiver
Listens to four hardware links and receives both
CODE and the following DATA, if it exist, and activates the
decoding process. In case of receiving errors, the fault
tolerance system is activated.
53
b. Decoder
Determines if the communication type is a
by-pass or an internal distribution, and if it is the




Sends the activation signal or data taken from
both the encoder or decoder to the appropriate process.
d. Listener
Listens to all user channels and receives the
data or activation message.
e. Encoder
It is activated by the listening process and
determines the CODE according to the multiprocessing config-
uration provided by the sequencer subsystem. Both transmit
or send channels are activated dependant on whether the
communication type is distribution or short-cut.
f. Interface
Determines the logical path to send the message
to the desired transputer. It uses the hardware configura-
tion which is provided by the fault tolerance subsystem.
g. Transmitter
Transmits the messages through links to other
transputers using acknowledgements. Uses the link number
determined by its interface process and activates the fault
tolerance system in case of transmission problems.
54
h. Duplexer
Closes the receiver during transmission to
prevent the system from false communication.
2
.
Implementation of the Communication System
Before starting to explain the details of the imple-
mentation a brief explanation will be given about CODE (or
token) used in this system.
As described before, CODE consist of a two's comple-
ment binary sixteen bit word, which can take on the maximum
positive decimal value of the 32767. The first digit of the
five digit code represent the type of code. In other words,
this digit shows whether there is following data or not. If
this digit is zero, that means there is no data following
the code. If it is 1,2 or 3 data will be assumed to follow.
The next two digits are used to show the process
number in case of data not exist. Therefore we can use 99
operating system processes within this system. If the infor-
mation sequence includes data in that case process number
will be determined by first 3 digit, in range of 100 - 327,
or we can use 227 user processes within this system.
The last two digits show the transputer number to
receive that information sequence. Therefore possible
transputer number in this system can be 67 maximum. These
values and their meanings are shown on Table 11 .
a. Receiver
The OCCAM program of this subprocess is given in
the Appendix A. This subprocess has five inputs and one
output. All channels used in this process are bidirectional
to provide an acknowledgement procedure. The processing of
this subprocess can be separated into three portions.
55
TABLE 11
CODE AND THE MEANINGS OF THE DIGITS
max . code value 3 2 7 6 7
without data P p t t 8 : process no: transputer no
with data X q q t t
X : 1,2 or 3
no : (x-l)qq
: transputer no
The first process is to WAIT for an external
message event. This is achieved using alternative structure.
All guards are inputs from the hardware links. When an input
event occurs, the variable ACTIVE. LINK is assigned to the
corresponding link number. This variable is used to make a
handshake through the same channel. Also it is used in the
interface process to determine the shortest transmission
link to reach the destination.
The acknowledgement signal is sent through the
active link in the second portion of this subprocess. Also
the code type is determined to find out if data exist
following the CODE. If data exist, it is received in the
same manner as CODE. When the receive process is completed,
the decoder process is activated and the receiver process
waits for the synchronization signal to prevent the system
deadlocks
.
Another task of the receiver process can be
named as "close receiver". The purpose of this process is to
prevent the system from deadlock during the transmission
process, because both the receiver and the transmitter
processes use the same hardware channels at the same time.
56
"Close receiver" is achieved by the duplexer
subprocess. This process sends the "close receiver" signal
through RECEIVER. OFF channel. When this signal is received
by receiver, the variable WAIT is assigned as TRUE. This
assignment causes waiting for the next synchronization
signal from the duplexer, which occurs at the end of trans-
mission procedure. Wait function will be disabled, before
the program starts to wait for the external input through
the links.
b. Decoder
This subprocess has one input and two outputs.
It is activated by the receiver process and the transputer
number of the code is determined by looking at the last two
digits. The next step is to decide if the communication
type is internal or by-pass. According to the communication
type either the sender process or the transmit interface
process is activated. After each activation, the process
waits for a synchronization signal from the activated
process. The last step before the termination of the
process is to send a synchronization signal to the receiver
process. The OCCAM program implementation of this process
is given in Appendix-A.
c. Sender
This subprocess is activated either by the
decoder process or the encoder process. The only task of
this process is to send the message to the specified user
process (or operating system process). Before the termina-





This process consists of repetitive alternative
constructs and guarded processes which are reading from the
user and/or operating system processes. When the input is
taken from any one of these channels, the encoder process is
activated to continue the communication procedure. The
listener process waits for acknowledgement from the encoder
process to terminate itself.
e. Encoder
This subprocess is activated by the listener
subprocess. The first procedure is to determine the
receiving transputer number. This is achieved using the
PROCESS . TABLE provided by the sequencer subsystem.
The next procedure is to determine the communi-
cation type (either external distribution or short-cut).
This is achieved by comparing the target transputer number
with the number of the "own" transputer.
In case of a short-cut, the send subprocess is
activated to send the message to an internal process. If
the message is targeted to an external transputer's process,
then a code word is computed for either with data or without
data cases, and the transmit interface subprocess is acti-
vated to send that information through the proper hardware
link.
The synchronization signal is waited from the
interface process before the termination. After that signal
is received, the listener process is released by synchroni-
zation signal and process terminates.
f. Interface
This subprocess is activated either from the
decoder or the encoder depending on the communication type.
58
The main task of this subprocess is to determine the logical
and the shortest link number to reach the destination. This
is achieved using distance tables and the hardware status
table. The distance tables for the first, second and third
priority levels are given in the Appendix C. The basic idea
is to compare hardware status of the chosen link to reach
the specified transputer and continue the comparison to find
the available link. If the communication type is a by-pass,
then the link number must be chosen differently from the
active link. In other words, we can not send the same
message back through the same channel again, which causes
system deadlock.
After finding the proper link number, the trans-
mitter subprocess is activated to transmit the message. The
acknowledgement must be received before the synchronization
signal is sent to the encoder or the decoder subprocesses
and the interface process terminates.
g. Transmitter
This subprocess is activated by the interface
subprocess and after receiving the necessary parameters for
transmission, the duplexer subprocess is activated to termi-
nate the receiver subprocess to prevent ourselves from a
deadlock and faulty communication. When the duplexer
subprocess gives the "receiver is closed" signal, the
transmit interface subprocess is released by the synchroni-
zation signal. The transmission procedure continues in the
same manner as the receiving process. After transmission is
completed, the duplexer unit is activated to release the
receiver process, and transmit process terminates.
h. Duplexer
As mentioned before, this subprocess provides
closing and opening of the receiver during the transmission
59
cycle. First it waits for the event message from the trans-
mitter to send a close message to the receiver. Then it
acknowledges the transmitter when the "receiver closed"
message is received from the receiver subprocess. After that
the duplexer waits to get "transmission completed" message
from the transmitter process and sends the "open receiver"





In this chapter the performance of the communication
system will be evaluated. The first step is the calculation
of the subprocesses execution times for different cases. For
example, the execution time of the sender process will be
calculated both for the decoder activation and the encoder
activation separately. This calculation will allow us to
calculate the total execution times of the different types
communications
.
A.. SUBPROCESSES EXECUTION TIMES
Table 2 is used to evaluate the execution times of the
processes. For a particular system application, IMS 1400
static RAM and IMS 3630 erasable ROM are assumed as external
memories. Therefore, in order to calculate additional
external program and data access times, the access times of
these memories are used [Ref. 4].
As an example, the receiver process execution time will
be calculated. The method that has been used to calculate
the execution time is taken from [Ref. 6]. The calculation
table includes every type of construct, evaluation and
operand in the OCCAM. By inspection of the receiver program
in Figure 5.1
,
the calculation table can be filled as
follows
.
The receive process contains the alternative construct
with 5 guard processes, 5 conditional branches, 1 replica-
tive construct and no parallel construct.
During the execution there will be 2 parenthesis, 11
constant, 13 variable and 10 vector variable evaluations.
61
The receive process executes 5 input and 3 output primi-
tives (maximum case). The number of arithmetic operations













































nk[act ive . link] ! ext . code
nk[act ive . link] ? acknowledge





















decode . advance ! ANY
decode . advance ? ANY
NOT acknowledge
fault . links [rev . trouble] ! active. link
Figure 5.1 The Receiving Process
These counted values provide the quantities for the
calculation table. Subtotals are found by multiplying the
quantities with their execution times, and the summation of
62
these subtotals gives us the total execution time of the
receiver process.
In the following section these calculations will be used
to estimate the worst case communication performances. Some
of these results may have larger values, but actual execu-
tion times will not be greater than calculated execution
times
.
The following thirteen tables show the instruction types
of the processes and their execution time calculations. In































Pi O u-i o
C o O O CM i—
i
• O O H on o o r-l rH CM
Pm O r-l O O O rH ON




PL, PiO m o <! o O
H On r^ PL, r-l CM CM
cm 00 £ CM <f
J O w P r-l m O
w o •J U
J r-l PQ O
J 1 <J <t m CM
p2 to
1 O H i-l i—i oo
Pi m O








• C O <uQ m H CM r—
1
CM




















• r-l o 53 vO •—
v
H + <r W 00 CM m •dJ C m ON Pi r^ r-l i m c
<: o v£> <! - o i o o






!3 RjH >* J O >< J W ix J co ix J eU H < H H <J > H <: P H < >
—
P H H H rH H H H H 53 H H
Pi H O <; H O H H o 3 H O JH a: H p 2 H H 13 H 53 H <;
to < PQ j < PQ £ < PQ W <3 pq H
s P P <3 P P H P P Pm P P O







































erf O m m
o O O I—
1
o
• O o H on P H r-l
Pm o r-l o u o i O
W vd \£> W <f H
Prf >
P
Pm WO H O erf o
H on o> < ^ 1 O
CM CM Pm CM
J o w P r-l i—
1
£
w o J Op r-l PQ O CJ
J 1 <3 <r CM
prf m









• c o <3Q o H cm O
525 O CM I—
1
CO vf to t—
1



















• I-l o S3 / ••H + <r W 00 i O T3
J C LO o> erf r^ I IT) a
<J o M3 <J - O 1 o o






H >< p O >H J W >H J CO >H J C
CJ H < H H < > H <d Q H < 1—
'
P H H H H H I-l H H S3 H H
erf H o <J H O H H O 2 H O JH Si H P 2 H H S3 H 2 H <
CO <C pa. J <J PQ £ < PQ W <J PQ H
S3 P P <J P P H P P Pm P D O





















<: <f o <r
H o oo <1- o CM
o o oo r> CM




Ph o m i oO O o
• O o H ON J r^
Pm o r-l o U O 1 oW o \D u <r H
Pi >
P W
Pm PiO O <J oH on CO r>- Pm r-l
CM oo £ CM i o
J o w P H CO o
w o J UJ H CQ <f O
J I <3 <f 00
e2 m






















• l—l 53 <*->
V
H + W oo T3
-J C 1 o Pi r^ i o 1 LO C





!3 cdH >^ hJ O :x J U >H J CO >> J C
u H <J H H < > H < Q H <J ^P M H H H H H M H S H H
Pi H O <: H O H H O <£ H o JH !Z5 H p z H H Z H Ph Z H <
CO <: P3 j <3 PQ s <«i pa W «! pa HZ p P <: P 3 H p P Pm p P O






























<! o 1-1 i—i









Pi u mO o o i o
• o o H os OS P H




Pm PiO O <j o
H cs i—l OS Pm i-i i o
CN CN £ CM
J O W P -I i—l O
w o J CJJ 1-1 PQ O

























o 53 CM m
<f • H CM
OS o H H
• i-l <f SB <~~*
H + v£> OS W 00 T)
P C r>» r^ Pi f^ i O i m C
<1 o ro r> < « o i o o






H >H J O >H P W >H P CO >H p cU H <d H H < > H < Q H <l ">—
'
P H H H HH H l-l H H S3 H H
Pi H o <3 H O H H O 2 H o pH SB H P SB H H 2! H SB H <J
co <S pq J <J PQ S <3 PQ u < PQ H





































Pi u mO o o 1 o
• o o H on J H
Pm O pH o u o i o




Pm PiO o <: o o
H on CM oo Pm rH r-l r-l
CM u-> £ CM CMJ o w P r-l CM O
w o -1 U
J H PQ o OJ i < <t o <d-
« m
i o H i-l r-l i—i
psj n CO
<J en <






• C <:Q o H CM <f
SS O i—
1
U~) CO <J" CM 00O m m SB r-l CM _^-












o SZ CM m
<r • r-l CM
on H H
• i-H Ss .-—
V
H + W oo NO T)
J C i o Pi r*. CM IT) I u-| C








H !* J o >< J W >-• J CO >H J CU H < H H «i > H <d Q H < ••—
'
P H H H H H H H H S3 rH H
Pi H O <3 H O H H O 3 H O JH SB H P IS H H SB H SB H <J
co <3 PQ J <! PQ s <! PQ w <s PQ H
SB P P O p P M P P Pm p P O






































Pi o mO o o i O
• O o H on P r-l




Cm PiO O < o
H on CM 00 P-l r-l O
CM m S CM CM CM
P O w P r-l CM o <fW O P u
P H pa o O
J i <! <t- o <r
pd m







• C <dP o H cm CM
S3 o CM o to <r r-l o-O m T—l Z H r—
1
^

















o Z CM m
•<f • r-l CM
ON H l-H
• r—l S /-N
H + W 00 r-l 00 T3
J C i O Pi r^ r^ 1 u-i C
<: o <J - O 1 o O





H >H J o >H p W >* J co < J C
CJ H < H H < > H <d P H < *—
'
P H H H H H r—l H H 2 H H
peS H O -< H O H H O
a
H O P
H 23 H P !25 H M Z H 2 H <d
CO O PQ P <J pa s <J pa w <J pa H



























<J on <rH o r>. o m ONO vl- ON r«s o m




Pi O to o
o o o r-l I—
1
• O o H o> ON P H
Pm o r-l o CJ o r-l o
W vo NO w <t <r H
Pi >
P W
Pm PiO o <J oH ON CM 00 Pm r-l 1 o
CM m S CM
P o w P H CM O
w o P UJ r-i pa o Op 1 < <f r>.
w m








• C o <J
P o H cm
53 O CM r—
1
co <j- i o








ON\ r-l 1 o
ON r-l ON










H + o W 00 T3
P c CM <r Pi r^» i o I LO C
< o ON <! - O 1 o O






H >* p o >H P w >H P co r-l p £u H < H H <i > H «! P H <*p H H H H H H H H S3 H H
Pi H O <i H O H H O <j H o JH S3 H P S3 H H S3 H Ph 2 H <i
co <J PQ -1 <C pa E < pa w <2 PQ H

































o ON <rH o r^ o LO ONO <f ON r^ o m
H SO
e




P* o m o
o o o i—l —I
• O o H on ON p 1-1
Pm O H o u o i—l o




Pm P4O o <J o
H on CM oo Pm r-l i o
CM m £ CM
•J o w P H CM o
w o J uJ l-l pa o O
J 1 <J <f r*s
« m











• C o <3
P o H CM

















• 1-1 25 '—
\
H + o W oo T3
P C CM <r Pm1 r-^ i o i m C
<3 o ON <i « O i o o






H >H P O >- P W >H P CO >^ J GU H < H H < > H <J Q H <u •—*
P l-l H H H H l-l H H 25 H H& H O <J H O H H O 2 H o JH 25 H P 25 H H 25 H 25 H <3
CO «i pa J o pa s O pa W < pa H































<J o r-l o rHH tn CM o l—l <rO r-l CT> vO CM <r
H r-l CM ON
U
H
P^ O mO O O i O
• O O H on o> J rH
Pm O r-l o U O r-l O





Pm PiO o < o o
H on CM 00 Pm r-l r-l
CM m £ CM t—
I
CM
J O w P H CM OW O J U
J H PQ CM OJ i <J <r i—
I
W LO











p o H cm











o 23 CM m
<f • r-l CM
on H H
• r-l 2= .•—•.
H + W oo Xi
J c i O PC r^ 1 o i m c








H >H rJ O >H rJ W >> J CO >H J CU H <J H H < > H <3 P H < —
'
D H H H i-l H I-l I-l H 2= rH H
Pd H O <J H O H H O
a
H O JH 25 H P 2= H H 2= H 22 H <1
t/) <3 CQ J <H pa £ <d PQ w <C pq H


































Pi O m i—l o
o ON O O r—
1
• o O H on o J r-l




Pm PiO o <J o O
H on CM oo Pm r-l o- <f
CM in £ cm CO
J o w P H CM O
w o J UJ H PQ <r OJ i <: <s- \n CM
pi m









• C •<Q o H CM 00
5a o <f o CO <r <f vO
o m CM S3 rH m *>*














o S3 CM in
<r r-l CM
ON H H
• H S3 <—
>
H + W co CO T3
J C 1 O Pi hs H r^ i m m c
< o <! - o i—l o o





H >< J O Sh J W >H J CO Sh 1-1 e
U H < H H <: > H < O H <; ^—
'
P H H H H H H H H S H H
Pi H O <l H O H H O
s
H o hJ
H S3 H P 2 H H S2 H S3 H <J
(/i <J PQ •J <* PQ s < PQ u <J PQ H
S3 P P < P P H P P Pm P P O

















































Pi O u-i oO <t- O O <r CM
• O r-l o H on Ll~| P rH <r
P-i o o u o NO <f




Pm PiO O <C oH On 00 Pm r-l
CM CM u-| £ CM i i
J o w P H CM O
w o J CJ
P H pa <d- OJ i O o- NO no
pd m



















o S3 CM CM m





H + o W oo NO NO T)
P c CM o- Pi r^ <r 1 LO c
< o QN <d - o i o o





S3 a3H >H P O >M p W >M P CO >H p C
u H <! H H <J > H <! O H < ^^
D H H H H H H H H S3 H H
Pi H O <J H O H H o 5 H O PH 2 H P |Z5 H H S3 H S3 H <
CO <; pa J < PQ £ < pa w <3 pa H
SB P P <J P P H P p P-I P p OO o- CO > O" CO Pi o* co o o» CO HU W PM
74
J
<J oH ON m O COO I—
1










S3 Pi o m mO O CO o o H OH • O o H on no J H i-l
H P* O H o CJ o r^ CO





to H on CM 00 P^ i-l
CO CM IT) £ CM i O
W J o w P rH CM OU u o J u
o .J r^ PQ o o
tf J 1 <! <T o CO
en p..
PS lO
i o H r-l CM CM
CM Pi m NO
Pi <! ro <3
W w Pm <j- >
•J p i-H
PQ o o






P o H CM
S3 2 O ro m CO <}• i oO o m vO S3 H ^M cj m r-l O H o






<J P< o O
pM ON co
w o S3 CM cm m








H H + O U co i o T3M J C <N <f Pi r^ i m C£ <J o ON «! - o i o oW o
o
I—




S3 dH >H -J o >< J W >H -J CO >H J C
u H <1 H H < > H <J p H <J >—
'
P H H H H H H H H S3 H H
Pi H O <J H O H H O 2 H O JH 2 H P 525 H H S3 H S3 H <d
CO «i PQ J < PQ £ <J PQ w <! PQ H
S3 P P «<! P P H P P Ph P P O
















PS" o "~i o
o LO o o CM rH
W • O o H on o- rJ rH CM£ Pm O r-l o U O UP) oM W MD NO u -J- CM H
H Pm" >
P3 WO Pm PiM o O < o OH H on m Pm rH ro
P CM m <t 2 cm ro NOU J O u P r-l v£> O
u w o r-l rj
X) hJ rH P3 CM O
w J i <d >* oo ON
<r
« m
1 o H rH cm l^x
CM CO Pd ro oo
co <! ro <JW w Pm <f >J u i—l
PQ o o
< & •!< m i OH Ph
u




H o o H cnJ <j-H 53 O NO ro CO <f CM ooH O >0 ro 25 r-l CM ^»-
s u m O H o
CO o ~ m
53 P ON i O












• r-l 53 •—>
H + W oo T)
J c 1 o pi! r^ 1 O 1 m c





H >-l rJ O >H J U >• J CO >H J CU H <U H H < > H <3 o H < ^sp H H H H H M M H S3 H H
f* H O <u H O H Eh O 2 H O JH 525 H p 53 H rH 52 H 53 H <
to < pq rJ <3 pa s <J « w <J pa H2 P P <3 P P M P P PM P P O
o O* co > O* co PS" c co o cy co H
u w Pm
76
B. SERIAL COMMUNICATION PERFORMANCE
As described in Chapter IV, there are four different
types of communication. The execution times of these commu-
nication types will be calculated separately in this
section. These four communication types and their subpro-
cesses are listed in Table 25 .
TABLE 25
COMMUNICATION TYPES AND INVOKED PROCESSES
COMM. TYPE PROCESSING SEQUENCE
By -pass Receive -de coder- Interface-
dup lexer- transmitter
Internal Dist. Receive-decoder- send






In this communication the invoked subprocesses are
receive, decoder, interface (activated by decoder), trans-
mitter and duplexer. Using Table 12, 13, 14, 17, 22 and 24,
the total time for the by-pass process is found to be 128.5
microseconds
.
2 Internal Distribution Performance
In this type of communication the receive, decoder,
send (activated by decoder) processes are executed. Using
77
Table 12, 16 and 18, the total execution time of this type




In this kind of communication, the invoked subpro-
cesses are listen, encoder, interface (activated by
encoder), transmit, duplexer and receiver closing. Using
Table 13, 14 15, 21, 23 and 24, the total execution time of
the external distribution type communication is found to be
447.8 microsecond.
4 Short-Cut Procedure Performance
Short-cut type of communication consist of listen,
encoder and send (activated by encoder) processes. Using
Tables 15, 19 and 20, the execution time of the short-cut
communication is found to be 404.8 microsecond.
The last two types of communication's execution
times are found to be about 400 microseconds. The reason for
this time is the large number of processes, which are moni-
tored by the communication system. This execution times can
be reduced to 50 - 100 microseconds by using a smaller
number of user processes. Also operating system processes
can be monitored separately than user processes.
C. FAULT FREE SYSTEM PERFORMANCE
In a system with parallel bus and common memory , as in
Figure 5.2
,
the block data transfer performance will be
calculated in this section.
That kind a operation requires bus check routines and
the data transfer protocols. The bus checking procedure
execution time can be neglected comparing to the data















Figure 5.2 Fault Free System Structure
1000 * 4 Bytes of data transfer requires 1000 memory
access cycles. In this procedure there is no communication
or fault tolerance control procedures, therefore the minimum
time to access these common and local memories, which are
the same kind of static memories, is calculated using Table
2 as follows
,
identifier evaluation = 120 + 1.7 * 55 = 213.5
memory access = 100.0
TOTAL 313.5
4 KBytes of information requires 313.5 microsecond
transfer time, or approximately the data transfer rate for
parallel bus structure is approximately 100 Megabits per
second.
79
D. SYSTEM WITHOUT SHARED MEMORY
In the system without shared memory (parallel bus
failure mode) the common data base will be assumed in one of
the resident transputer's memories. To transfer this data
to other transputers requires at least a four stage opera-
tion, where each stage has been denoted with stars in Figure
5.3 . In each stage a regular communication protocol will
be assumed. The special subroutines can be provided for this
purpose, therefore the total data transfer rate will be
dependent on the serial data transfer rate and communication
execution times.
Without fault tolerance controlling, the data transfer
procedure execution time for 4 * 1000 bytes will be deter-
mined by local memories access times and serial data
transfer rates, as follows;
i/o primitives 50 * 1000 + 625
serial transfer 625 * 1000
memory access 100 * 1000 + 500
TOTAL . == 776290 nano sec.
Distribution of 4000 Bytes of data to all transputers
will require the execution of the same procedure four times.
Therefore total time consumed at data transfer will be
3105.1 microseconds. This corresponds to 3.1 microseconds
per byte or approximately 0.3 Megabytes per second data
transfer rate. This evaluation is true, if there is no
interference in the internal buses.
If the interference is assumed on internal buses , in
that case there will be delays at each stage of data













Figure 5.3 Common Data Transfer
E. EXPANDABILITY
In this section different computation models will be
tried to analyze the performance of the mult itransputer
system, and to show the system expandability.
Assume that the computation proceeds in a linear pipe-
line fashion. This model can be adapted into the
mult itransputer system in many different configurations. To
provide triple or quadruple modular redundancy, a
81
multitransputer system may include three or four computation
models in itself. The basic reason is to provide simulta-
neous throughputs, and by comparison it will be possible to
find hardware faults, if comparisons fail. Using triple or
quadruple redundancy, hardware failures will be detected and
located, also correct results will be forwarded to the next
stage of calculation.
As an example of triple modular redundancy, a linear
type of computation model can be used. If we assume that
each row of a multitransputer system corresponds to a linear
type computation model, and the first three rows execute the
same program simultaneously. If one of the three results is
different, this row's computing elements are assumed failed.
This row's execution job is assigned to a spare row while
the failed row is diagnosed.
For quadruple redundancy, the system's components are
arranged into removable units in such a fashion that on each
removable unit two computing elements constantly produce
resultss which are checked for consistency. If the two units
generate inconsistent results, the removable unit is assumed
to have failed and it will be removed from the system by
service personell. A spare unit is placed into the system
while the other working pair of computational units has
propagated correct results. To allow the spare unit to be
switched into the system without powering the system down is
an important design feature included in such systems. Figure
5.4 shows an example of this computation model and its
adaptation.
The output element of each line carries out the compar-
ison procedure. These elements are denoted by "*" in the
Figure 5.4 .
This type of a pipeline computation can be used in the
real time systems to compute some time dependent events. For
82
' i ' * > ' | ' |
!X>UT OUTPUT t f t T
«. » 1 __*. J ». 4 _-*. . . . .
^-^-^rrLTr
JL JL. -L, _L
«•- -p. — • • -^V V V V
Figure 5.4 Linear Type Computation Model
example radar information would be input, second and third
computing elements can calculate the actual target coordi-
nates and weapon system outputs. These values can be
compared by the last elements of the model to decide correct
results
.
Another computation model could be a loop type of compu-
tation. Also triple or quadruple modular redundancy can be
applied to that model using three or four computation loops
in the mult itransputer system. The computation output
elements must be assigned as decision elements of the redun-
dant system, as in Figure 5.5
This type of computational model can also be used in
recursive calculations such as discrete signal analysis.
Also triple or quadruple voting process will provide correct
results at the end of each discrete period.
83
Figure 5.5 Loop Type Computation Model
A star type of computational model can be applied into
the multitransputer system also. As in previous applica-
tions, triple or quad uple modular redundancy is provided by
three or four computation groups in the system. An example
of that kind a system is shown on Figure 5.6 .
That type of modular design may be used to compute three
stage computations. For example the first two computing
elements can be used to evaluate both search and track radar
input for a certain time period and in the next stage target
evaluations can be done, and final stage can be used to
demonstrate these computations.
Another combination of modular designs also can be
applied to the multitransputer system using previous basic
modular structures.
84
L_. J ,, J
X




L__J 1 1 LjJ 1 11 3-x„




This thesis is focused on introducing the
multitransputer system and its building blocks: the
Transputer T424 and OCCAM programming language. Also the
role of the fault tolerance in a real time system, is empha-
sised in the implementation of the multitransputer operating
system.
The serial communication subsystem of the
multitransputer operating system is implemented using the
OCCAM programming language in the VAX 11/780 computer
system.
Performance of the serial communication subsystem is
evaluated and compared with a fault free system. As evalu-
ated in Chapter V, the proposed multitransputer system
performance is highly capable to achieve many present real
time applications and a good candidate for future applica-
tions. This system becomes more attractive with its fault
tolerance capability for many real time applications, espe-
cially in military based applications.
As far as the system dependability is concerned, the
serial communication construct will provide a very high
degree of probability of system functionality even if the
parallel bus fails. Graceful degradation will be provided
by sixteen computing elements in the multitransputer system.
Also a common database application is possible during
parallel bus failure.
The fault free operation is improved using triple or
quadruple voting mechanisms which provides fault tolerance
for many real time applications. This feature of the
86
mult itransputer system can be also provided in the parallel
bus failure case. In other words, the serial communication
system has the capability of triple or quadruple voting
mechanism applications.
B. FOLLOW- ON WORK
This thesis addressed only the serial communication
subsystem for the fault tolerant mult itransputer operating
system. Possible continuation of this work include other
subsystems of the proposed operating system, or the formali-




o CO o ?-i
•H CO •H CU C
. 4-> <N. CU 4-1 > o
oj CJ 03 •H •H
C c o N CU 4J
•H o 5-i •H CJ 03
4-) •H 5-i a C CU C




5-i CU o3 X 5-i 5-1 4-1 CO c
1—
1
CU "0 C s CU X\ O CO ty o 5-i
CU > •H 5 TS CJ 4-1 CU u •H CU
C •H CM 4-) c C C T3 o M >
e CU O CO CU >> i—
1
M 03 •H
cfl O CU x CO CO o3 4-1 a, N CU
X <l) c -a CU C O •H
5-1 o T3 CU 5-i 00 CU M C CU
• •H M C 4-) O •H 5-i •H O 5-i
•P e 4J a •H o3 CM CO 5-i B 5-i
m •H o o3 cu > O CO x: O
£ 5-i C 5-i tj •H 4-) CJ CJ C o 4-1
X CM •H M c 4J •H C C 03 c




5-1 CJ CU <4-l 03 5 CO 4-1 CO 03
i—
i
03 CU ^ l C
cu C 4J 1 1 1 i 1 1 CU 5-i 00
c 00 cu 1 CM l 1 i 1 4-) O •H
a •H -a •H o3 CM CO
to 03 CO 5-i >W ^ i 5-i i 0) •H 4-)
to Pi C i CU i XI CO M •H C
CO W • O XI s: CU CJ 03 !>>
W Q -a •H S .-—
N
5 >> 03 5 CO

















X Pm Q •H r-l 5-i ~^. CUH n 4-1 ,^- CU CU 4-i 1Q S5 CO 4-) CJ cu 4-1 T3 D 1
a o co d 03 T) D O (X
w H W CU O a CJ >> CO >H
0. H U > i CJ CO • >* >< *3 C >H >H !Z
P-, <J O 0) i • C 4-) s IS <! o3 2 25 <C





CU 4-1 y~-/ "•* c^.
4-1 A
*• (N-
4->V to <u S II II r-l rM e V r-l l—
1
C§ CJ <! ii • • CU CU CU CU CU CU












Z 4-1 CU a •a Xi X\ <U D X X CU
£ C
4-) a C o CJ > a CJ o >
CU D CO •H • •H CO • • •HU > a, c • T3 T) CU C 4-1 4-1 CU
>>—
'
CU CO rt 4-1 c c O o3 •H •H o
u • C u X <u CU CU U s = CU
cu p CU 03 4-1 O" CU CO CO 5-i 4-) c/ X X 5-i
T3 Pi > 5-i • w • w
O H •H 4-) 4-1 CO 4J co
O CU • K «













































}-l CJ E CO
co <u CO 3 5-i
> 5-i 3 oj CO
•H Rj 5-i >
CO £ 5-1 4-) •H
CJ o 4-J CO
CJ 5-1 E O
5-1 <+A O o OJ
4J H 5-i
O co M-l
4-) CO OJ O




rt Qu O 3 rH
3 CO a o OJ
CuO CO CO Q- 3
4-1 •H M co co 00
CO CO 5-i <U •H
ai z H CO
a E "3 t
cr 0) co >> ; ^
CO CO CO
-d aj 5-i




c O CJ 5-( X! •H
O OJ
•H 5-i S-i 4-1 4-) a
4J CO 0) •H •H OJ
•H > > E g 5-i
e •H •H CO CO
co CO CO 3 3 a
c u o oJ a3 0)
03 co CO 5-i H a,









































































































































































































































































H Jh 5-1 5-i XT
CU 0) CU cu cu
4J 4-> 4J 4-1 5-i
3 3 3 3
a a a a j
co w CO CO U
C C c 3 eg
0} 0) o3 o3 >
h 5-i U 5-i •H
4-1 4-1 4J P CU
U
5-1 4J 5-i cu
cu J= <U 4-1 5-1
a 00 S m
a •H o cu cu
a 5-( 1—1 rH CO
o
E E E E rH
o o o o
u 5-1 5-i 5h E
<4H <4H <4-l m
5-i
CU CU CU cu CU
no 00 00 00 X
03 03 03 03 CU
w CO 00 CO rH
00 w co CO a



















































































































































































































































-—>. • • •
o 0) o CU CU cu
o 0- o > > >
o ^ o •H H •H
o 4-> o 4-1 4-1 4J
r-l • I-l a a
~~^ 0) — 03 0) 03
a) "d cu i_i i i i—
TJ O -a AS AS AS
0) O O o G C C
00 o •H H H




a) 4-1 X 4-1 fa
















5-i O -d 3
CU CJ •d
•d CU o
o T3 4-J g
cj o


















c 03 CU J/J S aO
O c > co •HH 00 H ^ ~ CO
4-> •H 4-J co C -d
03 CO a o cu z
> 03 CU •H CO u
•H u CJ 4J o CU
4J c —
.
C 03 i-H >
































>H >H U 4-> CJ cu












cu CU CU 4H 03 i i
O CJ 4H
c e CU
o3 03 CU 5-i c MH >H r*
> > 00 i i o O S 55
T) -o T3 co •H <J <5
o3 03 CU AS 4J CU
cu • • r-l C o3 CO — . o.
00 CU CU 5 •H > 03
TJ T) •d O i-H •H 4H <4H
ai O o c . 4-1 <4H <4H
i—
i
O u K>{ 4J c O O
fa 5 CU CU cj r-H 03 H • •H o <y -d T> o3 3 CU CU
fa ^S C w o3 i I > >
D CO AS CO H m i l •H •H




















00 5-i c^. e>-. 3
CO CU •H
cu X C 3 E
o s o o 5-i
o 3 •H r-H CO •H cu r-i CO















5-i o •H •H o •H CO •H o
ii <U •H c CO 5-i 3 CU i <u CO 5-i
^—
s
w 4J 3 0- 3 ex i CJ 0-
4-) 3 rt E 3 £ ^ o 3
c c e CO o 5-i E 4-J 5-i O 5-i
CU E H o CO •H CU o 5-i 0- •H <u
> o 4-J o cu 4-J 3 CJ CU CU 4J 3
0) 5-i CO CJ 03 cu T) 4-J 5-i 03 CU
. 4-4 CU 4J o N 4-1 i-H O 3 CU N 4-1
cu T3 3 5-i •H CO 03 a a 4-1 •H CO
00 r-H CJ a 3 •H 3 CO 4-) 3 •H
03 03 1 i O i—
1
5^ CU 3 •H O r-i
w 3 1 4-J 5-i 5-i CU 3 03' C 5-1
w 00 5^ CU A 4-J •H 5-i CO X! o
cu •H 1—
1
O TJ CJ 4-J X s 4-1 3 CJ 4-1
s CO X X 3 3 CU fc • 03 3
cu CO aj ^ i-H CU 4-J U >-> i-H
•1 s X) CO CO <^S 1 4-) 3 4-) CO o3
i-H o c 1 3 1 CU •H 3
cu •H •H 1 CU 5-i 00 "3 0) 5-i 00
c 4-) • 4-1 O •H 5-1 + 4-) O •H
3 Rj 4-1 5-i 03 4-4 CO CU i o3 4-1 CO
«J > 3 CU > XI i /—
N
>X •H •H rQ •H 4-1 CJ e o •H 4-J CJ
Pi 4-J i—
i
s 4-J •H 3 3 o 4-J H 3
w • CJ 3 CJ 03 >^ 3 w 1—
1
CJ 03 ^
p 4-) Ctj CU 3 03 2 CO • CO U 03 5 CO
o •H i-H . • 5-i J D -,c
u £ 1 XI 5-i CO i 1 1 CU CO <J Pi i i i












X CO cu 4-1 >* & ^H CO 4-1 • • • « 3 >* >H >H
to (U cu CO CO •H S3 S3 S3 3 •H •H S3 S3 S3
w c "3 CU 3 <i <3 <U 03 cu OS cu • <J < <
u c 3 CJ o3 l U i ON Ou ON a 4J




4-1 i ON J*. t>i 3 — • (N. —
•
Pi J3 • 5-i 4-1 4-1 II 4-J •H
Pm u 4-) a 4-J A A • V • -—
'
4-J
PQ • 3 11 i-H i-H 3 V CU CU i—
1
i-H 33 -a •H n CU CU cu X "3 X •3 II CU CU CU
co c 5-i 3 3 > u CU o cu o 3 3 >
cu o. CU 3 3 <u CU -3 CJ •3 cj 3 3 CU
co 5-i 4-> 03 03 . 4-1 3 • 3 . <u 03 o3 •
4-1 CU 3 X X <u 3 •H 4-1 •H 4-1 T3 X X cu
55 3 4-1 <X a CJ 00 a • 3 • 3 o CJ CJ 00
3 CU a
CO • 03 CO 4-J •H 4-1 •H CJ • • 03
> a 3 -3 3 CO 3 3 3 • 4-1 4-1 CO




• c 5-i cu CU CU 5-i Pn 3 E E CU
<u 03 4-1 O* CO CO E 4-J O* H •H X X S3
5-i w 00 5-i • w w
a) p rt 4J 4-1 CO 4-1 CO
T3 Pi CO • c 3
O H CO 4-1 •H •H
CJ CU 3 Pn
























4-1 00 O O 00 O o
u •H CJ u •H CJ
0] 53 53 CO CU CU
43 <U cu X X
co c 53
1
' oH o4-> o4J o•H 4-1
o
4-)
5-i 4-> 5-i 4-1






X > 03 o3 X > 03 03
O •H 53 o3 53 o •H 53 03 53
O 4-> 00 4-1 00 CJ 4-1 00 4-1 aO
53 CJ •H 03 •H CU CJ •H 03 •H
dJ 03 W X co X 03 CO X CO
E X X O S X O X CJ
o aj G c C C o 03 53 53 03 53 53
m n i-i 4J CU >> 03 <U >-» 5-i 4-1 CU >, 4-i CU 5^
'—
V
M-4 cU co co 4-) CO CO 4-4 03 CO CO 03 CO CO
rH X 03 X X
<1J 4-1 1 i X i 1 4-1 1 i 1 i
e w O 1 i i 1 CO 1 i 03 1 i
c cu c 03 CU 53
oj 3 o3 D CO 03
43 cr w CO 4-) cr CO •H 4-1
o <u •H H o3 CU •H 03
. 5-i X 5-i CU X
u 0) CU • <U u •
cu ClO 5-i >+ >-i 5-1 4-1 >H oo 5-i >* >* CO 4-1 >H
X c CU s 5S cu C S 53 CU 2 2 43 X 2Q O •H 42 <J <3 43 •H <1 •H 43 < <^ 4-1 OJ <
























oO ~ K tt X 1 X
oo i—
1
1 i 0) 1 CU 1 l CU l CU
W <U 1 i x) 1 X 1 l X X
o c 53 !—
1
e i-H 53 i—i c i-H
o c •H 0) •H OJ •H CU •H CU
Pi B3 >* • e CU • 53 >H • 53 CU • 53
Ph 43 z 4-1 c a. 4-1 53 25 4-1 53 a 4-1 53
pq o <l C o3 » c 03 <J 53 03 >, 53 03














^ c 5-i X c 5-i i-H >. 53 5-i X 53 5-i
O 01 4-> o3 CU O 03 0) CU 4-1 03 CU o 03 0)
O e . j: X CJ 43 X C • r\ X CJ 41 X
e e CU o o • CJ o e CU a • CJ O
0) (4 XI • 4-1 • CJ 03 X . CJ 4-1 • CJ
43 o C c C C (3 X. o 53 CU X! 53 CU
S3 o <y -h cu H <y -h cu CJ O* -H X cu <y -h X
a
.
• w w • • u Ed
5-i 4-1 00 H oo 5-i 4-1 00 H oo




D X H s X CU S
Pi O En O EnX H U H O H
e 53 <U





























































































































































































































































































































































rH ^~v a CU
3 ^ Jxj o £ -d


















C H •H a CO rt a
o JJ 4-1 •H •H So 00
•H CJ CJ r—
1
•H •H




A > 01 rj r*
•H V •H JG
4-) i—
i
4J 4-1 H •H








































c OO o s^ a) rj c £)
•H 2 rj 6 CU £ r"-> 3W i—
1
—
• <3 -H a CO CO o
co i i i—
I
CU r*> u




x; 4-1 1 1 4-1





ii r— y <j C O r* •H
• CU e •H CJ £ S* >H 4-J
4-1 n •H i—
i
4-J •H 2 2 4-J
4-J i— rH O 4-) CU 03 JJ rH <; <J •H
•H 3 <j a •H TJ 4-1 X £
g 0) 0) fa . a O 03 CU — . r>. —
•
CO
<y X <4-4 •o H M CO O XJ C
w >" C C • • II CU CU 03
CO PQ •H 03 4-) 4-J CJ CJ rj 'h
i— i—
1
H X X f* 1— rj H
CO 4J 1) CU CU o3 03 H
3 fa fa fa > > "u 1
4-1 M H I II II i» 73 73 • 1
o3 fa >h I 4-1 03 03 0)
4-i co pa • • T3




-a 4-1 T) H •H CJ •H
D fa o 03 o S3 S CU S fa
4-1 H <y CJ 73 CJ X X "G X M
03 fa 4-J w fa




























>•> U x X!
4J in. a o3 5h
•H 1—1 m







































cu U C O •
T3 CU 0) e 4-1
O 4-> 5-i • c
U D 4-1 X •H




C c i—l CO
S oj O •H CU




u P • H X)
<4-l X CN >H 03
4-1 fl CU PQ 4->
4-1 C •H r—
1








4-) CU >H II 4-1 c
c r— fQ o3 •
cu X) 4-J M P-.
> 03 i— O CO G M
cu 4-) co C •H w ^
a t H i—l 3 CO
in. II 4-1 X O Pi
03 c JS H
C 4J •H ft,

































































CU o3 4J i-H <3 <l
id 4-1 G





. . II CU CU C
4-1 4-> • • CJ CJ 03
C G C C X
•H •H CU o3 03 a
p-l 0- > > •M II II r*> -d -a 5-iW !*S • • 4-1 03 03 CUp CO • • • T3
Pi CU o3 CU 4-J 4-1 O
H t3 4-1 13 •H •H CJ
o 03 o s £ C






CJ CU a OQ
03 X 3 3 03
4-1 CU -3 •H 4-J
5-i rH ^J 03
CU CU £ 03 "3
4-1 3 o ,3
3 -3 5-i CO ao
•H
o
cm CU3 •33 3•H 003










4-1 i—l 3 CO cu CU £ -3
** c 03 03 CO rC r-H CO CO
CU 3 3 6 cu 4-1 -Q 3 -3
a, o 00 cu B 3 o3 3














CU CU 3 "cu cu 4-1 •H i 1 i
1-1 "3 > o CO CO 4-> X i 1 i
co O CU •H o O •H 03
0) CJ 4-1 i—l i—
i
g ,3
3 • c 03 CJ CJ CO CO o3
ST a o N 3 -3 4-1 CU
0) E •H •H 5-i 5-i 03 3 03 CO
r* 5-i CU 4J 3 CU CU 5-i 03 -3 3
w • 4-) •H O > > 4-> ,3 • oH 4-1 £ 5-1 •H •H W Cu aH •H •• CO ,3 CU CU i i P £ COH s A5 3 a CJ CJ i i Pi 0) CU£ X 3 a3 3 CU CU H 4-1 5-i
CO •H 5-i P*> 5-i 5-iS •> i—
1




u • CU -3 cu





















CO CU 4J • cu a. a •H •H H
CO • X CU s CO CU >^ r-H r-H i—lW 4-1 - c T) cu CU •3 4-1 . . .U •H cd •H O 4J 5-i o • CU cu cu
o E 4-1 i—l CJ CJ CU B E £
Pi X oJ • >H >* —
.
<s. • •3 CU CU CU
Cm "0 . • a, CU 03 n 2; Z a O 4-1 4-1 4-1




E a i i i—
i
i 1
P <1 a 4-1 CU o 03 55 X X cu •
co p e i—
1
4-1 o 3 CU <l —
.
C*» 3 3 4-1 Cu X X X
u CU 3 a, •H •H B 3 3 3
"—
'












u »• 4-1 • 4-1 CU CU a a, CU w
CU CU •> 3 CU a3 CU 3 3 3 c B CO H CO
4-J TJ CU CU TJ 4-1 •3 CU D1 cr CU CU 3 O
4-1 O CO > O 03 o > CU cu 4-) 4-1 o 53
•H CJ 3 W CU O •3 CJ CU 5-i 5-i i l_l a Pn
£ . o P CO l-H
CO a, a Pi 4-) a a a 4-1 4-) 4-1 X X CU
a s CO H •H S £ S •H •H •H 3 3 5-i
« CU CU e CU <u CU E £ s •H •H (X,

















-a oo 00 •H m
c C C o H











cu 42 o jC 5-i o3 rH







rH 03 H 03 •H 13 •H
O 42 43 £ 0) O
r-l ao CO 4J E 4-1
4-> 0> c 01 C O 0)
C rH o iH oj 01 4-1 rH


















































































0) a o3 —
•
CJ
4J M o3 X 03 m C
oj C w T3 c O 5^ i—
i
>•>
-a •H to • H w C 4-1 m 01 CO
• rH J Cu rH 3 o rH
a <J E • Pi i i 43 1
s fa fa 0) a H i i C 3 1

























o> 4* rH 01 X iH iJ O •H H
CO a 3 CO a 3 <J • 4-1 E
C •H o3 C •H 03 fa a O X >H
o <y r-i 4-1 o cy h 4-1 E W 03 i i 3
fa w fa w n 01 P <J
CO CO CO co 4-1 Pi i CO


















D 4-1 CO 4J 4-1 3 3




























CHAN screen AT 1




cr : = 13
,









VT100 TERMINAL INITIALIZATION VALUES
PROC init. screen =
SEQ
location "BYTE := 4
location "BYTE 1 := 27
location "BYTE 21 := 'Y'
clear "BYTE := 2
clear 'BYTE 1" := 27
clear "BYTE 2 := 'J'
WRITING CHARACTER STRING TO CRT
PROC write. string ( VALUE string[] ) =
SEQ
SEQ i = [ 1 FOR string £ BYTE ] ]
screen ! string [ BYTE i ]
screen ! end. buffer :
POSITIONING THE CURSOR ON CRT
PROC cursorXY ( VALUE x, y ) =
SEQ location [ BYTE 3 1 := '
SEQ location " BYTE 4 J := '




CLEAN SCREEN AND HOME CURSOR




CARRIAGE RETURN / LINE FEED
PROC return =
SEQ
screen ! cr ; If ; end . buf fer :
WRITING DECIMAL NUMBER TO CRT
PROC write. number ( VALUE number ) =
DEF minus := -1 :
VAR k, j, negative, number.













temp F BYTE k := ( number \ 10 ) + ' '
k : = k + 1
number : = number / 10
SEQ i [ 2 FOR k+2 ]
SEQ
j := (k-i) + 1
string [ BYTE i ] := temp [ BYTE j ]
IF
negative
string [ BYTE 1 ] := ' -
'
NOT negative
string BYTE 1 :=
string BYTE := k+1
write. serine (string) :
100
* READING DECIMAL NUMBER FROM K/B *
PROC read .number =
VAR input, sign, digits :
SEQ
keyboard ? input






input <> - '
SKIP
digits :=
WHILE input <> cr
SEQ
digits := ( digits * 10 ) + ( input - '0')
keyboard ? input






numero := digits :
READING STRING FROM KEYBOARD
PROC read. string =




screen ! char ; end . buff er
WHILE char <> cr
SEQ
n : = n + 1
char. string £ BYTE n ] := char
keyboard ? char
screen ! char : end . buffer
char. string BYTE := n :
TIME DELAY








The following three tables are used to determine the
shortest available communication path between transputers.
Tables have been designed to reflect matrix structure of the
multi transputer system. Asterix '*' shows the propagation
center. In order to find the shortest path at each priority
level, we will need two input values. First propagation
center which is determined by variable transputer . number for
each transputer operating system. Second destination number
which it can be found from last two digits of the code
value. Actually each transputer operating system will
include a single linear table, and destination number will
be used as an index number of that table, in order to find





o- <* <f H
CM m CO <r
CM CO CM CM
CM on CM CM
J* CO r-l r-l
<r <r <r r-l
CM m CO <r
CM CO CO <r
CM co CM CM
m H i—
1
o- <r <r r-l
<f <r -J- r-l
CM m CO <f
CM CO CM CM
* CO l-< r-l
r-l
-;c CO r-l
r-l <f <f <r
<r CM CO CO
CM CM CO CM
CM CM CO CM
r-l .V CO 1—1
r-l <f <f <r
<r CM CO CO
<f CM CO CO
CM CM CO CM
r-l * CO r-l
T-< «*t <r o-
I—I <i- <r <r
<r CM CO CO






<t r-l <r <t
CO <r CM CO
CM CM CM CO
CM CM CM CO




CO <t CM co
CO <3- CM CO
CM CM CM CO
r-l r-l CO
<r i—l <f <t-
<f r-l o- <J-
CO o- CM CO




CO r-l 1—1 *
<r <r r-l <f
CO co <r CM
CO CM CM CM
CO CM CM CM
CO 1-1 1-1 *
<t o- 1—1 <t-
CO CO <r CM
CO CO <r CM
CO CM CM CM
CO 1-1 1—1 #
vj" <f r-l o-
<f o- r-l <r
co CO <t CM
CO CM CM CM
CO 1—1 i—l *
103
_V CM m <r
r-l ro rH <r
<f CM <f CM





-!« CNJ en <j-
iH m H <d-
<f CM <r CM
<f CM <r CM
i—i CM co r-l






H m i— <r
<f CM <r CM
l-l CM m t—
1






CM <r CM <r
r-l r—l CM CO
r-l r-l CM CO
<!
•a CM CO
«* r—l CO 1—1
CM <fr CM <r






<t- r-l CO r-l
<r r—l CO r—l
CM <f CM <r
r-l r—l CM co
<r -;c CM CO
ro <i- * CM
i—l <* —I CO
sfr CM <r CM
CO r-l r—l CM
CO r-l r—l CM
CO <f * CM
1—1 <f !-< CO
<r CM <f CM
o- CM <t CM
co r-l 1-1 CM
CO
-J- -:< CM
r-l <r r-l CO
r-l <t r-l CO
<f CM <f CM
CO r—l i—l CM
CO <f "#» CM
CM CO o- *
CO 1—1 <f i—i
CM <f CM <r
CM CO 1—1 r-l
CM CO r-l i—l
CM CO <J" -V-
CO r—l o- r—
1
CM <r CM <r
CM <r CM <r
CM CO r-l —I
CM CO <f -:c
CO 1—1 <r r-l
CO r—l <t r—l
CM <f CM <f
CM co r—l l—l
CM CO •>d- *
104




en o- CM r-l




-;c <t CM CM
en i—l CO CM
co <j" CM r-l
co <r CM r-l
m i—i r-l <f
j>0
** o- CM CM
CO i—i CO CM
m H CO CM
m <f CM i—l
co r-l 1—1 <r
* <r CM CM
CM •Jc <r CM
CM CO 1—1 CO
i-l CO <f CM
<r CO 1—1 r-l
<r CO 1—1 i-l
CM .»# <f CM
CM CO 1-1 CO
i—l CO <r CM
i-( CO <J- CM
<r CO 1—1 rH
CM <r CM
CM CO 1—1 CO
CM CO 1—1 CO
i—l CO <r CM
<f co 1—1 r-l
CM * <J- CM
CM CM * o-
CO CM CO 1-1
CM r-l CO <f
r-l <r CO r-l
i—l <r CO r-l
CM CM -;< <f
CO CM CO r-l
CM —I CO <r
CM rH CO <!-
r-l <r CO r-l
CM CM * <J-
CO CM CO i—l
CO CM CO i—l




CM CM a <!
<f CM CM -:c
i—l CO CM CO
<r CM r-l CO






<* CM CM *
rH CO CM CO
<f CM r-l CO
<t" CM r-l CO
i—l i—l <r CO
<r CM CM
—I CO CM CO
i—i CO CM CO
<r CM i—l CO
—I 1—1 <f co
<r CM CM -;<
105
LIST OF REFERENCES
1. Ihara, H., Fukuoka, K., Kubo, Y., Yokota, S., "Fault
Tolerant Computer System With Three Symmetric
Computers", Proceeding of the IEEE
,
October 19/8.
2. Avizienis, A., Fault To lerance : The Long Range
So lution to the Maintainability of Electronic Systems
,
Government- Ricroelecffonic Application Conference
,
1978.
3. Avizienis, A., "Fault Tolerance The Survival Attribute
of Digital Systems", Proceedings of the IEEE, October
1978. B
4. INMOS Limited. IMS T424 Transputer Advance
Information , 1984
5. INMOS Limited, OCCAM Programming Manual , 1983




7. Hopkins, A. , Fault Tolerant System Design: Broad Brush
and Fine Printing, Fault Tolerant Computing Symposium
8. Weitzman, C., Distributed Micro /Minicomputer Systems
Prentice-Hall, New~YorkT~T981
9. Drake A. W., Fundamentals of Appli ed Probability
Theory
,




1. Defense Technical Information Center 2
Cameron Station
Alexandria, Virginia 22341
2. Library, Code 0142 2
Naval Postgraduate School
Monterey, California 93943
3. Department Chairman, Code 62 1
Department of Electrical and Computer Engineering
Naval Postgraduate School
Monterey, California 93943
4. Prof. Uno R. Kodres , Code 52 Kr 3
Department of Computer Science
Naval Postgraduate School
Monterey, California 93943
5. Prof. M. L. Cotton, Code 62 Cc 1
Department of Electrical and Computer Engineering
Naval Postgraduate School
Monterey, California 93943
6. Zafer Selcuk 3
Haznedar Hurmali sk. Gunes apt. 3/4
Bahcelievler , Istanbul Turkey
7. Daniel Green, Code 20E 1
Naval Surface Weapons Center
Dahlgren, Virginia 22449
8. CAPT J. Donegan, USN 1
PMS 400B5
Naval Sea System Command
Washington, D.C. 20362




Moorestown, New Jersey 08057
10. Library (Code E33-05) 1
Naval Surface Weapons Center
Dahlgren, Virginia 22449




12. Dana Small 1
Code 8242, NOSC





14. Dz.Harp Ok.K. ligi 2
Fen Bilimleri Bl . Bsk.ligi
Heybeliada, Istanbul, Turkey
15. Istanbul Teknik Universitesi 1
Kutuphanesi
Istanbul, Turkey
16. Bogazici Universitesi 1
Kutuphanesi
Istanbul, Turkey
17. Orta Dogu Teknik Universitesi 1
Kutuphanesi
Ankara, Turkey
18 . Ercument Dokanakoglu 1
Koykahve sk. no: 11/3
Pasabahce, Istanbul, Turkey
19. Bekir Evin 1
SMC 2876 NPGS
Monterey, California 93943
20. Gokalp Bayramoglu 1
Yildiz Bloklar A- 1 blok























process for a fault
tolerant, real time,
multitransputer oper-
ating system.
-WBINo,

