1. Field of the Invention
Embodiments of the invention generally relate to electronics, and in particular, to data communication links.
2. Description of the Related Art
The transmitter (Tx) 102 converts a clocked digital data stream to an analog stream (thereby embedding a clock signal in the serial data stream). The communication channel 104 can introduce linear distortion, non-linear distortion, and noise. The receiver (Rx) 106 recovers the embedded clock signal and data from the distorted serial data stream.
A serial data communication link can also use an analog-to-digital converter (ADC) and digital signal processor (DSP)-based clock and data recovery (CDR) receiver 202 as illustrated in
The CDR receiver 202 operates as follows. The PGA 302 receives and amplifies the distorted serial data stream. The gain of the PGA 302 can be adjusted. The ADC 304 converts the distorted serial data stream from analog to digital. While the output of the ADC 304 may be digital, the data stream is still in soft symbol form and has not yet been sliced to hard symbols. The digital version of the distorted serial data stream is then provided as an input to the FFE 306 and to the equalizer 312. For example, the FFE 306 can provide equalization, such as pre-emphasis, that is complementary to the characteristics of the communication channel 104 (
The equalizer 312 can also provide equalization for the timing recovery path and provide an equalized signal as an input to the PD 314. The equalizer 312 is typically smaller and lower power than the equalizers 306, 310 of the data recovery path. The PD 314 determines a phase difference between the equalized signal and an output of the slicer 324. The output of the PD 314 is summed with a PD offset, then amplified by a PD gain, then low-pass or band-pass filtered by the filter 320, which then controls the CP generator 322. The CP generator 322 can be implemented in a variety of ways. For example, the CP generator 322 can be a numerically controlled oscillator (NCO) controlled by the output of the filter 320. In another example, the CP generator 322 can be a phase interpolator that receives a fixed clock frequency input and generates a different phase of that input fixed clock. The output of the CP generator 322 corresponds to the recovered clock signal.
For timing recovery, a Mueller-Muller phase detector 350 first estimates the impulse response of the channel 104 (
Improving upon the performance of the Mueller and Muller phase detector is one aspect of embodiments of the invention. A conventional Mueller-Muller phase detector places a main cursor at the midpoint of a pre-cursor and a post-cursor. However, when the impulse response of an associated transmission line is not symmetric, the main cursor can be misaligned by conventional Mueller-Muller techniques. By providing a replica clock and data recovery path, trial and error experiments on the phase detector offset and/or gain can be performed, and relatively good values found for the phase detector offset and/or gain without disturbing the reception of data by the phase detector that is being used to receive data. These settings can then be used by the phase detector that is being used to receive data, which can improve the bit error rate of the phase detector and corresponding clock and data recovery circuit.
One embodiment includes an apparatus, wherein the apparatus includes: a first clock and data recovery circuit having an input and an output, wherein the input is coupled to an input node, wherein the first clock and data recovery circuit has a first phase detector with at least one of an adjustable offset or an adjustable gain; a second clock and data recovery circuit having an input and an output, wherein the input is coupled to the input node, wherein the second clock and data recovery circuit has a second phase detector with at least one of an adjustable offset or an adjustable gain; and a control circuit communicatively coupled to each of the first clock and data recovery circuit and the second clock and data recovery circuit for control of at least one or the offset or the gain settings of phase detectors of the clock and data recovery circuits, wherein the control circuit is coupled to at least the output of the second clock and data recovery circuit; wherein the output of the first clock and data recovery circuit is at least temporarily configured to provide recovered data as an input to circuits other than the control circuit while at least one of the one or more configurable characteristics of the second clock and data recovery circuit is being adaptively adjusted by the control circuit.
In one embodiment, the apparatus includes portions of the first clock and data recovery circuit and the second clock and data recovery circuit and the control circuit. For example, the included portions can include equalizers, phase detectors, filters, and CP generators. The portions of the first clock and data recovery circuit and the second clock and data recovery circuit can further include analog to digital converters. The portions of the first clock and data recovery circuit and the second clock and data recovery circuit can further include programmable gain amplifiers.
One embodiment includes a method for setting up a clock and data recovery circuit, wherein the method includes: recovering a clock signal and data from an analog signal in a first clock and data recovery circuit, wherein the first clock and data recovery circuit has a first phase detector with at least one of an adjustable offset or an adjustable gain; recovering the clock signal and the data from the analog signal in a second clock and data recovery circuit, wherein the second clock and data recovery circuit has a second phase detector with at least one of an adjustable offset or an adjustable gain; providing recovered data from the first clock and data recovery circuit to one or more circuits that use the recovered data; adaptively adjusting at least one of the adjustable offset or the adjustable gain of the second clock and data recovery circuit to generate at least one of an adjustable offset setting or an adjustable gain setting; and applying the at least one of the adjustable offset setting or the adjustable gain setting obtained from adaptive adjustment of the second clock and data recovery circuit to the first clock and data recovery circuit.
One embodiment includes an apparatus for setting up a clock and data recovery circuit, wherein the apparatus includes: a first clock and data recovery circuit having an input and an output, wherein the input is coupled to an input node, wherein the first clock and data recovery circuit has a first phase detector with at least one of an adjustable offset or an adjustable gain; a second clock and data recovery circuit having an input and an output, wherein the input is coupled to the input node, wherein the second clock and data recovery circuit has a second phase detector with at least one of an adjustable offset or an adjustable gain; means for providing recovered data from the first clock and data recovery circuit to one or more circuits that use the recovered data; a means for adaptively adjusting at least one of the one or more configurable characteristics of the second clock and data recovery circuit; and means for applying the at least one of the adjustable offset setting or the adjustable gain setting obtained from adaptive adjustment of the second clock and data recovery circuit to the first clock and data recovery circuit.
These drawings and the associated description herein are provided to illustrate specific embodiments of the invention and are not intended to be limiting.
In this description, reference is made to the drawings in which like reference numerals indicate identical or functionally similar elements.
Although particular embodiments are described herein, other embodiments of the invention, including embodiments that do not provide all of the benefits and features set forth herein, will be apparent to those of ordinary skill in the art.
Returning to
In the illustrated embodiment, the one or more parameters that do not affect the power consumption include, but are not limited to, the following: (1) a phase detector offset, which corresponds to an offset adjustment for of the phase detector (PD) 314; and a phase detector gain, which corresponds to the gain of the amplifier 318, which is in the signal path with the PD 314.
Note the relationship of the Tx clock signal to the ADC clock signal. In the system shown in
Note that the ADC clock frequency and phase should be determined only from information contained in the digitized data stream itself. A feedback control system is constructed that examines the digitized waveform and controls the frequency and phase of an oscillator until the control system determines that the ADC clock is locked to the incoming data stream and sampling at the proper phase. This control loop is referred to as the “Timing Path.” The block that computes the phase of the sampling clock relative to the phase of the data is referred to as a phase detector 314 (
As a block in the timing path, the phase detector 314 has an offset and gain value. For the best performance, there exist optimal values for the offset and gain. However, relatively good values that exhibit less than the best performance obtained from optimal values can also be applicable. Phase detector errors can also be referred to as timing errors.
Example (a) of
For relatively good bit error rate (BER) performance, the main cursor sample 416 can be taken at the peak of the impulse responses 402, 404, 406, 408. While a better cursor position may be elsewhere,
With the symmetric impulse response 402 of example (a), the main cursor sample 416 is taken at the peak of the impulse response 402 for relatively good performance. With the unequal slopes of the impulse response 404 of example (b), the main cursor sample 416 is taken after the actual peak when sampled according to Mueller-Muller techniques. With the unequal slopes of the impulse response 406 of example (c), the main cursor sample 416 is taken before the actual peak when sampled according to Mueller-Muller techniques. Examples (b) and (c) result in a static phase error for a phase detector. The impulse response 408 of example (d) illustrates yet another different slope characteristic that results in gain variation in a loop transfer response.
As illustrated in
Embodiments of the invention reduce the gain and offset error of the Mueller-Muller phase detector by introducing a second, parallel, replica CDR path onto which the offset and gain of the phase detector can be experimented, without affecting the performance of the main CDR path. The resulting performance of the replica path can be measured for each trial or experiment, and a relatively good offset and gain, such as the best offset and gain, chosen for use on the main CDR path.
The control logic 508 controls the operation of the two CDR circuits 504, 506 and performs the trial-and-error hypothesis testing in the iPath CDR circuit 506. While the two CDR circuits 504, 506 should be implemented in hardware, the control logic 508 can be implemented by software/firmware, by electronic hardware, or by a combination of software/firmware and electronic hardware. For example, the software/firmware can include computer-executable instructions stored in a tangible non-transitory computer-readable medium, which are then executed by a processor, such as a microprocessor, microcontroller, general-purpose digital signal processor, licensable core, or the like. The presence and use of the iPath CDR circuit 506 advantageously permits the receiver to continue to provide normal default reception in an uninterrupted manner via the main path while testing for improved settings for at least one of clock recovery or data recovery.
The replica path serves as a “laboratory” for the receiver configuration experiments under the control of the control logic 508. The main path, which in the illustrated embodiment presents the data to the downstream system, is preferably not disturbed while experiments are in process on the replica path.
In one embodiment, for each experimental setting of the iPath CDR circuit 506, the performance of the particular trial can be estimated by determining the data eye opening of the recovered data. There are various performance measures, including estimation of the bit error rate (BER) that can be inferred from a data eye opening. In one example, the magnitude of the eye-opening can be used as an estimate of the performance of the setting.
After a relatively good performing parameter, such as the best parameter, is found on the replica path, that parameter can then be set on the main path. The changing of the parameter on the main path should be done in a smooth manner so as not to disrupt the real data reception. Examples of parameters that can be adjusted can include one or more of the phase detector offset and the phase detector gain. Typically, a particular parameter will be analyzed separately from the others, but parameters can alternatively be analyzed in a group.
At the start of the process, it is assumed that both of the CDR circuits 504, 506 are enabled, receiving data, and generating data as an output. In the illustrated process, there are a total of N variations for the parameter that is being tested. The value for N can vary in a very broad range, and can vary depending on the particular parameter. For example, the number of phase detector offsets can vary from the number of phase detector gain settings to be tested.
The process begins by entering a state 602. The state 602 can be entered upon startup, for recalibration, for each separate parameter, and the like. Prior to entering the state 602, a loop counter i is initialized to 1. The loop counter i tracks the variations being tested. The variable iBest stores the value of the loop counter for the best setting encountered during the process and can also be initialized to 1.
In the state 602, the process applies a parameter setting P[i] using the iPath CDR circuit 506. The parameter P[i] represents the i-th variation of the phase detector offset or phase detector gain. The process advances from the state 602 to a state 604.
In the state 604, the process determines the vertical data eye opening of the iPath CDR circuit 506 with the current parameter setting P[i] applied to determine the performance of the current parameter setting P[i]. For example, the soft symbol output of the summing circuit 308 (
If there remain additional settings for test, as can be indicated by the loop counter i having a value that is less than the value for N, and if a sufficiently good performing setting has not yet been found, the process returns from the state 604 to the state 602 to try another parameter setting P[i]. In addition, if the parameter setting P[i] that had just been tested has better performance than previous settings, the value for the loop counter i can be stored in the variable iBest. Also, the loop counter i can be incremented as indicated by the statement i++ for processing with the next parameter setting P[i].
If the last parameter setting P[N] has been tested or if the vertical data eye opening is sufficiently high, the process proceeds from the state 604 to a state 606. For example, the magnitude of the vertical data eye opening can be compared to a predetermined amount that is associated with a particular BER that is appropriate for the application. By exiting from the state 604 early, the process can select a setting that has good enough performance in a relatively fast manner. In an alternative embodiment, the extra step of checking whether the vertical data eye opening is sufficiently high can be skipped, and the process can check all the parameter settings in a brute force manner and later select a phase detector offset or phase detector gain that has exhibits sufficiently good performance. In addition, if the parameter setting P[i] that had just been tested has better performance than previous settings, the value for the loop counter i can be stored in the variable iBest.
In the state 606, the process applies the parameter P[iBest], which was determined via testing on the iPath CDR circuit 506, to the main CDR circuit 504. In one embodiment, the control logic 508 takes care to apply the new setting smoothly, such as gradually or incrementally from the previous parameter setting to the new parameter setting so as not to disturb the recovered data stream. The process then advances from the state 606 to a state 608.
In the state 608, the process determines the main path's vertical data eye characteristics, which should be similar to the iPath's vertical data eye characteristics to determine whether further processing is warranted. For example, additional parameters can be adjusted. When the iPath CDR circuit 506 is not being used, it can be disabled via control of the enable input (EN) to save power.
The process can be repeated as desired. Either the main path or the iPath can be used to monitor the performance of the main path (assuming the same settings are applied) and based on the performance, such as if the performance falls below a threshold amount, the process can be re-executed for updating of the parameters.
The cursor position for the FFE/DFE filter and values for the sampler thresholds of the ADCs can also be adaptively adjusted using the described process or an alternative adaptive adjustment process, such as a conventional process.
Both the main CDR circuit 504 and the iPath CDR circuit 506 receive the same analog data stream as inputs. The control logic 508 experiments with different settings for the phase detector offset or the phase detector gain of the iPath CDR circuit 506. In the illustrated embodiment, the vertical data eye opening is determined to assess the performance of a particular setting. Other techniques can be used, such as analysis of a bit error rate, can alternatively be used. By using an analysis technique such as a vertical eye opening or a bit error rate, the constraint of selecting a cursor based on pre-cursor and post-cursor levels being the same is removed and the performance of the main CDR circuit 504 can be improved, particularly when the slope of the impulse response is not symmetric or when the gain of the impulse response is less than ideal.
Advantageously, by experimenting with the settings in a replica path, that is, the iPath CDR circuit 506, the process of receiving data through the main CDR circuit 504 is unaffected. After relatively good performing settings are found for the phase detector offset and/or gain using the iPath CDR circuit 506, these settings can be applied to the main CDR circuit 504.
The replica path described in the foregoing is created in “space,” that is, there are actually two CDR paths. In an alternative embodiment, the main path is multiplexed in “time,” that is, the main path itself is used at certain times to run the experiments. Of course, when it is being used for experiments, the data output could become corrupted, so multiplexing in time may only be practical at power-up or other times when the main path output is not needed.
In an alternative embodiment, a multiplexer circuit (not shown) can be used to select a hard symbol output of either the first clock and data recover circuit 504 or the second clock and data recovery circuit 506 for provision of the digital output to circuits that use the data as opposed to the control logic 508. Similarly, another multiplexer can also be used at the input of the control logic to select the other of the first CDR circuit 504 or the second CDR circuit 506 during adaptation. The multiplexer can be implemented by, for example, three-state gates. In this manner, either CDR circuit can be used for data or for adaptation.
The foregoing description and claims may refer to elements or features as being “connected” or “coupled” together. As used herein, unless expressly stated to the contrary, “connected” means that one element/feature is directly or indirectly connected to another element/feature, and not necessarily mechanically. Likewise, unless expressly stated to the contrary, “coupled” means that one element/feature is directly or indirectly coupled to another element/feature, and not necessarily mechanically. Thus, although the drawings illustrate various examples of arrangements of elements and components, additional intervening elements, devices, features, or components may be present in an actual embodiment.
As used herein, a “node” refers to any internal or external reference point, connection point, junction, signal line, conductive element, or the like at which a given signal, logic level, voltage, data pattern, current, or quantity is present.
Various embodiments have been described above. Although described with reference to these specific embodiments, the descriptions are intended to be illustrative and are not intended to be limiting. Various modifications and applications may occur to those skilled in the art.
This application claims the benefit under 35 U.S.C. §119(e) of U.S. Provisional Application No. 61/507,428, filed Jul. 13, 2011, the entirety of which is hereby incorporated by reference. This application is related to commonly-owned copending application titled “Parallel Replica CDR to Reduce or Minimize ADC and DSP Complexity,” having Ser. No. 13/549,104 filed on the same date as the present application; to U.S. Provisional Application No. 61/507,435 filed Jul. 13, 2011; to commonly-owned copending application titled Gain Calibration for a Mueller-Muller Type Timing Error Detector, Ser. No. 13/549,030, filed on the same date as the present application; and to U.S. Provisional Application No. 61/509,914, filed on Jul. 20, 2011, titled Gain Calibration for a Mueller-Muller Type Timing Error Detector, the disclosures of each of which are hereby incorporated by reference in its entirety herein.
Number | Name | Date | Kind |
---|---|---|---|
5585975 | Bliss | Dec 1996 | A |
6618436 | Greiss et al. | Sep 2003 | B2 |
7292662 | Gregorius | Nov 2007 | B2 |
7489749 | Liu | Feb 2009 | B2 |
7564866 | Agazzi et al. | Jul 2009 | B2 |
7646807 | Manickam et al. | Jan 2010 | B1 |
7873073 | Frlan et al. | Jan 2011 | B2 |
8559582 | Hoang | Oct 2013 | B2 |
20040223568 | Liu | Nov 2004 | A1 |
20050185742 | Liu | Aug 2005 | A1 |
20070065157 | Katagiri et al. | Mar 2007 | A1 |
20080137790 | Cranford et al. | Jun 2008 | A1 |
20080219390 | Simpson et al. | Sep 2008 | A1 |
20090080584 | Hamano et al. | Mar 2009 | A1 |
20090135894 | Huang | May 2009 | A1 |
20090304064 | Liu et al. | Dec 2009 | A1 |
20100080282 | Zhong et al. | Apr 2010 | A1 |
20100103003 | Deval et al. | Apr 2010 | A1 |
20100135676 | Katagiri | Jun 2010 | A1 |
20100241918 | Nedovic | Sep 2010 | A1 |
20100289544 | Lee et al. | Nov 2010 | A1 |
20120063556 | Hoang | Mar 2012 | A1 |
20120163815 | Mori et al. | Jun 2012 | A1 |
20120314825 | Dillinger | Dec 2012 | A1 |
20130148712 | Malipatil et al. | Jun 2013 | A1 |
Entry |
---|
Mueller, et al.; Timing Recovery in Digital Synchronous Data Receivers; IEEE Transactions on Communications; May 1976; pp. 516-531; vol. COM-24, No. 5. |
USPTO; Office Action dated Aug. 29, 2013, from related U.S. Appl. No. 13/549,104, filed Jul. 13, 2012. |
USPTO; Office Action dated Jan. 6, 2014, from related U.S. Appl. No. 13/549,104, filed Jul. 13, 2012. |
USPTO; Office Action dated Aug. 1, 2013, from related U.S. Appl. No. 13/549,030, filed Jul. 13, 2012. |
USPTO; Examiner's Answer dated Aug. 14, 2014, from related U.S. Appl. No. 13/549,104, filed Jul. 13, 2012. |
Number | Date | Country | |
---|---|---|---|
61507428 | Jul 2011 | US |