Modern digital systems typically include multiple digital devices capable of communicating with each other using digital signals made of sequences of digital symbols. A digital symbol takes up a time interval, which is often referred to as a unit interval or a data interval. A digital device may transmit a digital data signal by setting the value of a signal parameter associated with a communication channel to one of a plurality of predetermined values for each data interval according to a transmitter clock. A digital device that receives the digital signal takes successive samples of the signal according to a receiver clock and determines the values of the signal parameter represented by the samples. The receiver clock is preferably synchronized with the digital signal so that the samples are taken at times corresponding to the bit intervals.
To communicate data at high speed, it is desirable to make the data intervals as short as possible, which, in turn, requires greater precision in the synchronization between the receiver clock used by the receiving device and the data intervals of the incoming signal. For example, modern interfacing and communication protocols such as PCI Express, SONET, InfiniBand and XAUI use data intervals on the order of nanoseconds or less, and require that the receiving device use a clock which is synchronized to the data intervals to within a fraction of one data interval. For ease of synchronization, many digital systems are designed such that the transmitter clock and the receiver clock both have a relatively stable frequency. However, such systems may be susceptible to electromagnetic interference (EMI) at or near a particular frequency, and may interfere with other systems that are sensitive to signals at or near the particular frequency.
The following detailed description given by way of example, but not intended to limit the invention solely to the specific embodiments described, may best be understood in conjunction with the accompanying drawings wherein like reference numerals denote like elements and parts, in which:
To reduce EMI, a digital system may employ a clock signal having a frequency that varies over time. That is, the digital system may impart a frequency modulation to a transmitter and/or receiver clock in the digital system. By varying the frequency of a clock signal, the spectrum of the clock signal is spread out over a frequency band so that the clock signal does not give rise to EMI that is concentrated at a particular frequency. Therefore, a signal with a narrow frequency band that is within the frequency band of the spread spectrum clock signal may be more easily discernable than it would be if the spectrum of the clock signal were concentrated at the same frequency as the narrowband signal. Moreover, spreading the spectrum of the clock signal makes it less likely for a narrowband signal in the clock signal's frequency band to significantly interfere with the clock signal.
One way in which a spread spectrum clock signal is generated is by application of a triangular frequency modulation to the clock signal.
In the case of modulating only one of a transmitter and receiver clock according to the modulation in
In one embodiment of the present system and method, a frequency modulation is imparted to the transmitter clock and to the receiver clock such that the frequency offset between the transmitter clock and the receiver clock, and thereby the frequency offset between the transmitted data signal and the receiver clock, exhibits a trapezoidal waveform pattern. To illustrate how such trapezoidal frequency offset is achieved, reference is made to
For purposes of this description, embodiments of the present system and method will be described in the context of the trapezoidal frequency offset depicted in
The receiving device 302 further includes a clock recovery circuit 100 to generate the at least one recovered clock signal 30. In one embodiment, the clock recovery circuit includes a feedback circuit 48 that generates a control signal 35 and a clock generating circuit 12 that generates the at least one recovered clock signal 30 from the receiver clock 15 according to the control signal 35.
The clock recovery circuit 100 according to one embodiment uses piece-wise linear (PWL) estimation of a periodic frequency offset waveform. The waveform is considered to traverse a plurality of segments (“N” segments) in a period of the waveform, with a ramp rate being associated with each segment. The number “N” of segments in a period may depend on the complexity of the waveform. The ramp rates of the respective segments are used to track the phase movement of the data signal and are free to vary on a segment-by-segment basis. The ramp rate associated with a particular segment is equal to the derivative of the frequency offset for the respective segment. The ramp rates may be updated iteratively. For example, each time the frequency offset waveform enters a new segment, a previously generated estimate of the ramp rate for the segment is used as an initial ramp rate value for the segment. As the waveform traverses the segment during a given period (or “iteration”), the ramp rate value for that segment is refined and the estimate for the ramp rate determined at the end of the segment is used as the initial ramp rate value for the same segment during a succeeding iteration.
Referring now to
It is noted that the core signals 20 and recovered clock signals 30 are analog signals, and that the digital phase estimation signal 35 is passed to the phase DAC via a digital bus. In this regard, the digital phase estimation signal is used in conjunction with the core signals to generate recovered clock signals that correspond to the circuit's estimation of the phase of the incoming data. Thus, it is said that the phase DAC “converts” the digital phase estimation signal 35 from a digital phase to an analog phase. In one embodiment, the phase DAC is a phase shifter that shifts the phase of the core signals 20 in response to the phase estimation signal 35. The phase shifter may be implemented through use of a phase interpolator and/or variable delay line.
The recovered clock signals 30 generated by the phase DAC 25 are passed to a phase detector (PD) 40, which samples the incoming data 5 with the recovered clock signals 30 to recover data and to generate a phase error signal 45, the phase error signal indicating whether the recovered clock signals are relatively early, relatively late, or closely aligned with respect to the incoming data signal.
The phase error signal 45 is, in turn, passed through feedback circuitry 48 that uses the phase error signal 45 to generate a value, by which the digital phase estimation signal 35 is updated to better align the digital phase estimation signal 35 with the incoming data signal.
The feedback circuitry 48 through which the phase error signal 45 is passed includes multiplication blocks 50, 55, and 125. The multiplication blocks 50, 55, and 125 multiply the phase error signal by respective mathematical constants “KP,” “KF,” and “KR”. The feedback circuitry 48 further includes an accumulator 70 associated with the multiplication block 50, an accumulator 75 associated with the multiplication block 55, and accumulators 1201 through 120N associated with the multiplication block 125. Each accumulator includes a delay element (Z−1) having its output fed back to its input such that the element's output signal is added to the element's input signal and the result is stored as the new element output signal. In one embodiment, the accumulators are implemented as clocked storage elements.
Accumulator 70 is designated as a “phase accumulator” because its output is proportional to the difference between the phase of the incoming data signal 5 and the phase of the receiver clock signal 15 when the system is in lock. Accumulator 75 is designated the “frequency accumulator” because its output is proportional to the difference between the frequency of the incoming data signal and the frequency of the receiver clock signal when the system is in lock. Accumulators 1201-120N are designated “rate accumulators” because, when the system is in lock, each accumulator's output is proportional to the rate of change of the frequency offset between the incoming data signal and the receiver clock signal for the accumulator's respective time segment.
It should be noted that in the context of the present system and method, the term “in lock” means that the phase of the recovered clock is tracking the phase of the incoming data signal, as determined by the transmitter clock, such that the recovered clock correctly samples the incoming data. That is, the recovered clock is in synchronism with the data intervals of the incoming data.
Referring again to
In one embodiment, a single most significant bit (MSB) of the frequency accumulator 75 represents an estimate of the polarity of the frequency offset. The MSB is a “0” when frequency offset is negative and a “1” when it is positive. Thereby, the MSB produces a square wave having the same period as the trapezoidal waveform of
An embodiment of DPLL 130 is shown in
Referring back to
The output of summer 105 is passed to accumulator 75. The output of accumulator 75 is, in turn, passed to a summer 110 which adds the output of accumulator 75 to the output of multiplication block 50. The output of summer 110 serves as the input to accumulator 70.
The output of accumulator 70 is a binary number proportional to the difference between the phase of the incoming data signal and the phase of the receiver clock signal (equivalently the core signals) when the system is in lock. It is an indication of how the phase of the recovered clock should be adjusted (in relation to the receiver clock) to match the phase of the incoming data. The output of accumulator 70 is passed to a coder 115. The coder encodes the binary output of accumulator 70 into a format that is compatible with the phase DAC. The output of the coder is the digital phase estimation signal 35.
Referring now to
The read/write accesses of the frequency offset derivative table must be synchronized with the frequency offset waveform. Such synchronization is achieved through the use of DPLL 130 having a digital phase accumulator 205. As in the case of the
A respective circuit element in
Referring now to
In an alternative embodiment, the adaptation block may vary “KF” instead of, or in addition to, “KP.”
One way in which the adaptation block can detect a non-lock condition is by monitoring the time history of the phase error signal. A monotonic phase error signal indicates a non-lock condition. Another way in which the adaptation block can detect a non-lock condition is by monitoring the DPLL 130. If the DPLL 130 is out of lock, then the clock recovery circuit 404 is out of lock. In view of the present disclosure, one skilled in the art will readily appreciate the many alternative techniques by which the adaptation block can detect the lock condition.
A respective circuit element in
Referring now to
In the
In an alternative of the
In any event, the entries in the frequency offset table are updated during each iteration or period of the frequency offset waveform. Accordingly, upon completion of a segment the table entry for the segment is updated by overwriting the entry with the current value of accumulator 75. In this manner, the initial table entry for the segment during the following iteration is set equal to the final value of the frequency accumulator during the current iteration. Thereby, the frequency offset estimate for each segment, and therefore the ramp rate estimate for each segment, is improved over time.
It should be noted that the amount of memory required to store the frequency offset table 155 may be reduced by performing a subtraction operation before writing values to the table, e.g. by storing the difference between the current and previous frequency offset estimates instead of storing the current frequency offset estimate. When implemented in this manner, the values stored in the table 155 are average frequency ramp rates. That is, for each segment, the value stored in table 155 is the average ramp rate for the segment. By contrast, the ramp rates stored in table 140 of
The read/write accesses of the frequency offset table must be synchronized with the frequency offset waveform. Such synchronization is achieved through the use of DPLL 130. As in the case of the embodiments of
When the MSBs of the phase accumulator's binary code are to be used to synchronize switching and ramp rate estimate generation, the number of MSBs that must be monitored is related to the number of segments by the following equation: M=Log2N (where “M” is the number of MSBs that must be monitored and “N” is the number of segments).
A respective element in
As these and other variations and combinations of the features discussed above can be utilized without departing from the present invention as defined by the claims, the foregoing description of the one embodiments should be taken by way of illustration rather than by way of limitation of the invention as defined by the claims.
This application is a continuation of U.S. application Ser. No. 14/574,253, filed Dec. 17, 2014, now U.S. Pat. No. 9,337,992, which is a continuation of U.S. application Ser. No. 13/674,812, filed Nov. 12, 2012, now U.S. Pat. No. 8,923,467, which is a continuation of U.S. patent application Ser. No. 12/441,003, filed Mar. 12, 2009, now U.S. Pat. No. 8,311,176, which is a national phase application filed under 35 U.S.C. 371, of International Application No. PCT/US2007/019418, filed Sep. 5, 2007, which claims the benefit of the filing date of U.S. Provisional Patent Application No. 60/849,868 filed Oct. 6, 2006, each of which is hereby incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6114973 | Winner et al. | Sep 2000 | A |
6696886 | Ke | Feb 2004 | B1 |
6732286 | Sutardja | May 2004 | B1 |
6914931 | Douglas et al. | Jul 2005 | B2 |
6937679 | Skinner | Aug 2005 | B2 |
6965754 | King | Nov 2005 | B2 |
7020791 | Aweya et al. | Mar 2006 | B1 |
7317361 | Duven et al. | Jan 2008 | B2 |
7339982 | Wood, Jr. | Mar 2008 | B2 |
7471691 | Black et al. | Dec 2008 | B2 |
7705815 | Yun et al. | Apr 2010 | B2 |
7738617 | Fortin et al. | Jun 2010 | B1 |
7825706 | Smith | Nov 2010 | B2 |
8311176 | Lee et al. | Nov 2012 | B2 |
8923467 | Lee et al. | Dec 2014 | B2 |
9337992 | Lee | May 2016 | B2 |
20030201839 | Luo et al. | Oct 2003 | A1 |
20040071251 | Sutioso et al. | Apr 2004 | A1 |
20060267647 | Chang | Nov 2006 | A1 |
20070024383 | Spijker et al. | Feb 2007 | A1 |
20080070532 | Moffatt et al. | Mar 2008 | A1 |
20080074154 | Shin | Mar 2008 | A1 |
Entry |
---|
Aoyama et al., “3Gbps, 5000ppm Spread Spectrum SerDes PHY with Frequency Tracking Phase Interpolator for Serial ATA,” NEC Electronics Corporation, 2003 Symposium on VLSI circuits Digest of Technical Papers. 4 pages. |
EP Communication dated Jul. 19, 2010 in EP Application No. 07837790.0. 4 pages. |
EP Communication dated Oct. 17, 2012, re EP Application No. 07837790.0. 4 pages. |
EP Examination Report dated Apr. 17, 2014 in EP Application No. 07837790.0. 5 pages. |
EP Examination Report dated Feb. 25, 2015 in EP Application No. 07837790.0. 4 pages. |
EP Response dated Apr. 22, 2013 in EP Application No. 07837890.0, Includes New Claims (Highlighted and Clear Copies) and a Claim Chart. 38 pages. |
EP Response dated Aug. 18, 2014 in EP Application No. 07837790.0. 6 pages. |
EP Response dated Jun. 9, 2015 in EP Application No. 07837790.0, Includes New Claims (Highlighted and Clear copies). 11 pages. |
EP Response dated Nov. 29, 2010 in EP Application No. 07837790.0. 12 pages. |
Lee et al., “A Second-Order Semi-Digital Clock Recovery Circuit Based on Injection Locking,” ISSCC 2003, Session 4, Clock Recovery and Backplane Transceivers, Paper 4.3. 8 pages. |
Lee et al., “Burst Mode Packet Receiver Using a Second Order DLL,” 2004 Symposium on VLSI Circuits Digest of Technical Papers. 4 pages. |
Lee et al., “Paper 18.4: Improving CDR Performance via Estimation,” 2006 IEEE International Solid-State Circuits Conference, Feb. 7, 2006. 8 pages. |
PCI-SIG, “PCI Express Card Electromechanical Specification,” Revision 1.1, Mar. 28, 2005. 90 pages. |
PCI-SIG,“PCI Express Base Specification,” Revision 1.0, Apr. 29, 2002. 416 pages. |
PCT International Search Report and Written Opinion dated Feb. 11, 2008 in International Application No. PCT/US2000/019418, 2 pages. |
Serial ATA Part Five, “Serial ATA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 371-434. 64 pages. |
Serial ATA Part Four, “Serial ATA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 301-370. 70 pages. |
Serial ATA Part One, “Serial ATA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 1-100. 100 pages. |
Serial ATA Part Seven, “Serial ATA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 501-587. 87 pages. |
Serial ATA Part Six, “Serial ATA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 435-500. 66 pages. |
Serial ATA Part Three, “Serial ATA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 201-300. 100 pages. |
Serial ATA Part Two, “Serial TA International Organization: Serial ATA Revision 2.5,” Oct. 27, 2005, pp. 101-200. 100 pages. |
Serial ATA, “Serial ATA II: Electrical Specification,” Revision 1.0, May 26, 2004. 187 pages. |
Serial ATA, “Serial ATA: High Speed Serialized AT Attachment,” Revision 1.0a, Jan. 7, 2003. 311 pages. |
Sidiropoulos et al., “A Semidigital Dual Delay-Locked Loop,” IEEE Journal of Solid-State Circuits, vol. 32, No. 11, Nov. 1997. 10 pages. |
Number | Date | Country | |
---|---|---|---|
20160330013 A1 | Nov 2016 | US |
Number | Date | Country | |
---|---|---|---|
60849868 | Oct 2006 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14574253 | Dec 2014 | US |
Child | 15150355 | US | |
Parent | 13674812 | Nov 2012 | US |
Child | 14574253 | US | |
Parent | 12441003 | US | |
Child | 13674812 | US |