This invention relates to the field of frequency synthesis, and in particular to a flexible waveform generator with extended range capability.
In frequency synthesis an accurate reference clock is used as basis for stability and accuracy. However such a clock generally has a fixed frequency. Therefore, fractional frequency synthesizers with analog PLLs (Phase Locked Loops) are used to generate a clock with the desired frequency. An analog PLL is usually used to multiply the frequency and a divider is used to divide the frequency.
There are many applications that require a very wide frequency spanning multiple decades from hundreds of MHz down to 1 Hz. Such a range is not feasible for the Voltage Controlled Oscillator (VCO) that is part of the analog PLL. Additionally to suppress jitter and noise the VCO frequency range should be limited to up most an octave. This makes the VCO frequency range relatively small. When the maximum VCO frequency is chosen to be the highest required frequency, the output frequency range of the synthesizer can be increased by the use of counters/dividers.
When the frequency synthesizer with its analog PLL and its dividers is implemented in a silicon chip the hardware is fixed and cannot be changed afterwards. This means that when an output clock is needed with frequency below the lower limit a new die is needed. An example for frequency synthesis can be found in U.S. Pat. No. 5,905,388.
Frequency synthesis systems make much use of counters and/or dividers in their designs. They are used to reduce the frequency of some clock generator or to count a sequence of states that can be decoded to produce a complex waveform. The fractional frequency synthesizer of
The schematics and designs of such counters and/or dividers can be found in any basic textbook on digital electronics. The counters can be designed either with a fixed division ratio or flexible with programmable division ratio between 1 and the maximum count value Qmax. The counting range or division ratio will be limited. When a larger division ratio is needed the counter design needs to be changed. This requires a hardware modification.
The architecture of a frequency synthesizer includes the following elements: A reference; an analog PLL; a counter, and a decoding circuit. The decoding circuits translates/decodes the counter state to an output value. The shape of the output value could be a 50% duty cycle clock, a frame pulse or any other complex repeating signal as shown in
Counters and dividers have some inherent limitations that have nothing to do with the skill of the circuit designer or the nature of counters. Some of these limitations are:
The start up phenomena in the analog PLL and output counters will introduce input/output and output/output misalignment. At start up the output counters will enter an undefined state. When two or more analog PLLs are started, the analog PLLs will follow different trajectories to a locked state even when they use the same clock as reference. This is due to slightly different component values, different noise sources, and delay values. The number of generated clocks over the locking period will be different. Consequently the counters that are connected to different analog PLLs will have different states.
Switching over to another reference frequency during the operation will force the analog PLL to lock to a different frequency. During locking the relation with the input clock might be lost. The trajectory the analog PLL follows during the locking has random components and is for a part not predictable. This will result in misalignment of the output in relation with the input and the other outputs.
Signals and clocks coming from different output counters will have different phases and there is a significant output-output offset and uncertainty about the offset. This is an undesired phenomenon. Precise and defined relations between different output clocks are a hard requirement for frequency synthesizers. In telecom systems, for example, when the frame pulse occurs all clocks must have rising edges at that moment.
These problems are solved when all counters have a direct relation with the reference. The relations between the analog PLLs and the reference are already defined. The reference is directly connected to the input of the PLL. But the counters must be tied to the reference. The state of the counters must be enforced to defined values at prescribed moments.
Loading a counter with a defined value on a precise moment can be done two different ways. Either the counter can be loaded with a constant value, which is not necessarily zero. This is called reset. Or, the counter is loaded with a varying value this is called loading. In essence reset is a specific form of loading. Both methods have been used either stand alone or in combination.
When the frequencies of the output clocks are very different; in other words with a very low common frequency, the number of common moments suitable for reset is significantly reduced. When more than one FEC (Forward Error Correcting) ratio is present in a telecom system the common frequency is very low. This causes long startup times. It takes a long time before one can be certain that the outputs are properly aligned. This will also become a problem during factory testing. Reset is not a optimal solution.
Factory test time of silicon chips is expensive. The more test time is required, the more money is involved. Any fabricated chip must be tested before can be sold and used. As stated earlier scan chains can be used in output counters because of the high frequencies involved. Only functional testing is possible. When however a long divider chain is required the test time will become unacceptably large.
The present invention addresses a number of the above-mentioned problems. It comprises two clocks whose frequencies have a fixed ratio QFB=fCLK2/fCLK1. One clock CLK1 has a low frequency and is used for counting and decoding. The second clock, CLK2, running at a higher rate is used to output the results of the counting and decoding operation.
Thus, according to the present invention there is provided a frequency synthesizer comprising a first clock running at a frequency fCLK1; a second clock running at a frequency fCLK2, wherein frequency fCLK2 is higher than frequency fCLK1, said frequencies having a fixed ratio QFB=fCLK2/fCLK1; a counter driven by said first clock and incrementing by a predetermined number which is either QFB or a submultiple of QFB for each cycle of said first clock; a decoder for converting the output of said counter to produce QFB or a submultiple thereof output values in parallel in successive cycles of said first clock; and a parallel-serial converter for serially outputting said output values at a rate determined by said second clock.
Embodiments of the invention offer a new architecture for output counters with one or more of the following benefits: Maximum division ratio is not limited by hardware; possibly higher VCO frequency; Quickly restored output-output alignment; Output-output alignment does not depend on the locking behavior of the analog PLL; Clock and frame pulse signals are generated with the same hardware; Easy to create offsets with a VCO cycle resolution; Shorter factory test time.
The invention will now be described in more detail, by way of example only, with reference to the accompanying drawings, in which:
A counter structure in accordance with an embodiment of the invention is shown in
Since the counting is done at a lower rate it is not possible to count the cycles of the high speed clock directly. There is however a relation between the frequencies of the low-speed clock and the high speed clock. For each cycle of the low speed clock the high speed clock will produce QFB cycles. Thus for each low speed clock cycle QFB high speed clock cycles must be counted.
The decoding circuit 16 that converts counter values to output values also runs at a lower frequency. For each cycle of CLK1 it generates multiple, that is QFB, output values in parallel. The set of output values are placed sequentially on the output at the rate of CLK2. Parallel-serial converter 18 runs at the speed of the high speed clock CLK2. A parallel-load shifter loads each reference cycle the QFB output values into the shift register and successively shifts them out. Alternatively the data is loaded into a register and a multiplexer successively selects them for output.
Now that the counters and decoders run at lower frequency the capacitive load on the counting circuits due to decoding logic is no longer a problem. The circuits have more time to settle and any carry has time to ripple through the circuit. Updating the counters with a new value is then also no problem. Because the control and/or interface logic can run synchronously with the cycle counters and decoders on the low speed clock no synchronizer is needed for the reset or load signal.
A analog PLL 22 with stable reference 24 can be used to generate the high speed clock from the low speed clock as shown in
A shifter 26 with a counter 28, such as is shown in
An alternative technique is to load the data parallel into a register 30 with the aid of counter 32 and multiplex the data to the output with multiplexer 34 as shown in
When a PLL is used to create the high-speed clock CLK2 from the low-speed clock CLK1 the counters M and L 32, 28 are already present in the analog PLL 22 as the feedback divider, so this does not add extra circuitry. The maximum count value of the counters M and L is equal to the feedback ratio QFB. In the combined solution of shifters and multiplexer the product of M and L is equal to the feedback ratio QFB. This fits with the requirement that for each reference cycle QFB output values are needed.
Mathematically speaking dividers are incrementers that are combined with a modulo operation. In other words they count and wrap around at the modulo value which happens to be the divider ratio Qout. (The result of the modulo operation is the remainder of an integer division.) Each high-speed clock cycle the counter increments until the end value (modulo value) is reached at which point the counter wraps around and gives a carry pulse to indicate it has wrapped around. Formulating this in mathematics with jcLK2 being the high-speed counter value:
φCLK2[n+1]=(φCLK2[n]+1)mod Qout
For each low-speed clock cycle the high-speed clock will generate QFB cycles. Here QFB is the frequency ratio of the two clocks. So instead of counting each high-speed clock individually they will be counted in groups of QFB. Whenever the low speed clock produces a cycle QFB is added to the cycle counter. The new counter value is found with:
φCLK2[n+1]=(φCLK2[n]+QFB)mod Qout
This equation must be evaluated every low-speed clock cycle as shown in
φCLK2[n+1]=(φCLK2[n]+(QFB mod Qout))mod Qout
This equation results in simpler hardware for the modulo operation, which can be implemented as shown in
In an alternative embodiment, a hardware table can be used. Since the frequency ratio has a limited division ratio value QFB, the table can also be kept limited in size.
It is now very easy to create time offsets in steps of one cycle of the high-speed clock. It is just necessary to add the number of high-speed clock cycles of offset that is desired to the value of the cycle counter and perform the modulo Qout operation. Again this operation is carried out at a low clock rate.
For the decoder implementation the table can contain the waveforms for different values of Qout. A method using thresholds can be employed. The threshold values determine cycle counter values for which the output changes and edges occur. We will see that the table method is most efficient for small values of Qout and that the method with thresholds and edges can be extended to cross the barrier of maximum count value of hardware implemented counters.
Table Method
With the cycle counter value known the next QFB output values for an output pattern must be generated. The decoder maps the cycle counter value to an output value. But with the cycle counter running at a lower clock frequency multiple output values must be calculated. The next QFB number of output values starting from the current cycle value must be determined.
When the full waveform is stored in a table the counter value can be used as an offset in the table to determine next output values. When the table is placed in a register a barrel shifter can be used to select the correct part of the waveform. The cycle counter value is used as an offset in the table to find the output pattern. See
When the counter value is for instance Qout−1 a wrap around must occur to the first part of the waveform. In hardware this not handled easily since the value for Qout can change. Therefore the waveform is extended with the next QFB-1 values, which happen to be the first values are copied. A similar problem occurs when Qout is smaller than QFB. The waveform must be extended. The minimum size of the waveform or base pattern is Qout+QFB−1. When the highest count value of the cycle counter is reached at the moment of a reference cycle then QFB−1 additional bits are needed for a complete output pattern as illustrated in
Table 4 gives examples up to the Qout=8. However division by 1 is simply the high-speed clock itself and that a circuit for the division by zero is still a challenge for engineers. When the division ratio is odd the output clock does not have a 50% duty cycle.
When Qout is increasing the size of the base pattern also increases. For large values of Qout the base pattern will become too large to store. So this method is only feasible for small values of Qout.
By adding the circuit of
A simple implementation for the decoder checks whether the cycle counter value φCLK2 is above or below the threshold TH0, which is in the case of clock signals half the division value Qout. Since the cycle counter never reaches TH1, the division value Qout, the hardware can be as simple as in
As explained earlier the mapping function hardware has to generate multiple output values per cycle of the low-speed clock. For each low-speed clock cycle QFB high speed clock cycles are processed. This implies that a total of QFB comparators would be required to compare the next QFB cycle counter values and find the output pattern. We need to compare the threshold TH0 with φCLK2, φCLK2+1, . . . , and φCLK2+QFB-1.
We start with an output pattern for the comparator around the threshold of the edge as shown in
The used base pattern and its use can be found in
When the counter value is for instance Qout-1 a wrap around must occur to the first part of the waveform. In hardware this not handled easily since the value for Qout can change. Therefore threshold TH1 also needs to be implemented in hardware next to threshold TH0. The result of the two threshold comparators must be combined. For this Table 6 has been compiled. In general TH0 will cross before TH1 however we need to define a value for that case TH1<TH0. For reasons of simplicity we choose the rule to be if one threshold has been crossed the output will be 0 when zero or two output have been crossed the output will 1. Study of the table shows that the table describes an EXNOR function. Threshold TH1 will set to Qout.
The outputs of the threshold comparators are The QFB bit wide EXNOR function has a QFB bit wide result.
The multiple values for the output of both thresholds are generated in the same way as it is used for the single threshold. The output results of both thresholds are bitwise EXNOR'ed in a QFB wide word. The resulting word is then loaded into the series-parallel converter. This will have same result as loading the results in two series-parallel converters and EXNOR the output of the converters.
When threshold TH0 is small, in fact smaller than QFB, it will come close to threshold TH1 of the previous cycle. Just as with TH1 at the end of the cycle, it needs to be detected in the previous cycle as shown in
Again multiple values for the output of the thresholds are generated is same way as is used for the single threshold. And again output results of the thresholds are bitwise EXNOR'ed in a QFB wide word.
Depending on the value Qout up to QFB edges can be present in the output. The maximum number of edges occurs when Qout is 2 when every high speed clock an edge occurs. This would imply that we need a total of QFB threshold circuits. This however is undesirable because of the big hardware overhead.
For output divider ratios bigger than the cycle counter capacity MAXCNT assistance is needed. An external process, for instance a program running on a microprocessor, does the cycle counting but at a much slower rate. When it is implemented in software only a change in the software is needed to expand the counting capability. The cycle counter SWcnt is compared with the thresholds SWTHx in software and it is checked whether the event occurs within the range MAXcnt of the hardware cycle counter. Then the counter is loaded with 0 and the appropriate values are loaded in the threshold registers. The algorithm below is an example how to calculate the thresholds.
This algorithm must be executed at regular intervals. When the interval is a fraction of the time interval that corresponds to the maximum counter value it will be robust for missing update ticks over the maximum capacity of the cycle counter. Everything goes well as long as the hardware counters are updated at least once for the maximum count interval.
When the counter crosses the maximum counter value MAXCNT minus (QFB+1) it must stop. The counter may not wrap around. This way the last output value is maintained until the software concludes the counter is in reach for the next edge.
In
These embodiments offer the advantages that the shifters can run at a higher frequency than counters; no counters are required in the high frequency domain (This Reduces the factory testing time), alignment of DCO and the output counters Flexible in division ratios, flexibility in the wave pattern, and offset easy to realize in steps of one high-speed clock cycle. Thus embodiments of the invention use two clocks CLK1 and CLK2 with a frequency ratio QFB, with a low-speed counter running on clock CLK1, a high speed counter running on clock CLK2, and a series parallel converter. The low frequency clock CLK1 is used for counting, output decoding or waveform generation. The high frequency clock CLK2 is used to output the waveform. A sub rate of the high frequency clock can also be used to output the waveform.
Each cycle of the clock CLK1 the counter value will be normally increased by QFB. When a subrate S of CLK1 is used the counter will be with S*QFB. A modulo Qout operation is performed on the result of the counter where Qout is the output division ratio. Embodiments of the invention include concurrent calculation of multiple output values, a table containing the output waveforms for varying division ratios, wherein the counter value is used as an offset in the waveform for the chosen division ratio Qout to get the next QFB output values.
Thresholds can be used to define the edges of the output signal, wherein the threshold is compared with the counter value, and the results of the threshold comparators are combined to form the output signal.
An external processor or computer can be used to update the counters and thresholds to be able to count beyond the physical limits of the hardware counters. In that case the counting is done by the computer or processor and the counter and thresholds are programmed to cover between the update moments. The limited counting range is extended by the software running on the computer or processor.
In the extended threshold mode the counters will not wrap around but halt when comes near the maximum count value.
A parallel-series converter is used to output the data with aid of high speed clock CLK2. The parallel-series converter can be implemented as a parallel load shifter or multiplexer, a combination of a multiplexer and parallel load shifter.
An external process can initialize and update the counter values and threshold values. This can be a processor or a computer. An optimal solution comprises a combination of the three described methods (table, edge and extended edge). The use more than three thresholds can create more complex waveforms than clock and frame pulses. Multiple sets of low-speed counter, decoder, high-speed counter and series-parallel converter can be used by a pair of low-speed CLK1 and high speed CLK2 clocks. When the division ratios are powers of 2 optimizations can be performed to reduce the amount of hardware.
Number | Date | Country | Kind |
---|---|---|---|
0714848.9 | Jul 2007 | GB | national |
Number | Name | Date | Kind |
---|---|---|---|
3500213 | Ameau | Mar 1970 | A |
3657657 | Jefferson | Apr 1972 | A |
4068178 | Tunzi | Jan 1978 | A |
5598448 | Girardeau, Jr. | Jan 1997 | A |
6127859 | Lim | Oct 2000 | A |
Number | Date | Country | |
---|---|---|---|
20090184736 A1 | Jul 2009 | US |