[go: up one dir, main page]

GB2078407A - Procedure and apparatus for inter processor data transfer in a multi processor system - Google Patents

Procedure and apparatus for inter processor data transfer in a multi processor system Download PDF

Info

Publication number
GB2078407A
GB2078407A GB8117915A GB8117915A GB2078407A GB 2078407 A GB2078407 A GB 2078407A GB 8117915 A GB8117915 A GB 8117915A GB 8117915 A GB8117915 A GB 8117915A GB 2078407 A GB2078407 A GB 2078407A
Authority
GB
United Kingdom
Prior art keywords
joint
memories
data
processor
procedure
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.)
Granted
Application number
GB8117915A
Other versions
GB2078407B (en
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Kone Corp
Original Assignee
Kone Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Kone Corp filed Critical Kone Corp
Publication of GB2078407A publication Critical patent/GB2078407A/en
Application granted granted Critical
Publication of GB2078407B publication Critical patent/GB2078407B/en
Expired legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • G06F15/163Interprocessor communication
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/36Handling requests for interconnection or transfer for access to common bus or bus system

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Multi Processors (AREA)

Abstract

Procedure and apparatus for transferring data between central units or processors in a multi-processor system, said system comprising one or several central units (3) with memories (4). The data to be transferred between central units (3) or processors are separated from their internal bus (6) by means of joint memories (2) and the data transfer between the joint memories (2) is effected by a separate copying means (1). <IMAGE>

Description

SPECIFICATION Procedure and apparatus for inter processor data transfer in a multi processor system The present invention concerns a procedure for transferring data between central units or processors in a multiple processor system comprising one or several central units with memories.
In multiprocessor systems most often two different techniques have been employed towards inter-processor data transfer: one is called the I/O technique and the second, the DMA technique. In the traditional I/O technique (Input/Output Technique) the processor reads the data sent by another processor one word or byte at a time and stores them in its memory, respectively reads one word or byte at a time from its memory and writes them to the other processor over a data transfer bus between them. Moreover, if the data transfer is fast, the writing processor must make sure that the reading processor has had time to read the preceding data before the next is written. This way of managing data transfer is comparatively slow owing to the fact that the processors have to perform several different operations in order to transfer one word or byte to the other.In addition, the use of the l/O technique slows down the execution of the processors' other programme because for the duration of said operations the execution of other programme has to be suspended, which furthermore necessitates extra processor state storings and returns. The I/O technique is usable only in data transfer events which are either slow or have a limited quantity.
The other way in which to manage interprocessor data transfer is the DMA (Direct Memory Access) technique, in which data are transferred from or to the processor's memory without any actual participation of the processor itself in the transfer event proper. This is most often implemented in that the processors participating in the transfer operation are stopped for the duration of the transfer event.
One avoids in this way the extra storing and recalling operations occurring in the I/O technique and, moreover, the transfer may be fast because it can be carried out by a logic circuit made exactly for this purpose. In other words, the logic does not e.g. read and record; instead, it directly stores the arriving data in the memory. This mode however requires a fairly complex logic circuitry and therefore this technique is expensive. Furthermore, if the need of data transfer is high, the logic circuit begins to slow down the operation of the processor because the interruption times increase in length or they are repeated at a higher frequency. The same occurs when there are several processors writing to or reading from the same memory, because transfer in this manner is usually only possible between two processors at any one time.By the DMA technique such constructions have also been carried out in which the interprocessor data transfer takes place over a joint memory. The system in this case includes a memory which can be written to by all processors and which can be ready by them, but this memory cannot be used but by one processor at the time, whence follows that any processor ~or the DMA technique at least-has to await the termination of data transfer by the other logic circuit or circuits or processor/processors. It is possible in this way to deduct part of the interruptions caused by the DMA in the interfacing of more than two processors, but it is still possible that waiting for the transfer event proper becomes necessary.
Other drawbacks of the DMA technique are its wide bus and the fast data transfer signals, which introduce a poor interference tolerance.
The DMA technique is usable when the requirement of data transfer is high and there are not many pieces of apparatus needing simultaneous data transfer.
The purpose of the procedure and apparatus of the invention is to eliminate the drawbacks mentioned and to provide a reliable and economical data transfer system in a multi-processor system.
The procedure of the invention is characterized in that the data to be transferred between central units are separated from the internal bus of these by joint memories and that the data transfer between the joint memories is carried out by a separate copying means. The advantage is then gained that the data are transferred between the central units memories without imposing any burden on the central units.
One favourable embodiment of the invention is characterized in that the copying means copies the writing block of each central unit simultaneously to all the others, into the equivalent block. The advantage is then that the synchronizing of the data processing processes carried out by the central units connected to these joint memories are facilitated because the copying means simultaneously updates the data in all joint memories.
Another favourable embodiment of the invention is characterized in that the copying means performs data transmitting without interruption while the system is in operation.
A third favourable embodiment of the invention is characterized in that the updating of data between the joint memories is carried out without in any way burdening the central units. The advantage is then that one central unit may have several jointmemory buses, and it is not burdened by them.
Still one favourable embodiment of the invention is characterized in that the data transfer between the joint memories is peformed in series mode 1 . . n bits in parallel.
Still one favourable embodiment of the invention is characterized in that the addressing of data in the copying event is performed between the joint memories by the aid of special address counters which are synchronized by the copying means. The advantage common to these two embodiments is that the joint memory bus may be kept narrow since no address data need be transferred therein.
Moreover, the narrow bus width and the permissible slowness thereof imply that the manufacturing costs of this bus may be lowered and the central units which will be connected thereto can be rather easily galvanically isolated, this expedient also reducing the manufacturing costs.
The invention also concerns an apparatus for carrying out the procedure mentioned. The apparatus comprises one or several central units with memories. The apparatus is characterized in that to the joint memory bus has been connected a copying means and for each central unit a joint memory, which has been connected by a local bus to the preceding central unit. The advantage is then that the joint memory bus does not improse any burden on the central units connected to it. It is a further advantage that the central units may carry out the normal writing and reading operations by means of the joint memories.
There is further the advantage of the low price of the apparatus.
In the following, the invention is described in greater detail with the aid of an example and with reference to the attached drawings, wherein: Figure 1 presents the principle of the invention in a block diagram.
Figure 2 shows the construction of the joint memory with its ancillary circuits, as a block diagram, and Figure 3 illustrates the memory copying event.
For the sake of clarity, the description of the invention has been confined to talk concerning data transfer between central units. However, all that is described here is also applicable e.g. to data transfer between the central units internal processors without substantially changing anything. For instance, when speaking of a "central unit", this word may be imagined replaced by "processor" as well, in the procedure of this invention. In the procedure of the invention is used a very simple processor which shall be termed the copying means (1) in the following, and which transfers the data between the joint memories (2).
The data transfer takes place along a joint memory bus (5). The connection from the joint memory bus (5) to the central units (3) has been established by mediation of each central unit's own so-called joint memory (2) and a local bus (6). The joint memory bus (5) is driven with a frequency so slow, and in synchronism with the central units (3), so that the use of the central unit's (3) joint memory (2) has no influence on the operation of the joint memory bus (5).Another, slightly more expensive way to make the operation of the central unit's (3) joint memory (2) such that it has no effect on the operation of the joint memory bus (5) is intercalating the operation of the joint memory bus (5) with regard to the timing of the central units (3) internal bus so that the joint memory bus (5) uses the joint memories (2) during those time intervals when the central units (3) cannot be active towards the joint memories (2). The joint memories (2) have furthermore been subdivided into a number of sections (A, B, C, . . N). The copying means (1) copies the writing memory of each central unit (3), shown as a shaded block in Fig. 3, to all others to the corresponding block, simultaneously.
The copying means (1) of the joint memory bus (5) is a clock generator which has been synchronized with the central units (3) to be connected to the joint memory bus (5) in such a way that there are time intervals during which no changes occur in the address bus (18) of any central unit (3) and during which the address changes of the joint memory bus (5) can be carried out. The central unit addresses the joint memory by the address bus (18). The copying means (1) generates to the joint memory bus (5) the following kinds of signals, at least: a clock pulse (7), by which the address counters (10) of all joint memories (2) increment, and a synchronizing pulse (8), with the aid of which all address counters (10) are checked once at least on every copying round.
The basis for the operation of the joint memory use is that each copying on the joint memory bus (5) takes place slowly enough to permit the central unit (3) in the middle of a copying event to read from or write to the joint memory (2) without this interfering with the operation of the joint memory bus (5+that is, the central unit (3) "steals" time from the joint memory (2), or the operation is intercalated, as described earlier already. The task of the address counter (10) is to operate in step with the clock pulse (7) from the copying means (1) and to count the address to a RAM type memory (12). Synchronisation is effected by means of a synchronizing signal (8). The unit (11) may be called the read/write selection unit. This is a logic unit performing the selection between the read and write blocks described and their timing.
The outgoing data holding unit (13) takes care that the data on the bus (5) remains unchanged in case the central unit (3) wants to use the RAM memory (12) while writing to the bus (5) is going on. It is also conceivable that one might to the circuit add an incoming data holding unit (15). The RAM unit has ports towards the bus (6) of the central unit (3) as well as to the joint memory bus (5). S he bus buffers (14) are circuits which adapt the RAM memory (12) and the joint memory bus (5) to be electrically compatible.
It is obvious to a person skilled in the art that the invention is not exclusively confined to the example presented above and that, instead, its embodiments may vary within the scope of the claims stated below.

Claims (9)

1. Procedure for transferring data between central units or processors in a multi-processor system, said system comprising one or several central units (3) with memories (4), characterized in that the data to be transferred between central units (3) or processors are separated from their internal bus (6) by means of joint memories (2) and that the data transfer between the joint memories (2) is effected by a separate copying means (1).
2. Procedure according to claim 1, characterized in that the copying means (1) copies the writing block of each central unit (3) or processor to all the others, to the same block, simultaneously.
3. Procedure according to claim 1 and 2, characterized in that the copying means (1) performs data transmission without interruption while the system is in operation.
4. Procedure according to claims 1-3, characterized in that updating of data between the joint memories (2) is carried out completely without burdening the central units (3) or the processors.
5. Procedure according to claims 1-4, characterized in that the data transfer between joint memories (2) is carried out in series form, 1 . . n bits in parallel.
6. Procedure according to claims 1-5, characterized in that the addressing of data in the copying event is carriedout between the joint memories (2) by means of separate address counters (10), which are synchronized by the copying means (1).
7. Apparatus for carrying out a procedure according to claim 1, comprising one or several central units (3) with memories (4), characterized in that to a joint memory bus (5) has been connected a copying means (1) and for each central unit (3) or processor one joint memory (2), which is by a local bus (6) further connected to the central unit (3) or the processor.
8. Procedure for transferring data between central units of processors in a multi-processor system, substantially as described herein.
9. Apparatus for carrying out the procedure as claimed in claim 1, substantially as described herein with reference to the accompanying drawing.
GB8117915A 1980-06-12 1981-06-11 Procedure and apparatus for interprocessor data transfer in a multiprocessor system Expired GB2078407B (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
FI801897A FI66995C (en) 1980-06-12 1980-06-12 OVER ANGLE CONNECTION FOR ATTACHMENT DATA MELLANPROCESSORER I ETT FLERPROCESSORSYSTEM

Publications (2)

Publication Number Publication Date
GB2078407A true GB2078407A (en) 1982-01-06
GB2078407B GB2078407B (en) 1984-11-14

Family

ID=8513563

Family Applications (1)

Application Number Title Priority Date Filing Date
GB8117915A Expired GB2078407B (en) 1980-06-12 1981-06-11 Procedure and apparatus for interprocessor data transfer in a multiprocessor system

Country Status (6)

Country Link
BE (1) BE889211A (en)
DE (1) DE3123382C2 (en)
FI (1) FI66995C (en)
FR (1) FR2484669B1 (en)
GB (1) GB2078407B (en)
HK (1) HK5890A (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2145255A (en) * 1983-07-19 1985-03-20 Telecommunications Sa Intercommunication of processors
GB2175421A (en) * 1985-05-13 1986-11-26 Singer Link Miles Ltd Computing system
GB2203571A (en) * 1986-11-08 1988-10-19 Trident Trade And Management S Data bank updating system
GB2348974A (en) * 1999-04-09 2000-10-18 Pixelfusion Ltd Data transfer controller with an array of processing elements
US7506136B2 (en) 1999-04-09 2009-03-17 Clearspeed Technology Plc Parallel data processing apparatus
US7526630B2 (en) 1999-04-09 2009-04-28 Clearspeed Technology, Plc Parallel data processing apparatus
US7627736B2 (en) 1999-04-09 2009-12-01 Clearspeed Technology Plc Thread manager to control an array of processing elements

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0076494B1 (en) * 1981-10-07 1988-08-24 Hitachi, Ltd. Data transmission bus system for a plurality of processors
DE3714429A1 (en) * 1987-04-30 1988-11-17 Bergwerksverband Gmbh Multiple microcomputer system for control systems
JP5285828B2 (en) 1999-04-09 2013-09-11 ラムバス・インコーポレーテッド Parallel data processor
US8762691B2 (en) 1999-04-09 2014-06-24 Rambus Inc. Memory access consolidation for SIMD processing elements using transaction identifiers
US8169440B2 (en) 1999-04-09 2012-05-01 Rambus Inc. Parallel data processing apparatus
US8174530B2 (en) 1999-04-09 2012-05-08 Rambus Inc. Parallel date processing apparatus
US8171263B2 (en) 1999-04-09 2012-05-01 Rambus Inc. Data processing apparatus comprising an array controller for separating an instruction stream processing instructions and data transfer instructions
US7966475B2 (en) 1999-04-09 2011-06-21 Rambus Inc. Parallel data processing apparatus
US7802079B2 (en) 1999-04-09 2010-09-21 Clearspeed Technology Limited Parallel data processing apparatus

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3753234A (en) * 1972-02-25 1973-08-14 Reliance Electric Co Multicomputer system with simultaneous data interchange between computers
DE2546202A1 (en) * 1975-10-15 1977-04-28 Siemens Ag COMPUTER SYSTEM OF SEVERAL INTERCONNECTED AND INTERACTING INDIVIDUAL COMPUTERS AND PROCEDURES FOR OPERATING THE COMPUTER SYSTEM
DE2641741C2 (en) * 1976-09-16 1986-01-16 Siemens AG, 1000 Berlin und 8000 München Computing system made up of several individual computers connected and interacting with one another via a manifold system and a control computer

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2145255A (en) * 1983-07-19 1985-03-20 Telecommunications Sa Intercommunication of processors
US4719562A (en) * 1983-07-19 1988-01-12 Sat Societe Anonyme De Telecommunications Multiprocessor system for intercommunication of processors
GB2175421A (en) * 1985-05-13 1986-11-26 Singer Link Miles Ltd Computing system
GB2175421B (en) * 1985-05-13 1989-11-29 Singer Link Miles Ltd Computing system
US5017141A (en) * 1985-05-13 1991-05-21 Relf Richard S Computing system
GB2203571A (en) * 1986-11-08 1988-10-19 Trident Trade And Management S Data bank updating system
GB2203571B (en) * 1986-11-08 1990-07-25 Trident Trade And Management S Data bank update system
GB2348974A (en) * 1999-04-09 2000-10-18 Pixelfusion Ltd Data transfer controller with an array of processing elements
GB2348974B (en) * 1999-04-09 2004-05-12 Pixelfusion Ltd Parallel data processing systems
US7506136B2 (en) 1999-04-09 2009-03-17 Clearspeed Technology Plc Parallel data processing apparatus
US7526630B2 (en) 1999-04-09 2009-04-28 Clearspeed Technology, Plc Parallel data processing apparatus
US7627736B2 (en) 1999-04-09 2009-12-01 Clearspeed Technology Plc Thread manager to control an array of processing elements

Also Published As

Publication number Publication date
FI801897A (en) 1981-12-13
DE3123382A1 (en) 1982-08-19
FI66995C (en) 1984-12-10
HK5890A (en) 1990-02-02
DE3123382C2 (en) 1995-04-06
FR2484669A1 (en) 1981-12-18
FI66995B (en) 1984-08-31
GB2078407B (en) 1984-11-14
BE889211A (en) 1981-10-01
FR2484669B1 (en) 1988-04-15

Similar Documents

Publication Publication Date Title
GB2078407A (en) Procedure and apparatus for inter processor data transfer in a multi processor system
US4539636A (en) Apparatus for inter-processor data transfer in a multi-processor system
JPH0232656B2 (en)
US4583167A (en) Procedure and apparatus for conveying external and output data to a processor system
GB2080582A (en) Procedure and apparatus for conveying external input and output data to a processor system
EP0122684B1 (en) Electronic switching system
JPH0715670B2 (en) Data processing device
JPH03177953A (en) Data transfer system
JPH024021B2 (en)
JPH02132543A (en) Information processor
RU1807495C (en) Process-to-process interface
JPS57196334A (en) Memory interface
US6295477B1 (en) Bus coupler between a system bus and a local bus in a multiple processor data processing system
RU2022345C1 (en) Interfaces matching device
SU1118997A1 (en) Information exchange device
SU1179351A1 (en) Interface for linking computer with peripheral units
SU1709325A1 (en) Processor-to-processor interface
JPS5983235A (en) Interface system between processors
RU1835551C (en) Data processor
SU1242970A1 (en) Interface for linking computer with bus
JPS60123956A (en) Memory writing device
JPH02211571A (en) Information processor
JPS63201810A (en) Time system for information processing system
WO1989003565A1 (en) Selective receiver for each processor in a multiple processor system
JPS62108351A (en) Common memory access system

Legal Events

Date Code Title Description
732 Registration of transactions, instruments or events in the register (sect. 32/1977)
PCNP Patent ceased through non-payment of renewal fee

Effective date: 19960611