The present invention relates generally to electronic circuits and in particular to timing circuits used in computer systems.
Spread spectrum clocks are widely used in electronic circuits, and are used in consumer, home, and office electronic products such as personal computers (PCs). Spread spectrum circuits operate by ‘spreading’ the frequency of a clock signal over a narrow band of frequencies, to reduce the peak Electromagnetic Interferences (EMI).
In a conventional spread spectrum solution, when a counter value changes overshoot occurs at the beginning of the first pulse of the resulting waveform and undershoot occurs at the bottom of the first pulse, as shown in
FCPU=(FREF*NCounter)/(MCounter*FCounter)
Conventionally, the M-counter is loaded with values while the value of the N-counter remains the same when performing a feed forward operation; and the N-counter is loaded with values while the value of the M-counter remains the same when performing a feedback operation. In the conventional solution, M- and N-counters are loaded with the spread profile from the ROM. There is no synchronization mechanism between the M- and N-counters. As a result, erroneous pump up and pump down pulses are passed to the charge pump, resulting in the overshoot and undershoot of the VCO clock frequency. In the conventional solution, the PLL loop is never open. The new counter values for M-counter 102, and N-counter 112 are just pushed into the PFD/CP and the PLL must adjust accordingly, resulting in the overshoot and undershoot of
The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
An apparatus and method are described for limiting overshoot and undershoot when turning on the spread spectrum of a reference signal, for example, a processor clock signal. The apparatus and method may be implemented with logic that interfaces to a PC clock PLL synthesizer to prevent overshoot, for example, to be less than 300 PPM and limit the undershoot to be less than negative 5300 PPM during the turning on of the spread spectrum of a negative 0.5% down spread. In other words, the overshoot and undershoot may be limited to be less than approximately ±300 PPM or ±0.03% of the reference signal, while turning on/off the spread spectrum.
As previously described, conventionally, when turning on the spread spectrum of an input reference signal, the counter values are changed, resulting in overshoot at the beginning of the first pulse of the resulting waveform and undershoot at the bottom of the first pulse. The overshoot and undershoot typically start oscillating outside the pre-determined spread range of the system. There is no synchronization mechanism between the counters used to apply the spread profile and loading the counters while the PLL remains closed results in erroneous pump up and pump down pulses to the charge pump resulting in the overshoot and undershoot of the VCO clock frequency.
Described herein is a spread-control circuit containing an algorithm to be used when a PLL is changing from “spread-off” to “spread-on” and vice versa. During this transition, the spread-control circuit opens the loop, changes the M- and N-values of the M- and N-counters, resets synchronously the M- and N-counters, and consequently closes the loop, forcing the PFD outputs to be zero. This provides minimum assurance that the output reference signal of the PLL is not changing abruptly during the transition.
Using the spread-control circuit does not alter the behavior of the PLL because the loading of the M- and N-counters are performed while the PLL is open (e.g., tri-stated), and subsequently, the phases of the output signals of the M- and N-counters are synchronously aligned before closing the PLL.
In one embodiment, the spread-control circuit includes three sampling flip-flops clocked by the crystal oscillator signal. The spread-control circuit acts as a timing control mechanism for controlling the transition of the PLL from “spread-on” to “spread-off” and vice versa. The control output signals are derived from or are provided directly from the sampling flip-flops. The sampling flip-flops sample the spread spectrum enable signal (e.g., SS_EN). The spread spectrum enable signal may be provided by a serial interface, such as a serial management bus interface (SMBUS). Alternatively, the spread spectrum enable signal may be provided by other components known by those of ordinary skill in the art.
Reference signals, such as clock signals, may generate radiation spikes in the fundamental frequency as well as the harmonic frequencies. By applying a spread spectrum to the signal, energies of the input reference signal can be spread out by modulating the input reference signal with a slower frequency. In other words, the spreading of the input reference signal over a narrow band of frequency reduces the peak EMI. For example, a spread spectrum may be applied to a 200 MHz clock signal, resulting in the 200 MHz signal being modulated with a slower frequency, for example, 33 kHz. In order to modulate the input reference signal by the slower frequency, a spread profile, which is stored in a spread ROM, contains offset values that change the value of the M/N divider (e.g., the values contained in the M- and N-counters that determines the how the input reference signal is multiplied and divided to generate the output reference signal.) The spread profile may substantially form an inverted triangular spread pattern in the output reference signal. Alternatively, the spread profile may substantially form an inverted Lexmark spread pattern in the output reference signal.
The spread profile may be a down-spread or a center-spread. The down- and center-spreads may have a value, expressed as a percentage of the amount of spread that is applied to the input reference signal. For example, a down-spread of negative 0.5%, having an inverted triangular spread profile may be applied to the input reference signal to form an inverted triangular spread pattern in the output reference signal. A down-spread of negative 0.5% results in an output frequency of 200 MHz, having peaks values at 200 MHz and 199 MHz (200 Mhz−((0.5%)*(200 MHz)). It should be noted that in this example, the resulting waveform of the output reference signal (e.g., inverted triangular spread pattern) will start at 200 MHz and decrease in frequency down to the first peak value of 199 MHz at the bottom of a first pulse of the resulting waveform (e.g., an initial negative frequency slope), then increase in frequency up to a second peak value of 200 MHz, and decrease back down to a third peak value of 199 MHz of a second pulse, repeating as long as the spread spectrum is turned on. The frequency between the first peak value and the third peak value is the spread frequency, for example, a spread frequency of 33 kHz. Similarly, an exemplary center-spread profile of negative 0.5% will decrease in frequency by negative 0.25% of the input frequency to the first peak value of the first pulse, and will increase up to positive 0.25% of the input frequency to the second peak value, repeating as long as the spread spectrum is turned on.
In one embodiment, the spread-control circuit, implementing the method described herein, may be used to reduce the peak energy in a clock signal for a processor at the fundamental and harmonic frequencies. Alternatively, this algorithm may be applied in reducing the radiation of a reference signal, such as a crystal output signal, in other physical chips known by those of ordinary skill in the art.
In one embodiment, the input reference signal FREF 211 may be an input reference signal received by a crystal oscillator. Alternatively, input reference signal FREF 211 may be an input reference signal received by other components known by those of ordinary skill in the art. In one embodiment, the input reference signal FREF 211 is received by a crystal oscillator and output reference signal FCPU 222 is a clock signal. Alternatively, the output reference signal FCPU 222 may be a processor clock signal.
Spread-control circuit 220 outputs control signals to the M-counter 202 on line 215, to the PFD/CP 204 on line 216, and to N-counter 212 on line 217. The input reference signal FREF 211 is divided by the value of M-counter 202 on line 218 before feeding the frequency into PFD/CP 204. Through the PFD/CP 204, the LF 206, and VCO 208, the frequency is multiplied by the value of the N-counter 212 on line 219. The output reference signal FCPU 222 is taken from the VCO 208 on line 221 after being divided by the value in F-counter 210. In other words, the output reference signal FCPU 222 is calculated using the following equation:
FCPU=(FREF*NCounter)/(MCounter*FCounter)
The spread address counter 430, which receives the address counter reset signal 402 from the spread spectrum switch 440, also receives as a clock input a gated signal including the spread spectrum enable signal 213 (e.g., SS_EN) and an overflow bit FV 401 of the N-counter 212. In other words, when the spread control circuit 220 receives the spread spectrum enable signal 213, meaning the spread operation is on, and receives the overflow bit FV 401, the spread address counter increments by 1, assuming the address counter reset signal 402 is released (e.g., deactivated). The spread address counter 430 outputs the current address of the spread ROM 320 on line 404. In one embodiment, the gated signal may be produced from inverter 407, which receives an input from the output of NAND gate 406, which receive the spread spectrum enable signal 213 (e.g., SS_EN) and the overflow bit FV 401 of the N-counter 212. Alternatively, other logic, known by those of ordinary skill in the art, may be used to provide a clock signal to the spread address counter 430.
Adder 410 receives as inputs, the one or more base values from the configuration ROM 310 on line 318, and the plurality of offset values from the spread ROM 320 on line 319. The adder 410 sums the base value received on line 318 with the offset value received on line 319, and outputs the added value to the MUX 420 on line 403. MUX 420 receives as inputs, the one or more base values from the configuration ROM 310 on line 318 and the added values received from the adder 410. The MUX 420 also receives a control signal, spread spectrum enable signal 213 from spread spectrum switch 440 to determine whether to use the added values received from the adder 410 on line 403 or the one or more base values received from the configuration ROM 310 received on line 403. The MUX 420 outputs the added values on line 322 to be loaded into the N-counter 212 on line 322 when the spread operation is on, or in other words, when the spread spectrum enable signal 213 is activated. The MUX 420 outputs the base values received on line 318 to be loaded into the N-counter 212 on line 322 when the spread operation is off, or in other words, when the spread spectrum enable signal 213 is deactivated. The MUX 420 and spread spectrum enable signal 213 create a bypass feature in spread-control circuit 220 to allow the spread spectrum operation to be bypassed.
The sampling flip-flops 501, 502, and 503 produce control output signals to control the operations of the spread spectrum operation as discussed below. Sampling flip-flops 501, 502, and 503 sample the spread spectrum enable signal 213 (e.g., SS_EN), and generate a plurality of output control signals. In one embodiment, before being sampled by the first sampling flip-flop 501, spread spectrum enable signal 213 may be input into an initial state decoder 510. Alternatively, the spread spectrum enable signal 213 may be directly input into the first sampling flip-flop 501.
In one embodiment, the initial state decoder 510 receives the spread spectrum enable signal 213 and an initial state signal 214 (e.g., CNT—00). The initial state signal 214 may be received from an address decoder that decodes the initial state of the spread address counter 430. The initial state of the spread address counter 430 is when the spread address counter 430 is at a 00 count or when the spread address counter 430 is reset. Alternatively, other processes known to those skilled in the art may be used to detect the initial state of the spread address counter 430 and to provide an initial state signal 214 (e.g., CNT—00).
In one embodiment, the initial state decoder 510 comprises AND gate 507 and OR gate 508. The AND gate 507 receives the initial state signal 214 and a feedback signal from the output of the first sampling flip-flop 501. The OR gate 508 receives the spread spectrum enable signal 213 and the output signal from the AND gate 507, and outputs a signal to the input of the first sampling flip-flop 501. Alternatively, other logic known by those skilled in the art may be implemented to decode the initial state signal 214 to ensure that the spread spectrum operation will begin with the spread spectrum address counter 430 being in an initial state or having a 00 count.
The output signal of the first sampling flip-flop 501 is output into the input of the second sampling flip-flop 502 and into a not exclusive or (NXOR) gate 509. The logic of NXOR gate 509 compares two input bits on the two output signals of the first and second sampling flip-flops 501 and 502 and generates one output bit to be input into not AND (NAND) gate 510. If the output signals from the sampling flip-flops 501 and 502 are the same, the resulting output signal is a logical one, if the output signals are different, then the resulting output signal is a logical zero. The output of NAND gate 510 inputs into flip-flop 504. Flip-flop 504 is clocked using the inverted input reference signal 511, which is created using inverter 523, receiving as an input the input reference signal FREF 211. In other words, flip-flop 504 is clocked on a falling edge of the input reference signal FREF 211.
Flip-flop 504 outputs the PFD control signal 216 (e.g., TRI_PFD) to open and close the PLL synthesizer 200. The PFD control signal 216 is feedback to NAND gate 514. NAND gate 514 receives as input, the PFD control signal 216 and an inverted reset M-counter signal 525 (e.g., FV_RE_B) synchronized to overflow bit signal FV 401. Inverted reset M-counter signal 525 is the inverted output from flip-flop 506, which is clocked by overflow bit signal FV 401. The output of NAND gate 514 is input into NAND gate 510. The inverted overflow bit 525 may be used to deactivate the PFD control signal 216 for closing the PLL synthesizer 200 after loading the N-counter 212 and the M-counter 202 with the base values of the configuration ROM 310. Loading the base values of the configuration ROM 310 into the N-counter 212 and the M-counter 202 while the PLL synthesizer 200 provides minimum assurance that the output reference signal FCPU 222 of the PLL synthesizer 200 is not changing abruptly during the transition of turning the spread spectrum on and off. This synchronization or timing mechanism between the M- and N-counters 202 and 212 prevents erroneous pump up and pump down pulses to be passed to the charge pump of the PFD/CP 204, which ultimately limits the overshoot and undershoot of the VCO clock frequency.
The spread spectrum switch 440 produces an output control signal, address counter reset signal 402, which resets spread address counter 430. In one embodiment, NOR gate 515 receives a reset signal 513 (e.g., R) and the PFD control signal 216. Reset signal 513 (e.g., R) is created using inverter 524, receiving as an input the inverted reset signal 512 (e.g., RB_IN). The inverted reset signal 512 is the chip reset. The chip reset may be generated by a power reset circuit. Alternatively, the chip reset may be generated by other functional blocks of the chip known by those of ordinary skill in the art. NOR gate 515 activates the address counter reset signal 402 when the PLL synthesizer 200 has been opened (e.g., tri-stated) and the reset signal 513 is activated. The NOR gate 515 deactivates the address counter reset signal 402 when the PLL synthesizer 200 has been closed (e.g., not tri-stated) or when the reset signal 513 is activated. Alternatively, other logic or circuitry known by those skilled in the art may be used to produce the address counter reset signal 402 to reset the spread spectrum address counter 430.
The spread spectrum switch 440 produces an output control signal, divider control signal 321 (e.g., SS_M/N_EN), to load the N-counter 212 with a first base value and the M-counter 202 with a first base value while the PLL synthesizer 200 is open (e.g., tri-stated). In one embodiment, the output signal of the second sampling flip-flop 502 generates the divider control signal 321 (e.g., SS_M/N_EN). The divider control signal 321 may also be buffered by buffer 516. Alternatively, other logic or circuitry known by those skilled in the art may be used to produce the divider control signal 321 to load the N-counter 212 with the first base value and the M-counter 202 with the first base value while the PLL synthesizer 200 is open (e.g., tri-stated).
The spread spectrum switch 440 produces an output control signal, first counter reset signal 316 (e.g., RNB), to activate and deactivate the reset the N-counter 212. In one embodiment, the output of the third sampling flip-flop 503 is output into NXOR gate 517. The NXOR gate 517 compares the output signals of the second and third sampling flip-flops 502 and 503, and generates one output signal to be input into inverter 518. If the signals output from the second and third sampling flip-flops 502 and 503 are the same, the resulting output signal is a logical one, if the output signals are different, then the resulting output signal is a logical zero. NOR gate 519 receives, as its inputs, the reset signal 513 (e.g., R) and the output of the inverter 518, and outputs the first counter reset signal 316 (e.g., RNB). NOR gate 519 releases or deactivates the first counter reset signal 316 when either of the inputs are asserted. Alternatively, other logic or circuitry known by those skilled in the art may be used to produce the first counter reset signal 316 to activate and release the reset of N-counter 212.
The spread spectrum switch 440 produces an output control signal, second counter reset signal 315 (e.g., RMB) to activate and deactivate the reset the M-counter 202. In one embodiment, NAND gate 520 receives as inputs, the output of the XNOR gate 517 and an inverted feedback signal from flip-flop 505. The output of NAND gate 520 outputs to the input of flip-flop 505. The input of flip-flop 505 is clocked by inverted input reference signal 511. Flip-flop 505 outputs to NOR gate 521, which also receives as an input, reset signal 513 (e.g., R). NOR gate 521 produces second counter reset signal 315 (e.g., RMB). Flip-flop 505 also outputs to the input of flip-flop 506, which is clocked by the overflow bit signal FV 401 of N-counter 212. Flip-flop 506 outputs an inverted reset M-counter signal 525 (e.g., FV_RE_B) used to activate/deactivate PFD control signal 216 (e.g., TRI_PFD) to open/close the PLL, and non-inverted output 526 to be used to activate/deactivate second counter reset signal 315 (e.g., RMB) to activate and deactivate the reset the M-counter 202. In one embodiment, the overflow bit signal FV 401 is the feedback sign from the output of the N-counter 212 transmitted to the PFD/CP 204. Flip-flop 506 provides the non-inverted output 526 to the input of NOR gate 522, which also receives as an input, reset signal 513 (e.g., R). NOR gate 522 outputs to activate or deactivate the reset of flip-flop 505. Alternatively, other logic or circuitry known by those skilled in the art may be used to produce the second counter reset signal 315 to activate and release the reset of M-counter 202.
In one embodiment, the spread spectrum switch 440 may be designed using logic, as described with respect to
In one embodiment, the spread-control circuit 220 may be used to synchronously open the PLL synthesizer 200, synchronously load the M- and N-counters 202 and 212, synchronously align phases of the output signals of the M- and N-counters 202 and 212, and synchronously close the PLL synthesizer and increment a spread address counter. The preceding operations may be performed by synchronously generating the plurality of output control signals, for example, phase frequency detector (PFD) control signal 216 (e.g., TRI_PFD) to open and close the PLL, first counter reset signal 316 to activate and release the N-counter 212 (e.g., RNB), second counter reset signal 315 to activate and release the M-counter 202 (e.g., RMB), divider control signal 321 (e.g., SS_M/N_EN) to load the N-counter 212 with the first base value and the M-counter 202 with the first base value, and address counter reset signal 402 to activate and release the spread address counter 430. The method to perform such operations are described below, including the timing and sequence of clocking events associated with the generation of these output control signals of the spread-control circuit 220.
In one embodiment, the PLL synthesizer 200 may be a serial ATA (SATA) PLL. The switch and spread logic of spread-control circuit 220 may control the behavior of the SATA PLL when the SATA PLL changes to/from spread. The spread-control circuit 220 of SATA PLL may open the PLL, change the M- and N-counter values to the first base values, reset the M- and N-counters synchronously, and subsequently to align the phase of their outputs, close the PLL. This provides minimum assurance that the output frequency of the PLL is not changing abruptly during the transition. In other words, no erroneous pump up and pump down pulses are passed to the charge pump of the PFD/CP 204, limiting the overshoot and undershoot of the VCO clock frequency. Alternatively, the PLL synthesizer may be used in connection with other circuits known by those of ordinary skill in the art to generate an output reference signal, such as output reference signal FCPU 222. In one embodiment, output reference signal FCPU 222 may be a clock signal. Alternatively, the clock signal may be a processor clock signal.
In one embodiment, the output reference signal is a clock signal. The clock signal may be a PC clock signal. Alternatively, the output reference signal is a reference signal used in other components known by those of ordinary skill in the art.
Limiting the overshoot in the output reference signal when turning on the spread spectrum in operation 602 may further include detecting an initial state of a spread address counter, operation 604; and loading a first counter with a spread profile where the spread profile causes an initial negative frequency slope in the output reference signal, operation 605.
In one embodiment, the method of limiting the overshoot may achieve having the overshoot be less than approximately 300 parts per million (PPM). PPM indicates the amount of frequency deviation from a specified frequency. Alternatively, the method of limiting the overshoot may achieve substantially no overshoot (e.g., 0 PPM).
Limiting the undershoot in the output reference signal when turning on the spread spectrum in operation 603 may further include synchronously opening the PLL, operation 606; synchronously loading a first counter and a second counter of the PLL, operation 607; aligning a phase of an output signal of the first counter with a phase of an output signal of the second counter, operation 608; and synchronously closing the PLL and incrementing a spread address counter, operation 609.
In one embodiment, the method of limiting the undershoot may achieve having the undershoot be less than approximately negative 5300 PPM. In other words, the undershoot may be limited to be less than approximately negative 300 PPM or ±0.03% below the spreading profile of the reference signal. Alternatively, the method of limiting the undershoot may achieve substantially no undershoot. It should be noted that in determining the undershoot, the undershoot value includes the decrease in frequency due to the spreading. For example, a negative 0.5% down-spread of an output reference signal without any undershoot would be negative 5000 PPM (e.g., −0.5%). Alternatively, substantially no undershoot may be negative 7500 PPM for a negative 0.75% down-spread, or negative 2500 PPM for a 0.5% center-spread.
In another embodiment, method 700 may further include the operations of synchronously opening the PLL, operation 606; synchronously loading a first counter and a second counter of the PLL, operation 607; aligning a phase of an output signal of the first counter with a phase of an output signal of the second counter, operation 608; and synchronously closing the PLL and incrementing a spread address counter, operation 609. Alternatively, method 700 may further include operations 801-813 of method 800, as described below.
In one embodiment, the plurality of offset values substantially form an inverted triangular spread pattern in the output reference signal. In another embodiment, the plurality of offset values substantially form an inverted Lexmark spread pattern in the output reference signal. Alternatively, the plurality of offset values substantially may form other spread patterns known by those of ordinary skill in the art.
In one embodiment, synchronously opening the PLL, operation 606 of method 800, may further include detecting a spread enable signal from a serial interface, operation 801; sampling the spread enable signal by a reference clock signal at a first rising edge, operation 802; and activating a PFD control signal to open the PLL at a second falling edge of the reference clock signal, operation 803.
In one embodiment, synchronously loading a first counter and a second counter of the PLL, operation 607 of method 800, may further include activating a reset signal of the spread address counter at the second falling edge of the reference clock signal, operation 804; enabling spread gates in a spread ROM including a spread profile on a third rising edge of the reference clock signal, operation 805; and loading first base values into the first and second counters on the third rising edge of the reference clock signal, operation 806.
In one embodiment, aligning a phase of an output signal of the first counter with a phase of an output signal of the second counter, operation 608 of method 800, may further include activating a reset signal of the first counter on the third rising edge of the reference clock signal, operation 807; activating a rest signal of the second counter on a third falling edge of the reference clock signal, operation 808; releasing the reset signal of the first counter on a fourth rising edge of the reference clock signal, operation 809; and releasing the reset signal of the second counter on a first rising edge of an overflow bit signal of the first counter, operation 810.
In one embodiment, synchronously closing the PLL and incrementing a spread address counter, operation 609 of method 800, may further include deactivating the PFD control signal to close the PLL at a fourth falling edge of the reference clock signal, forcing the PFD outputs to be zero, operation 811; releasing the reset signal of the spread address counter at the fourth falling edge of the reference clock, operation 812; and incrementing the spread address counter by one on a second rising edge of the overflow bit signal of the first counter, operation 813.
In one embodiment, the plurality of offset values substantially form an inverted triangular spread pattern in the output reference signal. In another embodiment, the plurality of offset values substantially form an inverted Lexmark spread pattern in the output reference signal. Alternatively, the plurality of offset values substantially may form other spread patterns known by those of ordinary skill in the art for the spreading profile.
In another embodiment, method 800 may further include the operations of detecting an initial state of a spread address counter before synchronously opening the PLL, operation 604, and loading a first counter with a spread profile, where the spread profile causes an initial negative frequency slope in the output reference signal, operation 605. Alternatively, method 800 may further include the operations of detecting an initial state of a spread address counter before synchronously opening the PLL, operation 604; loading a base value into the first counter after synchronously opening the PLL, operation 701; adding a first offset value of a plurality of offset values to the base value, where the first offset value decreases a frequency of the output reference signal, operation 702; loading the first added value into the first counter, operation 703; adding a second offset value of the plurality of offset values to the base value, where the second offset value decreases the frequency of the output reference signal, operation 704; and loading the second added value into the first counter after incrementing spread address counter, operation 705.
It should be noted that the foregoing description of methods 600, 700, and 800 are exemplary embodiments. Various operations of these methods are sometimes grouped together in single embodiment, figure, or description thereof for the purpose of streamlining the disclosure aiding in the understanding of one or more of the various inventive aspects. This method of disclosure, however, is not to be interpreted as being restrictive or limiting to the combinations available of performing the above-described operations. For example, some operations may be performed simultaneously, others may be performed subsequently, and others may be performed synchronously.
In one exemplary embodiment, the improved algorithm, implemented as a circuit, as described with respect to
In a fourth operation, on the next falling edge of the input reference signal FREF signal 211, the second counter reset signal 315 (e.g., RMB) is activated by going low. In other words, the assertion of the second counter reset signal 315 (e.g., RMB) holds the M-counter 202 at zero state. In a fifth operation, on the next rising edge of the input reference signal FREF 211, the first counter reset signal 316 (e.g., RNB) of first counter 212 is released and N-counter 212 starts counting. In other words, N-counter 212 is loaded with a base value when RNB 316 is de-asserted. In a sixth operation, the spread-control circuit 220 waits for a rising edge of an overflow bit signal FV 401 of N-counter 212. The overflow bit signal FV 401 is the feedback sign from the output of the N-counter 212 to the PFD/CP 204.
In a seventh operation, on the next rising edge of overflow bit signal FV 401, the second counter reset signal 315 (e.g., RMB) is released from the M-counter 202, and M-counter 202 starts counting. In other words, M-counter 202 is loaded with a base value when RMB 315 is de-asserted. By releasing the second counter reset signal 315 when receiving the overflow bit signal FV 401 from the N-counter 212, the phase of the output signal of the M-counter 202 and the phase of the output signal of the N-counter 212 are substantially aligned. In an eighth operation, on the next falling edge of the input reference signal FREF 211, the PFD control signal 216 (e.g., TRI_PFD) goes Low, closing the PLL. In addition, in the eight operation, the address counter reset signal 402 (e.g., R_ADDRCNT) is released from the spread address counter 430 and address counter reset signal 402 (e.g., R_ADDRCNT) goes high. In a ninth operation, on the next rising edge of overflow bit signal FV 401, the spread address counter 430 is changed by one, starting the spread spectrum operation.
The graph of
In one exemplary embodiment, the following clocking events occur at the corresponding edges: sampling the spread enable signal 213 by a input reference signal FREF 211 at a first rising edge 902(1) by first sampling flip-flop 501; activating a PFD control signal 216 to open the PLL synthesizer 200 at a second falling edge 901(2) of the input reference signal FREF 211; activating a address counter reset signal 402 of the spread address counter 430 at the second falling edge 901(2) of the input reference signal FREF 211; the signal SPREADING 405, which is a buffered signal from the spread spectrum enable signal 213, goes High enabling spread gates in a spread ROM 320 including a spread profile on a third rising edge 902(3) of the input reference signal FREF 211; loading first base values into the N- and M-counters 212 and 202, respectively, on the third rising edge 902(3) of the input reference signal FREF 211; activating a first counter reset signal 316 of the N-counter 212 on the third rising edge 902(3) of the input reference signal FREF 211; activating a second counter rest signal 315 of the M-counter 202 on a third falling edge 901(3) of the input reference signal FREF 211; releasing the first counter reset signal 316 of the N-counter 212 on a fourth rising edge 902(4) of the input reference signal FREF 211; releasing the second counter reset signal of the M-counter 202 on a first rising edge 903(1) of an overflow bit signal FV 401 of the N-counter 212; deactivating the PFD control signal 216 to close the PLL synthesizer 200 at a fourth falling edge 901(4) of the input reference signal FREF 211; releasing the address counter reset signal 402 of the spread address counter 430 at the fourth falling edge 901(4) of the input reference signal FREF 211; and incrementing the spread address counter 430 by 1 on a second rising edge 903(2) of the overflow bit signal FV 401 of the N-counter 212.
In another exemplary embodiment, the following clocking events occur at the corresponding edges: detecting an initial state of a spread address counter 430 at a first rising edge 902(1) of the input reference signal FREF 211; loading a base value on line 318 into the N-counter 212 at a second rising edge 902(2), after synchronously opening the PLL synthesizer 200 at the second falling edge 901(2); adding a first offset value on line 319 of a plurality of offset values to the base value on line 318 at the second falling edge 901(2); loading the first added value on line 322 into the N-counter 212 at a third rising edge 902(3); adding a second offset value on line 319 of the plurality of offset values to the base value on line 318 at a second rising edge 903(2) of the overflow bit signal FV 401; and loading the second added value on line 322 into the N-counter 212 after incrementing spread address counter 430 by 1 at the second rising edge 903(2) of the overflow bit signal FV 401. In one embodiment, the first added value on line 322 causes the output reference signal on line 221 of the VCO 208 to decrease in frequency, or in other words, to have an initial negative frequency slope after detecting the initial state of the spread address counter 430. The initial negative frequency slope may be part of a spreading profile causing an inverted triangular spread pattern in the output reference signal. Alternatively, the initial negative frequency slope may be part of a spreading profile causing an inverted Lexmark spread pattern in the output reference signal.
The graph of
In one exemplary embodiment, the following clocking events occur at the corresponding edges: de-asserting the spread enable signal 213; sampling the spread enable signal 213 by the input reference signal FREF 211 at a first rising edge 1002(1) by first sampling flip-flop 501; activating a PFD control signal 216 to open the PLL synthesizer 200 at a first falling edge 1001(1) of the input reference signal FREF 211; deactivating an address counter reset signal 402 of the spread address counter 430 at the first falling edge 1001(1) of the input reference signal FREF 211; the signal SPREADING 405, which is the buffered signal from the spread spectrum enable signal 213, goes Low disenabling spread gates in the spread ROM 320 including the spread profile on a second rising edge 1002(2) of the input reference signal FREF 211; de-asserting divider control signal 321 (e.g., SS_M/N_EN) on a second rising edge 1002(2) of the input reference signal FREF 211; activating the first counter reset signal 316 of the N-counter 212 on the second rising edge 1002(2) of the input reference signal FREF 211; activating the second counter rest signal 315 of the M-counter 202 on a second falling edge 1001(2) of the input reference signal FREF 211; releasing the first counter reset signal 316 of the N-counter 212 on a third rising edge 1002(3) of the input reference signal FREF 211; releasing the second counter reset signal of the M-counter 202 on a first rising edge 1003(1) of an overflow bit signal FV 401 of the N-counter 212; deactivating the PFD control signal 216 to close the PLL synthesizer 200 at a fourteenth falling edge 901(14) of the input reference signal FREF 211; and releasing the address counter reset signal 402 of the spread address counter 430 at the fourteenth falling edge 901(14) of the input reference signal FREF 211.
As previously described, the input reference signal FREF 211 is divided by the value of M-counter 202 on line 218 before feeding the frequency into PFD/CP 204. Through the PFD/CP 204, the LF 206, and VCO 208, the frequency is multiplied by the value of the N-counter 212 on line 219. The output reference signal FCPU 222 is taken from the VCO 208 on line 221 after being divided by the value in F-counter 210. In this exemplary embodiment, the first offset value of the plurality of offset values of the spreading profile is added to the base value of the configuration ROM 310. The first added value is loaded into N-counter 212, causing the output reference signal FCPU 222 to have an initial negative frequency slope 1103 starting from point 1102 to point 1104 after detecting the initial state of the spread address counter 430. In other words, the output reference signal FCPU 222 when the first added value is loaded into the N-counter 212 is less than the output reference signal FCPU 222 when the base value is loaded into the N-counter 212. The spreading profile of the spread ROM 320 is repetitively loaded into the N-counter 212 at a spread frequency FSS 1105. In this embodiment, the spread frequency FSS 1105 is approximately 33 kHz. Alternatively, other spread frequencies may be used as known by those of ordinary skill in the art.
The spread frequency is determined by the number of rows of the spread ROM 320. In one exemplary embodiment, if the frequency FN of the output signal of the N-counter 212 were approximately 4 MHz and the number of rows (e.g., # of Rows) of the spread ROM 320 were 120, then the spread frequency would be approximately 33 kHz. This calculation can be express in the following equation:
FSS=(FN)/(#ofRows)
The plurality of offset values are stored in the number of rows and are sequentially read out to be added to the base value to be loaded into the N-counter 212.
Since the spreading profile of the spread ROM 320 causes the output reference signal FCPU 222 to be at the downward trend, as illustrated in the initial negative frequency slope 1103 of
In an alternative embodiment, the overshoot in the output reference signal FCPU 222 may be substantially eliminated or limited, when turning on the spread spectrum of the output reference signal FCPU 222 by, first, detecting an initial state or zero count of the spread address counter 430, and second, loading the N-counter 212 with a spread profile, where the spread profile causes an initial negative frequency slope in the output reference signal FCPU 222.
Because the M- and N-counters 202 and 212 are synchronously loaded while the PLL loop is open, the PLL synthesizer 200 will not be abruptly react to the counter value changes. This may limit both the undershoot and overshoot in the output reference signal FCPU 222. In an alternative embodiment, the phase alignment of the output signals of the M- and N-counters 202 and 212 prior to closing the PLL loop substantially eliminates or limits the undershoot of the output reference signal FCPU 222, while turning on the spread function.
In this exemplary embodiment, the first offset value of the plurality of offset values of the spreading profile is added to the base value of the configuration ROM 310. The first added value is loaded into N-counter 212, causing the output reference signal FCPU 222 to have an initial negative frequency slope 1108 starting from point 1107 to point 1109 after detecting the initial state of the spread address counter 430. In other words, the output reference signal FCPU 222 when the first added value is loaded into the N-counter 212 is less than the output reference signal FCPU 222 when the base value is loaded into the N-counter 212. The spreading profile of the spread ROM 320 is repetitively loaded into the N-counter 212 at a spread frequency FSS 1105. In this embodiment, the spread frequency FSS 1109 is approximately 33 kHz. Alternatively, other spread frequencies may be used as known by those of ordinary skill in the art.
Since the spreading profile of the spread ROM 320 causes the output reference signal FCPU 222 to be at the downward trend, as illustrated in the initial negative frequency slope 1108 of
In an alternative embodiment, the overshoot in the output reference signal FCPU 222 may be substantially eliminated or limited, when turning on the spread spectrum of the output reference signal FCPU 222 by, first, detecting an initial state or zero count of the spread address counter 430, and second, loading the N-counter 212 with a spread profile, where the spread profile causes an initial negative frequency slope in the output reference signal FCPU 222.
Because the M- and N-counters 202 and 212 are synchronously loaded while the PLL loop is open, the PLL synthesizer 200 will not be abruptly react to the counter value changes. This may limit both the undershoot and overshoot in the output reference signal FCPU 222. In an alternative embodiment, the phase alignment of the output signals of the M- and N-counters 202 and 212 prior to closing the PLL loop substantially eliminates or limits the undershoot of the output reference signal FCPU 222 while turning on the spread function.
As previously described, reference signals, such as clock signals, may generate radiation spikes in the fundamental frequency as well as the harmonic frequencies. By applying a spread spectrum to the input reference signal, energies of the input reference signal can be spread out by modulating the input reference signal with a slower frequency, a spread frequency, such as spread frequency FSS 1205 of
In this exemplary embodiment of
In this embodiment, the spread profile is a down-spread of negative 0.5%. The negative 0.5% value is the amount of spread that is applied to the input reference signal. A down-spread of negative 0.5% results in an output frequency of 100 MHz, having peaks values at 100 MHz and 99.5 MHz (i.e., 100 Mhz−((0.5%)*(100 MHz)=99.5 MHz). It should be noted that in this example, the resulting waveform of the output reference signal (e.g., inverted Lexmark spread pattern) will start at 100 MHz and decrease in frequency down to the first peak value of 99.5 MHz at the bottom of a first pulse of the resulting waveform, and then increase in frequency up to a second peak value of 100 MHz, and decrease back down to a third peak value of 99.5 MHz of a second pulse, repeating as long as the spread spectrum is turned on. The frequency between the first peak value and the third peak value is the spread frequency 1205 (e.g., 33 kHz).
In another exemplary embodiment, the spread profile is a down-spread of negative 1.0%, resulting in peak EMI reductions of approximately −4.97 dB at the fundamental frequency, approximately −12.94 dB at the fifth harmonic frequency, and approximately −13.72 dB at the seventh harmonic frequency.
Embodiments of the present invention are well suited to performing various other operations or variations of the operations recited herein, and in a sequence other than that depicted and/or described herein. In one embodiment, such a process is carried out by processors and other electrical and electronic components, e.g., executing computer readable and computer executable instructions comprising code contained in a computer usable medium.
For purposes of clarity, many of the details of the spread-control circuit 220 and the methods of designing and manufacturing the same that are widely known and are not relevant to the present embodiments have been omitted from the following description.
It should be appreciated that reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Therefore, it is emphasized and should be appreciated that two or more references to “an embodiment” or “one embodiment” or “an alternative embodiment” in various portions of this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures, or characteristics may be combined as suitable in one or more embodiments of the invention.
Similarly, it should be appreciated that in the foregoing description of exemplary embodiments of the invention, various features are sometimes grouped together in a single embodiment, figure, or description thereof for the purpose of streamlining the disclosure aiding in the understanding of one or more of the various inventive aspects. This method of disclosure, however, is not to be interpreted as reflecting an intention that the claimed embodiments requires more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive aspects lie in less than all features of a single foregoing disclosed embodiment. Thus, the claims following the detailed description are hereby expressly incorporated into this detailed description, with each claim standing on its own as a separate embodiment of this invention.
This application claims the benefit of U.S. Provisional Application No. 60/637,719, filed Dec. 20, 2004.
Number | Name | Date | Kind |
---|---|---|---|
4843255 | Stuebing | Jun 1989 | A |
4890065 | Laletin | Dec 1989 | A |
5124597 | Stuebing et al. | Jun 1992 | A |
5315164 | Broughton | May 1994 | A |
5410191 | Miura | Apr 1995 | A |
5563605 | McEwan | Oct 1996 | A |
5651035 | Tozun et al. | Jul 1997 | A |
5682114 | Ohta | Oct 1997 | A |
5872807 | Booth et al. | Feb 1999 | A |
5933039 | Hui et al. | Aug 1999 | A |
5959479 | Woodward | Sep 1999 | A |
6055287 | McEwan | Apr 2000 | A |
6060922 | Chow et al. | May 2000 | A |
6622254 | Kao | Sep 2003 | B1 |
6665808 | Schinzel | Dec 2003 | B1 |
6762634 | Hattori | Jul 2004 | B1 |
6850554 | Sha et al. | Feb 2005 | B1 |
7176738 | Hwang et al. | Feb 2007 | B1 |
20030151453 | Laletin | Aug 2003 | A1 |
20030229816 | Meynard | Dec 2003 | A1 |
20050071705 | Bruno et al. | Mar 2005 | A1 |
Number | Date | Country | |
---|---|---|---|
60637719 | Dec 2004 | US |