DE1524134C - Multiple data processing system - Google Patents
Multiple data processing systemInfo
- Publication number
- DE1524134C DE1524134C DE1524134C DE 1524134 C DE1524134 C DE 1524134C DE 1524134 C DE1524134 C DE 1524134C
- Authority
- DE
- Germany
- Prior art keywords
- data processing
- data
- register
- processing device
- code
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired
Links
- 230000015654 memory Effects 0.000 claims description 60
- 238000000034 method Methods 0.000 claims description 18
- 230000000875 corresponding Effects 0.000 claims description 10
- 230000005540 biological transmission Effects 0.000 claims description 8
- 230000001276 controlling effect Effects 0.000 claims description 4
- 238000009434 installation Methods 0.000 claims 2
- 230000004044 response Effects 0.000 claims 1
- 241001442055 Vipera berus Species 0.000 description 22
- 239000004020 conductor Substances 0.000 description 19
- 238000010586 diagram Methods 0.000 description 12
- 230000000295 complement Effects 0.000 description 8
- 230000000903 blocking Effects 0.000 description 7
- 230000000630 rising Effects 0.000 description 5
- 230000000694 effects Effects 0.000 description 4
- 210000003608 Feces Anatomy 0.000 description 2
- 102100014171 RPL10A Human genes 0.000 description 2
- 101710013761 RPL10A Proteins 0.000 description 2
- 239000003990 capacitor Substances 0.000 description 2
- 230000003111 delayed Effects 0.000 description 2
- 241000196324 Embryophyta Species 0.000 description 1
- 235000008730 Ficus carica Nutrition 0.000 description 1
- 240000008401 Ficus carica Species 0.000 description 1
- 241000282941 Rangifer tarandus Species 0.000 description 1
- 238000005452 bending Methods 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 230000000052 comparative effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 230000002401 inhibitory effect Effects 0.000 description 1
- 239000010871 livestock manure Substances 0.000 description 1
- 230000000717 retained Effects 0.000 description 1
Description
Die Erfindung bezieht sich auf eine datenverarbeibende Mehrfachanlage, in der eine Vielzahl von datenverarbeitenden Geräten Zugriff zu einer Speichereinheit hat, um darin gespeicherte, durch Codes gekennzeichnete Posten gemeinsamer Daten zu verarbeiten, mit Registern zum Speichern des Codes und Vergleichsschaltungen zum Ableiten von die Verarbeitung der gespeicherten Daten steuernden Signalen. The invention relates to a data processing multiple system in which a plurality of data-processing devices have access to a storage unit in order to store them through Process items of common data marked with codes, with registers for storing the code and comparison circuits for deriving signals controlling the processing of the stored data.
Es ist bekannt, Gruppen oder Posten zusammengehörender Daten einem bestimmten Code zuzuordnen und diesen Code dazu zu verwenden, die Verarbeitung dieser Daten zu steuern, nämlich ein bestimmtes Programm zu unterbrechen, wenn der den Datengruppen oder -posten zugeordnete Code mit einem in einem Register gespeicherten Code übereinstimmt. In diesem Fall wird mit Hilfe einer Vergleichsschaltung ein Steuersignal abgeleitet, durch das das Programm unterbrochen und durch ein zu dem Code gehörendes Unterprogramm ersetzt wird. Bei diesem bekannten System ist jedoch dem Speicher nur ein datenverarbeitendes Gerät zugeordnet, und es wird mit Hilfe des die Dätenposten kennzeichnenden Codes das Programm beeinflußt, nach dem diese Daten verarbeitet werden.It is known to belong to groups or items To assign data to a specific code and to use this code for processing to control this data, namely to interrupt a certain program when the Code assigned to groups or items of data corresponds to a code stored in a register. In this case, a control signal is derived with the aid of a comparison circuit that the program is interrupted and replaced by a subroutine belonging to the code. In this known system, however, only one data processing device is assigned to the memory, and it the program is influenced with the help of the code identifying the data posts, according to which this Data are processed.
Im Gegensatz dazu befaßt sich die Erfindung mit datenverarbeitenden Mehrfachanlagen, die den Zweck haben, verhältnismäßig hohe Rechengeschwin-,In contrast, the invention is concerned with data processing multiple systems that the Have the purpose of having relatively high computing speed,
digkeiten zu erreichen, wie sie z. B. in Realzeit-Datenverarbeitungsanlagen oder in anderen Systemen benötigt werden, bei denen es erwünscht ist, daß eine maximale Menge von Daten in einer bestimmten Zeitspanne verarbeitet wird. Bei Verwendung eines üblichen Speichers ist jedes datenverarbeitende Gerät in der Lage, den Speicher aufzurufen. Wenn zu im Speicher enthaltenen Daten mehrere der datenverarbeitcndcn Geräte Zugriff haben, besteht die Ge-to achieve such things as B. in real-time data processing systems or in other systems where it is desired to have a maximum amount of data in a given period of time is processed. When using a common memory, every data processing device is able to call memory. If several of the data processing cndcn Devices have access, there is
3 43 4
fahr, daß die gleichen Daten gleichzeitig statt nach- F i g. 3 und 4 zwei Beispiele programmierter Untereinander verarbeitet werden, mit dem Ergebnis, daß programme, die zum Erklären der Prinzipien der die Wirkung der Operation, die von einem der daten- Arbeitsweise der vorliegenden Erfindung dienen, verarbeitenden Geräte ausgeführt wird, durch die F i g. 5 ein Blockschaltbild eines Teiles jedes der in Operation zunichte gemacht wird, die von dem ande- 5 F i g. 1 gezeigten datenverarbeitenden Geräte niit dem ren datenverarbeitenden Gerät ausgeführt wird. Ahn- mehr im einzelnen gezeigten Sperr-Register, liehe Probleme ergeben sich bei datenverarbeitenden Fig. 6 ein Blockschaltbild der Vergleichsschal-Mehrfachanlagen, in denen jedes datenverarbeitende tung jedes der datenverarbeitenden Geräte nach Gerät dazu geeignet ist, jede von einer Vielzahl von Fig. 1,drive, that the same data simultaneously instead of after- F i g. 3 and 4 two examples of programmed one below the other processed, with the result that programs that explain the principles of the the effect of the operation served by one of the data modes of the present invention, processing devices is carried out by the F i g. 5 is a block diagram of a portion of each of the FIGS Operation nullified by the other 5 F i g. 1 shown data processing devices with the ren data processing device is running. Ahn- more specifically shown lock registers, Problems arise in the case of data processing. in which each data processing device follows each of the data processing devices Device is suitable for any of a plurality of Fig. 1,
Funktionen auszuführen, und in denen es erwünscht io F i g. 7 ein Teilschaltbild der Programmsteuerein-Perform functions, and in which it is desired io F i g. 7 a partial circuit diagram of the program control
ist, und daß eine beliebige gegebene Funktion zu heit jedes der datenverarbeitenden Geräte,is, and that any given function is to be called each of the data processing devices,
einer beliebigen gegebenen Zeit nur von einem ein- F i g. 8 und 9 Impulsdiagramme zum Erklären derat any given time only by one single F i g. 8 and 9 are timing charts for explaining FIG
zigen datenverarbeitenden Gerät ausgeführt wird. Arbeitsweise der erfindungsgemäßen Verriegelungs-umpteen data processing device is running. Operation of the locking device according to the invention
Demgemäß liegt der Erfindung die Aufgabe zu- mittel,Accordingly, the object of the invention is to
gründe, eine verbesserte datenverarbeitende Mehr- 15 Fig. 10 ein Schaltbild einer Ausführungsformreasons, an improved data processing system. 15 Fig. 10 is a circuit diagram of an embodiment
fachanlage zu schaffen, die eine Vielzahl von daten- eines in den vorhergehenden Figuren gezeigtenCreate specialist system that contains a large number of data - one shown in the previous figures
verarbeitenden Geräten aufweist, die zu einem ge- NAND-Gatters,processing devices that lead to a gene NAND gate,
meinsamen Speicher, in dem gemeinsame Daten ge- Fig. 11 ein Blockschaltbild einer Ausführungs-common memory, in which common data is Fig. 11 a block diagram of an embodiment
speichert sind, Zugriff haben, jedoch so gegenein- form eines in den vorhergehenden Figuren gezeigtenare stored, have access, but in a counter-form to one shown in the preceding figures
ander verriegelt sind, daß zu einer beliebigen Zeit 20 Flipflops,other are locked so that at any one time 20 flip-flops,
nur ein datenverarbeitendes Gerät die gemeinsamen Fig. 12 ein Blockschaltbild einer Ausführungs-Daten auf den neuesten Stand bringen oder auf form eines Gatters zum Ausführen des Komplements andere Weise verarbeiten kann, damit keine wich- der exklusiven ODER-Funktion, das in der Vertigen Daten verlorengehen können. gleichsschaltung nach F i g. 6 verwendet wird,only one data processing device the common Fig. 12 is a block diagram of execution data Bring it up to date or in the form of a gate to perform the complement can process it in a different way, so that no one gives way to the exclusive OR function that is in the Vertigen Data can be lost. equivalent circuit according to FIG. 6 is used,
Diese Aufgabe wird ausgehend der eingangs er- 45 Fig. 13 eine Übersicht über das Komplement der wähnten datenverarbeitenden Mehrfachanlage nach exklusiven Oder-Funktion und der Erfindung dadurch gelöst, daß in jedem der F i g. 14 ein vereinfachtes Blockschaltbild, das zwei datenverarbeitenden Geräte ein Register und eine datenverarbeitende Geräte zeigt, die mit einem meh-Vergleichsschaltung vorgesehen sind, daß die Ver- rere Bänke umfassenden Speicher verbunden sind. · gleichsschaltung jedes Gerätes den in das zugeord- 3° Fig. 1 zeigt das Blockschaltbild von zwei datennete Register eingegebenen Code jeweils mit den verarbeitenden Geräten Pl und P 2, die mit einer Codes vergleicht, die in den Registern der anderen Speichereinheit 20 verbunden sind, die einen Speicher datenverarbeitenden Geräte enthalten sind, und ein 21, ein Adressenregister 22 und ein Datenregister 23 Vergleichssignal erzeugt, daß einen bestimmten Wert enthält. Obwohl nur zwei datenverarbeitende Geräte annimmt, wenn in dem Register eines anderen daten- 35 gezeigt sind, versteht es sich, daß eine beliebige Anverarbeitenden Gerätes schon der gleiche Code vor- zahl datenverarbeitender Geräte mit der Speicherhanden ist, und daß in jedem der datenverarbeitenden einheit 20 verbunden sein kann. Das datenverarbei-Geräte Mittel zur Programmsteuerung vorgesehen tende Gerät P2 ist dem datenverarbeitenden Gerät Pl sind, die auf das in dem jeweiligen Gerät erzeugte gleich und hat gleiche Bezugszeichen für gleiche EIe-Vergleichssignal ansprechen und die Übertragung des 40 mente. Das datenverarbeitende Gerät Pl enthält ein Postens gemeinsamer Daten, der durch den in das Pufferregister (B-Register) 31, ein Befehlsregister Register dieses Gerätes eingegebenen Code gekenn- (C-Register) 32 und einen Programmzähler (P-Zähzeichnet ist, aus der Speichereinheit auf das Gerät zu ler) 33. Allgemein ist es die Funktion der Register 31 sperren, wenn das Vergleichssignal den bestimmten und 32, Daten von dem Datenregister 23 der Wert aufweist, so daß zu jeder Zeit nur eines der 45 Speichereinheit 20 zu empfangen, und.es wird wenigdatenverarbeitenden Geräte einen durch einen be-- stens ein Teil der Daten, die von dem Befehlsregister stimmten Code gekennzeichneten Posten gemeinsamer 32 empfangen werden, in einem Decoder 34 decodiert, Daten zu verarbeiten vermag. um decodierte Programmsteuersignale zu liefern, die,This task will be based on the initially shown 45 Fig. 13 an overview of the complement of the mentioned data processing multiple system according to the exclusive OR function and solved the invention in that in each of the F i g. 14 is a simplified block diagram showing two data-processing devices a register and a data-processing device shows that with a meh comparison circuit it is provided that the memories comprising other banks are connected. · Each device is connected in the same way as in the associated 3 ° Fig. 1 shows the block diagram of two data networks Register entered code in each case with the processing devices Pl and P 2, which with a Compares codes that are linked in the registers of the other memory unit 20 that has a memory data processing devices are included, and a 21, an address register 22 and a data register 23 Comparison signal generated that contains a certain value. Although only two data processing devices assumes that if data is shown in someone else's register, it goes without saying that any processor Device already has the same code pre-number of data processing devices with the memory hand is, and that in each of the data processing unit 20 can be connected. The data processing devices Means for program control provided tend device P2 is the data processing device Pl are identical to that generated in the respective device and have the same reference symbols for the same EIe comparison signal address and transfer the 40 mente. The data processing device Pl contains a Item of common data entered by the buffer register (B register) 31, a command register Register of this device identified code entered (C-Register) 32 and a program counter (P-counting is to read from the memory unit to the device) 33. In general, it is the function of registers 31 disable when the comparison signal is the determined and 32, data from the data register 23 of the Has value so that only one of the 45 storage units 20 can be received at any given time, and it is less data-processing Devices one by one, at least part of the data that is received from the command register Correct code marked items common 32 are received, decoded in a decoder 34, Able to process data. to provide decoded program control signals which,
Durch die Erfindung wird also eine verriegelte wie dem Fachmann bekannt ist, dazu verwendetThe invention therefore uses a locked one, as is known to the person skilled in the art, for this purpose
datenverarbeitende Mehrfachanlage geschaffen, in der 5° werden, verschiedene Vorgänge in dem datenverar-data processing multiple system created in which 5 °, various processes in the data processing
gemeinsame Daten in einer Speichereinheit gespei- behenden Gerät zu steuern, das auch einen Takt-to control shared data in a storage unit, which also has a clock
chert sind, zu der jedes der datenverarbeitenden Ge- geber 35 zur Lieferung von Taktsignalen umfaßt,are chert, to which each of the data processing encoders includes 35 for the delivery of clock signals,
rate Zugriff hat, bei der jedoch die Daten zu jeder Zusätzlich umfaßt das Datenverarbeitungsgerät P1rate has access, but in which the data on each addition includes the data processing device P1
beliebigen Zeit nur von einem der datenverarbeiten- einen Parallel-Addierer 38, der zusammen mit einemany time only from one of the data processing a parallel adder 38, which together with a
den Geräte auf den neuesten Stand gebracht werden 55 Flipflop 39 mit Mitteln zur Programmsteuerung, näm-the devices are brought up to date 55 flip-flop 39 with means for program control, namely
können, während jedes andere der datenverarbeiten- lieh einer Programmsteuereinheit 40, verbunden ist,can, while each other of the data processing lent a program control unit 40, is connected,
den Geräte, das während dieser Zeit die gleichen ge- deren Funktion hernach im einzelnen beschriebenthe devices that have the same function during this time are described in detail below
meinsamen Daten benötigt, in einer Art Wartestel- werden wird. Die Arbeitsweise des Schaltungsauf-shared data is needed in a kind of waiting position. How the circuit layout works
lung gehalten wird, bis die auf den neuesten Stand baues des datenverarbeitenden Gerätes Pl, der zuvorment is held until the up-to-date construction of the data processing device Pl, which was previously
gebrachten gemeinsamen Daten zu der Speicherein- 6° beschrieben wurde, kann am besten in VerbindungThe shared data brought to the memory 6 ° can best be related
heit zurückgeführt worden sind. mit Fig. 2a erläutert werden, die ein Schema eineshave been returned. be explained with Fig. 2a, which is a scheme of a
Im folgenden wird ein Ausführungsbeispiel der Er- Befehlswortes 45 darstellt, das aus dem Speicher 21In the following, an embodiment of the Er command word 45 is shown, which is from the memory 21
findung an Hand der Zeichnung beschrieben. Es zeigt über das Register 23 in die Register 31 und 32 vonFinding described on the basis of the drawing. It points via register 23 to registers 31 and 32 of
Fig. 1 ein allgemeines Blockschaltbild einer er- Pl abgerufen werden kann. Wie es sich für den findungsgemäßen datenverarbeitenden Mehrfach- 65 Fachmann versteht, wird das Befehlswort 45 dadurch1 shows a general block diagram of an er-PI can be called up. As it is for the understands the inventive data processing multiple expert 65, the command word 45 is thereby
anlage, erlangt, daß das Adressenregister 22 mit dem Signalplant, obtains that the address register 22 with the signal
Fig.:2a und 2b Schemata von Befehlswörtern des in dem Programmzähler33 erregt wird, das eine in der erfindungsgemäßen Anlage verwendeten Typs, Adresse, wie z.B. X, desjenigen Befehlswortes dar-Fig.:2a and 2b Schemes of command words that are excited in the program counter 33, which is a type used in the system according to the invention, address, such as X, of that command word.
stellt, das von dem datenverarbeitenden Gerät P1 gewünscht wird. Wie Fig. 2a zeigt, umfaßt das Wort 45 18 Bits, von denen die ersten 5 Bits zur Bildung eines Operationscode verwendet werden. Die Bits 5 bis 8 definieren ein erstes Ä-Feld, das zusammen mit dem Operationscode auf das Befehlsregister übertragen wird, während die Bits 9 bis 17 ein F-FeId bilden, das auf das Pufferregister übertragen wird.represents that desired by the data processing device P1 will. As FIG. 2a shows, word 45 comprises 18 bits, of which the first 5 bits are used to form an operation code can be used. Bits 5 to 8 define a first λ field which, together with the operation code is transferred to the command register, while bits 9 to 17 are an F field which is transferred to the buffer register.
Der Code in den Bits 0 bis 4 wird in dem Decoder 34 decodiert, um. Steuersignale zu liefern, die. zur Steuerung der Verarbeitung der Daten in den Feldern Y und R, die in den Registern 31 und 32 gespeichert sind, in Verbindung mit anderen Daten, die in Schieberegistern, Akkumulatoren und/oder anderen nicht gezeigten Schaltungsteilen des datenverarbeitenden Gerätes gespeichert sind, durch das datenverarbeitende Gerät dienen. Methoden zum Decodieren eines Operationscode zum Steuern der Verarbeitung der von einem Speicher erhaltenen Daten durch ein datenverarbeitendes Gerät sind wohlbekannt und werden deshalb nicht im einzelnen beschrieben. Außer der Decodierung des Operationscode liefert der Decoder 34 auch ein Signal, das der Programmsteuereinheit 40 zugeführt wird. Die Funktion dieses Signals ist es, zu bewirken, daß der Programmzählef 33 seinen Inhalt, d. h. X, dem Parallel-Addierer 38 zuführt und das Flipflop 39 einstellt, das als eine Quelle eines +1-Wertes betrachtet werden kann, so daß eine +1 auch auf den Addierer 38 übertragen wird. Infolgedessen ist sein Ausgangssignal X+l, das nach Beendigung der Verarbeitung des letzten Befehlswortes auf den Programmzähler 33 übertragen wird, um von dem Speicher das nächste Befehlswort anzufordern, das sich an der Adresse X+1 befindet.The code in bits 0 through 4 is decoded in decoder 34 to. To deliver control signals that. to control the processing of the data in the fields Y and R, which are stored in the registers 31 and 32, in connection with other data which are stored in shift registers, accumulators and / or other circuit parts of the data processing device, not shown, by the data processing device Serve device. Techniques for decoding an operation code to control the processing of data received from a memory by a data processing device are well known and therefore will not be described in detail. In addition to the decoding of the operation code, the decoder 34 also supplies a signal which is fed to the program control unit 40. The function of this signal is to cause the program counter 33 to apply its contents, ie, X, to the parallel adder 38 and set the flip-flop 39, which can be considered a source of a +1 value, so that a +1 is also transmitted to the adder 38. As a result, its output signal is X + 1, which is transferred to the program counter 33 after the processing of the last command word has been completed, in order to request the next command word from the memory, which is located at the address X + 1.
Nach den Lehren der vorliegenden Erfindung enthält jedes der datenverarbeitenden Geräte Pl und P 2 eine Verriegelungsschaltung 50, die verhindert, daß die beiden datenverarbeitenden Geräte gleichzeitig einen Posten gemeinsamer Daten aufrufen und auf den neuesten Stand bringen. Kurz gesagt, umfaßt die Verriegelungsschaltung 50, die hernach im einzelnen beschrieben werden wird, ein Sperr-Register (L-Register) 51, das auf Daten in dem B-Register 31 und dem C-Register 32 und auf decodierte Signale von dem Decoder 34 anspricht, um das L-Register 51 einzustellen und darin Daten zu speichern, die eine Codezahl darstellen, die einen speziellen Posten gemeinsamer Daten zugeordnet ist. Das Ausgangssignal des L-Registers 51 des einen Gerätes 51 wird zusammen mit dem Ausgangssignal des L-Registers 51 des anderen datenverarbeitenden Gerätes P 2 einer Vergleichsschaltung 52 zugeführt. Der Ausgang der Vergleichsschaltung 52 ist mit der Programmsteuereinheit 40 und einer Schaltung 53 zur Rückstellung des Sperr-Registers verbunden, die bei entsprechender Ansteuerung das Sperr-Register 51 wieder zurückstellt. " ' . 'In accordance with the teachings of the present invention, each of the data processing devices P1 and P 2 includes an interlock circuit 50 which prevents the two data processing devices from running at the same time retrieve and update a post of shared data. In short, that includes Latch circuit 50, which will be described in detail hereinafter, a lock register (L register) 51, which is based on data in the B register 31 and the C register 32 and on decoded signals from responds to the decoder 34 to set the L register 51 and store therein data, the one Represent code number assigned to a specific item of common data. The output signal of the L register 51 of the one device 51, together with the output signal of the L register 51 of the Another data processing device P 2 is supplied to a comparison circuit 52. The output of the comparison circuit 52 is connected to the program control unit 40 and a circuit 53 for resetting the Lock register connected, which resets the lock register 51 when activated accordingly. "'.'
F i g. 2 zeigt das Schema eines Sperrcodezahl-Befehlswortes 55. Wie ersichtlich, enthält es in den ersten fünf Bits einen Operationscode, wie er auch im Wort 45 (Fig. 2a) enthalten ist. Das Wort 55 enthält jedoch anstatt der R- und Y-Felder in den Bits 4 bis 8 und 12 bis 17 iV-Felder und in den Bits 9 bis 11 einen erhöhenden Code, der anstatt wie bei einem gewöhnlichen Befehlswort auf das Pufferregister 31 auf das Befehlsregister 32 übertragen wird. Die /V-Felder definieren die Codezahl eines bestimmten Postens gemeinsamer Daten. Immer wenn ein Posten gemeinsamer Daten, in Pl auf den neuesten Stand gebracht werden soll, wird ein Befehlswort, wie z.B. das Wort55, auf die B- und C-Register des datenverarbeitenden Gerätes Pl übertragen. Die Bits 0 bis 4 und 8 bis 11 werden in dem Decoder 34 decodiert, wobei sie anzeigen, daß das Befehlswort ein Sperrcodezahl-Wort ist. Infolgedessen setzt der Decoder 34 das Sperr-Register 51 in den Stand, dieF i g. 2 shows the scheme of a locking code number command word 55. As can be seen, it contains an operation code in the first five bits, as is also contained in word 45 (FIG. 2a). However, instead of the R and Y fields in bits 4 to 8 and 12 to 17, word 55 contains iV fields and bits 9 to 11 an incrementing code, which instead of a normal command word to buffer register 31 to the Command register 32 is transferred. The / V fields define the code number of a particular item of common data. Whenever an item of common data is to be brought up to date in PI, a command word, such as word55, is transferred to the B and C registers of the data processing device PI. Bits 0-4 and 8-11 are decoded in decoder 34 indicating that the command word is a lock code number word. As a result, the decoder 34 sets the lock register 51 in the state, the
ίο Bits 5 bis 8 des C-Registers 32 und die Bits 12 bis 17 des B-Registers 31 zu speichern, die die darin enthaltene Codezahl darstellen. ' ίο Bits 5 to 8 of the C register 32 and bits 12 to 17 of the B register 31, which represent the code number contained therein. '
Diese Codezahl wird dann mit jeder Codezahl verglichen, die in dem Register 51 des datenverarbeitenden Gerätes P 2 gespeichert sein mag. Wenn dieser Vergleich positiv ist, d.h., wenn das Sperr-Register 51 von P 2 den identischen Code enthält, der anzeigt, daß P 2 den angegebenen Posten gemeinsamer Daten verarbeitet, wird die Rückstellschaltung 53 von Pl erregt, um das Register 51 von Pl zurückzustellen. Weiterhin veranlaßt die Vergleichsschaltung die Einheit 40 das nächste Befehlswort des Programms aufzurufen. Das nächste Wort kann ein Rückübertragungsbefehl sein, der besagt, daß der Code des vorhergehenden, die Befehlscodezahl darstellenden Wortes nicht erreicht wurde, und der Ubertragungsbefehl kann dann die Steuerung verschieben und bewirken, daß der rückständige Befehl erneut von der Speichereinheit empfangen wird. Dieser Vorgang kann fortgesetzt werden, bis das Sperr-Register 51 von P 2 frei ist, so daß dann, wenn die Codezahl wieder in dem Sperr-Register von Pl gespeichert wird, sich ein negativer Vergleich ergibt. In diesem Fall wird die Rückstellschaltung 53 stillgesetzt, so daß die Codezahl in dem Sperr-Register 51 gespeichert bleibt. Außerdem veranlaßt das Ausgangssignal der Vergleichsschaltung 52 die Programmsteuereinheit 40 den Rückübertragungsbefehl zu überspringen und die Verarbeitung der gemeinsamen Daten in dem datenverarbeitenden Gerät P1 fortzusetzen, wie es hernach mehr im einzelnen an Hand eines- speziellen Beispieles beschrieben werden wird.This code number is then compared with each code number in the register 51 of the data processing Device P 2 may be stored. If this comparison is positive, i.e. if the lock register 51 of P 2 contains the identical code indicating that P 2 is the specified item of common data processed, the reset circuit 53 of PI is energized to reset the register 51 of PI. Furthermore, the comparison circuit causes the unit 40 to call up the next instruction word of the program. The next word can be a retransmission command, stating that the code of the previous, the word representing the command code number was not reached, and the transfer command can then move the control and cause the delayed command again from the Storage unit is received. This process can continue until the lock register 51 of P 2 is free, so that when the code number is stored again in the lock register of Pl will result in a negative comparison. In this case, the reset circuit 53 is stopped so that the code number remains stored in the lock register 51. In addition, the output signal causes the Comparison circuit 52, the program control unit 40 to skip the retransmission command and the Continue processing of the common data in the data processing device P1, as it did afterwards will be described in more detail using a special example.
Es versteht sich, daß der Befehl, der dem Sperrcodezahl-Befehl folgt, ein anderer sein kann als, ein Rückübertragungsbefehl. Zum Beispiel kann beim Vorliegen eines positiven Vergleichs, der anzeigt, daß das andere datenverarbeitende Gerät den speziellen Posten gemeinsamer Daten verarbeitet, der nächste Befehl dem datenverarbeitenden Gerät ein anderes programmiertes Unterprogramm zuführen, bis der spezielle Posten gemeinsamer Daten von dem anderen datenverarbeitenden Gerät auf den neuesten Stand gebracht und in die Speichereinheit zurückgeführt ist.It goes without saying that the command following the lock code number command follows, may be other than, a retransmission command. For example, at Presence of a positive comparison indicating that the other data processing device is the specific one Post common data processed, the next command the data processing device another feed programmed subroutine until the particular item has common data from the other data processing device is brought up to date and returned to the storage unit.
Zum Zwecke der Erläuterung sei angenommen, daß ein Posten gemeinsamer Daten D in der Speichereinheit an einer Adresse X gespeichert ist und daß den Daten D eine Codezahl CD zugeordnet ist. In jedem Unterprogramm, in dem Daten D an der Adresse X vorkommen und bei dem es erwünscht ist, daß die Daten D zu einer gegebenen Zeit nur durch eines der datenverarbeitenden Geräte verarbeitet werden, gehen dann nach den Lehren der Erfindung dem Befehl zur Übertragung der Daten D in das datenverarbeitende Gerät zwei Befehle voraus. In den Fig. 3 und 4 werden Unterprogramme für die datenverarbeitenden Geräte Pl bzw. P 2 veranschaulicht. Das Unterprogramm nach F i g. 3 für Pl besteht darin, eine Eins (1) zu den Daten D zuFor the purpose of explanation, it is assumed that an item of common data D is stored in the memory unit at an address X and that the data D is assigned a code number C D. In any subroutine in which data D occurs at address X and in which it is desired that the data D be processed by only one of the data processing devices at a given time, the instruction to transfer the data then goes according to the teachings of the invention D in the data processing device two commands ahead. 3 and 4, subroutines for the data processing devices P1 and P 2 are illustrated. The subroutine according to FIG. 3 for PI is to add a one (1) to data D.
addieren, während das Unterprogramm nach F i g. 4 darin besteht, eine Zwei (2) von den Daten X abzuziehen. add, while the subroutine according to FIG. 4 is to subtract a two (2) from the X data.
In jeder der Fig. 3 und 4 stellt die erste Spalte die Befehlszahl oder die Adresse in der Speichereinheit dar, an der ein Befehlswort, das den in Spalte 2 gezeigten Aufbau hat, vorhanden ist. Die dritte Spalte stellt den Wert der Felder in jedem Befehlswort dar, während die vierte Spalte Angaben über die Art des Befehles enthält. Außer dem ersten und dem letzten haben die Befehlsworte in jedem der Unterprogramme einen Aufbau wie das Befehlswort 45 nach Fig. 2a, der in der Technik üblich ist. Es sind nämlich.die ersten fünf Bits einem Operationscode gewidmet, während die anderen 13 Bits auf die beiden Felder R und Y aufgeteilt sind. Die ersten und letzten Befehle in jedem der Unterprogramme beziehen sich auf das Sperren und Freigeben der Codezahl in dem Sperr-Register. Deshalb hat jedes der Sperrbefehlswörter ein Format wie das Befehlswort 55 nach Fi g. 2 b. Die Bits 0 bis 4 und 9 bis 11 sind dem Operationscode bzw. dem erhöhenden Code gewidmet, während die Bits 5 bis 8 und 12 bis 15 dem N-FeId gewidmet sind, das eine Codezahl des besonderen Datenpostens darstellt.In each of FIGS. 3 and 4, the first column represents the instruction number or the address in the memory unit at which an instruction word having the structure shown in column 2 is present. The third column shows the value of the fields in each command word, while the fourth column contains information about the type of command. Except for the first and the last, the instruction words in each of the subroutines have a structure like the instruction word 45 of FIG. 2a, which is common in the art. The first five bits are dedicated to an operation code, while the other 13 bits are divided between the two fields R and Y. The first and last instructions in each of the subroutines relate to locking and unlocking the code number in the lock register. Therefore, each of the lock command words has a format like the command word 55 of FIG. 2 B. Bits 0 to 4 and 9 to 11 are dedicated to the operation code and the incrementing code, respectively, while bits 5 to 8 and 12 to 15 are dedicated to the N field , which represents a code number of the particular data item.
Es sei angenommen, daß zu einem gewissen Zeitpunkt während seiner Operation das datenverarbeitende GerätPl das in Fig. 3 gezeigte Unterprogramm auszuführen hat, das beinhaltet, daß den an der Adresse X in der Speichereinheit 20 nach F i g. 1 gespeicherten Daten eine »1« hinzuaddiert werden soll. Um das Unterprogramm auszuführen, wird das datenverarbeitende Gerät Pl zuerst veranlaßt, von der Speichereinheit das Befehswort mit der Adresse W anzufordern. Wie aus Fig. 3 ersichtlich, stellt das Wort den Befehl dar, die Codezahl C0, die den Daten an der Adresse X zugeordnet ist, in einem Sperr-Register von Pl zu sperren. Das Feld N des Befehlswortes an der Adresse W ist nämlich gleich C0. Wenn dieses gesperrte Befehlswort im Pufferregister und. im Befehlsregister von Pl empfangen wird, werden die Bits 0 bis 4 und 9 bis 11 in dem Decoder 34 decodiert, um dem Sperr-Register 51 ein Signal zu liefern, das das Register 51 befähigt, das in den B- und C-Registern gespeicherte N-FeId aufzunehmen und zu speichern. Dann wird das Ausgangssignal des Sperr-Registers 51 von der Vergleichsschaltung 52 mit dem Ausgangssignal des Sperr-Registers 51 des anderen datenverarbeitenden Gerätes P2 verglichen. It is assumed that at some point during its operation, the data processing GerätPl has run subroutine shown in Fig. 3, which implies that the g at the address X in the memory unit 20 according to F i. 1 stored data a "1" should be added. In order to execute the subroutine, the data processing device P1 is first caused to request the command word with the address W from the memory unit. As can be seen from FIG. 3, the word represents the command to lock the code number C 0 , which is assigned to the data at address X , in a lock register of P1. This is because the field N of the command word at the address W is equal to C 0 . If this locked command word in the buffer register and. is received in the PI command register, bits 0-4 and 9-11 are decoded in decoder 34 to provide a signal to lock register 51 which enables register 51 stored in the B and C registers Record and save N-field. Then the output signal of the lock register 51 is compared by the comparison circuit 52 with the output signal of the lock register 51 of the other data processing device P2.
Wenn sich ein positiver Vergleich ergibt, d. h., wenn das Sperr-Register 51 von P 2 die Codenummer C0 enthält und dadurch anzeigt, daß das datenverarbeitende Gerät P 2 auf die an der Adresse X gespeicherten Daten einwirkt, wird ein Signal der Rückstellschaltung 53 zugeführt, um eine Rückstellung des Sperr-Registers 51 in Pl zu bewirken. Damit erhöht das datenverarbeitende Gerät Pl während seiner normalen Arbeitsweise den Inhalt des Programmzählers 33, so daß das nächste bei einer Adresse W+.'l gespeicherte Befehlswort angefordert wird. Wenn das zuletzt erwähnte Befehlswort empfangen wird und in den B- und C-Registern des Gerätes Pl gespeichert wird, wird der Code 00 des Befehlswortes, der in den ersten fünf Bits des Wortes vorhanden ist, decodiert, um einen Befehl zur Rückübcrtragung auf die vorhergehende Adresse W zu liefern. Der Befehl, die Codezahl C0 in dem Sperr-Register 51 von P1 zu sperren, wird nämlich wiederholt. If a positive comparison results, ie if the lock register 51 of P 2 contains the code number C 0 and thereby indicates that the data processing device P 2 is acting on the data stored at address X , a signal is fed to the reset circuit 53 to cause a reset of the lock register 51 in PI. The data-processing device P1 thus increases the content of the program counter 33 during its normal operation, so that the next command word stored at an address W +. '1 is requested. When the last-mentioned command word is received and stored in the B and C registers of the device P1, the code 00 of the command word, which is present in the first five bits of the word, is decoded in order to send a command back to the previous one Deliver to address W. Namely, the instruction to lock the code number C 0 in the lock register 51 of P1 is repeated.
Diese Operationen werden wiederholt, bis das Sperr-Register 51 des datenverarbeitenden Gerätes P 2 nicht gesperrt sein wird, so daß dann, wenn die Codezahl C0 in dem Sperr-Register 51 von P1 gespeichert ist und von der Vergleichsschaltung 52 ein Vergleich vorgenommen wird, ein negatives Ergebnis erzielt wird. Wenn dies der Fall ist,, wird die Rück-Stellschaltung 53 stillgesetzt, d. h., sie wird das Sperr-Register nicht zurückstellen. Daher wird die Codezahl C0 in dem Register 51 von Pl gespeichert und eingeschrieben bleiben. Der negative Vergleich wird auch die Programmsteuereinheit 40 dazu veranlassen, das Befehlswort in der Adresse W + 1 zu überspringen. Das heißt, daß der Wert in dem Programmzähler 33 um »2« vermehrt wird, wenn ein negativer Vergleich zustande kommt, so daß nach dem Empfang des Befehlswortes von der Adresse W als näch- stes das Befehlswort von der Adresse W + 2 angefordert und der Ubertragungsbefehl, der an der Adresse W + 1 vorhanden ist, übersprungen wird.These operations are repeated until the lock register 51 of the data processing device P 2 is not locked, so that when the code number C 0 is stored in the lock register 51 of P1 and a comparison is made by the comparison circuit 52, a negative result is obtained. If so, the reset circuit 53 is shut down, that is, it will not reset the lock register. Therefore, the code number C 0 will be stored and retained in the register 51 of P1. The negative comparison will also cause the program control unit 40 to skip the command word in the address W + 1. This means that the value in the program counter 33 is increased by "2" if a negative comparison is made, so that after the command word has been received from the address W, the command word from the address W + 2 is next requested and the Transfer command that is present at address W + 1 is skipped.
Danach arbeitet das Datenverarbeitungsgerät P1 in konventioneller Weise, indem es den Befehl empfängt, der an der Adresse W + 2 vorhanden ist, der einen Füllbefehl zum Übertragen der Daten von Adresse X darstellt. Nachdem diese Daten auf Pl übertragen und vorübergehend in einer beliebigen konventionellen Schaltung, wie z. B. in einem Akkumulator oder anderen (nicht gezeigten) Registern gespeichert worden -sind, wird ein Befehl gegeben, um das datenverarbeitende Gerät mit einem Befehls-. wort zu versorgen, das sich an der Adresse W + 3 befindet. Wie aus F i g. 3 ersichtlich, hat dieses Befehlswort einen Operationscode, der durch Zahl 22 dargestellt wird, die anzeigen mag, daß zu den zuvor auf Pl übertragenen Daten eine »1« addiert werden soll, also zu den Daten, die auf Pl von der Adresse X übertragen worden sind. Nach dem nächsten Befehl soll das Befehlswort von der Adresse W + 4 angefordert werden, das einen Code 26 hat, der bedeutet, daß die in Pl gebildeten Daten im Speicher an einer Adresse gespeichert werden sollen, die durch die Summe der Felder R und Y des Befehlswortes definiert ist und, wie aus Spalte 3 ersichtlich, gleich X ist. Daher wird der gebildete Wert D + 1 auf die Adresse X übertragen. Nach diesem Befehl ist das konventionelle Unterprogramm beendet, weil die zuvor an der Adresse X gespeicherten Daten D durch Addieren einer »1« auf den neuesten Stand gebracht und der Wert D + 1 an der Adresse X wieder gespeichert worden ist.Thereafter, the data processing device P1 operates in a conventional manner by receiving the command present at address W + 2 which is a fill command for transferring the data from address X. After this data has been transferred to PI and temporarily used in any conventional circuit, such as e.g. B. have been stored in an accumulator or other (not shown) registers, a command is given to the data processing device with a command. to supply a word that is located at address W + 3. As shown in FIG. 3, this command word has an operation code, which is represented by number 22, which may indicate that a "1" is to be added to the data previously transferred to PI, i.e. to the data transferred to PI from address X. are. After the next command, the command word is to be requested from the address W + 4, which has a code 26, which means that the data formed in Pl are to be stored in the memory at an address which is determined by the sum of the fields R and Y des Command word is defined and, as can be seen from column 3, is equal to X. The formed value D + 1 is therefore transferred to the address X. After this command, the conventional subroutine is ended because the data D previously stored at address X has been updated by adding a "1" and the value D + 1 at address X has been stored again.
In Übereinstimmung mit den Lehren der vorliegenden Erfindung ist jedoch die Codezahl C0 noch im Sperr-Register 51 gespeichert. Daher ist ein zusätzlicher Befehl in dem Unterprogramm enthalten, um das Sperr-Register von Pl freizugeben. Dies wird dadurch erreicht, daß ein weiteres Befehlswort vorgesehen ist, das an einer Adresse W + 5 gespeichert ist. Dieses Befehlswort kann in den Bits 0 bis 4 eine Codezahl 14 aufweisen, die anzeigt, daß es sich entweder um einen Sperrbefehl oder um einen Freigabebefehl handelt. Jedoch ist der erhöhende Code in den Bits 9 bis 11 eine »0«, so daß dann, wenn er in dem Decoder 34 decodiert wird, angezeigt wird, daß es sich um einen Freigabebefehl handelt. Auch sind die Felder der Bits 5 bis 8 und 12 bis 17 gleich »0«, wodurch ebenfalls angezeigt wird, daß das IK'- However, code number C 0 is still stored in lock register 51 in accordance with the teachings of the present invention. Therefore, an additional instruction is included in the subroutine to enable PI's lock register. This is achieved in that a further command word is provided which is stored at an address W + 5. This command word can have a code number 14 in bits 0 to 4, which indicates that it is either a blocking command or a release command. However, the incrementing code in bits 9 to 11 is a "0" so that when it is decoded in the decoder 34 it is indicated that it is an enable command. The fields of bits 5 to 8 and 12 to 17 are also "0", which also indicates that the IK'-
209 643Ί11209 643-11
9 109 10
fehlswort ein Freigabebefehl ist. Als Ergebnis liefert Gerät Pl die Zahl »2« abzuziehen hat, D -f- 1, undThe wrong word is a release command. As a result, device Pl returns the number "2" must be subtracted, D -f- 1, and
der Decoder der Rückstellschaltung 53 ein Signal, es führt die Verarbeitung dieses Wertes in dem daten-the decoder of the reset circuit 53 sends a signal, it carries out the processing of this value in the data
damit das Sperr-Register 51 von Pl zurückgestellt verarbeitenden Gerät P 2 zu dem Wert D — 1, denso that the lock register 51 of PI reset processing device P 2 to the value D - 1, the
oder freigegeben wird. das datenverarbeitende Gerät P 2 wieder an deror is released. the data processing device P 2 back to the
Danach ist das datenverarbeitende Gerät Pl in 5 Adresse X speichert, nachdem es den durch das an
der Lage, ein beliebiges anderes programmierte's der Adresse Z + 4 gespeicherte Befehlswort beUnterprogramm
auszuführen. Wenn das auszu- stimmten Befehl ausgeführt hat.
führende, nachfolgende Unterprogramm auch einen Aus dem Vorhergehenden ist ersichtlich, daß,
Posten gemeinsamer Daten umfaßt, wird ein ahn- obwohl beide datenverarbeitenden Geräte unabhängig
licher Arbeitsvorgang wiederholt. Das heißt, daß zu- io voneinander mit der Speichereinheit 20 verbunden
erst ein Sperrbefehl zum Sperren der Codezahl, die sind und beide Zugriff zum Speicher haben, um von
einem Posten gemeinsamer Daten zugeordnet ist, ihm Daten zu empfangen und sie zu verarbeiten, die
empfangen wird, um festzustellen, ob ein beliebiges verarbeitenden Geräte do,ch mit Mitteln verknüpft
anderes der datenverarbeitenden Geräte diesen Posten sind, die sicherstellen, daß zu irgendeiner beliebigen
gemeinsamer Daten verarbeitet. Wenn andere daten- 15 gegebenen Zeit nur ein datenverarbeitendes Gerät
verarbeitende Geräte solche Daten verarbeiten, wird einen Posten gemeinsamer Daten auf den neuesten
der Übertragungsbefehl empfangen, der bewirkt, daß Stand bringen kann. Und erst wenn dieses eine datendas
datenverarbeitende Gerät Pl so langö den verarbeitende Gerät seine Operationen beendet und
Sperrcodezahl-Befehl rücküberträgt, bis das andere die Daten an ihre Adresse oder ihren Platz in dem
datenverarbeitende Gerät seine Operationen an dem 20 Speicher zurückübertragen hat, kann ein anderes
Posten gemeinsamer Daten beendet hat. datenverarbeitendes Gerät den auf den neuestenThereafter, the data processing device P1 is stored in 5 address X after it has executed the subroutine stored by the subroutine which is capable of any other programmed address Z + 4. When the command to be determined has been carried out.
leading, subsequent subroutine also includes a. From the foregoing it can be seen that, if items include common data, an operating process is repeated, although both data processing devices are independent. That is, first connected to one another with the memory unit 20 a lock command for locking the code number which are and both have access to the memory in order to receive data from an item of common data, and to process them which are received is to determine whether any processing device do, ch associated with means other of the data processing devices are these items, which ensure that any common data is processed. If other data processing devices are only processing such data at a given time, a common data item will be received up to date of the transmission command, which causes status to be received. And only when this one data processing device Pl so long the processing device ends its operations and returns the lock code number command until the other has returned the data to its address or its place in the data processing device its operations on the 20 memory, another can Has finished posting shared data. data processing device that is up to date
Wie aus Fig. 4 ersichtlich, sind die Befehlswörter Stand gebrachten Posten gemeinsamer Daten empin den beiden Unterprogrammen sehr ähnlich, ab- fangen, um ihn weiteren Operationen zu unterwerfen, gesehen von dem vierten Befehlswort, das in Fig. 3 1So werden akkumulative Fehler, die durch das gleicheinen Befehl zur Addition einer Zahl zu den auf das 25 zeitige Verarbeiten eines Postens gemeinsamer Daten datenverarbeitende Gerät übertragenen Daten dar- durch mehr als ein datenverarbeitendes Gerät bedingt stellt, während in Fig. 4 der Befehl darin besteht, sein können, vermieden.As seen from Fig. 4, the command words stand accommodated items common data empin the two sub-programs are very similar off, catching, to subject it further operations, as seen from the fourth instruction word shown in FIG. 3 1 Thus accumulative errors, the data transmitted by more than one data processing device, while in FIG. 4 the command consists in this, can be avoided.
eine Zahl von den Daten in dem datenverarbeitenden F i g. 5 zeigt das Blockschaltbild eines speziellen, Gerät zu subtrahieren. Nach dem vorhergehenden praktisch verwirklichten Ausführungsbeispieles zur versteht es sich, daß dann, wenn das datenverarbei- 30 Verriegelung einer Codezahl in dem Sperr-Register tende Gerät P 2 versucht, das in- F i g. 4 veranschau- 51 nach den oben behandelten Lehren der vorliegenlichte Unterprogramm auszuführen, während das den Erfindung. Wie aus F i g. 5 ersichtlich, umfaßt datenverarbeitende Gerät P1 das in Fig. 3 veran- das Datenregister 23 der Speichereinheit 20 ein schaulichte Unterprogramm ausführt und von dem 18-Bit-Register, dessen erste neun Bits 0 bis 8 mit datenverarbeitenden Gerät P 2 das Befehlswort von 35 den ersten neun Bits 0 bis 8 des Befehlsregisters der Adresse Z empfangen und die Codezahl CD in verbunden sind, das nach F i g. 5 12 Bits umfaßt, dessen Sperr-Register 51 eingegeben wird, der Ver- Weiterhin sind die Bits 12 bis 17 des Datenregisters gleich in dessen Vergleichsschaltung positiv ausfallen 23 mit den Bits 12 bis 17 des Pufferregisters 31 ver- und deshalb das datenverarbeitende Gerät P2 den bunden, das nach Fig. 5 18 Bit umfaßt, von denen Befehl erhalten wird, das nächste Befehlswort zu emp- 40 jedoch nur die Bits 9 bis 17 wirklich verwendet fangen, das an der Adresse Z + 1 vorhanden ist und werden. Die Bits 9, 10 und 11 des Datenregisters 23 das das datenverarbeitende Gerät P2 dazu veranlaßt, sind sowohl mit den Bits 9, 10 und 11 des Befehlszu dem Befehlswort zurückzukehren, das an der registers als auch mit den Bits 9, 10 und 11 des Adresse Z vorhanden ist und in dem der Befehl Pufferregisters 31 verbunden. Eine solche Anordnung enthalten ist, die Codezahlen C0, die dem an einer 45 ist nötig, weil die Bits 9, 10 und 11 des Daten-Adresse X gespeicherten Posten gemeinsamer Daten registers 23 manchmal dem B-Register zugeführt zugeordnet ist, zu sperren. werden, wenn die darin enthaltenen Daten ein Teila number from the data in the data processing FIG. Figure 5 shows the block diagram of a special subtracting device. According to the foregoing, practically implemented exemplary embodiment, it goes without saying that when the data processing device P 2 tries to lock a code number in the lock register, the in-FIG. 4 illustrates 51 executing the present subroutine in accordance with the teachings discussed above while practicing the invention. As shown in FIG. 5, the data processing device P1 comprises the data register 23 of the memory unit 20, which is shown in FIG first nine bits 0 to 8 of the command register of the address Z received and the code number C D in are connected, according to F i g. 5 comprises 12 bits, the lock register 51 of which is entered, the further bits 12 to 17 of the data register are the same in its comparison circuit are positive 23 with bits 12 to 17 of the buffer register 31 and therefore the data processing device P2 den which, according to FIG. 5, comprises 18 bits, of which the command is received to receive the next command word, but only bits 9 to 17 actually used, which are and are present at address Z + 1. Bits 9, 10 and 11 of data register 23 which cause data processing device P2 to return with bits 9, 10 and 11 of the command to the command word at the register as well as with bits 9, 10 and 11 of the address Z is present and in which the command buffer register 31 is connected. Such an arrangement is included, the code numbers C 0 , which is necessary to lock the code numbers C 0, because bits 9, 10 and 11 of the data address X stored items of common data register 23 are sometimes assigned to the B register. when the data it contains is a part
Wenn das an der Adresse Z vorhandene Befehls- des R-Feldes sind, wie es zuvor in Verbindung mit wort von dem datenverarbeitenden Gerät P2 emp- Fig. 2a erläutert wurde, während in anderen Fällen fangen wird, nachdem das datenverarbeitende Gerät 5° die Bits 9 bis 11 des Datenregisters 23 den Er-Pl die Daten auf den neuesten Stand gebracht und höhungscode enthalten, wie es in Verbindung mit den Befehl zur Freigabe seines Sperr-Registers erteilt Fig. 2b beschrieben wurde. Deshalb müssen die hat, fällt der Vergleich negativ aus. Infolgedessen Bits 9, 10 und 11 des Datenregisters 23 mit den entwird das an der Adresse Z + 1 vorhandene Befehls- sprechenden Bits in beiden Registern 31 und 32 verwort übersprungen, und das datenverarbeitende Ge- 55 bunden sein. Die Ausgänge der Bits 0 bis 4, 9, 10 rätP2 ist dann frei, die an den Adressen Z + 2 bis und 11 des C-Registers 32 sind mit dem Decoder 34 Z + 5 gespeicherte Befehlsserie zu empfangen und verbunden.If the command at address Z is the R field, as previously explained in connection with the word from the data processing device P2, while in other cases the bits are caught after the data processing device 5 ° 9 to 11 of the data register 23 the Er-Pl brought the data up to date and contain elevation code, as it was described in connection with the command to release its lock register issued Fig. 2b. Therefore, the comparison is negative. As a result, bits 9, 10 and 11 of data register 23 with the command-speaking bits present at address Z + 1 will be skipped in both registers 31 and 32, and the data-processing link will be bound. The outputs of bits 0 to 4, 9, 10 guessP2 are then free, the command series stored at addresses Z + 2 to and 11 of the C register 32 can be received and connected to the decoder 34 Z + 5.
dabei das Unterprogramm auszuführen, das darin Es sei angenommen, daß ein von den Registern besteht, den Wert 2 von den Daten abzuziehen, die 31 und 32 von dem Datenregister 23 empfangenes ihm zuvor von der Adresse X übertragen worden 60 Befehlswort ein Sperrcodezahl-Befehlswort ist, wie es sind. Jedoch sollte darauf hingewiesen werden, daß beispielsweise in der ersten Zeile von F i g. 3 dargedie Daten, die das daten verarbeitende Gerät P 2 stellt ist. Es ist ersichtlich, daß ein solches Wort in empfängt, nicht den Wert D haben, sondern vielmehr den Bits 0 bis 4 eine Codezahl 14 und in den Bits 9, den Wert D I 1, der auf die Adresse X von dem 10 und 11 eine Codezahl 4 enthält. Wenn die Ausdatenverarbeitenden Gerät Pl übertragen wurde, als 65 gangssignale der Bits 0 bis 4 und 9, 10 und 11 des es den Befehl ausführte, der durch das an der Befehlsregisters dem Decoder 34 zugeführt werden, Adresse W + 4 vorliegende'Wort dargestellt wird. liefert.es auf seiner Ausgangsleitung 61 ein Sperr-So ist der Wert, von dem das datenverarbeitende signal MYC29. Wie zuvor an Hand der Fig. 2b,while executing the subroutine which consists in assuming that one of the registers is to subtract the value 2 from the data 31 and 32 previously received by the data register 23 from the address X. 60 command word is a lock code number command word as it are. However, it should be noted that, for example, in the first line of FIG. 3 shows the data that the data processing device P 2 represents. It can be seen that such a word received in does not have the value D , but rather bits 0 to 4 have a code number 14 and bits 9, the value DI 1, which is assigned to the address X of the 10 and 11 a code number 4 contains. When the data processing device P1 was transmitted, it executed the command as 65 output signals of bits 0 to 4 and 9, 10 and 11, which is represented by the address W + 4 present in the command register to the decoder 34. Deliver.es on its output line 61 a blocking So is the value of which the data processing signal MYC 29. As before with reference to Fig. 2b,
11 1211 12
3 und 4 erläutert wurde, wird die Codezahl des men der Ausgang des Flipflops 38, auf einem ersten3 and 4, the code number of the men is the output of the flip-flop 38, on a first
Postens gemeinsamer Daten durch die N-Felder in Pegel sein werden, der eine binäre »Null« darstellt,Post of common data through which N-fields will be in level representing a binary "zero",
dem Sperrcodezahl-Befehlswort dargestellt, die sich während das Ausgangssignal des Flipflops 88, dasthe lock code number command word, which occurs during the output of the flip-flop 88, the
in den Bits 5 bis 8 des Befehlsregisters und den Bits der Nummer 4 entsprich!, auf einem zweiten Pegelin bits 5 to 8 of the command register and the bits of the number 4 correspond to! on a second level
12 bis 17 des Pufferregisters befinden. 5 sein wird, der eine binäre »Eins« darstellt. In12 to 17 of the buffer register. 5, which represents a binary "one". In
Wie aus Fig. 5 ersichtlich, enthält das Sperr- Fig. 5 sind die Ausgänge der Flipflops 81 bis 90As can be seen from Fig. 5, the lock contains Fig. 5 are the outputs of the flip-flops 81 to 90
Register 51 zehn NAND-Gatter 71 bis 80, von denen als L01,4 bis LlOA bezeichnet. Die Zahl bezeichnetRegister 51 ten NAND gates 71 through 80, one of which is designated as L01.4 through L10A . The number denotes
der Einfachheit halber nur die ersten und. die letzten das Flipflop, während der Buchstabe A angibt, daßfor the sake of simplicity only the first and. the last the flip-flop, while the letter A indicates that
beiden dargestellt sind. Das Register enthält außer- das Signal von dem Sperr-Register 51 des Gerätes P1both are shown. The register also contains the signal from the lock register 51 of the device P1
dem 10 Flipflops 81 bis 90, von denen auch nur die io stammt.the 10 flip-flops 81 to 90, from which only the io comes.
ersten und die letzten beiden in Fig. 5 dargestellt" Die Ausgangssignale L01A bis LWA der Flipsind. Alle NAND-Gatter arbeiten als UND-Gatter, flops 81 bis 90 werden der Vergleichsschaltung 52 weil nur dann, wenn alle ihreEingangssignal »wahr« zugeführt, die in Fig. 6 dargestellt ist. Wie aus sind, das Gatter ein Ausgangssignal »falsch« liefert, Fig. 6 ersichtlich, wird jeder der Ausgänge LOlA während jedes der Flipflops eingestellt und gelöscht 15 bis LlOA einem anderen von Gattern 101 bis 110 wird als Funktion des Signals, das einer Eingangs- zugeführt. Jedes dieser Gatter führt das Komplement klemme / zugeführt wird, wenn das Signal, das einer einer exklusiven ODER-Funktion durch; eine spe-Steuerklemme C zugeführt wird, wahr ist. Spezielle zielle Ausführungsform eines solchen Gatters wird Ausführungsformen eines als UND-Gatter arbeiten- . hernach im einzelnen beschrieben. Ein anderes Einden NAND-Gatters und eines wie zuvor beschrieben 20 gangssignal wird von Gattern 101 bis 110 von je arbeitenden Flipflops werden hernach.im einzelnen einem anderen Flipflop des Sperr-Registers 51 des behandelt. · anderen datenverarbeitenden Gerätes P 2 zugeführt,The first and the last two shown in Fig. 5 "The output signals L 01 A to LWA of the flips are. All NAND gates operate as AND gates, flops 81 to 90 are fed to the comparison circuit 52 because only if all of their input signals are" true " which is shown in Fig. 6. As can be seen from Fig. 6, the gate provides a "false" output signal, each of the outputs LOIA is set and cleared during each of the flip-flops until L10A becomes another one of gates 101-110 . Specific a spe control terminal C is supplied, is true essential embodiment of a; as a function of the signal fed to an input each of these gates performs the complement clamp / is supplied when the signal of an exclusive-OR function by. of such a gate, embodiments of one operating as an AND gate will be described in detail hereinafter, another one of the NAND gate and one as previously described is output from gates 101 to 110 of FIG each operating flip-flops are subsequently treated in detail with a different flip-flop of the lock register 51 of the. Supplied to other data processing device P 2,
Wie aus F i g. 5 ersichtlich, sind die Steuerklemmen wobei der letzte Buchstabe B anzeigt, daß die SignaleAs shown in FIG. 5 shows the control terminals, the last letter B indicating that the signals
der Flipflops 81 bis 90 mit den Ausgängen eines von dem Sperr-Register 51 von P 2 stammen. Demof the flip-flops 81 to 90 with the outputs of one originate from the lock register 51 of P 2. To the
NAND-Gatters 53 verbunden, das die zuvor an Hand 25 Gatter 101 wird demnach das Ausgangssignal LOlA NAND gate 53 connected, the previously on hand 25 gate 101 is accordingly the output signal LOlA
Fig. 1 beschriebene Rückstellschaltung bildet. Das des Flipflops 81 des Sperr-Registers 51 von Pl undFig. 1 forms the reset circuit described. That of the flip-flop 81 of the lock register 51 of P1 and
Gatter 53 führt eine ODER-Funktion aus, indem es weiterhin das Ausgangssignal L 01B eines gleichenGate 53 performs an OR function in that it continues to output signal L 01 B of the same
ein Ausgangssignal »wahr« immer dann liefert, wenn Flipflops in dem Sperr-Register 51 von P2 zuge-an output signal "true" always supplies when flip-flops in the lock register 51 of P2 are
ein beliebiges seiner Eingangssignale »falsch« ist. führt.any of its input signals is "false". leads.
Eine der Eingangsklemmen des NAND-Gatters 53 30 In gleicher Weise wird jedes der anderen Gatter ist mit dem Decoder 34 verbunden und erhält über der Vergleichsschaltung 52 mit den Ausgangssignalen die Leitung 62 ein »falsch«-Signal OMYC 29 immer je eines anderen der Flipflops der Sperr-Register 51 dann, wenn der Decoder 34 auf der Ausgangsleitung der Geräte Pl und P2 versorgt. Die Funktion eines 61 das Sperrcodezahl-Signal MYC 29 liefert. Im jeden der Gatter 101 bis 110 besteht darin, ein folgenden bezeichnet der Buchstabe O, der einer be- 35 »wahr«-Ausgangssignal nur dann zu liefern, wenn liebigen Signalbezeichnung vorhergeht, einen »falsch«- die beiden ihnen zugeführten Signale entweder beide Pegel. So stellt das Signal MYC 29 ein »wahr«- binäre Nullen oder binäre Einsen sind. Die AusSignal dar, während OMYC 29 ein »falsch«-Signal gangssignale der Gatter 101 bis 110 bilden die darstellt. Das Sperrcodezahl-Signal MYC 29 wird je Eingangssignale eines NAND-Gatters 112, das als einem Eingang aller NAND-Gatter 71 bis 80 züge- 4° UND-Gatter wirkt, so daß nur dann, wenn alle führt, während der andere Eingang jedes der Gatter Ausgangssignale der Gatter 101 bis 110 und damit mit dem Ausgang eines anderen Bits entweder des . alle Eingangssignale des NAND-Gatters 112 »wahr« Befehlsregisters 32 oder des Pufferregisters 31 ver- sind und dadurch anzeigen, daß die Zahlen, die bunden ist. in den beiden Sperr-Registern 51 der beiden daten-One of the input terminals of the NAND gate 53. 30 In the same way, each of the other gates is connected to the decoder 34 and receives a "false" signal OMYC 29 via the comparison circuit 52 with the output signals, always from a different one of the flip-flops Lock register 51 when the decoder 34 supplies the devices P1 and P2 on the output line. The function of a 61 supplies the lock code number signal MYC 29. In each of the gates 101 to 110 there is a following one denotes the letter O, which one can only deliver "true" output signal when preceded by any signal designation, a "false" one - the two signals fed to them either at both levels . The signal MYC 29 thus represents a "true" - binary zeros or binary ones are. The AusSignal represents, while OMYC 29 represents a "false" signal output signals of the gates 101 to 110 represent. The lock code number signal MYC 29 is per input signals of a NAND gate 112, which acts as an input of all NAND gates 71 to 80 and 4 ° AND gate, so that only if all leads, while the other input of each of the Gate Output signals of gates 101 to 110 and thus with the output of another bit of either the. all input signals of the NAND gate 112 "true" command register 32 or the buffer register 31 are gone, thereby indicating that the numbers that are bound. in the two lock registers 51 of the two data
Wie aus F i g. 5 ersichtlich, sind die Gatter 71 und 45 verarbeitenden Geräte gespeichert \sind, identisch 72 mit den Bits 5 bzw. 6 des Befehlsregisters 32 ver- sind, ein Ausgangssignal »falsch« ist. Der Ausgang bunden, während die Gatter 79 und 80 mit den Bits des NAND-Gatters 112 ist mit dem Eingang eines 16 und 17 des Pufferregisters 31 verbunden sind. NAND-Gatters 114 verbunden, das als Negator wirkt Entsprechend sind die Bits 7 und 8 des Befehls- und ein »wahr«-Ausgangssignal liefert, wenn Zahlen registers und die Bits 12 bis 15 des Pufferregisters 50 in den beiden Registern identisch sind, mit den NAND-Gattern 73 bis 79 verbunden. Wenn Das Ausgangssignal des Gatters 114 wird als die Ausgangssignale der Bits 0 bis 4 und 9,10 und 11 Eingangssignal für ein NAND-Gatter 116 verwendet, des Befehlsregisters 32 decodiert werden und darin das als UND-Gatter wirkt. Das andere Eingangsdie Codes 14 und 4 festgestellt werden, liefert der signal des NAND-Gatters 116 wird vom Decoder 34 Decoder 34 ejn Sperrcodezahl-Signal MYC 29 und 55 zugeführt und bildet ein Vergleichs-Bereitschaftsdessen Komplement OMYC ■. 29 zu den Gattern 71 Signal CEl, das der Decoder 34 gleichzeitig mit dem bis 80 bzw. zu dem Gatter 53. Infolgedessen wird der Sperrcode-Signal MYC 29 liefert. Wenn also zwei Gehalt der Bits 5 bis 8 des Befehlsregisters 32 und Zahlen in zwei Registern, identisch sind, so sind der Bits 12 bis 17 des Pufferregisters 31 über die beide Eingangssignale des NAND-Gatters 116 NAND-Gatter 71 bis 80 in den Flipflops 81 bis 90 6° »wahr«, und es ist infolgedessen sein Ausgangsgespeichert. ■ signal OLKR »falsch«. Wenn jedoch während derAs shown in FIG. 5, the gates 71 and 45 processing devices are stored, 72 are identical to bits 5 and 6, respectively, of the command register 32, an output signal is "false". The output is tied, while the gates 79 and 80 with the bits of the NAND gate 112 are connected to the input of a 16 and 17 of the buffer register 31. NAND gate 114 connected, which acts as an inverter. Correspondingly, bits 7 and 8 of the command and a "true" output signal are provided when number registers and bits 12 to 15 of buffer register 50 in the two registers are identical with the NAND gates 73 to 79 connected. When the output of gate 114 is used as the output of bits 0 through 4 and 9, 10 and 11 input to a NAND gate 116, instruction register 32 is decoded and therein acts as an AND gate. The other input, the codes 14 and 4 are determined, supplies the signal of the NAND gate 116 is supplied by the decoder 34 to decoder 34 a lock code number signal MYC 29 and 55 and forms a comparison readiness of its complement OMYC ■. 29 to the gates 71 signal CEl, which the decoder 34 delivers simultaneously with the to 80 or to the gate 53. As a result, the lock code signal MYC 29 is delivered. If two contents of bits 5 to 8 of command register 32 and numbers in two registers are identical, bits 12 to 17 of buffer register 31 are NAND gates 71 to 80 in flip-flops 81 via the two input signals of NAND gate 116 up to 90 6 ° "true", and as a result its initial value is stored. ■ OLKR signal »wrong«. However, if during the
Es sei z. B. angenommen, daß die Codezahl einen Sperrcodezahl-Periode, d. h. zu der Zeit, in der dasLet it be Assume, for example, that the code number has a lock code number period, i. H. at the time that
Wert 4 hat und das Ausgangssignal des Flipflops 81 Signal CEl dem NAND-Gatter116 zugeführt wird,Has the value 4 and the output signal of the flip-flop 81 signal CEl is fed to the NAND gate 116,
das höchststellige Bit und das' Ausgangssignal des die beiden Zahlen in den Sperr-Registern 51 derthe most significant bit and the output of the two numbers in the lock registers 51 of the
Flipflops 90 das letztstellige Bit darstellt. Es versteht 65 datenverarbeitenden Geräte Pl und P2 nicht iden-Flip-flops 90 represents the last digit. It understands 65 data processing devices Pl and P2 not identical
sich dann für den Fachmann, daß nach dem Ein- tisch sind, ist eines der Eingangssignale des NAND-then it is clear to the expert that after the table is one of the input signals of the NAND-
schreiben der Codezahl 4 in das Sperr-Register 51, Gatters 112 »falsch« und deshalb das Ausgangssignalwrite the code number 4 in the lock register 51, gate 112 "wrong" and therefore the output signal
die Ausgänge aller Flipflops 81 bis 90, ausgenom- des NAND-Gatters 112 »wahr«. Infolgedessen istthe outputs of all flip-flops 81 to 90, with the exception of NAND gate 112, are "true". As a result is
13 14 13 14
das Ausgangssignal des Negators 114 »falsch« und tiven Vergleich zwischen den beiden Codezahlen, das Ausgangssignal des als UND-Gatter wirkenden das NAND-Gatter 123 ein »wahr«-Ausgangssignal NAND-Gatters 116 »wahr«. Wenn daher während liefert, das in Fig. 7 mit MYC161 bezeichnet ist. der Sperrcodezahl-Periode des Ausgangssignals des Das letztgenannte Signal wird den Informations-the output signal of the negator 114 "false" and tive comparison between the two code numbers, the output signal of the NAND gate 123 acting as an AND gate, a "true" output signal of the NAND gate 116 "true". If, therefore, during supplies, which is denoted by MYC 161 in FIG. 7. the lock code number period of the output signal of the The last-mentioned signal is the information
NAND-Gatters 116 »falsch« ist, zeigt es an, daß die 5 Eingängen von Flipflops 124 und 125 zugeführt. Die beiden Zahlen in den beiden Sperr-Registern iden- Funktion des FlipflopsJi24 besteht darin, ein Signal tisch sind, während ein »wahr«-Ausgangssignal wäh- zu liefern, um das Flipflop 39 (s. Fig. 1) zu erregen rend dieser Periode bedeutet, daß die beiden Zahlen sowie einen + 1-Wert auf den Parallel-Addierer 38 voneinander abweichen. zu übertragen. Die Funktion des Flipflops 124 ist inNAND gate 116 is "false", it indicates that the 5 inputs of flip-flops 124 and 125 are supplied. the Both numbers in the two lock registers are identical. The function of the flip-flop Ji24 is to generate a signal are table while a "true" output signal is to be supplied to energize the flip-flop 39 (see FIG. 1) End of this period means that the two numbers and a +1 value are sent to the parallel adder 38 differ from each other. transferred to. The function of the flip-flop 124 is in
Wie aus Fig. 5 ersichtlich, wird die Rückstell- io Fig. 7 durch die Zahl +1 dargestellt, die in runden schaltung, die voh dem NAND-Gatter 53 gebildet Klammern in den Block 124 eingetragen ist. Ähnlich wird, das als ODER-Gatter arbeitet, mit dem Aus- hat das Flipflop 125 die Funktion, ein Steuersignal gangssignal des NAND-Gatters 116 versorgt, d. h., an den Programmzähler 33 zu liefern, um den Inhalt daß das Signal OLKR einem seiner Eingänge züge- des Programmzählers 33 dem Parallel-Addierer 38 führt wird. Immer wenn die Zahlen in den beiden 15 zuzuführen. Die Funktion des Flipflops 125 ist in Sperr-Registern 51 identisch sind, ist das Signal F i g. 7 durch das in Klammern gesetzte Symbol Ρ-*Σ OLKR »falsch« und infolgedessen das Ausgangs- veranschaulicht.As can be seen from FIG. 5, the reset io FIG. 7 is represented by the number +1, which is entered in brackets in the block 124 in a round circuit formed by the NAND gate 53. Similarly, which works as an OR gate, with the output, the flip-flop 125 has the function of supplying a control signal output signal of the NAND gate 116, that is to say supplying the program counter 33 with the content of the signal OLKR to one of its inputs Zug- the program counter 33 leads to the parallel adder 38. Whenever the numbers in the two 15 feed. The function of the flip-flop 125 is identical in lock registers 51, the signal F i g is. 7 by the symbol Ρ- * Σ OLKR in brackets »wrong« and thus the starting point is illustrated.
signal des NAND-Gatters 53 »wahr«. Hierdurch Das NAND-Gatter 123, das als ODER-Gattersignal of the NAND gate 53 "true". As a result, the NAND gate 123, which acts as an OR gate
werden alle Flipflops 81 bis 90 gelöscht, so daß die. arbeitet, wird noch mit weiteren Eingangssignalen Codezahl, die ihnen zuvor von den Bits 5 bis 8 des 20 versorgt. Eines der Eingangssignale wird von dem C-Registers 32 und den Bits 12 bis 17 des B-Regi- Ausgangssignal eines NAND-Gatters 126 gebildet, sters31 zugeführt wurde, gelöscht wird. das als UND-Gatter arbeitet. Wie dargestellt, weistall flip-flops 81 to 90 are cleared, so that the. works, is still with further input signals Code number that was previously supplied to you by bits 5 to 8 of 20. One of the input signals is from the C register 32 and bits 12 to 17 of the B register output signal of a NAND gate 126, sters31 was supplied, is deleted. that works as an AND gate. As shown, has
Das Ausgangssignal der Vergleichsschaltung 52, das Gatter 126 zwei Eingangsklemmen auf, denen das durch das Ausgangssignal OLKR des NAND- decodierte Signale von dem Decoder 34 zugeführt Gatters 116 dargestellt wird, wird auch der Pro- 25 werden, die als K5 — 1 und OTRY bezeichnet wergrammsteuereinheit 40 zugeführt, um den Programm- den. Im wesentlichen besteht die Funktion des ablauf des datenverarbeitenden Geräts Pl so zu NAND-Gatters 126 darin, dem NAND-Gatter 123 steuern, daß das notwendige nachfolgende Befehls- ein »falsch«-Signal zuzuführen, um die Zahl des wort, wie oben behandelt, angefordert wird. Wenn Programmzählers 33 in dem Parallel-Addierer 38 nämlich das Ausgangssignal OLKR der Vergleichs- 30 immer dann um »1« zu vermehren, wenn ein Befehlsschaltung 52 »wahr« ist und dadurch einen nega- wort von dem Decoder decodiert wird, ausgenomtiven Vergleich anzeigt, wird das datenverarbeitende men dann, wenn das Befehlswort einen Über-Gerät veranlaßt, eines der Befehlsworte, nämlich tragungsbefehl darstellt, der durch den Code 00 den Rückübertragungsbefehl zu überspringen, um (s. F i g. 3 und 4) charakterisiert wird. Wenn ein fähig zu sein, seine Funktion mit dem Aufnehmen 35 Übertragungsbefehl empfangen wird, ist somit das des Postens gemeinsamer Daten fortzusetzen. Wenn Signal OLRY, das dem NAND-Gatter 126 zugeführt jedoch das Ausgangssignal OLKR »falsch« ist und wird, »falsch«, und es ist deshalb das von dem dadurch einen positiven Vergleich anzeigt, wird das NAND-Gatter 126 gelieferte Eingangssignal für das datenverarbeitende Gerät so gesteuert, das es seine NAND-Gatter 123 »wahr«, so daß das Signal Funktion mit der Anforderung des nächsten Befehls- 40 MYC161 »falsch« und daran gehindert ist, die Wortes fortsetzt, bei dem es sich um einen Über- Flipflops 124 und 125 zur Ausführung ihrer enttragüngsbefehl handelt, so daß das datenverarbei- sprechenden Funktionen zu veranlassen. Wie aus tende Gerät in gewissem Sinne in einer Schleife Fig. 7 ersichtlich, können dem NAND-Gatter 123 gefangen ist, die bewirkt, daß ihm der Sperrcode- weitere Eingangssignale zugeführt werden, die, wenn zahl-Befehl so lange zugeführt wird, bis ein nega- 45 sie »falsch« sind, bewirken, daß das NAND-Gatter tiver Vergleich in der Vergleichsschaltung 52 zu- 123 ein »wahr«-Ausgangssignal MYC161 liefert, das stände kommt. eine Erhöhung des Inhaltes des Programmzählers 33The output signal of the comparison circuit 52, the gate 126 having two input terminals, to which the gate 116 fed by the output signal OLKR of the NAND- decoded signal from the decoder 34 is represented, will also be the pro-25 which is designated as K 5-1 and OTRY denotes wergram control unit 40 supplied to the program. Essentially, the function of the sequence of the data processing device P1 in relation to NAND gate 126 is to control NAND gate 123 so that the necessary subsequent command is supplied with a "false" signal in order to determine the number of the word, as dealt with above, is requested. If the program counter 33 in the parallel adder 38 indicates that the output signal OLKR of the comparison 30 is increased by "1" whenever a command circuit 52 is "true" and a negative word is decoded by the decoder, indicates an excepted comparison, If the command word causes an over-device, the data processing menu represents one of the command words, namely transfer command, which is characterized by the code 00 to skip the return transfer command (see FIGS. 3 and 4). If one is to be able to receive its function with the recording 35 transmission command, that of posting common data is thus to continue. If the signal OLRY, which is fed to the NAND gate 126, but the output signal OLKR is "false" and becomes "false," and it is therefore that of which thereby indicates a positive comparison, the NAND gate 126 is supplied input signal for the data processing The device is controlled in such a way that its NAND gate 123 is "true", so that the function signal is "false" with the request for the next command 40 MYC 161 and is prevented from continuing the word which is an over- Flip-flops 124 and 125 act to execute their enttragüngsbefehls, so that the data processing-speaking functions to initiate. As can be seen from the device in a certain sense in a loop Fig. 7, the NAND gate 123 is trapped, which causes it to be supplied with the locking code further input signals, which, if the number command is supplied until a negative 45 they are "false" have the effect that the NAND gate tive comparison in the comparison circuit 52 to 123 delivers a "true" output signal MYC 161, which comes up. an increase in the content of the program counter 33
Zur besseren Erklärung der Art und Weise der um »1« bewirkt, damit das nächste Befehlswort, Steuerung der Programmsteuereinheit 40 wird auf von der nächsten Adresse des Speichers angefordert Fig. 7 verwiesen, die ein vereinfachtes Blockschalt- 5° wird.For a better explanation of the way that "1" causes the next command word, Control of the program control unit 40 is requested from the next address of the memory 7 referenced, which is a simplified block circuit 5 °.
bild eines Teiles der Programmsteuereinheit 40 zeigt, Der Teil der Programmsteuereinheit 40, der beiFigure of a portion of the program control unit 40 shows the portion of the program control unit 40 that is shown at
das für die Anwendung der hierin offenbarten Lehren der Anwendung der Lehren der vorliegenden Erfinnotwendig ist. Wie ersichtlich, umfaßt die Schaltung dung benötigt wird, enthält auch ein NAND-Gatter ein NAND-Gatter 122, dessen einem Eingang das 128, das als Negator arbeitet. Der Eingang des Vergleichs-Bereitschafts-Signal CEl zugeführt wird, 55 Gatters 128 ist mit dem Ausgang des NAND-Gatters während einem anderen Eingang des NAND-Gatters 116 (F i g. 6) verbunden. Das Ausgangssignal des 122 das Ausgangssignal OLKR der Vergleichsschal- Gatters 128 dient als Eingangssignal für ein NAND-tung 52 zugeführt wird. Das NAND-Gatter 122 Gatter 132, das als UND-Gatter arbeitet. Das andere arbeitet als UND-Gatter, so daß während der Sperr- Eingangssignal des NAND-Gatters 132 kann von codezeit-Periode, wenn das Signal MYC29 verfügbar. 6° dem datenverarbeitenden Gerät Pl geliefert werden ist, nur dann, wenn die beiden Codezahlen in den und die Priorität der Operationen von Pl in bezug beiden Sperr-Registern 51. verschieden sind und daher auf die Prioritäten der anderen datenverarbeitenden das Signal OLKR »wahr« ist, das Ausgangssignal Geräte anzeigen. Unter der Annahme, daß die Oper des NAND-Gatters 122 »falsch« ist. Dieses; : Aus- rationen des datenyerarbeitenden Gerätes;/'2 den gangssignal· wird als eines der Eingangssignal^'einem 65 Vorrang vor den Operationen des datenyerarbeiten-NAND-Gatterl23 zugeführt, das als ODER-Gatter den Geräts Pl haben, ist das mit OFO7 bezeichnete arbeilet, so daß dann, wenn das Ausgangssignal des Eingangssignal des NAND-Gatters 132 »wahr«. Weil, NAND.-Gatters 122 falsch ist, d.h. bei einem nega- wie zuvor beschrieben, bei Vorliegen eines positivenas is necessary to practicing the teachings of the present invention disclosed herein. As can be seen, the circuit comprises manure, a NAND gate also contains a NAND gate 122, one input of which is the 128, which operates as an inverter. The input of the comparison ready signal CEl is fed to 55 gate 128 is connected to the output of the NAND gate while another input of the NAND gate 116 (FIG. 6). The output signal of the 122, the output signal OLKR of the comparison gate 128 is used as an input signal for a NAND device 52 is supplied. The NAND gate 122 gate 132 which functions as an AND gate. The other works as an AND gate, so that during the inhibit input signal of the NAND gate 132 can be of code time period when the signal MYC 29 is available. 6 ° is supplied to the data processing device P1, only if the two code numbers in and the priority of the operations of P1 with respect to the two lock registers 51. are different and therefore the signal OLKR is "true" on the priorities of the other data processing devices. is to display the output signal devices. Assuming that the opera of NAND gate 122 is "false". This ; : Ausrations of the data processing device; / '2 the output signal · is supplied as one of the input signals ^' to a 65 priority over the operations of the data processing NAND gate 23, which has the device P1 as an OR gate, this is with OFO 7 designated arbeilet so that if the output of the input of NAND gate 132 is "true". Because NAND. Gate 122 is false, that is to say if there is a negative as described above, if a positive is present
15 1615 16
Vergleiches, d. h. bei Gleichheit der Codezahlen in' wird, deren Ausgänge mit den Informations-Eingänzwei Sperr-Registern, das Signal OLKR »falsch« und gen der Flipflops 81 bis 90 verbunden sind. Zur daher das Ausgangssignal LKR des NAND-Gatters selben Zeit liefert der Decoder 34 auf die Leitung 62 128 »wahr« ist, sind in diesem Falle beide Eingangs- ein Signal, das in Fig. 5 mit OMYC29 bezeichnet signale des NAND-Gatters 132 »wahr« und deshalb 5 ist, so daß das NAND-Gatter 53 ein »wahr«-Aussein Ausgangssignal »falsch«. Das Ausgangssignal gangssignal an jede der Steuerklemmen der Flipflops des Gatters 132 wird einem NAND-Gatter 134, das 81 bis 90 liefert und sie dadurch befähigt, in Überais ODER-Gatter arbeitet, als eines der Eingangs- einstimmung mit den Ausgangssignalen ihrer entsignale zugeführt, so daß dann, wenn das Ausgangs- sprechenden NAND-Gatter eingestellt zu werden, signal des Gatters 132 »falsch« ist, das als MYC162 io Während des Anfangsteils des Taktintervalls i4 werbezeichnete Ausgangssignal des Gatters 134 »wahr« den daher die Flipflops 81 bis 90, die das Sperrist. Dieses Ausgangssignal wird als eines der Ein- Register 51 bilden, in Übereinstimmung mit dem gangssignale für die Informations-Eingangsklemme binären Gehalt der Bits 5 bis 9 des C-Registers 32 des Flipflops 125 verwendet. Daher wird immer und der Bits 12 bis 17 des B-Registers 31 eingestellt, dann, wenn das Ausgangssignal MYC162 »wahr« 15 Das Einstellen dieser Flipflops oder des Sperr-Regiist, das Flipflop 125 gestellt, um den Programm- sters 51 wird in F i g. 8 durch die positiv ansteigende zähler 33 (F i g. 1) zu veranlassen, seinen Inhalt auf Kurve 154 veranschaulicht.Comparison, ie if the code numbers are equal in ', the outputs of which are connected to the information input two lock registers, the signal OLKR "false" and to the flip-flops 81 to 90. Therefore, when the output signal LKR of the NAND gate is at the same time, the decoder 34 on the line 62 delivers 128 "true", in this case both input signals are signals of the NAND gate 132, denoted OMYC 29 in FIG "True" and therefore 5, so that the NAND gate 53 has a "true" -out output signal "false". The output signal output signal to each of the control terminals of the flip-flops of gate 132 is fed to a NAND gate 134, which supplies 81 to 90 and thereby enables them to operate in Überais OR gates, as one of the input matches with the output signals of their designals, see above that when the output-speaking NAND gate is set, the signal of the gate 132 is "false", the output signal of the gate 134 advertised as MYC 162 io during the initial part of the clock interval i 4 is "true", therefore the flip-flops 81 bis 90 that is blocked. This output signal is used as one of the input registers 51, in correspondence with the output signals for the information input terminal binary content of bits 5 to 9 of the C register 32 of the flip-flop 125. Therefore, bits 12 to 17 of the B register 31 are always set if the output signal MYC 162 is "true" F i g. 8 illustrated by the positively increasing counter 33 (FIG. 1) causing its contents on curve 154.
den Parallel-Addierer 38 zu übertragen. Der Zweck Es sei angenommen, daß der Vergleich des Aus-the parallel adder 38 to transmit. The Purpose Assume that the comparison of the
dieser Maßnahme ist, beim Starten' des Speicher- gangssignals des Sperr-Registers 51 des datenverarzyklus eine Verzögerung um eine Taktimpulszeit zu 20 beitenden Gerätes Pl mit dem Ausgangssignal des erreichen, damit die Codezahl in dem datenverarbei- Sperr-Registers 51 des datenverarbeitenden Gerätes tenden Gerät P 2 gesperrt werden kann, das die P 2 positiv ausfällt. Es ist dann aus der vorhergehen-Priorität hat. Dieses Merkmal der Erfindung wird den "Beschreibung der Vergleichsschaltung 52 nach hernach im einzelnen beschrieben. . F i g. 6 verständlich, daß in diesem Falle das NAND-this measure is 'when starting' the memory output signal of the lock register 51 of the data processing cycle a delay of one clock pulse time to 20 beitenden device Pl with the output signal of the Achieve so that the code number in the data processing lock register 51 of the data processing device Bending device P 2 can be blocked, the P 2 is positive. It is then from the previous priority has. This feature of the invention will be described in the description of the comparison circuit 52 described in detail below. . F i g. 6 understandable that in this case the NAND
Um die neuen Lehren der vorliegenden Erfindung, 25 Gatter 116 ein »falsch«-Ausgangssjgnal liefert, das nach denen eine Vielzahl von datenverarbeitenden in Fig. 6 mit OLKR bezeichnet ist. Dieses Signal Geräten so gesperrt wird,, daß zu einer gegebenen wird dann der Rückstellschaltung 53 (F i g. 5) zuge-Zeit nur ein datenverarbeitendes Gerät einen Posten führt, um die Flipflops 81 bis 90 zu löschen. Das gemeinsamer Daten auf den neuesten Stand bringen Löschen der Flipflops hat das Löschen der Codezahl kann, besser verständlich zu machen, wird auf die 30 zur Folge, die zuvor darin gespeichert war. Das F i g. 8 und 9 verwiesen, die Impulsdiagramme dar- »falsch«-Ausgangssignal OLKR des NAND-Gatters stellen, die zum Erklären der zuvor beschriebenen 116 ist in Fig. 8 durch den positiven Impuls 155 Sperrfunktionen nützlich sind. In den F i g. 8 und 9 bezeichnet.In order to comply with the new teachings of the present invention, 25 gate 116 provides a "false" output signal which is indicated by OLKR in FIG. 6 after a large number of data processors. This signal devices is blocked in such a way that, at a given time, the reset circuit 53 (FIG. 5) only has one data processing device carrying out an item to clear the flip-flops 81 to 90. Bringing the shared data up to date, clearing the flip-flops has resulted in the clearing of the code number being able to make it more understandable, will result in the 30 that was previously stored in it. The F i g. 8 and 9, the timing diagrams depicting the "false" output signal OLKR of the NAND gate useful in explaining the 116 is previously described in FIG. 8 by the positive pulse 155 blocking functions. In the F i g. 8 and 9 designated.
bezeichnen die Linien 141 bis 148 den Beginn von Wie aus F i g. 8 ersichtlich, wird das Vergleichs-lines 141 to 148 denote the beginning of How from FIG. 8, the comparative
Taktintervallen J1 bis i8. Diese Taktintervalle sind 35 Bereitschafts-Signal CEl, das durch die Kurve 153 X durch Taktimpulse definiert, die von dem Taktgeber . wiedergegeben wird, von dem Decoder zu Beginn 35 (s. F i g. 1) in bekannter Weise erzeugt werden. der Taktperiode f3 erzeugt. Dieses Signal wird dannClock intervals J 1 to i 8 . These clock intervals are 35 ready signal CEl, which is defined by the curve 153 X by clock pulses generated by the clock. is reproduced, generated by the decoder at the beginning 35 (see FIG. 1) in a known manner. the clock period f 3 is generated. This signal will then
Es sei angenommen, daß vor der Zeit I1 das daten- dem NAND-Gatter 122 ■ der Programmsteuereinheit verarbeitende GerätP1 veranlaßt wird, das in Fig. 3 40 zugeführt. Während der Periode t3, bevor nämlich gezeigte Unterprogramm auszuführen. Als Folge 40 die Codezahl im Sperr-Register 51 gesperrt wird, um davon wird zu Beginn der Zeit ^1 (Linie 141) das in der Vergleichsschaltung 52 verglichen zu werden, datenverarbeitende Gerät Pl das an der Adresse W ist das Signal OLKR »wahr«. Demnach sind die vorhandene Befehlswort anfordern. Diese Anforde- beiden Eingangssignale des NAND-Gatters 122 rung wird auf die Speichereinheit 20 während der (Fig. 7) »wahr«, und infolgedessen ist dessen AusPeriode t2 übertragen, wie es durch die positiv 45 gangssignal »falsch«. Daher ist das Ausgangssignal ansteigende Kurve 151 angezeigt wird, so daß zu des NAND-Gatters 123, das als ODER-Gatter Beginn des Taktintervalls /3 (Linie 143) das Befehls- arbeitet, »wahr«, was zur Folge hat, daß zu Beginn wort von der Adresse W auf das Pufferregister und des Taktintervalls ta ein Programmsteuersignal das Befehlsregister von Pl übertragen wird, wie es MYC161 erzeugt wird. Dieses Signal wird in Fig. 8 durch die positiv ansteigende Kurve 152 dargestellt 50 durch einen positiv ansteigenden Impuls 156 darwird. Der Inhalt der Bits 0 bis 4 und 9, 10 und 11 gestellt. Wie aus Fig. 7 ersichtlich, wird das Signal des Befehlswortes wird, wie zuvor beschrieben, auf MYC161 den Flipflops 124 und 125 zugeführt, so das C-Register 32 übertragen und von diesem dem daß zu Beginn des nächsten Taktintervalls i4, der Decoder 34 zugeführt, um den Inhalt zu decodieren. durch die Linie. 144 angezeigt wird, die beiden FHp-Wie aus Fig. 3 ersichtlich, stellt der Code in diesen 55 flops eingestellt werden. Die Funktion des Flipflops Bits eine Sperrcodezahl dar, die in dem mit N 124 besteht darin, das Flipflop 39 (Fig. 1) zu verbezeichneten Feld vorhanden ist. Daher wird an anlassen, den Wert +1 dem Parallel-Addierer 38 einem Punkt während des Taktintervalls t3 der hinzuzuaddieren. Diese Funktion wird in Fig. 8 Decoder 34 das Sperrcodesignal liefern, das oben durch den positiv ansteigenden Impuls 157 angezeigt, mit MYC29 bezeichnet wurde. Dieses Sperrcode- 60 Weiterhin besteht die Funktion des Flipflops 125 signal wird in F i g. 8 durch den positiven Impuls 153 darin, dem Programmzähler 33 ein Steuersignal zuwiedergegeben. . zuführen, um dessen Inhalt dem Parallel-Addierer 38It is assumed that before time I 1 the device P1 processing the data to the NAND gate 122 of the program control unit, which is supplied to 40 in FIG. 3, is initiated. During the period t 3 , namely before executing the shown subroutine. As a result 40 the code number in the lock register 51 is locked, so that at the beginning of the time ^ 1 (line 141) the data processing device Pl that is to be compared in the comparison circuit 52 and the signal OLKR at address W is "true" . Accordingly, the existing command word are to be requested. This request two input signals of the NAND gate 122 becomes "true" on the memory unit 20 during (FIG. 7), and as a result its off period t 2 is transmitted, as indicated by the positive 45 output signal "false". Therefore, the output signal rising curve 151 is displayed, so that at the NAND gate 123, which works as an OR gate at the beginning of the clock interval / 3 (line 143) the instruction is "true", which has the consequence that at the beginning word from the address W to the buffer register and the clock interval t a, a program control signal is transferred to the command register from PI, as MYC 161 is generated. This signal is represented in FIG. 8 by the positively rising curve 152, which is represented by a positively rising pulse 156. The content of bits 0 to 4 and 9, 10 and 11 are set. As can be seen from Fig. 7, the signal of the command word is, as previously described, fed to the flip-flops 124 and 125 on MYC 161, so the C register 32 is transferred and from this that at the beginning of the next clock interval i 4 , the decoder 34 to decode the content. through the line. 144 is displayed, the two FHp-As can be seen from Fig. 3, the code in these 55 represents flops to be set. The function of the flip-flop bit is a lock code number contained in the field labeled N 124 to identify flip-flop 39 (Fig. 1). Therefore, we start adding the value +1 to the parallel adder 38 at a point during the clock interval t 3 of the. This function will deliver the lock code signal in FIG. 8 to decoder 34, which was indicated above by the positive rising pulse 157, designated MYC29. This locking code 60 continues the function of the flip-flop 125 signal is shown in FIG. 8 by the positive pulse 153 in it, the program counter 33 reproduces a control signal. . to feed its content to the parallel adder 38
Wie aus Fig. 5 ersichtlich, wird das Sperrcode- zuzuführen. Diese Funktion wird in Fig. 8 durch signal MYC29 jedem der NAND-Gatter 71 bis 80 den positiv ansteigenden Impuls 158 veranschaulicht, zugeführt, so daß zu Beginn des nächsten Taktinter- 65 Als Wirkung des .Programmsteuersignals MYC161 valls/, (Linie 144) der Inhalt der Bits 5 bis 8 des wird also während des Taktintervalls tt der Inhalt C-Registers 32 und der Bits 12 bis 17 des B-Regi- des Programmzählers 33 und ein zusätzlicher Wert stM 31 den NAND-Gattern 71 bis 80 zugeführt -|-1 auf den Parallel-Addierer38 übertragen.As can be seen from Fig. 5, the lock code is supplied. This function is shown in Fig. 8 by signal MYC29 to each of the NAND gates 71 to 80, the positive rising pulse 158 is applied, so that at the beginning of the next clock interval 65 As an effect of the .Program control signal MYC 161 valls /, (line 144) the content of bits 5 to 8 of the is supplied to the NAND gates 71 to 80 during the clock interval t t, the content of C register 32 and bits 12 to 17 of the B register of the program counter 33 and an additional value stM 31 - | -1 is transferred to the parallel adder 38.
Dieser Vorgang findet unabhängig von dem Vergleich der Codezahl statt, die in dem Sperr-RegisterThis process takes place independently of the comparison of the code number in the lock register
51 gespeichert ist und in der Vergleichsschaltung 52 verglichen wird. Die Technik des Steuerns der Übertragung des Inhalts eines Registers auf einen Parallel-Addierer sowie das Addieren von Werten, wie z. B. +1 zum Addierer, um den Inhalt des Programmregisters zu vermehren, ist in der Technik wohlbekannt und braucht deshalb hier nicht im einzelnen beschrieben zu werden. Zu Beginn des Taktintervalls ts wird dann der Inhalt des Parallel-Addierers, der nun den vorherigen Inhalt des Programmzählers 33 plus den Wert +1 darstellt, zurück auf den Programmzähler übertragen, wie es in F i g. 8 durch den Pegelwechsel 159 angezeigt wird, so daß während des Anfanges eines folgenden Taktintervalls, wie z. B. t6, das nächste Befehlswort, d. h. W + 1, in Übereinstimmung mit dem Inhalt des Programmzählers 33 angefordert wird.51 is stored and is compared in the comparison circuit 52. The technique of controlling the transfer of the contents of a register to a parallel adder as well as adding values such as e.g. B. +1 to the adder to augment the contents of the program register is well known in the art and therefore need not be described in detail here. At the beginning of the clock interval t s , the content of the parallel adder, which now represents the previous content of the program counter 33 plus the value +1, is transferred back to the program counter, as shown in FIG. 8 is indicated by the level change 159, so that during the beginning of a following clock interval, such as. B. t 6 , the next command word, ie W + 1, is requested in accordance with the content of the program counter 33.
Wenn das Befehlswort, das an der Adresse W + 1 gespeichert ist, von dem datenverarbeitenden Gerät Pl empfangen und decodiert wird, zeigt es, wie aus Fig. 4 ersichtlich an, daß ein Übertragungsbefehl die Rückübertragung zur Adresse W bewirken soll, was weiterhin bewirkt, daß der zu speichernde Sperrcodezahl-Befehl oder die Sperrcodezahl C0 wiederholt wird. Die Codezahl wird erneut in einem Sperr-Register 51 gespeichert, und es wird anschließend ein Vergleich ausgeführt. Wenn das Speicherregister irgendeines anderen datenverarbeitenden Gerätes, wie z.B. des datenverarbeitenden GerätesP2, eine Codezahl C0 speichert, wird ein positiver Vergleich, wie er durch den Impuls 155 in Fig. 8 dargestellt wird, erzielt, der zur Folge hat, daß von dem gesteuerten datenverarbeitenden Gerät Pl das nachfolgende Befehlswort von der Adresse W + 1 empfangen wird. So ist es für den Fachmann ersichtlich, daß das daten verarbeitende Gerät P1 in einem gewissen Sinn gesperrt bleibt und nacheinander die Befehlsworte an den Adressen W3-WfI, W, W+l, usw. verarbeitet. Das datenverarbeitende Gerät ist nämlich daran gehindert, zum Empfang des nächsten Befehlswortes von der Adresse W + 2 überzugehen, das einen Befehl zum Übertragen eines Postens gemeinsamer, an der Adresse X gespeicherter Daten auf das datenverarbeitende Gerät P1 darstellt.When the instruction word is at address W stored + 1, is received by the data-processing device Pl and decoded, it shows, as shown in FIG. 4 can be seen in that a transfer instruction to the address is to effect the retransmission W, which further causes that the locking code number command to be stored or the locking code number C 0 is repeated. The code number is again stored in a lock register 51, and a comparison is then carried out. If the memory register of any other data processing device, such as data processing device P2, stores a code number C 0 , a positive comparison, as represented by pulse 155 in FIG Device Pl the following command word is received from address W + 1. It is apparent to a person skilled in the art that the data processing device P1 remains blocked in a certain sense and processes the command words at the addresses W 3 -WfI, W, W + 1, etc. one after the other. This is because the data processing device is prevented from proceeding to receive the next command word from the address W + 2 , which is a command to transfer an item of common data stored at the address X to the data processing device P1.
Es wird jetzt auf F i g. 9 verwiesen, in der Elemente, die Elementen in den vorhergehenden Figuren gleich sind, durch gleiche Bezugszahlen bezeichnet sind. Zum Zwecke der Erläuterung sei angenommen, daß nach dem Sperren oder Einschreiben der Codezahl C0 in dem Sperr-Register 51 gesperrt und Ausführen des Vergleichs in der VergleichsschaltungIt is now shown on FIG. 9, in which elements that are the same as elements in the previous figures are denoted by the same reference numerals. For the purpose of explanation it is assumed that after the blocking or writing of the code number C 0 in the blocking register 51 is blocked and the comparison is carried out in the comparison circuit
52 ein negatives Vergleichssignal erzeugt wird, das durch die gestrichelte Linie 155./! wiedergegeben wird und anzeigt, daß keines der Sperr-Register der anderen datenverarbeitenden Geräte eine Codezahl enthält, die der Codezahl C0 gleich ist, die in dem Sperr-Register 51 von Pl gespeichert ist. Dann versteht es sich nach dem Vorhergehenden, daß das Ausgangssignal des NAND-Gatters 116 (Fi g. 6) »wahr« ist. Das Signal OLKR an dem Ende der Vergleichsperiode ist nämlich »wahr«. Wenn dies der Fall ist, wird das NAND-Gatter 122 (F i g. 7) wieder mit zwei »wahrÄ-Eingangssignalen erregt, so daß dessen Ausgangssignal »falsch« ist, was ein positives Programmsteuersignal MYC161 zur Folge hat, das von dem NAND-Gatter 123 erzeugt wird. Das zuletzt erwähnte Signal wird in F i g. 9 durch den Impuls 156 A wiedergegeben.52 a negative comparison signal is generated, which is indicated by the dashed line 155./! is reproduced and indicates that none of the lock registers of the other data processing devices contain a code number which is the same as the code number C 0 stored in the lock register 51 of P1. Then it will be understood from the foregoing that the output signal of the NAND gate 116 (Fig. 6) is "true". The signal OLKR at the end of the comparison period is namely "true". If so, the NAND gate 122 (Fig. 7) is again energized with two "true" inputs so that its output is "false", resulting in a positive program control signal MYC 161 which is generated by the NAND gate 123 is generated. The last-mentioned signal is shown in FIG. 9 represented by the pulse 156 A.
Das zusätzliche Programmsteuersignal MYC161 wirkt wieder auf die Flipflops 124 und 125 ein, die das Flipflop 39 bzw. den Programmzähler 33 veranlassen, ihren Inhalt auf den Parallel-Addierer 38 zu übertragen. Während im Taktintervall Z4 das Flipflop 39 dem Parallel-Addierer den Wert f 1 zuzuführt, der nach dem Addieren zu dem Inhalt desThe additional program control signal MYC 161 acts again on the flip-flops 124 and 125, which cause the flip-flop 39 or the program counter 33 to transfer their content to the parallel adder 38. While in the clock interval Z 4 the flip-flop 39 supplies the parallel adder with the value f 1, which after adding to the content of the
ίο Programmzählers 33, der den Wert der Adresse W darstellt, zu einem Gesamtausgangssignal des Parallel-Addierers W+l führt, liefert daher wegen des zusätzlichen Programmsteuersignals MYC161, das durch den Impuls 156vl dargestellt wird, das FHpflop 39 einen zusätzlichen Wert + 1, der durch den Impuls 157 A dargestellt wird, so daß die Addition in dem Parallel-Addierer 38 am Ende des Taktintervalls t. den Gesamtwert W + 2 ergibt. Dieser Gesamtwert, der durch den Impuls 159.4 veranschau-ίο program counter 33, which represents the value of the address W , leads to a total output signal of the parallel adder W + 1 , therefore, because of the additional program control signal MYC 161, which is represented by the pulse 156vl, the FHpflop 39 provides an additional value + 1, which is represented by the pulse 157 A , so that the addition in the parallel adder 38 at the end of the clock interval t. gives the total value W + 2. This total value, illustrated by the pulse 159.4
ao licht wird, wird zu Beginn des Zeitintervalls t6 auf den Programmzähler 33 übertragen, so daß zu Beginn eines nachfolgenden Taktintervalls von dem datenverarbeitenden Gerät das Befehlswort von der Adresse W + 2 angefordert wird.ao is light, is transferred to the program counter 33 at the beginning of the time interval t 6 , so that the command word from the address W + 2 is requested by the data processing device at the beginning of a subsequent clock interval.
Wie aus Fig. 3 ersichtlich, stellt das Befehlswort, das an der Adresse W + 2 vorhanden ist, einen Befehl zur Übertragung oder Eingabe des Postens gemeinsamer Daten, die an Adresse X gespeichert sind, auf bzw. in das datenverarbeitende" Gerät dar. Daher wird der Posten gemeinsamer Daten auf das datenverarbeitende Gerät übertragen und es wird ähnlich jedes nachfolgende Befehlswort, das an einer der Adressen W + 3 bis W + 5 gespeichert ist, dem datenverarbeitenden Gerät zugeführt, bis das Unterprogramm abgeschlossen ist. Es versteht sich, daß das Befehlswort in der Adresse W + 5 ein Freigabebefehl für das Sperr-Register ist. Das ergibt sich aus dem Code 14 in den Bits O bis 4 und aus dem O-Code in den Bits 9 bis 11 des Befehlswortes. Wenn diese Codes, d. h. 14 und O, dem Decoder 34 über das Befehlsregister 32 zugeführt werden, liefert der Decoder auf einer Ausgangsleitung 63 ein »falsch«- Freigabesignal OMYC 30, das das als ODER-Gatter arbeitende NAND-Gatter 53 erregt, um ein »wahr«- Ausgangssignal zu erzeugen und dadurch alle Flipflops 81 bis 90 des Sperr-Registers 51 (Fig. 5) zu löschen. Das datenverarbeitende Geräte ist danach bereit, ein anderes Unterprogramm anzufangen, das von ihm ausgeführt werden soll.As can be seen from Fig. 3, the command word present at address W + 2 represents a command for transferring or inputting the item of common data stored at address X to the data processing device. Therefore the item of common data is transferred to the data processing device and, similarly, each subsequent command word stored at one of the addresses W + 3 to W + 5 is fed to the data processing device until the subroutine is completed Command word in address W + 5 is a release command for the lock register. This results from code 14 in bits O to 4 and from the O code in bits 9 to 11 of the command word and O, are fed to the decoder 34 via the command register 32, the decoder delivers a "false" enable signal OMYC 30 on an output line 63, which excites the NAND gate 53, operating as an OR gate, to a "true" output ssignal and thereby all flip-flops 81 to 90 of the lock register 51 (Fig. 5) to delete. The data processing device is then ready to start another subroutine that is to be executed by it.
Es versteht sich nach der vorhergehenden Beschreibung, daß, wenn in irgendeinem beliebigen nachfolgenden Unterprogramm, das durch das datenverarbeitende Gerät ausgeführt werden soll, eines der Befehlswörter dieses Unterprogramms einen Posten gemeinsamer Daten auf das datenverarbeitende Gerät übertragen soll, damit diese Daten verarbeitet und auf den neuesten Stand gebracht werden, diesem speziellen Befehlswort zwei Befehlswörter vorhergehen können, die das Sperren der Codezahl, die solchen Daten zugeordnet ist, in dem datenverarbeitenden Gerät steuern. Eins von ihnen kann den Sperrbefehl für die Codezahl, wie z. B. das erste Wort in den Fig. 3 und 4, und das andere kann den Rückübertragungsbefehl darstellen, wie z. B. das in der zweiten Zeile der F i g. 3 und 4 gezeigte Wort. Nach dem Sperren des Code des speziellen Postens gemeinsamer Daten wird ein Vergleich ausgeführt. Wenn ein positives Vergleichssignal erzeugt wird.It will be understood from the foregoing description that if in any subsequent subroutine that is to be executed by the data processing device, one of the Command words of this subroutine have a common data item on the data processing device should be transmitted so that this data is processed and brought up to date, this special command word can be preceded by two command words that block the code number, the such Data is assigned to control in the data processing device. One of them can be the lock order for the code number, such as B. the first word in Figures 3 and 4, and the other may be the retransmission command represent, such as B. the one in the second line of FIG. Word shown 3 and 4. To a comparison is made to the locking of the code of the special item of common data. When a positive comparison signal is generated.
19 2019 20
d. h., wenn ein anderes der datenverarbeitenden Ge- tätsgrad Zugriff zum Speicher hat. Zum besserend. That is, if another of the data processing level has access to the memory. For the better
rate diese Codezahl in seinem Sperr-Register enthält, Verständnis der Technik, die dazu benutzt wird, dasrate has this code number in its lock register, understanding the technique used to do that
wird das datenverarbeitende Gerät zum nächsten Be- die Priorität habende datenverarbeitende Gerät zuthe data processing device becomes the next priority data processing device
fehl übergehen, bei dem es sich um den Riicküber- befähigen, zuerst den Posten gemeinsamer Daten auf-fail over, which is the back-over-empowering to first post the common data post.
tragungsbefehls handeln wird. Wenn jedoch in kei- 5 zurufen, wird wieder auf die F i g. 7 und 8 hinge-order will act. If, however, no calls are made, the system reverts to FIG. 7 and 8
nem der anderen datenverarbeitenden Geräte die wiesen und die besondere Aufmerksamkeit auf dienem of the other data processing devices that pointed and pay special attention to the
spezielle Codezahl gesperrt ist, wird ein einen nega- drei unteren Zeilen der Fig. 8 gerichtet, die zur Er-special code number is blocked, a negative three lower lines of FIG.
tiven Vergleich anzeigendes Signal erzeugt, das, wie klärung der Arbeitsweise der Programmsteuereinheittive comparison generated signal that, how clarify the operation of the program control unit
oben beschrieben, die Programmsteuereinheit 40 40 in demjenigen datenverarbeitenden Gerät dienen,As described above, the program control unit 40 40 serve in that data processing device,
(Fig. 1) in solch einer Weise erregt, daß zwei auf- io das nicht die Priorität oder einen niederen Grad von(Fig. 1) excited in such a way that two on- io that is not the priority or a lower degree of
einanderfolgende Werte + 1 von dem Flipflop 39 zu Priorität hat. Wie aus F i g. 7 ersichtlich, erhält dasconsecutive values +1 from the flip-flop 39 has priority. As shown in FIG. 7 shows that
dem Parallel-Addierer 38 zugeführt werden, so daß NAND-Gatter 132 ein Eingangssignal OFO 7, das,are fed to the parallel adder 38, so that NAND gate 132 has an input signal OFO 7 which,
das an der nächsten Adresse gespeicherte Befehls- wie zuvor erklärt, in dem datenverarbeitenden Gerätthe command stored at the next address as previously explained in the data processing device
wort übersprungen wird und das datenverarbeitende mit dem niederen Prioritätsgrad »wahr« ist. Weiter-word is skipped and the data processing with the lower priority level is "true". Continue-
Gerät zu dem darauffolgenden Befehlswort fort- 15 hin wird ein anderes Eingangssignal des NAND-Device continues with the next command word - 15 another input signal of the NAND
schreiten kann, das den Befehl für die Übertragung Gatters 132 von dem Ausgangssignal des NAND-can take the command for the transmission of gate 132 from the output signal of the NAND
des Postens gemeinsamer Daten auf das Gerät Gatters 128 gebildet, das als Negator für sein vonof the entry of common data on the device gate 128, which acts as a negator for its from
enthält. der Vergleichsschaltung 52 zugeführtes Eingangs-contains. the comparison circuit 52 supplied input
Obwohl bisher angenommen wurde, daß immer signal OLKR arbeitet. Wie zuvor in Verbindung mitAlthough it was previously assumed that signal OLKR always works. As before in connection with
dann, wenn ein Posten gemeinsamer Daten auf das 20 den Fig. 8 und 9 beschrieben, bewirkt das Signalthen when a common data item is written to the 20 of Figs. 8 and 9, the signal causes
datenverarbeitende Gerät übertragen werden soll, CEl, daß der Programmzähler 33 seinen Inhalt aufdata processing device is to be transmitted, CEl that the program counter 33 to its content
ihm Befehlsworte zum Sperren des ihm zugeordneten den Parallel-Addierer 38 überträgt, wie es der Im-he transmits command words for blocking the parallel adder 38 assigned to him, as the im-
Code in dem datenverarbeitenden Gerat vorher- puls 158 anzeigt.Code in the data processing device fore-pulse 158 indicates.
gehen, versteht es sich, daß das Rechenprogramm Wenn die beiden datenverarbeitenden Geräte Unterprogramme zur Übertragung von Posten ge- 25 gleichzeitig versuchen, die gleiche Codezahl zu speimeinsamer Daten ohne Rücksicht auf die Tatsache, ehern oder zu sperren, ist das Ausgangssignal OLKR daß andere datenverarbeitende Geräte gerade diese der Vergleichsschaltung, wie zuvor beschrieben, Daten verarbeiten, enthalten kann, also Unterpro- »falsch«. Infolgedessen ist das Ausgangssignal des gramme zum Umgehen der Verriegelungsvorrich- Negators 128 (Fig. 7) »wahr«. Auch in dem datentung. Es genügt, wenn diese Unterprogramme die Be- 30 verarbeitenden Gerät, das nicht Priorität hat, ist das fehlsworte, die den Codezahlen solcher Daten züge- Signal OFO 7 ebenfalls »wahr« und deshalb das Ausordnet sind, nicht enthalten. gangssignal des als UND-Gatter arbeitenden NAND-go, it goes without saying that the arithmetic program If the two data processing devices subroutines for the transmission of items simultaneously try to store or block the same code number regardless of the fact, the output signal OLKR is that other data processing devices precisely these of the comparison circuit, as described above, can process and contain data, that is, subpro- "false". As a result, the output of the gram to bypass latch inverter 128 (FIG. 7) is "true". Also in the date. It is sufficient if these subroutines are the processing device, which does not have priority, is the wrong word, which refers to the code numbers of such data - signal OFO 7 is also "true" and is therefore not included. output signal of the NAND operating as an AND gate
Es besteht die Möglichkeit, daß zwei datenverar- Gatters 132 »falsch«. Weil das Ausgangssignal des beitende Geräte, wie Pl und P2, gleichzeitig ver- Gatters 132 als Eingangssignal einem NAND-Gatter anlaßt werden, zwei Unterprogramme wie jene aus- 35 134 zugeführt wird, das als ODER-Gatter arbeitet, zuführen, die in den Fig. 3 und 4 veranschaulicht ist das Ausgangssignal des Gatters 134, das ein zweisind. Es kann nämlich das Gerät Pl ein Befehlswort tes Programmsteuersignal MYC162 bildet, »wahr«, von der Adresse W zu der gleichen Zeit anfordern, wenn der Ausgang des Gatters 132 »falsch« ist. Wie zu der das Gerät P2 das Befehlswort von der aus Fig. 7 ersichtlich, wird das zweite Steuersignal AdresseZ anfordert. Wie aus den Fig. 3 und 4 er- 40 MYC162 dem Informationseingang des Flipflops sichtlich, sind die Befehlsworte an den beiden Adres- 125 so zugeführt, so daß, wenn das zweite Steuersen (W und Z) dieselben. Die beiden datenverarbei- signal MYC162 gegenwärtig ist, das Flipflop 125 tenden Geräte werden gleichzeitig versuchen, eine eingestellt wird und den Programmzähler 33 veran-Codezahl CD in ihrem entsprechenden Sperr-Register laßt, seinen Inhalt wieder auf den Parallel-Addierer 51 zu sperren. Infolgedessen wird sich in der Ver- 45 38 zu übertragen. Diese zusätzliche pbertragung ist gleichsschaltung 52 jedes der beiden datenverarbei- in Fig. 9 durch den positiven Impuls 158.4 angetenden Geräte ein positives Vergleichssignal ergeben, . zeigt.There is a possibility that two data processing gates 132 are "false". Because the output signal of the processing devices, such as P1 and P2, are simultaneously fed to gate 132 as an input signal to a NAND gate, two subroutines such as the one that operates as an OR gate, which are shown in FIGS Figures 3 and 4 illustrate the output of gate 134 being two. This is because the device P1 can generate a command word of the program control signal MYC 162, "true", request from the address W at the same time if the output of the gate 132 is "false". As the device P2 uses the command word from FIG. 7, the second control signal AdresseZ is requested. As the information input of the flip-flop clear from FIGS. 3 and 4 ER- 40 MYC 162, the instruction words on the two addressed 125 are supplied as so that when the second Steuersen (W and Z) are the same. The two data processing signal MYC 162 is present, the flip-flop 125 devices will simultaneously try to set one and the program counter 33 causes code number C D in their corresponding lock register to lock its contents back to the parallel adder 51 . As a result, the 45 38 transfer will take place. This additional transmission is equalization circuit 52 of each of the two data processing devices, which result in a positive comparison signal in FIG. 9 due to the positive pulse 158.4. indicates.
welches, wie zuvor beschrieben, jedes datenverar- Andererseits ist in dem datenverarbeitenden Gebeitende Gerät veranlassen wird, zu dem nächsten rät, das die Priorität hat, das Signal OFO 7 »falsch«, Befehlswort an der nächsten Adresse seines entspre- 5" und es wird deshalb in diesem Gerät während des chenden Unterprogrammes fortzuschreiten, bei dem Zeitintervalls f5 der Inhalt des Programmzählers 33 es sich um einen Rückübertragungsbefehl handelt nicht wieder auf den Parallel-Addierer zurücküber-(s. die zweiten Zeilen der F i g. 3 und 4). Die Rück- tragen, so daß der Inhalt des Parallel-Addierers in übertragung wird wieder die beiden datenverarbei- dem die Priorität aufweisenden Gerät während des tenden Geräte veranlassen, gleichzeitig auf das erste 55 Taktintervalls f5 auf den Programmzähler 33 überBefehlswort in jedem Unterprogramm zu reagieren, tragen wird, um dieses Gerät zu Beginn des Taktdas ein Sperrbefehl für die Codezahl ist. So können Intervalls/e zu befähigen, das nächste Befehlswort die beiden datenverarbeitenden Geräte in einer ge- anzufordern. In dem datenverarbeitenden Gerät, das schlossenen Schleife gesperrt werden, in der sie nach- nicht die Priorität hat, verursacht die Übertragung einander nur den ersten und den zweiten Befehl 6o des Inhaltes des Programmzählers 33 auf den Parihrer entsprechenden Unterprogramme verarbeiten. allel-Addierer 38 während des Taktintervalls i5, diewhich, as previously described, every data processing device is caused to advise the next one, which has priority, the signal OFO 7 "false", command word at the next address of its corresponding 5 "and it will Therefore, to proceed in this device during the corresponding subroutine, at the time interval f 5 the content of the program counter 33 is a retransmission instruction not transferred back to the parallel adder- (see the second lines of FIGS. 3 and 4) The return, so that the content of the parallel adder in transmission will again cause the two data processing devices having the priority during the device to move simultaneously to the first 55 clock interval f 5 to the program counter 33 via the command word in each subroutine react, will carry to this device at the beginning of the clock, which is a blocking command for the code number. So interval / e can enable the next e Command word to request the two data processing devices in one. In the data processing device, the closed loop in which it does not have priority, the transmission causes each other only to process the first and second instruction 60 of the contents of the program counter 33 to the corresponding subroutines. allele adder 38 during clock interval i 5 , the
Um zu verhindern, daß eine solche Sperrung in durch den Impuls 158B veranschaulicht wird, eineTo prevent such an inhibition from being illustrated in FIG. 4 by pulse 158 B , one
einer geschlossenen Schleife auftritt, sieht die Erfin- Zeitverzögerung um ein Taktintervall. Infolgedessena closed loop occurs, the invention sees a time delay of one clock interval. Consequently
dung eine zusätzliche Schaltung vor, die das einen kann das datenverarbeitende Gerät, das nicht die Vorrang aufweisende datenverarbeitende Gerät be- 65 Priorität hat, erst zu Beginn des nächsten Taktfähigt, den Speicher anzurufen und einen Posten ge- Intervalls /7, der durch die Linie 147 dargestellt wird, meinsamer Daten zu verarbeiten, bevor ein daten- das nächste Befehlswort anfordern,dung additional circuitry before, which may have a which the data processing device that is not the priority having data processing unit loading has 6 5 priority, until the beginning of the next Taktfähigt to call the memory and a post overall interval / 7, by the Line 147 is shown to process common data before a data request the next command word,
verarbeitendes Gerät mit einem niedrigeren Priori- Aus dem Vorhergehenden ist somit ersichtlich,processing device with a lower priority - From the above it can be seen
daß das die Priorität aufweisende datenverarbeitende Gerät fähig ist, das nächste Befehlswort zu Beginn des Taktintervalls f6 anzufordern, während das datenverarbeitende Gerät, das nicht die Priorität hat, um ein Taktintervall verzögert wird und das nächste Befehlswort erst zu Beginn des folgenden Taktinter- . valls f7 anfordern kann. Solch eine Anordnung bewahrt die beiden datenverarbeitenden Geräte davor, in einer geschlossenen Schleifenanordnung gesperrt zu bleiben. Es setzt das vorrangige datenverarbeitende Gerät instand, das nächste Befehlswort anzufordern, bevor das datenverarbeitende Gerät mit dem niederen Prioritätsgrad anfordern kann. Daher ist das vorrangige Gerät in der Lage, die Codezahl, die dem Posten gemeinsamer Daten zugeordnet ist, zu sperren und diese Daten zu verarbeiten. Andererseits muß das datenverarbeitende Gerät, das den niedrigeren Prioritätsgrad hat, abwarten, bis das vorrangige Gerät die Verarbeitung des Postens gemeinsamer Daten beendet hat und diesen Posten in den Speicher zurückführt. Es sei z. B. angenommen, daß das datenverarbeitende Gerät Pl einen höheren Grad von Priorität als das datenverarbeitende Gerät P 2 aufweist und daß die beiden datenverarbeitenden Geräte gleichzeitig mit der Ausführung der in den F i g. 3 und 4 veranschaulichten Unterprogramme beginnen. Es versteht sich dann aus dem Vorhergehenden, daß das datenverarbeitende Gerät Pl das erste sein wird, das den Posten gemeinsamer Daten empfängt, der an der Adresse X vorhanden ist, um ihn durch Hinzuaddieren einer »1« auf den neuesten Stand zu bringen. Erst nachdem der auf den neuesten Stand gebrachte Posten gemeinsamer Daten in den Speicher zurückgebracht worden ist und das Sperr-Register 51 des , datenverarbeitenden Gerätes Pl entsprechend dem Befehlswort, das an der Adresse W + 5 gespeichert ist, freigegeben worden ist, kann das datenverarbeitende Gerät P 2 den auf den neuesten Stand gebrachten Posten gemeinsamer Daten von der Adresse X empfangen, um von ihm entsprechend dem an der Adresse Z + 3 (s. F i g. 4) gespeicherten Befehlswort die Zahl »2« zu subtrahieren. that the data processing device having the priority is able to request the next command word at the beginning of the clock interval f 6 , while the data processing device that does not have the priority is delayed by one clock interval and the next command word only at the beginning of the following clock interval. valls f 7 can request. Such an arrangement prevents the two data processing devices from remaining locked in a closed loop arrangement. It enables the primary data processing device to request the next command word before the data processing device with the lower priority level can request. Therefore, the primary device is able to block the code number assigned to the post of common data and to process this data. On the other hand, the data-processing device which has the lower priority level must wait until the higher-priority device has finished processing the item of common data and returns this item to the memory. Let it be B. assumed that the data processing device P1 has a higher degree of priority than the data processing device P 2 and that the two data processing devices simultaneously with the execution of the F i g. 3 and 4 begin. It is then understood from the foregoing that the data processing device P1 will be the first to receive the item of common data present at address X in order to update it by adding a "1". Only after the updated item of common data has been returned to the memory and the lock register 51 of the data processing device P1 has been released in accordance with the command word stored at address W + 5, the data processing device can P 2 receives the updated item of common data from address X in order to subtract the number "2" from it according to the command word stored at address Z + 3 (see FIG. 4).
Kurz zusammengefaßt ist aus der vorhergehenden Beschreibung ersichtlich, daß in Übereinstimmung mit den Lehren der vorliegenden Erfindung eine Vielzahl von datenverarbeitenden Geräten Pl und P 2 so verriegelt sind, daß zu jeder beliebigen Zeit ein Posten gemeinsamer Daten, der in der Speichereinheit 20 enthalten ist, zu der jedes der datenverarbeitendeh Geräte Zugriff hat, nur von einem dieser datenverarbeitenden Geräte auf den neuesten Stand gebracht oder verarbeitet werden kann. Wenn ein datenverarbeitendes Gerät die gemeinsamen Daten benötigt, um mit ihnen ein Unterprogramm auszuführen, während ein anderes der datenverarbeitenden Geräte mit diesen gemeinsamen Daten arbeitet, wird dieses später gekommene datenverarbeitende Gerät daran gehindert, sein Unterprogramm fortzusetzen, bis das andere datenverarbeitende Gerät den auf den neuesten Stand gebrachten Posten gemeinsamer Daten wieder in die Speichereinheit zurückgebracht hat. Die Feststellung, welches der datenverarbeitenden Geräte einen Posten gemeinsamer Daten verarbeitet und auf den neuesten Stand bringt, wird dadurch ermöglicht, daß jedem Posten gemeinsamer Daten in einem Operationssystem eine Codezahl zugeordnet wird, die auf das datenverarbeitende Gerät übertragen und in dessen Sperr-Register gespeichert wird, bevor dieser Posten gemeinsamer Daten dem datenverarbeitenden Gerät zugeführt wird. Dann wird ein Vergleich vorgenommen, bei dem der Inhalt aller Sperr-Register verglichen wird, um sicher zu sein, daß keines der Sperr-Register der anderen datenverarbeitenden Geräte die interessierende Codezahl enthält, wodurch angezeigt wird, daß keines der anderen datenverarheitenden Geräte den Posten gemeinsamer Daten verarbeitet. Briefly summarized, it can be seen from the foregoing description that, in accordance with the teachings of the present invention, a plurality of data processing devices P1 and P 2 are interlocked so that at any one time an item of common data contained in memory unit 20 is closed which each of the data processing devices has access, can only be updated or processed by one of these data processing devices. If a data processing device needs the shared data to execute a subroutine with them while another of the data processing devices is working with this common data, this later data processing device is prevented from continuing its subroutine until the other data processing device is up to date Has brought back the item of common data that has been brought back into the storage unit. The determination of which of the data processing devices is processing an item of common data and brings it up to date is made possible by the fact that each item of common data in an operating system is assigned a code number which is transmitted to the data processing device and stored in its lock register before this item of common data is fed to the data processing device. A comparison is then made in which the contents of all lock registers are compared to be sure that none of the lock registers of the other data processing devices contain the code number of interest, thereby indicating that none of the other data processing devices have the item in common Data processed.
Zur Erläuterung eines NAND-Gatters, das in dem erfindungsgemäßen System verwendet werden kann, wird nun auf Fig. 10 hingewiesen. Mehrere Eingangsklemmen 210 und 212 sind über die Kathoden-Anoden-Strecken entsprechender Dioden 214 und 216 mit dem Leiter 220 verbunden, der wiederum über einen Widerstand 122 mit einer + 15-Volt-Klemme 224 verbunden ist. Der Leiter 220 ist außerdem über einen Widerstand 226 mit einem Leiter 228 und dieser Leiter über einen Widerstand 230 mit einer — 15-Volt-Klemme 232 verbunden. Der Leiter 228 ist auch mit der Basis eines NPN-Transistors 234 verbunden, dessen Emitter mit Masse undReference is now made to FIG. 10 to explain a NAND gate which can be used in the system according to the invention. Several input terminals 210 and 212 are connected via the cathode-anode paths of corresponding diodes 214 and 216 to the conductor 220 , which in turn is connected via a resistor 122 to a +15 volt terminal 224 . The conductor 220 is also connected to a conductor 228 via a resistor 226 and this conductor is connected to a -15 volt terminal 232 via a resistor 230 . Conductor 228 is also connected to the base of an NPN transistor 234 , the emitter of which is connected to ground and
as dessen Kollektor über einen Widerstand 236 mit einer + 5-Volt-Klemme 238 verbunden ist. Ein Kondensator 240 kann parallel zu dem Widerstand 226 geschaltet sein, um die Anstiegszeit des Transistors zu verkleinern, wenn er in den leitenden Zustand gesteuert wird. Eine Ausgangsklemme 242 des Gatters ist mit dem Kollektor des Transistors 234 verbunden.as whose collector is connected to a +5 volt terminal 238 via a resistor 236. A capacitor 240 may be connected in parallel with resistor 226 to decrease the rise time of the transistor when it is driven into the conductive state. An output terminal 242 of the gate is connected to the collector of transistor 234 .
Im Betrieb verursacht ein »falsch«-Signal vonDuring operation caused a "false" signal from
0 Volt, das entweder einer oder beiden Eingangs^ klemmen 210 und 212 zugeführt wird, einen Stromfluß von der Klemme 224 durch den Widerstand 222 und durch eine oder beide der Dioden, so daß der Transistor 234 in einem nichtleitenden Zustand gehalten wird. Daher liegt an der Ausgangsklemme 242 0 volts applied to either or both input terminals 210 and 212 causes current to flow from terminal 224 through resistor 222 and through one or both of the diodes so that transistor 234 is maintained in a non-conductive state. Therefore is at the output terminal 242
■ ein +5-VoIt- oder »wahr«-Signal. Wenn jedoch beide Eingangssignale, die den Eingangsklemmen 210 und 212 zugeführt werden, »wahr« sind oder 5VoIt haben, werden die Dioden 214 und 216 so vorgespannt, daß sie nicht mehr leiten, und es wird an der Basis des Transistors 234 eine positive Spannung aufrechterhalten. Der Transistor wird daher in den leitenden Zustand gesteuert, so daß im wesentlichen OVoIt oder ein »falsch«-Signal an der Ausgangsklemme 242 liegt. Das NAND-Gatter von Fig. 10 wirkt als UND-Gatter, weil es ein »falsch«- Ausgangssignal nur dann liefert, wenn alle Eingangssignale vom »falsch«-Pegel auf den »wahr«-Pegel überwechseln.■ a +5 VoIt or “true” signal. However, if both of the inputs to input terminals 210 and 212 are "true" or at 5VoIt, diodes 214 and 216 will be biased so that they will no longer conduct and a positive voltage will be maintained at the base of transistor 234 . The transistor is therefore switched to the conductive state, so that essentially OVoIt or a "false" signal is present at the output terminal 242 . The NAND gate of Fig. 10 acts as an AND gate because it provides a "false" output signal only when all input signals change from the "false" level to the "true" level.
Wenn die Signale an allen Eingangsklemmen normalerweise auf dem »wahr«-Pegel gehalten werden, um an der Ausgangsklemme 234 ein »falsch«-Signal zu erzeugen, wirkt das Gatter als ein ODER-Gatter, weil das Gatter an der Ausgangsklemme 242 ein ■ »wahr«-Signal liefert, wenn nur eines der Eingangssignale den »falsch«-Pegel annimmt. Wenn das Gatter als Negator für ein sich in positiver Richtung änderndes Eingangssignal wirkt, d. h., wenn die Ausgangsklemmc normalerweise auf dem »wahr«-Pegel ist, können alle nicht benutzten Eingangsklemmen des Gatters nach Fig. 10 an 4-5 Volt angeschlossen werden. Das Eingangssignal, das der einzigen aktiven Eingangsklemme zugeführt wird, verursacht dann, daß das Ausgangssignal an der Ausgangsklemme 242 »falsch« wird. Diese Operation des NAND-GattersIf the signals at all input terminals are normally held at the "true" level in order to generate a "false" signal at output terminal 234 , the gate acts as an OR gate because the gate at output terminal 242 has a ■ » delivers true "signal if only one of the input signals assumes the" false "level. If the gate acts as an inverter for an input signal changing in the positive direction, ie if the output terminal is normally at the "true" level, all unused input terminals of the gate according to FIG. 10 can be connected to 4-5 volts. The input signal applied to the only active input terminal then causes the output signal at output terminal 242 to be "false". This operation of the NAND gate
nach Fig. 10 ist derjenigen gleich, die es ausführt, wenn es als UND-Gatter arbeitet, abgesehen davon, daß beim Betreiben als Negator nur eine einzige der Eingangsklemmen als aktive Eingangsklemme verwendet wird.according to Fig. 10 is the same as that which executes it, if it works as an AND gate, apart from the fact that only one of the Input terminals is used as the active input terminal.
Wenn das NAND-Gatter nach Fig. 10 als Negator für ein sich in negativer Richtung änderndes Eingangssignal wirkt, wobei sein Ausgangssignal normalerweise »falsch« ist, werden alle nicht benutzten Eingangsklemmen an einen +5-Volt-Pegel angeschlossen, und die einzige aktive Eingangsklemme, die auf den »falsch«-Pegel übergeht, bewirkt, daß das Ausgangssignal »wahr« wird, was der Operation des Gatters ähnelt, wenn es als ODER-Gatter verwendet wird. Je nachdem, ob das Gatter nach F i g. 10 normalerweise ein »wahr«-Ausgangssignal oder ein »falsch«-Ausgangssignal hat, sind die in dem veranschaulichten System verwendeten Symbole dementsprechend die einer UND-Funktion (ein Gattersymbol mit einer geraden Eingangskante) oder die einer ODER-Funktion (ein Gattersymbol mit einer konkaven Eingangskante). Diejenigen NAND-Gatter, die als UND-Gatter arbeiten, sind außerdem durch den Buchstaben N mit dem Index A (NA) bezeichnet, während solche NAND-Gatter, die als ODER-Gatter arbeiten, durch den Buchstaben N mit dem Index O (N0) bezeichnet sind. Die NAND-Gatter, die als Negator arbeiten, .sind durch ein N mit dem Index 1(N1) bezeichnet. Es versteht sich, daß das NAND-Gatter nach Fig. 10 jede beliebige Anzahl von Eingangsklemmen aufweisen kann, obwohl in Fig. 10 nur_zwei Eingänge dargestellt sind. Ferner versteht es sich, daß das in Fig. 10 gezeigte Gatter nur zum Zwecke der Erklärung dargestellt ist und daß beliebige andere Gatter-Schaltungen verwendet werden können, die die UND-, ODER- und Negator-Funktionen ausführen können.When the NAND gate of FIG. 10 acts as an negator for an input signal changing in the negative direction, with its output signal normally being "false", all unused input terminals are connected to a +5 volt level, and the only active input terminal going to the "false" level causes the output to go "true", which is similar to the operation of the gate when used as an OR gate. Depending on whether the gate according to FIG. 10 normally has a "true" output or a "false" output, the symbols used in the illustrated system are accordingly those of an AND function (a gate symbol with a straight input edge) or an OR function (a gate symbol with a concave entrance edge). Those NAND gates that work as AND gates are also denoted by the letter N with the index A (N A ) , while those NAND gates that work as OR gates are denoted by the letter N with the index O ( N 0 ) are designated. The NAND gates, which work as inverters, are denoted by an N with the index 1 (N 1 ) . It is understood that the NAND gate of FIG. 10 can have any number of input terminals, although only two inputs are shown in FIG. Further, it should be understood that the gate shown in Figure 10 is shown for purposes of explanation only and that any other gate circuit capable of performing the AND, OR and invert functions may be used.
An Hand Fig. 11 wird nun ein Flipflop beschrieben, das in dem erfindungsgemäßen System verwendet werden kann. Es umfaßt zwei NAND-Gatter 246 und 248, die als ODER-Gatter arbeiten. Die Ausgangsklemme des Gatters 246 ist sowohl mit der »falsch«-Ausgangsklemme 249 des Flipflops als auch mit einer Eingangsklemme des Gatters 248 verbunden. Die Ausgangsklemme des Gatters 248 ist mit der »wahr«-Ausgangsklemme 250 des Flipflops .und außerdem mit einer Eingangsklemme des Gatters 246 verbunden. Das Umkippen der Gatter 246 und 248 wird durch NAND-Gatter 252 und 254 gesteuert, die als ODER-Gatter wirken und über je eine Verzögerungsleitung 256 bzw. 258 mit Eingangsklemmen der entsprechenden NAND-Gatter 246 und 248 verbunden sind. Die Ausgangsklemme des NAND-Gatters 252 ist durch die Leiter 259 und 260 mit einer Eingangsklemme des NAND-Gatters 254 verbunden. A flip-flop which can be used in the system according to the invention will now be described with reference to FIG. It comprises two NAND gates 246 and 248 which function as OR gates. The output terminal of gate 246 is connected both to the "false" output terminal 249 of the flip-flop and to an input terminal of gate 248 . The output terminal of the gate 248 is connected to the "true" output terminal 250 of the flip-flop and also to an input terminal of the gate 246 . The flipping of gates 246 and 248 is controlled by NAND gates 252 and 254 , which act as OR gates and are connected to input terminals of the corresponding NAND gates 246 and 248 via delay lines 256 and 258, respectively. The output terminal of NAND gate 252 is connected to an input terminal of NAND gate 254 by conductors 259 and 260 .
Den Gattern 252 und 254 werden an einer Klemme 262 Taktimpulse und an einer Klemme 264 Steuerimpulse C zugeführt. Die Informations-Eingangssignale / werden durch Leiter wie 266 und 268 dem Gatter 252 zugeführt. Um eine zeitliche Verschiebung zwischen deri Informationssignalen, die dem Leiter 260 zugeführt werden, und dem Taktsignal zu erzeugen, ist ein Kondensator 270 zwischen Erde und eine Eingangsklemme des Gatters 254 geschaltet. Nicht verwendete Eingangsklemmen des Gatters 252 sind an den »wahr«- oder konstanten + 5-Volt-Pegel angeschlossen.The gates 252 and 254 are supplied with clock pulses at a terminal 262 and control pulses C at a terminal 264. The information inputs / are provided to gate 252 through conductors such as 266 and 268 . A capacitor 270 is connected between ground and an input terminal of gate 254 in order to produce a time shift between the information signals fed to conductor 260 and the clock signal. Unused input terminals of gate 252 are tied to the "true" or constant +5 volt level.
Das Flipflop nach Fig. 11 wird mit Informations-Eingangssignalen / auf den Leitern wie 266 und 268 betrieben, die normalerweise »wahr« sind, so daß bei Vorliegen von Takt- und Steuersignalen das Signal auf dem Leiter 260 »falsch« ist. Die Informations-Eingangsleiter, wie z. B. 266 und 268, sind bei Fehlen einer Koinzidenz-Bedingung an (nicht gezeigten) NAND-Gattern, die damit gekoppelt sind, normalerweise auf dem »wahr«-Pegel. Das Signal aufThe flip-flop of Fig. 11 operates with informational input signals / on conductors such as 266 and 268 which are normally "true" so that when clock and control signals are present, the signal on conductor 260 is "false". The information input ladder, such as 266 and 268, in the absence of a coincidence condition on NAND gates (not shown) coupled to them, are normally at the "true" level. The signal on
ίο dem Leiter 259 ist immer »wahr«, ausgenommen zur Taktzeit, zu der es »falsch« wird, um das Flipflop in den »falsch«-Zustand einzustellen, wenn alle Informations-Eingangssignale und auch das Steuersignal oder der Steuereingangsimpuls »wahr« sind.ίο the conductor 259 is always "true", except at the clock time at which it becomes "false" in order to set the flip-flop to the "false" state when all information input signals and also the control signal or the control input pulse are "true" .
Wenn jedoch eines der Eingangssignale zur Taktzeit »falsch« ist, ist das Signal auf dem Leiter 259 »wahr«, und das Flipflop wird auf den »wahr«-Zustand eingestellt oder bleibt im »wahr«-Zustand.However, if any of the input signals is "false" at clock time, the signal on conductor 259 is "true" and the flip-flop is set to the "true" state or remains in the "true" state.
Wenn z. B. das Flipflop im »falsch«-Zustand istIf z. B. the flip-flop is in the "false" state
ao und ein »wahr«- oder +5-Volt-Pegel an der Klemme 249 aufweist, sind die Eingangssignale des Gatters 248 beide »wahr«, so daß dem Gatter 246 ein »falsch«-Signal von der Klemme 250 zusammen mit dem' normalerweise »wahr«-Signal auf dem Leiter 259 zugeführt wird. Wenn eins der Informations-Eingangssignale auf den Leitern wie 266 und 268 zur , Taktzeit »falsch« ist, bleibt das Signal auf dem Leiter 259 »wahr«. Infolgedessen wird von dem Gatter 254 ein »falsch«-Signal gebildet, so daß das Gatter 248 ein »wahr«-Ausgangssignal liefert. Das Gatter 246 bildet daher ein »falsch«-Signal, das das Gatter 248 veranlaßt, weiterhin ein »wahr«-Signal zu liefern. Das Signal auf dem Leiter 259 bleibt nach der Taktzeit »wahr«, so daß ein »falsch«-Ausgangssignal von dem Gatter 246 aufrechterhalten wird und ein »wahr«-Ausgangssignal durch das Gatter 248 aufrechterhalten wird, so daß sich eine stabile »Eins« oder der »eingestellte« Zustand des Flipflops ergibt. Das Flipflop arbeitet in gleicher Weise, wenn esao and a "true" or +5 volt level at terminal 249 , the input signals of gate 248 are both "true", so that gate 246 receives a "false" signal from terminal 250 together with the ' normally the "true" signal is supplied on conductor 259. If any of the information input signals on conductors such as 266 and 268 are "false" at clock time, the signal on conductor 259 will remain "true". As a result, a "false" signal is generated by gate 254 , so that gate 248 provides a "true" output signal. Gate 246 therefore forms a "false" signal which causes gate 248 to continue to deliver a "true" signal. The signal on conductor 259 remains "true" after the clock time, so a "false" output is maintained by gate 246 and a "true" output is maintained by gate 248 so that a stable "one" is maintained. or the "set" state of the flip-flop results. The flip-flop works the same way when it does
zuvor einen »wahr«-Zustand gespeichert hatte und die Informations- und Steuersignale zur Taktzeit alle »wahr« sind, um das Gatter 246 in einen Zustand zu bringen, in dem es ein positives oder »wahr«-Ausgangssignal liefert, was einer gespeicherten »Null« oder dem »gelöschten« Zustand entspricht. Die Verzögerungsleitungen 256 und 258 bewirken eine Verzögerung der Eingangssignale, so daß die Information in zuverlässiger Weise von den Klemmen 249 und 250 zu Beginn der Taktperiode abgefragt und eine neue Information während derselben Taktperiode in den Flipflop eingeschrieben werden kann. Es sei bemerkt, daß das Signal an der Steuereingangsklemme 264 zu der Taktzeit »wahr« sein muß, damit der Flipflop seinen Zustand ändert.had previously stored a "true" state and the information and control signals at the clock time are all "true" in order to bring the gate 246 into a state in which it supplies a positive or "true" output signal, which corresponds to a stored " Corresponds to zero "or the" deleted "state. The delay lines 256 and 258 cause a delay in the input signals, so that the information can be interrogated in a reliable manner from the terminals 249 and 250 at the beginning of the clock period and new information can be written into the flip-flop during the same clock period. It should be noted that the signal at control input terminal 264 must be "true" at clock time for the flip-flop to change state.
55' Wenn das Signal an der Steuereingangsklemme 264 zur Taktzeit »falsch« ist, verbleibt das Flipflop in seinem vorhergehenden Zustand gesperrt, weil das Signal auf dem Leiter 259 »wahr« bleibt und auch das Signal, das von dem Gatter 254 gebildet wird, auf dem »wahr«-Pegel bleibt. Wenn weiterhin das Signal an der Steuereingangsklemme 264 auf dem »wahr«-Pegel gehalten oder auf diesen Pegel gebracht wird, wird das Flipflop zur Taktzeit in den »falsch«-Zustand gebracht (gelöscht), wobei es als Vcrzögerungs-Flipflop wirkt, wenn alle Informations-Eingangssignale auf dem »wahr«-Pegel sind.55 'If the signal at control input terminal 264 is "false" at clock time, the flip-flop remains disabled in its previous state because the signal on conductor 259 remains "true" and so does the signal generated by gate 254 the "true" level remains. Further, when the signal is held, or at the control input terminal 264 on the "true" level brought to this level, the flip-flop at clock time in the "wrong" state is brought (deleted), where it acts as Vcrzögerungs flip-flop when all Information input signals are at the "true" level.
Hs wird jetzt auf Fig. 12 verwiesen,die ein Blockschaltbild einer der Gattcranordnungen zeigt, die,Reference is now made to Figure 12 which is a block diagram shows one of the Gattcran orders,
209643/ΊΠ209643 / ΊΠ
wie ζ. B. das in Fig. 6 gezeigte Gatter 101, das Komplement der exklusiven ODER-Funktion von zwei Eingangssignalen LOlA und LOlB liefern. Fig. 13 ist eine Funktionstabelle für die exklusive ODER-Funktion und deren Komplement zweier 'Eingangssignale. Die exklusive ODER-Funktion wird mit Θ bezeichnet, während ihr Komplement mit Θ bezeichnet wird. Wie aus Fig. 13 ersichtlich, ist das Ausgangssignal einer Gatterschaltung, die das Komplement einer exklusiven ODER-Funktion liefert, nur dann eine »Eins« oder »wahr«, wennihre beiden Eingangssignale gleich sind, d. h., wenn entweder beide Eingangssignale »Nullen« oder »falsch« sind oder wenn beide Eingangssignale »Einsen« oder »wahr« sind.like ζ. B. the gate 101 shown in Fig. 6, the complement of the exclusive OR function of two input signals LOlA and LOlB . Fig. 13 is a function table for the exclusive OR function and its complement of two input signals. The exclusive OR function is denoted by Θ , while its complement is denoted by Θ. As can be seen from Fig. 13, the output signal of a gate circuit which provides the complement of an exclusive OR function is only a "one" or "true" if its two input signals are the same, ie if either both input signals are "zeros" or Are "false" or if both input signals are "ones" or "true".
Bei der vorliegenden Erfindung ist das Eingangssignal LOIA der Gatterschaltung 101 das »wahr«- Ausgangssignal des Flipflops 81 des Sperr-Registers 51 des datenverarbeitenden Gerätes Pl, während das Ausgangssignal LOIB das Ausgangssignal des Flipflops 81 des Sperr-Registers 51 des datenverarbeitenden Gerätes P 2 ist. Das Eingangssignal LOIA wird direkt als ein Eingangssignal einem NAND-Gatter 301, das als ODER-Gatter wirkt, und einem NAND-Gatter 302, das als Negator arbeitet, zugeführt. Das Ausgangssignal des NAND-Gatters 302 wird als Eingangssignal einem NAND-Gatter 303 zugeführt, das als ODER-Gatter arbeitet. Entsprechend wird das Eingangssignal LOlS dem anderen Eingang des NAND-Gatters 303 und einem NAND-Gatter 304 zugeführt, das als Negator arbeitet und dessen Ausgangssignal als zweites Eingangssignal dem NAND-Gatter 301 zugeführt wird. Die Ausgänge der Gatter 301 und 303 sind an einem Punkt 305 miteinander verbunden, der durch eine Leitung 306 mit einem der Eingänge des NAND-Gatters 112 (Fig. 6) verbunden ist, das ein Teil der oben behandelten Vergleichsschaltung bildet.In the present invention, the input signal LOIA of the gate circuit 101 is the "true" output signal of the flip-flop 81 of the lock register 51 of the data processing device P1, while the output signal LOIB is the output signal of the flip-flop 81 of the lock register 51 of the data processing device P 2 . The input signal LOIA is fed directly as an input to a NAND gate 301 which acts as an OR gate and a NAND gate 302 which acts as an inverter. The output signal of the NAND gate 302 is fed as an input signal to a NAND gate 303, which operates as an OR gate. Correspondingly, the input signal LOIS is fed to the other input of the NAND gate 303 and to a NAND gate 304, which operates as an inverter and whose output signal is fed to the NAND gate 301 as a second input signal. The outputs of gates 301 and 303 are connected together at a point 305 which is connected by line 306 to one of the inputs of NAND gate 112 (FIG. 6) which forms part of the comparison circuit discussed above.
Aus dem Vorhergehenden ist ersichtlich, daß dann, wenn die beiden Signale LOIA und LOIB gleich sind, gleichgültig ob »wahr« oder »falsch«, durch die Negation der NAND-Gatter 302 und 304 ein Eingangssignal jedes der Gatter 301 und 303 »falsch« ist. Deshalb liefert jedes der Gatter 301 und 303 ein »wahr«-Ausgangssignal, so daß das Signal an dem Verbindungspunkt 305 »wahr« ist. Wenn jedoch LOlA von LOlB abweicht, sind die Eingangssignale eines der Gatter 301 oder 303 »wahr«, und deshalb ist das Ausgangssignal dieses Gatters »falsch«. Paher befindet sich der Punkt 305 auf dem »falseh«-Pegel, der dann dem NAND-Gatter 112 (F i g. 6) zugeführt wird und bewirkt, daß das Gatter 112 ein »wahr«-Ausgangssignal liefert, das anzeigt, daß wenigstens eines der Flipflops 81 bis 90 in dem Sperr-Register 51 ein Bit speichert, das von dem Bit abweicht, das in dem entsprechenden Flipflop des Sperr-Registers des anderen datenverarbeitenden Gerätes gespeichert ist. Nur wenn alle Eigenschaften des NAND-Gatters 112 (Fig. 6) »wahr« sind, liefert das Gatter ein »falsch«-Ausgangssignal, das anzeigt, daß der Code im Register 51 des einen datenverarbeitenden Gerätes einen positiven Vergleich mit dem Code liefert, der in dem Sperr-Register des anderen datenverarbeitenden Gerätes gespeichert ist.From the above it can be seen that if the two signals LOIA and LOIB are the same, regardless of whether "true" or "false", the negation of the NAND gates 302 and 304 results in an input signal of each of the gates 301 and 303 being "false" is. Therefore, each of gates 301 and 303 provides a "true" output so that the signal at junction 305 is "true". However, if LOIA differs from LOIB, the input of either gate 301 or 303 is "true" and therefore the output of that gate is "false". Thereafter, point 305 is at the "false" level which is then fed to NAND gate 112 (FIG. 6) and causes gate 112 to provide a "true" output indicating that at least one of the flip-flops 81 to 90 stores a bit in the lock register 51 which differs from the bit which is stored in the corresponding flip-flop of the lock register of the other data processing device. Only if all the properties of the NAND gate 112 (FIG. 6) are "true" does the gate supply a "false" output signal, which indicates that the code in register 51 of a data processing device supplies a positive comparison with the code, which is stored in the lock register of the other data processing device.
Kurz zusammengefaßt wird durch die Erfindung eine gesperrte datenverarbeitende Mehrfachanlage geschaffen, in der jedes datenverarbeitende Gerät zu einer gemeinsamen Speichereinheit Zugriff hat, um mit ihr zur Ausführung verschiedener Unterprogramme in Verbindung zu treten. Einige dieser Unterprogramme können Befehlsworte umfassen, wie z. B. die Worte, die an den Adressen W + 2 und Z + 2 (F i g. 3 und 4) gespeichert sind, die jedes datenverarbeitende Gerät veranlassen, auf sich einen Posten gemeinsamer Daten D, wie z. B. den an der Adresse X gespeicherten Posten, zu übertragen, um diesen Posten auf den neuesten Stand zu bringen.Briefly summarized, the invention creates a locked data-processing multiple system in which each data-processing device has access to a common memory unit in order to connect with it for the execution of various subroutines. Some of these subroutines may include command words such as B. the words that are stored at addresses W + 2 and Z + 2 (Fig. 3 and 4), which cause each data processing device to be an item of common data D, such as. B. the item stored at address X , to bring this item up to date.
ίο Um zu verhindern, daß mehr als ein datenverarbeitendes Gerät die gemeinsamen Daten D zur selben Zeit auf den neuesten Stand bringt, sind in jedem Unterprogramm zwei Befehlsworts enthalten, die . dem Befehl zur Übertragung der gemeinsamen Daten D auf das datenverarbeitende Gerät vorhergehen. Ein Wort befiehlt dem datenverarbeitenden Gerät, einen Code C0, der den Daten D zugeordnet ist, zu sperren, während das folgende Wort dem datenverarbeitenden Gerät befiehlt, auf die Adresse zurück-ίο In order to prevent more than one data processing device from bringing the common data D up to date at the same time, each subroutine contains two command words, the. precede the command to transfer the common data D to the data processing device. One word commands the data processing device to block a code C 0 , which is assigned to the data D , while the following word commands the data processing device to return to the address.
ao zuübertragen, an der der Code gespeichert ist. Diese Befehlsworte werden zusammen mit der Sperrschaltung in jedem datenverarbeitenden Gerät dazu verwendet, sicherzustellen, daß zu jeder beliebigen Zeit der Code C0 nur in dem Sperr-Register eines der datenverarbeitenden Geräte gesperrt werden kann, so daß nur dieses datenverarbeitende Gerät die Speichereinheit aufrufen, die gemeinsamen Daten D empfangen und sie als Teil der Ausführung seines Unterprogrammes auf den neuesten Stand bringen kann. Am Ende des Unterprogrammes werden die auf den neuesten Stand gebrachten gemeinsamen Daten wieder in ihrer Adresse gespeichert, und es wird das Sperr-Register gelöscht, um ein beliebiges anderes datenverarbeitendes Gerät zu befähigen, den Code C0 in seinem Speicher-Register zu sperren und im weiteren Verlauf die auf den neuesten Stand gebrachten gemeinsamen Daten zu empfangen und sein eigenes Unterprogramm zu vollenden.ao to be transmitted on which the code is stored. These command words are used together with the locking circuit in each data processing device to ensure that at any time the code C 0 can only be locked in the lock register of one of the data processing devices, so that only this data processing device call the memory unit receive common data D and update it as part of the execution of its subroutine. At the end of the subroutine, the updated common data are saved again in their address, and the lock register is cleared in order to enable any other data processing device to lock the code C 0 in its memory register and in the continue to receive the updated common data and complete its own subroutine.
Zur Erläuterung der Verbindung zwischen mehreren datenverarbeitenden Geräten, wie Pl und P 2 und der Speichereinheit 20, sei nun auf das vereinfachte Schaltbild nach F i g. 14 verwiesen. In dem dargestellten System umfaßt die Speichereinheit 20 zwei Speicherbänke 20^4 und 2OB, von denen jede ein Adressenregister 22, einen Speicher 21 und ein Datenregister 23 enthält. Die Buchstaben Λ und B sind jedem der Elemente der Bänke 2OA und 20 B sinngemäß zugeordnet. Zusätzlich enthält jede Bank eine Wählschaltung 24, eine Steuerschaltung 25 und eine Datenwählstufe 26. Die Funktion der letztgenannten Stufe besteht darin, das Datenregister 23 mit einer Vielzahl von Datenleitungen 351 bis 354 zu verbinden. Die Leitungen 351 und 352 werden zum Verbinden des datenverarbeitenden Gerätes Pl mit den Datenwählstufen verwendet. Die Leitung 351 dient dazu, Daten von dem datenverarbeitenden Gerät Pl über die Datenwählstufe 26 dem Datenregister 23 zuzuführen, damit sie im Speicher 21 gespeichert werden. So werden z. B. auf den neuesten Stand gebrachte Daten eines Postens gemeinsamer Daten auf den Speicher über die Leitung 351 übertragen. Andererseits wird die Leitung 352 zur Übertragung von Daten von dem Speicher auf das datenverarbeitende Gerät P1 verwendet. Entsprechend werden die Leitungen 353 und 354 dazu verwendet, um Daten von einem datenverarbeitenden Gerät P 2 zu empfangen und Daten auf dieses Gerät zu übertragen. Weiterhin werden die Leitungen 356 bis 359 dazu verwen-To explain the connection between several data processing devices, such as P1 and P 2 and the memory unit 20, refer to the simplified circuit diagram according to FIG. 14 referenced. In the illustrated system, the memory unit 20 comprises two memory banks 20 ^ 4 and 20B, each of which contains an address register 22, a memory 21 and a data register 23. The letters Λ and B are each of the elements of the banks 2OA and 20 B mutatis mutandis assigned. In addition, each bank contains a selection circuit 24, a control circuit 25 and a data selection stage 26. The function of the latter stage is to connect the data register 23 to a plurality of data lines 351 to 354. The lines 351 and 352 are used to connect the data processing device P1 to the data selection stages. The line 351 is used to feed data from the data processing device P1 via the data selection stage 26 to the data register 23 so that they are stored in the memory 21. So z. B. updated data of an item of common data is transferred to the memory via line 351. On the other hand, the line 352 is used to transfer data from the memory to the data processing device P1. Correspondingly, the lines 353 and 354 are used to receive data from a data processing device P 2 and to transmit data to this device. Lines 356 to 359 are also used for
27 2827 28
det, die datenverarbeitenden Geräte Pl und P 2 mit können. Auch die Leitungen 356 und 358, über diedet, the data processing devices Pl and P 2 with can. The lines 356 and 358, via the
der Wählschaltung 24 und dem Adressenregister 22 Signale den Wählschaltungen 24 zugeführt wurden,the selection circuit 24 and the address register 22 signals have been supplied to the selection circuits 24,
einer jeden der Speicherbänke 2<L4 und 20 B zu ver- können mehr als einen Leiter umfassen, so daß derof each of the memory banks 2 <L4 and 20 B can comprise more than one conductor, so that the
binden. Die Leitungen 356 und 357 werden dazu Wählschaltung ein oder mehrere Bits zugeführt wer-tie. Lines 356 and 357 will be supplied with one or more bits for this purpose.
verwendet, Signale von dem datenverarbeitenden 5 den können, um die aufgerufene Speicherbank zuused, signals from the data processing 5 den can to the called up memory bank
Gerät Pl zuzuführen, während die Leitungen 358 steuern. Zum Beispiel kann die Wählschaltung 24Feed device P1 while the lines 358 control. For example, the selection circuit 24
und 359 dazu verwendet werden, Signale von dem auf 1 oder 2 Bits eines vollständigen, 15 Bits um-and 359 can be used to convert signals from the to 1 or 2 bits of a complete 15 bit.
datenverarbeitenden Gerät P 2 zuzuführen. fassenden Adressenwortes ansprechen, um die spe-data processing device P 2 feed. address full address word in order to
Wie in F i g. 14 angegeben, wird eine Anforderung zielle Speicherbank, an die die Anforderung gerichtetAs in Fig. 14, a request becomes the target memory bank to which the request is directed
an den Speicher von Pl als Signal auf der Leitung io ist, auszuwählen. Zu diesem Zweck wird das Adres-to the memory of Pl as a signal on the line io is to be selected. For this purpose, the address
356 zugeführt, während der Speicherplatz oder die senregister der aufgerufenen Speicherbank angesteu-356 while the memory location or the sensor register of the memory bank called up is being
Adresse der Information, die von dem datenverar- ert. Die Datenwählstufe 26 jeder Speicherbank kannAddress of the information to be processed by the. The data selection stage 26 of each memory bank can
behenden Gerät Pl gewünscht wird oder die auf den eine Vielzahl von Gattern umfassen, die von deragile device Pl is desired or which on the comprise a variety of gates that of the
Speicher übertragen werden soll, auf Leitung 357 Steuerschaltung 25 in der Weise gesteuert werden,Memory is to be transferred, on line 357 control circuit 25 is controlled in such a way that
zugeführt wird. Die letzten Signale werden auch dem 15 daß Daten sowohl von jeder der Speicherbänke (2OA, is fed. The last signals are also sent to the 15 that data from each of the memory banks (2OA,
Adressenregister 22 zugeführt. In entsprechender 20B) auf jedes der datenverarbeitenden Geräte PlAddress register 22 supplied. In corresponding 20B) on each of the data processing devices Pl
Weise werden die Leitungen 358 und 359 dazu ver- und P 2 als auch von jedem der datenverarbeitendenLines 358 and 359 are supplied to this and P 2 as well as from each of the data processing units
wendet, die Signale von dem datenverarbeitenden Geräte auf jede der beiden Speicherbänke übertragenapplies, which transmit the signals from the data processing device to each of the two memory banks
Gerät P 2 zuzuführen, wobei die Signale auf der Lei- werden können.To feed device P 2, the signals on the line can be.
tung 358 eine Anforderung an den Speicher von dem ao Die speziellen Gatter-Anordnungen zum Steuernprocessing 358 a request to the memory from the ao The special gate arrangements for controlling
datenverarbeitenden Gerät P 2 anzeigen und die des Zugriffs einer Vielzahl von datenverarbeitendendisplay data processing device P 2 and the access of a variety of data processing
Signale auf der Leitung 359 die aufgerufene Adresse Geräten zu einer oder mehreren SpeicherbänkenSignals on line 359 the called devices address to one or more memory banks
bezeichnen. Die Wählschaltung ist mit der Steuer- werden nicht gezeigt, weil, wie. für den Fachmanndescribe. The selector circuit is with the control are not shown because how. for the professional
schaltung 25 verbunden, um den Zugriff zu der ersichtlich, die Ausführung dieser Anordnungen voncircuit 25 connected to provide access to the can be seen the implementation of these arrangements of
Speicherbank und die richtige Übertragung der In- 45 dem speziellen Verwendungszweck abhängt. Es ver-Memory bank and the correct transfer depends on the 45 specific purpose. It ver
formationen entweder von. dem datenverarbeitenden steht sich ebenfalls, daß eine beliebige der gegen-formations from either. the data processor is also aware that any of the opposing
Gerät auf den Speicher oder von dem Speicher auf wärtig bekannten Gatter- und SignalsteuertechnikenDevice to the memory or from the memory to currently known gate and signal control techniques
das datenverarbeitende Gerät zu steuern. verwendet werden kann, um die notwendigen Ver-to control the data processing device. can be used to provide the necessary
Die Datenleitungen 351 bis 354 und die Adressen- knüpfungen zu schaffen, damit eine Vielzahl vonThe data lines 351 to 354 and the address links are used to create a large number of
leitungen 357 und 359 umfassen eine Vielzahl von 30 datenverarbeitenden Geräten mit der SpeichereinheitLines 357 and 359 comprise a plurality of data processing devices with the memory unit
einzelnen Leitern, so daß mehrere Bit umfassende 20 verbunden werden kann, die, wie zuvor beschrie-individual conductors, so that 20 comprising several bits can be connected which, as previously described,
Wörter oder Daten sowie mehrere Bit umfassende ben, eine oder mehrere Speicherbänke enthaltenWords or data as well as multi-bit benches, one or more memory banks
Adressen über diese Leitungen zugeführt werden kann.Addresses can be fed through these lines.
Hierzu S Blatt ZeichnungenSee S sheet drawings
Claims (4)
Family
ID=
Similar Documents
Publication | Publication Date | Title |
---|---|---|
DE1524134B1 (en) | Data processing multiple system | |
DE2234867C2 (en) | Arrangement in a data processing system for controlling the processing of two mutually independent command sequences | |
DE3424962C2 (en) | ||
DE2130299A1 (en) | Input / output channel for data processing systems | |
DE1499200B2 (en) | DATA PROCESSING SYSTEM WITH PRIORITY CONTROLLED PROGRAM INTERRUPTION | |
DE2630323B2 (en) | Data storage device with a main memory, an auxiliary memory and a look-ahead logic | |
DE2062211A1 (en) | Storage arrangement with simultaneous access to n storage locations | |
DE2331589A1 (en) | DATA PROCESSING ARRANGEMENT | |
DE2023354A1 (en) | Programmable unit and method of operating a programmable unit | |
DE1774870C3 (en) | Device for addressing a memory cell of a memory in a data processing system | |
DE2039040A1 (en) | Device and method for transmitting data between a central data processing system and several remote data terminals | |
DE2647574C2 (en) | Device for processing data field segments of variable length, delimited by a start and end character, in a circular memory | |
DE2054830A1 (en) | Information processing system with word-structured memory and method for accessing such a memory | |
DE3900246C2 (en) | ||
DE1909477A1 (en) | Memory control system for a multi-program data processing system | |
DE1524111B2 (en) | Electronic data processing system | |
DE1524898B2 (en) | Data memory with direct multidimensional access for the simultaneous extraction of several words | |
DE2000066A1 (en) | Data processing arrangement | |
DE2233193A1 (en) | STACK STORAGE SYSTEM | |
DE1524134C (en) | Multiple data processing system | |
DE1935945A1 (en) | Overlap clock control for several memories and a common error correction device | |
DE2164718A1 (en) | Method and data processing system for controlling a large number of input / output units by means of a central unit | |
DE2217565A1 (en) | Control part of a computer that forms the relative base address of commands | |
DE1499286B2 (en) | DATA PROCESSING SYSTEM | |
DE2644180C3 (en) | Data processing system |