This application is based upon and claims the benefit of priority from prior Japanese Patent Application P2005-217789 filed on Jul. 27, 2005; the entire contents of which are incorporated by reference herein.
1. Field of the Invention
The present invention relates to a pipeline processor capable of extending instructions, and a method for automatically designing the pipeline processor.
2. Description of the Related Art
A reduced instruction set computer (RISC) and a complex instruction set computer (CISC) has been known as processor architecture. By simplifying instructions, the RISC processor implements the pipeline process, the process commencing the processing of the subsequent instruction before the processing of the previous instruction has completed. The basic pipeline process executes each stage independently, those stages being: an instruction fetch stage (hereinafter referred to as “F stage”), an instruction decode stage (hereinafter referred to as “D stage”), an instruction execution stage (hereinafter referred to as “E stage”), and a write back stage (hereinafter referred to as “W stage”).
When a pipeline processor executes an instruction, it is necessary to resolve any hazard caused by the instruction and processor architecture. There are two types of hazard in the typical pipeline processor: data hazard and structural hazard. There is also the term “control hazard,” but this is included in the general sense of data hazard. Data hazard is hazard originating from the difference of two cycles, those cycles being: the cycle where information necessary for the execution of an instruction is read from the register, and the cycle where the results of the execution are written to the register. There are various types of structural hazards, depending upon the structure of the pipeline processor. Basically, however, it is a hazard caused by insufficient hardware resources.
The pipeline processor reads the register information in the D stage, and writes to the register in the W stage. Here, it is assumed that instruction A, which stores process results in register 0, and instruction B, which uses the register 0. When the instruction A exists in the E stage, the subsequent instruction B exists in the D stage. When the instruction A cannot reach W stage, the results for the instruction A cannot be obtained, even if instruction B reads the register 0. This type of hazard is called a read after write hazard” (hereafter referred to as “RAW hazard”). In contrast, there is a “write after write hazard” (hereafter referred to as “WAW hazard”). The hazard overwrites the next instruction after the first instruction for a register has been written.
Structural hazard occurs in events such as two requests for readout from a memory device that has only one readout port. In this event, since the memory cannot process more than one demand at a time, it is necessary for one request or the other to wait. A solution is possible when using memory capable of simultaneously processing two requests for a readout. However, as the hardware scale increases, this can cause a decrease in operation speed.
To resolve data hazard, “stall” or “interlock” can halt the succeeding instruction executions. As for other resolutions, there is one method that sets the hardware to send data to the succeeding instructions before the preceding instructions reach W Stage. This is known as data “bypass” or “forwarding”. Data hazard of a pipeline processor is typically resolved by a combination of stall and data bypass.
For efficient instruction execution, it is necessary to control optimum stall and bypass in the pipeline structure. However, this control depends greatly on the pipeline structure. For example, the control of stall and bypass meant to execute efficient instructions becomes unusually complex (1) when there are multiple pipelines for instruction execution, (2) each pipeline has a different number of execution stages, and (3) in a complex processor that changes the number of execution stages depending on the operation data.
Alternatively, as a way where the user expands optional instructions, there is a known method that connects the device (hereinafter referred to as “user customizable instruction unit”) executing instructions defined by the user (hereinafter referred to as “user customizable instruction”) to the processor core.
With a classical pipeline processor, when the number of execution stages for the user customizable instruction is longer than the execution pipelines in the processor core, an exception may occur during the following stages of the pipeline. In this event, until it has been confirmed whether or not there is an exception, instructions following the user customizable instruction stop the execution of instructions in order to avoid changing the condition of the processor. Consequently, a problem arises with lowered efficiency in instruction execution.
As a method of hazard detection in pipeline processors which include a user customizable instruction unit, stall control utilizing score-boarding is used. The score-boarding device is configured from the device storing the information concerning the instructions in each of the pipelines and stages, and the hazard detection device, itself dependent on the instruction set and pipeline structure. The score-boarding device tends to be very complex, even though the circuit scale is small. There are also methods which use a reorder buffer in pipeline processors not fitted with a user customizable instruction unit.
Nevertheless, in instruction customizable processors, the processor itself and the defined instructions increase in complexity, complicating the score-boarding device. Also, in pipeline processors including a score-boarding device, when a user customizable instruction is added, the pipeline structure executing the added user customizable instruction changes depending upon the user definition. Consequently, for the efficient execution of instructions, it becomes necessary to change the design of the score-boarding device and increase the development period. It is possible to do without the change in the score-boarding device when efficient execution of instructions is unnecessary. However, instruction execution efficiency is adversely affected. In recent years, the speed of pipeline processors with user customizable instruction units has been advancing. It is hoped that, rather than implementing highly complex score-boarding devices, there can be a method established to improve reliability.
Until recently, in regards to methods of improving instruction execution efficiency, pipeline processors without user customizable instruction units utilized reorder buffers.
However, the purpose of using existing reorder buffers is to complete things like instructions issued out-of-order and instructions issued simultaneously in super scalar processors.
An aspect of the present invention inheres in a pipeline processor encompassing, an instruction decode unit configured to decode fetched instruction, and to selectively issue one of a user customizable instruction defined by a user and a core instruction, a core instruction execution unit configured to execute the issued core instruction, a user customizable instruction unit configured to execute the issued user customizable instruction, and a reorder buffer configured to temporarily store instruction execution results of the core instruction execution unit and the user customizable instruction unit, and to reorder the instruction execution results in accordance with an order in which the core instruction and the user customizable instruction were issued.
Another aspect of the present invention inheres in a pipeline processor encompassing, an instruction decode unit configured to decode fetched instruction, and to issue an instruction, an instruction execution unit configured to execute the issued instruction, a reorder buffer configured to temporarily store instruction execution results of the instruction execution unit, and to reorder the instruction execution results in accordance with an order in which the instruction was issued, and a timeout controller configured to count clock cycles required for execution of the issued instruction, and to generate a timeout when a count result exceeds a fixed value.
Sill another aspect of the present invention inheres in a method for automatically designing a pipeline processor including an instruction decode unit configured to decode fetched instruction, and to issue an instruction, an instruction execution unit configured to execute the issued instruction, and a reorder buffer configured to temporarily store instruction execution results of the instruction execution unit, and to reorder the instruction execution results in accordance with an order in which the instruction was issued, the method encompassing, acquiring a meta hardware description defining an arrangement and a function of the pipeline processor, acquiring configuration information for adding or a removing hardware description regarding the meta hardware description, and generating a hardware description for the pipeline processor from the meta hardware description in accordance with the configuration information.
Various embodiments of the present invention will be described with reference to the accompanying drawings. It is to be noted that the same or similar reference numerals are applied to the same or similar parts and elements throughout the drawings, and description of the same or similar parts and elements will be omitted or simplified. In the following descriptions, numerous specific details are set forth such as specific signal values, etc. to provide a thorough understanding of the present invention. However, it will be obvious to those skilled in the art that the present invention may be practiced without such specific details. In other instances, well-known circuits have been shown in block diagram form in order not to obscure the present invention with unnecessary detail. In the following description, the words “connect” or “connected” defines a state in which first and second elements are electrically connected to each other without regard to whether or not there is a physical connection between the elements.
As shown in
The processor core 4a includes an instruction fetch unit 400, an instruction decode unit 401a, a core instruction execution unit 40, a register file 408a, a reorder buffer 406a, a reorder buffer controller 407a, an instruction cache 410, a data cache 412, a bus interface (hereinafter abbreviated as “bus I/F”) 411, and a bypass network 409a.
The instruction decode unit 401a decodes the instruction fetched by the instruction fetch unit 400, and selectively issues either a core instruction or a user customizable instruction defined by the user. The core instruction execution unit 40 executes the issued core instruction. The user customizable instruction unit 402a executes the issued user customizable instruction. The reorder buffer 406a temporarily stores the instruction execution results for both the core instruction execution unit 40 and the user customizable instruction unit 402a. The reorder buffer 406a reorders the instruction execution results in accordance with the order in which the core instruction and user customizable instruction were issued. The core instruction execution unit 40 and the user customizable instruction unit 402a configure an instruction execution unit 1a.
The term “core instruction” refers to instructions previously prepared for the processor core 4a. A floating point instruction, an integer instruction, a branch instruction, and a load/store instruction are core instruction, for instance. The number of instruction execution cycles for core instructions is fundamentally a fixed value. A digital signal processor (DSP), a coprocessor, or a combination of these can be utilized as the user customizable instruction unit 402a. The following will explain an example using a DSP as the user customizable instruction unit 402a. In this case, DSP instructions are used as user customizable instructions. The execution cycle of the DSP instructions will change depending on operation data. The number of instruction execution cycles in the DSP instruction is a variable value.
The external memory 41 includes a random access memory (RAM) 413 and a read only memory (ROM) 414. The ROM functions as a program memory storing each instruction executed by the pipeline processor. The RAM functions as a program memory storing each instruction executed in the pipeline processor. The RAM can temporarily store data used during the instruction execution process in the pipeline processor, or it may function as temporary data memory used as work area.
The bus I/F 411 arbitrates both data transmission requests sent from the core instruction execution unit 40 through the data cache 412, and instruction transmission requests sent from the instruction fetch unit 400 through the instruction cache 410. On the results of the arbitration of these two requests, the bus I/F 411 transmits requests to the external bus 450, and transmits and receives data with the external memory 41.
The bus I/F 411 also receives instructions and data read from external memory 41. The bus I/F 411 transmits the data to the data cache 412 and the instructions to the instruction cache 410.
The instruction cache 410 transmits a transmission request to the bus I/F 411 and accepts the instruction transmitted from the bus I/F 411. The data cache 412 transmits a transmission request to the bus I/F 411 and accepts the data transmitted from the bus I/F 411.
The instruction fetch unit 400 transmits a bus request through the instruction cache 410 to the bus I/F 411. The bus request acquires the instruction, which is to be the object of execution by the core instruction unit 40 and the user customizable instruction unit 402a. When the instruction fetch unit 400 receives data from bus I/F 411, the instruction fetch unit 400 transmits the received data to the instruction decode unit 401a as an instruction to be executed.
The instruction decode unit 401a, when the instruction from the instruction fetch unit 400 is a core instruction, decodes the core instruction. The instruction decode unit 401a outputs a control signal that controls the core instruction execution unit 40. When the instruction from the instruction fetch unit 400 is a user customizable instruction (DSP instruction), the decoding of the user customizable instruction (DSP instruction) is handled by a decoder (not illustrated) created within the user customizable instruction unit 402a.
The register file 408a includes multiple registers, and stores the pipeline processor condition and the operation results. The multiple registers of the register file 408a are general-purpose registers used to execute programs. The register file 408a includes first and second readout control ports R0 and R1, first and second readout ports RD0 and RD1 for outputting readout results, and write back-use port W for inputting the results of the execution of instructions that are subject to write back.
A request from the instruction decode unit 401a is input to the first and second readout control ports R0 and R1 of the register file 408a. The request is for a general-purpose register number, required for the execution of instructions.
The following is input to the bypass network 409a: data read from the first and second readout ports RD0 and RD1 of the register file 408a, data read from the first and second readout ports RD0 and RD1 of the reorder buffer 406a, the immediate data of the instruction transmitted via a data line 464a from the instruction decode unit 401a, and the results of the decode of the user customizable instruction transmitted via a data line 463 from the user customizable instruction unit 402a. Consequently, the data necessary to the execution of the instruction is either bypassed or selected, and output to the user customizable instruction unit 402a and the core instruction execution unit 40.
The reorder buffer controller 407a controls the reorder buffer 406a. The reorder buffer 406a includes multiple memory devices for storing the result of instruction execution (each memory device inside the reorder buffer 406a is referred to as “entry” hereinafter). The results of the execution of either user customizable instructions (DSP instructions) or core instructions are written to multiple entries via four write ports (first to fourth write ports W0 to W3). Furthermore, a reorder buffer capable of y simultaneous writing is a reorder buffer with y write ports (y is an integer greater than or equal to 2). Writing the results of instruction execution to the reorder buffer 406a is called “completion”.
Further, the reorder buffer 406a is equipped with two readout control ports (the first and second readout ports R0 and R1) and two readout ports (the first and second readout ports RD0 and RD1).
When an instruction is executed, the instruction decode unit 401a transmits a reorder buffer 406a entry reservation request to reorder buffer controller 407a. Consequently, an empty entry in the reorder buffer 406a is reserved. The reorder buffer controller 407a posts the reserved entry's number as a tag number to the reorder buffer 406a. As a result, after each executed instruction is allocated a tag number, the results of the instruction execution are written to the entry with the corresponding tag number.
The reorder buffer controller 407a outputs the results of instruction execution according to the order in which they were executed. This is carried out by controlling the “first in, first out” (FIFO) of completed instruction execution results. Consequently, The reorder buffer 406a, based on the order that the entries were reserved via requests from the instruction decode unit 401a, outputs instruction execution results to the register file 408a via the data line 460. This operation is called “commit processing.”
When there are no empty entries in the reorder buffer 406a, since instructions cannot be executed, the reorder buffer controller 407a outputs a stall request to the instruction decode unit 401a via the data line 456. The instruction decode unit 401a receives the stall request from the reorder buffer controller 407a and, by stalling D stage of the pipeline, halts the execution of instructions.
When the writing of entry instruction execution results is not yet being handled, the reorder buffer 406a does not carry out commit processing until the writing is completed. Also, the reorder buffer 406a, by emptying those entries which have completed commit processing, assumes a state that can be used by a subsequent entry reservation.
Further, the core instruction execution unit 40 includes the following: a floating point unit (FPU) 403, an integer instruction and branch instruction execution unit (IBU) 404 and a load instruction and store instruction execution unit (LSU) 405.
The IBU 404, as shown in FIGS. 2(c) and 2(b), executes integer instructions and branch instructions. The FPU 403, as shown in FIGS. 2(e) and 2(f), executes floating-point instructions. The LSU 405, as shown in FIGS. 2(g) and 2(h), executes load instructions and store instructions.
The core instruction process and the user customizable instruction process have the following three points in common: the F stage shown in
D stage of the core instruction, as shown in
In detail, the instruction decode unit 401a decodes the core instruction and generates the following information: whether the instruction will be the target of the core instruction's timeout, whether the instruction will necessitate write back to the register file 408a, and whether there is the possibility of generating an exception. This information is transmitted to the reorder buffer 406a via the data line 461a.
In contrast, the user customizable instruction unit 402a decodes the user customizable instruction (DSP instruction) and generates information on whether or not the instruction will necessitate write back to register file 408a and whether there is the possibility of generating an exception. This information is then transmitted to the reorder buffer 406a via the data line 462.
Also, the user customizable instruction unit 402a, the FPU 403, the IBU 404 and the LSU 405 each complete the execution of instructions and write the execution results to the reorder buffer 406a.
Specifically, the instruction execution results for the LSU 405, as shown in
Also, the instruction execution results for the IBU 404 are transmitted to the second write port W1 of the reorder buffer 406a via the data line 458. The instruction execution results for the IBU 404 include: execution results data, signals indicating the validity of execution results data, signals indicating the generation of an exception, and instruction tag numbers.
Here, an “exception” is generated when, for example, in a division operation, zero is divided. When this occurs, the execution of the division instruction is halted, and the exception process program is executed. After solving the zero division problem, and when the division instruction is restarted in order to recommence the process of the program, it becomes impossible to accurately restart the execution of the program itself. This is because instructions succeeding the division instruction have already been executed, so succeeding instructions are executed twice.
Therefore, when the signal indicates the generation of an exception, the reorder buffer 406a, at the time of completion, discards the entry where the exception-generating instruction execution results are stored. Therefore, commit processing is not performed on execution results stored in the discarded entry.
Also, when the instruction execution results are discarded, all succeeding instruction execution results are discarded as well. All instructions succeeding the instruction generating the exception are discarded. In order to preserve the processor condition, a “precise exception” process can occur.
Further, the reorder buffer 406a, as shown in
The following, referencing the time chart in
In cycle 0 of
In cycle C1 of
In cycle C2 of
In cycle C3 of
In cycle 4 of
In this way, by have each of F stage, D stage, E1 stage, E2 stage, and W stage acting independently, before each stage completes one integer instruction, the next integer instruction process is commenced in parallel. Consequently, the pipeline processor in
The following, referring to the time chart in
In cycle C0 of
In cycle C1 of
In cycles C2 and C3 of
In cycle C4 of
Load instructions 2 to 5, shown in
In accordance with the above, the pipeline processor shown in
As shown in FIGS. 5(b) and 5(d) (Core) instruction 1 and 2, processed by each of F stage, D stage, E stage, M stage, and W stage, are defined. Further, as shown in
Because there are four cycles in the execution cycle of the user customizable instruction (DSP instruction) shown in
When the reorder buffer 406a shown in
On the other hand, when the reorder buffer 406a shown in
The following, referring to the time chart in
The user customizable instruction (DSP instruction) shown in
Both the user customizable instruction (DSP instruction) shown in
Again, the load instruction shown in
The following, using
Bit numbers 0 to 15 are immediately allocated. When the user has defined an optional user customizable instruction (DSP instruction), it is used immediately. For example, by using the discrimination of the user customizable instruction (DSP instruction) into the highest four bits (bit numbers 12 to 15), it is possible to define 16 user customizable instructions (DSP instructions).
Bit numbers 16 to 19 are allocated into the minor op-code. The minor op-code of the user customizable instruction (DSP instruction) is “0011”. Both register number Rm and register number Rn are the numbers for the registers used in the operation. They each indicate a single general purpose register within the register file 408a shown in
Bit numbers 20 to 23 and bit numbers 24 to 27 are allocated to register number Rn and register number Rm, respectively. Bit numbers 28 to 31 are allocated to the major op-code. The major op-code of the user customizable instruction (DSP instruction) is “1111”.
Further, the data line 452, which connects the instruction decode unit 401a and the user customizable instruction unit 402a (as shown in
In table 1, the signal “medpDRobIndex” refers to entry number for the reorder buffer for the user customizable instruction. The signal “medpDCode” refers to value of the immediate and operand (Rm, Rn) use bit field. The signal “medpDValid” refers to a signal indicating the value of “medpDCode” is valid. The signal “dpmeDBusy” refers to a signal indicating the user customizable instruction unit cannot accept an instruction. The signal “medpERmData” refers to value of operand Rm. The signal “medpERnData” refers to value of operand Rn. The signal “dpmeDOpUse” refers to a signal indicating whether operand is in use. The signal “dpmeDReExPossibility” refers to a signal indicating whether write back is necessary. The signal “dpmePAck” refers to a signal reporting completion of user customizable instruction to the processor core. The signal “dpmePRobIndex” refers to entry number for the reorder buffer of the completed instruction. The signal “dpmePResultData” refers to value of the user customizable instruction execution results. The signal “dpmePValid” refers to a signal indicating whether value of dpmePResultData is valid. The signal “dpmePExcept” refers to a signal indicating generation of an exception in the user customizable instruction.
Moreover, the code [A:B] for bit width shown in Table 1 indicates a bit width from bit B to bit A. For example, the bit width [2:0] for the signal “medpDRobIndex” indicates three bits width from bit 0 to bit 2. The “Direction [I/O],” shown in Table 1 indicates the following: when the symbol is “I” data (signal) has been transmitted from the user customizable instruction execution unit 402a to the processor core 4a, and when the symbol is “O,” data (signal) has been transmitted from the processor core 4a to the user customizable instruction unit 402a.
For example, when the user defines sixteen instructions using the highest four bits shown in
The user customizable instruction unit 402a, depending on the allocation results of the user customizable instruction, generates the “dpmeDOpUse” signal shown in table 1. The “dpmeDOpUse” signal is a 2-bit signal showing whether the user customizable instruction is using register numbers Rm and Rn. When either register number Rm or Rn is being used, the corresponding bit becomes 1. When neither is being used, the corresponding bit becomes 0. For example, when the signal “dpmeDOpUse” is “11” in binary code, it indicates the instruction is using both register numbers Rm and Rn. When the signal “dpmeDOpUse” is “00” in binary code, it indicates that neither register number Rm nor Rn is being used.
The instruction execution results for the user customizable instruction unit 402a are transmitted to the fourth write port W3 of the reorder buffer 406a via the data line 455. Included in these instruction execution results are, as shown in table 1, the following: the execution results data “dpmePResultData”, the signal indicating the validity of the data “dpmePValid,” the signal indicating the generation of an exception “dpmePExcept”, and the instruction tag number “dpmePRobIndex”.
Further, the reorder buffer 406a, as shown in
Each entry includes the following: a 1-bit R flag, a 1-bit C flag, a 1-bit T flag, a 1-bit W flag, a 1-bit E flag, a 5-bit RFN field, a 32-bit WDATA field, and a 32-bit PC field.
As an example, the “R flag” of the first entry E1 indicates whether the first entry E1 currently in use. Therefore, when the logic value of R flag is “1”, first entry E1 is currently in use, and when the logic value is “0,” first entry E1 is not currently in use.
Further, the “V flag” of the first entry E1 indicates whether instruction execution results allocated to the first entry E1 have been written. When the logic value of the V flag is “1,” it indicates that the instruction execution results allocated to the first entry E1 have been written. When the logic value is “0,” it indicates that they have not been written.
The “T flag” of the first entry E1 indicates if the instructions allocated to the first entry E1 have been targeted for a timeout. When the logic value of the T flag is “1,” it indicates that the instructions have been targeted for a timeout. When the logic value is “0,” it indicates that they have not been targeted for a timeout.
The “W flag” of the first entry E1 indicates whether it is necessary to write back the instructions allocated to the first entry E1 to the register file 408a. When the logic value of the W flag is “1”, it indicates that a write back of the instructions is necessary. When the logic value is “0,” it indicates that a write back is not necessary.
The “E flag” of the first entry E1 indicates whether the instructions allocated to first entry E1 are capable of generating an exception. When the logic value of the E flag is “1,” it indicates that the instructions are capable of generating an exception. When the logic value is “0,” it indicates that they are not capable of generating an exception.
The “RFN field” of the first entry E1 indicates the register number for the updated register file 408a, depending on the instructions allocated to the first entry E1. The “WDATA field” of the first entry E1 is a field where the execution results of the instructions allocated to the first entry E1 are stored. The “PC field” of the first entry E1 is a field where the program counter for the instructions allocated to the first entry E1 is stored. Second to Eighth entries E2 to E8 are all compiled in a manner identical to that of the first entry E1.
Further, the reorder buffer controller 407a primarily includes a first counter 602, used in commit processing, and a second counter 603, which generates tag numbers. As an example, both the first counter 602 and the second counter 603 have a bit length of 3 bits. Therefore, they are capable of expressing 8 pattern values. As such, in decimal code, a value of “7” and a value or “1” when added, would become “0”.
The instruction decode unit 401a executes an instruction and, in the succeeding cycle, increases the value of the second counter 603 by 1. The value of the second counter 603 is used as a tag number, which is transmitted to the reorder buffer 406a via the data line 451, both shown in
Depending on the instruction decode unit 401a, an instruction is issued and the logic value of the R flag for the entry assigned by the second counter 603 is set to “1”. Also, the register number of the register file 408a, updated by the issued instruction, is set to the RFN field of the entry assigned by the second counter 603.
Further, when the issued instruction necessitates write back, the logic value of the W flag for the entry assigned by the second counter 603 is set to “1”. In contrast, when the issued instruction does not necessitate write back, the logic value of the W flag is set to “0”.
When the issued instruction is capable of generating an exception, the logic value of the E flag for the entry assigned by the second counter 603 is set to “1”. When the issued instruction is not capable of generating an exception, the logic value of the E flag is set to “0”.
As an example, when the issued instruction is a user customizable instruction (DSP instruction), the logic value of the T flag for the entry assigned by the second counter 603 is set to “1”. When the issued instruction is a core instruction, the value set for the T flag differs, depending on the type of core instruction.
The reorder buffer 406a generates completion unaccompanied by the generation of an exception and writes execution results to the WDATA field of the entry assigned by the second counter 603. Also, the logic value of the V flag is set to “1”.
The reorder buffer 406a, when the entry assigned by the first counter 602 has an R flag logic value of “1” and a V flag logic value of “1,” outputs a request to the register file 408a. This request is for the writing of WDATA field data to the register number indicated by the RFN field. This process is the aforementioned “commit processing”.
The reorder buffer 406a, in the cycle succeeding commit processing, sets the entry's R flag, V flag, and T flag logic value to “0”. When an exception has been generated, in descending order from the value of the first counter 602, the entry ending in the counter value of the second counter 603 is scanned, and the logic value of that R flag is set to “0”. Then, the value of the second counter 603 is set to that of the first counter 602. Consequently, the execution results for instructions succeeding the instruction that generated an exception are discarded. It is then possible to perform the precise exception process.
Following is an explanation of the timeout controller 604 shown in
Systems which produce hang-up caused by a bug in the hardware or programming are unreliable. The system's overall security becomes especially difficult as the processor reliability becomes dependent upon the function definition of a user customizable instruction and upon the user customizable instruction unit 402a which executes that user customizable instruction.
Further, in the stages of hardware and program development, if hang-up is produced due to a bug, the time necessary to debug is increased. This is because, outside of a reset, there is no way to restart the processor's instruction execution. Further, because a debugger cannot be used to investigate the conditions at the time of hang-up, it takes time for bug analysis.
The timeout controller 604 shown in
A user customizable instruction executed by the user customizable instruction unit 402a cannot complete its execution if a completion request is not sent from the user customizable instruction unit 402a. Consequently, if a completion request is not sent, the moment the entry for the reorder buffer 406a becomes full, instruction execution becomes impossible. This indicates the halt of the processor.
The timeout controller 604 monitors the entry assigned by the first counter 602, and when completion cannot be generated within the fixed cycle period, causes an exception to be generated. The following is an explanation of the process that causes the generation of an exception.
The timeout controller 604 commences the count of the number of clock cycles when the logic value of the T flag and the R flag for the entry assigned by the count value of The first counter 602 is set to “1”, and the logic value of the V flag for the same is set to “0”. If the logic value of the V flag becomes “1”, the count is halted.
As an example, if the count of the number of clock cycles exceeds 4096, the timeout controller 604 processes the instruction of the entry assigned by the first counter 602 as if it had generated an exception.
Moreover, the number of clock cycles that becomes a criterion for the generation of a timeout process is not limited to the previous example of 4096 cycles. For example, 8192 clock cycles, 16384 cycles, etc. can become a criterion. The editing of the number of clock cycles is possible when using the meta hardware described below. By using the value set in the special register of the register file 408a as the number of clock cycles that become the criterion for generating a timeout process, it is also possible to use the value established in the program by the user.
As described above, according to the first embodiment of the present invention, by using, not the score-boarding method, but the reorder buffer 406a, it is possible to offer a pipeline processor capable of: efficient execution of instruction groups which include user customizable instructions (DSP instructions) with an optional execute cycle; and capable of user customizable instructions with a high degree of freedom in regards to the number of execution cycles and exception generation. Consequently, because the complexity of the pipeline processor has been lessened, high speed operations are possible, and a highly reliable pipeline processor can be configured. Further, because the timeout controller 604 can generate a timeout process, it is possible to further enhance the reliability of the pipeline processor.
As shown in
Stored in the memory unit 102 is the following: the “configuration information”, which is the hardware description that described such things as the conditions of configuration and function in the process being designed; and the “meta hardware description,” which adds or removes hardware description according to the configuration information.
Based on the configuration information and the meta hardware description, the hardware description of the processor being designed is configured. In this way, the processor being designed is called a “configurable processor”. The configurable processor, according to the configuration information, is designed depending on the processor design device, which automatically adds or removes hardware description.
By using the meta hardware description it is possible to add or remove hardware description according to the user's demands. However, doing so increases the cost of function verification. For example, there are eight parameters as configuration information. When each of those parameters takes a value of “1” or “0,” it is possible to design a circuit that has a difference of factor 2 of 8, that is, a 256 pattern. Recently, even assuming function verification was made automatic, 256 times the calculation time is necessary.
When reducing calculation time, depending on the limits of dependant relationships between parameters and the reduction of the number of parameters, the elimination of verification space becomes necessary. To the degree that hardware configuration and operation is concise, it is possible to eliminate verification space. In the score-boarding device described previously, because hardware configuration and operation is complex, in order to eliminate the time necessary to verify function, it is common for limits to be placed on things like the function of the score-boarding device.
In contrast, with the pipeline processor shown in
The meta hardware description, as shown in
The processor 101 shown in
Following is a description of the processor design method relating to the Modification of the First Embodiment of the Present Invention, referencing the flowchart shown in
Furthermore, the Description D1 shown in
Description D4 is the description called the default item. The default item is chosen when, in the case statement, there is not a single input signal enumerated other than the default item. For example, in
When the “%if OP_USE_DSP” parameter for the configuration information is set to “true”, it indicates the use of the user customizable instruction (DSP instruction). When the “%if OP_USE_DSP” parameter for the configuration information is set to “false”, it indicates the user customizable instruction (DSP instruction) is not used.
In Step S01, the Pre-processor 1011 shown in
In Step S02, the logic synthesis unit 1011 executes meta control language and implements hardware description for the processor being designed. Specifically, when the “%if OP_USE_DSP” parameter for the configuration information obtained in Step S01 is “true”, as shown in
Conversely, when the “%if OP_USE_DSP” parameter for the configuration information obtained in Step S01 is “false,” as shown in
In Step S03, the logic synthesis unit 1012 shown in
Further, if the meta hardware description shown in
Description D5, shown in
Description D6, shown in
As described above, in the method of designing the processor in the modification of the embodiment of the present invention, by automatically implementing hardware description according to configuration information, it is possible to easily obtain the most appropriate hardware description. Consequently, instead of using the score-boarding method, user customizable instructions with a high level of freedom in regards to number of execution cycles and exception generation are possible. It is also possible to design pipeline processors with efficiently executable instruction groups which include user customizable instructions (DSP instructions) with optional execution cycles.
The pipeline processor in the second embodiment of the present invention, as shown in
Basically, the instruction decoder can easily become the critical pass which decides the maximum clock frequency of the processor. When the user customizable instruction unit 402a, shown in
In
Also, in
As shown in
Conversely, in
In table 2, the signal “medpDRobIndex” refers to number of the user customizable entry. The signal “medpDCode” refers to value of the immediate value and operand-use (Rm, Rn) bit field. The signal “medpDValid” refers to a signal indicating that the value of medpDCode is valid. The signal “dpmeDBusy” refers to a signal indicating that user customizable instruction unit cannot accept an instruction. The signal “medpERmData” refers to value of Operand Rm. The signal “medpERnData” refers to value of Operand Rn. The signal “dpmePAck” refers to a signal notifying the processor core of user customizable instruction completion. The signal “dpmePRobIndex” refers to number of the completed instruction's reorder buffer entry. The signal “dpmePResultData” refers to value of user customizable instruction execution results. The signal “dpmePValid” refers to a signal indicating value of dpmePResultData is valid. The signal “dpmePExcept” refers to a signal indicating the generation of an exception by the user customizable instruction.
The “dpmeDOpUse” signal generated by the instruction decode unit 401b is transmitted to the bypass network 409b via data line 464b, shown in
Also, the first embodiment uses the method of generating exceptions as a timeout process. However, the second embodiment uses interrupt as a timeout process. The register file 408, shown in
In the same manner as the first embodiment, the timeout controller 604 and the reorder buffer 406b, both shown in
Following is a description of the procedure for the interrupt process for the reorder buffer 406b. The reorder buffer 406b generates a timeout, the instruction's entry V flag is set to a logic value of “1”, and the instruction is completed. The execution results for the instruction become in an invalid value. Consequently, the entry's WDATA flag becomes an invalid value, but if the logic value for that entry's W flag becomes “1”, the write back procedure to the register file 408b commences. Also, the instruction decode unit 401b, in accordance with the interrupt request from the reorder buffer 406b, begins an interrupt for an instruction that differs from the one that generated timeout.
As described above, according to the second embodiment of the present invention, it is possible to solve the critical bus problem by the decoding of one part of the user customizable instruction (DSP instruction) by the instruction decode unit 401b. Consequently, compared to the pipeline processor shown in
As for the Modification of the second embodiment of the present invention, following is a description of the method of process design for the pipeline processor in
By using the configuration information as shown in
Various modifications will become possible for those skilled in the art after receiving the teachings of the present disclosure without departing from the scope thereof.
In the aforementioned modification was a description of one exemplary usage of the DSP as the user customizable instruction units 402a and 402b, and of the DSP instruction as a user customizable instruction. However, it is acceptable to use, for example, a coprocessor as user customizable instruction units 402a and 402b.
Relating to the aforementioned Modification, it is acceptable to configure the pipeline processor as a reconfigurable processor. A “reconfigurable processor” indicates a processor where, by using the technique represented in field programmable gate array (FPGA), dynamic configuration of processor functions is possible. In order to design a reconfigurable processor, it is possible to use the same procedure as the processor design method relating to the aforementioned Modification.
Number | Date | Country | Kind |
---|---|---|---|
2005-217789 | Jul 2005 | JP | national |