1. Field of the Invention
The present invention relates to an integrated circuit, and more particularly, to an integrated circuit design system for designing an application-specific integrated circuit (ASIC).
2. Description of the Prior Art
In accordance with the rapid development of electronic technologies, many complicated circuits can be integrated into an integrated circuit (IC) to save space in an electronic apparatus having complicated design. Integrated circuit design systems are used to design ICs.
Please refer to
According to the scenario described above, a netlist such as an Nth netlist shown in
It is therefore a primary objective of the claimed invention to provide an integrated circuit design system to solve the drawbacks of the prior art.
According to the claimed invention, the integrated circuit design system includes a second interface for displaying a plurality of description instructions corresponding to an application-specific integrated circuit (ASIC) according to a variety of display instructions, a first interface for inputting the display instructions and for updating the description instructions displayed on the second interface according to the display instructions, and a logic unit for updating any description instruction but an updated description updated by the first interface corresponding to the ASIC according to the updated description instruction.
These and other objectives of the claimed invention will no doubt become obvious to those of ordinary skill in the art after reading the following detailed description of the preferred embodiment that is illustrated in the various figures and drawings.
Please refer to
In general, in a process of designing an ASIC 50, a plurality of the elementary cells 14 installed neighboring to one another can be arranged to form a macro cell having a specific function. Please refer to
Please refer to
The first interface 22 is installed for a user to input display instructions and to update information related to ASIC 50 of a variety of reports, such as a netlist, a noise analysis report, a power analysis report, and a timing slack report, etc.
The logic unit 24 is installed to execute a variety of processes, such as a placement & routing process, a clock tree synthesis process, a timing optimization process, and a cell and wire delay extraction process, etc., on the integrated circuit chip 10 according to the information updated through the first interface 22 by the user, and to further generate an updated netlist, an updated noise analysis report, an updated power analysis, an updated timing slack report, and an updated cell and wire delay extraction report.
In operation, for example, if a netlist of the ASIC 50 has been updated by a logic designer with the use of the first interface 22, then the logic unit 24 will execute the placement & routing process, the clock tree synthesis process, the timing optimization process, and the cell and wire delay extraction in accordance with the updated netlist, and generate a variety of information relating to the ASIC 50, such as the updated noise analysis report, the updated power analysis, the updated timing slack report, and the updated cell and wire delay extraction report, according to the updated netlist. In another example, if what the logic designer has updated through the use of the first interface 22 is circuit component information of the timing slack report of the ASIC 50, the logic unit 24 will generate another updated noise analysis report, another updated power analysis, another updated netlist, and another updated cell and wire delay extraction according to the updated circuit component information of the timing slack report, and all of the updated noise analysis report, the updated power analysis, the updated netlist, and the updated cell and wire delay extraction relating to the updated circuit component information of the timing slack report. Equivalently, the integrated circuit design system 20 transforms the ASIC 50 into a core database consisting of the above-mentioned information, any updated information of the core database providing an influence on the remaining information.
In the core database, the timing slack report comprises a plurality of timing slack information, each of which comprises a plurality of timing slacks Sss, each of the timing slacks Sss equal to a required time Rs, within which a signal S has to be stabilized, minus an arrival time As, the time for the signal S to be stabilized. If the timing slack Ss is positive, the signal S has been stabilized before arriving at other circuits, such as a latch capable of fetching the signal S during a rising edge of a driving clock, when the signal S has been stabilized. On the contrary, if the timing slack Ss is negative, the signal S is not stabilized during the rising edge of the driving clock and the latch has therefore a large chance of fetching a wrong signal S. The benefit of the logic unit 24 calculating the timing slack information is that the logic designer can update the netlist with the use of the first interface 22 in accordance with the timing slack information, and instantly acquire new timing slack information, which are calculated by the logic unit 24 and corresponding to the updated netlist, so as to promote the efficiency in designing the ASIC 50 and to reduce any potential errors that the ASIC 50 may have.
The second interface 26 is installed to display the varieties of information of the core database in accordance with the display instructions. These varieties of information comprise, for example, a netlist, an updated netlist, and a plurality of the netlist- or the updated netlist-related reports, such as a placement & routing report, a clock tree synthesis report, a timing optimization report, and a cell and wire delay extraction report, etc.
In the preferred embodiment, the second interface 26 only has to display the negative timing slacks Sss of the timing slack information calculated by the logic unit 24, instead of displaying all of the timing slack Sss, which consist of not only the negative timing slacks Sss, but also the positive timing slacks Sss, which correspond to signals which are not stable and have a large chance of induced errors, so as to reduce the complexity of the integrated circuit design system 20.
In the preferred embodiment, the first interface 22 can be a keyboard 22 or a mouse 22, and the second interface 26 can be a display panel 26, on which the above-mentioned information, such as the netlist and the timing slack report, can be displayed in the form of a window. Shown in
According to the prior art described previously, after updating a netlist according to timing slack information transferred from the physical designers, the logic designers are not able to refer to any physical circuit information corresponding to the timing slack information and cannot know immediately whether the timing slack problem corresponding to a physical circuit corresponding to the updated netlist is solved or not, so the logic designers and the physical designers still have to alternatively update the netlist in accordance with the timing slack information, update the physical circuit in accordance with the updated netlist, and calculate the timing slack information corresponding to the updated physical circuit.
However, according to the preferred embodiment of the present invention, the first interface 22 is capable of updating any information of the core database, which is in equivalent corresponding to the ASIC 50, the logic unit 24 is capable of updating the remaining information of the core database according to the updated information, and the display panel 26 is capable of displaying the noise analysis report on the noise analysis report window 32, the netlist on the netlist window 34, the layout of the ASIC 50 on the physical circuit window 36, and the timing slack report corresponding to the netlist of the ASIC 50 on the timing slack report window 38 in accordance with the display instructions input to the keyboard 22 or the mouse 22. The logic designers therefore are able to update the circuit component information shown on any one of the windows 32, 34, 36 and 38, without the need to ask for the help offered by the physical designers.
Please refer to Table 1, which contains a timing slack information TS shown in the timing slack window 38.
The timing slack TS is equal to a required time Rs minus an arrival time As, which is the sum of delay time of a plurality of components disposed along a data path. In Table 1, the arrival time As is equal to 0.54+0.18+0.07+0.06+0.15=1.0, and the timing slack TS is equal to 4.88−1.0=3.8. After a logic designer updates the netlist corresponding to the ASIC 50, the logic unit 24 will update a timing slack report, which includes the delay time of each of the components, the required time Rs, the arrival time As and the timing slack TS, corresponding to the updated netlist in accordance with the updated netlist. The logic designer can therefore input a set of specific display instructions to enable the second interface 26 to display the timing slack report window 38, to read on the timing slack report window 38 an updated timing slack report corresponding to the updated netlist. The logic designer can also update circuit component information shown in the timing slack report window 38 through the use of the first interface 22 to reduce the slack time TS by equivalently inserting an approximate component between two pieces of data path information, CGEN_A_PST/I—62/Y(NAND2x1) and CGEN_A_PST/I—23/Y(BUFx4) respectively corresponding to two delay times (0.18) and (0.07). Accordingly, the logic unit 24 will update the remaining information of the core database according to the updated circuit component information, and the logic designer can input certain display instructions to enable the second interface 26 to display the netlist window 34 or the physical circuit window 36, and can read the updated netlist shown on the netlist window 34 or execute the placement & routing process on the physical circuit shown on the physical circuit window 36.
In general, the timing slack report that the logic unit 24 generates in accordance with the execution on the placement & routing process, the clock tree synthesis report and the timing optimization report comprises much information. In order to accelerate the update to the timing slack report, the logic unit 24 of the system 20 further has a capacity to classify the timing slack report according to the contents of the timing slack report and divide a large timing slack report into a plurality of small timing slack reports. Therefore, more than one logic designer can cooperate to update the plurality of small timing slack reports at the same time. The logic unit 24 can classify the timing slack report by referring to the circuit components of the timing slack report or to the clock that the timing slack report corresponds.
According to the preferred embodiment, the logic unit 24 not only has the capability to calculate the noise analysis report, power analysis report and timing slack report corresponding to an updated netlist, the logic unit 24 is also capable of referring the updated circuit component information shown on any window and of updating the information shown on the remaining windows. As described previously, the logic designers can update the circuit component information of the timing slack information shown on the timing slack window 36, and at the same time the logic unit 24 will update the netlist and the physical circuit according to the updating process on the circuit component information of the timing slack information, the updated netlist and physical circuit will be shown on the netlist window 34 and the physical circuit window 36 respectively. Moreover, since the circuit is updated, the logic unit 24 will further update the information shown on the remaining windows, such as the timing slack report, the power analysis report and the noise analysis report, etc. In conclusion, the logic designers of the system 20 can select any window and execute the updating process on the circuit shown on the selected window, and the logic unit 24 of the system 20 will accordingly update the information shown on the remaining windows according to the updating process.
In general, since the IC chip 10 can consist of up to millions or tens of million elementary cells 14, the system 20 does not display all the elementary cells 14 on the display panel 26 in great detail. Instead, the system 20 displays on the display panel 26 only those elementary cells 14 and the interconnects 18 connecting the displayed elementary cells 14 which are corresponding to a netlist or a timing slack Ss according to the display instructions input to the first interface 22, for example clicking the mouse 22 to select the netlist shown on the netlist window 34.
For instance, when a logic designer selects a circuit description instruction in a netlist set consisting of a plurality of netlist instructions shown on the netlist window 34, a elementary cell 14 in a physical circuit consisting of a plurality of elementary cells shown on the physical circuit window 36, or circuit component information corresponding to a timing slack Ss in a timing slack report consisting of a plurality of timing slack Sss shown on the timing slack window 36 with the use of the mouse 22 by generating a corresponding display instruction, the system 20 will control the display panel 26 to highlight the circuit description instruction, the elementary cell 14, or the elementary cells 14 and the corresponding interconnects 18 of the IC chip 10 corresponding to the circuit component information corresponding to the timing slack Ss of the timing slack information according to the display instruction. In addition, the system 20 is capable of controlling the display panel 26 to display a plurality of spare cells 28 neighboring the highlighted elementary cells 14, the spare cells 28 being the elementary cells 14 not yet utilized by the system 20. Therefore, the logic designers can take a reference of the elementary cells, the interconnects 18 and the spare cells 20 and update the netlist to amend any design errors hid in the timing slack information corresponding to the ASIC 50.
Please refer to
In order to increase the readability of the system 20 further, the display panel 26 is capable of selectively displaying a variety of icons, each of the icons corresponding to a elementary cell 14 of the ASIC 50 and having a predetermined pattern corresponding to a predetermined function that the elementary cell 14 plays in the ASIC 50. For example, as shown in
In contrast to the prior art, the present invention can provide an integrated circuit design system capable of displaying all the information of the core database corresponding to the ASIC 50. Therefore, a logic designer can refer to the timing slack report or the function verification report and not only update the netlist, the logic designer can also acquire a variety of information relating to the ASIC 50, such as the placement & routing information and the updated netlist, so as to reduce the time to update the netlist and to increase the efficiency of designing the ASIC 50.
Following the detailed description of the present invention above, those skilled in the art will readily observe that numerous modifications and alterations of the device may be made while retaining the teachings of the invention. Accordingly, the above disclosure should be construed as limited only by the metes and bounds of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
093112925 | May 2004 | TW | national |