Implementation and testing of the NPS Data Communication Ring by Meserve, John S.
IMPLEMENTATION AND TESTING




«f» /*•* «""•) /»» Pfll
IS \ il S« ; t onunniftp] ! J J; it E 81 rJJB '' M s I B I











THESIS ADVISOR: GARY M e RAETZ
Approved for public release; distribution unlimited.
TU7972

SECURITY CL ASSIFlCATION OF THIS PAGE (Whan Data . ninro-i)
REPORT DOCUMENTATION PAGE READ INSTRUCTIONSBEFORE CGMPLET:..^ FORM
1 REPORT NUMBER 2. GOVT ACCESSION NO. J. RECIPIENT'S CAT Ai.OG NUMBER
4. TITLE (and Su6(/f/e;
Implementation and Testing of the
NPS Data Communication Ring
5. TYPE OF REPORT ft PERIOD COVERED
Master's Thesis;
June, 1975
6. PERFORMING ORG. RLPORT NUMBER
i
7. authorc*;
John S. Meserve and
Robert Stewart
8. CONTRACT OR GRANT NUMBERC»J
9. performing organization name and address
Naval Postgraduate School
Monterey, California 93940
10. PROGRAM ELEMENT. PROJfCT, TASK
AREA ft WORK UNIT NUMBERS
II, CONTROLLING OFFICE name and address
Naval Postgraduate School
Monterey, California 93 940
IT. REPORT DATE
June, 1975
1 i. NUMBER OF PAGES
14. MONITORING AGENCY NAME ft ADDRESSf// dlllerant trom Controlling Oltlco)
Naval Postgraduate School
Monterey, California 93 940
15. SECURITY CLASS, (ol thla rip^rt)
Unclassified
15a. DECLASSIFI CATION/ DOWN GRADING
SCHEDULE
16. DISTRIBUTION STATEMENT (ol thta Raport)
Approved for public release; distribution unlimited.




IS. KEY WORDS (Conllnua on rararaa alda II nacaaaary and ld*ntlty by block .lumber)
20. ABSTRACT (Continue on ravaraa aid* It ntcateiuy and Identity by block niurbai)
The Naval Postgraduate School Ring Communication Network is a project
which, when fully operational, will allow connection of designated computer
facilities at the school. The capability provided to these facilities will be
the transmission of data or messages to one another, which will alio.'.
DD | j°n n 1473 EDITION OF 1 NOV 68 IS OBSOLETE
(Page 1) S/ N 0102-014-6601 |
SECURITY CLASSIFICATION OF THIS PAGE (Whan Data tnlartd,

Implementation and Testing
Of the NPS Data Communication Ring
by
John S. Meserve
Lieutenant Commander, United States Navy
B.S., Merchant Marine Academy, 19^3
and
Robert E. Stewart
Lieutenant, United States Navy
B.S., Purdue University, I969
Submitted in partial fulfillment of the
requirements for the degree of








The Naval Postgraduate School Ring Communication Network is a
project which, when fully operational, will allow connection of
designated computer facilities at the school. The capability provided
to these facilities will be the transmission of data or messages to
one another, which will allow sharing of resources. The main
considerations in design of the network were modularity, to simplify
construction and testing, and common hardware interfaces between
the ring and each computer facility. To provide the capability to
test all hardware /software functions test procedures were developed,
and a hardware test module was constructed.
The basic design of the ring network and test module is described.
Test procedures and results are presented, as well as a proposal
for a system modification, and recommendations concerning follow-






C. DESIGN CONCEPTS 9
II. FUNCTIONAL COMPONENTS OF A NODE 12
A. REPEATER 12
B. RING INTERFACE 12
C. HOST ADAPTOR 15
D. PARALLEL DATA ADAPTOR 16
E. MICRO-CONTROLLER 16
III. MESSAGE HANDLING 17
A. MESSAGE FORMATS 17
B. TOKENS 17
C. RI CONTROL 20
IV. TIMING 23
V. TEST PROCEDURES 25
A. INITIAL CONSIDERATIONS 25
B. TEST MODULE 26
VL CONCLUSIONS AND RECOMMENDATIONS 35
A. STATE OF THE PROJECT 35
B. RECOMMENDATIONS 37
APPENDIX A LIST OF COMMON ABBREVIATIONS 41
APPENDIX B RI PROCEDURAL FLOWCHARTS 48
APPENDIX C KA PROCEDURAL FLOWCHARTS 63
BIBLIOGRAPHY 82




1. EXAMPLE NPS DATA COMMUNICATION RING
CONFIGURATION 10
2. NODE CONFIGURATION AND INTERCONNECTIONS- 13
3. MESSAGE FORMATS 18
4. TYPICAL RING MESSAGE 19
5 . LOCAL COMMAND MESSAGE FORMATS 22
6. TEST MODULE CONFIGURATION 27
7. STATUS PANEL WIRING DIAGRAM 23
8. SIMULATION PANEL WIRING DIAGRAM 29
9. STATUS PANEL, SIMULATION PANEL, AND BUFFER
BOARD INTERCONNECTING WIRING DIAGRAM 30
10. HA, RI. AND BUFFER BOARD INTERCONNECTING
WIRING DIAGRAM 31
11. BUFFER BOARD PHYSICAL LAYOUT 32




DEDICATED TO MARY AND KATHY
WHO HAVE PROVED THAT




The Naval Postgraduate School Data Coramunication Ring has been
under design and construction for over two years. Originally con-
ceived by Lieutenant Keith Hirt, and described in his master's
thesis, "A Prototype Ring-Structured Computer Network Using
Micro-Computers, " [Ref. 4], the theory of such a network was
formalized. The hardware implementation was then undertaken in
separate projects. The ring interface and its associated micro-
controller was implemented by Ensign Michael J. Harris, and
described in his master's thesis, "A Prototype Ring Interface for
the NPS Data Communication Ring. " [Ref. 3]; while concurrently
in time the Ring Literface /Host Adaptor and its associated
micro -controller was implemented by Lieutenant Commander
Eberhard O. Wortmann, and described in his master's thesis,
"Design and Implementation of a Ring Interface /Host Adaptor for an
IBM System 360. " [Ref. 8]. Details of the theory and implementation
previously accomplished will not be reproduced in this report;
rather, those items required for clarity will be paraphrased or
summarized where necessary.
B. TERMINOLOGY
Much specialized terminology has been introduced in the various
papers that deal with the ring network. This creates some difficulty
in understanding the protocols that exist. Another area of confusion
exists concerning the control lines that connect the Ring Interface
(RT) to the Host Adaptor (MA). Although their functions are well

defined, labeling differs between the Harris and Wortmann papers.
In order to have a ready reference of common terms and abbrevia-
tions that apply to this system, Appendix A is included in this report..
This Appendix lists all commonly used abbreviations and terms in
alphabetical order, and gives a brief definition or explanation. In
addition, where considered necessary, a cross reference is made
to any other abbreviation or term which is applied to the same
functional entity.
C. DESIGN CONCEPTS
A Data Communication Ring consists of a Data Transmission
Line (DTI,), Ring Interfaces (RI), and Host Adaptor (HA) if required.
Each Host Processor and Ring Interface constitute a Node in the
network. Figure 1 shows a possible configuration of such a network
at the Naval Postgraduate School. The Data Transmission Line
transmits data, in the form of messages, serially and unidirectionally
around the ring. The Nodes have the ability to connect and disconnect
from the ring without disturbing the flow of data. The Host Proces-
sors are the computers, terminals, disk systems, etc.
,
to and from
which data is transmitted. In essence then, the ring network allows
the Host Processors to communicate data to one another and
therefore allows sharing of resources in the ring.
Key requirements in the design of the NPS ring were reliability
and economy. To maintain high reliability no Node is given ultimate
control of the ring, therefore, failure of any Node will not cause
failure of the network. A control hierarchy is built into the system
via a timer at each RI. A RI will take control of the ring automati-









FIGURE 1 . Example NPS Data Communication Ring Configuration
10

order, to take control. The important facet is that only one RI is in
control at any time, eliminating multiple message flow or control on
the ring. Control of the ring is designed to pass cyclically around
the ring from Node to Node. When a Node has control of the ring
any host processor residing at that Node is then allowed to transmit
data to any other host on the ring. If any process in the host does not
wish to transmit a message then control of the ring is passed to the
next Node on the ring. If a message arrives for a host processor
the RI signals his host processor to prepare to receive the data. The
data is buffered in the HA to eliminate problems of differing data
transmission rates. The RI signals the end of message to the host
processor and continues to monitor the ring either for another
message addressed to its host, or for a signal that it can take control
of the ring. Messages are not removed from the ring but merely
copied. Therefore, more than one host processor can be addressed
by a message. The sending Node, however, does remove the message
from the ring, simultaneously checking status bits to determine if the
message was received error free. Message formating will be covered
in detail later in this report.
Cost constraints were met by using micro -controllers to control
all functions of the RI and HA. This reduced hardware requirements
to a minimum. As part of this project a second RI and HA with their
associated micro -controllers were locally constructed. The cost cf
the integrated circuit components was less than $500. 00 (not including




Purchase of materials would be considerably less if larger
quantities were ordered; and when the system is implemented, the
PROM in each micro- controller would be replaced by a metal masked
ROM at a considerable cost reduction.
II. FUNCTIONAL COMPONENTS OF A NODS
Each node can be logically subdivided into functional hardware
components which have distinct responsibilities. Figure 2 shows
such a subdivision with the associated interconnections. Following
is an overview of the functional responsibilities of the components.
A. REPEATER
The Repeater provides the necessary signal boost to drive the
messages over long cable lengths. It is designed to be directly
connected to the ring, receive the signals, recover clocking informa-
tion, and pass on (cleaned up, reshaped) data to the outbound cable.
The design of the Repeater is dependent on several characteristics of
t
the actual hardware. That is; the cable type, cable length between
Nodes, type of drivers /receivers, and ring speed all affect Repeater
design. The actual hardware design has been deferred until more is
known about these characteristics.
B. RING INTERFACE
The heart of the ring network is the Ring Interface, which is
Host Processor independent from a design standpoint. The RI has
three major responsibilities:
1. Accept and comply with all control signals sent by the host




ing In Rins Outie
Repeater















Control and Data Lines
A. Input Data
(16 lines)














































FIGURE 2. Node Confisuration and Interconnections
13

2. Accept, deliver, retransmit, and evaluate data and tokens to
and from the ring.
3. Continuously check for errors in outgoing and mcoming
messages, keeping the host processor informed by the use of status
lines.
In the transmit mode the RI receives data in 8 bit parallel format.
The message is sent to the ring in the correct order, with data encoded
(coding formats are discussed in detail later in this report) and con-
verted to serial format for transmission to the ring. While transmitting
this data the RI continuously checks for errors. A bipolar violation
error is a series of three like bits (111) or more in sequence. These
sequences are not allowed in data bytes, and are an indication to the
RI that either an error has been detected or that one of the tokens has
been detected. The RI is able to determine the difference between an
error and a token. At the same time the outgoing serial data stream
is being continuously divided by a polynomial technique handled by the
RI. At the end of the data stream the remainder is transmitted as a
Cyclic Redundancy Check Character (CRCC). At the receiving Node
this same calculation is performed on the incoming data bytes,
including the CRCC. If there were no errors introduced into the data
stream the new remainder will be zero.
In the receive mode the RI receives serial data from the Repeater,
decodes it, and converts it to 8 bit parallel format, which is passed on
to the HA buffer. A handshaking routine is carried on between the RI
and HA to insure proper handling of the data bytes. The RI has the
responsibility to determine what messages are addressed to one or
more processes resident in the Node. In the receive mode the RI
14

again maintains a constant check for bipolar violation errors and the
CRC check, keeping the host advised by status lines. At the end of a
message the RI updates the message status bits which are included in
the retransmitted data stream that goes back to the originating Node.
The message status bits are discussed in detail later in this report.
C. HOST ADAPTOR
The Host Adaptor (HA) acts as an interpreter between a host
processor and the RL The HA design for a particular Node therefore
is dependent upon the host being served. The HA implemented by
Wortmann was designed to interface with the IBM 360 hardware,
specifically the IBM 3 60 Parallel Data Adaptor. In some cases,
especially mini-computer applications, the host processors could be
directly linked to the Ring Interface, with the HA functions being
accomplished by host software. The original concepts for the NPS
ring by Hirt [Ref. 4] envisioned common RI's with mini-computers
acting as the adaptors to the host processors, but this concept has
been modified. Unless specifically stated otherwise, all discussion
in this paper of the HA design or functional responsibilities will refer
to the IBM 360 HA.
The HA converts 16 bit parallel data from the PDA to 8 bit
parallel data for the RI. This sequence is reversed in the receive
mode. A major function is buffering of the data in a first-in-first-out
(FIFO) buffer, which consists of a 1024 x 8 bit random access memory.
Through the use of hardware this RAM is configured to allow data to
"fall through" in FIFO order in both directions, depending on whether
the Node is in a receive or transmit mode. The major reason for
15

this buffer is to allow for differing rales of data flow in the various
components of the system.
The HA also interprets and passes on messages (commands) from
the host to the RI. These Local Command Messages (LCM) are used
by the host to control the actions of the RI.
D. PARALLEL DATA ADAPTOR
The PDA is an IBM hardware device which acts as an interface
between external devices, and the hardware of the IBM 360. Software
interface with the ring is discussed in the Johnson /Kirkham Thesis
[Ref. 5],
E. MICRO-CONTROLLER
To minimize hardware costs and allow for ease of prototype
modification, control of the functions accomplished by both the RI
and HA is maintained by micro -controllers (MCs). The MCs used in
the prototype Node are very similar in hardware design, with
different programs residing in the respective PROMs. Basically,
the MCs are able to test logic levels of up to 32 input ports, set logic
levels on any of 32 output ports, and receive or transmit over 8
parallel data lines. The instruction set is quite simple and consists
of unconditional jump, conditional jump, jump external and output
instructions. Particulars of hardware design are given by Brubaker
in Ref. 1. Flowcharts of the micro -controller programs are listed





Message formats change considerably between the PDA, HA, RI
functional units and the ring. Data is sent in 16 bit parallel format to,
and from, the PDA. Between the HA and RI the data is transmitted in
8 bit parallel format. All handshaking techniques are handled by-
control and status lines between these units. The RI changes the
format of data and encodes it for transmission on the ring. Figure 3
shows the format of messages on the ring, Message Status Bit
definition, and coding format. Note that each data bit is encoded into
two bits. For example, a data byte (10011001) would be encoded and
would be transmitted as 16 serial bits (100101101001 Q10) on the ring.
Note also the low order bits are transmitted first. Figure 4 shows
an example message, excluding the data bits.
B. TOKENS
Control of the ring and message signals are accomplished through
the use of tokens, which are listed in Figure 3. All tokens start with a
bipolar violation (111 ) which is interpreted by the Rls to mean that
possibly a token follows and allows for decoding. The uses of the
three tokens are now described:
1. CTL - The Control Token signals to an RI that it may take
control of the ring and send a message if the host desires. If no
message is ready for transmission, or when it is through transmitting
a message, the RI places a CTL token on the ring, which passes to the
next Node "downstream". Thus, the CTL token allows one Node to be









































BIT MEANING IF ZERO (0)







MEANING IF ONE (1)
At least one RI matched
and accepted message
At least one RI matched
but did not accept




D is encoded to 01
L is encoded to 10
FIGURE 3' Message Formats
]8

3CRCC: CRC Character. The remainder following xhe polynomial
SOM TOKEN: Alerts all nodes a message follows. Padded with












§ PNAME: Address of ho& t processor message is intended for.
In this example address is node 5 (decimal). Low order






















EOM TOKEN: End of message token. Alerts node that the message


















^1 MSE: f/iessarre status bits.
o
o
FIGURE 4. Typical Ring Message.
19

Each RI has a "time-out clock" which is used to start up the ring,
prevent hogging of the ring by one Node and prevent multiple messages
on the ring simultaneously, by generating CTL tokens at the appropriate
time. Details of the time-out feature are discussed in the timing
section of this report.
2. SOM - The Start of Message Token alerts all Nodes that a
message follows. The SOM resets the time-out clocks as it is
received. Because tokens are only 8 bits in length and the counters
in the RIs are modulo sixteen, the tokens are padded with eight zeros.
3. EOM - The End of Message Token alerts the RI that the
message body is over and that the Node address (sending) and status
bits follows.
C. RI CONTROL
The RIs then, use the tokens to get, and pass, control of the
ring; as a signal that a message follows; and as a message delimiter.
Receive and transmit sequences will now be discussed.
1. Receive Sequence
When an RI recognizes a SOM Token and recognizes that the
message is addressed to a resident process in its host it begins the
receive sequence. While constantly checking for three identical
transmission bits in a row (bipolar violation) the RI uses the reception
clock (clocked once for each incoming bit) to time the bits. After 16
bits have been clocked, a serial -in -parallel -out shift register is
triggered. The 16 bits are decoded (the first bit of each pair is the
data bit ) and passed to the HA. After the EOM Token is recognized,
the RI sets the appropriate bits into the message status bits. As this
20

data is being read into the FIFO buffer, the HA simultaneously readies
the data and transfers it to the host in 16 bit parallel format as rapidly
as the host can accept the information.
2. Transmit Sequence
In the transmit sequence two types of messages can be sent
from the host; the local command message (LCM), and the regular
transmit message (TM). The LCM never reaches the ring, but
rather is used by the host to control the RL Figure 5 lists valid LCMs,
with the code used by the HA to differentiate the messages, and the
functions accomplished by each LCM. Each LCM is two bytes in
length, whereas all TMs are over two bytes. The host adaptor uses
this fact to start the decoding process. Any time the HA receives a
message from the host of one worjf (two bytes) it assumes a LCM is
being transmitted and decodes the appropriate four bits of the first
byte of the word. The command is then passed to the RI for action.
As stated, an LCM never reaches the ring but is used for
local control. The transmission message, however, causes the RI
to shift into the transmit sequence. As soon as the RI gets control of
the ring (via a CTL token) it places an SOM token on the ring, followed
by an address byte and all data bytes. The data bytes are automatically
encoded for transmission. During this transmit sequence the host
adaptor alternately gets data from the PDA until the final two data
bytes are sent, and outputs the bytes to the RI. Again, the buffer in
the host adapter allows for any speed variance in shifting the data
through the Node to the ring. Error checking of the message is an
ongoing function of both the sending and receiving ring interfaces.



















Turns on appropriate bit in PNAME
memory. See note.
Erases the appropriate bit in
PNAME memory
.
Signals the RI to disconnect
from the ring network.
Signals the RI to connect to the
ring.
Strobes reset line to RI
Requests status bytes from the
RI in case of an error.
Note: The HA decodes bits k through 7 (other bits are ignored)
of the first byte sent from the host to determine which LCM is
being transmitted. In the case of WRITENAME or CLEARNAME the
second byte is theaddress of the bit written into or erased
from PNAME memory. After this interpretation the host adapter
passes on the LCM with appropriate handshaking to the ring
interface for action.
FIGURE 5. Local Command Message Format:
22

it from the ring, finally checking the message status bits for correct
reception. This information is passed on to the host for any action
required. As an example, if a host transmitted a message and was
notified by its RI that the receiving Node detected an error in the
received bits, the originating host might retransmit the message the
next time it had control of the ring.
IV. TIMING
Timing and data transmission rates on the ring and within the
components of a Node have been discussed in the various references.
Presented here is an overall discussion of expected ring data trans-
mission rates and timing problems.
The rate at which data will eventually flow around the ring network
is a function of how fast the hardware can send the data, characteristics
of the data transmission line, and finally, how fast the data can be
received at a target Node. In Reference 2, Brubaker discussed various
data transmission line possibilities, and suggests that line speed will
be limited to about 250,000 bits per second. This limitation is
primarily based on the fact that any cable acts as a low pass filter. As
the bits are placed on the line at a faster rate less definition can be
detected in the high and low peaks, until finally "one" and "zero" bits
can no longer be distinguished. This data rate translates to a 125, 000
bps actual data rate due to encoding of all bits into two bits. Reception/
transmission rate of Nodes is another limiting factor, the assumption
being made that all host processors will be able to handle dataflow at
least as fast as the envisioned ring. Within a Node then, the critical
component is considered to be the RI, specifically the RI micro -controller
23
M
Program design requires that the micro -controller execute several
instructions between the reception or transmission of data bits. This
allows the MC to test and set flags in the interval.
Brubaker [Ref. 1], considers the maximum MC cycle rate to be
about 1. 1 usee. To allow for four cycles from the MC between each
bit, the ring interface is then limited to a cycle rate of about 4. 5 usee.
This translates to a rate of about 220, 000 baud, or about 110, 000
information bits per second.
This is well within the range allowed by the data transmission
line. To maintain these cycle rates, a crystal clock is proposed to
reside in the repeater. This clock would provide transmit clock
pulses to the RI micro- controller, and after proper division would
also provide transmit clock pulses to the RI. Although the host
adaptor and its micro -controller run independently from the RI, cycle
times which varied greatly from the MC could cause underflow or
overflow of the FIFO buffer. This would cause an error condition
whenever the RI is forced to wait for the IIA. Therefore, it is
recommended that the IIAMC be driven by the same clocking pulse
that drives the RIMC.
Clocking during message reception is accomplished by a recovery
clock, which also resides in the repeater. This "clock" pulse is
generated and synchronized by the incoming data bits. During a receive
sequence the RI must immediately start sending the data bytes to the IIA
FIFO buffer. If this buffer overflows an error condition occurs as
previously noied. If data is received at the maximum designed
transmission rate, then the buffer is being filled at a rate of 13, 75
bytes per second. This allows the resident host over 75 ms to initiate
its receive sequence and start taking the data out of the buffer.
24

The timeout feature of each Node is discussed in detail by Harris
on pages 20-24 of Ref. 3. The circuitry to handle this time-out clock
has been designed and tested, but is not presently in operation in the
prototype Node. The time-out clock prevents any Node from tying up
the ring for long periods of time, and allows for starting and restarting
of the ring. Each time-out clock has a unique delay time to prevent
simultaneous control of the ring. This delay is varied by varying a
capacitor and resistor used in conjunction with a timer. Actual
implementation of this timer has been deferred until more is known
about number of Nodes planned for the ring and proposed message
lengths.
V. TEST PROCEDURES
At the inception of this thesis the status of the NPS ring system
was as follows:
1. Basic design of hardware/firmware elements of a Node was
complete.
2. Hardware implementation of the RI and HA and their
associated micro -controllers was complete with some initial testing
accomplished.
The next logical step then, was to thoroughly test each unit singly,
followed by integration of the units and testing the resulting Node for
inter-module protocol handling.
A. INITIAL CONSIDERATIONS
To prepare for future testing, construction of a second Node was
conducted. This accomplished three purposes:
25

1. As a learning tool the wiring practice helped with familiari-
zation of the components, and hrought out some less -than clear details
presented in reference material.
2. The second host adaptor was constructed because it was felt
that very minor hardware modifications would be required to modify
it for use with other host processors.
3. Any real application would require at least two Nodes. Initial
work included verifying the PROM programs by checking against the
original program paper tapes. Also, at this time a second set of
PROMs was programed and checked. It was determined that in order
to completely test data flow and protocol handling an extensive test
apparatus would have to be constructed. This test module is described
in the next section.
B. TEST MODULE
The design considerations that led to the construction of the test
module were requirements that all data lines, control lines, and flags
must be able to be continuously monitored as well as simulated, i, e. ,
input. ed by hand toggled switches. Figure 6 shows the configuration
employed. Figures 7 , 8 and 9 show wiring details of the test module.
This design allows the components to be tested singly as well as
interconnected. Testing proceeded on the host adaptor and its MC,
followed by the RI and its MC, and finally, testing of the units together.
Figure 10 shows the schematics of the interconnections between the HA,
RI, and Buffer Board. The Buffer Board acts as an interface between
the test module and the unit being tested. Tins allows monitoring of
all signals without causing signal drain. The physical layout of the

















'ST MODULE - Consists of the following units:
POWER PANEL- Supplies 5 volts, -9 volts, and a common ground.
STATUS PANEL- Contains display lights which monitor the status
of all data and control lines to, and from, the RI and HA.
SIMULATION PANEL- Contains switches that allow simulating
inputs of all data and control lines into the RI and HA.
jOCK 1 - Supplies external clock input (simulating transmit clock)
to the two micro-controllers.
jOCK 2 - Supplies external clock input
.
(simulating transmit clock)
Required to be at least four times slower than clock 1
.
Supplies clocking to the RI.
[SPLAY PANEL - A 32 light display panel which is used to monitor
the program counters in each MC. Used as a debugging tool.
FIGURE 6. Test Module Configuration.
27

V < - « -H
Ih
o • C o o o
-J
!












r. >- ^ > I
jr •*,*f>.S-VJ .
ii •< ii -•->-» - .
.
J 7
p j : < . r J ;. >> ' ^ ,i o » o • I J 2 2, J - ' » » » • i » 2 3 3
Hiijj nil •] j \\\ih\ i urn




























« O i k>
*"
. . , ..







j .i. ; t _: L :. ^ >! Ll J _j J !. li












a vl a 3 ^ k ^ •-; h h h - m -. a r, 3 j fi
1 'f"- tr*" !*" '-"", ->1 '




















































































































. « t i




































1 ?. v !
Us 1 7 /fr
I** V/; J
CIlJ CsZD
QZj [ / <7
/ '/
Z/C 1 1 /2/
/. ' / J 22*






T i e 2 T/o\






FIGURE 11. Buffer Board Physical Layout
32

1. Host Adapter Test Setup
To test the HA singly, the following procedure must be
followed:
a. Buffer Board plugs installed: P99, P100, PI 01, P102, P103,
P104, P105, P106, P107.
b. All host adapter switches in "normal".
c. All ring interface switches in "simulate initial".
d. All PDA switches to "off". All other switches on the
simulation pari el are disconnected.
This setup allows simulating all outputs from the PDA and the RI, while
monitoring all output data and control lines from the HA. After
supplying the required power and clock inputs the HA is ready to be
tested. A complete test consists of forcing the HA through all paths
in the flowcharts of the receive and transmit sequences listed in
Appendix C. In the transmit and receive sequences simulated data
can be written into and removed from the FIFO buffer with the
appropriate handshaking techniques. Tests accomplished have shown
that the HA recognizes, decodes, and properly passes all local
command messages. Simulated data bytes flow through the FIFO
buffer correctly in both directions, and the micro -controller functions
correctly.
2. Ring Interface
To test the RI singly the following procedure must be
followed:
a. Buff er board plugs installed: P 99, P100, PI 01, P103, PI 01,
P105, P103.. P109 and RIMC.
b. All HA switches in "simulate initial".
33

c. All HI switches in "normal".
d. Data in switch "off".
e. All RI internal switches "off". All other switches are
disconnected and position doesn't matter.
Again the testing of the unit is accomplished by following the flowcharts
(listed in Appendix B) to exercise all functions of the RI micro-
controller. In testing the RI it was much more difficult to determine
if data was flowing and being encoded correctly. Two factors caused
this difficulty; serial data flow to and from the ring, and the fact that
the repeater has not yet been constructed. This problem area is
discussed in more detail in section VI.
3. Ring Interface and Host Adaptor
The final test was to check the Node as a single entity. This
was needed to prove that the protocols and handshaking routines
between the RI and HA actually work. The following procedure is to
be followed to test the units together:
a. Buffer board plugs to be connected: P102, P103, P104,
P106, P107, P108, P100, RIMC.
b. All PDA switches "off".
c. All RI internal switches "off".
d. Data-in switch "off". All other switches are disconnected.
The tests consisted of going through all receive and transmit sequences.
As both micro -controllers are operating simultaneously it was found
to be somewhat difficult to follow the internal handshaking, but with
familiarity this problem lessened. All Local. Command Messages
were received by the RI correctly. However, it was impossible to
check PNAME memory for correct writes and erases. This problem
34

siill exists concerning the input of serial data, which will be resolved
upon incorporation of the repeater.
VI. CONCLUSIONS A NIP RECOMMENDATIONS
A. STATE OF THE PROJECT
At this time the NPS Data Communication Network has one
working Node with the exception of a repeater. In addition, a second
Node has been constructed, but not tested due to lack of operable
integrated circuit components. The complete Node has been
thoroughly tested at hand clocked speeds. This testing included
functional testing of the host adapter and its micro- controller singly.
Each function of the micro- controller (see Appendix C) was exercised.
Simulated data words were inputed from both the PDA and the RI side
to insure proper operation of the FIFO buffer. Using the flowcharts
listed in Appendix B the III was similarly exercised. Using slow
speeds, outputed serial tokens were visually checked for correctness.
Finally, the RI and HA were connected via the proper control and data
lines, and the Node was tested as afunctional unit. Of special interest
was whether the internal protocols would work in this total environment.
Simulation of the PDA was accomplished via the Test Module.
Local command messages as well as regular transmit messages were
simulated to test all handshaking routines. All protocols functioned as
designed. The following minor problems were encountered during this
testing:
1. Power fluctuations
The test module, and all components of the Node are supplied
by the same power source. The stability of the 5 volt power supply was
35

found to be critical. Fluctuations above 5. 5 volts or below approxi-
mately 4. 5 volts caused the micro-controller programs to become
erratic. Ensuring good connections and proper sized wiring solved
this problem, but a regulated power supply is recommended for
future work.
2. Integrated Circuit Chips Inoperable
Several ICs were found to be faulty on the prototype Node.
The 74161 synchronous 4-bit counters, used as program counters,
were found to be especially susceptible to failure. The ability to test
the RI and HA singly was a powerful debugging tool. The Display
Panel, which allowed monitoring of the MC program counters, was
valuable, in that it allowed a constant check on MC activity.
3. Lack of Repeater
The fact that the Repeater had not been constructed caused
testing problems. The transmit clock was simulated with two external
clock inputs. It was found more difficult to simulate the "recovered"
clock, used during receive sequences. This fact also made it
impossible to simulate known data streams from the ring side of the
RI. This prevented testing the decoding and PNAME matching
functions of the RI.
4. Inability to Test at High Speed
The external clock inputs were varied from 1 to 100 kc during
testing. While no problems were encountered at the higher cycle
speeds, no real high speed test results can be assumed. Because of
the test procedures employed, the micro- controllers were spending
the vast majority of time waiting for the next hand simulated input,
so no conclusions can be drawn about high speed operation. Design
36

speed testing should be performed when a high speed simulated PDA
can be connected to the Node.
5. No Reset L ine Into the RI Micro- controller
On the prototype Node, hand toggled reset switches were
provided to restart both micro -controllers. A reset line is provided
from the HA to the RIMC, and is enabled as one of the local command
messages from the PDA. The required circuitry was not incorporated
into the design or implementation of the RI micro -controller. Figure
12 shows the circuitry modification required to include this function.
B. RECOMMENDATIONS
Recommendations on future development of the project deal with
two areas: first, a recommended hardware modification; and second,
follow --on test requirements.
After studying the various host processors at NPS, it is considered
that buffering of data between the RI and the hosts is a common re-
quirement. As the FIFO buffer would then be common to each Node,
a logical hardware modification would be to shift the buffering function
from the HA to the RL This would be in keeping with the basic design
concept that the ring interface is host processor independent, and
provides functions common at each Node. This modification would
require both hardware and software changes to the RI and HA.
Handshaking techniques between the HA and RI, as well as between
the HA and PDA, would remain the same. The FIFO buffer circuitry
would be an integral part of the RI. During a receive sequence the
RI would still signal the host concerning the incoming message, but
data bytes would immediately start filling the buffer. The functions


















FIGURE 12. Reset Line Modification To RI Micro-controller
38

from the 8 bit parallel format of the RI to the format required by the
host, and providing the necessary control and status lines. This
modification would allow the direct connection of some hosts (such as
a mini- computer) to the RI without the need for a host adaptor, with
handshaking procedures accomplished using software.
Of immediate necessity is construction of the Repeater, as high
speed testing requires this hardware in the system. The second Node
should then be completed and tested in order to constitute a two Node
network. At this point high speed tests can commence. Because of
equipment availability the use of mini- computers for initial testing is
recommended. The use of one mini- computer would allow all LCMs to
be tested, and would also allow data to be transmitted Node to Node.
Maintaining data streams of less than 1024 bytes in length would
allow the Test Module to be used as the second, or receiving Node.
With software simulation of the PDA, the mini-computer could
transmit a known data stream to the second Node. The Test Module
would allow connection of the second Node to the ring. Very short
data streams could also be visually checked for accuracy by using the
Test Module to simulate a receiving PDA and removing the data from
the buffer. Message Transmission, and reception by the RI would be
accomplished, however, at design speeds. After transmitting a
message the software program could also simulate the receive
sequence of the PDA and therefore status information, decoded from
message status bits by the RI, would be automatically passed on by
the RI after the return of the just- completed message. The status
information could then be displayed or printed out on a teletype. This
test procedure would fully check all functions at operating speeds.
39

Follow-on testing would be concerned with establishing two host
processors on-line to check transmission of longer, more realistic
messages. Two other projects of interest are designing software
protocols for using the ring and an investigation into modifying the
host adaptor to interface with other computer hardware.
In conclusion, the NPS ring data communication system is
considered to be a viable means of sharing resources among computer
systems. The data transmission rates are seen to be adequate with
very reasonable costs -per-Node expected. Further developmental











Alter process name control line form the host adaptor
to the ring interface. Called ALTER in Ref. 3. When
enabled by the HA it signals the RI to either write into
or erase from PNAME memory, depending on the state
of the WTNM control line.
Bipolar violation error. An error condition which occurs
when three or more "one" bits are detected in a row in
the serial data stream. This condition does not normally
occur due to the encoding of data bits. This encoding is
shown in Figure 3. The BPV is also used to alert the
RI to the start of a possible token.
Control token. A recognizable token or code byte, which
is used to maintain and pass control of the ring network.
The disconnected flag from the RI to the HA. When
enabled this flag signals the host that the Node is not
connected to the ring. The same signal the RI used to
set this flag is also used to signal the repeater, which
actually performs the function of electronically discon-
necting the Node from the ring.
Demand control line from the HA to the PDA. In a
receive sequence, enabling this line tells the PDA that
the next word is ready. During a transmit sequence this




DISC - Disconnect control line from the I1A to the RI. When
enabled this line signals the RI to disconnect from the
ring. This line is raised by the HA in response to a
Local Command Message.
DTL - Data Transmission line. The actual shielded cable that
connects the Nodes. Proposed cabling is discussed by
Brubaker in Ref. 2.
EOF - End of file control line form the HA to the PDA. Enabling
this line indicates that the HA has completed its operation.
During a receive operation this line indicates an error
was detected on the incoming message.
EOM - End of message token. A message delimiting token or
code that signals a RI that data bytes in the message are
finished.
EOR - End of record control line from the HA to the PDA.
Enabling this line indicates that the HA has completed
its operation. A normal ending to a receive sequence.
HA - Host Adaptor. A functional hardware unit which acts as
a buffer and adaptor between the IBM 360 and the RI.
Also an acronym for the host accept control line from
the host adaptor to the ring interface. Called HACCEPT
in Ref. 3. During a receive sequence this line signals
to the RI reception of a data byte by the host adaptor.
HDR - Host data ready control line from the HA to the RL
Called HDATARDY in Ref. 3. Enabling this line signals




INT - Interrupt control line from the HA to the PDA. Enabling
this line signals the host to prepare to receive a message.
The host must respond by jumping to the receive mode.
LCM - Local command message. Messages sent from the host
used to control the actions of the RL LCMs are shown in
detail in Figure 5.
MSB - Message status bits. The last three bits in a message
which are set by the receiving Node to indicate to the
sending Node how the message was received. Figure 3
lists interpretations of the message status bits.
NODE - As used in this paper a Node consists of a ring interface
with its associated host processor or processors. As
designed the ring can support up to 256 Nodes. This
limit is primarily due to the addressability of PNAME
memory.
PDA - Parallel data adapter. An IBM hardware unit which
provides interfacing of external devices into the IBM 360.
PNAME - Process name memory. A 256 x 1 RAM which resides
within the ring interface. Used to match any incoming
message address byte to determine if the message is
addressed to a resident host.
RCRC - Flag from RI to HA. When enabled this flag signals the
HA that a CRC error was detected during a receive
sequence.
RCV - Receive control line from the RI to the HA. Called
RECEIVAL in Ref. 3. The RI raises this line to signal
the HA that an incoming message is being received (and
43

has been recognized as being addressed to a resident
host of that Node). Raising of this line pre-empts a
transmission sequence.
RDR - Receive data ready control line from RI to HA. Called
RDATARDY in Ref. 3. During a receive sequence this
line is raised to signal the HA that the next byte of
incoming data is ready to be sent to the HA.
RESET - Reset control line from the HA to the RI. When this
line is enabled (strobed for a minimum of 1. 1 microseconds)
it forces the RIMC to reset the program counter back to
the "initial" location. Used to restart the RI after a
lockup due to an error condition.
RI - Ring Interface. A functional unit of hardware which
allows a host processor to link up and use the ring
network.
RID - Ring interface demand. A control line from the RI to the
HA. Called DEMAND in Ref. 3. This control line is used
during a transmit sequence to signal the HA that the data
byte was accepted.
RIHAMC- Ring interface host adaptor micro -controller. Controls
actions of the host adaptor functions.
RIMC - Ring interface micro- controller. Controls actions of the
ring interface functions.
ROVER - Receive overrun flag from the RI to HA. When enabled
indicates to the HA that a data overrun occurred during
a message reception. This data overrun occurs when
the FIFO buffer is filled because the host did not accept
44

data fast enough during a receive sequence.
RPTR - Repeater. A functional unit of hardware in a Node whose
primary purpose is to recover clocking information
from incoming data bits, reshape, and act as a line
signal booster to the ring.
RR - Read ready control line from the PDA to the HA. When
enabled this line signals the HA that the host is ready to
accept the next two bytes of data.
RRERROR- Receive ring error flag from the RI to HA. When enabled,
signifies an error was detected on incoming data during a
reception sequence.
RS - Read select control line from the PDA to the HA. When
enabled, this line signals the HA that the host is in the
read sequence.
SMA.L - Symbolic Micro -controller Assembly Language. A
special language developed by Assistant Professor Gary
A. Kildall to program the micro -controller read-only
memories. Ref. 6 describes this language.
SOM - Start message token. Used to signal the various Nodes
that a message follows, and alerts the RIs to prepare to
check the next byte for a match with PNAME memory.
TM - Transmit message. A normal message to be outputed to
the ring. As sent from the host the first two bytes con-
sist of the address of the target Node followed by the




TOKEN - A special recognizable byte that is used to control the
ring and signal start and end of messages. All tokens
start with three "l" bits which are interpreted as a
bipolar violation and initiate a decoding sequence within
the ring interface.
WC z - Word count equals zero control line from the PDA to the
HA. This line is enabled to indicate normal end of write
operation, and in a read operation that the PDA will no
longer accept data (an error condition).
WR - Write ready control line from the PDA to the HA. When
enabled this line signals the HA that the next 16 bits of
data are ready to transmit from the host. Handshaking
techniques can be followed by studying the flowcharts
listed in Appendix B.
WRTN - Write name control line from the HA to the RI. Called
PNAME ACTIVE in Ref. 3. When raised simultaneously
with an APN line it causes the RI to set the appropriate
bit in PNAME memory.
WS - Write select control line from the PDA to the HA. When
enabled this line signals the HA that the Host desires to
transmit a message.
XCRC - Transmit CRC error flag from the RI to the HA. When
enabled, signals the HA that MSE-3 returned in a "one"
state, which indicates that a CRC error was detected by
a target RI during reception.
XMIT - Transmit control line from the HA to the RL When
enabled this line signals the RI that the host desires to
46

transmit a message to the ring. Called XMITL in Ref. 3,
XOVER - Transmit overrun flag from the RI to the I1A that signals
an overrun during a transmission sequence. It indicates
that the host did not supply data fast enough to the HA to
be transmitted to the ring.
XRERROR- Transmit ring error flag from the RI to the HA. This



























: the use of small letters, (a), is used to denote areas in the
procedural flowcharts that can be correlated with functions, 02


















































































































































































































































































































































































1. Brubaker, R. II. , A GENERAL PURPOSE MICROCONTROLLER,
paper prepared at Computer Science Group (internal document),
Naval Postgraduate School, Monterey, California, i97 4.
2. Brubaker, R II. , PROPOSED RING REPEATER DESIGN, paper
prepared at Computer Science Group (internal document). Naval
Postgraduate School, Monterey, California, 1974.
3. Harris, M. S. , A PROTOTYPE RING INTERFACE FOR THE
NPS DATA COMM UNICATION RING , Master's Thesis, Naval
Postgraduate School, Monterey, California, 1974.




Postgraduate School, Monterey, California, 1973.
5. Johnson, R, P. and Kirkham, J. H. , THE SYSTEM 3BQ
SOFTWARE INTERFACE FOR THE NAVAL POSTGRADUATE
SCHOOL COMPUTER RING 3YSTEAI , Master's Thesis, Naval
Postgraduate School, Monterey, California, 1974.
6. Kildall, G. A. , A SYMBOLIC MIC ROCONTROLLE R ASSEMBLY
LANGUAGE, paper prepared at Computer Science Group (internal
document), Naval Postgraduate School, Monterey, California, 1974.
7. Loomis, D. C. , RING COMMUNICATIONS PROTOCOLS, U. C.
Irvine Distributed Computer Project, Memo 46-A, 197 2.
8. Wortmann, E. O. , DESIGN AND IMPLEMENTATION OF A RING
INTERFACE /HOST ADAPTOR FOR AN IBM SYSTEM 360. Master's





1. Library (Code 0212)
Naval Postgraduate School
Monterey, California 93 940
2. Chairman, Computer Science Group (Code 72)
Naval Postgraduate School
Monterey, California 93 940
3. Defense Documentation Center
Cameron Station
Alexandria, Virginia 22314
4. LT(jg) Gary M. Raetz, USN (Code 72 Rr)
Computer Science Group
Naval Postgraduate Group
Monterey, California 93 940




6. LCDR J. S. Meserve, USN
5 624 Jockey Way
Bonita, California 92 002
7. LT. R. E. Stewart, USN
3003 Corral Court
























Implementation and testing of the NPS Da
3 2768 001 88277 2
DUDLEY KNOX LIBRARY
