A microprocessor based star communication network by Drygalski, Donald Gregory, Jr.
A MICROPROCESSOR BASED STAR COMMUNICATION NETWORK 
BY 
DONALD GREGORY DRYGALSKI JR. 
B.S., University of Illinois, 1977 
THESIS 
Submitted in partial fulfillment of 
the requirements for the degree of 
Master of Science in Electrical Engineering 
in the Graduate College of the 
University of Illinois at Urbana-Champaign 
1979 
Urbana, Illinois 
I would like to thank the following people for their 
help and advice on this project: 
Peter S. Moldauer 
Mary K. Phinney 
Andrew N. Fu 
Ricardo B. Uribe 
William G. Albright 
Chapter 
I 
II 
III 
IV 
v 
TABLE OF CONTENTS 
INTRODUCTION . .......•.•••..••.•...•.•....••.•.. 
THE SYSTEM . •.•..••••.••••••••.••••••.•••...•••• 
2.1 
2.2 
2.3 
2.4 
2.5 
2.6 
2.7 
Connect Command • ..•.•.........•...•.•..... 
Reconnect Command . ................•....... 
5 tat us CoiTlitl.and ••••••••••••••••.•••••.••••• 
Disconnect Command ....................... . 
Escape Cornrnaild . .......................... . 
Message Cornrnand . .............•••••........ 
Baud Rate Cortm'land . ....................... . 
HARDWARE 
3.1 
3.2 
3.3 
3.4 
3.5 
CPU Board . .•.........••......•......•..... 
Memo .. ry Board • •...••....•••••••.•••..••.... 
Serial I/O Board ..........•..•...•........ 
Interrupt Board ....•.....•.............•.• 
Mother Board and the System Busses ....... . 
SOFTWARE • ••••••••••••••• • • • • • • • • • • • • • • • • • • • • • • • 
4.1 
4.2 
The System's Program ..............•....... 
The System's Tables and Buffers .......... . 
FUTURE MODIFICATIONS ...........•............... 
5.1 
5.2 
5.3 
Minor Software Modification .............. . 
Minor Hardware Modification .............. . 
Major System Modification •...•......•..... 
1 
3 
4 
5 
5 
6 
6 
7 
7..-!r-
8 
8 
16 
20 
24 
27 
33 
33 
37 
43 
43 
44 
45 
1 
CHAPTER I 
INTRODUCTION 
The Star Communication Network is a very useful piece 
of laboratory equipment because much time and effort can be 
saved when data links are automated. This network replaces 
matrices of rotary switches or of plug networks. A computer 
or terminal, that is connected to this network, is able to 
quickly connect to other devices since an operator does not 
have to physically change a connection. The star network is 
similar to one type of automated telephone switching system 
since both use a central processor to control the flow of data 
from any input to any other output. Thus, a star network 
increases the power of a small computer system since it can 
easily connect to a larger computer system that has, for 
example, a mass storage device. Also, the star network can 
increase the usage of expensive peripheral devices, because 
many systems can easily access these devices through the star 
network. The topic of this paper is the design of a star 
communication network. 
This system must have the following requirements in 
order to be a useful tool. First, it must be easy to operate, 
because people will not want to learn a complicated computer 
language to do a simple task. If the commands are too difficult 
2 
to learn, people will avoid the use of this tool. Another 
requirement is that slower devices must be able to communicate 
with faster devices. Unlike the switch networks, the star 
network should let a 11~ BAU"D terminal communicate with a 9600 
BAUD microprocessor. This means that the star network must 
buffer incoming data. Finally, the star network must be in 
control of all conversations. Two l:ines, the 'Data Set Ready' 
and the 'Data Terminal Ready' lines, must be used to control 
the devices on the system. If a device tries to send too much 
data to the network, the system must temporarily halt the 
device so that data is not lost. 
This system is also designed such that it can easily 
be expanded. The initial star network is able to control 16 
I/O ports, but this may not be enough for future use. Identi-
cal 8 port I/O boards can be added to the system to expand the 
size of the network. The number of buffers must also increase, 
since the number of ports can be increased. Identical 8K RAM 
boards can be added to this system to increase its storage 
capacity. Finally, speed will be a very important factor, 
since the system can grow larger. An appropriate method is 
needed to increase the speed of this system. The final chapter 
of this paper will briefly explain one way to do this. 
3 
CHAPTER II 
USER COMMANDS 
There are two operating modes for this system. In 
command mode, a user can execute any of the user commands. The 
user will receive a prompt sequence from the star network to 
show that he is in command mode. A carriage return indicates 
the end of the command. An error message is printed if an 
invalid command is entered. An invalid character is ignored 
by the star and will not be echoed back to the device if it 
is in command mode. All ports are placed in command mode 
when the system is powered up or is reset. 
The second mode, connect mode, is used to transfer 
data from one port to another. The user will not be prompted 
by the star network in this mode. The user can go from connect 
mode to command mode by entering his command sequence. Ini-
tially, all ports have the 'ESC' key as their escape sequence. 
All but the last character of the escape sequence is passed 
on as data to the other port. A port can be prevented from 
disconnecting a link, by removing its escape sequence with 
one of the system commands. Most microprocessors should not 
be able to disconnect a link, so their escape sequence should 
be removed. Removal of this sequence will also increase the 
speed of the system. If a port receives an invalid character 
in connect mode, all the ports it is linked to will be put into 
4 
command mode and an 'Invalid Character' message will be printed 
on all ports. 
There are two types of user commands for this system. 
The first type of command is for the common user. He should 
be able to do basic operations such as connecting his port to 
another port. These commands have a basic construction such 
as the connect command, 'C 0, 1'. These commands start with 
a one letter code and may have a list of decimal parameters 
following it. These parameters are always separated by a 
comma. The other type of command is for a responsible user 
that knows how to operate the system well. These commands 
can control ports other than the users port, so one must be 
careful when using them. These commands contain either a pass-
word or a special parameter, so they have a structure different 
from the general user commands. Also, if a parameter is in-
valid or out of range, an 'Invalid Command' message will be 
printed rather than an 'Invalid Parameter' message. This way 
the common user will not know that these commands exist if he 
is playing with the system. 
2.1 Connect Command c #1, #2, •.• 
The connect command is a general user command and is 
used to connect two or more ports. A minimum of two parameters 
is required for this command. The star network will take the 
output from the first port and input it to the second port. 
Likewise, the output of the second port is input to the third 
port and so on. The output from the final port is input to the 
5 
first port. All ports must be in command mode to be put 
into connect mode. If one of the ports is in connect mode, the 
'Port Busy' message will be displayed, and all the unconnected 
ports will remain in command mode. 
2.2 Reconnect Command R 
The reconnect command, another general user command, 
is useful when a connection is accidentally dropped or when 
the same connection is always requested. This command re-
connects the users port in the same manner that it was 
previously connected. For example, if the user is on port 1, 
and he was connected to port 2, he could reconnect to port 2 
by using the reconnect command. Again, port 2 must be in 
command mode for the connection to occur. If port 2 is not 
in command mode, port 1 will remain in command mode and the 
'Port Busy' message will be printed on port 1. 
2.3 Status Command s #1, #2, ... , #5 
The status command, the final general user command, 
is used to print the status of part of the network. The user 
must input from one to five parameters for this command. The 
port number of the users terminal is the first piece of data 
to be displayed. A heading is displayed below this. Then 
one row of data is printed for each parameter that is requested. 
This data contains the escape sequence of that port in hexa-
decimal characters, the mode of operation, the input to that 
port and the receiver of that port's data. 
6 
2.4 Disconnect Command D #, PLEASE 
The disconnect command is used to disconnect a con-
versation that is external to the users port. The requested 
port must be in connect mode, otherwise an error message will 
be printed. If that port is in connect mode, all ports in 
that conversation will be put into command mode and the prompt 
message will be sent to them. This command is followed by 
the system's password, 'PLEASE'. If the password is not 
present, an 'Invalid Command' message is output to the user's 
terminal. 
2.5 Escape Command X#, PLEASE, YYYYYY 
This command changes the escape code of the requested 
port. This port can be in either command mode or connect mode 
for the change to occur. The system password follows the port 
number, in order to prevent a general user from changing escape 
codes. The final parameter is optional. If there is no final 
parameter, the escape code is erased. This port will not be 
able to disconnect a command and will not be able to execute 
commands. The system will run somewhat faster if escape codes 
are erased. If the final parameter exists, the escape code is 
updated to the contents of this parameter. The maximum length 
of an escape sequence is six characters. 
7 
2.6 Message Command M#, PLEASE, Message 
The message command sends a message from the users 
terminal to the requested port. This port can be in either 
connect mode or command mode. The port number must be followed 
by the system's password. The last parameter is the message 
that will be sent to the other terminal. A carriage return and 
line feed will automatically be placed at the end of this 
message. 
2.7 Baud Rate Command B#, XXXX 
The baud rate command updates the baud rate of the 
requested port. The second parameter is the three or four 
character baud rate. The allowable baud rates are: 
110 
1200 
300 
2400 
600 
4800 9600 
Two stop bits will be sent out for all 110 baud ports and only 
one stop bit will be sent out for all other rates. 
8 
CHAPTER III 
SYSTEM HARDWARE 
The hardware of the star network is broken up into 
four types of circuit boards that are connected by the systems 
backplane. The CPU board controls the entire system. The 
addressing signals and most of the control signals originate 
from this board. The program memory in ROM is also located 
on this board. A second board, the 8K RAM board, holds the 
system's tables and buffers. There is enough storage space 
for a twenty~four port system on this board. The third 
board, the 8 port serial I/O board, is the network's interface 
to all the devices. The initial system will contain two of these 
boards. The final board is the interrupt board. This board 
chooses the highest priority interrupt which will be passed 
to the CPU board and also generates the interrupt signal. 
3.1 CPU Board 
The CPU board is the brain of the star network. A Z8~ 
microprocessor is used in this design, because the 4MHz version 
of the Z-80 may possibly be used in a future version of the 
star network. Speed is a very important factor in this system. 
This 4 MHz version cannot be used until a faster program memory 
is used. There are two 2708, lK EPROMs on this board that 
hold the system's program. · These memories have an access time 
9 
of 500 ns, which is half the speed of the fast Z80. The lK of 
RAM located on this card, is mainly used for the stack and 
for some temporary variables. This RAM has an access time of 
around 100 ns which is more than fast enough for a 4 MHz system. 
Finally, there is an Intel 8251 USART to do the serial I/O for 
a system monitor. This device uses the I/O request line rather 
than the memory request line, so the Z80 will add an extra wait 
state for this device. Thus, only a faster ROM is needed 
to increase the speed of the CPU card (See also Chapter V). 
The diagram for the CPU board can be seen in the next 
five figures. Figure 3.1 illustrates the data bus structure 
of the system. The internal data bus structure consists of 
two unidirectional busses and are used for only the lower 32K 
locations. The DO# lines carry information from the processor 
and the DI# lines carry data to the processor. The DO# lines 
are always enabled, but the DI# lines are enabled when the 
INT DATA IN EN line is low. The external data bus, on the other 
hand, is a bidirectional bus. All external peripherals will 
have address locations in the upper 32K of memory. The 
EXT DATA IN EN signal enables data to flow from an external 
device to the processor. The EXT DATA OUT EN signal enables 
information to flow from the CPU board to another board. The 
external bus uses tri-state devices in both directions so that 
a possible second processor can use the system bus, while the 
main processor uses its internal bus. 
--
-
l.80 J Al4 
- --!1,--1 L~~- 1!'1.115_j l'f I~ ro J 1 10 I 
F.jf. DA1K IN tN. 
Elf. OMtK 001 EN . 
fAt. 61\tA IN fi\1 . Pr .s. .. . " \ !!Jn.. IT'll ;Jif r- ~ Ttl o~(IJ ,.., 
t __II p . LIS 1>1:7 los - l)l'C. ~ 
'ot tl .. bts -~ '[I Ol 
J l 1 4 l>lof - ~ r-1- 1 0 
1 
, 8Tt?u l.i bll ll. .. ~ 8T'f7 
...! 
"' 
I>U .. 
• "" 1 I ~ ., l..r!. bll I All Ll!. -5 - · 
Jh ... 1 14 
.. l>J4f 11 iR. c. l!l 
__n ~~ t>7C" &1 t!~ 
l 'I ~ "_, ril: L' _liS r l'!r IllllS un r-,. 
,_!. Et 
"" 4 · 81"11 81'11 l 
" 1'- ~ ~~ !Itt. 88 DS ,. 9: t)T'tf U:l"' 
,, 
0~ Ol OJ o4 Y 
·rt= ~ s 1 I I l)oft_; 15 611 
- bol 
El 
115 
Dot. I>J L.. ~ 1'1 
boS J:l 1 01 
I>Oof 
,.. 
J 01 1 4 
bos 
l>lt...... 
l 05 ... ~ 
bol 1>1~ 1 ., 8Ti7 1• .. 
t>ol 
r 11 11K At2. 15 11 
t>tC ,., I' n.l..!1 
""' u u . 
I' 1''5 DATA BUS STRUCTURE 
UNIVERSITY OF IlliNOIS 
ADVANCED DIGITAL SYSTEMS LAB 
C. PU BoiiiC:t> 
Folt f:891 MYEl> ~TIIIIt C.of1HUr.h<All0~ 
IJ!!.TklO It tt. 
IUA':l!/ .. /78 -~-L~ 1/Z. 
~-'I'C.IIL~t<J No.1 oF s MAD ... y A ,.,.OY-.0 tu:v. DESCitiPlloN DATE CHM:bBY 
Figure 3.1. CPU BOARD--DATA BUS STRUCTURE 
11 
Figure 3.2 shows the address bus and some of the 
processor generated control lines. These lines are uni-
directional so the internal lines are always enabled. The 
external lines have tri-state devices because other processors 
must control these lines, too. The EXT BUS EN line controls 
the tri-stating of the address lines. The external RD and WR 
lines are open collector to keep these lines in a high impedance 
state. There should be no glitches at all on these two lines 
because data may be destroyed on the memory card or on the 
I/O cards if a glitch occurs. The Ml line is used as a clock 
on the Interrupt Board so it is always enabled. The Bus 
Req line i ·s not used in this system but it will be used if a 
second processor is added. 
Figure 3.3 illustrates most of the additional control 
logic on the processor board and it can be broken up into 
4 smaller circuits. The first circuit is the reset generation 
circuit. A long reset pulse is needed by the CPU and other 
devices in the system to ensure proper initialization. The 
74123, monostable chip generates this pulse on power up and 
also when manually reset. Below this monostable is the system 
clock generator. This circuit generates the 2 MHz clock signal 
that is· used by the CPU and other devices. The crystal is easily 
changed to produce other clocking rates if desired. The wait line 
control and external bus control circuit are at the bottom of 
this figure. This circuit determines whether an off board 
device is requested and also determines whether an internal 
111. 
I.S 
' AJS ~ 21 .. 1 A lot ~ os r • 
' AU ;;:;:::.. " ~ t IT'tl Jt : .. 
Atz r:u ~ I At• II 
~· 'I ,, ... 
u u 
All :::::; " I! 114 
Ate c 14 II I 11 l A1 :::; ... 
• •'""' I tO I 
As c" M • l 
,oa I h -1 A 7 r::)'.' 
I I I~ 
A " :::::; '' 1 lJ 
A5 - •• 
., 
" s 
"' A'f ....... , '..,A3 
• IT"' I '• At c•• 
A 1 '' a At 1 Af ~· H ~ l I I 
.. . ..
ElT. 80S EN. 'I 
.. , 
•&5~~ 'f ' O . w~- 53 .If. ., .. toloz 
''-" cu 1-
:.~ 1'f0(, .. 5 
,., . 
" 1 ... " l"llJI 
-~J •I 14 I ~ 
• ll 
r- !t 8UT 
.,, f-ra~t 
..... 
I S I I 
-=-
. .. 
"I " pi "1 .. 
• 14 
' .l 
fl 9T1l 
~n II .. 
Ol . ... 
! I I I 
-=-
28~ J A14-
!I!J ..... ~"----r.t~·~Tr~ ril-'~l· . . ~ t ~~. r ·;:· f? .... 
- -::- l! -:: 
mEi 
• 
• 
... 
AI'J 
At 'I 
AU 
AU 
All 
Alfl 
A1 
All 
AT 
A4 
AS 
"" H 
At 
Al 
"" WI{ 
J~-1~ 
A1J 'flj()Of 
.. 
18) 
tomi 
;:tR(5 
UN IVERS 
Rl)i1r,l t~ '-' .. cu ADDRESS BUS 
'f'fO 
AND CONTROL 
ITY OF IlliNOIS 
DtGITAL SYSTEMS LAB ADVANCED  
C.PU BOARD 
'FIT.__ 51 
,0111 .... ~!.all " TAll GQMM\.INtUITIOft 
~-·· II I tl I lll'h.tot,., 
·T IDAfK .. , .. ,, .. 
_ 8T17 I I I 
.,,_ 
"lrV. DlrSCRlf>tiON DATI! 1:::::: lA a:5 
Fi gure 3.2. CPU BOARD--ADDRESS BUS AND CONTROL 
...-' 
I 
l90 
tc.""' A1't 
1 ~ fl ~ mff I 
t-tl til r z.·• 
.. s 
,., 1trnT 
~~~" IIJ I f l'IO'f 
IVIVI[; I "~ ~ 
I 1•1 I 
lHII• 
II< 
~D" I 1 1 
8USUlD111 I d~ol)o" 'I ' 
AIS • I t 
Ill 1'11'1 
Q'" 
wr.IT • 'I ' ~ 
~
;;;r.tc:" .. "I -- "' 
NOTE: 
-w1 ST!t"P I 'I> NE£0Eb WIIEIII 1 CP\.1 I'!> USE I> . 
RIEV. 
Figure 3.3. CPU BOARD--CONTROLLER 
1'10'f 
~
XRti 
CONTROLLER 
OIESCRIPTION 
r--------- hT fiiJs Ell. 
)" • INf DilfA 
""J1lEN. 
• EXT IJM A )~ -nrm:-
)" • EXT D"1A 
OJ¥ !A . 
~-----------~ 
J: :: 
-:- HC. 
UNIVERSITY Of' IlliNOIS 
ADVANCED DIOITAL SYSTEMS LAB 
CPU BOARD 
FOR reo 8115£0 ST"R COMP1VMIC'1Tiof'l 
tlET'\IOIORI( 
'/2 
~s 
14 
wait or external wait is requested. The wait line is not 
connected to the processor in the 2MHz system because no wait 
states are needed. Also the BUS EN input is strapped to ground 
since only one processor is being used and it will not have to 
share the buses. The final circuit on this drawing is the 
bus controlling circuit. Extended read, XRD, and extended 
write, XWR, pulses are generated to make sure that the buses 
are not disabled until after the RD or WR pulses go high. The 
rest of this circuit controls which bus should be enabled. 
Figure 3.4 contains the serial I/O circuit and the 
ROM circuit. The Intel 8251 USART is the serial to parallel 
and parallel to serial converter. This is the only chip on 
the CPU board that has a bidirectional data bus, so the 
internal data buses are merged with a tristate buffer. This 
tristate is enabled during an internal write. Some special 
signals are generated, because the 8251 is designed for an 
8080 system and not a Z-80 system. The delayed read, DRD, and 
delayed write, DWR, are needed because the read and write signals 
for the 8251 must occur after the chip is selected. The ex-
tended I/O request signal is used because the USART must still 
be selected after the write line goes high. The I/0 circuit 
also contains a programmable baud rate generator to produce 
an accurate clocking rate for the input and output of the 8251. 
This generator also produces the internal clock for the USART. 
Finally, the 1488 and 1489 interface chips convert the TTL 
~ 
voltage levels to the voltage level of RS232. This serial I/O 
' 
'"' ---·---!1 
Gl 
mn--+---. 
Wl(--+-t-..!!.1 
At• ' 
Dll 
bt4 
J)IS -
t>Iof ~ 
013 
Dll 
Dfl 
l>Ifof ~ 
I 
+ 
007 
ooc. . 
D05 
ooot 
~~,,3· 
~t>~" b03. 
bOot 
_l'f R. vOC."f""'.;_' ___ _ 
iWif =t:f ~K, 
Dot 
UJ 
~----~u.:::llrr 6T'fl :~: 
• "u.b10 1>041'-
l.o I( 
•s I • 
1T 
... , · •el 15J 
~ .k. fie. 
%0 
SERIAL VO 
... .. 
Figure 3.4. CPU BOARD--SERIAL I/0 AND ROM 
11118 
r~N11T 
lffL 
_r<=l6ND 
ROM 1 (2) 
At'5 
,., .. 
"'~ I 
A•t: ~~ ::~ :: 
wm,. /'flo( {~) 
,.., 
A8 
~A· 
llJAI 
Al I A~ 
Ac. I 1\(. 
A5 ' 5 
AI/ 111 
"' ~) At At • 
,., . 
Dll~---------------J 
biL~----------------_j 
17~8 
C 1 ( Di) 
btS~------------------__. 
-~ .. ~--------------------~ 
D%5~-----------------------J 
btl~-------------------------J 
t>tl~--------------------------j 
•! 
I• 
bt, I 
I UNIVERSITY OF IlliNOIS 
ADVANCED DIOITAl SYSTEMS lAB 
c." " eo111tD 
J'"O~ 1!~ 81\:!>Eb ~~2 t.O~M\)t.)IU\TIOrJ 
f\I£TWOitt( 
16 
port is accessed by doing an INPUT 1 or an OUTPUT 1 instruction. 
The status of this port is accessed by doing an INPUT ~ or 
OUTPUT ~ instruction. 
There are two identical ROM circuits on this CPU board. 
These circuits use a 2708 EPROM for a memory element. Even-
tually a ROM with a 250 ns access time should replace these 
EPROM's so that the CPU can operate at 4 MHz. Each ROM uses 
a 7485 as an address decoder. The possible address locations 
of these ROMs are between 0000 and 3FFF. Initially these 
ROMs will use locations 0000 to 03FF and locations 0400 to 
07FF. 
Figure 3.5 illustrates the lK by 8 RAM circuit which 
contains eight Intel 2125 memories. Since these RAMs have 
an access time of 100 ns, they do not need to be replaced when 
the system is modified. The RAM circuit uses the same address 
decoder as the ROM circuit. Initially the location of this 
memory will be from 3COO to 3FFF. 
3.2 Memory Board 
This system has many large buffers and tables and an 
8K RAM board is the correct size for a 24 port system. This 
RAM board is separated into two 4K circuits as pictured in 
Figures 3.6 and 3.7. Each circuit has its own address decoder, 
so that either group of 4K can be placed at any address in 
the system. Initially they will be located from addresses 
0000 to EFFF. This board also breaks up the system's bi-
directional data bus into two internal unidirectional data 
... 
A•!:-' 
/11'4 1 
lli3 ..... ----'.>j 
f.t2 ~s 
/111-----'-'1 
"'"----"'111 
~---- -----
ViR---- - - -····- ---,.....- t- ----jt-- lf---
Dn--------
bY~------------
t>ts•·-·- - - - -----
RAM 
II" llo'f"E. A() TIIROIJM4 A1 60 -ro IILL 1-iErfOF'~ I£S oN -roll~ rrt,r,r: . 
TilE f'r'-1 c..ot~~Jt:c. TrmJ~ ll~r; ~r.o.ow. 
AtJ - z. A 5 ~ ., 
/II - 3 
"' 
-
10 
~ z. - ., AT 
-
" /\3 - 5 AS - 12.
~~~ 
- ' A 1 -
,, 
- --·==-1---r---- -
--- -·-·---~-
toT'!•··· ·-· - ~ 11 - --·- - --f--1 1---l 
-·- · - - - ··-- ····t-~~:~ "=3 - --------~ 
bT.; . 
bi')'J. --· -- ------- --·- -·- 1- - --·-· - ·- -
l>OI. ..... ··- ... ~--·--·· .... 
bos•-- -----·-r- -· -~-==~=--·-·- · -----~:: . ..:.=~=--=~=-=--~==--=- ·=-~ : .-~-: :·~-==r==-~==t -~----· --
- ---boz~.·=~~-------- ------t-------b"' 
~--------
Figure 3.5. CPU BOARD--RAM 
•· -- --··- ·- - -~- ·· -- - - --
-· -- ------ - -
UNIVERSITY OF ILLINOIS 
ADVANCED DIGITAl SYSTEMS LAB 
C.P I) IV)IIP.t> 
FOR. P8-' {'11\:!>~b .S"t"l\~ C.""'HVNIC.IlnOM 
"'ETWOI!K . 
' 1 ~/l'-/71 1•exu,/z. 
'"rv. btt!K:NIPTION No. s ol' s 
~ '•• I 
~·.' ,, 
. ,, 1$ 
m:-1 
1115 
- - -
.... 
~Lt 
rrJK 
~ 
rrllf 
rrJl( 
~ 
en! 
n-n 
~ 
"f; 
MY. M!ICRIPTioN 
Figure 3.6. MEMORY BOARD--CONTROLLER 
.,,£3 
u.~ 
tl5"~ 
.... ~ 
t)l)t 
·<L!.'L_ ___ ,. I>O It 
I 
t\. u 
'115[ 
~--t---IltS 
IL--t----Dt'l 
II 
'I 
Ill!. ~;---Lt_j_J..r. 
Pl '<i;:;-----uL.C D" ._r__,=-'-------
•bt3 
bt z. 
bT 1 
Dt, 
.. 
0 
'L 
~ 
HUt . 
ffM; 
twf. 
,~., -
••m~" '1f' -~ 
f'IT11 
,1 
UNIVERSITY OF IlliNOIS 
ADVANCED DIGITAL SYSTEMS LAB 
l>OIIL 41<. MEHoRV 8oARt> 
J:OR ~~ 81\:!>Eb STnlt C.oHH'-""ICAToo~ 
WETwoRK. 
'lt. 
1 or 2 
' 
1
1";,_;' Dl ~5"- ~ ~ '"..":;~~ ' o 
,. u .. EI" · "" ,1- T~ U ... £~ a •. a n. 
m I' 
I~ r 
~., 
- - r · I·- I. .. 14 m 
(!, ' ~f.- f.-~ _.s -~ •• 'll bt til 1e or 'IZ. 
1>1.1.:..2.~11. bO l .., 1.12.5' 1-'- De b:t or bl!l 
Wi 
-
ll .,.. "' ~ lrf- H~ lt>r tt.t.~z.r 1.11.!1 
ct,:o- ttt 11< ~ ~ ~ C.t .. C.Ill B a_ 
r 
,, 
r 
.. 
m 
l , .. I. .. m 
c;. ...... ~ H-~ C\ it. 2.SwSl 0 1- ~ 1'- .. !18 
ll 1'5 jL t-2~ 8!'!'8,, 111 ... 1111. 111 
..,. _________ 
... 
... 
~l 
:~~ --. -· 
• 
d_ 1 .... ~ Df ~ 0[ ...... 3'-
~·z.os 2.12.~ 
E!l .,..Eiof._, .t.. 1 0o t:of ..-EIS 
es- i1 a If. 
r 
If 
- -
_ _j: ll't 
l-. -·- -- I-- I- -----r · 
.. Itt 
~ . ~~--- ~---~ ~ '-II .... , - Ill bl'll. ..... ., 
b!l 1.!::!11)11 b: 1 lib b'l Z.~51>1S 
1i.rs51 111 ~~--- ~---~~ 11110 .. !11 lllS C.' orC.1'4 '-" p.. '-' .,. t " Or (.15 
<:\ 0£\ ; Jl 
r r I" ' 
-
-- - ---
.... --~r-I. 1 .. IN 
~ .... ~ 15 ~--~ Co .. , 1.1 .- S't fZ t- rr L & _ ~· 
ttZ.S ~"" 8~ tit' &1'1 ~ f.lll) e~ 1!5BIS 
- ·- -· -h J 
1>01 ... . . - ······· - -- --~- - .. . ... - . .. . --···-·· -. - f·- . ~ 
- . .. 111 n u 
-· l'l II I~ 
A:ft-~ -It NOTE, Al1 Tlllt""6-tl "'' 
II LLLL(// GO To IIU. tU:HoiU£ S 
oil TillS PI'61E. Ttl( tiN 
C.ONN~t. TION$ AU liSTtb. 
-- - ---
-. 
llfl - a 
A 1 - l 
AJ. - • 
'" - ~ 
.... c. 
Figure 3.7. MEMORY BOARD--4K SECTIONS 
-
. .. 
115 - ~ 
'"' - '" 111 - II 
'" - tl 
"• - ,, RIEV. 
.. 
s .,.. ,, .-.I~ _15 or " •· !8 , ... '" .,. ~,-_ ------,_.11. Dr 6 ... 'lo 
J.llo!l 111$ 112.S' 111.$ 
!~•t"I!IC.·""I:t. _! 00 l!.orl!ll l!l or E18.t>ol~ ,.1."" '-!:&orF.I, 
-~- ·~· lt .a C!; ~ ~ ·r.r 
r 
11 
·0- '-- _o _ _r_· ~---J- --~~ --T· 
0 .. 
·- · -l. 1'1 1 ... I. 11 I . If 
c .. - ~ '-- ~ (S H.. C.'!> " i" f- - ~ CJ tf: .. '' _.,s -.. bt ,., ... .,. l'f -·n bt Ill ·~ -"8 1>52.'..!~1~ Ill! fl.. Z.t~S l.l25 ~ l IJO l.ll!l ~"" t>C. ... 'DI1 01 .. ot8.,., 0!1 or011 
... z ,";,/' Ill IS _ ~Ill Z,l- 5'1 l!l or !IS Dl ~~-- f.- f.!§ 1>1. ........ 5lo 
11-
ZIZS z•zs l:r. 
t.ll5' 
C5' or (.I~ to ~ .,.,c" ortll C.l .. l.l~"" ~1!>0 ce .... et' 
a. .. ~ ~ tJ;. Ill. 'n ~ 
r I"' 
I I"' r 
,., 
I' I 'I 
- --
.. . 
---- ·· 
-- -+-ll. l 1 .. 1 ... r. ... Itt 
~ ...... ~~-- 1-- JS cr il l:~ "''t I..:~ I- ~ a \ll , ..... l>l ,., ... ,_ 31, •• ~!· "' ~ ""n ... ~o'f 
Z.ll.$ iL 
e!f .... etto"" ~ ZIU Do "~ ... ll'l Z.t1.5 lll< 1 
""- "'' ""' 
T l.tlS ~!"" es-e•, 
II 
-
UNIVERSITY oF llliNOI: s 
SLAB 
- - -- ···- -·· 
M5CRIPTION 
ADVANCED DIOITAL SYSTEM! 
FOI:: i: 80 131\~E"b STIIR C.OI1HU'-'tCATIDN 
t.IETWORK 
DAniM.ol>a•Y IXF .. novlb .. - 11"10 Z - Z. 
CHtl"D•Y • 
20 
buses, since the Intel 2125 memory chips do not have bidirec-
tional data lines. The second of the figures shows how the 
control and data lines are connected to the memories. The 
address lines connect to all memory chips as described in the 
note on the drawing. 
3.3 Serial I/O Board 
The serial I/0 boards interface the series I/O devices 
to the processor of the star network. Each I/O board contains 
eight identical serial ports and one controller for these ports. 
Figures 3.8 and 3.9 illustrate the controller of the I/O 
board and other common circuits. The address decoder, part 
of the I/O controller, is quite different from the decoders 
on the other boards. Three pins on the edge connector, the 
B.A. pins, determine what port numbers are on that I/O board. 
If pins 59, 17, and 60 are all low, the board contains ports 
~through 7. If pins 59 and 17 are low and pin 60 is high, 
the board contains ports 8 through 15. Thus each identical 
I/0 board will have a different address bec:ause they will be 
plugged into a different coded connector. The boards must be 
placed in consecutive order with the first board in slot ~-
Once the port numbers are determined, the address 
locations that the board matches on are determined. Locations 
FFOO through FF3F are reserved for the status information of 
the Intel 8251 USARTs. If one reads location FFOO, he will 
read the status of port g. Port 1 will have its status location 
at FF~l and so on. Locations FF40 through FF7F are saved 
.. 
AI~ 
AN 
A~~ 
AI? 
~II 
,.,, 
1\'l 
AS 
A7 
AI. 
A~ 
M 
"·' 
A:. 
M 
"" 
r. .AC.D 
4~--~ 
1'lo'l 
:11 I 
~ · " · t> c:>!!'7 _______ _ 
6-,. ·" [_~ ~llllll> 1\llt:JRt~'!> '-'"''!!. 
I •1m ·po-t II ~ ~
'P----- u? 
.m: 
r~ll!: 
11" .. mo-
!Wl; 
sp:---iw." 
ofJ-L-- r .R•I 
F:1f; 
E l3U f:Fo' filii 
++- +------C=+------------~<.s'm 
lf6iT c-·· "I ,~ u .. n; 
53 "lA!<>!' . - .. --------~WR 
~srT 
·-----·· rtJ" ·· ~., 
,•lo•l 
~~.~. I 3~.. .. 6El' 
l'IO'f l'IO'# T ·'1,...-.,y: 
~ 
r /O (Ot-ITROLER .. 5 
REV. 
Figure 3.8. I/0 BOARD--CONTROLLER AND CLOCK 
'110JL •no.t. 
I ,., I 
~ -011111@ 
, . 
\• : 
•it>'~ .. <1. ( 
CUt. 
(3#\Ul> RIITE C.LOC.K GEPJERI\T'OR 
DE!K:ftti"TION DAnl::!:: 
UNfYEASITY OF IlliNOIS 
ADVANCED DIOITAL SYSTEMS LAB 
r to eo ARt> 
Foil ~flO ell$t1> !>TAl: C..OMMII~ICATIOal 
»ET..,o~.C 
'/z.. 
Of' .3 
... 
I • Pf' r•----------•. --~----· Br ~ 
bl 0 t b t7 E ~ ~0~ 
I I 01 I'H l 
L-------4--------~-----t--------.. ~Ol 
t>s 0 1 rul, 
b'-
1>7 D I 111/1 
b 3 
81.3 
----.. 1103 
·. 'I I .--D•I 
11"> 1 I I I I - I>!> 
~----------------
~I>EN----------------
Dl\ T A BIJ~ 
Figure 3.9. I/0 BOARD--DATA BUS AND INTERRUPT BUFFERS 
1 
c. 
!i 
RI:C.. If• 
INT. 3 
2 
1 
Ill• 
J 
" 5 
'1.HIT ., .. 
INT. 
3 
z 
1 
ltf:V. bf:9CitiP"TION 
8"T<f1 
4 
RE.c. 
~.!....:_"] 3 INT 
.,.b z 
~ ::J I 
n<:J ~ 
-::-0'""' 
-"' 
. 
'tHIT 
~ tNr 
2. 
tl 
~ 
INTER UP! BU~FERS 
UNIVERSITY Of' IlliNOIS 
ADVANCED DIGITAL SYSTEMS LAB 
:C /0 BOAI<.t> 
~OE. ~60 CII'!.F.t> ~1"Ait Co~H'-'~'""T'""' 
pJF.:r\llo~IC 
•IL 
OF" 3 
23 
for the programmable baud rate of the ports. Again location 
FF40 corresponds to the baud rate of port ~- Finally, addresses 
FF80 through FFBF are the locations of the data in the USART. 
If one reads location FF84, he will read the input of port 4. 
The I/O controller in Figure 3.8 has two major functions, 
address decoding and data bus control. The output of the 7485 
comparator in the address decoder determines -- whether the board 
is being accessed or not. The output of the top 74155 multi-
plexer enables the proper USART on a status or data request. 
The lower 74155 enables the proper baud rate circuit on a 
baud rate request. The read enable signal, RD EN, and the 
write enable signal, WR EN, control the data buses on the 
I/O board. Data will flow into this board when the write 
enable signal is low. 
Three small circuits are illustrated in Figures 3.8 
and 3.9. The Baud Rate Clock Generator is a 5.07 MHz oscilla-
tor that is divided down by the baud rate generators in 
Figure 2.10 to create the proper clocking rates. This circuit 
has two outputs, CLK and CLK. The Data Bus Controller circuit 
is the second circuit. This circuit controls the bidirectional 
data bus that connects the USARTs to the processor. This 
circuit also controls the data bus that is connected to the 
baud rate generators. The last of these circuits is the 
interrupt line buffers. The USARTs do not have the capability 
to drive a llO abmline, so these buffers are needed. Also, these 
buffers isolate the USART from the system bus. 
24 
Figure 3.10 shows one of the eight identical I/0 
sections. The 74157 data selector controls the data path to 
the 7475 baud rate latch. On a reset, the switched baud rate 
is clocked into the baud rate latch. The data bus is connected 
to this latch when a new baud rate is written from the CPU. The 
8T97, tristate buffer, is enabled when the baud rate is read. 
The programmable baud rate generator produces the internal clock 
for the USART and also produces the baud rate clock. The USART 
is the main component of the I/O section. The USART is connec-
ted to the CPU by the data bus and by some control lines. The 
data and handshaking signals are converted to RS232 levels in 
the 1488 and 1489 interface gates. The RTS line signals the de-
vice that the · USART is ready to receive . data. The DSR lin~ 
signals the USART that the device is ready to receive data. The 
+12V line should be strapped to the DSR line on the connector if 
these handshaking lines are ignored. 
3.4 Interrupt Board 
The final board in this system is the interrupt board 
and is pictured in Figure 3.11. The main element in this cir-
cuit is a 48 level priority decoder. The upper 24 lines are 
for receiver interrupts and the lower 24 lines are for trans-
mitter interrupts. The first six 74148 priority decoders deter-
mine which interrupt on the 48 lines has the highest priority and 
will put out the lower 3 bits of the number of the device. 
' ~ 
o~c. -- . - ~ ·- - ·~ - -- ~- ~- -- · -· ---- --~ -----·-· --.. -- -·---·----- - -------- -----·---·-
II<H li 
&oa. o's1'tf' .. .... , 
eot a. 1 t : . ·• .,,, 
&of I Jl I I j - ~- .1 IE. 
:if12 eta I! ! 0 ll T D~ 0,, .. 
eu. 1 fot fl If l't7SQ' ~ 
·•J--! ""(;"' eu 'Al'l'llS Gil~ bl Q 10 F.N ~ CIC 
etf 
' • "'~ 3 .,,_ . IC 0 c.m,« .!,___ •I~~ '1>1 ~~f- " $'0 
inT Qll- I e .. ,~»lllet 2~ .. 
" ~f-- m•"l- 8 "' 
•5 'A -~ 
u 1'1!1 .01 YA ~ 101!iU6 1-: fll-:z 3 11 !s >--
~ 1 I lr-H-l.J' ... l tof81 !;I..--... -- •• II~ til 01. 
' II G~-~Ol Wll. 1111"0 ·~ 
" I 114 10~ :11 1'1811 01 \T"ii;"- II 
"R5 ~•s " II. 10 ·CJ'fiAN. ll lt~'f vc.c. l1 (~115) G 6-,.o 
vn • 81.51 -!:- :l 
lD ,: 8 ~ u - 3 '"" Ol CJ ~'f:S 11 :l lo 
I UT - M 
• b'f ~ lu. Ol~o:.lt 
114. 
.. 113 m ~ I et .... , bS 
- -- r----.!1 ~ .,., 
-
l:ll iii j!1. I ·-- ~ t3 ",., .~~ ~ 
Ill 
- ·~ 111 ,., 
111 
.,,. ~ ~ .. UNIVERSITY OF IlliNOIS 
l 
lx ... -
ll. 
ADVANCED .DIGITAL SYSTEMS Ull 
-r 1 o e'->llll!o 
ONE OF EfGHT I/O .SECTIONS F'oll. ~~0 e"~l!t) STIIIII. (.0>4~\Jollc.IITIO"' 
foiE"T" woiU( 
1
'"""!r!lrhtt ~/L 
MAOC•Y 
I Dto'b~':, .bit .. ~,.. ... ~.a No. 3 ,,.. 3 lt~Y. M!ICitiPTION DATil C:M"'D eY 1•~""ovao 
-- I/0 BOARD--ONE I/0 SECTION Figure 3.10. 
.. 
:1 
"Z 
;:j 
0 
t r~,!:~~::_%·i:)Ol-4 rrt1". DEY. '·""' 
l 
. ' ~..SJ.:..L~-!J1Ebf:~4'f 
•f r'.lo-lo.l~ ......... .....,~---'"'1 
'5' r: ..... ..~o.:.._~~ 
. ~~--~~ 
1 r",....!:c!.:JIL-~..Lf 
8 ~~--~ 
J1cj Otl ~ ... _.., Ill 
_.Hv_,,~t 
.LJ:J~ 1 bJ 
1;: ' .. .I "" ~ I 1>1 
~ 
~ ~ > 
... 
.. 
" Ill 
"' 
IZ 
7'110 • 
r·~·~· 
XHIT ..,.. I REC. .. T 1-IO'f 
~ 
a 
J 
t 1 - · II ' 
i "" .. ~ 
" ~· 
.. 
r --
:E 
"' 2 ~ 
Figure 3.11. INTERRUPT BOARD 
RI!:V. bl!~btiPfioN 
UNIVERSITY OF IlliNOIS 
ADVANCED DIGITAL SYSTEMS LAB 
PRIORYT'I' INTEII:urr ,0/II::D 
Ft>lt J:e, ~~~~Eb STI\~ (0111ofOHICATION 
Ne:rwo~K 
IDAftq/t,/78 JSCAU Jjz.. 
16t•:: ~~ ... 4ALHT 
DATI!I"Aoi!•T Jl .. l'lioVib JNQ 
CHM"b • .,. • 
27 
The seventh 74148 determines the middle 3 bits of the device 
number and also puts out the interrupt signal if there is an 
interrupt. The highest order bit is set if a transmitter is 
the interrupting device; if this bit is not set then a receiver 
is the interrupting device. The Ml signal from the CPU clocks 
the interrupting device number into a latch so that it is 
stable during a read. The address location of this latch is 
FFFF. If there are no interrupts, the INT line will be high 
and a 3F will appear on the latch. An interrupt is removed 
when the interrupting device is read from or written to. 
3.5 Mother Board and the System Busses 
The backplane of this system is designed to minimize 
wave reflections at the ends of the lines and to minimize 
crosstalk between lines. This backplane consists of a one-
sided mother board mounted over a brass ground plane. The 
mother board connects some of the pins of the board connectors 
together in a bus system, while other pins are not connected 
so that they can be used for special interboard signals. The 
lines in the bus system form a group of coupled transmission 
lines since high frequency signals appear on them. This section 
will briefly explain the design and construction of this bus. 
There are many factors one must consider when designing 
the transmission lines in the bus. The characteristic impedance 
of the lines should be low to reduce the crosstalk between the 
lines, but it cannot be too low because the buffers cannot drive 
28 
low impedance lines. The dielectric constant of the mother-
board and the line width on this board determine the charac-
teristic impedance of the transmission lines, as shown in 
the Wheeler Curves in Figure 3.12. The dielectric of the 
motherboard should have good characteristics at high frequencies 
to reduce the loss in these lines. Teflon or epoxy glass are 
two examples of a good dielectric. A thick line will decrease 
the ohmic loss of the line especially if the line width is 
narrow. The line separation and line length also is an 
important factor in the bus design. The lines should not be 
too close together, otherwise the crosstalk between adjacent 
lines will be high. The bus should be as short as possible 
to reduce crosstalk. 
Once the board is etched, the characteristic impedance 
of the lines should be measured. A Time Domain Reflectometer 
(TDR) is used to measure the reflection coefficient, p, at 
every point on the transmission line. The following equation 
converts p to an impedance: 
z = 50 <1 + p). 1 p 
The characteristic impedance of the TDR is 50 ohms so a 50 ohm 
cable must connect the TDR to the motherboard. The wire connec-
ting the cable to the board must be as short as possible to get 
an accurate reading. Once the impedance is calculated, a 
resistor of that impedance should be placed at the other end 
of the line. The reflection coefficient of the line and the 
0 
. s 
IC 
• 
30 
reflection coefficient of the resistor should be the same on 
the TOR. 
Shorting capacitors provide an AC short for the ter-
mination network at high frequencies, and allow a DC bias 
voltage to be placed on the bus. These capacitors should have 
a very low impedance between the systems clocking frequency 
and the fifth harmonic of this frequency. A Vector Impedance 
Meter (VIM) can measure the impedance of capacitors at these 
frequencies. The leads of the capacitor should be as short 
as possible to take these measurements. The best capacitors 
to use for this short are 360 microfarad @ 6V, Tantalex capaci-
tors. These capacitors have an impedance less than 10 ohms 
below 20 MHz. 
Figure 3.13 illustrates the electrical design of the 
system bus to minimize crosstalk and reflections. There are 
two active terminations to put a 2.6 volt bias voltage on the 
bus. This will put all inputs to a high state but near the 
switching level to reduce crosstalk. The 360 microfarad 
capacitors provide the AC ground that terminates the data bus. 
180 ohm resistors, rather than 100 ohm resistors, terminate 
one side of the data bus, because the drivers cannot sink 
' 
enough current from the termination network to produce a 
reliable low voltage level with the 100 ohm resistors. There 
will be a reflection coefficient of .3 at this end of the bus 
because it is not terminated in 100 ohms. The data lines are 
positioned a few inches away from the address lines to reduce 
crosstalk between the two groups. Spacing is not as critical 
-----
-45--t-----, L ---·- ·- ·---::t--·-- -- - -·--·±· -----t-~--
-=- -= - ·j_ 
-= 
~RoM - ~I• 
'l10p~ IOO.ft. 
.,. 
UIU.U. 
+ 3'-0..f'! 
A 
v 
ISO St. 
r- ! ~ 
Wmt 
.r--------·- ·-:r-- t 
otH..., .. ---" JC,Q,.F 180J\y--1A:001---------
A1 --- --------
r-- -:.t -
-= 
l!o = IOO.Il.. -t~l• 
'l10pF IOO.Jt. 
:I l 
-= 
+5-----. 
• 
-= 
·- ----·-··-------~ AlS teo.n. 
Zlltlltl 
A ~-·--be· - - --- ------··----··· ----------
••oA bt ··-
------------ - --- ------
31.0 .. ::-L" I 
....L.F-········--- --·-· . --· ·-·-·---·  ····--·-· --·· ..  ··· ·· ·· .  -· ····· ·------- I 
D'l • I UNIVERSITY Of' ft.LINOIS 
31.0 .. ~ -t ADVANCED DIGITAL SYSTEMS LAB 
Rt:Y. bUCRli'TioH 
SVSTE.H eos 
f'o~ ~&<> eii~Et> ST)IIt C..OHJ-HhJot.I\Tt<*l 
IJOIO)Oitl( 
""!r I t'f/ ~1 i'c'"u 'Ia. 
lb:~~tlt' .. Al ,., ... 
bii.Ttl""0 "•• IXFr .. o¥16 1N0 
CHM'b •• • 
Figure 3.13. SYSTEM BUS 
32 
within each group since all lines change states at the same 
time. Close control lines like the RDM and ~1 lines, are 
separated by a ground line to reduce crosstalk between them. 
These lines are terminated at both ends to cut down on cross-
talk even more and also to reduce reflections. 
This is just a first attempt to design a'high speed 
bus system. If higher speeds are needed, the crosstalk and 
line reflections should be reduced even more. The line impedance 
could be reduced from 100 ohms to reduce the crosstalk problem. 
This is done by adding a second ground plane to the motherboard 
on the other side of the transmission lines. Plated holes 
in the board would make this bus easier to build. The line 
reflections could be greatly reduced if both ends of all the 
lines are terminated. The second termination can be 100 ohms 
or lower because no DC current flows through this resistor 
to upset the buffers. Capacitors should be placed from each 
line to g 1:ound unlik~ the termination on the other end, 
so that no DC current flows from one line to another. The 
value of these capacitors should be less than 500 pf, because 
this RC network must have a fast rise time. 
33 
CHAPTER IV 
SOFTWARE 
The discussion of the software in this system is broken 
up into two parts. First, the four major divisions of the 
system•s program are discussed. This will just be a brief 
descriptio~ of what each part does. The second part of this 
chapter describes how the system's tables and buffers are 
arranged and it will be a more detailed description of speci-
fic parts of the program. 
4.1 The System's Program 
The system's program is broken up into four major 
divisions, and the first one is the initialization routine. 
This routine executes immediately after a reset occurs. First, 
the number of 8_port I/O boards in this system are determined. 
Then all the tables and pointers are initialized. The USARTs 
are then initialized into the asyncronous mode. Finally, the 
USARTs are read twice to remove bad data. 
After the system is initialized, the enable loop rou-
tine is entered. The system allows si~ interrupts to occur 
before the next transmitter and receiver are scanned. This 
scan checks to see if either is disabled. The transmitter will 
be enabled if its buffer is not empty and the device is ready 
to receive data. The receiver will be enabled if its buffer 
is not full. After this scan is done, the port number is 
incremented and then the enable loop is reentered. 
34 
Figure 4.1 contains the flowchart of the interrupt 
routine. First this routine reads the device number and then 
determines if this is a transmitter interrupt or a receiver 
interrupt. If this is a transmitter interrupt, then the 
status of the buffer is checked. The transmitter will be 
disabled if its buffer is empty. Otherwise the next data 
word is transmitted to the device. If this is a receiver 
interrupt, then the following sequence of events occurs. 
The incoming data must be a valid character, otherwise the 
program jumps to the error section of the command routine. 
Next, the interrupt routine determines if the escape sequence 
was entered, and will jump to the escape section of the command 
routine if it was entered. If the escape sequence was not 
entered, the data is placed in a buffer. If the buffer becomes 
full then this receiver's interrupt is disabled and the device 
is signaled not to send any more data. 
Figure 4.2 contains the flowchart of the command routine 
which can be entered in two places. The first entry point is 
in the error section of this routine. If the port is in 
command mode, then the error is just ignored so it will not 
be echoed back to the device. If the port is in connect mode, 
then all devices connected to this port are placed into command 
mode, and an error message will be sent to each of these devices. 
Figure 4.1. INTERRUPT ROUTINE 
OISAeL.£ 
RE<:.E 1 IJ£Jl 
I)~~ - fl 
35 
36 
------, 
£RRO~ i 
t.IO 
Figure 4.2. COMMAND ROUTINE 
37 
The second entry point is in the escape section of this routine. 
If the escape sequence is entered and if the device is in 
connect mode, then all devices connected to this port are 
placed in command mode and are sent the prompt sequence. If 
the device is in command mode, then the processor decodes the 
command in the receiver buffer. The command will be executed 
if it is valid. Otherwise the command is ignored, and an 
error message will be sent to the · terminal. 
4.2 The System's Tables and Buffers 
The processor uies the tables and buffers for three 
major functions. The processor uses the three tables in 
Figure 4.3 to control the data flow through the system. The 
ReceiverBuffer Table (RBT) contains the location of the buffer 
that stores the data from a given port. This is a table of 
two byte entries. The port number must be multiplied by two 
and added to the address D¢¢¢ to find the position of the low 
order byte. The high order byte is in the next location in the 
table. The Transmitter Buffer Table (TBT) holds the buffer 
location that contains the data to be transmitted for a given 
port. This table is accessed the same way that the RBT is, 
except D~8~ is added to twice the port number. If both tables 
contain the same buffer position for a given port, then the 
port is in command mode. The buffer is a 256 word circular 
buffer, and it contains four pointers. Two of these pointers, 
the beg~n pointer (BGN PTR) and the end pointer (END PTR) 
38 
RBT Te"T'" 
rf - -~:..¢_ - -DCit~<Zt rf - _!) ~ ~&I -- - - - 01 01 
-- _f/1_'1_ 000Z ~ttl 0~92 
- -- - -- -oz O!S 
T- --1 r- -'J -J r.Jt/J D03E IJ~ DIJBE - - - -- - - D.A ES 
4 Rec. P1"R (jle 
OWl 
D1G& 
D1P8 
DlF"F 
Figure 4.3. TABLES FOR BUFFER CONTROL 
39 
contain the address of the first and last position in the 
buffer. The receive pointer (REC PTR) contains the location 
in the buffer to store the next data byte. This pointer is 
updated after a new byte is put into the buffer. If this 
pointer becomes equal to the transmit pointer after insertion, 
then the buffer has just filled. The transmit pointer (XMT PTR) 
contains the buffer location to retrieve the next data byte. 
This pointer is updated when a data byte is taken from the 
buffer. If this pointer becomes equal to the receive pointer 
after deletion, then the buffer is empty. 
The command table and the buffers hold data which the 
processor uses to control the command recognition routine. The 
command table contains the location of the commands in each 
buffer. The position of an entry in this table is found by 
adding the port (or buffer) number to EB¢¢. The receivepointer 
of the buffer contains the location that is one byte beyond 
the last character of the command. Two examples of this process 
are pictured in Figure 4.4. The command in buffer ¢ starts at 
location ~6. The command ends at location ~A which is one 
position before the contents of the receive pointer. The 
command in buffer 1 begins at location ~9. The end of the 
command is also position ~9 which is one position before the 
contents of the receive pointer. 
The processor uses the escape table to determine if a 
command has been terminated. The structure of this table is 
illustrated in Figure 4.5. Locations EC¢¢ to EC17 of this 
40 
~~¢...--
-
_fJ~ 
-
- -
~-
-
t • . T . 
L....--
auF 0 6UF' 1 
0~ l):Z.~ OA 
F'F' ~ 
~e D~¢:Z. ' OA 
O'f 04 
·~ D~~of 1- ~ 
- - -i' - - - - - - - - -? 
- - - - - - ~ - - - - - -:f.' D%~· 
- - -
? 
- - -- - - - -, ? 
- - )~ - - - - -·- - -02.'8 7 
- - - -
.,.._ 
- - - - -:, :. '11. I l+-
- - - -
- - - - -
-
' "+ ' '02.\fft 7 
- - - - - - -·- - -
.. 
-?- ? :l - - - - - - 1-- - -·- - -._ 
'"" 
D11b& l 
D]4A 
OlFF r = = = = = = r bZ.F~ r------r ------1 
Figure 4.4. TABLES FOR COMMAND RECOGNITION 
E5C.APE 
TA3~E 
00 
ECtl2. 38 
- - - - - - - - -
5'& I 
----:----* 
• I 
• I 
NXT PTR 3A 
- - - - - - - -? 
EOA 00 
- ~ 
. 
--
-:L 
TNX.T ?TR ~' T 
ECH E~C. 
l~~==r~~ 
"'"r- * 
ec.ss f'.)"cr J"TR 56 
EN tl P7'Ff S"D 
EC.SA '11' 
'e.' 
e.c.se '1. I 
--------
-L- - • - - ·~I • - - -1 
1----?----r 
Figure 4.5. TABLE FOR ESCAPE SEQUENCE CONTROL 
41 
42 
table are pointers to each port's escape sequence. The pointer 
of a given port is found at a location of EC¢¢ added to the port 
number. If this pointer is a ¢¢, then the port does not have 
an escape sequence. This port cannot execute commands or 
terminate a connection. If the pointer is a 38, then the 
port is in command mode and a carriage return is the escape 
sequence. If the pointer is a different value, then the port 
is in connect mode, and it uses its own escape sequence. The 
lower part of the escape table contains a group of 25 lists 
that hold the escape sequence for each port. These lists start 
at location EC38 and end at ECFF. Each list is allocated 8 
bytes and contains two pointers. Next pointer (NXT PTR) holds 
the location of the next character to be entered in the escape 
sequence. End pointer (END PTR) contains the location of the 
last character in the sequence. The list starting at location 
EC38 is used for ports that are in command mode and that can 
execute commands. The list starting at position EC40 contains 
the escape sequence for port ~ when it is in connect mode. The 
list for port 1 would start location EC48 and so on. 
43 
CHAPTER V 
FUTURE MODIFICATIONS 
This star network has been designed with the purpose 
to show that a microprocessor system can control a large 
number of devices. The present system can transfer approximate-
ly 3,000 data bytes per second. This rate can be increased by 
10% if only one port in every connection is allowed to termi-
nate the connection. This rate may not be fast enough if the 
system is used extensively. This chapter explains how to 
modify the system to increase the transfer rate. 
5.1 A Minor Software Modification 
The data transfer rate of this system can be increased 
if two software changes are made. The first and last memory 
position of a buffer is presently looked up because the length 
of the buffers can be variable. If the buffers are of a fixed 
lengt.h, then the Receiver Buffer Table, and the Begin Pointer 
and the End Pointer of each buffer, can be eliminated because 
these values can be calculated. This calculation is much 
faster than using a lookup table. The Transmit Buffer Table 
uses two byte entries to locate the proper table because the 
buffers can start at any memory position. If all buffers start 
at a memory position with ~~ as the lower byte address, then 
44 
this table can be reduced to one entry per buffer. If these 
two software changes are made, then the system's transfer 
rate can be increased by 15%. 
5.2 A Minor Hardware Modification 
The hardware of this system was originally designed 
with a ZB~-A microprocessor, which is the 4 MHz version of 
the ZB~ microprocessor. The 4 MHz version is not used in the 
final design, because a 2 MHz ROM is the fastest ROM available 
(within a reasonable price range) for use as program memory. 
If a faster program memory is used, the following changes must 
be made. First, a ZB~-A processor should replace the ZB~, 
because the Z8~ is operating at its highest speed. Also, the 
ROM sockets may need to be rewired to accept the new ROMs. 
Next, the wait line must be connected to the processor. There 
are still some 2 MHz devices on this system so that one wait 
state is added when accessing these devices. The USARTs on 
the I/O board are 2 MHz devices. 
If fast ROMs cannot be found, then the following trick 
can be used. There is lK of 100 ns RAM on this board. If 
lK more of this RAM is put onto this board, then the program 
can be moved from ROM to RAM. The processor can operate at 
4 MHz, because now the RAM conta±ns this program. The data 
transfer rate ~Till almost double if a faster program memory and 
CPU is used. 
45 
5.3 A Major System Modification 
The speed of the system may be very inadequate if the 
system is expanded. The system will have more processing power 
to increase this speed, if a board with four parallel processors 
replaces the single CPU board. This change will cause the 
interrupt board to be replaced by a board with a microprocessor 
that controls the system. The four parallel processors will 
be slaves to this control processor. The system's software 
must be separated into groups because the two types of processors 
have two different functions. This change is discussed in 
this section of the paper. 
The structure of these four slave processors should 
be similar to the structure of the single processor. Each 
of the slaves should have its own internal bus system to access 
2K of ROM and to access a small amount of RAM. A USART is 
not needed for these processors. Each CPU should have its 
own bidirectional tristate buffer to access the system bus. 
This entire structure is important because each of the slaves 
will be independent of the others for its program memory. Each 
slave will use the system data bus for 4% of the cycles in the 
interrupt routine, so there should be little contention for this 
bus. 
The interrupt board must be redesigned to perform the 
functions in Figure 5.1, by expanding the existing CPU board. 
A group of parallel input ports are added so that this processor 
can scan the interrupt lines and choose the next device to be 
.. 
E1-TER"'AL 
P~oc.esso~ 
(.OpfiROLLE.R 
llllrEIH~tJ~ ti~ES ' t ; 1 ' t I 
I I I I L.LLJ I I I I I I 
~ ~ 
PARALLEL I"'PV'r Po~T 
I;J 
C..PU 
!Ill!> IIlii 
C.\.1( AtK• kilO· 
~tNTERROPT" Ut!J lArc.H tl~TA ~0~ Co,.,T"'Ro LL.ER 
~ 1 I ~-u - If] [II 
1 z a ., 
'"r. RfQ 
1 I. 3 ., 
tNT. 
AC.IC· 
1 l 3., 
IIALT 
Figure 5 . 1. FUTURE INTERRUPT BOARD 
'llT 
IIUS 
lti:Y. 
~ 
~ 
!'Y.T 
110~ 
bfSChii"TION 
1t3'1 1Z3'f 1.23'1 
eo5 
l'l f:Q. 
C.l-~ 6\JS 
... ., .. ., 
bATt I~ 
A c. I<'. 
UNIVERSITY OF IlliNOIS 
ADVANCED DIGITAL SYSTEMS LAB 
rUT'IJR~ IIIIT~RRUI"T .,01'1~1> 
F'oR ~ e• tlll~f:D SrAR C.OI'lHliNI C:IITIO~ 
ta:nJOI'.I< 
~q In - twc•u • Ia. 
"Fbi ... c.111..5Kr INo. AI' "ovl 6 
47 
handled. The CPU will then put this device number into the 
Interrupt Latch which is still read at location FFFF on the 
system bus. This CPU must control the other four processors, 
hence the External Processor Controller (EPC) function is 
added to this card. · The CPU scans the four halt lines to see 
which of the slaves is idle. The controller uses the interrupt 
request lines to get a slave to respond to an interrupting 
device. The interrupt acknowledge lines signal the EPC to 
clear the interrupt request line. A final function that is 
added to this board is the System Bus Controller. The Bus 
Request . signal from the five processors, request the system 
data bus. This signal can be implemented by a 32 by 5 ROM. 
This circuit also generates a five phase clock which is used 
by all processors. This will cause the Bus Request signal of 
each processor to occur at a different time of a given cycle . . 
The four software routines of the one processor system, 
can be used in this new system, by making a few minor changes. 
Two of the routines, the interrupt routine and the command 
routine, are used as program memory for the slave processors. 
There are changes made to these routines, but when the processor 
returns from either routine, it must halt to signal the control 
processor that the slave is idle. The other two routines, the 
initialization routine and the enable loop, are used by the 
control processor as part of its program memory. The control 
processor will initialize the system after a reset, so the 
slaves should be halted. After the reset, the control processor 
should execute a scan routine which replaces the first part of 
48 
the enable loop of the existing system. This routine deter-
mines the next interrupting device and controls the EPC. The 
control processor then executes the second part of the old 
enable loop. 
