|Publication number||US5081377 A|
|Application number||US 07/586,127|
|Publication date||Jan 14, 1992|
|Filing date||Sep 21, 1990|
|Priority date||Sep 21, 1990|
|Also published as||DE69119521D1, DE69119521T2, EP0476940A2, EP0476940A3, EP0476940B1|
|Publication number||07586127, 586127, US 5081377 A, US 5081377A, US-A-5081377, US5081377 A, US5081377A|
|Inventors||Ronald L. Freyman|
|Original Assignee||At&T Bell Laboratories|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (9), Referenced by (45), Classifications (10), Legal Events (4)|
|External Links: USPTO, USPTO Assignment, Espacenet|
1. Field of the Invention
The present invention relates to integrated circuits having latch circuitry that operates with asynchronous signals.
2. Description of the Prior Art
Latch circuits are widely used to capture and temporarily store logic signals in integrated circuits. For example referring to FIG. 6, a microprocessor (60) may receive inputs (I1, I2, I3) from a variety of external sources that are asynchronous from the microprocessor (60) clock (clock). A latch (65) at a given input (line 61) allows the external signal to be received at any time, and clocked out into the microprocessor circuitry at a time determined by the microprocessor clock. The design of a typical "DQ" latch is illustrated in FIG. 3. The clock signals SCK, MCKL and SCKL may be generated from the master clock signal MCK by the action of inverters 416, 417, 418, and 419 as shown in FIG. 4, with other clock schemes being possible.
The operation of the DQ circuit is as follows: A signal at the D input is passed through the transmission gates 300, 301 to node 302 when the "master" clock MCK is high (and SCK low). The inverters 303 and 304 supply the signal to node 305. The feedback transmission gates 306 and 307 provide positive feedback that holds the voltage at node 302 at its previous state (i.e., latches node 302) when signal SCKL is high (and MCKL low). The signal on node 305 is passed through transmission gates 308 and 309 when the "slave" clock signal SCK is high (and MCK low). The inverters 311 and 312 provide the output signal Q at node 313. The transmission gates 314 and 315 provide for latching node 313 when MCKL is high (and SCKL low) by conducting positive feedback to the input of inverter 311. The net result is that either a low or high logic level (e.g., VSS or VDD) at the D input is latched at the Q output when the clock MCK goes low. Thereafter, the Q output can not change state until the next high to low transition of the MCK clock.
One problem with latch circuitry occurs when the voltage at the D input changes at the same time that the clock signal MCK makes its high-to-low transition. For example, if the D input is making a low-to-high transition at that moment, then it is indeterminate whether a low or high voltage will appear at the Q output. In fact, the Q output may remain at an intermediate state midway between the logic levels (e.g., about VDD /2, which is 2.5 volts in the case of a 5 volt power supply) for an indefinite period of time. In that case, the output is said to be metastable, which is also referred to as being "hung". The time necessary to resolve the output, that is, to go to either a high or low stable state, is a measure of the effectiveness of the overall design of the latch circuitry.
To reduce the probability of a metastable output, circuit designers typically choose the gain of the inverters (303, 304, 311, and 312) to be relatively high. This provides a large positive feedback signal through the feedback transmission gates (306-307 and 314-315), in order to promote achieving a stable state in a short time period after the high-to-low transition of clock MCK. In addition, the clock signals to the feedback transmission gates (MCKL, SCKL) are typically delayed with respect to the clock signals MCK and SCK. This delay may be accomplished by inverters 417, 418, and 419 as shown in FIG. 4. The delayed clock signals MCKL and SCKL then help assure that the feedback signal applied to the input of inverter 303 arrives at the same time as the clock MCK is making a high-to-low transition (and SCK a low-to-high transition). In this manner, the possibility of contention between the D signal and the feedback signal is minimized. Such contention could otherwise pull node 302 in opposite directions, which would increase the probability that the output would hang. A similar situation obtains for the delayed clock signals applied to the feedback transmission gates 314 and 315.
Although these steps reduce the probability of a metastable output, it is still possible for a transition of the D input to occur so close in time to a transition of the MCK clock that a metastable output can occur. It can be seen that a metastable output can cause erroneous signals to be supplied to a microprocessor or other circuitry connected to the output of a latch. It is especially important that control signals not be erroneous, or else the instruction sequence may be altered. As a result, a large quantity of data may be corrupted by the erroneous signals. Therefore, still improved means for reducing the probability of a metastable latch output are desirable.
I have invented an improved latch circuit. Means are included to conduct a desired voltage to a receiving node when the voltage on one or more internal nodes is in an intermediate state between high and low logic levels. Typically, the desired voltage is the output voltage of the latch. In this manner, metastable states may be avoided or reduced.
FIG. 1 shows an illustrative embodiment of the invention.
FIG. 2 shows the voltage across typical n-channel and p-channel devices as a function of gate voltage.
FIG. 3 shows a typical prior art DQ latch circuit.
FIG. 4 shows a typical prior art clock generation circuit.
FIG. 5 shows an alternate embodiment of the intermediate state transmission means.
FIG. 6 shows a system having a processor and an input latch that receives asynchronous inputs.
The following detailed description relates to an improved latch circuit technique for reducing or eliminating the occurrence of metastable states. Referring to FIG. 1, an illustrative embodiment of the invention, as implemented in CMOS technology, is shown. However, application to other types of circuit technologies, including bipolar types, is possible, and included herein. The "D" input signal to the latch is applied to the drains of transistors 100 and 101, which form a transmission gate controlled by clocks MCK and SCK, respectively. When MCK goes high (and SCK goes low), the signal is passed to receiving node 102, and inverted by inverter 103 at node 104. From node 104, the signal is again inverted by inverter 105 at node 108. When clock SCKL goes high (MCKL goes low), the signal is passed through transmission gates 106 and 107 back to node 102, thereby providing positive feedback to inverter 103 that latches node 104 in a stable state in normal operation.
On the next master clock transition, MCK goes low (SCK goes high), and the signal at node 104 is passed through transmission gates 113 and 114 to node 115. From node 115, the signal is inverted by inverters 116 and 117, and inverted again by inverter 121, where it appears at the "Q" output (node 122). The next time that the delayed clock signal MCKL goes high (SCKL goes low), the feedback signal is passed from node 118 back to node 115 through transmission gates 119 and 120. Therefore, inverters 116 and 117 are latched in a stable state in normal operation, so that the Q output signal is also latched in a stable state through inverter 121. The operation as thus described as "normal" means that the D input signal did not make a transition simultaneously with the high-to-low transition of clock signal MCK (or low-to-high transition of clock SCK). Hence, no metastable condition is created.
Referring to the "intermediate state transmission means" 123, it will be seen that n-channel transistor 109 is serially connected to p-channel transistor 110, with their gates being tied together and connected to node 108. Similarly, n-channel transistor 111 is serially connected to p-channel transistor 112, and their gates are tied together and connected to node 104. In normal operation, node 108 is at a stable state (either high or low), so that one of the transistors 109 and 110 is turned off (non-conducting). Similarly, in normal operation, node 104 is in a stable state, opposite to the state of node 108, so that one of transistors 111 and 112 is turned off. Therefore, the voltage on the output node 122 is not coupled to node 102 through the intermediate state transmission means 123, and the operation of the latch circuitry proceeds as described above.
However, consider the situation in which node 102 is in an intermediate state between VDD and VSS when clock MCK goes low. For example, node 102 may be metastable at around the threshold of inverter 103 if there is contention between the D input signal and the feedback signal from inverter 105. In that case, an intermediate voltage between VDD and VSS will be produced on node 104 by the action of inverter 103. The intermediate voltage on node 104 will cause conduction to occur through transistors 111 and 112, effectively connecting the Q output (node 122) to the node 102, thereby forcing node 102 to assume the logic level of the Q output (since the low MCK isolates node 102 from the D input signal). A similar situation arises if node 108 assumes an intermediate voltage level due to the action of inverter 105. In that case, the intermediate voltage on node 108 causes transistors 109 and 110 to conduct, which similarly provides a conducting path from the Q output to the node 102, thereby forcing node 102 to assume the logic level of the Q output. Note that in a typical case of indeterminate voltages levels, conduction occurs through both transistor pairs 109-110 and 111-112, although conduction through only one of the pairs is sufficient to prevent a metastable output condition.
It will be understood by persons of skill in the art that a series connection between n-channel and p-channel transistors having their gates connected together is typically considered to be a non-conducting path, since one of the transistors is usually assumed to be turned off. In fact, that is the principle by which complementary CMOS inverters provide for low power supply consumption. However, referring to FIG. 2, the known characteristic curves of typical n-channel and p-channel transistors (21 and 22, respectively) are shown on the same graph, for the case wherein the channel currents are small. Since the gates and sources of transistors 109 and 110 (and 111 and 112) are tied together, the gate-to-source voltage Vgs is the same for both the n-channel and p-channel transistor. It can be seen that as Vgs exceeds the threshold of the n-channel transistor (Vtn), the drain-to-source voltage Vds goes rapidly to zero due to conduction through the channel. Similarly, when Vgs is below the threshold of the p-channel transistor (Vtp), the drain-to-source voltage rapidly drops to zero due to conduction through the channel. Therefore, a conducting path exists through the series pair of n and p channel transistors when the gate voltage is in the range between VSS +Vtn and VDD -Vtp. Furthermore, the action of the series pair of n-channel and p-channel devices ensures that no conduction will occur through the pair when the gate voltage is outside this range (e.g., at VSS or VDD), as is the case when the nodes connected to the gates are in a stable state.
It can be seen that two complementary pairs (109-110 and 111-112) are shown in a parallel configuration, which provides for minimal voltage drop when the pairs are turned on. However, in some cases only a single pair is sufficient to provide protection against metastable states. On the other hand, additional complementary pairs may be provided for other feedback paths, depending on the number of nodes that might hang in an intermediate state. Furthermore, the above embodiment has shown that the conduction path through the intermediate state transmission means (123) is from the Q output node to receiving node 102 at the input of the first inverter (103). That configuration forces the latch to remain in the last stable state in the case of a conflict at the receiving node. However, other conduction paths are possible. For example, the intermediate state transmission means may be connected to a fixed logic level (e.g., VDD or VSS), so that the node 102 is forced to that known level at the onset of an intermediate state at one of the internal nodes (e.g., 104 or 108). Note that although node 102 is designated as an " receiving" node herein, other nodes may be found that can force the output to assume the desired state, and hence may be controlled by the intermediate state transmission means.
The gates of each transistor in a given series pair (109-110 and 111-112) are shown connected together, and driven from complementary nodes (108 and 104, respectively) in the above embodiment. However, the gates may be separately driven. For example, as shown in FIG. 5, a first inverter (125) may drive the n-channel transistor in a given pair (e.g., transistor 109), whereas a second inverter (124) may drive the p-channel transistor in the pair (e.g., transistor 110). The switching thresholds of the first and second inverters may then be chosen to be different, so as to increase the time period in which both transistors in the series pair conduct. In this manner, a more robust signal may be provided to the receiving node (102), even with only a single series pair. Also, one or more control transistors may be included with intermediate state transmission means 123, to allow conduction only in certain cases. For example, conduction only when the output node 122 is low (or alternatively only when node 122 is high) may be desirable in some designs. Finally, while the above embodiment has been given in terms of a DQ latch, the application of the present invention to various other types of latch circuits is clearly possible, and included herein.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4398105 *||Jan 22, 1981||Aug 9, 1983||Signetics Corporation||Arbiter circuit|
|US4498176 *||Feb 11, 1982||Feb 5, 1985||Siemens Aktiengesellschaft||Method and apparatus for the error-free synchronization of asynchronous pulses|
|US4591737 *||Dec 13, 1982||May 27, 1986||Advanced Micro Devices, Inc.||Master-slave multivibrator with improved metastable response characteristic|
|US4719366 *||Oct 11, 1985||Jan 12, 1988||Advanced Micro Devices, Inc.||Output state protection network for D-type flip-flop|
|US4777388 *||Dec 14, 1987||Oct 11, 1988||Tektronix, Inc.||Fast latching flip-flop|
|US4786829 *||Feb 24, 1987||Nov 22, 1988||Letcher John H||Latched fedback memory finite-state-engine|
|US4808840 *||Nov 20, 1987||Feb 28, 1989||International Business Machines Corporation||Dynamic edge-triggered latch|
|US4920282 *||Jun 20, 1988||Apr 24, 1990||Kabushiki Kaisha Toshiba||Dynamic latch circuit for preventing short-circuit current from flowing during absence of clock pulses when under test|
|US4963772 *||Feb 7, 1989||Oct 16, 1990||North American Philips Corp., Signetics Div.||Metastable-immune flip-flop arrangement|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US5168181 *||May 23, 1991||Dec 1, 1992||Sgs-Thomson Microelectronics S.R.L.||Spike filtering circuit for logic signals|
|US5463340 *||Jun 15, 1993||Oct 31, 1995||Mitsubishi Denki Kabushiki Kaisha||Phase clocked latch having both parallel and shunt connected switches for transmission gates|
|US5497114 *||Sep 2, 1994||Mar 5, 1996||Fujitsu Limited||Flip-flop circuit|
|US5576645 *||Jun 5, 1995||Nov 19, 1996||Hughes Aircraft Company||Sample and hold flip-flop for CMOS logic|
|US5640115 *||Dec 1, 1995||Jun 17, 1997||Sun Microsystems, Inc.||Self-enabling latch|
|US5789945 *||Feb 27, 1996||Aug 4, 1998||Philips Electronics North America Corporation||Method and circuit for improving metastable resolving time in low-power multi-state devices|
|US5796283 *||Oct 15, 1996||Aug 18, 1998||Philips Electronics North America Corporation||BINMOS latch circuit with symmetric set-up times|
|US5874843 *||May 28, 1997||Feb 23, 1999||Taiwan Semiconductor Manufacturing Co., Ltd.||Power-on reset circuit without an RC Network|
|US5939915 *||Aug 6, 1997||Aug 17, 1999||International Business Machines Corporation||Noise-immune pass gate latch|
|US6097230 *||Dec 7, 1998||Aug 1, 2000||Texas Instruments Deutschland Gmbh||Clock-independent latch setup-and-hold time in a combined D-type latch and flip-flop|
|US6184701 *||May 27, 1999||Feb 6, 2001||Samsung Electronics Co., Ltd.||Integrated circuit devices having metastability protection circuits therein|
|US6310500 *||Jun 23, 2000||Oct 30, 2001||International Business Machines Corporation||Race removal or reduction in latches and loops using phase skew|
|US6429713 *||Feb 23, 2001||Aug 6, 2002||Ando Electric Co., Ltd.||D-FF circuit|
|US6498513||Jun 7, 2001||Dec 24, 2002||Cypress Semiconductor Corp.||Metastability recovery circuit|
|US6515517 *||Jun 7, 2001||Feb 4, 2003||Cypress Semiconductor Corp.||Discriminator circuit|
|US6531905||Dec 19, 2001||Mar 11, 2003||Neoaxiom Corporation||Flip-flop with metastability reduction|
|US6538471 *||Oct 10, 2001||Mar 25, 2003||International Business Machines Corporation||Multi-threshold flip-flop circuit having an outside feedback|
|US6573774 *||Mar 25, 2002||Jun 3, 2003||Aeroflex Utmc Microelectronic Systems, Inc.||Error correcting latch|
|US6621302||Sep 5, 2001||Sep 16, 2003||Bae Systems Information And Electronic Systems Integration, Inc||Efficient sequential circuits using critical race control|
|US6674306||Jun 7, 2001||Jan 6, 2004||Cypress Semiconductor Corp.||Multiport arbitration using phased locking arbiters|
|US6794916 *||May 30, 2003||Sep 21, 2004||International Business Machines Corporation||Double edge-triggered flip-flops|
|US6826642||Jun 7, 2001||Nov 30, 2004||Cypress Semiconductor Corp.||Method and apparatus for the use of discriminators for priority arbitration|
|US6831496||Nov 19, 2002||Dec 14, 2004||Aeroflex Utmc Microelectronic Systems, Inc.||Error correcting latch|
|US6853218||Dec 19, 2003||Feb 8, 2005||Cypress Semiconductor Corp.||Multiport arbitration using phased locking arbiters|
|US7071749||Jun 15, 2004||Jul 4, 2006||Aeroflex Colorado Springs Inc.||Error correcting latch|
|US7446581 *||Oct 7, 2005||Nov 4, 2008||Kabushiki Kaisha Toshiba||Semiconductor integrated circuit with a logic circuit including a data holding circuit|
|US7688107 *||Mar 24, 2006||Mar 30, 2010||Semiconductor Energy Laboratory Co., Ltd.||Shift register, display device, and electronic device|
|US7759995||Oct 16, 2008||Jul 20, 2010||Kabushiki Kaisha Toshiba||Semiconductor integrated circuit with a logic circuit including a data holding circuit|
|US7876127 *||Aug 7, 2009||Jan 25, 2011||National Kaohsiung University Of Applied Sciences||Automatic hold time fixing circuit unit|
|US7977983||May 1, 2008||Jul 12, 2011||Freescale Semiconductor, Inc.||Device having synchronizing capabilities|
|US8508254 *||May 31, 2011||Aug 13, 2013||Altera Corporation||Apparatus for using metastability-hardened storage circuits in logic devices and associated methods|
|US8749287||Aug 2, 2010||Jun 10, 2014||Fujitsu Semiconductor Limited||Semiconductor device|
|US20030179030 *||Nov 19, 2002||Sep 25, 2003||Gardner Harry N.||Error correcting latch|
|US20040227551 *||Jun 15, 2004||Nov 18, 2004||Gardner Harry N.||Error correcting latch|
|US20060071695 *||Sep 7, 2005||Apr 6, 2006||Samsung Electronics Co., Ltd.||Signal driving circuits including inverters|
|US20060082404 *||Oct 7, 2005||Apr 20, 2006||Chihiro Ishii||Semiconductor integrated circuit with a logic circuit including a data holding circuit|
|US20060233293 *||Mar 24, 2006||Oct 19, 2006||Semiconductor Energy Laboratory Co., Ltd.||Shift register, display device, and electronic device|
|US20090039937 *||Oct 16, 2008||Feb 12, 2009||Kabushiki Kaisha Toshiba||Semiconductor Integrated Circuit with a Logic Circuit Including a Data Holding Circuit|
|US20100295592 *||Aug 7, 2009||Nov 25, 2010||Liang-An Zheng||Automatic hold time fixing circuit unit|
|US20100308881 *||Aug 2, 2010||Dec 9, 2010||Fujitsu Semiconductor Limited||Semiconductor device|
|US20110227625 *||May 31, 2011||Sep 22, 2011||Altera Corporation||Apparatus for using metastability-hardened storage circuits in logic devices and associated methods|
|US20160004959 *||Jul 8, 2015||Jan 7, 2016||Knowmtech, Llc||Memristor apparatus|
|WO2002078185A1 *||Mar 20, 2002||Oct 3, 2002||Bae Systems Information And Electronic Systems Integration Inc.||Efficient sequential circuits using critical race control|
|WO2011038404A2 *||Sep 28, 2010||Mar 31, 2011||Altera Corporation||Apparatus for Metastability-Hardened Storage Circuits and Associated Methods|
|WO2011038404A3 *||Sep 28, 2010||Oct 6, 2011||Altera Corporation||Apparatus for Metastability-Hardened Storage Circuits and Associated Methods|
|U.S. Classification||327/198, 327/211, 327/141, 327/142|
|International Classification||H03K3/037, H03K3/356|
|Cooperative Classification||H03K3/356156, H03K3/0375|
|European Classification||H03K3/037C, H03K3/356G2F2|
|Sep 21, 1990||AS||Assignment|
Owner name: AMERICAN TELEPHONE AND TELEGRAPH COMPANY, NEW YORK
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST.;ASSIGNOR:FREYMAN, RONALD L.;REEL/FRAME:005466/0020
Effective date: 19900921
|Jun 1, 1995||FPAY||Fee payment|
Year of fee payment: 4
|Jul 1, 1999||FPAY||Fee payment|
Year of fee payment: 8
|Jul 10, 2003||FPAY||Fee payment|
Year of fee payment: 12