1. Field
This invention relates to oscillators, and more specifically, to an RC oscillator based on a delay-free comparator.
2. Background
The resistive-capacitive (RC) oscillator is an important block in very-large-scale integration (VLSI) systems. It provides a reference clock when a crystal oscillator is not available or off for power saving purpose. However, the frequency accuracy of the RC oscillator is limited by RC process variation, resistor temperature coefficient, and comparator delay variation.
The temperature variation of the comparator delay is the major contributor of the frequency variation. Conventionally, the bias current of the comparator is boosted up to make the total delay a small fraction of the clock period. However, the comparator delay saturates at high bias current. To counter this effect, the device size is increased. However, this results in even more current requirement. Therefore, the power efficiency of the RC oscillator prevents it from use in low power applications. Other solutions include selecting low frequency for sleep-mode clock to bypass the delay issue or applying a closed-loop integrator to force the comparator trip voltage to be equal to the reference.
The present invention provides for extracting and cancelling a comparator delay which causes frequency variation in a clock pulse of an RC oscillator, using a switched-capacitor technique.
In one embodiment, a method for cancelling a delay in a comparator of an RC oscillator configured to generate a clock pulse is disclosed. The method includes: selectively coupling a plurality of current sources to a first capacitor, a second capacitor, and a resistor, wherein the plurality of current source charge and discharge the first capacitor and the second capacitor, and charge the resistor; charging the first capacitor at a higher rate during a first phase of the clock pulse than a second phase of the clock pulse, and charging the second capacitor at a higher rate during a third phase of the clock pulse than a fourth phase of the clock pulse; and generating the clock pulse by enabling the comparator to compare a voltage on the first or second capacitor with a voltage on the resistor.
In another embodiment, an RC oscillator which generates a clock pulse is disclosed. The RC oscillator includes: a comparator delay cancellation circuit comprising: a resistor and a pair of capacitors including a first capacitor and a second capacitor; a plurality of current sources configured to charge and discharge the pair of capacitors and the resistor, wherein the first capacitor is charged during first and second phases of the clock pulse and is discharged during third and fourth phases of the clock pulse, and the second capacitor is charged during the third and fourth phases of the clock pulse and is discharged during the first and second phases of the clock pulse, wherein the first capacitor is charged at a same rate during the first phase as the second phase, and the second capacitor is charged at a higher rate during the third phase than the fourth phase; a plurality of switches configured to selectively couple the plurality of current sources to the pair of capacitors and the resistor; and a comparator having a first input and a second input, the comparator configured to generate the clock pulse by comparing a voltage on the first or second capacitor with a voltage on the resistor.
In yet another embodiment, an apparatus to generate a clock pulse is disclosed. The apparatus includes: means for comparing two voltages having a first input and a second input; means for canceling delay in the means for comparing two voltages comprising: means for charging and discharging a first capacitor and a second capacitor, wherein the means for charging and discharging charges the first capacitor at a higher rate during a first phase of the clock than a second phase of the clock pulse, and charges the second capacitor at a higher rate during a third phase of the clock pulse than a fourth phase of the clock pulse; means for selectively coupling the means for charging and discharging to the pair of capacitors and a resistor, wherein the means for comparing two voltages generates the clock pulse by comparing a voltage on the first or second capacitor with a voltage on the resistor.
Other features and advantages of the present invention should be apparent from the present description which illustrates, by way of example, aspects of the invention.
The details of the present invention, both as to its structure and operation, may be gleaned in part by study of the appended further drawings, in which like reference numerals refer to like parts, and in which:
As stated above, the RC oscillator is an important block in VLSI systems. It provides a reference clock when a crystal oscillator is not available or off for power saving purpose. However, the frequency accuracy of the RC oscillator is limited by RC process variation, resistor temperature coefficient, and comparator delay variation. In a conventional RC oscillator design, the offset voltage of the comparator is canceled by comparing two capacitor voltages with a resistor voltage. When the voltage on the first capacitor is ramped up as it is being charged by the first charging current, the second capacitor is shorted to the ground. The comparator compares the first capacitor voltage to the resistor voltage. Upon transition of the comparator, the first capacitor is shorted to the ground, while the voltage on the second capacitor is ramped up as it is being charged by the second charging current. The comparator now compares the second capacitor voltage to the resistor voltage with connections of the capacitor voltage and the resistor voltage to the comparator inputs swapped. The voltage offsets of the comparator are equal in value but opposite in sign during the two phases of the clock cycle (i.e., T1 and T2), and thus, they cancel out. Equation (1) shows the duration of the first phase of the clock cycle as RC minus the product of C and the offset voltage VOS divided by the current I, plus the time delay (Td). Equation (2) shows the duration of the second phase of the clock cycle as RC plus the product of C and the offset voltage VOS divided by the current I, plus Td. Equation (3) shows the derivation of the clock period (T) of the RC oscillator as the sum of the durations of the first phase and the second phase. Thus, the clock period is shown as being equal to two times the RC time constant plus rise and fall time delays (2*Td) of the comparator. Therefore, equation (3) shows the cancellation of the comparator offset voltage (VOS), but the time delays of the comparator remain.
T
1
=RC−CV
OS
/I+T
d (1)
T
2
=RC+CV
OS
/I+T
d (2)
T=T
1
+T
2=2*RC+2*Td (3)
Certain embodiments as described herein provide for extracting and cancelling the comparator delay which causes frequency variation in a clock pulse of an RC oscillator, using a switched-capacitor technique. After reading this description it will become apparent how to implement the invention in various implementations and applications. Although various implementations of the present invention will be described herein, it is understood that these implementations are presented by way of example only, and not limitation. As such, this detailed description of various implementations should not be construed to limit the scope or breadth of the present invention.
During the first clock phase (Φ1), switches S1, S2, and S6 are closed so that capacitor CL is charged with current from current sources CS1 and CS2, while capacitor CR is discharged by current sink CS4. Moreover, capacitor CL is charged at 50% higher rate than a nominal rate because current source CS1 supplies current I (nominal rate), while current source CS2 supplies additional current 0.5*I (50% more) to capacitor CL. During the second clock phase (Φ2), switches S1 and S8 are closed so that capacitor CL is charged with current from current source CS1, while capacitor CR is shorted to the ground. During the third clock phase (Φ3), switches S3, S4, and S5 are closed so that capacitor CR is charged with current from current sources CS2 and CS3, while capacitor CL is discharged by current sink CS4. Moreover, capacitor CR is charged at 50% higher rate than the nominal rate because current source CS3 supplies current I (nominal rate), while current source CS2 supplies additional current 0.5*I (50% more) to capacitor CR. During the fourth clock phase (Φ4), switches S4 and S7 are closed so that capacitor CR is charged with current from current source CS3, while capacitor CL is shorted to the ground. Current source CS5 supplies current I to resistor R so that the resistor voltage VR will have a constant value IR. The clock pulse repeats the four phases as described above.
[I*T1+I/2*(Tr+Tf)]/C=I*R−VOS+I*Tf/C (4)
[I*T2+I/2*(Tf+Tr)]/C=I*R+VOS+I*Tr/C (5)
T=T
1
+T
2=2*RC (6)
Equation (4) shows the comparator voltage during the first time period (T1) including the first phase (Φ1) and the second phase (Φ2) of the clock pulse. Equation (5) shows the comparator voltage during the second time period (T2) including the third phase (Φ3) and the fourth phase (Φ4) of the clock pulse. The difference in the comparator voltage during these two time periods is the opposite polarity of the offset voltage and the time delay, which cancel out to produce resultant equation (6). Thus, equation (6) shows that the clock period depends solely on the time constant (RC).
After mitigating the temperature and voltage-dependence, the RC oscillator frequency is still dependent on process parameters. For example, the frequency of the RC oscillator can vary up to ±20% across corners, which is due to the resistance and capacitance variation at different corners. To remove or calibrate out the process variation in the oscillator design, a compensation current (ΔI) can be added to the resistor by adding a compensation current source.
T=T
1
+T
2=2(1+Δ)*RC (7)
In the illustrated embodiment of
During the first and second clock phases (Φ1 and Φ2), switches S1 and S6 are closed so that capacitor CL is charged with current from current source CS1, while capacitor CR is shorted to the ground. Thus, during these clock phases, capacitor CL is charged at a nominal rate because current source CS1 supplies current I (nominal rate) to capacitor CL. During the third clock phase (Φ3), switches S2, S3, and S4 are closed so that capacitor CR is charged with current from current sources CS2 and CS3, while capacitor CL is discharged by current sink CS4. Moreover, capacitor CR is charged at 100% higher rate (i.e., CR has double the ramp-up rate of CL during Φ3) than the nominal rate because current source CS3 supplies current I (nominal rate), while current source CS2 supplies additional current I (100% more) to capacitor CR. During the fourth clock phase (Φ4), switches S3 and S5 are closed so that capacitor CR is charged with current from current source CS3 only at a nominal rate, while capacitor CL is shorted to the ground. Current source CS5 and CSΔ supply current I+ΔI to resistor R (similar to the delay-cancellation circuit configuration 700 including the resistor compensation current source (CSΔ) shown in
I*T
1
C=I*R−V
OS
+I*T
f
/C (8)
[I*T2+I*(Tf+Tr)]/C=I*R+VOS+I*Tr/C (9)
T=T
1
+T
2=2*RC (10)
Equation (8) shows the comparator voltage during the first time period (T1) including the first phase (Φ1) and the second phase (Φ2) of the clock pulse. Equation (9) shows the comparator voltage during the second time period (T2) including the third phase (Φ3) and the fourth phase (Φ4) of the clock pulse. The difference in the comparator voltage during these two time periods is the opposite polarity of the offset voltage and the time delay, which cancel out to produce resultant equation (10). Thus, equation (10) shows that the clock period depends solely on the time constant (RC).
Q/(2RC)=fRCO*2n, (11)
wherein RC is the time constant, fRCO is the RC oscillator frequency, and n is the number of bits in the compensation current source.
In one example in which n=10 and fRCO=9.6 MHz, Q is equal to 9.6M*1024*2RC. In order to make the RC oscillator frequency equal to 9.6 MHz, the delta current can be derived as 1+Δ=1024/Q. Since the LSB current has been scaled down by 1024, the normalized binary compensation current (Y) is given below in equations (12) and (13).
Y=(1024−Q)/Q*1024 (for Q<1024) (12)
Y=(Q−1024)/Q*1024 (for Q>1024) (13)
Although code Y is not directly used to control the compensation current mirror, it provides an index indicating where to start the calibration. For example, if Y=14, the calibration should start from the fourth LSB. In another example, if Y is 122, the calibration should start from the fourth MSB, and if Y is 277, the calibration should start from the second MSB. Therefore, once code Y is generated, it is then converted to a one-hot code. The hot position indicates the highest bit of code Y which is one. Accordingly, the one-hot code indicates to the controller where to start the calibration.
Once the RC oscillator frequency is compared to the reference frequency, at step 910, and it is determined that the oscillator frequency is greater than the reference frequency, ΔI is set to positive (POS), at step 920, and Y is calculated to be (2n−Q)/Q*2n, at step 922, where n is the resolution of the compensation current source. In the example of
During the calibration, the binary current source is turned on, at step 932, for bit i, and the new oscillator frequency is compared to the reference frequency, at step 940. Thus, the binary currents are turned on one at a time from MSB to LSB. If the frequency comparison keeps the same polarity, then the binary current source is kept on, and the calibration process jumps to the next current source. That is, if the new oscillator frequency is greater than the reference frequency and ΔI is equal to POS (i.e., the previous oscillator frequency was also greater than the reference frequency) to produce a YES answer, at step 942, then the binary current source at bit i is kept on, at step 950. However, if the new oscillator frequency is greater than the reference frequency and ΔI is equal to NEG (i.e., the previous oscillator frequency was less than the reference frequency) to produce a NO answer, at step 942, then the binary current source at bit i is turned off, at step 952. Otherwise, if the new oscillator frequency is less than the reference frequency and ΔI is equal to NEG (i.e., the previous oscillator frequency was also less than the reference frequency) to produce a YES answer, at step 944, then the binary current source at bit i is kept on, at step 954. However, if the new oscillator frequency is less than the reference frequency and ΔI is equal to POS (i.e., the previous oscillator frequency was greater than the reference frequency) to produce a NO answer, at step 944, then the binary current source at bit i is turned off, at step 952.
After step 950, 952, or 954, the index for the binary current source shifts to the next bit, at step 960. If it is determined, at step 962, that the incremented index for the binary current source is equal to 2*n, then the calibration ends, at step 970. Otherwise, if the incremented index for the binary current source has not yet reached 2*n, then the calibration resumes, at step 932, by turning the binary current source on at bit i on. Thus, during the calibration, a selected set of binary current sources is used to provide the correct amount of compensation current to adjust the RC oscillator frequency. After each calibration, a 2*n-bit calibration code is provided to the current mirror.
In the illustrated embodiment of
In the controller 1030, the arbiter unit 1046 generates multiple timing control signals, which are sent to the D-flip-flops (DFF) in other sub-blocks. The one-hot generator 1050 generates (2n+1)-bit one-hot code, which indicates the current position or index of the double binary current sources under comparison. The current control unit 1048 includes 2n DFF pairs, which turns the current sources on or off. In the illustrated embodiment of the controller 1030 in
Although several embodiments of the invention are described above, many variations of the invention are possible. For example, although the illustrated embodiments described above use two charging capacitors for the RC oscillator, more than two capacitors can be used. Further, features of the various embodiments may be combined in combinations that differ from those described above. Moreover, for clear and brief description, many descriptions of the systems and methods have been simplified. Many descriptions use terminology and structures of specific standards. However, the disclosed systems and methods are more broadly applicable.
Those of skill will appreciate that the various illustrative blocks and modules described in connection with the embodiments disclosed herein can be implemented in various forms. Some blocks and modules have been described above generally in terms of their functionality. How such functionality is implemented depends upon the design constraints imposed on an overall system. Skilled persons can implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the invention. In addition, the grouping of functions within a module, block, or step is for ease of description. Specific functions or steps can be moved from one module or block without departing from the invention.
The various illustrative logical blocks, units, steps, components, and modules described in connection with the embodiments disclosed herein can be implemented or performed with a processor, such as a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor can be a microprocessor, but in the alternative, the processor can be any processor, controller, microcontroller, or state machine. A processor can also be implemented as a combination of computing devices, for example, a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration. Further, circuits implementing the embodiments and functional blocks and modules described herein can be realized using various transistor types, logic families, and design methodologies.
The above description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the invention. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles described herein can be applied to other embodiments without departing from the spirit or scope of the invention. Thus, it is to be understood that the description and drawings presented herein represent presently preferred embodiments of the invention and are therefore representative of the subject matter which is broadly contemplated by the present invention. It is further understood that the scope of the present invention fully encompasses other embodiments that may become obvious to those skilled in the art and that the scope of the present invention is accordingly limited by nothing other than the appended claims.