The present invention relates to delay-locked loop (DLL) circuits. More particularly, this invention relates to DLL circuits for use in, for example, programmable logic devices (PLDs) or semiconductor memory devices for providing adjustable phase shift control of a DLL clock signal using a processed control signal.
In general, a PLD is a general-purpose integrated circuit device that is programmable to perform any of a wide range of logic tasks. It is known to incorporate one or more DLL circuits into PLDs to achieve a certain phase shift between clock and data signals as required by many different applications (e.g., for several memory interface standards). Alternatively, DLL circuitry may be incorporated directly into semiconductor memory devices or other types of circuitry. For example, a DLL circuit may be used to provide a data input/output timing signal, or data strobe signal (DQS), that is phase shifted with respect to an external, or reference clock signal. In turn, this phase shifted DQS may be used for clocking data into and out of a memory device during respective write and read cycles.
A conventional DLL circuit that provides a phase shifted DLL control signal based on a reference clock signal may include a pair of variable delay circuits (e.g., a main variable delay circuit and a second, smaller variable delay circuit), a phase detector and an up down counter that provides the main and smaller variable delay circuits with a main control signal. The phase detector compares the reference clock signal with a delayed version of the reference clock signal, or internal clock signal, that is produced by the main variable delay circuit. Based on this comparison, the phase detector either increments or decrements the up down counter. In response, the main control signal produced by the up down counter is adjusted to either increase or decrease the delay setting of the main variable delay circuit. This process repeats, with the internal clock signal coming closer in phase to the reference clock signal following each adjustment to the delay setting of the main variable delay circuit.
Once the DLL circuit is locked (i.e., the internal clock signal and the reference clock signal are in phase), the main control signal is set such that the delay by the main variable delay circuit is equal to one complete clock cycle of the reference clock signal. At this time, the main control signal is also used to control the delay setting of the smaller variable delay circuit, which provides a certain phase shift to a DQS. Depending on the relative sizes of the main and smaller variable delay circuits (e.g., the number of delay stages in the smaller variable delay circuit compared to the number of delay stages in the main variable delay circuit), a particular phase shifted DQS is generated.
With conventional DLL circuits such as described above, the phase shift for DQS when the DLL circuit is locked is not adjustable once the size relationship between the main and smaller variable delay circuits is set. For example, if the frequencies of the reference clock signal and the DLL clock signal are substantially identical, and the smaller variable delay circuit is one-fourth the size of the main variable delay circuit, then the DLL clock signal will be shifted by one-fourth of a complete clock cycle (i.e., 90°) when the DLL circuit is locked. Many applications, however, require the phase shift of a DLL clock signal (e.g., a DQS) to be adjustable even after the size relationship between the main and smaller variable delay circuits is set.
Therefore, DLL circuitry is needed that is capable of providing a DQS or other type of DLL clock signal with adjustable phase shift even after the size relationship between the main and smaller variable delay circuits has been set.
In accordance with the principles of the present invention, circuits and methods for providing a DQS (or any other suitable DLL clock signal) with an adjustable phase using a processed control signal are described herein.
In a first implementation of the invention, a DLL circuit is provided that includes a main variable delay circuit, a second, smaller variable delay circuit, a phase detector and an up down counter for providing a main control signal, each of which operates substantially as described above. The DLL circuit according to the invention, however, also includes a processing circuit. In a first embodiment, the processing circuit includes an arithmetic logic unit (ALU). The ALU receives the main control signal produced by the main variable delay circuit, and, in response to an ALU control signal and an offset control signal, produces a processed control signal that is provided to the smaller variable delay circuit. When the DLL circuit is locked, the smaller variable delay circuit provides a phase shift to the DQS based on the processed control signal. Given that the ALU control and offset control signal may be provided directly by user inputs or any other suitable source and may be varied during operation of the DLL circuit, the phase shift of DQS is adjustable even after the size relationship between the main and smaller variable delay circuits is set.
In another implementation of the invention, a DLL circuit is provided that, as with the first implementation, includes a main variable delay circuit, a second, smaller variable delay circuit, a phase detector, an up down counter for providing a main control signal and a processing circuit. Instead of an ALU, however, the processing circuit of the DLL circuit includes a second up down counter for producing a processed control signal. An initial counter value signal is used to set an offset value between the two up down counters, which, during operation of the DLL, are synchronously incremented or decremented based on the output signals provided by the phase detector. When the DLL circuit is locked, the control signal from the second up down counter (i.e., the processed control signal) is used to control the delay setting of the smaller variable delay circuit. Accordingly, by adjusting the initial counter value signal, which may also be provided directly by user inputs or any other suitable source, the phase shift of the DQS by the smaller variable delay circuit can be adjusted even after the size relationship between the main and smaller variable delay circuits is set.
Further features of the invention, its nature and various advantages will be more apparent upon consideration of the following detailed description, taken in conjunction with accompanying drawings, in which like reference characters refer to like parts throughout, and in which:
The present invention relates to DLL circuits that provide a DLL clock signal (e.g., a DQS) with an adjustable phase shift using a processed control signal.
DLL circuit 100 includes a main variable delay circuit 102 that delays a reference clock signal REF CLK to provide an internal clock signal INT CLK. REF CLK may come from the output of an oscillator, another DLL circuit or any other suitable source. As illustrated in
Phase detector 104 of DLL circuit 100 is used to detect a difference between the phase of INT CLK and the phase of REF CLK. It will be understood that phase detector 104 may be as simple as a register (not shown), where REF CLK is used to sample the delayed clock (i.e., INT CLK). Alternatively, phase detector 104 may be constructed using a D-type flip-flop (not shown), or any other suitable circuitry.
Based on a detected phase difference between INT CLK and REF CLK, phase detector 104 provides an output signal Q to up down counter 106, thereby causing up down counter 106 to either count up or count down, and main control signal 108 to adjust the delay setting of main variable delay circuit 102 accordingly. For example, if phase detector 104 determines that the phase of INT CLK leads the phase of REF CLK, then phase detector 104 provides an output signal Q that increments up down counter 106, causing main control signal 108 to increase the amount of delay introduced by main variable delay circuit 102 on REF CLK. On the other hand, if phase detector 104 determines that the phase of INT CLK lags the phase of REF CLK, then output signal Q phase detector 104 decrements up down counter 106, causing the amount of delay introduced by main variable delay circuit 102 on REF CLK to be reduced. In this manner, following each comparison made by phase detector 104, the difference in phase between INT CLK and REF CLK is reduced and is eventually brought close to zero. Once DLL circuit 100 is locked (e.g., INT CLK is substantially in phase with REF CLK), control signal 108 is set such that the delay by main variable delay circuit 102 equals one complete clock cycle of REF CLK.
DLL circuit 100 further includes a second, smaller variable delay circuit 110 for providing a phase shifted DQS, which is 1/K times the size of main variable delay circuit 102. As illustrated in
In accordance with the principles of the present invention, DLL circuit 100 also includes a processing circuit, ALU 120, for providing a processed control signal 122 to smaller variable delay circuit 110. As illustrated in
ALU 120 uses a main control signal 108 and a variable control signal (i.e., offset control signal 124) in producing processed control signal 122. In particular, ALU 120 produces processed control signal 122 by either adding or subtracting offset control signal 124 from main control signal 108, depending on the value of ALU function control signal, ALU_CNTRL. It will be understood that while ALU 120 separately receives offset control signal 108 and ALU_CNTRL, as illustrated in
Persons skilled in the art will also appreciate that ALU 220 can be as simple as an adder that can do both addition and subtraction, or may be any other suitable type of circuitry. Moreover, it will further be understood that ALU_CNTRL and offset control signal 124 may be provided directly by user inputs, by configuration random access memory (CRAM) bits, or any other suitable source. Accordingly, the delay provided by smaller variable delay circuit 110, and thus the phase shift of DQS, can be dynamically adjusted during the operation of DLL circuit 100 by varying ALU_CNTRL and offset control signal 124.
In operation, processed control signal 122 of DLL circuit 100 generates DQS with a phase shift of (360/K)±(S*AD*Δw) when DLL circuit 100 is locked, where K=4 for DLL circuit 100 (as explained above) and S is the number of delay stages in smaller variable delay circuit 110 being controlled by processed control signal 122 (for DLL circuit 100, S=1). AD, meanwhile, is the decimal equivalent of offset control signal 124 that will be used to offset main control signal 108 (i.e., either added to or subtracted from main control signal 108, as controlled by ALU_CNTRL), and Δw is the phase delay associated with each delay step of the various delay stages in variable delay circuits 102 and 110.
As an example, assume that each delay stage of variable delay circuits 102 and 110 has associated with it a minimum delay time (T0) of 150 ρs, and a minimum phase delay (W0) of 16°. Moreover, assume that for each delay stage the time delay (Δt) associated with each of the 64 delay steps is 40 ρs, and that REF CLK has a frequency of 300 MHz, in which case Δw is approximately 4.32°. The following is a table illustrating the respective time delays and equivalent phase shift values associated with each delay stage of either delay circuit 102 or delay circuit 110, where “Control Signal” is the control signal being used to control the respective delay circuit and DCS is its decimal equivalent.
When DLL circuit 100 is locked at 300 MHz, the four delay stages of main variable delay circuit 102 will have a combined delay of one complete clock cycle (i.e., 360°), which is approximately 3.33 ns. Each of the four delay stages of main variable delay circuit 202 will thus have a delay of approximately 833 ρs (which is one-fourth of the combined delay of the four delay stages).
As illustrated by Table 1, the closest delay provided by DLL circuit 200 using the values provided above is 830 ρs. This amount of delay can be achieved through the use of 17 delay steps in each of the four delay stages of main variable control circuit 102, corresponding to a main control signal 108 of 010001. Without the use of ALU 120 (as in conventional DLL circuits), this value of main control signal 108 would be used to directly control the one delay stage of smaller variable delay circuit 110, resulting in a fixed DQS phase shift equaling approximately 90°.
To provide a DQS with an adjustable phase shift when DLL circuit 100 is locked (i.e., a phase shift that is not fixed once the value of K is set), ALU 120 is used to add or subtract offset control signal 124 from main control signal 108. For example, assume a 300 phase shift is desired for DQS. Solving the equation above for AD yields a value of −13.89 (rounded to −14). Accordingly, to achieve a phase shift for DQS closest to the desired 30°, ALU 120 is used to subtract an offset control signal 124 of 001110 (the binary equivalent of 14) from the main control signal 108 of 010001 that is being used to provide a one cycle delay by main variable delay circuit 102. In this manner, ALU 120 produces a processed control signal 122 of 000011 (the binary equivalent of 3). When provided to smaller variable delay circuit 110, which has only one delay stage, the adjustable phase shift of DQS is set to 28.96°, the closest phase shift to the desired 30°.
Alternatively, assume for example that a phase shift of 95° is desired. In this case, ALU 120 may be used to add an offset control signal 108 of 000001 (given that AD=1 after rounding to the nearest integer) to main control signal 108, which as explained above is set to 010001 when DLL circuit 100 is locked. Accordingly, processed control signal 122 becomes equal to 010010, and smaller variable delay circuit 110 will produce DQS with 93.76° phase shift, the closest phase shift to the desired 95°. As demonstrated by these two examples, ALU_CNTRL and offset control signal 124 may be used to control the processed control signal 122 produced by ALU 120, and thus, to dynamically adjust the phase shift for DQS even after K is set.
As illustrated by the values shown in Table 1, the difference in phase between selectable phase shifts for a DQS when using DLL circuit 100 is equal to Δw, or 4.32°. It will be appreciated that, for DLL circuits using a smaller variable delay circuit having more than a single delay stage, the difference in phase between selectable phase shifts is equal to Δw multiplied by the number of delay stages in the smaller variable delay circuit being controlled by processed control signal 122. For example, assuming Δw=4.32° in a DLL circuit where the smaller variable delay circuit includes three delay stages each being controlled by processed control signal 122, the difference in phase between selectable phase shifts for a DQS will be approximately 13°. Therefore, in order to provide finer adjustability for the DQS phase shift provided, delay stages using delay steps that each introduce a smaller phase shift (i.e., less than 4.32°) may be used. As explained above, the parameters of the delay circuits used in providing a phase shifted DQS are not limited to the examples provided herein.
Moreover, it will also be understood by those skilled in the art that processed control signal 122 produced in accordance with the principles of the present invention does not need to be used to control each of the delay stages in smaller variable delay circuit 110. For illustrative purposes, assume that instead of one delay stage as illustrated in
In particular, phase detector 204 compares the phase difference between INT CLK (the delayed signal produced by main variable delay circuit 202) and REF CLK. On the basis of a detected phase difference between INT CLK and REF CLK, phase detector 204 provides an output signal Q to increment or decrement up down counter 206, thereby causing main control signal 208 to adjust the delay setting of main variable delay circuit 202. For example, assuming phase detector 204 measures INT CLK as leading REF CLK, output signal Q increments up down counter 106, thereby causing main variable delay circuit 202 to increase the amount of delay on REF CLK. On the other hand, if INT CLK is measured by phase detector 204 to be lagging REF CLK, output signal Q decrements up down counter 206, thereby causing main variable delay circuit 202 to decrease the amount of delay on REF CLK. In this manner, following each comparison of INT CLK and REF CLK by phase detector 204, and each subsequent adjustment to the delay setting of main variable delay circuit 202, the phase difference between these INT CLK and REF CLK is reduced. Eventually, the phase difference between INT CLK and REF CLK will be substantially close to zero, and DLL circuit 200 will become locked.
Once DLL circuit 200 is locked, control signal 208 is set such that the delay by main variable delay circuit 202 is equal to one clock cycle of REF CLK. Accordingly, the four delay stages of main variable delay circuit 202 will have a combined delay of one complete clock cycle (i.e., 360°). Assuming the same values used above in connection with DLL circuit 100 described above, the complete clock cycle delay is approximately 3.33 ns. Thus, each of the four delay stages of main variable delay circuit 202 has a delay of approximately 833 ρs (which is one-fourth of the combined delay of the four delay stages), corresponding to a main control signal 208 of 010001.
DLL circuit 200, like DLL circuit 100, also includes a processing circuit to provide an adjustable phase shift to DQS (i.e., the phase shift is not fixed when the value of K for DLL circuit 200 is set). Unlike the processing circuit of DLL circuit 100 (which includes ALU 120), however, the processing circuit of DLL circuit 200 includes a second up down counter 220. In particular, second up down counter 220 provides a processed control signal 222 for generating DQS with a phase shift of (360°/K)±(S*BD*Δw) when DLL circuit 200 is locked, where K=4 for DLL circuit 200 and S is the number of delay stages in the smaller variable delay circuit 210 being controlled by processed control signal 222 (for DLL circuit 200, S=1). Moreover, BD is the decimal equivalent of initial value difference between counters 206 and 220 as set a variable control signal (i.e., initial counter value signal 224). In particular, counter 220 will initially be set to a value that is greater than or less than the value of counter 206 by an amount as determined by BD. Moreover, Δw is the phase delay associated with each delay step of the various delay stages in variable delay circuits 202 and 210.
As indicated above, initial counter value signal 224 is used to set the initial value of up down counter 220 to a different value than that of up down counter 206. During operation of DLL circuit 200, up down counter 220 counts up or down (i.e., it is incremented or decremented) synchronously with up down counter 206 based on the output signals Q from phase detector 204. Accordingly, the initial difference in value between counters 206 and 220 (as set by value signal 224) is maintained during operation of DLL circuit 200, and thus, so is the relationship between control signals 208 and 222. It will be understood that initial counter value signal 224 may be provided directly by user inputs, by CRAM bits or any other suitable source. The following examples illustrate the manner in which the phase shift for DQS may be adjusted by varying value signal 224.
Assume, for example, that main control signal 208 from up down counter 206 has an initial value of 100000 (the binary equivalent of 32), and that a DQS with 35° phase shift is desired. In this case, solving the equation above for BD results in a value of −12.73, which rounded to the nearest integer is −13. Accordingly, initial counter value signal 224 sets the initial value of up down counter 220 to 13 less than the value of counter 206, corresponding to an initial processed control signal 222 of 010010 (the binary equivalent of 32−13, or 19). Using the values of Table 1, when DLL circuit 200 becomes locked, up down counter 206 will have been decremented 15 times such that main control signal 208 has a value of 010001 (and each of the four delay stages of main variable delay circuit 202 provides a delay of 90°). Meanwhile, up down/counter 220 will also have been decremented 15 times, and thus, processed control signal 222 will have a value of 000100. Therefore, when DLL circuit 200 is locked, DQS will be phase shifted by 33.280, the closest available phase shift to the desired 35°.
As another example, assume that up down counter 206 has an initial value corresponding to a main control signal 208 of 000010 (the binary equivalent of 2), and that a 275° phase shifted DQS is desired. In this case, BD is rounded to 43, and thus, initial counter value signal 224 is set to 43 greater than the value of counter 206, corresponding to an initial processed control signal 222 of 101110 (the binary equivalent of 2+43, or 45). Using the values of Table 1, up down counter 206 will have been increased 15 times such that main control signal 208 has a value of 010001 (causing approximately 90° delay in each of the four delay stages of main variable delay circuit 202) when DLL circuit 200 is locked. Therefore, up down/counter 220 will also have been increased by 15, and processed control signal 222 will have a value of 111100 (the binary equivalent of 60). Accordingly, when DLL circuit 200 is locked, DQS will be phase shifted by 275.20°, the closest available phase shift to the desired 275°. As demonstrated by these past two examples, initial counter value signal 224 may be used to vary the value that processed control signal 222 will have when DLL circuit 200 is locked, and thus, to dynamically adjust the phase shift for DQS.
As with DLL circuit 100 explained above, it will be understood that processed control signal 222 does not need to be used to control each of the delay stages that may be present in smaller variable delay circuit 210. In particular, DLL circuit 200 may be constructed such that processed control signal 222 controls one or more stages in smaller variable delay circuit 210, while main control signal 208 controls the remaining delay stages. As previously explained, S in the equation above will be equal to the number of delay stages being controlled by processed control signal 222, and not simply to the number of delay stages present in delay circuit 210. The invention is not limited (in this or any other embodiment) by the number of delay stages in smaller variable delay circuit 210 being controlled by the processed control signal 222.
It will be understood that DLL circuits, such as those illustrated in
System 300 can be used in a wide variety of applications, such as computer networking, data networking, instrumentation, video processing, digital signal processing, or any other application. Circuitry 310 may be used to perform a variety of different logic functions. For example, circuitry 310 may be configured as a processor or controller that works in cooperation with processor 304. Circuitry 310 may also be used as an arbiter for arbitrating access to a shared resource in system 300. In yet another example, circuitry 302 can be configured as an interface between processor 304 and one of the other components in system 300. It should be noted that system 300 is only exemplary, and that the true scope and spirit of the invention should be indicated by the following claims.
Moreover, various technologies can be used to implement PLDs (like the circuitry 302 in
Persons skilled in the art will appreciate that the principles of the present invention are not limited to the specific embodiments described above. For example, while the DLL circuits 100 and 200 described above are used in a PLD to provide a phase shifted DQS signal, it will be understood that these circuits may also be used in other types of circuitry and to provide phase shifts for different types of signals (i.e., not just a DQS). Additionally, for example, while DQS and REF CLK are shown to be independent signals in
Furthermore, persons skilled in the art will appreciate that various features of the DLL circuits described herein may be changed without departing from the spirit of the present invention. For example, while DLL circuits have been described that produce an INT CLK that is in phase with REF CLK when the DLL circuits are locked, the invention is not limited in this manner. Rather, when clock distribution delay is to be accounted for, it may be desirable to provide an additional delay circuit between the output of the main variable delay circuit and the phase detectors, such that INT CLK leads REF CLK (instead of being matched in phase) when the DLL circuits are locked. Moreover, for example, the DLL circuits according to the invention can be either completely digital or partially analog. The above described embodiments of the present invention are presented for purposes of illustration and not of limitation, and the present invention is limited only by the claims which follow.
This is a continuation of U.S. patent application Ser. No. 10/788,221, filed Feb. 25, 2004, now U.S. Pat. No. 7,091,760, which is incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
3473160 | Wahlstrom | Oct 1969 | A |
4494021 | Bell et al. | Jan 1985 | A |
4633488 | Shaw | Dec 1986 | A |
4719593 | Threewitt et al. | Jan 1988 | A |
4857866 | Tateishi | Aug 1989 | A |
4868522 | Popat et al. | Sep 1989 | A |
4959646 | Podkowa et al. | Sep 1990 | A |
5072195 | Graham et al. | Dec 1991 | A |
5075575 | Shizukuishi et al. | Dec 1991 | A |
5079519 | Ashby et al. | Jan 1992 | A |
5133064 | Hotta et al. | Jul 1992 | A |
5204555 | Graham et al. | Apr 1993 | A |
5349544 | Wright et al. | Sep 1994 | A |
5397943 | West et al. | Mar 1995 | A |
5418499 | Nakao | May 1995 | A |
5420544 | Ishibashi | May 1995 | A |
5506878 | Chiang | Apr 1996 | A |
5542083 | Hotta et al. | Jul 1996 | A |
5581214 | Iga | Dec 1996 | A |
5642082 | Jefferson | Jun 1997 | A |
5646564 | Erickson et al. | Jul 1997 | A |
5656959 | Chang et al. | Aug 1997 | A |
5699020 | Jefferson | Dec 1997 | A |
5742180 | DeHon et al. | Apr 1998 | A |
5744991 | Jefferson et al. | Apr 1998 | A |
RE35797 | Graham et al. | May 1998 | E |
5777360 | Rostoker et al. | Jul 1998 | A |
5815016 | Erickson | Sep 1998 | A |
5815017 | McFarland | Sep 1998 | A |
5847617 | Reddy et al. | Dec 1998 | A |
5883534 | Kondoh et al. | Mar 1999 | A |
5900757 | Aggarwal et al. | May 1999 | A |
5963069 | Jefferson et al. | Oct 1999 | A |
5987543 | Smith | Nov 1999 | A |
6011732 | Harrison et al. | Jan 2000 | A |
6014048 | Talaga, Jr. et al. | Jan 2000 | A |
6069506 | Miller, Jr. et al. | May 2000 | A |
6069507 | Shen et al. | May 2000 | A |
6094082 | Gaudet | Jul 2000 | A |
6114915 | Huang et al. | Sep 2000 | A |
6137325 | Miller, Jr. | Oct 2000 | A |
6141394 | Linebarger et al. | Oct 2000 | A |
6154073 | Choi | Nov 2000 | A |
6166990 | Ooishi et al. | Dec 2000 | A |
6208183 | Li et al. | Mar 2001 | B1 |
6255870 | Na | Jul 2001 | B1 |
6278332 | Nelson et al. | Aug 2001 | B1 |
6313676 | Abe et al. | Nov 2001 | B1 |
6320469 | Friedburg et al. | Nov 2001 | B1 |
6388485 | Kim | May 2002 | B2 |
6486716 | Minami et al. | Nov 2002 | B1 |
6518807 | Cho | Feb 2003 | B1 |
6667641 | Wang et al. | Dec 2003 | B1 |
6680635 | Lee | Jan 2004 | B2 |
6683928 | Bhullar et al. | Jan 2004 | B2 |
6741107 | Borkar et al. | May 2004 | B2 |
7002384 | Chong et al. | Feb 2006 | B1 |
7009433 | Zhang et al. | Mar 2006 | B2 |
7034589 | Chao | Apr 2006 | B2 |
20010009385 | Lai et al. | Jul 2001 | A1 |
Number | Date | Country |
---|---|---|
0 266 065 | Sep 1987 | EP |
0 416 930 | Mar 1991 | EP |
0 778 517 | Jun 1997 | EP |
1 137646 | May 1989 | JP |
Number | Date | Country | |
---|---|---|---|
Parent | 10788221 | Feb 2004 | US |
Child | 11479660 | US |