A controller is provided that is configured to receive a timing value for a static timing model and a timing value for an extracted timing model. The controller is further configured to determine whether the timing value for the extracted timing model falls within a permissible range of deviation from the timing value for the static timing model.
|
14. A method for testing an abstracted timing model, comprising the steps of:
comparing a first value that is responsive to a time required for a signal to propagate through a path represented by a first model of a circuit with a second value that is responsive to a time required for a signal to propagate through a path represented by a second model of the circuit, wherein the second model is an abstraction of the first model; and outputting a result of the step of comparing the first value and the second value.
17. A system for testing an abstracted timing model, comprising:
means for comparing a first value that is responsive to a time required for a signal to propagate through a path represented by a first model of a circuit with a second value that is responsive to a time required for a signal to propagate through a path represented by a second model of the circuit, wherein the second model is an abstraction of the first model; and means for outputting a result of the step of comparing the first value and the second value.
8. A method of testing an abstracted timing model, comprising the steps of:
receiving a reference timing value representative of a time required for a signal to propagate through a path represented by a first model of a circuit; receiving an extracted model timing value representative of a time required for a signal to propagate through a path represented by a second model of the circuit, wherein the second model is an abstraction of the first model; determining a difference between said reference timing value and said extracted model timing value; determining whether said difference is within a predetermined permissible range; and outputting an indication of success if said difference falls within said predetermined permissible range.
11. A computer program for testing an abstracted timing model, the computer program comprising:
a first code segment for receiving a reference timing value representative of a time required for a signal to propagate through a path represented by a first model of a circuit; a second code segment for receiving an extracted model timing value representative of a time required for a signal to propagate through a path represented by a second model of the circuit, wherein the second model is an abstraction of the first model; a third code segment for determining a difference between said reference timing value and said extracted model timing value; and a fourth code segment for outputting an indication of success if said difference falls within a predetermined permissible range.
1. A system for testing an abstracted timing model representative of an integrated circuit design comprising:
a controller; memory associated with said controller for storing electronic format instructions; said controller is configured to: receive a reference timing value representative of a time required for a signal to propagate through a path represented by a first model of a circuit; receive an extracted model timing value representative of a time required for a signal to propagate through a path represented by a second model of the circuit, wherein the second model is an abstraction of the first model; determine a difference between said reference timing value and said extracted model timing value; determine whether said difference is within a predetermined permissible range; and output an indication of success if said difference falls within said predetermined permissible range. 2. The system of
3. The system of
4. The system of
5. The system of
6. The system of
7. The system of
12. A computer program according to
13. A computer program according to
15. The method of
16. The method of
18. The system of
19. The system of
|
The present invention is directed to a system for testing integrated circuit designs and more particualrly, to a system for determining whether the deviation between a timing value for an extracted model representation of a circuit design falls within a permissible range from a timing value for a static model of the same circuit design.
In the design of integrated circuits, static timing tools such as Prime Time® by Synopsys® are commonly used to evaluate static timing models of a circuit prior to actual fabrication of the circuit in semiconductor material. As a part of pre-fabrication evaluation of a circuit design, a timing value for a static timing model representation of the circuit is determined and subsequently a timing value for an extracted model of the same circuit is determined. These timing values are then manually evaluated to determine whether or not the timing value of the extracted model falls within a predetermined range of the timing value for the static model of the circuit.
As a typical integrated circuit design incorporates tens of thousands to millions of gates and wiring traces, the process of analyzing an integrated circuit design using these typical techniques can be very time consuming as each signal path of the circuitry must be modeled and evaluated. Further, a great deal of manual intervention is required to compare the timing values and operation of the extracted timing model with the timing value and operation of the static timing model to determine whether or not the circuit design is successful
Other features and advantages of the present invention will become apparent from the following description, drawings and claims. The present invention provides a system and method for testing abstracted timing models. Briefly described, in architecture, one embodiment of the system, among others, can be implemented as follows.
A controller is provided that is configured by software instructions stored on memory. This controller is configured to receive a static model timing value and to receive an extracted model timing value. The controller is further configured to determine the difference between the static model timing value and the extracted model timing value and then to determine whether the difference is within a predetermined permissible range. If so, the controller outputs an indication of success if said difference falls within said predetermined permissible range.
The present invention can also be viewed as providing methods for testing abstracted timing models. In this regard, one embodiment of such a method, among others, can be broadly summarized by the following steps: receiving a static model timing value. Receiving an extracted model timing value and determining the difference between the static model timing value and the extracted model timing value. A determination is made as to whether the difference is within a predetermined permissible range. If the difference does fall within the predetermined permissible range, an indication of success/qualification is output.
Other systems, methods, features, and advantages of the present invention will be or become apparent to one with skill in the art upon examination of the following drawings and detailed description. It is intended that all such additional systems, methods, features, and advantages be included within this description, be within the scope of the present invention, and be protected by the accompanying claims.
Many aspects of the invention can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present invention. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
The present invention provides a system and method for evaluating an integrated circuit (IC) design to determine whether or not the IC design meets predetermined criteria. More particularly, the present invention provides for evaluating an integrated circuit design to determine whether, for a given input signal, the integrated circuit design will allow the input signal to propagate through the integrated circuit within a permissible range of time.
The software 105 (FIG. 1), comprises an ordered listing of executable instructions for implementing logical functions, and can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions. In the context of this document, a "computer-readable medium" can be any means that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer-readable medium can be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a nonexhaustive list) of the computer-readable medium would include the following: an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical). Note that the computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via for instance, optical scanning of the paper or other medium then compiled, interpreted or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory.
In one embodiment, Verilog hardware description language (Verilog) may be utilized to create this behavioral description. Verilog is a hardware description language commonly used to design and document electronic circuits and systems. Verilog allows a designer to design to various levels of abstraction. Once the behavioral description is input, a Verilog format data file representative of the circuit is generated based on the input behavioral description (204). A Verilog format data file representative of a circuit may be generated by using, for example, a synthesis engine such as that provided by, for example, Design Compiler® by Synopsys, Inc. The synthesis engine, allows a designer to input behavioral descriptions of the circuit design that are then translated into an initial structural model representing the various gates and connective conductors comprising the circuit. This structural model may be represented in, for example, Verilog format (Verilog format data)
An artwork database is then generated based on the initial structural model (206). The initial structural model is used as the basis for creating an artwork database representative of the layout of the circuit described by the initial structural model. This artwork database represents a graphical representation of the layout of various blocks (components) and traces (connective conductors) necessary to physically implement the data path circuit via known IC fabrication techniques. The artwork database essentially describes the physical size and location of components and conductive tracing that will comprise the integrated circuit once it is fabricated using known semiconductor fabrication techniques. This artwork database may be created, for example, by using a place and route tool such as that provided by, for example, Silicon Ensemble® by Cadence Design, Inc.
Once the artwork database is created, a design rules check may be carried out to ensure that the circuit layout described by the artwork database does not violate predetermined rules and criteria for circuit layout. For example, the design rules check could be carried out to make sure that there are no signal conductors shorted to each other. The design rules check could also make sure that all signals that should be connected together are actually connected together in the artwork database.
Parasitic values are then extracted (208). Parasitic values include the resistance and capacitive values of the components and conductive tracing described by the artwork database and may be extracted from the artwork database using a commonly known parasitic extraction tool.
A second structural model is then generated (210) based upon the artwork database. This second structural model of the circuit design may be created using, for example, a known connectivity extraction tool.
The timing value for the signal path represented by the extracted parasitic values and the second structural model is determined (212). More particularly, for a given predetermined input signal, a timing value is determined that is representative of the time it takes for the given input signal to propagate through the circuit or signal path having characteristics represented by the extracted parasitic values and the second structural model. This signal timing value may be referred to as the reference timing value.
A static timing tool such as that provided by, for example, Prime Time® by Synopsys' Inc., may be used to determine a timing value for the circuit design represented by the extracted parasitic values and the second structural model derived from the artwork database.
An extracted timing model is then generated based upon the extracted parasitic values and the initial structural model (214). The extracted timing model is representative of a circuit having characteristics represented by the extracted parasitic values and the initial structural model. In the best of circumstances, this extracted timing model will be equivalent to the initial structural model in function, performance and operation when evaluated. The extracted timing model may be generated using an extracted model generator tool such as that provided by, for example, Prime Time® by Synopsys, Inc.
A signal timing value is then calculated for the extracted timing model for the same given input signal used to determine the static model signal timing value (216). This signal timing value for the extracted model is then compared with the static model signal timing value previously determined, to determine the difference between them and more particularly whether the difference falls within an allowable range (218). This determination may be made via calculations in accordance with the following:
where T1 is the reference timing value and T2 is the timing value determined for the extracted timing model.
Where it is determined that the signal timing value for the extracted model is within a predetermined percentage range of the reference timing value, for example, ±5%, the extracted model for the signal path may be said to qualify for use in the overall timing model of the IC design. It may also be said that the signal path successfully met the timing requirements. Where the extracted model models more than one signal path, as is often typical in IC design, this determination will typically be carried out for every signal path that is modeled by the extracted model. Where the signal path is found to qualify for use in the overall timing model, an indicator may be output indicating the successful qualification of the signal path (220). Such an indicator is discussed further below with respect to FIG. 3A and FIG. 3B.
With reference to FIG. 3A and
The flow chart of
It should be noted that the present invention has been discussed with reference to preferred and example embodiments. The present invention is not intended to be limited to these embodiments. For example, the present invention is not limited to the processing conditions discussed above. The processing conditions described herein are merely for purposes of demonstration of particular implementations as well as for the purpose of demonstrating that a variety of processing conditions are suitable for achieving the goals of the present invention. Those skilled in the art will understand, in view of the discussion provided herein that many modifications may be made to the embodiments specifically described herein without deviating from the scope of the present invention.
Patent | Priority | Assignee | Title |
7089174, | Feb 21 2003 | ARM Limited | Modelling device behaviour using a first model, a second model and stored valid behaviour |
Patent | Priority | Assignee | Title |
6360356, | Jan 30 1998 | MAGMA DESIGN AUTOMATION, INC | Creating optimized physical implementations from high-level descriptions of electronic design using placement-based information |
6438731, | Sep 13 1999 | Synopsys, Inc. | Integrated circuit models having associated timing exception information therewith for use in circuit design optimizations |
6487705, | Sep 05 2001 | NEC Electronics, Inc. | Timing optimization and timing closure for integrated circuit models |
20030121013, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jan 29 2002 | MIELKE, DAVID JAMES | Agilent Technologies, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 012998 | /0885 | |
Jan 30 2002 | Agilent Technologies, Inc. | (assignment on the face of the patent) | / | |||
Dec 01 2005 | Agilent Technologies, Inc | AVAGO TECHNOLOGIES GENERAL IP PTE LTD | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 017207 | /0020 | |
Dec 01 2005 | Agilent Technologies, Inc | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | CORRECTIVE ASSIGNMENT TO CORRECT THE NAME OF THE ASSIGNEE PREVIOUSLY RECORDED ON REEL 017207 FRAME 0020 ASSIGNOR S HEREBY CONFIRMS THE ASSIGNMENT | 038633 | /0001 | |
May 06 2014 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 032851 | /0001 | |
Feb 01 2016 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | BANK OF AMERICA, N A , AS COLLATERAL AGENT | PATENT SECURITY AGREEMENT | 037808 | /0001 | |
Feb 01 2016 | DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENT RIGHTS RELEASES RF 032851-0001 | 037689 | /0001 | |
Jan 19 2017 | BANK OF AMERICA, N A , AS COLLATERAL AGENT | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS | 041710 | /0001 | |
May 09 2018 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | MERGER SEE DOCUMENT FOR DETAILS | 047196 | /0097 | |
Sep 05 2018 | AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | CORRECTIVE ASSIGNMENT TO CORRECT THE EXECUTION DATE PREVIOUSLY RECORDED AT REEL: 047196 FRAME: 0097 ASSIGNOR S HEREBY CONFIRMS THE MERGER | 048555 | /0510 | |
Aug 26 2020 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | BROADCOM INTERNATIONAL PTE LTD | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 053771 | /0901 |
Date | Maintenance Fee Events |
Jan 11 2008 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Dec 14 2011 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Dec 29 2015 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Jul 13 2007 | 4 years fee payment window open |
Jan 13 2008 | 6 months grace period start (w surcharge) |
Jul 13 2008 | patent expiry (for year 4) |
Jul 13 2010 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jul 13 2011 | 8 years fee payment window open |
Jan 13 2012 | 6 months grace period start (w surcharge) |
Jul 13 2012 | patent expiry (for year 8) |
Jul 13 2014 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jul 13 2015 | 12 years fee payment window open |
Jan 13 2016 | 6 months grace period start (w surcharge) |
Jul 13 2016 | patent expiry (for year 12) |
Jul 13 2018 | 2 years to revive unintentionally abandoned end. (for year 12) |