Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
FRACTIONAL CLOCK GENERATOR WITH RAMP CONTROL INCLUDING FIXED TIME INTERVAL AND COARSE/FINE FREQUENCY CHANGE STEPS
Document Type and Number:
WIPO Patent Application WO/2018/164828
Kind Code:
A1
Abstract:
A clock signal generator including a fractional clock divider and a frequency ramp control circuit. The fractional clock divider is configured to generate an output clock signal with a frequency being a divider ratio multiplied by a frequency of an input clock signal. The frequency ramp control circuit is configured to provide the fractional clock divider a set of divider ratios so that the frequency of the output clock signal is ramped in steps from a current frequency to a target frequency. The frequency ramp control circuit is configured to produce frequency change steps each having substantially the same duration. The frequency ramp control circuit is also configured to provide the set of divider ratios such as a first portion of the frequency ramp is performed using coarse frequency changes and a second portion of the ramp is performed using at least one fine frequency change.

Inventors:
BOWLES KEVIN (US)
PAL DIPTI RANJAN (US)
Application Number:
PCT/US2018/018623
Publication Date:
September 13, 2018
Filing Date:
February 19, 2018
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
QUALCOMM INC (US)
International Classes:
H03K3/017; H03L7/085
Foreign References:
US20070080724A12007-04-12
Other References:
YOON JONG-HYEOK ET AL: "A DC-to-12.5 Gb/s 9.76 mW/Gb/s All-Rate CDR With a Single LC VCO in 90 nm CMOS", IEEE JOURNAL OF SOLID-STATE CIRCUITS, IEEE SERVICE CENTER, PISCATAWAY, NJ, USA, vol. 52, no. 3, 1 March 2017 (2017-03-01), pages 856 - 866, XP011641923, ISSN: 0018-9200, [retrieved on 20170227], DOI: 10.1109/JSSC.2016.2646803
Attorney, Agent or Firm:
FOUNTAIN, George (US)
Download PDF:
Claims:
CLAIMS

1. An apparatus, comprising:

a fractional clock divider, comprising:

a first counter configured to generate an index of edge positions of an input clock signal; and

an output clock generator configured to generate an output clock signal based on a current divider ratio and the index;

a frequency ramp control circuit, comprising:

a second counter configured to generate a first signal based on a selected duration for a frequency change step of the output clock signal, wherein the second counter is synchronized with the first counter; and

a divider ratio determining device configured to determine the current divider ratio.

2. The apparatus of claim 1, wherein the second counter is configured to generate a second signal indicating an end of a sequence of edges of the output clock signal, wherein the first counter is primed based on the second signal.

3. The apparatus of claim 2, further comprising a logic circuit configured to generate a fourth signal indicating an end of the frequency change step based on the first and second signals, wherein the first counter is primed based on the fourth signal.

4. The apparatus of claim 3, wherein the first counter comprises:

a base counter configured to generate a count based on a modulo set by the current divider ratio; and

a loop counter configured to generate the first signal based on the count and a signal for setting the selected duration for the frequency change step.

5. The apparatus of claim 1, wherein the divider ratio determining device is configured to generate a set of divider ratios including the current divider ratio to ramp a current frequency of the output clock signal to a target frequency.

6. The apparatus of claim 5, wherein the divider ratio determining device is configured to:

select a first set of same denominators for a first subset of the set of divider ratios; and

select a second set of one or more same denominators for a second subset of the set of divider ratios.

7. The apparatus of claim 6, wherein each of the same denominators of the first set is less than each of the one or more same denominators of the second set.

8. The apparatus of claim 6, wherein the first set of same denominators are used to achieve a majority of the ramp of the current frequency to the target frequency.

9. The apparatus of claim 6, wherein the first set of same denominators numerators are used to achieve at least a defined percentage of the ramp of the current frequency to the target frequency.

10. The apparatus of claim 6, wherein the divider ratio determining device is configured to select a set of sequential numerators for the first subset of divider ratios.

1 1. A method, comprising:

generating an index of edge positions of an input clock signal;

generating an output clock signal based on a current divider ratio and the index; generating a first signal based a selected duration for a frequency change step of the output clock signal;

synchronizing the generation of the first signal with the generation of the index; and

determining the current divider ratio.

12. The method of claim 1 1, wherein synchronizing the generation of the first signal with the generation of the index, comprises: generating a second signal indicating an end of a sequence of edges of the output clock signal at substantially the same time as the generation of the index; and

generating the first signal based on the second signal.

13. The method of claim 12, further comprising generating a fourth signal indicating the end of the frequency change step based on the first and second signals.

14. The method of claim 13, wherein generating the first signal comprises generating a count based on a modulo set by the current divider ratio and initiated by the fourth signal.

15. The method of claim 11, further comprising generating a set of divider ratios including the current divider ratio to ramp a current frequency of the output clock signal to a target frequency.

16. The method of claim 15, wherein generating the set of divider ratio comprises:

selecting a first set of same denominators for a first subset of the set of divider ratios; and

selecting a second set of one or more same denominators for a second subset of the set of divider ratios.

17. The method of claim 16, wherein each of the same denominators of the first set is less than each of the one or more same denominators of the second set.

18. The method of claim 16, wherein the first set of same denominators are used to achieve a majority of the ramp of the current frequency to the target frequency.

19. The method of claim 16, wherein the first set of same denominators are used to achieve at least a defined percentage of the ramp of the current frequency to the target frequency.

20. The method of claim 16, further comprising selecting a set of sequential numerators for the first subset of divider ratios.

21. An apparatus, comprising:

a fractional clock divider configured to generate an output clock signal with frequencies pursuant to a frequency ramp from a current frequency to a target frequency based on a set of divider ratios multiplied by a frequency of an input clock signal, respectively; and

a divider ratio determining device configured to generate the set of divider ratios including selecting a first set of same denominators for a first subset of the set of divider ratios, and selecting a second set of one or more same denominators for a second subset of the set of divider ratios.

22. The apparatus of claim 21, wherein each of the same denominators of the first set is less than each of the one or more same denominators of the second set.

23. The apparatus of claim 21, wherein the first set of same denominators are used to achieve a majority of the frequency ramp of the current frequency to the target frequency.

24. The apparatus of claim 21, wherein the first set of same denominators are used to achieve at least a defined percentage of the frequency ramp of the current frequency to the target frequency.

25. The apparatus of claim 21, wherein the divider ratio determining device is configured to select a set of sequential numerators for the first subset of divider ratios.

26. A method, comprising:

generating an output clock signal with frequencies pursuant to a frequency ramp from a current frequency to a target frequency based on a set of divider ratios multiplied by a frequency of an input clock signal, respectively; and

generating the set of divider ratios including selecting a first set of same denominators for a first subset of the set of divider ratios, and selecting a second set of one or more same denominators for a second subset of the set of divider ratios.

27. The method of claim 26, wherein each of the same denominators of the first set is less than each of the one or more same denominators of the second set.

28. The method of claim 26, wherein the first set pf same denominators are used to achieve a majority of the frequency ramp of the current frequency to the target frequency.

29. The method of claim 26, wherein the first set of same denominators are used to achieve at least a defined percentage of the frequency ramp of the current frequency to the target frequency.

30. The method of claim 26, wherein generating the set of divider ratios includes selecting a set of sequential numerators for the first subset of divider ratios.

Description:
FRACTIONAL CLOCK GENERATOR WITH RAMP CONTROL INCLUDING FIXED TIME INTERVAL AND COARSE/FINE FREQUENCY CHANGE STEPS

CROSS-REFERENCE TO RELATED APPLICATION

[0001] This application claims priority to and the benefit of Non-Provisional Application No.

15/453,712 filed in the U.S. Patent and Trademark Office on March 8, 2017, the entire content of which is incorporated herein by reference.

BACKGROUND

Field

[0002] Aspects of the present disclosure relate generally to clock signal generators, and in particular, to a fractional clock signal generator with frequency ramp control characterized with fixed time interval and coarse/fine frequency change steps.

Background

[0003] A clock generator may be configured as a fractional clock divider. A fractional clock divider receives an input clock signal and generates therefrom an output clock signal with a frequency equal to a divider ratio multiplied by the frequency of the input clock signal. Often a fractional clock divider is used in applications where the frequency of the output clock signal is changed based on certain requirements.

[0004] If the output clock signal is applied to a core of an integrated circuit (IC), a change in the frequency of the output clock signal produces a change in the current supplied to the core. If the change in frequency is a large positive change, the current supplied to the core increases substantially. This may cause a relatively large voltage droop in a supply or rail voltage used by the core. The large voltage droop may cause malfunction or other adverse effects in the operation of the core.

[0005] Accordingly, to prevent or reduce the voltage droop produced in the rail voltage, the frequency of a clock signal supplied to the core is gradually changed in steps from a current frequency to a target frequency. This produces a small voltage droop per each frequency change step, wherein the small voltage droop is not likely to cause malfunction or other adverse effects in the operation of the core.

[0006] It is desirable for the frequency change steps to have substantially the same duration so that the corresponding current surge and voltage droops are sufficiently spaced apart so that the rail voltage may recover from each voltage droop. Further, it is desirable for the frequency change steps to be configured to produce a relatively fast frequency ramp from a current frequency to a target frequency and with high resolution in achieving the target frequency.

SUMMARY

[0007] The following presents a simplified summary of one or more embodiments in order to provide a basic understanding of such embodiments. This summary is not an extensive overview of all contemplated embodiments, and is intended to neither identify key or critical elements of all embodiments nor delineate the scope of any or all embodiments. Its sole purpose is to present some concepts of one or more embodiments in a simplified form as a prelude to the more detailed description that is presented later.

[0008] An aspect of the disclosure relates to an apparatus including a fractional clock divider having a first counter configured to generate an index of edge positions of an input clock signal, and an output clock generator configured to generate an output clock signal based on a current divider ratio and the index; and a frequency ramp control circuit including a second counter configured to generate a first signal based on a selected duration for a frequency change step of the output clock signal, wherein the second counter is synchronized with the first counter, and a divider ratio determining device configured to determine the current divider ratio.

[0009] Another aspect of the disclosure relates to a method including generating an index of edge positions of an input clock signal; generating an output clock signal based on a current divider ratio and the index; generating a first signal based a selected duration for a frequency change step of the output clock signal; synchronizing the generation of the first signal with the index; and determining the current divider ratio.

[0010] Another aspect of the disclosure relates to an apparatus including a fractional clock divider configured to generate an output clock signal with frequencies pursuant to a frequency ramp from a current frequency to a target frequency based on a set of divider ratios multiplied by a frequency of an input clock signal, respectively; and a divider ratio determining device configured to generate the set of divider ratios including selecting a first set of same denominators for a first subset of the set of divider ratios, and selecting a second set of one or more same denominators for a second subset of the set of divider ratios.

[0011] Another aspect of the disclosure relates to a method including generating an output clock signal with frequencies pursuant to a frequency ramp from a current frequency to a target frequency based on a set of divider ratios multiplied by a frequency of an input clock signal, respectively; and generating the set of divider ratios including selecting a first set of same denominators for a first subset of the set of divider ratios, and selecting a second set of one or more same denominators for a second subset of the set of divider ratios.

[0012] To the accomplishment of the foregoing and related ends, the one or more embodiments include the features hereinafter fully described and particularly pointed out in the claims. The following description and the annexed drawings set forth in detail certain illustrative aspects of the one or more embodiments. These aspects are indicative, however, of but a few of the various ways in which the principles of various embodiments may be employed and the description embodiments are intended to include all such aspects and their equivalents.

BRIEF DESCRIPTION OF THE DRAWINGS

[0013] FIG. 1A illustrates a block diagram of an exemplary integrated circuit (IC) in accordance with an aspect of the disclosure.

[0014] FIG. IB illustrates a graph of an exemplary clock signal and associated rail voltage

VDD supplied to a core in accordance with another aspect of the disclosure.

[0015] FIG. 1C illustrates a graph of another exemplary clock signal and associated rail voltage

VDD supplied to a core in accordance with another aspect of the disclosure.

[0016] FIG. 2 illustrates a block diagram of an exemplary clock signal generator in accordance with another aspect of the disclosure.

[0017] FIG. 3 A illustrates a table depicting exemplary clock rising edge positions of an output clock signal relative to edge positions of an input clock signal in accordance with another aspect of the disclosure.

[0018] FIG. 3B illustrates a table depicting exemplary clock falling edge positions of an output clock signal relative to edge positions of an input clock signal in accordance with another aspect of the disclosure.

[0019] FIG. 4 A illustrates a graph of exemplary signals that define a duration of a frequency step interval in the clock signal generator of FIG. 2 in accordance with another aspect of the disclosure.

[0020] FIG. 4B illustrates a graph of another exemplary signals that define a duration of a frequency step interval in the clock signal generator of FIG. 2 in accordance with another aspect of the disclosure. [0021] FIG. 5 illustrates a table of divider ratios (M/N) and exemplary frequency ramp profile in accordance with another aspect of the disclosure.

[0022] FIG. 6 illustrates a block diagram of another exemplary clock signal generator in accordance with another aspect of the disclosure.

[0023] FIG. 7 illustrates a graph of exemplary signals that define duration of a frequency step interval in the clock signal generator of FIG. 6 in accordance with another aspect of the disclosure.

[0024] FIG. 8A illustrates a table of divider ratios (M/N) and an exemplary frequency ramp profile in accordance with another aspect of the disclosure..

[0025] FIG. 8B illustrates a table of divider ratios (M/N) and another exemplary frequency ramp profile in accordance with another aspect of the disclosure..

[0026] FIG. 9 illustrates a flow diagram of an exemplary method of generating a clock signal in accordance with another aspect of the disclosure.

[0027] FIG. 10 illustrates a flow diagram of another exemplary method of generating a clock signal in accordance with another aspect of the disclosure.

DETAILED DESCRIPTION

[0028] The detailed description set forth below, in connection with the appended drawings, is intended as a description of various configurations and is not intended to represent the only configurations in which the concepts described herein may be practiced. The detailed description includes specific details for the purpose of providing a thorough understanding of the various concepts. However, it will be apparent to those skilled in the art that these concepts may be practiced without these specific details. In some instances, well-known structures and components are shown in block diagram form in order to avoid obscuring such concepts.

[0029] A power delivery network (PDN) is often employed in an integrated circuit (IC) to supply power to one or more cores of the IC. Controlling the power supplied to an IC core typically involves providing a particular supply or rail voltage VDD and a clock signal with a particular frequency f. The amount of power consumed by the core is a function of the square of the rail voltage (e.g., VDD 2 ) and the frequency f of the clock signal.

[0030] The supplying of power to a core via a particular voltage-frequency pair is typically referred to in the relevant art as Dynamic Clock Voltage Scaling (DCVS) or Dynamic Voltage Frequency Scaling (DVFS) (referred to hereinafter as "DCVS"). A core may also be operated under a set of performance modes. For example, a particular core may be operated in a high performance mode (e.g., Turbo mode) when it is performing a demanding task (e.g., processing large amounts of data in a fast manner). The core may also be operated in a medium performance mode (e.g., Nominal mode) when it is performing a medium complexity level task (e.g., processing non-time-critical data). Similarly, the core may be operated in a low performance mode (e.g., Retention mode) when it is performing a minimal task (e.g., a memory core merely retaining data).

[0031] Correlated with the set of performance modes are a set of calibrated voltage-frequency pairs or DCVS levels for supplying appropriate power to the core based on the current power performance mode. For instance, if a core is being operated in a high power mode, a particular high-power DCVS level VDDi-fi is supplied to the core; if the core is being operated in a medium power mode, a particular medium-power DCVS level VDD 2 -f2 is supplied to the core; and if the core is being operated in a low power mode, a particular low-power DCVS level VDD 3 -f 3 is supplied to the core, wherein generally VDDi>VDD 2 >VDD 3 and fi> f 2 > f 3 .

[0032] FIG. 1A illustrates a block diagram of an exemplary integrated circuit (IC) 100 in accordance with an aspect of the disclosure. The IC 100 includes a power delivery network (PDN) for controlling the delivery of power in the form of specific DCVS levels to a set of cores. In particular, the IC 100 includes a power management unit (PMU), an input clock generator 120, a set of voltage regulators VREG-1 to VREG-n, a set of output clock generators CLK-1 to CLK-n, and a set of cores 1-n.

[0033] The PMU 110 is configured to receive DCVS requests (e.g., DCVS-i REQ) for supplying power to the cores 1-n (e.g., the i th core). Based on DCVS requests, the PMU 110 generates regulator control signals RCSi to RCS n and frequency control signals M/Ni to M/N n to provide the requested power to the cores 1-n, respectively. The voltage regulators VREG-1 to VREG-n, in turn, generate rail voltages VDDi to VDD n for the cores 1-n based on the control signals RCSi to RCS n , respectively. Similarly, the output clock generators CLK-1 to CLK-n generate clock signals f ou t-i to f ou t-n based on frequency control signals M/Ni to M/N n and an input clock signal f in generated by the input clock generator 120, respectively. [0034] Each of the frequency control signals M/N 1 to M/N n is a divider ratio including an integer numerator M and an integer denominator N. The clock generators CLK-1 to CLK-n generate the output clock signals f ou t-i to f ou t-n by dividing frequency of the input clock signal f in by the divider ratios M/Ni to M/Nn, respectively. As discussed below with reference to FIGs. 1B-1C, each of the clock generators CLK-1 to CLK-n ramps the frequency of the output clock signal from its current frequency to a target frequency to reduce voltage droop in the corresponding rail voltage.

[0035] FIG. IB illustrate an exemplary graph of an output clock signal f ou t-i generated by the i th clock generator CLK-i and an associated rail voltage VDD; generated by the i th voltage regulator REG-i versus time in accordance with another aspect of the disclosure. In this example, at time tO, the clock signal f out- i supplied to the i th core-i is at 50% of maximum frequency (e.g., ½ * f in of the input clock signal). Based on the DCVS change request, at time tl, the frequency of the clock signal f ou t-i is abruptly changed from 50% to 100% of maximum frequency. This causes the 1 th core to suddenly draw a large amount of current from the voltage regulator REG-i. As a result, the rail voltage VDD; experiences a substantial voltage droop at around time tl, which may cause malfunction or other adverse effects in the operation of the core-i.

[0036] FIG. 1C illustrate another exemplary graph of the output clock signal f out- i generated by the i th clock generator CLK-i and the associated rail voltage VDD; generated by the i th voltage regulator REG-i versus time in accordance with another aspect of the disclosure. In this example, at time tO, the clock signal f out- i supplied to the i th core-i is at 50% of maximum frequency. Based on a DCVS change request, instead of producing a substantial frequency change (e.g., from 50% to 100%) in a single step, the corresponding clock divider CLK-i generates a series of steps to ramp the frequency from 50% to 100%. This is done to reduce voltage droop in the rail voltage VDD; supplied to the core-i.

[0037] Based on a DCVS change request, at time tl, the frequency of the clock signal f out- i is stepped up from 50% to 60% of maximum frequency. This produces a small voltage droop in the rail voltage VDDi for the core-i. At time t2, the frequency of the clock signal f ou t-i is again stepped up from 60% to 70% of maximum frequency, which produces another small voltage droop in the rail voltage VDD;. The process of stepping the frequency of the clock signal / ou t-i continues until reaching the target frequency of 100%; resulting in small voltage droops at times t3-t5. The small voltage drops prevents or reduces the likelihood of malfunction or other adverse effects in the operation of the corresponding core-i.

[0038] FIG. 2 illustrates a block diagram of an exemplary clock signal generator 200 in accordance with another aspect of the disclosure. The clock signal generator 200 may be a detailed implementation of any of the clock signal generators CLK-1 to CLK-n previously discussed. The clock signal generator 200 includes a frequency ramp control circuit 210 and a fractional clock divider 220.

[0039] The frequency ramp control circuit 210, in turn, includes a minimum frequency step interval counter 212 and an M/N determining device 214. The minimum frequency step interval counter 212 is for setting a minimum duration for each frequency change step pursuant to a ramp of a current frequency to a target frequency of an output clock signal /out- The counter 212 receives a MIN_INTERVAL signal indicating such duration in periods of an input clock signal / . The counter 212 is clocked by the input clock signal /i n . When a count generated by the counter 212 reaches the MIN_INTERVAL, the counter 212 asserts an update signal.

[0040] The M/N determining device 214 is configured to receive the final M and N values (M Final and N Final) and a ramp initiation signal INIT RAMP, and generate a series of M and N values (Mj and N_j) for ramping the frequency of the output clock signal f out from a current frequency to a target frequency indicated by M Final and N Final. An asserted end-of-interval (int_end) signal initiates the M/N determining device 214 to generate another pair of Mj and Nj values. The asserted int_end signal indicates an end (or a beginning) of a frequency change step.

[0041] The fractional clock divider 220 includes an input clock edge position counter 222, an output clock edge position determining device 224, a clock edge multiplexer 226, an AND logic circuit 228, and a set of registers REG-1 , REG-2, and REG-3. The AND logic circuit 228 is configured to assert the int_end signal in response to the update signal being asserted (meaning that the minimum step interval has been met) and an end-of-sequence (seq_end) signal being asserted. The input clock edge position counter 222 asserts the seq_end signal at an end of each repetition of a complete sequence of edge positions of the output clock signal f out , as discussed further herein. [0042] At an end of a frequency step interval, the AND logic circuit 228 causes the registers REG-1, REG-2, and REG-3 to output the int end signal, the current divider ratio numerator Mj, and the current divider ratio denominator Nj. The int_end signal is applied to the input clock edge position counter 222 to inform it that it should output an input clock edge position index k and assert the seq_end signal based on the current values of Mj and Nj. As mentioned, the current Mj and Nj values are applied to the input clock edge position counter 222, as well as to the output clock edge position determining device 224. Based on the current Mj and Nj values and the current input clock edge position index k, the output clock edge position determining device 224 instructs the clock edge multiplexer 226 to output either a positive edge (+) or negative edge (-) of the input clock signal / ln to generate the output clock signal / out . The input clock signal f m drives the input clock edge position counter 222.

[0043] The input clock edge position counter 222 is a modulo-2N counter. That is, the input clock edge position counter 222 increments the input clock edge position index k from zero (0) to 2N by one (1) for each edge of the input clock signal fm. When the input clock edge position index k reaches 2N, the input clock edge position counter 222 causes the edge position index k to return to zero (0) in response to the next edge of the input clock signal fm. So, if the current Nj value is 20, the input clock edge position counter 222 increments k from 0 to 40 in steps of one (1), and then returns k to zero (0) upon receiving the next edge of the input clock signal fm.

[0044] The input clock edge position counter 222 asserts the seq end signal when the index k coincides with a zero (0) phase edge or at the end of a complete sequence of edges of the output clock signal fm. Following a complete sequence, the sequence just repeats itself. A sequence of edges may reach zero (0) as few as k equal to four (4) for the case where Mj/Nj=l/2 (e.g., 10/20). For instance, in this case, the first rising edge of the output clock signal / out coincides with the k=0 edge of the input clock signal fm. The first falling edge of the output clock signal / out coincides with the k=2 edge of the input clock signal fm. Beginning with k=4, the sequence of edges repeats itself, where each edge of the output clock signal / ou t occurs every other edge of the input clock signal f m (e.g., at k=4, 6, 8, etc.). Thus, for the Mj/Nj=10/20 case, the seq_end signal is asserted at k=4, 8, 12, 16, 20, 24, 28, 32, 36, and mod 40 (or zero (0)). [0045] Similarly, for M j /N j =5/20, a sequence of edges is completed at k=8 (phase zero (0)) and repeats thereafter. Thus, for this case, the seq_end signal is asserted at k=8, 16, 32, and mod 40 (or zero (0)). For other values of M j and N j , the sequence of edges require 2N edges of the input clock signal / ln to repeat itself (e.g., the only zero (0) phase occurs at k=2N). In such case, the seq_end signal is asserted every 2N edges of the input clock signal /;„. Thus, as described, the seq_end signal may be asserted as frequent as every k=4 edges and as infrequent as every k=2N edges. As discussed in more detail below, this variance produces unequal frequency change step durations, which may be undesirable.

[0046] Thus, to summarize the operation of the input clock edge position counter 222, the counter 222 receives the int_end signal and the current M j and N j values from the output of the registers REG-1, REG-2 and REG-3 each time the int end signal is asserted. The int_end signal informs the counter 222 to operate based on the new or current M j and N j values. The modulo for the counter 222 is set by the current N j value; the modulo being 2Nj. As such, the counter 222 increments the input clock edge position index k from zero (0) to N j - 1 by one (1) for each edge of the input clock signal /;„, and then returns k to zero (0) in response to the next edge of the input clock signal / . The counter 222 also asserts the seq_end signal upon completion of a unique time sequence of edges of the output clock signal / out based on the M j and N j values.

[0047] The output clock edge position determining device 224 is configured to instruct the clock edge multiplexer 226 to either output a positive edge (+) or a negative edge (-) of the input clock signal ;„ to generate the output clock signal / out based on the current Mj and N j values and the input clock edge position index k. The output clock edge position determining device 224 causes the clock edge multiplexer 226 to output a positive edge of the input clock signal ;„ by asserting a signal at the positive input (+) of the clock edge multiplexer 226 (as well as deasserting a signal at the negative input (-) of the clock edge multiplexer 226). Similarly, the output clock edge position determining device 224 causes the clock edge multiplexer 226 to output a negative edge of the input clock signal ;„ by asserting a signal at the negative input (-) of the clock edge multiplexer 226 (as well as deasserting a signal at the positive input (+) of the clock edge multiplexer 226). [0048] FIG. 3A illustrates a table depicting exemplary the rising edge positions TR(1 of the output clock signal / out relative to the input clock edge positions k for the case where N j =20 in accordance with another aspect of the disclosure. The leftmost column header indicates the divider ratio M/N. Below the leftmost column header provides a series divider ratios (M/N), such as 10/20, 9/20, 8/20, and down to 1/20. The following column headers 0 to 10 indicate the index T R (k) of the edges of the output clock signal /out, such as zero (0) being the first rising edge of the output clock signal / ou t and 10 being the 11 th rising edge of the output clock signal / out . Below the column headers 0 to 10 provides the corresponding input clock edge positions k of the input clock signal / la

[0049] Considering the case where M j /N j is 10/20, the output clock edge position determining device 224 instructs the clock edge multiplexer 226 to output rising edges of the input clock signal / ln such that the rising edges 0 to 10 of the output clock signal / out substantially coincides with edges k = 0, 4, 8, 12, 16, 20, 24, 28, 32, 36, and mod 40 (or 0) of the input clock signal / la Considering next the case where M/N=5/20, the output clock edge position determining device 224 instructs the clock edge multiplexer 226 to output rising edges of the input clock signal ;„ such that the rising edges 0 to 5 of the output clock signal / out substantially coincides with edges k = 0, 8, 16, 24, 32, and mod 40 (or 0) of the input clock signal /;„ . The output clock edge position determining device 224 may include tables for instructing the clock edge multiplexer 226 to output positive clock edges of the input clock signal / ln for all desired M and N values.

[0050] FIG. 3B illustrates a table depicting exemplary falling edge positions T F (k) of the output clock signal / ou t relative to the input clock edge positions k for the case where N=20 in accordance with another aspect of the disclosure. Similarly, the leftmost column header indicates a divider ratio M/N. Below the leftmost column header provides a series of divider ratios (M/N), such as 10/20, 9/20, 8/20, and down to 1/20. The following column headers 0.5 to 10.5 indicate the index T F (k) of the falling edges of the output clock signal / out , such as zero (0.5) being the first falling edge of the output clock signal out and 10.5 being the 11 th falling edge of the output clock signal / out . The indices T F (k) of the falling edges are indicated with a resolution of 0.5 because they are situated between rising edges of the output clock signal / out . As an example, the 0.5 falling edge occurs between the zero (0) and one (10 rising edges of the output clock signal / out . Below the column headers 0.5 to 10.5 provides the corresponding input clock edge index k of the input clock signal /;„.

[0051] Considering again the case where Mj/Nj is 10/20, the output clock edge position determining device 224 instructs the clock edge multiplexer 226 to output falling edges of the input clock signal ;„ such that falling edges 0.5 to 10.5 of the output clock signal out substantially coincides with edges k = 2, 6, 10, 14, 18, 22, 26, 30, 34, 38, and mod 42 (or 2) of the input clock signal fm. Considering next the case where Mj/Nj =5/20, the output clock edge position determining device 224 instructs the clock edge multiplexer 226 to output falling edges of the input clock signal ;„ such that the falling edges 0.5 to 5.5 of the output clock signal / ou t substantially coincides with edges k = 0, 12, 20, 28, 36, and mod 42 (or 2) of the input clock signal /;„. The output clock edge position determining device 224 may include tables for instructing the clock edge multiplexer 226 to output negative clock edge of the input clock signal ;„ for all desired M and N values.

[0052] Instead of using tables, the output clock edge position determining device 224 may determine the rising edge index TR(k) of the output clock signal / ou t in terms of the edge index k of the input clock signal ;„ in accordance with the following relationship:

T R (k) = round{2k(N/M)}

Similarly, the output clock edge position determining device 224 may determine the falling edge index T F (k) of the output clock signal / ou t in terms of the edge index k of the input clock signal ;„ in accordance with the following relationship:

T F (k) = round {2k(N/M)} + 2

Where the round {} operation rounds the number inside the brackets to the nearest integer.

[0053] As mentioned above, a problem with the clock signal generator 200 is that it produces frequency change steps having unequal or varying durations. The problem stems from the fact that the assertion of the seq_end signal varies with the current values of Mj and Nj and the counters 212 and 222 are free running and not synchronized with each other. The end of a frequency change step occurs when the update and seq end signals are both asserted. However, because both counters 212 and 222 are free running, these two signals are not asserted at the same time. As explained below with reference to FIGs. 4A-4B, this causes the clock signal generator 200 to produce frequency change steps of varying durations.

[0054] FIG. 4A illustrates a graph of exemplary signals that define a duration of a frequency step in accordance with another aspect of the disclosure. In this example, the seq end signal (further abbreviated in FIGs. 4A-4B as "SE") occurs often, such as every fourth edge of the input clock signal / ln as in the case where M j /N j is equal to 10/20. Further, in accordance with this example, the MIN_INTERVAL is set to be approximately 4N or 80 edges of the input clock signal /;„. Additionally, in this example, the input clock edge position counter 222 begins two edges earlier than the minimum frequency step interval counter 212 as these counters are not synchronized.

[0055] As illustrated, the update signal generated by the counter 212 gets asserted at time tl .

The seq_end (SE) signal gets asserted at time t2. As previously discussed, the AND logic circuit 228 asserts the int_end signal when both the update signal and the seq_end (SE) signal are asserted. In the graph, this occurs at substantially time t2. Thus, per this example, the duration of the frequency change step is approximately t2 (t2-0). As the seq_end (SE) signal is asserted every fourth edge of the input clock signal / ln for M j /N j =10/20, the difference between the assertion of the update signal and the seq_end (SE) signal is at most four (4) edges of the input clock signal /;„ .

[0056] FIG. 4B illustrates a graph of another exemplary signals that define a duration of a frequency change step in accordance with another aspect of the disclosure. In this example, the seq_end (SE) signal occurs less often, such as every 2N or 40 th edge of the input clock signal ;„ as in the case where M j /N j is equal to 1/20. Similarly, the MIN_INTERVAL is set to be approximately 4N or 80 edges of the input clock signal /in. Additionally, in this example, the input clock edge position counter 222 begins two edges earlier than the frequency step interval counter 212 as these counters are not synchronized.

[0057] Similar to the graph of FIG. 4 A, the update signal generated by the counter 212 gets asserted at time tl. The seq_end (SE) signal gets asserted at time t3. As previously discussed, the AND logic circuit 228 asserts the int_end signal when both the update signal and the seq_end (SE) signal are asserted. In the graph, this occurs at substantially time t3. Thus, per this example, the duration of the frequency change step is approximately t3 (t3-0). As the seq_end (SE) signal is asserted every 40 th edge of the input clock signal ;„ for M j /N j =l/20, the difference between the assertion of the update signal and the seq_end (SE) signal is at most 40 edges of the input clock signal /;„ .

[0058] The aforementioned graphs illustrate that the duration of the frequency change interval or step varies because the seq_end signal is asserted at different times based on the values of M j and N j , and the two counters 212 and 222 are free running and not synchronized with each other. If the MIN_INTERVAL is set to be relatively large (e.g., 100 * N j ), then the percent difference in the durations of the frequency change steps of FIGs. 4A-4B is relatively small and may be acceptable. However, if the MIN- INTERVAL is relatively small (in order to speed up the frequency ramping time of the output clock signal / out , then the percent difference in the durations is relatively large and may have adverse consequences as voltage droops are not uniformly distributed in time.

[0059] Another problem with the clock signal generator 200 concerns the M/N determining device 214. The M/N determining device 214 employs a Manhattan algorithm to select M j and N j values. In a Manhattan algorithm, the M/N determining device 214 changes either M j or N j by one (1) to generate the next M j+1 and N j+1 values. That is, the following relationship applies:

M_INT j+ i = M INT j + (or -) 1 and N_INT j+ i = NJNT j

or

M_INT j+ i = M INT j and N_INT j+ i = N_INT j + (or -) 1

[0060] Because of the aforementioned restrictions, if a relatively high frequency resolution is desired to achieve a precise target frequency (e.g., each frequency change being five (5) percent of maximum frequency), then a relatively high N (e.g., N=40) needs to be selected. However, choosing a relatively high N requires a relatively long duration to ramp the current frequency to a target frequency. As a comparison, ramping the current frequency to a target frequency with N=40 requires four (4) times the duration required for ramping the current frequency to the target frequency using N=20. The corollary is that choosing a relatively low resolution (e.g., N=20, where each frequency change is 10 percent of maximum frequency) produces faster frequency ramp at the expense of frequency precision. This is better explained with reference to the following example.

[0061] FIG. 5 illustrates a table of divider ratios (M/N) and exemplary frequency ramp profile in accordance with another aspect of the disclosure. The leftmost column includes incrementing M values from 1 to 20 from the bottom row to the top row of the table. The bottom row includes incrementing N values from 1 to 40 from the leftmost column to the rightmost column of the table. The divider ratios are noted for various M values for N=20 and N=40 columns.

[0062] In both of examples described below, the current frequency of the output clock signal out is 1/20 * frequency of the input clock signal /;„ . In the first example, the target frequency for the output clock signal / out is 9/20 the frequency of the input clock signal /in. In such case, the M/N determining device 214 chooses N=20 because that resolution is sufficient to achieve the target frequency of 9/20 * frequency of the input clock signal fm- Thus, as indicated by the frequency ramp profile (dashed arrow along the N=20), the M/N determining device 214 begins at M/N=l/20 and increments M by one (1) for each frequency change step until it reaches M/N=9/20.

[0063] In the second example, the target frequency for the output clock signal / out is 19/40 * frequency of the input clock signal /;„. In such case, the M/N determining device 214 chooses N=40 because that resolution is required to achieve the target frequency of 19/40 * frequency of the input clock signal /;„. Thus, as indicated by the frequency ramp profile (dashed arrow along the N=40), the M/N determining device 214 begins at M/N=l/40 and increments M by one (1) for each frequency change step until it reaches M/N=19/40.

[0064] The problem with the higher resolution frequency ramp profile at N=40 is that the duration of the frequency ramp from the current frequency to the target frequency takes four (4) times longer than the frequency ramp at the lower resolution N=20. This is because there are twice as many frequency change steps in N=40 than in N=20, and each step in N=40 takes twice as long as each step in N=20. Thus, there is a need for an improved algorithm to produce a frequency ramp profile that can achieve target frequencies at high resolution (e.g., at N=40) at lower resolution speeds (e.g., at N=20 speed). [0065] FIG. 6 illustrates a block diagram of an exemplary clock signal generator 600 in accordance with another aspect of the disclosure. In summary, the clock signal generator 600 is configured to produce substantially equal duration frequency change intervals or steps. It accomplishes this by synchronizing a counter for determining the duration of each frequency change step and the counter used to generate the clock input edge position index k. Because of such synchronization, the update signal is asserted at substantially the same time as the end-of-sequence (seq_end) signal, which produces equal duration frequency change intervals.

[0066] Secondly, the clock signal generator 600 includes an M/N determining device that selects a set of divider ratios that achieves a fast frequency ramp with high resolution target frequency acquisition. In particularly, the M/N determining device chooses divider ratios to perform coarse frequency change steps (e.g., at N=20 resolution) for a first portion of a transition from a current frequency to a target frequency, and then chooses divider ratios to perform fine frequency change steps (e.g., at N=40 resolution) for a second portion (or remaining) portion of the transition from the current frequency to the target frequency. So that fast frequency ramping is achieved, the length of the first portion may be larger (e.g., 90% of the entire transition) than the second portion (e.g., 10% of the entire transition).

[0067] More specifically, the clock signal generator 600 includes a frequency ramp control circuit 610 and a fractional clock divider 620. The frequency ramp control circuit 610 includes a loop counter 612, a base counter 614, and an M/N determining device 616. The fractional clock divider 620 includes an AND logic circuit 628, registers REG-1, REG-2, and REG-3, an input clock edge position counter 622, an output clock edge position determining device 624, and a clock edge multiplexer 626.

[0068] The base counter 614 and loop counter 612 are configured to set the duration of each frequency change interval or step. The base counter 614 is primed (e.g., count reset to zero (0)) by an asserted the end-of-interval (int_end) signal. As the int_end signal is asserted based on an asserted end-of-sequence (seq_end) signal, this effectively synchronizes the base counter 614 and the input clock edge position counter 622. Additionally, the current Nj value is provided to the base counter 614 by the M/N search algorithm 616. The current Nj value serves as the modulo for the base counter 614. Because the current Nj also serves as the modulo for the input clock edge position counter 622, the output of the base counter 614 is synchronized with the seq_end signal asserted by the input clock edge position counter 622. Further, the base counter 614 is driven by the input clock signal /;„, which also drives the input clock edge position counter 622, further ensuring that the base/loop counters 614/612 are synchronized with the input clock edge position counter 622.

[0069] The loop counter 612 receives the output of the base counter 614 and also a loop signal, which sets a duration of the current frequency change step. The output of the base counter 614 triggers a count increment in the loop counter 612. The loop signal serves as the modulo for the loop counter 612. Thus, the loop counter 612 asserts an update signal every LOOP x N j . Again, as the base counter 614 is primed by the int_end signal, which is asserted when the AND logic circuit 628 determines that both the update signal and the seq_end signal are asserted, the loop counter 612 asserts the update signal at substantially the same time as the input clock edge position counter 622 asserts the seq_end signal. As a result, each frequency change interval or step has a duration given by LOOP x N j .

[0070] FIG. 7 illustrates a graph of exemplary signals that define a duration of a frequency change interval or step in the clock generator 600 accordance with another aspect of the disclosure. As illustrated, at time tO, both the update and seq_end signals are asserted. This causes the AND logic CIRCUIT 628 to assert the int_end signal, which primes the base counter 614 and marks the beginning of a frequency change step.

[0071] At time tl, both the update and seq_end signals are asserted, causing the AND logic circuit 628 to assert the int_end signal. The asserted int_end signal again primes the base counter 614, and marks the beginning of the next frequency change interval or step. In this example, the seq_end signal is asserted four (4) times during the frequency change step. This may be the case where the seq_end is asserted every N periods of the input frequency signal ;„ and the LOOP signal is set to four (4). Or, it may be the case where the seq_end is asserted every N/2 periods of the input frequency signal ;„ and the LOOP signal is set to two (2). Or, it may be the case where the seq end is asserted every N/4 periods of the input frequency signal fm and the LOOP signal is set to one (1).

[0072] Similar to the M/N determining device 214 previously discussed, the M/N determining device 616 receives the M_FINAL and N_FINAL values associated with the target frequency, and a ramp initiation (INIT_RAMP) signal. The M/N determining device 616 generates the M 0 and N 0 associated with the current frequency. And, the M/N determining device 616 performs a search algorithm to determine the other values of Mj and Nj associated with the intermediate frequencies pursuant to the frequency ramp from the current frequency to the target frequency. The asserted int end signal initiates the M/N determining device 616 to output the Mj and Nj values for the fractional clock generator 620.

[0073] The M/N determining device 616 differs from M/N search algorithm 214 in that the current Nj value is provided to the base counter 614 to set the modulo thereof, as previously discussed. Further, the M/N determining device 616 uses a combination of at least two different N values to generate the frequencies pursuant to the frequency ramp. In particular, the M/N determining device 614 uses a lower N (e.g., N=20) for coarse frequency change steps for a first portion of the frequency ramp from the current frequency to the target frequency. The M/N determining device 614 uses a higher N (e.g., N=40) for fine frequency change steps for a second portion of the frequency ramp from the current frequency to the target frequency. This is better explained with reference to the following examples.

[0074] FIG. 8A illustrates a table of divider ratios (M/N) and an exemplary frequency ramp profile in accordance with another aspect of the disclosure. Similar to the table of FIG. 5, the leftmost column includes incrementing M values from 1 to 20 from the bottom row to the top row of the table. The bottom row includes incrementing N values from 1 to 40 from the leftmost column to the rightmost column of the table. The divider ratios (M/N) are noted for various M values for N=20 and N=40 columns.

[0075] In this example, the current or start frequency of the output clock signal / out is at 1/20 * /in of the input clock signal /;„. The target frequency for the output clock signal / out is 19/40 * in of the input clock signal /;„. Because of target frequency resolution is 1/40, the M/N determining device 614 may choose N=40 to step the frequency from the current frequency to the target frequency. However, the frequency ramp time with N=40 is four (4) times longer than it would be at N=20.

[0076] Instead, in this example, the M/N determining device 616 initially chooses N=20, with M=l for the start or current of the output clock signal / out , as indicated by the beginning of the frequency ramp profile (dashed arrow line along column N=20). The M/N determining device 616 increments M by one (1) for each frequency change step until it reaches M=9 or M/N=9/20, as indicated by the end of the first portion of the frequency ramp profile. At M/N=9/20, the frequency of the output clock signal / out is about 90 percent of the target frequency at M/N=19/40. Next, the M/N determining device 616 chooses N=40 and sets M to 19 to achieve the target frequency for the output clock frequency / out of 19/40 * /;„, as indicated by the second portion of the frequency ramp profile (the dashed arrow line extending from M/N = 9/20 to 19/20).

[0077] Thus, as illustrated, the M/N determining device 616 performs frequency change steps along the N=20 column or coarse frequency resolution (e.g., each step is a 10% frequency change at the frequency of the input clock signal /;„) to achieve a first portion of the frequency ramp from the current frequency at 1/20 * ;„ to an intermediate frequency 9/20 * /;„. This produces relatively fast frequency ramping as there are half as many steps required to perform the same transition using N=40, and each step using N=20 has a duration half that of each step using N=40. When the intermediate frequency reaches a certain percentage of the target frequency (e.g., about 5%), the M/N determining device 616 changes to N=40 to complete the transition to the target frequency at the higher resolution frequency step. Thus, this algorithm provides for fast ramping time and high resolution in achieving the target frequency.

[0078] FIG. 8B illustrates a table of divider ratios (M/N) and another exemplary frequency ramp profile in accordance with another aspect of the disclosure. This figure provides another example of the algorithm performed by the M/N determining device 616 to ramp the frequency of the output clock signal / out from a current frequency to a target frequency. In this example, the frequency ramp has a negative slope, i.e., the current frequency is greater than the target frequency. Further, in accordance with this example, the current frequency of the output clock signal / out is 19/40 * ;„ and the target frequency of the output clock signal / out is 3/40 * /;„.

[0079] For this frequency ramp, the M/N determining device 616 initially chooses N=20, with a first Mi value of nine (9) to achieve a first portion of the frequency ramp profile as indicated by the diagonal dashed arrow line beginning with M/N=19/40 and ending with M/N=9/20. The M/N determining device 616 then decrements M by one (1) for each frequency change step until it reaches M=2 or M/N=2/20 to achieve the second portion of the frequency ramp profile, as indicated by the vertical dashed arrow line along column N=20. At M/N=2/20, the frequency of the output clock signal / out is about 90 percent of the target frequency at M/N=3/40. Next, the M/N determining device 616 chooses N=40 and sets M to 3 to achieve the target frequency for the output clock frequency / out of 3/40 * ;„ via a third portion of the frequency ramp profile as indicated by the dashed arrow line extending from M/N = 2/20 to 3/40.

[0080] Similarly, the M/N determining device 616 performs frequency change steps along the N=20 column or coarse resolution (e.g., each step is 10% change of the frequency of the input clock signal /;„) to achieve a portion of the transmission from the current frequency at 19/40 * ;„ to an intermediate frequency 3/20 * /;„. This produces relatively fast frequency ramping as there are half as many steps required to perform the same transition using N=40, and each step using N=20 has a duration half that of each step using N=40. When the intermediate frequency reaches a certain percentage of the target frequency (e.g., about 5%), the M/N determining device 616 changes to N=40 to complete the transition to the target frequency at the higher resolution frequency step. Thus, this algorithm provides for fast ramping time and high resolution in achieving the target frequency.

[0081] Referring again to FIG. 6, the remaining components of the clock signal generator 600 operate similar to the corresponding components of the clock signal generator 200 previously discussed. In summary, the AND logic circuit 628 is configured to assert the int end signal (indicating an end of a previous frequency change step and/or the beginning of the next frequency change step) in response to both the update and the seq_end signals being asserted. The AND logic circuit 628 also causes the registers REG-1, REG-2, and REG-3 to output the int end signal and the current Mj and Nj values.

[0082] The input clock edge position counter 622 is configured to output an input clock edge position index k based on the current Nj, which sets the modulo for the counter 622. The input clock edge position counter 622 is also configured to or assert the seq_end signal at the end of a complete sequence of edges or at a zero (0) phase edge. The int_end signal informs the input clock edge position counter 622 that it has new Mj and Nj values upon which to generate the input clock edge position index k and assert the seq end signal. Further, the input clock edge position counter 622 is driven by the input clock signal /;„. [0083] The output clock edge position determining 624 is configured to instruct the clock edge multiplexer 626 to output either a positive or negative edge of the input clock signal ;„ based on the input clock edge position index k and the current Mj and Nj values to generate an output clock signal / out with frequency Mj /Nj * /;„. Based on the instruction received from the output clock edge position determining 624, the clock edge multiplexer 626 outputs either a positive edge or a negative edge of the input clock signal ;„ to generate the output clock signal / ou t-

[0084] FIG. 9 illustrates a flow diagram of an exemplary method 900 of generating a clock signal in accordance with another aspect of the disclosure.

[0085] The method 900 includes generating an index of edge positions of an input clock signal (block 910). An example of a means for generating an index of edge positions of an input clock signal includes any of the edge position counters 222 and 622 described herein.

[0086] The method 900 further includes generating an output clock signal based on a current divider ratio and the index (block 920). An example of a means for generating an output clock signal based on a current divider ratio and the index includes any of the clock edge state machines 224 and 624 and clock edge multiplexers 226 and 626 described herein.

[0087] The method 900 further includes generating a first signal based a selected duration for a frequency change step of the output clock signal (block 930). An example of a means for generating a first signal based a selected duration for a frequency change step of the output clock signal includes the base and loop counters 612 and 614.

[0088] The method 900 further includes synchronizing the generation of the first signal with generation of the index (block 940). An example of a means for synchronizing the generation of the first signal with the generation of the index includes the AND logic circuit 628 generating the int_end signal for priming the base counter 614 and using the current Nj value as the modulo for the base counter 614.

[0089] The method 900 further includes determining the current divider ratio (block 950). An example of determining the current divider ratio includes any of the M/N determining devices 214 and 616 described herein.

[0090] FIG. 10 illustrates a flow diagram of another exemplary method 1000 of generating a clock signal in accordance with another aspect of the disclosure. [0091] The method 1000 includes generating an output clock signal with frequencies pursuant to a frequency ramp from a current frequency to a target frequency based on a set of divider ratios multiplied by a frequency of an input clock signal, respectively (block 1010). An example of a means for generating an output clock signal with frequencies pursuant to a frequency ramp from a current frequency to a target frequency based on a set of divider ratios multiplied by a frequency of an input clock signal, respectively, includes any of the fractional clock dividers 220 and 620 described herein.

[0092] The method 1010 further includes generating the set of divider ratios including selecting a first set of same denominators for a first subset of the set of divider ratios, and selecting a second set of one or more same denominators for a second subset of the set of divider ratios (block 1020). An example of a means for generating the set of divider ratios including selecting a first set of same denominators for a first subset of the set of divider ratios, and selecting a second set of one or more same denominators for a second subset of the set of divider ratios includes the M/N determining device 616 described herein.

[0093] The previous description of the disclosure is provided to enable any person skilled in the art to make or use the disclosure. Various modifications to the disclosure will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other variations without departing from the spirit or scope of the disclosure. Thus, the disclosure is not intended to be limited to the examples described herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.