This application claims priority under 35 USC § 119(e)(1) of European Patent Application Number 03290003.7 filed Jan. 2, 2003.
Not Applicable
Not Applicable
1. Technical Field
This invention relates in general to electronic circuits and, more particularly, to circuitry for reducing the skew between two signals.
2. Description of the Related Art
In the design of electronic circuits, it is often necessary to compensate for skew between two signals arriving at a common block. Traditionally, the skew between the two signals is reduced with the addition of buffers to equalize the difference between the paths of the two signals. Often, the appropriate buffers can be determined automatically using computer aided design tools.
An example of the problem is set forth in connection with
Delay(A−B)=Skew(Ca−Cb)+Db−Da
In mixed signal design, there will be digital spread delays and analog spread delays. The spread of each cannot be easily compensated with a unique addition of digital delay.
Therefore a need has arisen for a method and circuit for reducing skew between two signals.
In the present invention an electronic circuit includes a first source circuit for generating a first signal and for generating a first calibration signal responsive to a calibration mode and a second source circuit of generating a second signal and for generating a second calibration signal responsive to the calibration mode. A variable delay circuit detects a delay between the first and second calibration signals and applies a delay to the first signal responsive to the detected delay.
The present invention provides significant advantages over the prior art. The variable delay circuit can provide high precision compensation for delays between two signals as determined at the input to a circuit that uses the two signals. Therefore, the variable delay circuit takes into account all sources of delay, without needing any knowledge of the sources of delay or their possible variations. Since calibration can occur as often as desired, the variable delay circuit can compensate for dynamically varying delays. The variable delay circuit is particularly well suited for use with analog RF designs which need frequent high precision calibration between signals.
For a more complete understanding of the present invention, and the advantages thereof, reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
a is a block diagram of an circuit illustrating the problem of skewed signals;
b is a timing diagram for the circuit of
a is a block diagram of a prior art solution for skewed signals;
b is a timing diagram for the prior art solution of
a is a block diagram of a circuit with a variable delay circuit to minimize delays between signals;
b is a timing diagram for the circuit of
The present invention is best understood in relation to
a and 2b illustrate a prior art solution to the problem of signal skew.
Delay(A−B)=Skew(Ca−Cb)+Db−(Da+Dc)
However, it should be noted that clock and signal delays are not exact, since each has a spread which may very based on processing variations and environmental factors. Some environmental factors, such as temperature, may vary during operation of a device. Hence Ca=Canom±ΔCa, Cb=Cbnom±ΔCb, Da=Danom±ΔDa, Db=Dbnom±ΔDb, and Dc=Dcnom±ΔDc, where “nom” indicates and expected nominal value and Δ indicates an expected variation.
In many cases, the possible variations in the delays and clock skew, along with the variation on the compensation delay, Dc, make it impossible to guarantee that the delay between the A and B signals will be within maximum design specifications.
a and 3b illustrate a circuit using dynamic best fit delay compensation. In
During operation of the device, a Start signal is used to calibrate the variable delay circuit 18, such that Dcv is set to an appropriate value that will compensate for the clock skew and delays Da and Db. Dcv is set until a reset signal initiates another calibration. Depending upon the design, the circuit could be calibrated upon start-up, periodically, upon an event, or upon each use of the user circuitry block 14.
The output (B1) of the second source block 12 is coupled to fixed delay buffer 32, with a delay D0. The output of fixed delay buffer 32 is the input to the user block 14.
In operation, the Start signal begins a calibration cycle. It is assumed that the B1 signal is known to (or is designed to) transition to an active state after the A1 signal. Prior to calibration, all flip-flops 24 are reset to output logical “0”s by the RESETZ signal. When the B1 signal transitions high (active), the A1 signal will have begun propagation through the fixed delay buffers 22. When the flip-flops are set, there will be a single occurrence where flip-flops from two consecutive stages have outputs of different logical values—the earlier stage will output a logical “1” and the later stage will output a logical “0”. This is the point where the active edge has propagated through the delay buffers 22.
The AND gate 28 of the stage 20 having the exclusive-or gate 26 with a “1” output will pass the output of that stage's fixed delay buffer 22. Hence, the exclusive-gates 26 and the AND gates 28 form a multiplexer which selects the output of a fixed delay buffer 22 whose cumulative delay (i.e., the delay of all buffers in the chain) most closely matches the delay between the A1 and B1 outputs. In the illustrated embodiment, the exclusive-or gates 26 are configured to choose the output of the fixed delay buffer 22 in the earlier of the two stages at which the transition occurs as the best fit delay; alternatively, the output of the fixed delay buffer 22 in the later of the two stages could be chosen as the best fit delay by coupling each exclusive-or gate to the output of the flip-flop 24 of its own stage and the output of the flip-flop 24 of the preceding stage (rather than the output of the flip-flop 24 of the subsequent stage, as shown).
Table 1 illustrates the propagation of the A1 signal through the variable delay buffer 18 during a calibration cycle. When B1 transitions to an active state, A1 has passed through the delay buffers 22 of stages 1-4, but has not yet passed through the delay buffer 22 of stage 5. If the delay of each delay buffer 22 is D, it can be said that 4*D<=Delay(A1−B1)<5*D.
The exclusive-or gate 26 for stage “4” will be the only exclusive-or gate that outputs a “1”; the remainder of the exclusive-or gates 26 will output “0”s. Accordingly, only the AND gate 28 of stage “4” will pass the output of the stage's fixed delay buffer 22. The outputs of all other AND gates 28 will be logical “0”s.
The maximum delay is provided at the output of the fixed delay buffer 22 of the last stage. If the active edge of A1 precedes the active edge of B1 by more the sum of all the fixed delay buffers 22, then the maximum delay will be used (since the input of the exclusive-or gate 26 in the last stage is set to a “1”).
The implementation of the variable delay circuit 18 shown in
For a given maximum delay, the resolution of the variable delay circuit 18 can be increased by providing more delay elements 22, each with a smaller delay D.
After the appropriate delay buffer 22 is selected for output, the Start signal transitions to an inactive state. At this point, the appropriate delay is memorized in the variable delay circuit 18. The A1 signal will continue to pass through the chain of delay buffers 22 up to the selected delay buffer, at which point it will pass through the AND gate 28 of the associated stage and the OR gate 30 to the user block 14. This will continue until another calibration is initiated using the Start signal.
The delay buffer 32 compensates for the delays associated with the AND gate 28 and OR gate 30 through which the A1 signal must pass. However, since these delay buffer 32 is fabricated in close proximity to the AND gates 28 and OR gates 30, any variation due to processing or temperature will be closely matched.
The present invention provides significant advantages over the prior art. The variable delay circuit 18 provides high precision compensation for delays between two signals. The compensation is determined at the input to the user circuit 14 and therefore takes into account all sources of delay, without needing any knowledge of the sources of delay or their possible variations. Since calibration can occur as often as desired, the variable delay circuit 18 can compensate of dynamically varying delays. The variable delay circuit is particularly well suited for use with analog RF designs which need frequent high precision calibration between signals.
As is known to those skilled in the art, the logic used to implement the multiplexer could be varied, without changing the functionality of the variable delay circuit 18. The concept is easily extended to cases where the active edges of A1, B1 and Start could be logical “0”s or mixed.
Although the Detailed Description of the invention has been directed to certain exemplary embodiments, various modifications of these embodiments, as well as alternative embodiments, will be suggested to those skilled in the art. The invention encompasses any modifications or alternative embodiments that fall within the scope the claims.
Number | Date | Country | Kind |
---|---|---|---|
03290003 | Jan 2003 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
4814879 | McNeely | Mar 1989 | A |
5880612 | Kim | Mar 1999 | A |
6192092 | Dizon et al. | Feb 2001 | B1 |
6469550 | Kurd | Oct 2002 | B1 |
20020191719 | Hasako et al. | Dec 2002 | A1 |
Number | Date | Country |
---|---|---|
199 20 335 | Sep 2000 | DE |
0 831 588 | Mar 1989 | EP |
2 768 575 | Mar 1999 | FR |
Number | Date | Country | |
---|---|---|---|
20050040862 A1 | Feb 2005 | US |