GB2216310A - Data processing apparatus - Google Patents
Data processing apparatus Download PDFInfo
- Publication number
- GB2216310A GB2216310A GB8906978A GB8906978A GB2216310A GB 2216310 A GB2216310 A GB 2216310A GB 8906978 A GB8906978 A GB 8906978A GB 8906978 A GB8906978 A GB 8906978A GB 2216310 A GB2216310 A GB 2216310A
- Authority
- GB
- United Kingdom
- Prior art keywords
- program
- processors
- memory
- supplied
- signal
- 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
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/22—Microcontrol or microprogram arrangements
- G06F9/24—Loading of the microprogram
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Multi Processors (AREA)
Abstract
In an apparatus including a large number of processors to be driven by respective microprograms, the microprograms being provided in random access memories (RAMs) 11-14, apparatus is provided for transferring the microprograms from a host computer to the RAMs. The apparatus comprises a memory 41 in which the microprograms are stored, and each microprogram supplied from the host computer is formed of pieces of data each with an address attached thereto, the piece of data and the address are separated in the microprogram being supplied, the data are written in the memory 41 according to the separated addresses, and the memory 41 is read and the data are transferred to the RAM as required. <IMAGE>
Description
DATA PROCESSING APPARATUS
This invention relates to data processing apparatus.
A proposed information processing apparatus, for example, a video image processing apparatus (such as that disclosed in the Transactions of the
Institute of Electronics and Communication Engineers of Japan 85/4, Vol.
J68-D No 4, and Japanese laid-open patent specification no 58/215813) is provided with a plurality of processors, and microprograms forming the contents of microprogram memories therein are arranged to be exchanged when the extent of the processing is to be increased. In such a case, the microprograms are supplied from a program supplying portion which in general is formed of a host computer for each of the processors, and it is arranged, for example, that the microprograms are exchanged on request of a user effecting operation of a switch.
When a plurality of short programs are to be sequentially executed by a processor, it is usual for the programs to be sent one by one to the processor each time the preceding program has been executed.
If there are a plurality of data processors and different programs are to be transferred to the plurality of processors, it is usual for the processor to which a program is to be transferred to be selected for each program to be transferred.
When such a transfer system is used with a plurality of short programs which are to be sequentially sent to a processor for execution, the transfers have to be repeated the same number of times as the number of the programs, and a large portion of the potential processing time is occupied in the transferring, so the overall processing speed is considerably reduced.
Moreover, where a plurality of different programs are to be transferred to a plurality of processors, and the processors are to be selected for each program to be transferred, it is necessary to provide an arrangement to control selection of the processors, and so the circuit becomes rather complex.
According to the present invention there is provided in an apparatus including a large number of processors to be driven by respective microprograms, said microprograms being provided in random access memories (RAMs), apparatus for transferring said microprograms from a host computer to said RAMs, said transfer apparatus comprising: a memory in which said microprograms are stored; and wherein: said microprograms supplied from said host computer are formed of pieces of data each with an address attached thereto; said piece of data and said address are separated in each said microprogram being supplied; said data are written in said memory according to said separated addresses; and said memory is read and said data are transferred to said RAM as required.
The invention will now be described by way of example with reference to the accompanying drawings, throughout which like parts are referred to by like references, and in which:
Figure 1 is a block diagram of the whole of an image processing apparatus in which an embodiment of data processing apparatus according to the present invention is used;
Figure 2 is a block diagram showing an example of the main portion of the image processing apparatus of Figure 1;
Figure 3 is a circuit diagram showing an example of a portion of
Figure 2;
Figure 4 is a flow chart of mode control;
Figures 5 and 6 are block diagrams showing examples of the main portion of the image processing apparatus of Figure 1;
Figure 7 is a block diagram showing another example of the main portion of the image processing apparatus of Figure 1;;
Figure 8 is a timing chart showing operations of the arrangement of
Figure 7;
Figure 9 is a flow chart showing a diagnosis circuit as indicated in
Figure 6;
Figure 10 is a circuit diagram showing another example of the main portion of the image processing apparatus of Figure 1;
Figure 11 is a diagram indicating the contents of a memory shown in
Figure 10;
Figures 12 and 13 are block diagrams showing other examples of the main portion of the image processing apparatus of Figure 1;
Figure 14 is a drawing showing an example of a program to be transferred by the arrangement of Figure 13; and
Figures 15 and 16 are block diagrams showing other examples of the main portion of the image processing apparatus of Figure 1.
An embodiment of the present invention for use in a video image processing system will now be described with reference to the accompanying drawings.
The example of a video image processing apparatus as shown in
Figure 1 is provided for achieving high-speed data processing, and comprises an input/output portion (IOC) 1, a memory portion (VIM) 2 comprising an input image memory (VIMIN) 2A and an output image memory (VIMOUT) 28, a data processing portion 3 comprising a position stationary processor system (PIP) 3A chiefly for calculating picture element values and a position variant processor system (PVP) 3B for controlling data flows such as controlling of addresses and for adjusting processes to coincide in time, and a processor (TC) 4 forming a total controller for controlling execution and stopping of processes and exchange of programs. The TC 4 is provided with a host computer (HC) 5 for controlling the entire video image processing apparatus.
The IOC 1 effects analogue-to-digital (A/D) conversion of video signals coming from a video camera or a video tape recorder (VTR), for example, to provide digital image data and writes the converted data in the
VIMIN 2A, and also, reads out processed image data from the VIMCUT 28 and effects digital-to-analogue (D/A) conversion of the read out data to restore analogue video signals, so that they may, for example, be recorded in a VTR 7 or supplied to a monitor receiver 8 for monitoring of the video image.
In the present case, the video signals are of the NTSC system or the
R-G-B system, and either of these systems is specified by the TC 4. A picture element is represented, for example, by an 8-bit data word.
The writing and reading of image data in and out of the VIM 2 is performed in blocks of a field or a frame. Therefore, each of the VIMIN 2A and the VIMOUT 28 is made up of a plurality of memory planes (or sheets), each having capacity for the image data of a field or a frame, for example, twelve planes of 768 x 512 bytes of frame memories. In the case of the present example, the use of these twelve planes of frame memories is not fixed but can be flexibly allotted to either of the VIMIN 2A and the
VIMOUT 2B according to the purpose of the processing or the picture image forming the object of the processing.Moreover, the memory is arranged such that two planes are used as one set, namely, when one plane is enabled for writing, the other plane is enabled for reading, whereby it is possible for processing from outside the VIM 2 by the IOC 1 and processing within the
VIM 2 by the PIP 3A and the PVP 38 to be performed in parallel.
The control mode signal determining whether the plurality of planes of frame memories of the VIM 2 should come under the control of the IOC 1 or under the control of the PVP 3B is issued from the IOC 1 and supplied to the VIM 2.
The data processing portion 3 comprises a processor which reads image data stored in the VIMIN 2A according to its program, processes the data various ways, and writes the processed data in the VIMOUT 2B.
The data processing portion 3 is made up of separated systems of the
PIP 3A and the PVP 38, and by virtue of such separated arrangement, the processing time used in the data processing portion is determined only by whichever is longer of the processing times taken by both the systems, while previously it has been determined by the sum of the processing times in the data processing portion. Therefore, in the present example, high-speed processing for real time processing of video data can be achieved.
The processor of the data processing portion 3 is made up of one plane or a plurality of planes of processors, and the microprograms forming the contents of their microprogram memories are arranged to be exchanged when the extent of the processing is to be increased.
The program exchange is carried out in this way: the microprograms are supplied from the HC 5 to the TC 4 in advance and stored, for example, in a random access memory (RAM) provided therein, and thereafter, when, for example, the user has made a request for exchanging some programs (by turning a switch on), the TC 4 supplies the programs to each of the processors.
The PIP 3A and the PVP 38 are basically of the same architecture, being an independent processor comprising a control unit, an arithmetic unit, a memory unit, and an input/output port. Each thereof is arranged in a multiprocessor structure made up of a plurality of unit processors and high speed processing is achieved chiefly by adoption of a parallel processing system.
The PIP 3A comprises, for example, sixty planes of PIP processors and several planes of sub-processors, and it processes image data coming from the VIM 2 or generates image data within the PIP 3A itself.
The PVP 38 comprises, for example, thirty planes or so of processors, and-controls flows of image data inward of the VIM 2 such as allotment of the picture element data to the PIP 3A or collection.
Thus, the PVP 38 generates address data and control signals for the
VIM 2 and supplies these to the VIM 2, and also generates input/output control signals and other control signals for the PIP 3A and supplies these to the PIP 3A.
The image data processing is not always conducted in such a manner that the data from the plane of a frame of the VIMIN 2A are processed and the processed data are written in the VIMOUT 28, but sometimes such data coming from a plurality of planes of the frame memories and extending over a plurality of planes of the frames are processed.
The number of digits for arithmetic processing in the PIP 3A and
PVP 38 is 16-bit as a standard, and the processing speed achievable in the arithmetic processing of image data is such that image data of one frame can be processed within one frame, namely, real-time processing. There are also processes that require longer processing time than one frame.
In the present case, the image data processing by the PIP 3A and
PVP 38 is performed in synchronism with the frame. Therefore, a process start timing signal PS in synchronism with the frame is supplied from the IOC 1 to the PVP 38. The signal PS is usually at a high level and it is brought to a low level at the processing start timing. A signal OK indicating that processing has been finished is supplied from the PVP 38 to the IOC 1.
The end signal OK is supplied from a processor at the core of the PVP 38, the processor performing timing control of the processors of the processing system in the processors of the PVP 38, when a process has been finished.
The process start timing signal PS is generated in the ICC 1 based on a frame start signal indicating the first line of each frame and the end signal
OK.
When the processing is performed on a real time basis, since the end signal OK is always obtained at the end of each frame, the signal PS becomes the same signal as the frame start signal FL.
On the other hand, when the processing time is longer than one frame, the signal PS does not coincide with the frame period but is obtained at the start of a frame after an end signal OK has been supplied.
When it is detected by the processor at the core of the PVP 3B that the process start timing signal PS from the IOC 1 has been brought to the low level, this processor starts to run, and, according to a program, supplies timing signals to other processors (inclusive of the PIP 3A), supplies addresses to the VIM 2, reads the image data from the VIM 2, allows the image data to be processed in the PIP 3A, and when the processing has been finished, supplies the end signal OK and stops, waiting for issuance of the next process start timing signal PS.
In this case, only the image signal portion, excluding the synchronizing signal or burst signal, is taken as the object of processing, and the data read out from the VIM 2 does not include the synchronizing signal and the burst signal. Therefore, the IOC 1 is provided with a ROM generating the synchronizing signal, the burst signal, and the vertical blanking signal, and in the case of an NTSC signal, the data from the
VIMOUT 28 (after being rearranged, if necessary) are transferred to the
D/A converter together with the synchronizing signal, thevburst signal, and the vertical blanking signal.
Also, in the case of the three primary colour (R-G-B) signal system, an outer synchronizing signal becomes necessary. This signal is also generated in the IOC 1 and supplied to the monitor and elsewhere.
In the above parallel processing system using multiprocessors, the
TC 4 effects control in three modes, and thereby, execution of processes, stopping and program transfer (exchange) are carried out consistently, and also, the transfer and execution are effectively carried out using a slow clock signal and a fast clock signal at the times of the program transfer and the program execution, respectively.
Figure 2 shows connections between the control unit of one of the plurality of processors which form the PIP 3A or the PVP 38 and the TC 4, and the structure is common to all of the processors of which programs are exchanged. That is, the portion other than the TC 4 shows an example of the structure of the control unit of the processor. A microprogram controller 10 generates addresses of microprogram memories 11 to 14 formed of RAMs.
The microprogram memory 11 provides an instruction, for example, of four bits for selecting one from a plurality of instructions in the microprogram controller 10, and the instruction is supplied to the instruction terminal I of the controller 10 through a register 15. In the present case, the controller 10 has sixteen kinds of instructions.
A selector 16 is supplied with a plurality of pieces of desired 1-bit information, and one of these is selected according to information read out from the microprogram memory 12. The 1-bit information from the selector 16 is supplied to the terminal CC of the microprogram controller 10 as a condition code, which is combined with the instruction bit and serves as information for enabling the next address to be selected as the last one advanced by one increment, or the address supplied at the direct input terminal D, or another address.
The microprogram memory 13 provides, for example, information about the address of the destination of a "GO TO statement", the number of times of repetition of a DO loop, or the like, and the information is latched by a register 17a.
The microprogram memory 14 provides information about the microinstructions and the information is also supplied to the arithmetic unit of this processor through a register 18.
There is also provided a predetermined code generator 25 for supplying a predetermined code which has been established by the designer, and the predetermined code from the predetermined code generator 25 is supplied through a register 26 to the arithmetic unit by way of the bus used in common with the microinstructions from the microprogram memory 14.
The microprogram controller 10 is arranged to enable one of three enable signals PL, VECT and MAP, according to the instruction bit. Hence, one of registers 17a to 17c is enabled according to the instruction bit, and the address which has been latched by that register 17a to 17c becomes the direct input. The signal PL is enabled by most of the instructions, while the signals VECT and MAP are enabled only by special instructions. For a given state of that instruction bit, whether the direct input is chosen or not is dependent on the condition code from the selector 16.
The microprogram controller 10 is so arranged that, when the 4-bit instruction from the register 15 is 0000 , which represents an instruction
JUMP ZERO, the address zero as the start address is always supplied from the microprogram controller 10 regardless of the condition code.
The TC 4 includes a RAM 41 in which the programs to be supplied to the microprogram memories 11 to 14 are stored and an address generator 42 for the same.
There is also provided a mode signal generator 43 for generating 2-bit mode signals MA and MB to effect three modes; execution mode, reset (stop) mode and program exchange mode, as well as a write signal generator 44 for generating a program write signal for the microprogram memories 11 to 14 in the program exchange mode.
The mode signal generator 43 is formed, for example, as shown in
Figure 3.
Switches SWA and SWB are switches to be changed by the user, one terminal A being supplied with a positive DC voltage and the other terminal
B being earthed. A signal a obtained at the switch SWA is supplied to one input terminal of an OR gate 45. A signal b obtained at the switch SWB is, on the one hand, led out as the mode signal M8 and, on the other hand, supplied to the other input terminal of the OR gate 45. The mode signal MA is derived from the OR gate 45.
In this case, the modes are established as shown below from the 2-bit mode signals MA and MB:
Table 1
MA = O MB = 0 program transfer mode
MA =1 MB = 0 reset (stop) mode
MA = 1 MB = 1 execution mode
That is when the switch SWB engages the terminal A, the mode is set to the execution mode regardless of the state of the switch SWA, when the switch SWA engages the terminal A and the switch SWB engages the terminal B, the mode is set to the reset mode, and when the switch SWB engages the terminal B and the switch SWA also engages the terminal B, the mode is set to the program exchange mode.
As apparent from Table 1, execution of the program is stopped when the signal My is turned to "0", and the program becomes executable when the signal is turned to "1", and so the mode signal MB is understood to mean a reset (stop) signal.
When the signal MA is turned to "0", exchange of program becomes possible. Therefore, the mode signal is understood to mean a change signal.
By these two mode signals MA and MB, each of the modes are effected in the following manner.
That is, the selector 20 selects the address for the microprogram memories 11 to 14 from the address from the microprogram controller 10 and the address from the TC 4. As the select signal therefor, the signal MA is supplied, and the address from the microprogram controller 10 is selected when the signal MA is "1", and the address from the TC 4 is selected when the signal MA is "0".
An OR gate 21 gates a write signal WR according to the signal MA as the gate signal. Namely, the gate circuit 21 is open when the gate signal
MA is "0" and the signal WR is supplied to each of the write enable terminals WE of the microprogram memories 11 to 14. The microprogram memories 11 to 14 are brought to a write enabled state when "0" is supplied to their write enable terminals WE. Moreover, the signal MB is supplied to the reset terminal of the register 15, and when it is "0", the register 15 is reset.
The TC 4 is provided with a clock generator 46 of a fast clock signal
CKF at 7.16 MHz (twice as high as the colour sub-carrier frequency of an
NTSC colour signal) as well as a clock generator 47 of a slow clock signal
CKS at 2 MHz.
The fast clock signal CKF used at the time of program execution is supplied to the microprogram controller 10 and the registers 15 and 18, and further to the clock terminals of the registers 17a and 17b. The clock CKF is also supplied to the clock terminal of a register 19 through a buffer 22.
The slow clock signal CKS used at the time of program transfer is supplied as the clock signal to a load control unit 48 within the TC 4 as well as to the address generator 42 and elsewhere, and it is also supplied to the clock terminal of the register 19 via a buffer 23.
The mode signal MA is supplied as it is to the output enable terminal of the buffer 23 and is also supplied through an inverter 24 to the output enable terminal of the buffer 22, whereby, as also discussed later, the output of the buffer 22 is made effective at the time of execution of a program, and the fast clock signal CKF is supplied to the register 19, while the output of the buffer 23 is made effective at the time of transfer of a program and the slow clock signal CKS is supplied to the register 19.
The load control unit 48 within the TC 4 supervises the states of the mode signals MA and MB, and controls the processing in the TC 4 according to each mode.
In the program execution mode, the mode signal MA is "1", and so the selector 20 provides the addresses changing with the fast clock signal CKF from the microprogram controller 10, and these addresses are supplied to each of the microprogram memories 11 to 14 through the register 19 with a timing delayed by one clock. At this time, since the mode signal MA is "1", the buffer 22 is effective and the clock signal of the register 19 is the fast clock signal CKF.
Since the signal MA is "1", the output of the OR gate 21 is kept on at the "1" level and the memories 11 to 14 do not become write enabled.
Moreover, since the mode signal MB is "1", the register 15 is not reset, and so, the data read out from the microprogram memory 11 is delayed by one clock of the clock signal CKF in the register 15, and supplied to the instruction terminal of the microprogram controller 10 whereby the program is executed.
At this time, since the mode signal MA is "1", the register 18 to which the signal MA is supplied through an inverter 27 is rendered output enabled, while the register 26 is disabled, and so the microinstruction read out from the microprogram memory 14 is delayed by one clock of the clock signal CKF in the register 18 and is supplied to the arithmetic unit.
In the present execution mode, while the program is executed with the fast clock signal CKF, there are provided pipeline or serial registers, namely, the register 19 between the microprogram controller 10 and the microprogram memories 11 to 14, as well as the registers 15 and 17a and a register (not shown) at the input of the selector 16 between their respective output sides of the microprogram memories 11, 13 and 13 and the microprogram controller 10. In this way the clock cycle can be shortened.
That is, in the image processing apparatus of the present example, a parallel processing system using multiprocessors is primarily employed, but a pipeline processing system is also employed in some portions as mentioned above to achieve higher speed processing.
In the program transfer mode, the mode signal MB is "0", and so the register 15 is reset and 0000 is supplied to the instruction terminal of the microprogram controller 10. Hence, the microprogram controller 10 supplies the zero address continuously and is stopped. That is, the program addresses for all the processing systems processors, the PIP 3A and PVP 38, are "0" and they are in the program stopped state.
Since the mode signal MA is also "0", the selector 20 is brought to the condition to select the address from the address generator 42 of the TC 4.
Since the output of the buffer 22 is made invalid and that of the buffer 23 is made valid, the clock of the register 19 becomes the slow clock signal CKS.
In this program transfer mode, all the microprogram memories of all the processors are completely controlled by the TC 4, and hence, the clock signal becomes the slow clock signal CKS.
Since the mode signal MA is "0", the register 26 is rendered enabled and the register 18 is rendered disabled, and so the predetermined code from the predetermined code generator 25 is supplied to the arithmetic unit.
In the present case, it is also practicable to arrange that the signal
MA is supplied to the output enable terminal OE of the microprogram controller 10 and the output buffer of the microprogram controller 10 is thereby turned off.
In this program transfer mode, addresses are supplied from the address generator 42 to the RAM 41 under instruction from the load control unit 48 in accordance with the program for program transfer of the TC 4, and the program data to be sent to the microprogram memories 11 to 14 are read out from the RAM 41 at the rate of the clock CKS. At the same time, the write signal WR from the write signal generator 44 becomes "0", and since the mode signal MA is "0", the output of the OR gate 21 also becomes "0", and therefore, the microprogram memories 11 to 14 are brought to a write enabled state.
Thus, according to the addresses from the address generator 42, the program data from the RAM 41 are sequentially written in the microprogram memories 11 to 14 and the program transfer is carried out.
In the present example, the program transfer is made to each, one at a time, of a plurality of processors.
That is, the TC 4 is provided with a ROM 49 in which a processor select signal is stored. At the time of program transfer, the processor select signal is read out from the ROM 49 under instruction from the load control unit 48. The processor select signal is decoded in a decoder 50, whereby only the select signal SEL for the select processor becomes "0" and the others become "1". This select signal SE is supplied to the OR gate 21, and only the microprogram memories 11 to 14 of the processor in which the select signal SEL is "0" are rendered write enabled and the program is rewritten therein.
When rewriting in the microprogram memories of one processor is finished, the ROM 49 supplies the processor select signal of the next processor, whereby the select signal SEL to that processor becomes "0" and the program transfer to this processor is carried out in the same way as described above. f the programs of all of the processors have to be exchanged, the above procedure is repeated the same number of times as the number of the processors. o
Now, it is possible to arrange that specific data other than the processor select signals are stored at a specific address in the ROM 49, and in the case where the program is not to be transferred to all of the processors, but is to be transferred to a few of them, the specific data at the specific address are read out under instruction from the load control unit 48 to be given when the transfer to the few processors have been finished, namely, when the program transfer to the sequentially designated processors covering all of them to which the program had to be transferred has been finished. This output from the ROM 49 may be supplied to a detector circuit 52 for detecting the specific data.Thus, it can be arranged such that, when the specific data are read out from the ROM 49, this is detected by the detector circuit 52, and the detection signal is supplied to the load control unit 48 to stop the program load.
As the specific data, data of the processor select signal of which all bits are "1" may be used, in which case, the specific detector circuit 52 may be formed of an AND gate.
It is also practicable to include signals other than those which it is essential to send to each of the processors. Such signals may be program contents, addresses thereof, and different parameters for each of the processors, in the specific data and make use of such specific data.
Then, if the programs to be sent to each of the processors are more than one, or the programs to be sent to each of the processors are more than one and different from each other, these programs together may be considered to be one program and written in each processor. Designation of the program to be executed in the next place by each processor may be given by providing each processor with the relevant execution start address.
The execution start addresses are supplied from the RAM 51 to the register 17c of each processor. As the latch signal for the register 17c, the above mentioned select signal SEL is supplied thereto, and at the time the select signal SEL is turned from "0" to "1", the then appearing execution start address is latched.
The register 17c is enabled by an enable signal MAP from the microprogram controller 10, and thereby the latched data are supplied to the direct input terminal D. When the program is started in the previously discussed execution mode, it is arranged such that the address from the register 17c is taken in by the microprogram controller 10, and therefrom the address from the microprogram controller 10 is generated.
In the described manner, the program and the execution start addresses thereof are sent to each processor in sequence. Incidentally, the execution start addresses for each processor in the RAM 51 are previously supplied thereto from the host computer 5.
In this program transfer mode, as also described before, the microprogram controller 10 keeps on supplying the zero address and is in a stopped state.
Now, it is not known what microinstruction is stored in the register 18. However, since the register 18 is disabled as described above, the microinstruction is not supplied to the arithmetic unit, but a predetermined code from the predetermined code generator 25 is supplied through the register 26 to the arithmetic unit as a microinstruction.
In the present case, the predetermined code is what is freely decided by the hardware designer in advance. If it is made to be an opportune code at the time of the program transfer such as, for example, to forbid writing in the RAM in the processing arithmetic unit, the contents in the RAM will never be lost during the program transfer.
If, as the predetermined code, an instruction is prepared as to allow the initial value of the sum-of-products calculating circuit or accumulating circuit to become "0", then it will become possible, when the program transfer is finished and the next program is to be executed, immediately to start the execution without taking the step of initializing the sum-ofproducts or accumulating calculation.
In the reset (stop) mode, the mode signals MA = 1 and MB = 0, and so the address from the microprogram controller 10 is selected by the selector 20 of each processor, and the clock signal CKF is selected as the clock of the register 19. But, since the register 15 is put in the reset state by the signal -MB, the zero address is continuously supplied from the microprogram controller 10 and all the processors are brought into a program execution stopped state.
Since the signal MA is "1", any write signal becoming "0" is not supplied to the microprogram memories 11 to 14.
In this reset mode, the start address of the specific program desired to be executed in the next of the plurality of programs which have previously been written in the microprogram memory of each of the processors is re-specified.
That is, in the same way as in the program transfer mode, while the processor select signals are supplied in sequence from the ROM 49, the execution start addresses are sequentially supplied from the RAM 50 for each of the processors, and the execution start addresses are latched in sequence by the signal SEL in the register 17c of each processor.
Therefore, when next entering the execution mode, execution in each processor will be started with the program for which the execution start address has been re-specified. Thus, different programs can be executed by each of the processors without new programs transferred thereto.
The above described three modes are controlled by the program of the processor in the TC 4.
Figure 4 is a flow chart showing the procedure in the TC 4.
At first, the state of the reset signal MB is detected in the step (101).
If the signal MB = 1, when the signal MA = 1 as apparent from Figure 3, the mode is judged to be the program execution mode and the TC 4 continues to take the step (101).
If the signal MB becomes MB = 0, the program proceeds from the step (101) to the step (102), wherein the state of the signal MA is detected.
If the signal MA = 1, the mode is the reset mode, and, as described previously, the microprogram controllers 10 of all of the processors continuously supply the zero address and the program execution is stepped.
The program then proceeds to the step (103) wherein the start address is supplied to each of the processors in sequence, and returns to the step (101).
In the step (102), if the signal MA = 0, since the signal MB = 0, the mode becomes the program exchange mode. The program proceeds to the step (104), wherein 0 is loaded into the ROM 49 of the TC 4 whereby the first processor is specified, and in the step (105), the program is transferred to that processor. In the next step (106), the address in the ROM 49 is advanced by one increment. In the next step (107), it is judged whether the program has been transferred to all the processors, or to all of the processors to which the program had to be transferred, and if this has not been finished, the program returns to the step (105) and the program is transferred to the next processor in the step (106).
The steps (105) to (107) are repeated the same number of times as the total number of processors.
If it is judged that the transfer of the program has been finished in the step (107), the program proceeds to the step (109), wherein the state of the signal MA is detected. If the signal MA = 0, this step (109) is taken repeatedly and the program exchange mode is held. If the signal MA has changed to MA = 1, then the program is released from the program exchange mode and returns to the step (101).
In the case where the program transfer is to be decided to have been finished by detection of some specific data, the address in the ROM 49 is, although advanced by one increment in an ordinary case, changed to the address at which the specific data are written in the step (106), and this- is read out.
In the next step (107), judgement whether or not the read output from the ROM 49 is the specific data is made in the specific data detector circuit 52.
If the read output from the ROM 49 is the specific data, program transfer stopping is effected by the load control unit 48 in the step (108).
If the read output from the ROM 49 is not the specific data, the program returns to the step (105) and the program transfer is made to the next processor.
When the program transfer is stopped in the step (108), the state of the signal MA is detected in the next step (109).
Although the above description has been given taking a multiprocessor system as an example, the present invention is also applicable to mode controlling of one processor.
In the case of the above example, a plurality of processors forming a parallel processing apparatus are arranged to be totally controlled in three modes by the TC 4, and so each of the processors can be controlled without having conflicts with another. That is, if a plurality of processors are controlled individually, some may execute a program, some may exchange a program, and some may be reset, and thus, there is the possibility of erroneous execution. According to the above described example, such a fault can be prevented.
In the case of the present example, it is possible to shift from the program exchange mode or the execution mode to the reset mode instantly using the switches SWB and SWA. Therefore, in the middle of program execution or in the stage where program exchange has not been finished for all the processors, the mode can be changed to the reset mode as required.
Moreover, process execution, stopping and program transfer can be clearly and consistently controlled by virtue of the total controlling of the data processors in the three modes.
The program execution and transfer can be performed effectively without reducing the execution speed or without increasing the hardware by virtue of the appropriate use of different clock signals according to whether the mode is the program transfer mode or the program execution mode.
At the time of program transfer, supply of any instruction from the microprogram memory to the arithmetic unit is forbidden, and instead, a predetermined code most opportune at the time of program transfer is supplied to the arithmetic unit as an instruction. Therefore insecurity arising because it is not know what instruction is currently supplied to the arithmetic unit can be removed, and, for example, the contents of the memory in the arithmetic unit can be protected.
Since it is arranged that, when a signal to be sent to a processor to which a program is to be transferred becomes a specific one, it is detected, and the program transfer is thereby stopped, the program transfer can easily be finished at any point in time. Thus, the total loading time for the program transfer can be reduced.
Figure 5 shows a specific structure of the PIP system 3A. Although the PIP system 3A has, in reality, a large number (sixty sets, for example) of processors arranged in parallel, only two sets of them are shown in the drawing. In this drawing, digital data from the VIM system 2 are supplied to input registers (FRA) 31-1 to 31-n provided for each of the processors 3-1 to 3-n, and the registers 31-1 to 31-n are controlled by the PVP system 38 in accordance with the address read out of the VIM system 2 and stored with a predetermined amount of data necessary for each processor.
The data written in the registers 31-1 to 31-n are supplied to arithmetic units 32-1, 33-1 to 32-n, 33-n, respectively, each of which is provided with an adder/subtractor, multiplier, coefficient memory, data memory, etc. and makes linear and non-linear data conversion calculations according to a control signal from the control units 34-1 to 34-n. Results of the calculations are obtained at the arithmetic units 33-1 to 33-n, and further, the arithmetic units 33-1 to 33-n are controlled by the PVP system 38 according to write addresses of the VIM system 2, whereby the results of the calculations are written in appropriate portions in the VIM system 2.
In the present case, the control signals from the control units 34-1 to 34-n are formed according to the microprogram written in the microprogram memories (MPM) denoted by 11 to 14 in Figure 2 (denoted representatively by 35-1 to 35-n in Figure 5). The microprogram is written from outside through program change controls 36-1 to 36-n.
However, in the above case, if the above mentioned microprogram is formed by the existing host computer (HC) 5, etc., the transfer rate from the HC 5 to each MPM 35-1 to 35-n is limited by the capacity of the line, and therefore, it is only possible to transfer the program at the rate, for example, of 500 Kbytes/sec or so, and therefore, it takes a substantial time for the rewriting in all of the MPMs 35-1 to 35-n. Due to the fact that processing in the PIP system 3A etc. becomes impossible during that time, many inconveniences have been experienced. Since the transfer cannot be performed until the processing the PIP system 3A etc. has been finished, the
HC side has had to wait until it is finished, and therefore, there has been a difficulty that the efficiency of usage of the HC 5 is considerably lowered.
In Figure 6, the microprogram transferred in 16-bit structure from the HC 5 is supplied to the previously described 64 Kbytes RAM 41 in the
TC 4. Moreover, a write control signal from the HC 5 is supplied to the load control unit 48, the signal from the load control unit 48 is supplied to the
RAM 41 and a memory address generator circuit 42a in the address generator circuit 42, and the generated address is supplied to the RAM 41, whereby the microprogram is written in the RAM 41 at an arbitrary address.
At this time, a status signal showing that the RAM 41 is write enable is supplied from the load control unit 48 to the HC 5.
A status signal showing that the microprogram memories are rewrite enabled is supplied from the PIP system 3A to the load control unit 48.
Thereby, the signal from the load control unit 48 is supplied to the memory address generator circuit 42a and an MPM address generator circuit 42b.
While the addresses sequentially to read the RAM 41 are generated by the circuit 42a, a chip select signal for writing the read microprogram in the specified MPM and addresses for writing the program in sequence in the
MPM are generated by the circuit 42b.
Thus, while the microprogram read out from the memory 41 in, for example, 16-bit structure is supplied to the PIP system 3A through a multiplexer (MUX) 53, the addresses etc. from the circuit 42b are supplied to the PIP system 3A. Moreover, the write control signal from the control unit 48 is supplied to the PIP system 3A.
Wlth this arrangement, the RAM 41 and the PIP system 3A can be connected through a dedicated line and, further, transfer in mult ibit structure, such as 16-bit structure, can be used. Therefore, assuming that the transfer rate is 8 Mbytes/sec, for example, the transfer can be made at a rate sixteen times as high as that in the case of the conventional direct transfer from the HC 5, 500 Kbytes/sec, for example.
In the case where the same microprogram is to be transferred to the plurality of processors in the PIP system 3A, the program can be sent to them simultaneously by arranging a plurality of chip select signals to be generated by the MPM address generator circuit 42b. Thereby, the program can be transferred, for example, within the vertical blanking period of the video signal, and thus, real-time signal processing can be performed without producing any disturbance in the image.
The described transfer process has been made possible by structuring the load control unit 48 etc. with a so-called microprocessor. Incidentally, the above described program transfer can be applied not only to the PIP system 3A as described above, but also to the IOC 1, the PVP 38, etc. Even in such cases, however, the transferring time between the HC 5 and the memory is the same as before, and the HC 5 and the line are occupied during the transferring line, and so there is the possibility of a lowering of efficiency in the usage of the HC 5 and the line.
In the above described example, when the program is to be transferred to inside the TC 4, it has been arranged that the program only is sent thereto and the address in the RAM 41 is produced inside the TC 4. In the next example, the address in the RAM 41 is also transferred from the
HC 5 together with the program.
That is, in Figure 7, the data transferred, for example, in 16-bit structure from the HC 5 are supplied to registers 9a, 9b, 9c and 9d, each being of 16-bit structure. A control signal from the HC 5 is supplied to the control unit 48a, and the write signal produced is supplied to the registers 9a to 9d.
Here, as the data from the HC 5, as shown in Figure 8A, for example, data identification information (ID) is transferred at the time in synchronism with the control signal (the start signal: Figure 88) indicating the start of the transfer from the HC 5, and thereafter, data (D) are transferred at intervals of a predetermined clock signal (Figure 8C). Then, the above identification information (ID) from the control unit 48a is written in the register 9a by means, for example, of the write signal output to the register 9a at the time of the above mentioned start signal, and this information is detected in the load control unit 48a. Then, the data D are written in sequence in the register 9b by means of the write signal output to the register 9b at the time of the clock signal.The data (D) are supplied through a register 9e to the IOC 1, etc. In the data (D), there are provided, for example, an indication of the kind of processing system (NTSC, R-G-B, etc.) and information for mode setting (real time, waiting for processing to be finished, still picture, etc.).
When the above mentioned microprogram is to be rewritten, information (L) showing the length of the program to be transferred following the identification information (ID) is transferred from the HC 5, in succession to the identification information (ID) as shown in Figure 8D.
Thereafter, later discussed addresses (A) of the RAM 41 and data forming the program (PD) are transferred alternately. Meanwhile, from the load control unit 48a, as shown in Figure 8E, a write signal is again supplied to the register 9a at the time of the next clock to that for the start signal, in response thereto the identification information (ID) indicating the program has been written in the register 9a, and thereby, the information (L) about the length is written in the register 9a. Then, as shown in Figures 8F and 8G, write signals are alternately supplied to the registers 9c and 9d at every other clock, whereby the address A is written in the register 9c and the program data PD is written in the register 9d, separately.
The address A from the register 9c is supplied through a MUX 53a to the#RAM 41 and the program data (PD) from the register 9d are written at that address. Meanwhile, a write control signal is supplied from the load control unit 48 to the RAM 41. The writing is continued to the extent specified by the length information (L).
When the writing has finished, the MUX 53a is switched by a signal from the load control unit 48a. A signal from a second load control unit 48 is supplied to the memory address generator circuit 42a and the MPM address generator circuit 42b. While addresses to read in sequence from the
RAM 41 are supplied from the circuit 42a, chip select signals for writing the read microprograms in a specific MPM and addresses for sequentially writing them in the MPM are supplied from the circuit 42b.
Thus, the microprograms read from the RAM 41 are supplied through the MUX 53 to the PIP system 3A, the PVP system 3B, etc. and the addresses etc. from the circuit 42b are supplied to the PIP system 3a and elsewhere.
In the above described apparatus, since the program data (PD) and the address data (A) are separated, and writing in the RAM 41 is made according to these addresses, it is possible to change a portion of the program while keeping all the rest of the program as it is. That is, in a filtering process, a new filtering can be performed with the program for arithmetic processing not changed, but only the coefficient data therein changed. In such a case, with the above described apparatus, first, the entire arithmetic program is transferred, and then, according to the need, only the coefficient data are exchanged, and thereby, various processes can be performed.
With the above described apparatus, it takes twice as long a time as in the usual case for transferring the first program, but the data for changing the coefficient data etc. in the filtering process only accounts for 1% or less of the entire data. Therefore, supposing five exchanges are made, if the entire portion is expressed by 1, the time taken by the present apparatus becomes:
1 x 2 + 0.01 x 2 x 5 = 2.1 which is less than half that in the usual case, that is:
1 x 5 = 5.0
Moreover, with the above described apparatus, it becomes unnecessary to provide a circuit for generating the write address within the apparatus.
Since addresses are attached to the data forming the microprogram transferred from the host computer and the writing is done according to these addresses, it is possible to rewrite any portion of the program once written in the memory by specifying the address for that portion. Thus, in such a case, to rewrite a portion of a long program, it is only required to transfer that portion, and therefore, it is possible to finish the rewriting in a very short time.
It sometimes occurs that the result of the processing performed according to a transferred microprogram is found to be incorrect. Various causes are considered for such an incorrect result, such as malfunction of the processor etc. within the processing apparatus, failure in the line between the host computer and the processing apparatus, and others. And, there have been such problems where the cause is difficult to determine.
The usual practice has been to inspect the processors one by one with a probe, each of the processors being provided with a testing terminal, or to inspect the line with the operation of the host computer halted. However, in the case of the apparatus including a large number of processors as described above, it has taken much time and labour for checking those processors one by one. Also, since the line has been inspected first for the reason that such a failure is commonly attributable to the ine, the host computer has had to be frequently halted and it has been a problem that the efficiency of the usage of the host computer is thereby lowered.
Therefore, the TC 4 is provided, as shown in Figure 6, with a ROM 54 with a program for diagnosis written therein. In the diagnostic program, a system is adopted in which arithmetic operations are made with all the functions of the processor employed therein, and the results are compared with previously calculated right answers. By properly arranging a program, it is possible to detect, from each register incorporated in the processor, whether the processor is in good order or not.
While the address from the memory address generator circuit 42a is supplied to the ROM 54 and the program from the ROM 54 is supplied to the
MUX 53, a control signal from the control unit 48 is supplied to the MUX 53, and thereby the program from the RAM 41 is supplied to the PIP system 3A.
Moreover, the addresses etc. from the circuit 42b are supplied to the PIP system 3A, and the write control signal from the control unit 48 is supplied to the PIP system 3A.
Therefore, in the above described arrangement, by supplying a command signal from outside to the load control unit 48 when errors are found in the result of the processing, the program written in the ROM 54 is supplied to the PIP system 3A and the processors-etc. of the PIP system 3A are diagnosed. If there nothing is found wrong in the result of the diagnosis, it is understood that no processor is out of order and the line between the host computer and the apparatus is then inspected, but if something is found to be wrong in the result of the diagnosis, the processor is subjected to closer examination.
Figure 9 shows a flow chart for the diagnosis, wherein, first, in the step (201), the MUX 53 is switched to the side of the ROM 54. In the next step (202), the address generator circuits 42a and 42b are driven and the
ROM 54 is read, whereby the program for diagnosis is transferred to the PIP system 3A. In the step (203), arithmetic operations are effected by the processor according to the program for diagnosis.
In the step (204), decision (diagnosis) by the result of the operations is made, and if it is found to be incorrect (NG), a closer examination is made in the step (205) and the result thereof is displayed in the step (206). When the operation result is correct (OK) in the step (204), the line between the host computer and the apparatus is inspected in the step (207) and the result thereof is displayed in the step (208).
When the display is made in the steps (206) or (208), the MUX 53 is reset to the side of the RAM 41 and the diagnostic operation is ended.
When the diagnostic operation is to be performed in the above described manner, the ROM 54 with the program for diagnosis written therein is incorporated in the transferring arrangement, and so the transfer of the program is not affected by whether the line is good or not and correct diagnosis is ensured, and moreover, by the result of the diagnosis, it can be decided whether the line is good or not.
Since the program for diagnosis can be transferred in a shorter time than in the case where the program is transferred from the host computer, the diagnosis can be finished quickly, without disturbing the operation of the host computer, whereby the reliability of the overall apparatus can be improved.
The processing to diagnose the processor with a built-in ROM has been made possible by forming the load control unit 48 etc. of so-called microprocessors.
The diagnosis of the processor is applicable not only to the PIP system 3A as described above, but also to the IOC system 1, the PVP system 3B, etc. Moreover, the above described ROM 54 can be loaded with programs, etc. which are repeatedly used for ordinary processing in addition to the program for diagnosis.
In the TC 4 of the embodiment in Figure 2, it is required to provide many memory units and peripheral circuits such as the RAM 41 for storing the program, the address generator circuit 42 for generating the addresses therein, the ROM 49 for storing the select signal of each of the processors, and the RAM 51 for storing the execution start addresses for each processor, but it is possible to embody these in a large scale memory.
That is, the load control unit 48 and a memory 41' can be arranged as shown in Figure 10, and the memory 41' has stored at its sequential addresses the execution start addresses and such parameters as processor select signals, addresses, program contents, and write signals.
These signals to be supplied to the processors are sequentially read out from the memory 41' according to the addresses from the load control unit 48, whereby the processors selected by the processor select signals are supplied with the parameters and the microprogram memories thereof are written with the program contents.
With Figure 11 taken as an example, when the addresses 0 to 7 of the memory 41' are read out, the program contents are written in the microprogram memory of the processor no. 10 at its addresses 0 to 7, and when, in succession thereto, the addresses 8 to 23 of the memory 41' are read out, the program contents are written in the microprogram memory of the processor no. 25 at its addresses 0 to 15.
Out of the signals to be sent to the processors shown in Figure 11, only one kind of the processor select signal and the parameter are given to one processor, that is, the same signals are repeatedly supplied for each of the addresses from the memory 41' to one processor.
On the other hand, the program contents and their memory addresses as well as the write signals must be supplied differently for each address, not for each processor.
In the case where these data are read out from one memory 41' and transferred to each of the processors as shown in Figure 10, it is required as indicated in Figure 11 that not only the data necessary for each address of the memory 41' but also the data unchanged for each processor must be stored at the addresses in sequence, and therefore, the efficiency of usage of the memory is substantially lowered.
Then, in another embodiment of the present invention as shown in
Figure 12, the TC 4 is provided with the load control unit 48 and a memory for storing the signals to be supplied to the microprogram memories 11 to 14. As the memory, in the present case, a processor-wise memory 41'a and an address-wise memory 41'b are provided.
In the processor-wise memory 41'a are stored one kind of data for each of the processors, that is, the parameter and processor select signal as well as a program identification signal IDP.
In the address-wise memory 41'b are stored the prgram contents and address data thereof as well as the write signals WR written for each of the addresses.
As the program identification signal IDP in the present example, the address in the front of the address-wise memory 41' for the program to be sent to each of the processors is used. For example, according to the example of Figure 11, when the processor 10 is selected, the address in the front, "0", for its program, and when the processor no. 25 is selected, the address in the front, "8", for its program are used as the program identification signals IDP, respectively.
A counter 42' generates the address for the address-wise memory 41'b. The program identification signal IDP from the memory 41'a is preset by a preset signal in synchronism with selection of each processor from the load control unit 48, and its value is sequentially counted up from the preset value.
A comparator circuit 44' detects an end of the program transfer to one processor through comparison of a processor-wise program end address
END output from the processor-wise memory 41'a and the address for the memory 41'b from the counter 42'. The comparison output is supplied to the load control unit 48.
In the present program transfer mode, the program transfer to each processor is carried out according to the program transfer program from the
TC 4 and under instruction from the load control unit 48 in the following way.
In the first place, the first address is supplied from the load control unit 48 to the processor-wise memory 41'a. Then, the select signal for selecting the processor to which the transfer is to be made at first, the parameter for the processor, the front address as the identification signal
IDP of the program for the processor, and the end address END for the program are read out from the memory 41'a.
The processor select signal read out from the memory 41'a is decoded by the decoder 50, whereby only the select signal SEL for the processor to be selected becomes "0" and others become "1". The select signal SEL is supplied to the OR gate 21. Since the mode signal MA is "0" at this time, this OR gate functions so that the microprogram memories 11 to 14 of the processor for which the select signal SEL is "0" is rendered write enabled when the write signal WR becomes "0", and then, the program becomes rewritable.
On the other hand, the front address as the identification signal IDP is preset in the counter 42' by the preset signal from the load control unit 48, and the counter 42' is allowed to count up from the preset front address value.
As previously described, when the selected processor is the processor no. 10 as shown in Figure 11, the same is allowed to count up from the address 0. According to the address from the counter 42', the program contents, the address therefor, and the write signal WR becoming "0" are sequentially read out from the address-wise memory 41'b.
Therefore, the microprogram memories 11 to 14 of the selected processor are written in with the program contents in sequence at the addresses sent from the address-wise memory 41'b.
When there appears the end address END (for example, the address no. 7 for the processor no. 10) of the program being transferred to that processor, agreement between the output address value from the counter 42' and the end value END is detected in the comparator circuit 44', and responding to the detection signal, the load control unit 48 supplies the next address, which has been advanced by one increment, to the processor-wise memory 41'a.
Then, the processor select signal for selecting the next processor is generated by the processor-wise memory 41'a, the select signl SEL selecting the processor becomes "0", and thus, in like manner, the program e#xchange is carried out for this processor. If the programs of all of the processors are to be exchanged, like operations are repeated the same number of times as that of the processors.
In the present example, if a plurality of programs are to be sent to each of the processors or a plurality of programs which are different from each other are to be sent thereto, this plurality of programs is considered to be one program, and this program is arranged to be written in each processor. It is further arranged that the programs required by each processor can be specified by providing each processor with an execution start address as the parameter.
The execution start addresses are obtained from the processor-wise memory 41'a as described above, and supplied to the register 17c of each processor. The signal SEL is supplied to the register 17c as the latch signal therefor, and at the time this select signal SEL turns from "0" to "1", the then appearing execution address is latched. The contents of the memories 41'a and 41'b have been given from the HC 5 in advance.
In the reset mode, the start address of the program desired to be executed next out of the plurality of programs previously written in the microprogram memory of each processor are re-specified. That is, the same as in the case of the program transfer, the processor select signals and the execution start addresses are sequentially supplied from the memory 41'a for each of the processors, whereby the execution start addresses are sequentially latched in the registers 17c of each of the processors by the signal SEL.
Since the mode signal MA = 1 at this time, the output of the OR gate 21 does not become "0", and therefore the program is not rewritten.
The flow chart of the processing in the TC 4 is similar to that of
Figure 4, but in the step (104), the address 0 is supplied from the load control unit 48 of the TC 4 thereby to specify the first processor, and in the step (105), the program is transferred to the processor. In the next step (106), the address for the memory 41'a is advanced by one increment. In the next step (107), it is judged whether the programs have been transferred to all of the processors, or have been transferred to the processors to which the programs had to be transferred, and if it is judged not to have been finished, the process flow returns to the step (105) and the program transfer to the next processor is performed in the step (106).
Thus, the apparatus is provided with two memories, that is, the memory storing processor-wise information and the memory storing addresswise information of the program to be transferred, and thereby the program supplying portion has been arranged as a hierarchical structure. Therefore, as compared with the case where information for each processor is stored at each of the addresses for the transferred program, memory area can be saved and effective usage of the memory can be achieved.
Figure 13 illustrates an example of the circuit of the program transfer system in the case where a plurality of programs are transferred to a plurality of processors is indicated.
The present program supplying portion formed of the TC 4 includes a program RAM or ROM 41 storing the plurality of programs to be transferred, an address RAM or ROM 51 storing the execution start addresses for each of the processors, an address counter 42 for the program
RAM 41, and a write signal generator 44 formed of a comparator, and which supplies the programs to n sets of processors 3-1, 3-2, ..., 3-n. In the present case, it is arranged that only a plurality of programs which have to be sent can be sent out of the plurality of programs stored in the program
RAM 41.
That is, the load control unit 48 is provided with a start value generator 48a for generating the start address of the program with lowernumbered addresses of the plurality of programs to be sent out of the plurality of programs stored in the program RAM 41 and an end value generator 48b for generating the end address of the program with highernumbered addresses of the plurality of programs to be sent out of the plurality of the programs stored in the program RAM 41. That is, in the case, for example, where the contents of the first to third programs are stored in the program RAM 41 at the addresses from "0" to "28" as shown in
Figure 14 and the first to third programs are to be transferred to the processors 3-1 to 3-n, the start value generator 48a provides the data for the address value "0" and the end value generator 48b provides the data for the address value "28".
The start value from the start value generator 48a is supplied to the address counter 42 and the address counter 42 starts counting from this start value. The counted-value output is supplied to the program RAM 41 as read- addresses, and is also supplied to the microprogram memories of each of the processors 3-1 to 3-n as write addresses ADRS. The program data
DATA read out from the RAM 41 are also supplied to the microprogram memories of each of the processors 3-1 to 3-n. In this case, the microprogram memories of each processor are provided with virtually equal capacity to that of the program RAM 41.
The address data ADRS from the address counter 42 is also supplied to a comparator 44 and therein compared with the end value from the end value generator 48b. From the comparator 44 is supplied a write signal WR, which is held, for example, at "0" until the address data ADRS sequentially changing from the start value reaches the end value. The write signal is supplied to the write enable terminals of the microprogram memories of each of the processors 3-1 to 3-n, and writing of the program in the memories is enabled while the write enable signal is kept at "0".
In the described manner, the write signal WR is held at "0" while the address data ADRS from the address counter 42 changes from "0" to "28", and during this period of time, the first to third programs written in the program RAM 41 at the addresses "0" to "28", regarded as one program, are sequentially read out from the program RAM 41 and written in the microprogram memories at the addresses according to the address data
ADRS.
While the programs are transferred to each of the processors 3-1 to 3-n, execution start addresses CS1 to CSn, that is, the start addresses of the programs out of the first to third programs to be executed in the next place by each of the processors are supplied from the address RAM 51 individually to each thereof, and are latched by the registers of each of the processors 3-1 to 3-n. If the example of Figure 14 is taken up, the execution start address of the first program is "0", the execution start address of the second program is "6", and the execution start address of the third program is "19".
In the event of the program execution to be started by each processor after the transfer has been finished, the program is started at the execution start address, and thus, desired programs can be executed.
If the programs to be executed in the next place are included in the plurality of programs which have already been transferred, the execution addresses only will be re-transferred, and thereby different programs are enabled to be executed by each of the processors.
It is possible individually to transfer a plurality of programs, as a block of program, to each processor, but the transfer can be finished at one time if the programs are simultaneously transferred in the manner illustrated in Figure 13.
As described above, a plurality of programs are regarded as one program and transferred at one time, and the execution start signals of each of the programs are separately sent, and therefore the programs requiring a plurality of times of transfer can be transferred at one time, and the transferring time can be reduced. Moreover, since a plurality of different programs can be transferred to a plurality of processors without requiring a selection control arrangement, the circuit for the transfer becomes smaller in scale.
However, in the case where each of a plurality of processors are supplied with different programs, the number of programs to be sent in a block will become the same as the total number of the processors and the transferring time will accordingly become longer. Then, in the case where there is a large number of processors, the transferring time as a whole may be reduced if arranged such that the programs of the same number as the number of the processors to which program transfer is to be made are arranged in a block and this block of programs is individually transferred to each of the processors in question.
Figure 15 shows another example of the apparatus. This example is characterised by the portion in the transferring processor supplying select signals to a plurality of processors.
The plurality of processors are divided into groups in such a way, for example, that those processors which are able to perform the same work are put in a group. In the present case, they are divided into k groups, each group being formed of i processors, namely, the first group of processors 3-11, 3-12, ..., 3-li, the second group of processors 3-21, 3-22, ..., 3-2i, and the k-th group of processors 3-kl, 3-k2, ..., 3-ki.
The transferring processor 4 is provided with decoders 55-1, 55-2,..., 55-k for supplying each of the processors of each of the groups with a select signal. The decoders 55-1, 55-2, ..., 55-k are, similar to the decoder 50 in
Figure 2, such that only one select signal therefrom becomes "0" and all the others become "1" according to the input bit thereto, and, as the input data, the least significant 1-bit portion of a m-bit select signal is supplied. The more significant (m-1)-bit portion of the m-bit select signal is supplied to a decoder 56.The decoder 56 generates select signals 51, 52, ..., Sk for selecting one out of the decoders 55-1, 55-2, ..., 55-k for each of the groups, and each of the select signals Si, 52, ..., Sk is supplied to enable terminals EN of the decoders 55-1, 55-2,..., 55-k.
In the present case, m, 1, k and i are so selected so that 21 is greater m-1 than or equal to i and 21 is greater than or equal to k.
The select signal is provided with one extra bit so that group-wise selection is made possible. The 1-bit signal GS is supplied to one of the input terminals of each of the OR gates 57-1, 57-2, ..., 57-k. The other input terminal of the OR gate 57-1 is supplied with the select signal Si, the other input terminal of the OR gate 57-2 is supplied with the select signal S2, ..., and the other input terminal of the OR gate 57-k is supplied with the select signal Sk.
From each of the decoders 55-1, 55-2, ..., 55-k; i processor select signals are supplied through each of i of AND gates 58-11 to 58-li, 58-21 to 58-2i, ..., 58-kl to 58-ki, respectively, to each group of processors 3-11 to 3-li, 3-21 to 3-2i, ..., 3-ki to 3-ki, respectively. The output of the OR gate 57-1 is commonly supplied to the first group of AND gates 58-11 to 58-li, the output of the OR gate 57-2 is commonly supplied to the second group of
AND gates 58-21 to 58-2i, ..., and the output of the OR gate 57-k is commonly supplied to the k-th group of AND gates 58-kl to 58-ki, respectively.
With the above described structure, sequentially transferring different programs to each of the processors one by one and writing the programs in their respective memories as has hitherto been practised is carried out in the following manner.
Firstly, the signal GS is made "1". Hence, all of the outputs of the
OR gates 57-1 to 57-k become "1", and the AND gates 58-11 to 58-ki are all brought into the state of gating the outputs of the decoders 55-1 to 55-k as they are. Under these conditions, the input select signal is sequentially advanced by one increment at each transfer time.
In the present case, the input to the decoder 56 is held in an unchanged state until the program transfer to one processor has been finished, namely, it is held in a state of selecting the decoder of one group.
That is, according to the input select signal, only the select signal S1 first becomes "0", whereby the decoder 55-1 is rendered operative as a decoder, while the processor select signals supplied from all of the others become "1" regardless of the inputs thereto. Thus, the first group is selected and the program is sequentially written over a bus in the memories of the processors 3-11 to 3-li of the first group in accordance with the 1-bit select signal of the decoder 55-1.
When i times of the program transfers to the processors 3-11 to 3-li of the first group have been finished, the least significant bit of the more significant (m-1)-bit input select signal is inverted, whereby only the select signal S2 of the output of the decoder 56 becomes "0" to render the decoder 55-2 operative as a decoder, and outputs of all of the other decoders 55-1, 55-3 to 55-k become "1". Thus, in like manner, the program is sequentially transferred to the processors of the second group according to the least significant 1-bit select signal.
Thereafter, one of the decoders 55-1 to 55-k is likewise rendered operative as a decoder according to the select signal output from the decoder 56, and program transfers are sequentially made i times to processors of the group of that decoder, and thereby the program transfers to all of the processors are carried out in sequence.
Next, at the time of group-wise program transfer, the signal GS is made "0". Then, the outputs of the OR gates, to which the select signals being "0" out of the select signals S1 to Sk from the decoder 56 are supplied, become "0". For example, if the signal S1 is "0", the output of the OR gate 57-1 becomes "0", whereby outputs of all of the i AND gates 58-11 to 58-le of its group become "0", regardless of the select signals supplied from the decoder 55-1. Thus, the memories of the processors 3-11 to 3-li of the first group are rendered write enabled, and so the same program is written in the processors 3-11 to 3-li of the first group at one time of transfer.
Then, in like manner, an identical program is simultaneously written in i processors of the group selected by one of the select signals S1 to Sk from the decoder 56, at one time of transfer. Therefore, in the present case, program transfer to all of the k x i processors can be carried out by transfers and the transferring time can thereby be reduced.
Incidentally, instead of transferring programs to all the processors in sequence, it is of course possible to transfer the program to any processor or to any group of processors at any desired time by arranging the input select signal to become the data to select that processor or group.
In dividing the processors into groups, each of the groups need not be formed of the same numbers of processors but may be formed of any number of processors which will use the same program. In such a case, by storing the number of processors belonging to each of the groups in a memory, the loss of time produced when the transfer is sequentially made to each group can be eliminated.
Figure 16 shows another example of the apparatus, which is an improved example of that in Figure 15, and parts thereof corresponding to the example in Figure 15 are denoted by the same reference numerals.
In the present example, n processors are divided into a first group including i processors and a second group including (n-i) processors. In this case, n select signals from a decoder 55 for selecting n processors are supplied through AND gates 58-1 to 58-n, respectively, to each of the processors 3-1 to 3-n. There is also provided a group selector circuit 59, to which a 2-bit select signal is supplied.
A first group select signal GSI is supplied to the AND gates 58-1 to 58-j, to which the select signals from the decoder 55 for selecting the processors 3-1 to 3-j of the first group are supplied at one input terminal, at the other input terminal. The second group select signals GS2 is supplied to the AND gates 58-j+l to 58-n, to which the select signals from the decoder 55 for selecting the processors 3-j+1 to 3-n of the second group are supplied at one input terminal, at the other input terminal.
In the case where different programs are sequentially transferred to each of the processors one by one the same as hitherto in practice, the group selector circuit 59 is supplied with signals causing both the signals GS1 and GS2 to become "1". Hence, the AND gates 58-1 to 58-n are brought to the state allowing the outputs of the decoder 55 as they are, and thereafter, the sequential transfers to all of the processors are carried out in just the same way as previously described.
Next, if the selector circuit 59 is supplied with signals that will make only the signal CS1 "0", then all of the outputs of the AND gates 58-1 to 58-j become "0" regardless of the output select signals from the decoder 55, and thereby the same program is simultaneously written in the processors 3-1 to 3-j of the first group at one time of transfer.
In the case where only the signal GS2 is made "0", the outputs of the
AND gates 58-j+1 to 58-n all become "0" regardless of the output select signals from the decoder 55, whereby an identical program is simultaneously written in the processors 3-j+1 to 3-n of the second group at one time of transfer.
If both of the signals GS1 and GS2 are made "0", the outputs of the
AND gates 58-1 to 58-n all become "0", in which case an identical program can be simultaneously transferred to all of the processors 3-1 to 3-n.
Thus, when transferring information to a plurality of processors, information can not only be transferred individually to each of the processors, but can also be simultaneously transferred, at one time of transfer, to a plurality of processors which will use the same information, and so a reduction in the transfer time can be achieved.
Although the case where the apparatus of the present invention is applied to video signal processing has been described above, the present invention is applicable to digital processing of other information signals such as an audio signal, because a portion of such a signal for the duration of a unit time can be stored in a memory and the signal can be sequentially processed for each such unit-time portion.
Claims (7)
1. In an apparatus including a large number of processors to be driven by respective microprograms, said microprograms being provided in random access memories (RAMs), apparatus for transferring said microprograms from a host computer to said RAMs, said transfer apparatus comprising: a memory in which said microprograms are stored; and wherein: said microprograms supplied from said host computer are formed of pieces of data each with an address attached thereto; said piece of data and said address are separated in each said microprogram being supplied; said data are written in said memory according to said separated addresses; and said memory is read and said data are transferred to said RAM as required.
2. Apparatus according to claim 1 comprising: means for transferring a microprogram to said program memory; means for generating a predetermined code; and means for supplying instruction data from said memory to a processing arithmetic unit at the time of program execution and blocking the instruction from said memory and supplying said predetermined code as an instruction to the processing arithmetic unit at the time of said program transfer.
3. Apparatus according to claim 1 comprising means for transferring microprograms in sequence from a program supplying portion to a plurality of processors operating under the microprograms, said means comprising: a load control unit; a memory for storing the data to be sent to said processors at the time of program transfer; and means for detecting specific data; wherein: said specific data if data other than the information to be sent to each of said processors are stored at a specific address of said memory, and it is arranged that said specific data are read out according to addressing from said load control unit when said program transfer is to be finished, the read out specific data are detected by said detector means, the detection signal is supplied to said load control unit, and thereby the transfer is stopped.
4. Apparatus according to claim 1 including program transferring apparatus capable of loading any microprogram to each of a plurality of processors, the transferring apparatus comprising: a load control unit; and a first memory and a second memory, said first memory storing a signal for selecting a processor and an identification signal of a microprogram to be sent to the processor, and said second memory storing address data for each microprogram and the contents of the microprogram; and wherein: the process select signal is read out from said first memory according to an address from said load control unit whereby the processor to which a microprogram transfer is to be made is specified, said program identification signal is read out, addressing is made to said second memory according to said identification signal, said address data and said microprogram contents are read out from said second memory, and, according to the read out address, said microprogram contents are written in the program memory of said specified processor.
5. Apparatus according to claim 1 wherein a plurality of different microprograms from a microprogram supplying portion are supplied to processors operating under the microprograms, said plurality of different microprograms, the whole being treated as one program, are supplied at one time of transfer to said processors, and an execution start address corresponding to one microprogram out of said plurality of different microprograms is supplied to each of said processors.
6. Apparatus according to claim 1 wherein information is supplied to a plurality of said processors over a common bus, but writing of said information in memories provided for said plurality of processors is allowed only for selected ones out of said plurality of processors, the apparatus further comprising: first selector means capable of individually selecting each processor out of said plurality of processors; and second selector means capable, when said plurality of processors are divided into groups, of commonly selecting the processors of each said group regardless of the state of the output of said first selector means.
7. Data processing apparatus substantially as hereinbefore described with reference to the accompanying drawings.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP60259543A JPH06103460B2 (en) | 1985-11-19 | 1985-11-19 | Program transfer method |
GB8627177A GB2183375B (en) | 1985-11-19 | 1986-11-13 | Information processing apparatus |
Publications (3)
Publication Number | Publication Date |
---|---|
GB8906978D0 GB8906978D0 (en) | 1989-05-10 |
GB2216310A true GB2216310A (en) | 1989-10-04 |
GB2216310B GB2216310B (en) | 1990-05-30 |
Family
ID=26291539
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB8906978A Expired - Lifetime GB2216310B (en) | 1985-11-19 | 1989-03-28 | Data processing apparatus |
GB8906979A Expired - Lifetime GB2216311B (en) | 1985-11-19 | 1989-03-28 | Methods of program transfer |
GB8906977A Expired - Lifetime GB2216309B (en) | 1985-11-19 | 1989-03-28 | Program transfer apparatus |
Family Applications After (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB8906979A Expired - Lifetime GB2216311B (en) | 1985-11-19 | 1989-03-28 | Methods of program transfer |
GB8906977A Expired - Lifetime GB2216309B (en) | 1985-11-19 | 1989-03-28 | Program transfer apparatus |
Country Status (1)
Country | Link |
---|---|
GB (3) | GB2216310B (en) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6366215B1 (en) * | 1998-12-04 | 2002-04-02 | Pittway Corporation | Communications systems and methods |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3287703A (en) * | 1962-12-04 | 1966-11-22 | Westinghouse Electric Corp | Computer |
US3287702A (en) * | 1962-12-04 | 1966-11-22 | Westinghouse Electric Corp | Computer control |
US4037092A (en) * | 1973-11-26 | 1977-07-19 | Hewlett-Packard Company | Calculator having preprogrammed user-definable functions |
GB1497679A (en) * | 1975-07-22 | 1978-01-12 | Int Computers Ltd | Data processing systems |
IT1059493B (en) * | 1976-04-22 | 1982-05-31 | Olivetti & Co Spa | DEVICE TO CHANGE THE WORKING ENVIRONMENT OF A COMPUTER |
JPS6180338A (en) * | 1984-09-27 | 1986-04-23 | Fanuc Ltd | Loading method of system program |
-
1989
- 1989-03-28 GB GB8906978A patent/GB2216310B/en not_active Expired - Lifetime
- 1989-03-28 GB GB8906979A patent/GB2216311B/en not_active Expired - Lifetime
- 1989-03-28 GB GB8906977A patent/GB2216309B/en not_active Expired - Lifetime
Also Published As
Publication number | Publication date |
---|---|
GB2216309A (en) | 1989-10-04 |
GB8906977D0 (en) | 1989-05-10 |
GB2216309B (en) | 1990-05-30 |
GB8906978D0 (en) | 1989-05-10 |
GB2216311B (en) | 1990-05-30 |
GB2216310B (en) | 1990-05-30 |
GB8906979D0 (en) | 1989-05-10 |
GB2216311A (en) | 1989-10-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
DE69128565T2 (en) | Microcomputer equipped with a DMA controller | |
US4503495A (en) | Data processing system common bus utilization detection logic | |
US4443849A (en) | Error recovery system of a multi-processor system for recovering an error by transferring status singals from one processor to another without use of a main memory | |
US4821187A (en) | Processor capable of executing one or more programs by a plurality of operation units | |
US4080651A (en) | Memory control processor | |
US4354227A (en) | Fixed resource allocation method and apparatus for multiprocessor systems having complementarily phased cycles | |
US3909802A (en) | Diagnostic maintenance and test apparatus | |
US4251859A (en) | Data processing system with an enhanced pipeline control | |
US4920482A (en) | Multiple mode microprogram controller | |
US5625834A (en) | Information processing section and system for operating a plurality of vector pipeline sets in two different modes | |
EP0247383A2 (en) | Apparatus for arithmetic processing | |
JPH1083303A (en) | Electronic circuit and method for using coprocessor | |
GB2216310A (en) | Data processing apparatus | |
US5872961A (en) | Microcomputer allowing external monitoring of internal resources | |
JP2918019B2 (en) | Test circuit for single-chip microprocessor | |
EP0169577B1 (en) | Microcomputer | |
CA1290071C (en) | Method and apparatus for data transfer | |
JP2557042B2 (en) | Program transfer device | |
JP2557043B2 (en) | Bit pattern detector | |
JP2806799B2 (en) | Information processing system | |
JPH077337B2 (en) | Information processing equipment | |
SU1094038A1 (en) | Interface for linking analog-to-digital converter with digital computer | |
JPH0341528A (en) | Diagnostic device in computer | |
US20020169909A1 (en) | Data-processing arrangement including an interrupt generator | |
JPS5848299A (en) | Fault diagnosing device of memory |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PCNP | Patent ceased through non-payment of renewal fee |