System for simultaneously loading program to master computer memory devices and corresponding slave computer memory devices by Hall, William A.
111111 111ll111111111111ll111111111111111 IIIII 11111 11111 llllll 111 Il1 1111 
United States Patent [I91 
US005 187794A 
[11] Patent Number: 5,187,794 
Hall [451 Date of Patent: Feb. 16, 1993 
[54] SYSTEM FOR SIMULTANEOUSLY 
LOADING PROGRAM TO MASTER 
COMPUTER MEMORY DEVICES AND 
CORRESPONDING SLAVE COMPUTER 
MEMORY DEVICES 
[75] Inventor: William A. Hall, Houston, Tex. 
[73] Assignee: Tbe United States of America as 
represented by the Administrator of 
the National Aeroneutics and Space 
Administration, Washington, D.C. 
[21] Appl. NO.: 323,748 
I221 Filed: MPT. 15,1989 
[51] Int. C l . 5  .............................................. G06F 15/06 
[52] U.S. Cl. ............................. 395/800; 3 6 4 D I G .  1; 
364/229; 364/240; 364/243; 364/187; 395/500, 
395/700; 371/16.1 
[58] Field of Search ... 364/200 MS File, 900 MS File, 
364/187; 395/500, 800, 700, 371/16.1 
[561 References Cited 
U.S. PATENT DOCUMENTS 
4,180,860 12/1979 Driscoll et al. ..................... 364/900 
4,451,884 5/1984 Keath et al. ........................ 364/200 
4,459,655 7/1984 Willemin .. 
4,660,170 4/1987 Hui et al. ...... 
4,675,803 6/1987 Kendall et 
4,700,292 10/1987 Campanini .......................... 364/200 
4,862,350 8/1989 Orr et a]. ............................. 364/200 
4,876.643 10/1989 McNeill et al. ..................... 364/200 
4,882,702 11/1989 Struger et al. ........... 364/900 
5,021.950 6/1991 Nishikawa .......... 364/200 
4,368,514 1/1983 Persaud et al. ..................... 364/200 
MASTER COMPUTER 
FOREIGN PATENT DOCUMENTS 
0159548 3/1985 European Pat. Off. . 
Primury Examiner-Thomas C. Lee 
Assistun: Examiner-Mehmet Geckil 
Attorney, Agent, or Firm-Hardie R. Barr; Guy M. 
Miller; Edward K. Fein 
t571 ABSTRACT 
A bus programmable slave module card 30 for use in a 
computer control system which comprises a master 
computer and one or more slave computer modules 
interfacing therewith by means of a bus and wherein 
each slave module includes its own microprocessor 
memory, and control program for acting as a single 
loop controller. The slave card includes a plurality of 
memory means corresponding to  a like plurality of 
memory devices in the master computer, for each slave 
memory means its own communication lines connect- 
able through the bus with memory communication lines 
of an associated memory device in the master computer, 
and a one-way electronic door which is switchable to 
either a closed condition or a one-way open condition. 
With the door closed, communication lines between 
master computer memory and slave memory are 
blocked. In the one-way open condition invention, the 
memory communication lines of each slave memory 
means connect with the memory communication lines 
of its associated memory device in the master computer, 
and the memory devices of the master computer and 
slave card are electrically parallel such that information 
seen by the master’s memory is also seen by the slave’s 
memory. The slave card is also connectable to a switch 
for electronically removing the slave microprocessor 
(45) from the system. 
4 Claims, 10 Drawing Sheets 
SLAVE COMPUTER 
11% 
J 
DOOR 
CLOSED 
LAST 
MEMORY 
CHIP 
https://ntrs.nasa.gov/search.jsp?R=19930009666 2020-03-24T07:28:54+00:00Z
U,S, Patent Feb. 16, 1993 Sheet 1 of 10 5,187,794 
(PRIOR 
10 
EXPERIMENT 1 
EXPERIMENT 3 
FIGURE 1 
US. Patent Feb. 16, 1993 Sheet 2 of 10 5,187,794 
(PRIOR ART) 
FIGURE 2 
US. Patent 
ND 
Feb. 16, 1993 Sheet 3 of 10 5,187,794 
\ 30 
33 
34 36 
OPTIONAL [ I 
32 
FIGURE 3 
U.S. Patent Feb. 16, 1993 Sheet 4 of 10 5,187,794 
E 
51 
PROGRAMMING - 
RECEIVING 
CIRCUITRY 
MASTER 
COMMUNICATION 
45 
CLOCK 
53 
SLAVE 
PAL MICROPROCESSOR 
44 
1 
- v 
A/D CONVERTER 
8 SINGLE ENDED OR 
4 DIFFERENT 
TO 
SOLENOIDS 42 
A L 
FROM ANALOGUE INPUT TO TERMINAL 
1 4 3 1  
SERIAL 
COMMUNICATIONS 
-TWO SERIAL PORT SECTIONS 
-ONE PARALLEL PORT 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
GHOST 
PAL 
SLAVE 
MEMORY 
CONTROL 
1 
I 
I 
I 
I 
1 
55.) 55 56 57 , 47 \ _ I - - -  
I - - - - - ,  + ic 
i ROMl ROM2 RAM BOOT PROM 
r 
I OPTION 
I Chip 
- 1  
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
I 
30 / 
FIGURE 4 
U.S. Patent Feb. 16, 1993 
F 
7 
MASTER 
CPU 
60 ' 
I SLAVE RESET, 
v) 
3 
M 
L3 
I- 
C/) 
Sheet 5 of 10 5,187,794 
BUFFERS k- --I 
DATA IN 4 BUFFERS 1-1 
4-1 BUFFERS bs 
I I 
6 4 ~ - ,  STATUS 
39 t- 
7 49 'L I SLAVECPU] 
/ 65 START 
I 
I  COMMAND^ I 4 RESET 1 BUFFERS I SLAVE 
I I 
FIGURE 5 
U.S. Patent Feb. 16, 1993 Sheet 6 of 10 5,187,794 
U 
w 
I- 
3 a. 
2 
0 
0 
w > 
I -  -3 r '  
I 1 I I J 
I - 
I 
cu 
T- 1. r" # N P 
T- 
F 
U.S. Patent Feb. 16, 1993 Sheet 7 of 10 
U 
W 
I- 
3 e 
2 
0 
0 
5,187,794 
U.S. Patent Feb. 16, 1993 
MASTER 
COMPUTER 
r- 
I 
100 
- 
Sheet 8 of 10 5,187,794 
SLAVE 
COMPUTER 
101a 119a 
w 
c 1  S i  E ' 1 0 5 J  
c2 ; 
C I  101b I 
I I 
I I 
I I 
I I 
I I 
COMMUNICATION 
LINES 
FIGURE 8 
U.S. Patent Feb. 16, 1993 Sheet 9 of 10 
a 
W 
I- 
3 e 
3 
0 
0 
W > 
v) 
4 
U 
W 
k 
3 e 
3 
0 
0 
W 
I- o 
r 
a 
a 
5,187,794 
‘;P =\ 0 
> a - -  
n 
a 
W 
I- 
n 
k 
K a 
U 
0 
E e 
W 
U.S. Patent Feb. 16, 1993 Sheet 10 of 10 5,187,794 
4 
0 a 
0 
w 
k 
0 
w 
f 
n 
a 
n 
n 
N 
-
i= 
U a 
a 
0 
E e 
U 
0 
w 
3 
r 
a 
ii 
5,187,794 
1 2 
block to  an area of RAM not accessible by the master 
CPU. In a second technique, a dual part RAM chip is 
used as the bus interface, acting as a bus buffer and data 
transfer mechanism controlled by the slave. This tech- 
5 nique provides maximum flexibility since all transac- 
tions take place via software but the software protocol 
is very involved to such degree that it is best written by 
SYSTEM FOR SIMULTANEOUSLY LOADING 
PROCRAM TO MASTER COMPUTER MEMORY 
DEVICES AND CORRESPONDING SLAVE 
COMPUTER MEMORY DEVICES 
ORIGIN OF T H E  INVENTION 
The invention described herein was made in the per- the manufacturer and then purchased as a software 
formance of work under a NASA Contract and is sub- routine to be added to a program. A further disadvan- 
ject to the provisions of Sections 305 of the National 10 tage evolves from the operating system of a micro- 
Aeronautics and Space Act of 1958, Public Law 85-568 processor control, hereinafter referred to  as “CP/M”, 
(72 Stat. 435; 42 U.S.C. 2457). in that there is a limited memory or RAM “window” in 
the normal memory map addresses which is accessible 
to  a user for programs. FIELD OF T H E  INVENTION 
In either of those prior systems, it is not possible to 
puter systems which comprise a master microprocessor load a program onto the slave card without assistance 
and several slave microprocessors and more panicu- from the CPU and a considerable collection of special- 
larly to a bus programmable slave module. ized development equipment. To run any application 
program, it is required that the program first be stored 
*O in some kind of read-only-memory or ROM. Accord- BACKGROUNDART 
Multi-microProceSsor computer systems are fie- ingly, such systems cannot handle dramatically differ- 
quently used for controlling industrial processes and ent application program philosophies without changing 
wherein one microprocessor acts as the master which 25 processor development stat,on and ROM programmers, 
provides overall system control and bus arbitration and Furthemore, to use a program On a master cpu re- 
controlling specific functions. Each slave board con- file and such serial downloading is very time tains its own control program and system components consuming, typically several minutes. such that, except for data logging or setpoint changes in 30 Representative systems in the prior art which make a database, it is able to function as a stand alone, single evident these limitations are illustrated in u.s, Pat, Nos. loop controller distributing the work load from one 4,459,655 and 4,700,292 which disclose computer sys- microprocessor to several microprocessors as neces- 
development of a particular industrial system or project 35 wherein equipment such as RoM program- 
different systems or projects. such systems, the flexi- development stations are required it if is desired to run 
bility of a slave board and how it may be utilized is an application program. U.S. Pat. No. 4,675,803 dis- 
restricted by the nature of the system, as being either closes a system with an interconnect processor coupled 
hardware-dependent or software-dependent. In a hard- 40 to a Slave Processor by a first bus and to an operator 
ware dependent system, the slave board closest to one station by a Second bus. While the slave Processor may 
end of the card cage has a higher priority than a slave be reprogrammed by the interconnect, an application 
card further away from that end of the card cage and Program must be stored in the erasable Programmable 
gets most of the bus attention to the disadvantage of the  read-only-memory (EPROM) or the non-volatile RAM 
slave card at the end of the priority chain which may 45 and cannot be downloaded to the slave. U.S. Pat. NO. 
have severe difficulty in obtaining required bus time. In 4,451,884 discloses a data processing system with a 
a variation of the hardware dependent system, the slave secondary subsystem containing Processor and memory 
Is permitted to temporarily take control of the bus while facilities separate from those of a primary subsystem 
freezing the master. However, this variation allows and U.S. Pat. NO. 4,180,860discloses a universal module 
only one master and one slave per bus and should the 50 for controlling process instrumentation and including a 
slave need the bus frequently, the master may experi- dual mode microprocessor wherein a microprocessor 
ence repercussions from the frequent interruptions. It is can exchange data with a host station or a remotely 
an advantage of hardware dependent systems, that since located device. 
SUMMARY OF T H E  INVENTION all bus arbitration is done in hardware, the programmer is freed from having to develop sophisticated master/- 55 
slave bus protocol software, but a major disadvantage is 
that a particular manufacturer’s slave boards will not 
work with those of another manufacturer. 
The software dependent systems are characterized by 
the use of “windowing” techniques wherein a portion 60 
of the read-and-write memory, hereinafter referred to as 
the RAM, is allocated common to both the slave and 
the master. In one technique, the allocated RAM is part 
of the RAM used by the slave. The central processing 
unit or “CPU” of the master stops the slave CPU and 65 
then transfers a block of information into the slave’s 
RAM area. The slave is then released and if its memory 
has been modified, the slave moves the new information 
This invention relates to  multi-microprocessor com- l5 
many kinds of complex system operations. Such come 
puter are typically IWter/slave systems 
either the hardware or reprogramming the read-only- 
memory by using external equipment such = a micro- 
the Other microprocessors act as r ~ ~ n s i v e  slaves for quires another program for downloading a command or 
sary. This capability therefore allows for a modular 
or alternatively, the simultaneous operation of several 
comprising and ’lave microprocessors 
mers* proprietary bus structures~ and microprocessor 
The invention is a bus programmable slave module or 
card for use in a multi-processing computer control 
system comprising a master computer and one or more 
slave computer modules which interface therewith by 
means of a standard data communications bus, and 
wherein each of said slave computer modules includes 
its own microprocessor, volatile and non-volatile mem- 
ory means, and a control program whereby it can act as 
a stand alone, single loop controller. The slave module 
card of the present invention is provided with a plural- 
ity of memory storage devices corresponding t o  a like 
plurality of memory storage devices in the master com- 
puter, for each of the slave memory storage devices its 
5.187,794 
3 
own set of memory communication lines connecting 
with the bus and connectable therethrough to the mem- 
ory communication lines of an associated correspond- 
ing memory storage device in the master computer, and 
a one-way electronic door. The electronic door on said 
slave card is operable by an appropriate switch means to 
either a closed condition or a one-way open condition. 
In the closed condition of the door, the memory com- 
munication lines between the master computer and the 
slave memory devices are blocked and the master com- 
puter is effectively isolated from the slave card in the 
non-programming mode of operation of the multi-proc- 
essing computer control system. In the one-way open 
condition of the door corresponding to  the program- 
ming mode of operation wherein it is possible to  pro- 
gram the bus programmable slave card of the invention, 
the memory communication lines of each slave memory 
storage device are in direct communication with the 
memory communication lines of its associated corre- 
sponding memory storage device in the master com- 
puter, and an electrical parallel connection exists be- 
tween the memory storage devices of the master com- 
puter and the memory storage devices of the slave card 
such that any information seen by the master’s memory 
devices is also seen by the slave’s memory devices. The 
microprocessor of the slave card is also connectable to  
said switch means which is selectively operable to  sever 
communications between the slave microprocessor and 
the slave memory storage means and thereby electroni- 
cally remove the slave microprocessor from the system 
when the master computer and the slave module card 
are in their programming mode relationship. Accord- 
ingly, with the master computer and the slave module 
card in their programming mode relationship, a user 
may load an application program in the memory storage 
devices of the master computer and thereby accomplish 
a parallel loading of the program into the memory de- 
vices of the slave card. 
BRIEF DESCRIPTION OF THE DRAWINGS 
FIG. 1 is an illustration of a multi-processing com- 
puter installation which is typical of the prior art; 
FIG. 2 is an illustration of an assembly of equipment 
which has been conventionally used for programming a 
slave module; 
FIG. 3 is a schematic block diagram of the slave card 
of the present invention; 
FIG. 4 is an illustration of a representative layout 
design for the slave card of the present invention; 
FIG. 5 is a schematic block diagram which illustrates 
the standard state of the slave card of the invention 
when operating in the general run mode; 
FIG. 6 is a schematic block diagram which illustrates 
the relationship of the master and slave in a non-pro- 
gramming mode of operation which uses the bus pro- 
grammable slave card of the present invention; 
FIG. 7 is a schematic illustration of the relationship of 
the master and slave when using the slave card of the 
present invention similar to FIG. 6, but showing the 
programming mode of operation; 
FIG. 8 is a schematic diagram similar to FIG. 7 de- 
picting the relationship of master and slave when in the 
programming mode and illustrating the parallel loading 
of memory; 
FIG. 9 is a schematic block diagram for a prior art 
system illustrating the relationship of the master and 
slave in the normal routine non-programming mode of 
operation; and 
5 
10 
I5 
20 
25 
30 
35 
40 
45 
50 
55 
60 
62 
4 
FIG. 10 is a schematic diagram for a prior art system 
depicting relationship of the master and the slave when 
operating a program routine. 
DETAILED DESCRIPTION OF THE 
INVENTION 
Referring more particularly to the drawings, there is 
shown in FIG. 1, a multi-processing computer 10 in a 
setup for controlling a multiplicity of experiments or 
projects, which might be any of a variety of processes 
or apparatuses for performing specific functions. By 
means of a terminal 12 and a connecting interface cable 
13, a user may issue commands to the computer 10, 
typiczlly a standard (STD) computer, which includes a 
master microprocessor module IS and slave micro- 
processor modules 16, 17, 18 installed and intercon- 
nected therewith in a common chassis. There may be 
more or less of such slave microprocessor modules. 
h c e  :le master and slave are programmed, a terminal 
is not necessary but can be used. Each microprocessor 
module includes its own CPU and microchips for an 
unalterable memory or ROM, and a volatile read-and- 
write memory or RAM. While the master microproces- 
sor acts as a masterbus arbitrator, each slave micro- 
processor module contains its own control program and 
except for data logging or setpoint changes, acts as a 
single loop controller. 
If it is desired to program a slave card, such as to  
reprogram or add an application program, an arrange- 
ment of equipment such as shown in FIG.  2 has hereto- 
fore been necessary. The programming setup requires a 
personal computer 20, a microprocessor development 
station 22 connected thereto by an RS 232 serial line 24, 
a microprocessor emulator 26 connected to the devel- 
opment station 22 by a ribbon cable 28 and to the multi- 
processing computer 10 by a similar connector cable 29. 
For this arrangement, the user unplugs the micro- 
processor from the particular target slave module and 
plugs in the emulator 26, whereby the emulator 26 and 
personal computer 20 can simulate the microprocessor 
which has been removed, with total control in the hands 
of the user. The user uploads the application program 
which has been written and cross-compiled on the per- 
sonal computer 10 and uploads the result to the micro- 
processor development station 22. From there the de- 
velopment station runs the program on the target slave 
system. In addition to the undesired amount of time 
required for the loading of an execute file and an appli- 
cation program with such external equipment, the 
equipment itself, particularly the microprocessor devel- 
opment station 22 is expensive and it is very difficult, 
sometimes impossible, for the user to  locate all the 
equipment in close enough proximity such that the emu- 
lator connector 29 can reach the slave module’s CPU 
socket with a very short restricted maximum length of 
connector cable. 
The bus programmable slave card 30 of the present 
invention shown in its layout-configuration in FIG. 4 is 
designed to allow interactive, microprocessor based, 
single loop control with the ability to load and run a 
program from the STD bus without the need of a mi- 
croprocessor development station and other specialized 
development equipment, thereby reducing capital costs 
for equipment, software development and testing, and 
reducing the time to load a program into a slave proces- 
sor by several orders of magnitude. The base configura- 
tion of the card 30, showing principal components and 
their interconnection, is illustrated in FIG.  3. As shown 
5,187,794 
5 6 
therein, the card comprises 64 K bytes of memory 31; a communication lines 105, and to the bus 110 by memory 
real time clock 33 indicating year, month, day, hour, communication lines 1050. Through the bus 110, its 
minutes, and seconds; four channels 35 for differential memory communication lines 1050 are also connected 
analog-to-digital conversion (or 8 channel single to  the electronic door 115 by communication lines 1056. 
ended): twelve channels of high powered relay type 5 Similarly, chip C2 1016 is connected by communication 
devices 37; and a central processing unit 39 or CPU lines 106,1060, and 1066 to the microprocessor 100, bus 
with master/slave bi-directional communication, and 110, and the electronic door 115, respectively, and chip 
bus/slave programming capability. In addition, one of C3 lOlc is connected by communication lines 107,1070, 
the following three options can be installed on the card: and 1076 to  microprocessor 100, bus 110, and electronic 
a counter time 32, and RS232 chip 34 for providing a 10 door 115. In the non-programming mode, the tn-state 
standard signal interface for terminal communication drivers of the door 115 are placed in a state such that the 
capability, or a digital-to-analog output chip 36. door 115 is closed and the memory communication lines 
A board layout for the card 30 utilizing one of the from the master can not pass through to the slave 
above options is shown in FIG. 4. As shown therein, the thereby placing the cards in functional isolation from 
card 30 is provided with its own microprocessor 45, 15 one another. 
which is connected directly or indirectly to all other In the programming mode, shown in FIG. 7, the 
functional chips on the board, such as a programmed- slave’s microprocessor 120 is electronically removed 
array logic chip 46 or GHOST PAL which connects from the slave board by operation of a toggle switch 
directly to the ROM 55 and RAM 56 memory chips for 129 to  the closed condition. If desired, the switch 129 
providing slave memory control. A boot PROM mem- 20 could be in the form of an electronic switch adapted to  
ory chip 57 for the bootstrapping process is also con- be operationally controlled by the master computer. In 
trolled by the GHOST PAL. addition, the electronic door 115 normally included in 
The microprocessor 45 is also in direct communica- the programming receiving circuitry is opened by the 
tion with an OPTION chip 47, selected from the three electronic removal of the microprocessor 120 which 
options noted above, namely a counter timer, R S  232 25 electronically place the tri-state drivers in a conducting 
signal interface chip, or a digital-to-analog converter. It state, thereby establishing Connection of the communi- 
also receives programming information from the mas- cation lines 1056 from the master’s first memory chip 
ter’s computer bus 49 through a programming receiving with communication lines 121~ between the electronic 
circuit 51 to which it is directly connected. When the door 115 and the slave’s first memory chip 1190, and 
programming receiving circuitry is used, the micro- 30 similar connections from the master’s second memory 
processor 45 is electronically removed by a switch chip with the slaves second memory chip 1196, and so 
means as will hereinafter be described. A circuit 52 on for the rest of the memory chips including the slave’s 
permitting two way master/slave communication be- last memory chip 119c, as by connection of communica- 
tween the microprocessor 45 and the master’s computer tion lines 1066 with connection lines 12z0, and commu- 
bus 49 is also provided. In addition, through a pro- 35 nication lines 1076 with communication lines 1230. In 
grammed-array-logic chip 40 the microprocessor 45 this way, all of the slave’s memory chips are put in 
communicates with a clock 41, an A D  converter 42, a 
serial communications chip 43 and a plurality of high 
powered relay chips 44 for solenoid operation to  con- 
trol such functions as fluid flow, etc. 
The bus programmable slave card 30 offers two 
modes of operation. The first is the general run opera- 
tion which characterizes the standard state the card will 
be in for most operations. The second is the program- 
ming mode, which deals with activities involved in 
programming the card from the STD bus. 
In the general run mode as illustrated schematically 
in FIG. 5, the slave card acts as a single loop slave 
processor to the master CPU. As a slave, it never gets 
on the STD bus. The card is totally self sufficient and is 
capable of running its own input/output functions as 
well as data transfers to and from the STD bus via the 
master. 
It will be seen in FIG. 5, that the slave’s CPU 39 is in 
two-way communication with the master CPU through 
the bus 49 and temporary data storage buffers 61-64 for 
receiving or outputting status and data information. It 
also receives start command signals and slave reset 
signals from the master CPU through the bus 49 and 
buffers 65. 
The interrelationship of the master computer card 
and a slave computer card is illustrated schematically in 
FIGS. 6, 7 and 8. As shown in FIG. 6, the master and 
slave microprocessor cards are joined by a common 
electronic bus, yet separated by an electronic door 115 
comprised of electronic parts conventionally referred to 
as tri-state drivers. In the master computer, the memory 
chip C1 lola is connected to  the microprocessor 100 by 
direct parallel with the master’s memory chips and as a 
result, any information seen by the master’s memory 
chips is also seen by the slave’s memory chips. This 
40 parallel connection relationship is shown more clearly 
in FIG. 8 wherein the common bus 110 and the elec- 
tronic door 115 are omitted. 
It will therefore be seen from FIGS. S through FIG. 
8, that all data and status information can be latched-in 
45 using tri-state buffers. In addition, the master can reset 
the slave card at will. If the slave is reset, then it will 
idle, waiting for a start program execution command 
from the master card. The slave card 30 does not re- 
quire any modification to the operating system and 
50 gives the user 64 k worth of programming space. This 
64 k can be configured as either EPROM or RAM in 8 
k blocks by a simple jumper selection without changing 
out chips or using outside voltage sources. 
The way in which the bus programmable slave card 
5 5  of the present invention is programmed is its most sig- 
nificant advantage, particularly when contrasted with 
the methods of programming slave modules in the prior 
an .  Prior art systems utilizing programming by the 
master, are centered around using a small amount of 
60 memory for programming instead of the entire memory 
as in the slave card of the invention. As result, a pro- 
gram is loaded in small sections at a time by the master 
microprocessor and then moved by the slave micro- 
processor to another part of the slave’s memory. 
In all cases the prior art systems will cover only a 
portion of their total memory with an electronic door, 
such as the one-way door 140 in the prior art system 
shown schematically in FIG.  9. Procedurally, the first 
65 
5,187,794 
7 
memory chip in the master computer, and possibly 
others, is loaded with software dedicated just to mas- 
ter/slave bus arbitration and the transferring of data 
from the last memory chip to  another memory other 
than memory chip 1. Depending on the type of actual 
master microprocessor 130 used, the last memory chip 
is used only as a mailbox drop off point and includes in 
simplest form two mail boxes 131, 132 and a temporary 
data storage area 133. The slave microprocessor 135 
will write a special code to  one of the two mailboxes 
wherein writing to the second mailbox is reserved for 
the master although either microprocessor can read all 
mailboxes. The slave processor 135 will periodically 
read its assigned mailbox to  see if it can read back the 
special code that it stored there. If it finally does read 
that code, it then reads the master's mailbox t o  see if the 
master left a message saying that data has been left and 
the slave needs to transfer it out of the last memory chip 
before new data can be transferred in. If a message was 
left, it then goes to  an assigned area in memory on the 
last memory chip and moves data from that area to 
some other memory chip, other than memory chip 1. 
There will be extensive additional electronic cir- 
cuitry involved t o  handle proper bus arbitration for use 
of the common bus 141 and which microprocessor 
(master or slave) gets to  talk to  the last memory chip 
and when. In the programming mode, illustrated in 
FIG. 10, the master microprocessor electronically re- 
moves the last memory chip 119c from the slave's mem- 
ory and makes it a part of its own memory. It then 
copies the necessary information onto this newly ac- 
quired memory chip, leaving a message in its assigned 
mailbox signifying that it has left new information for 
the slave microprocessor, and then gives it back to the 
slave. The slave microprocessor continues to scan for its 
special code that it placed in its mailbox. While the 
master has control of that last memory chip, the slave 
will not be able to read its special code and thus know 
that the chip is off line. When the memory chip is trans- 
ferred back to the slave, the slave will again be able to 
read its special code and then check the master's mail- 
box for status on new data. If it finds that new data is 
available, it transfers that data from the last memory 
chip to some other memory chip that is not accessible 
by the master. This process is repeated until all of the 
required information has been transferred. 
It will therefore be seen that by means of the unique 
bus programmable slave card of the present invention, 
the personal computer, microprocessor development 
station, emulator and cable are not required to program 
the slave card. In the programming mode the user nips 
a switch, sending the slave into tri-state suspension 
while its memory is imaged to the STD bus. At this 
stage, the user loads the application program into the 
master's memory. Once the program is loaded, the 
switch is closed and the slave is released. The master 
CPU is free to exit D D T  and continue other activities. 
The slave card can be programmed with a 16 k .com file 
in less than 4 seconds compared to more than 13 minutes 
using serial loading methods. Once loaded, the program 
can then be treated as either RAM or ROM depending 
on jumper selection. At this point the slave will monitor 
the status port for a command to start program execu- 
tion. It will loop endlessly until it receives that com- 
mand. 
It is also to be noted that a significant difference be- 
tween the slave card of the invention and the prior art 
devices is that the master/slave bus interface design of 
8 
the invention is based on the internationally accepted 
STD (Standard Bus) card system and can be both con- 
trolled and programmed by any STD computer system 
conforming to STD standards without the use of exter- 
5 nal equipment such as microprocessor development 
stations with emulators or ROM (Read Only Memory) 
programmers. In addition, the said program can be 
loaded onto the slave card of the invention into volatile 
RAM (Random Access Memory), without any assist- 
10 ance from its CPU, and run without any part of the 
application program first having to  be stored in some 
kind of ROM. Because of this unique feature (loading of 
an application program without any assistance from the 
slave CPLJ), the slave card of the invention can accept 
and run dramatically different application program 
philosophies without touching or changing any compo- 
nent thereon. These application programs can include 
commercial programs so long -LS 'hey 60 riot require a 
floppy disk. Furthermore, this card will run commercial 
2o programs which require a standard CPM operating 
system. 
While the foregoing description of the invention has 
been presented for purpose of illustration and explana- 
tion, it is to  understood that it is not intended to  limit the 
2s invention to the precise form disclosed. For  example, 
the particular layout and configuration for the slave 
card of the invention can be other than shown in FIG. 
4 as by adding or  reducing memory chips, or other 
3o functional chips. Electronic switches other than me- 
chanical switches 129 and 131 might also be provided. I t  
is to be appreciated therefore, that various structural 
changes may be made by those skilled in the art without 
departing from the spirit of the invention. 
35 I claim: 
1. A multi-processing computer system comprising: 
a master computer having memory means comprising 
at least one slave computer each slave computer fur- 
a plurality of memory storage devices: 
@ ther comprising: 
a microprocessor; 
slave memory means comprising a plurality of 
slave memory storage devices corresponding in 
number to  the plurality of memory storage de- 
vices in said master computer and electrically 
connected with said microprocessor; 
memory communication means for connecting 
each said slave memory storage device with a 
corresponding one of the plurality of memory 
storage devices in the master computer; 
electronic door means associated with said mem- 
ory communication means for effecting a first 
closed condition wherein said memory commu- 
nication means are blocked and a second one- 
way open condition wherein each slave memory 
device is connected with its corresponding mem- 
ory storage device in the master computer, 
switching means for selecting either said first 
closed condition or said second one-way open 
condition and electronically removing said elec- 
t r i a l  connection between said microprocessor 
and said slave memory means 
whereby upon operation of said switch means to  
place the electronic door in said second one-way 
open condition and to remove said microproces- 
sor from electrical connection with said slave 
memory means, loading a program into said 
memory storage devices of the master computer 
45 
50 
5 5  
60 
65 
5,187,794 
9 10 
also accomplishes simultaneous loading of the one-way communication whereby information input to  
program into said slave memory means. the master computer memory storage devices are input 
2. The multi-processing computer system as set forth to mid slave memory means, 
in claim 1 wherein said electronic door comprises a 3. The multi-processing system Bs set forth 
plurality of tri-state electronic devices, each of which is 5 in claim , wherein said of slave memory stor- 
age devices are a part of the volatile memory or RAM operably connected to one of said slave memory de- vices and to one of said master computer memory stor- 
age devices, and said tri-state devices are controllable Of said 'lave computer. 
by said swljtch means to mid first closed condition 4. The multi-processing computer system as set forth 
wherein the memory connection means ofeach mid pair 10 in claim 1 wherein said plurality of memory storage 
are blocked and said second one-way open condition devices are a part Of the nOn-VOlatik read-only-memory 
wherein the slave memory means and the master com- of said slave computer. 
puter memory storage of each said pair are connected in * . * * +  
15 
20 
25 
30 
35 
45 
50 
55 
65 
