A form of symbolic logic gate, referred to as don't-- care logic, provides a construct that does not have a technology primitive correspondent, and that is useful for carrying valuable additional information to logic synthesis and/or logic optimization processes. Thus, a logic optimization process may proceed more effectively when presented with such don't-- care information because, e.g. overlapping combinational logic is simplified (but not always eliminated) and dependency (i.e. shared combinational logic) is resolved between the data input and the enable input. The don't-- care gate is readily generalized, such that it can be applied for any technology primitives that have an enable line input, where there is potential shared combinational logic between the data input (or any inputs) and the enable input. Such category may include technology primitives, such as a latch, a D-- flip-- flop, and a tri-state element.
|
1. A method for effecting logic optimization, comprising the steps of:
defining a logic function having an overlapping data input and enable input; providing at least one symbolic don't-- care logic gate that does not have a technology primitive correspondent; carrying additional information to logic synthesis and/or logic optimization processes with said don't-- care logic gate in the form of a don't-- care state; and generating a netlist that does not contain such symbolic don't-- care logic gate; wherein overlapping combinational logic is simplified and dependency is resolved between said data input and said enable input of said logic function by said don't-- care logic gate.
11. An apparatus for effecting logic optimization, comprising:
a logic function having an overlapping data input and enable input; and at least one symbolic don't-- care logic gate that does not have a technology primitive correspondent, said don't-- care logic gate carrying additional information to logic synthesis and/or logic optimization processes in the form of a don't-- care state; wherein said logic synthesis and/or logic optimization processes generate a netlist that does not contain such symbolic don't-- care logic gate; and wherein overlapping combinational logic is simplified and dependency is resolved between said data input and said enable input of said logic function by said don't-- care logic gate.
2. The method of
DCfunction =(IN and EN) or (DON'T-- CARE and EN); or DCfunction =(IN and EN) or (DON'T-- CARE and EN), where DCfunction is the don't care logic gate function, IN is the input to said logic function, and EN is enable input to said logic function.
3. The method of
providing at least one don't-- care symbolic cell that includes an input terminal, a conditional terminal, and an output terminal.
4. The method of
5. The method of
inserting a don't-- care logic gate into a logic path of said logic function.
6. The method of
applying don't-- care logic gates to technology primitives that have an enable line input, where there is shared combinational logic between another input and said enable input.
7. The method of
8. The method of
9. The method of
10. The method of
12. The apparatus of
DCfunction =(IN and EN) or (DON'T-- CARE and EN); or DCfunction =(IN and EN) or (DON'T-- CARE and EN), where DCfunction is the don't care logic gate function, IN is the input to said logic function, and EN is enable input to said logic function.
13. The apparatus of
at least one don't-- care symbolic cell that includes an input terminal, a conditional terminal, and an output terminal.
14. The apparatus of
15. The apparatus of
a don't-- care logic gate inserted into a logic path of said logic function.
16. The apparatus of
at least one don't-- care logic gate applied to technology primitives that have an enable line input, where there is shared combinational logic between another input and said enable input.
17. The apparatus of
18. The apparatus of
a latch having a DATA input that receives a data set, an ENABLE input that receives an enable set, and an OUTPUT, where there is an overlap between said data set and said enable set.
19. The apparatus of
a D-- flip-- flop (DFF) having a DATA input that receives a data set, a DATA-- EN input that receives a data enable set, a clock input CLK, and an output Q, where there is an overlap between the data set and the data enable set.
20. The apparatus of
a three-state element having an input IN that receives a data set, an enable input EN that receives an enable set, and an output, where there is an overlap between the data set and the enable set.
|
1. Technical field
The invention relates to combinational logic. More particularly, the invention relates to overlapping logic for data and enable inputs to a logic function.
2. Description of the Prior Art
Application specific integrated circuit (ASIC) is a designation applied to a variety of devices fabricated in a variety of semiconductor technologies. An ASIC is designed to perform a specific function. The major advantages of ASICs are typically lower unit cost and higher performance. This is the result of eliminating circuitry from the chip otherwise needed to make it programmable and incorporating only the logic functions that are needed for the application. This makes a smaller, less costly chip. Higher performance is a result of directly implementing the logic instead of using an instruction set that requires multiples of clock cycles to execute, as with a microprocessor.
ASICs can be divided into two categories: standard and custom. Standard ASICs are generally commodity items which have been designed by a semiconductor manufacturer and which are sold in large volumes. Custom ASICs are generally designed by or for a specific customer and are not available to the public. This allows the developer of a custom ASIC to exploit the advantages of the device. One disadvantage of custom ASICs is the high nonrecurring engineering cost associated with designing the ASIC.
ASICs are typically designed using a schematic entry design system which includes a library of cells that are usable by a target silicon foundry and technical data relating to cell performance that must be programmed into a schematic capture tool.
A block diagram of the desired ASIC is first created by the system designer. The design is implemented by placing logical elements from the library onto the screen of a workstation. The elements of the design are uniquely defined by an instance number, connections are drawn in, and the wires are named. The operator then runs the schematic entry program to produce a netlist. In producing the netlist, all of the positional information contained in the schematic drawing, i.e. what elements goes next to what and where the critical signal paths are, is lost. Because the netlist is produced from a schematic, there is no actual information regarding such factors as, for example stray capacitance, inductive coupling, or transmission line length. These parameters must be estimated and added to the netlist in a format that is usable by a timing simulator.
In addition to the netlist obtained from the schematic entry program, test vectors must be generated to simulate the netlist. To bridge the interface between the schematic entry program and the simulator program, the test vectors must be in a format required by the simulator. The simulator program itself must be programmed to handle all of the logic elements contained in the foundry library.
When the simulation is completed, the results must be examined. This requires a program that takes the output of the simulator and displays it in the format desired.
The next interface is that between the schematic entry program and the auto-place-and-route program. The router must be programmed with the appropriate standard cell library and the output from the schematic entry tool must be in a format acceptable to the router.
The router outputs the geometrical data that define the structures and locations of the structures used in the fabrication of the design in silicon. These structures define data paths and capacitive loading which may be critical to the performance of the circuit. Because the router may not produce performance that meets the design specification, it is necessary to run an extraction program on the output of the router. The extraction program traces the layout and constructs a netlist of the actual layout. The extractor can also calculate the actual node loading.
The extractor must be programmed with appropriate data relating to the electrical properties of the various structural layers. The extractor also must assure that the output format of the router is usable by the input to the extractor, and that the output of the extractor is usable by the input to the timing simulator. The netlist containing the actual loading obtained by extraction from the layout is referred to as back-annotated data. The timing simulation obtained from simulating the back-annotated netlist should represent the actual circuit performance. Otherwise, engineering (i.e. human) intervention is required.
The actual netlist, i.e. the netlist provided by the extractor, and the netlist provided by the schematic entry, i.e. the intended netlist, must be compared to determine if the real netlist is the same as the intended netlist. This is performed by a layout-versus-schematic program.
Many design systems are based upon the use of a Hardware Description Language, such as VHDL or Verilog, and may use a silicon compiler and synthesizer. Assuming the system is described in VHDL and partitioned, if needed, into one or more ASICs, the resulting VHDL description must be converted to a detailed specification. The specification is typically dependent upon the design system that is used to implement the design. For example, a synthesizer program that is used to synthesize the ASIC from the VHDL description must be expanded to include specified timing. To determine if the specification is correct, the VHDL description must be simulated. Thus, test vectors described in the required stimulus format for a VHDL simulator must be provided. Once the specification is determined to be correct, a synthesizer program which contains a library of cells and a set of design rules appropriate for the target silicon foundry is run.
The HDL design tools ideally should allow the user to describe only the desired operation of the logic circuit, i.e. the signals generated by the logic circuit. However, HDL only permits an operational description of simple circuit elements. Accordingly, only designers that have knowledge of both the use and operation of logic elements and the operational features of the desired logic circuit can successfully use HDL.
B. Gregory, R. Segal, Method For Converting A Hardware Independent User Description Of A Logic Circuit Into Hardware Components, U.S. Pat. No. 5,530,841 (25 Jun. 1996) describe the generation of a logic network using a hardware independent description technique. A hardware generator is used to synthesize the logic network based upon information provided by an assignment condition generator.
In general, during the synthesis of latch logic using such systems, enable and data logic, i.e. combinational logic, overlap. It would be advantageous to simplify the overlapping logic for data and enable inputs, and thereby simplify the design. Additionally, such overlapping logic can cause timing problems after technology mapping because the same signal, i.e. the shared signal, may arrive to the data input of the latch at a different time than to the enable input of the latch. It would therefore also be advantageous to optimize circuit design in such way as to minimize or eliminate timing issues related to enable and data logic overlap.
The invention provides a form of symbolic logic gate, referred to as don't-- care logic. Such logic is a construct that does not have a technology primitive correspondent. Accordingly, at the time of technology mapping, the netlist does not contain such symbolic don't-- care gates. However, don't-- care logic, as defined herein, is useful for carrying valuable additional information to logic synthesis and/or logic optimization processes. Thus, a logic optimization process may proceed more effectively when presented with such don't-- care information because, e.g. overlapping combinational logic is simplified (but not always eliminated) and dependency (i.e. shared combinational logic) is resolved between the data input and the enable input.
The invention herein may also be generalized, such that the don't-- care gate can be applied for technology primitives that have an enable line input, where there is potential shared combinational logic between the data input (or any inputs) and the enable input. Such category may include technology primitives, such as a latch, a D-- flip-- flop, and a tri-state element.
FIG. 1 is a block schematic diagram of a latch showing an enable and data logic overlap as is known in the prior art;
FIG. 2a is a block schematic diagram of a simple conditional logic function after allocation as is known in the prior art;
FIG. 2b is a block schematic diagram of a simple conditional logic function after allocation according to the invention;
FIG. 3a is a block schematic diagram of a simple conditional logic function after logic optimization as is known in the prior art;
FIG. 3b is a block schematic diagram of a simple conditional logic function after logic optimization according to the invention;
FIG. 4 is a block schematic diagram of a latch as is known in the prior art;
FIG. 5 is a block diagram of a don't-- care symbolic cell according to the invention;
FIG. 6a is a block schematic diagram of a mature incomplete conditional logic function after allocation as is known in the prior art;
FIG. 6b is a block schematic diagram of a mature incomplete conditional logic function after allocation according to the invention;
FIG. 7a is a block schematic diagram of a mature incomplete conditional logic function after logic optimization as is known in the prior art;
FIG. 7b is a block schematic diagram of a mature incomplete conditional logic function after logic optimization according to the invention;
FIG. 8 is a block schematic diagram showing a technology primitive for a latch according to the prior art;
FIG. 9 is a block schematic diagram showing a technology primitive for a D-- flip-- flop according to the prior art; and
FIG. 10 is a block schematic diagram showing a technology primitive for a three-state element according to the prior art.
The invention provides a form of symbolic logic gate, referred to as don't-- care logic. Such logic is a construct that does not have a technology primitive correspondent. Accordingly, at the time of technology mapping, the netlist does not contain such symbolic don't-- care gates. However, don't-- care logic, as defined herein, is useful for carrying valuable additional information to logic synthesis and/or logic optimization processes. Thus, a logic optimization process may proceed more effectively when presented with such don't-- care information because, e.g. overlapping combinational logic is simplified (but not always eliminated) and dependency (i.e. shared combinational logic) is resolved between the data input and the enable input.
It is known that the hardware description functions generated during design synthesis and simulation using modern ASIC design systems may include a don't-- care function. See, for example B. Gregory, R. Segal, Method For Converting A Hardware Independent User Description Of A Logic Circuit Into Hardware Components, U.S. Pat. No. 5,530,841 (25 Jun. 1996), which describes an assignment condition that is generated for the don't-- care function when the user assigns a value of don't-- care to a variable. In this system, a hardware generator uses the don't-- care function assignment to Boolean minimize the logic circuit that is created. As discussed above, the herein disclosed invention is the first use of a don't-- care function to address the issue of enable and data logic overlap.
FIG. 1 is a block schematic diagram of a latch showing an enable and data logic overlap as is known in the prior art. In the figure, a latch 10 has a data input point 12 that receives a data set 13, has an enable input terminal 14 that receives an enable set 15. Data and enable overlap 17 are shown as a cross hatched region in the figure. As discussed above, it would be advantageous to simplify the overlapping logic for data and enable inputs, and thereby simplify the design. Because such overlapping logic can cause timing problems after technology mapping when the same signal, i.e. the shared signal, arrives at the data input of the latch at a different time than at the enable input of the latch. The following is an example of a simple conditional statement:
______________________________________ |
Module Test1 (cond, in, out); |
Input cond, in; |
Output out; |
Always @ (in or cond) |
If (cond) out=in; |
Endmodule |
______________________________________ |
FIG. 2a is a block schematic diagram of the simple conditional logic function after allocation as is known in the prior art. In the figure, a latch 20 and an AND gate 21 are used to define the conditional logic function. The function includes an input terminal 27, a conditional terminal 28, and an output terminal 29.
FIG. 2b is a block schematic diagram of a simple conditional logic function after allocation according to the invention. In the figure, a latch 22 and an AND gate 24 are used to define the conditional logic function. The function includes an input terminal 27, a conditional terminal 28, and an output terminal 29. The function also includes a don't-- care symbolic gate 26.
FIG. 3a is a block schematic diagram of the above simple conditional logic function after logic optimization as is known in the prior art. In the figure, a latch 20a and an AND gate 21a are used to define the conditional logic function. The function includes an input terminal 27, a conditional terminal 28, and an output terminal 29. As can been seen, after optimization, the function is defined at the same level of complexity as after allocation (see FIG. 2a).
FIG. 3b is a block schematic diagram of a simple conditional logic function after logic optimization according to the invention. In the figure, a latch 22a is used to define the conditional logic function. The function includes an input terminal 27, a conditional terminal 28, and an output terminal 29. The use of a don't-- care symbolic gate 26 during optimization (after allocation--see FIG. 2b) results in a less complex function. It can be seen that, after optimization, the symbolic don't-- care gate has been eliminated from the function.
Thus, after optimization the overlapping combinational logic, i.e. the AND gate in this example, is optimized out of the function when a symbolic don't-- care gate is used. Further, there is no more dependency, i.e. overlap, between the data input and the enable inputs of the latch. Accordingly, potential timing problems, as outlined above, are eliminated after technology mapping.
A latch is used for a rudimentary explanation of the applicability of such don't-- care function. For example, FIG. 4 is a block schematic diagram of a latch as is known in the prior art. The latch 40 includes an input terminal 41, a conditional terminal 42, and an output terminal 43. The internal data of the latch are updated only when the enable line is set to a logic "1." Otherwise, the data are not updated. Thus, a don't-- care symbolic gate (also referred to herein as a cell) can be inserted into the logic path of the latch, i.e. the latch only "cares" when the enable line is set to a logic "1."
FIG. 5 is a block diagram of a don't-- care symbolic cell according to the invention. The cell 50 includes an input terminal 51, a conditional terminal 52, and an output terminal 53.
The don't-- care function can be described in many ways. With regard to the presently preferred embodiment of the invention, the don't-- care function is described in two forms, as follows:
DCfunction =(IN and EN) or (DON'T-- CARE and EN) (1)
DCfunction =(IN and EN) or (DON'T-- CARE and EN) (2)
The following is an example of a mature incomplete conditional function:
______________________________________ |
Module Test2 (a, sel, out); |
Input [0:1]sel; |
Input a; |
Output out; |
Always @ (sel or a) |
Case (sel) |
2'b00 : out=1'b1; |
2'b10 : out=a; |
Endcase |
Endmodule |
______________________________________ |
FIG. 6a is a block schematic diagram of the above mature incomplete conditional logic function after allocation. In the figure, two select lines 68 and 69 are used to condition the function via a data input 70. The select lines are coupled through inverters 66, 67 to AND gates 63, 65. The output of the AND gate 65 is ANDed with the data line a 70 and by the AND gate 64. The output of the AND gate 64 is ORed with the output of the AND gate 63 at the input of OR gate 62. The output of the AND gate 63 is also ORed with the output of the AND gate 65 at the OR gated 61. The outputs of OR gates 62 and 61 are connected to the respective DATA and ENABLE inputs of a latch 60, which includes an input terminal 72, a conditional terminal 73, and an output terminal 71.
FIG. 6b is a block schematic diagram of the above mature incomplete conditional logic function after allocation according to the invention. In the figure, two select lines 68 and 69 are used to condition the function via data input a 70. The select lines are coupled through inverters 66, 67 to AND gates 63, 65. The output of the AND gate 65 is ANDed with the data line 70 and by the AND gate 64. The output of the AND gate 64 is ORed with the output of the AND gate 63 at the input of OR gate 62. The output of the AND gate 63 is also ORed with the output of the AND gate 65 at the OR gated 61. The outputs of OR gates 62 and 61 are connected to the respective DATA and ENABLE inputs of a latch 60, which includes an input terminal 72, a conditional terminal 73, and an output terminal 71. The function also includes a don't-- care symbolic gate 75 at the input of the latch 60.
FIG. 7a is a block schematic diagram of the above mature incomplete conditional logic function after logic optimization as is known in the prior art. In the figure, two select lines 68 and 69 are used to condition the function via data input a 70. The select lines are coupled through inverters 66, 67 to AND gates 76, 77. The outputs of the AND gates are ORed at the input of OR gate 78. The outputs of the OR gate 78 is connected to the respective DATA and ENABLE inputs of a latch 60a, which includes an input terminal 72, a conditional terminal 73, and an output terminal 71. Thus, logic optimization has simplified the function, i.e. by replacing gates 61-65 with gates 76-78.
FIG. 7b is a block schematic diagram of the above mature incomplete conditional logic function after logic optimization according to the invention. In the figure, two select lines 68 and 69 are used to condition the function via a data input 70. A first select line SEL[0] 68 is coupled through an inverter 79 to an OR gate 81. A second select line SEL[1] 69 is coupled through an invertor 80 to the ENABLE input of a latch 60b, which includes an input terminal 72, a conditional terminal 73, and an output terminal 71. The data input 70 is coupled to an input of the OR gate 81. The output of the OR gate 81 is coupled to the DATA input of the latch 60b. The use of a don't-- care symbolic gate 75 during optimization (after allocation--see FIG. 6b) results in a less complex function. It can be seen that, after optimization, the symbolic don't-- care gate has been eliminated from the function.
The foregoing example illustrates that logic optimization is more effective when presented with don't-- care information. Thus, overlapping combinational logic is simplified, although not always eliminated; and dependency (i.e. shared combinational logic) is resolved between the data input and the enable input of the logic function in question.
The invention herein may also be generalized, such that the don't-- care gate can be applied for technology primitives that have an enable line input, where there is potential shared combinational logic between the data input (or any inputs) and the enable input. Such category may include technology primitives that comprise a logic function having one or more general inputs; an output; and enable logic for enabling said logic function whether or not data is present at said one or more general inputs, said enable logic passing any data present at said one or more general inputs to said output during an enable state and not passing any data present at said one or more general inputs to said output during an enable state.
For example, FIG. 8 is a block schematic diagram showing a technology primitive for a latch 85 having a DATA input 86 that receives a data set 89, an ENABLE input 87 that receives an enable set 90, and an OUTPUT 89, where the overlap 91 between the data set and the enable set is indicated by cross hatching; FIG. 9 is a block schematic diagram showing a technology primitive for a D-- flip-- flop (DFF) 92 having a DATA input 94 that receives a data set 97, a DATA-- EN input 98 that receives a data enable set 98, a clock input CLK 96, and an output Q 93, where the overlap 99 between the data set and the data enable set is indicated by cross hatching; and FIG. 10 is a block schematic diagram showing a technology primitive for a three-state element 100 having an input IN 103 that receives a data set 104, an enable input EN 102 that receives an enable set 105, and an output OUT 101, where the overlap 106 between the data set and the enable set is indicated by cross hatching.
Although the invention is described herein with reference to the preferred embodiment, one skilled in the art will readily appreciate that other applications may be substituted for those set forth herein without departing from the spirit and scope of the present invention. Accordingly, the invention should only be limited by the Claims included below.
Li, Hong, Limqueco, Johnson, Moricz, Michael
Patent | Priority | Assignee | Title |
6056784, | Oct 04 1996 | Synopsys, Inc | Circuit synthesis verification method and apparatus |
6243852, | Aug 29 1997 | NEC Corporation | Method of and an apparatus for logic circuit synthesis |
6665844, | Oct 04 1996 | Synopsys, Inc. | Circuit synthesis verification method and apparatus |
6711719, | Aug 13 2001 | GOOGLE LLC | Method and apparatus for reducing power consumption in VLSI circuit designs |
6842884, | Aug 28 2002 | Cadence Design Systems, INC | Combinational equivalence checking methods and systems with internal don't cares |
7240311, | Aug 28 2002 | Cadence Design Systems, INC | Combinational equivalence checking methods and systems with internal don't cares |
7627842, | Jun 03 2003 | Cadence Design Systems, INC | Method and system for verification of circuits with encoded signals |
8332800, | Dec 15 2010 | Apple Inc.; Apple Inc | Method for identifying redundant signal paths for self-gating signals |
8434047, | May 29 2007 | Synopsys, Inc | Multi-level clock gating circuitry transformation |
8539401, | Jul 24 2006 | Siemens Industry Software Inc | Generating a convergent circuit design from a functional description using entities having access to the functional description and to physical design information |
8543962, | Dec 15 2010 | Apple Inc. | Method for identifying redundant signal paths for self-gating signals |
8832633, | Jul 24 2006 | Siemens Industry Software Inc | Generating a convergent circuit design from a functional description using entities having access to the functional description and to physical design information |
8990758, | Jul 24 2006 | Siemens Industry Software Inc | Generating a convergent circuit design from a functional description using entities having access to the functional description and to physical design information |
Patent | Priority | Assignee | Title |
5461574, | Mar 09 1989 | Fujitsu Limited | Method of expressing a logic circuit |
5499191, | Jun 15 1992 | XILINX, INC , A CORP OF DELAWARE | Multi-level logic optimization in programmable logic devices |
5530841, | Dec 21 1990 | Synopsys, Inc. | Method for converting a hardware independent user description of a logic circuit into hardware components |
5649165, | Jan 31 1995 | Fujitsu Limited | Topology-based computer-aided design system for digital circuits and method thereof |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Mar 06 1997 | MORICZ, MICHAEL | AMBIT DESIGN SYSTEMS | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 008509 | /0519 | |
Mar 06 1997 | LI, HONG | AMBIT DESIGN SYSTEMS | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 008509 | /0519 | |
Mar 06 1997 | LIMQUECO, JOHNSON | AMBIT DESIGN SYSTEMS | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 008509 | /0519 | |
Mar 12 1997 | Ambit Design Systems, Inc. | (assignment on the face of the patent) | / | |||
May 03 2001 | AMBIT DESIGN SYSTEMS, INC | Cadence Design Systems, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 011806 | /0143 |
Date | Maintenance Fee Events |
Sep 16 2002 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jan 17 2003 | R2551: Refund - Payment of Maintenance Fee, 4th Yr, Small Entity. |
Jan 17 2003 | STOL: Pat Hldr no Longer Claims Small Ent Stat |
Sep 26 2006 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Oct 06 2010 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Apr 06 2002 | 4 years fee payment window open |
Oct 06 2002 | 6 months grace period start (w surcharge) |
Apr 06 2003 | patent expiry (for year 4) |
Apr 06 2005 | 2 years to revive unintentionally abandoned end. (for year 4) |
Apr 06 2006 | 8 years fee payment window open |
Oct 06 2006 | 6 months grace period start (w surcharge) |
Apr 06 2007 | patent expiry (for year 8) |
Apr 06 2009 | 2 years to revive unintentionally abandoned end. (for year 8) |
Apr 06 2010 | 12 years fee payment window open |
Oct 06 2010 | 6 months grace period start (w surcharge) |
Apr 06 2011 | patent expiry (for year 12) |
Apr 06 2013 | 2 years to revive unintentionally abandoned end. (for year 12) |