This invention relates to CMOS logic synthesis and in particular to logic synthesis in high-frequency CMOS designs.
It is common practice to specify the logic description of a CMOS design in a high-level language (such as Verilog or VHDL) and to synthesis this description into a circuit level implementation. Synthesis selects gates from a discrete gate library. It is especially common to synthesis random control logic to reduce the time to develop CMOS designs. Unfortunately synthesized circuit implementations are often slower than a non-synthesized (custom) circuit implementation and these synthesized control logic paths often limit the speed of high-frequency CMOS designs.
The disclosed tapered gate and synthesis methodology improves the quality of synthesized implementations. The critical path delays of these new implementations much closer to the delays of a custom circuit implementation. The discrete gate library is augmented with tapered gates to give synthesis more freedom in generation of a circuit implementation. In a tapered gate, the widths of the stacked devices are varied to achieve significant input pin to output pin delay differences. For example the bottom device(s) in a stack are designed with longer widths than the top device(s) to achieve smaller top input to output pin delay at the expense of larger bottom input to output pin delay. New synthesis algorithms are developed to exploit these tapered gates. Tapered and non-tapered gates are functionally equivalent—they differ in delay characteristics only. The input to output pin delay characteristics are coded in a rule. A timing analysis routine invokes these rules to compute arrival times and slacks (timing criticality) for each net in an implementation. A sorted, by timing criticality, list of nets is provided to the tapered gate synthesis algorithm.
The gate library from which gates are selected comprises a set of non-tapered gates and a set of tapered gates. The non-tapered gates are characterized by a stack of devices of the same width and the tapered gates are charactered by a stack of devices of different widths. Also, for each non-tapered gate there exists a plurality of tapered gates which are gunctionally equivalent to the non-tapered gate. Each set of tapered gates includes NAND gates, NOR gates, AND-OR-INVERT gates, and OR-AND-INVERT gates.
This algorithm modifies the input net to gate pin connections and swaps traditional non-tapered gates with tapered gates to improve the delay of the most timing critical paths. The latest arriving gate input net is swapped with the net connected to the top pin. The gate is then temporarily converted to a tapered gate and the timing analysis routine is invoked to re-compute arrival times and slacks for all nets. This tapered gate is retained if the slack of the temporary implementation is better than the slack of the original design.
These and other improvements are set forth in the following detailed description. For a better understanding of the invention with advantages and features, refer to the description and to the drawings.
My detailed description explains the preferred embodiments of my invention, together with advantages and features, by way of example with reference to the drawings.
Any CMOS gate containing a stack of devices with height greater than one can be tapered. CMOS NAND gates contain a two or higher stack of NFET devices. CMOS NOR gates contain a two or higher stack of PFET devices and CMOS AIR and OAI gates contain (two or higher) stacks of both NFET devices and PFET devices. The only common CMOS gate which cannot be tapered is an inverter since it simply consists of a (1-high) NFET device stack and a (1-high) PFET device stack. A tapered gate is illustrated with a 3-input NAND and 2-input NOR.
In particular consider the case where t is greater than 1. The delay from falling input pin A (46) to rising output node Y (49) is reduced since the top PFET device 44 is wider compared to the non-tapered gate. The wider device width effectively reduces the resistance of the PFET stack and speeds up the charging of the output node Y from ground to Vdd. But the path delay through input pin B (48) to output node Y (49) is increased. This is not obvious from a stand-alone analysis of this gate. But consider the gate which drives input pin B (48); the tapered gate with t>1 has larger input capacitance and this increases the delay of the gate driving input pin B. Thus, it is clear that the parameter t can be varied to change the input delay characteristics of the NOR gate.
Other types of CMOS gates may be tapered using the same methods just described for the 3-input NAND and 2-input NOR. These types of gates include (but are not limited to) CMOS NAND gates with 2 or 4 inputs, CMOS NOR gates with more than 2 inputs, and CMOS AND-OR-INVERT (AOI) and OR-AND-INVERT (OAI) gates with any number of inputs. CMOS AOI and OAI gates contain both a 2 or more high PFET stack and a 2 or more high NFET stack; therefore both the NFET and PFET stacks may be tapered for these gates.
While the preferred embodiment to the invention has been described, it will be understood that those skilled in the art, both now and in the future, may make various improvements and enhancements which fall within the scope of the claims which follow. These claims should be construed to maintain the proper protection for the invention first described.
Number | Name | Date | Kind |
---|---|---|---|
4827428 | Dunlop et al. | May 1989 | A |
5168455 | Hooper | Dec 1992 | A |
5654898 | Roetcisoender et al. | Aug 1997 | A |
5724250 | Kerzman et al. | Mar 1998 | A |
6192508 | Malik et al. | Feb 2001 | B1 |
6397169 | Shenoy et al. | May 2002 | B1 |
20010049814 | Matsumoto et al. | Dec 2001 | A1 |
Number | Date | Country | |
---|---|---|---|
20020157079 A1 | Oct 2002 | US |