US7599457B2 - Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits - Google Patents

Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits Download PDF

Info

Publication number
US7599457B2
US7599457B2 US11/199,287 US19928705A US7599457B2 US 7599457 B2 US7599457 B2 US 7599457B2 US 19928705 A US19928705 A US 19928705A US 7599457 B2 US7599457 B2 US 7599457B2
Authority
US
United States
Prior art keywords
clock
data
phase
signal
offset
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US11/199,287
Other versions
US20070030936A1 (en
Inventor
Phillip Johnson
Zheng Chen
Barry Britton
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Lattice Semiconductor Corp
Original Assignee
Lattice Semiconductor Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Lattice Semiconductor Corp filed Critical Lattice Semiconductor Corp
Priority to US11/199,287 priority Critical patent/US7599457B2/en
Assigned to LATTICE SEMICONDUCTOR CORPORATION reassignment LATTICE SEMICONDUCTOR CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BRITTON, BARRY, CHEN, ZHENG, JOHNSON, PHILLIP
Priority to PCT/US2006/030501 priority patent/WO2007019339A2/en
Publication of US20070030936A1 publication Critical patent/US20070030936A1/en
Application granted granted Critical
Publication of US7599457B2 publication Critical patent/US7599457B2/en
Assigned to JEFFERIES FINANCE LLC reassignment JEFFERIES FINANCE LLC SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DVDO, INC., LATTICE SEMICONDUCTOR CORPORATION, SIBEAM, INC., SILICON IMAGE, INC.
Assigned to LATTICE SEMICONDUCTOR CORPORATION, SILICON IMAGE, INC., DVDO, INC., SIBEAM, INC. reassignment LATTICE SEMICONDUCTOR CORPORATION RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: JEFFERIES FINANCE LLC
Assigned to WELLS FARGO BANK, NATIONAL ASSOCIATION, AS ADMINISTRATIVE AGENT reassignment WELLS FARGO BANK, NATIONAL ASSOCIATION, AS ADMINISTRATIVE AGENT SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: LATTICE SEMICONDUCTOR CORPORATION
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L7/00Arrangements for synchronising receiver with transmitter
    • H04L7/02Speed or phase control by the received code signals, the signals containing no special synchronisation information
    • H04L7/033Speed or phase control by the received code signals, the signals containing no special synchronisation information using the transitions of the received signal to control the phase of the synchronising-signal-generating means, e.g. using a phase-locked loop
    • H04L7/0337Selecting between two or more discretely delayed clocks or selecting between two or more discretely delayed received code signals
    • H04L7/0338Selecting between two or more discretely delayed clocks or selecting between two or more discretely delayed received code signals the correction of the phase error being performed by a feed forward loop
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03LAUTOMATIC CONTROL, STARTING, SYNCHRONISATION, OR STABILISATION OF GENERATORS OF ELECTRONIC OSCILLATIONS OR PULSES
    • H03L7/00Automatic control of frequency or phase; Synchronisation
    • H03L7/06Automatic control of frequency or phase; Synchronisation using a reference signal applied to a frequency- or phase-locked loop
    • H03L7/08Details of the phase-locked loop
    • H03L7/081Details of the phase-locked loop provided with an additional controlled phase shifter
    • H03L7/0812Details of the phase-locked loop provided with an additional controlled phase shifter and where no voltage or current controlled oscillator is used
    • H03L7/0816Details of the phase-locked loop provided with an additional controlled phase shifter and where no voltage or current controlled oscillator is used the controlled phase shifter and the frequency- or phase-detection arrangement being connected to a common input

Definitions

  • the present invention relates to electronics, and, in particular, to clock-and-data-recovery circuits.
  • a receiver can perform clock-and-data-recovery (CDR) processing to recover a clock signal from each data stream, where the clock signal is derived based on the timing of the data represented in the data stream.
  • CDR clock-and-data-recovery
  • a typical CDR circuit comprises a sampling clock generator, such as a phase-locked loop (PLL) or a delay-locked loop (DLL), that generates one or more sampling clocks used to sample the received data stream.
  • PLL phase-locked loop
  • DLL delay-locked loop
  • a single receiver may receive multiple, different data streams, potentially having different data rates. Such a receiver will typically have a different CDR circuit for each different data stream. Implementing multiple CDR circuits, each with its own sampling clock generator can require too much layout area and/or operating power for some integrated circuit applications.
  • the present invention is a clock-and-data recovery system, comprising a clock generator and one or more channel circuits.
  • the clock generator generates a plurality of phase-offset clock signals
  • each channel circuit generates an output data stream and a recovered clock signal based on an input data signal.
  • Each channel circuit comprises a data for each phase-offset clock signal, a logic circuit, and a data sampler.
  • Each data register generates an output signal based on the level of the corresponding phase-offset clock signal at a transition in the input data signal.
  • the logic circuit processes the output signals from the data registers to select one of the phase-offset clock signals as a sampling clock signal, and the data sampler samples the input data signal based on the sampling clock signal to generate the output data stream and generates the recovered clock signal based on the sampling clock signal.
  • the present invention is a clock-and-data recovery system, comprising a clock generator and two or more channel circuits coupled to the clock generator.
  • the clock generator generates a plurality of phase-offset clock signals.
  • Each channel circuit generates an output data stream and a recovered clock signal based on an input data signal and the plurality of phase-offset clock signals.
  • FIG. 1 is a block diagram of a clock-and-data-recovery system, according to one embodiment of the present invention
  • FIG. 2 is a more-detailed block diagram of one possible implementation of the CDR system of FIG. 1 ;
  • FIG. 3 shows an exemplary timing diagram illustrating the relationship between the input data signal and the sixteen clock signals of FIG. 2 .
  • FIG. 1 is a block diagram of a clock-and-data-recovery system 100 , according to one embodiment of the present invention.
  • CDR system 100 has a multi-phase clock generator 102 and N CDR channel circuits 104 , where N ⁇ 1.
  • Clock generator 102 generates a multi-phase set of clock signals 106 (i.e., multiple versions of a clock signal sequentially separated from each other in phase over one clock period by a specified phase-offset increment). For example, in one implementation, clock generator 102 generates 16 clock signals, each having the same frequency, but separated in phase from the previous clock signal by about 22.5 degrees. Clock signals 106 are all applied to each CDR channel circuit 104 , which uses the set of clock signals to generate a (different) recovered clock signal 110 and a (different) output data stream 112 from a corresponding (different) input data signal 108 , potentially having different data rates.
  • FIG. 2 is a more-detailed block diagram of one possible implementation of CDR system 100 of FIG. 1 .
  • FIG. 2 shows only one CDR channel circuit 104 , the implementation may include other, similar CDR channel circuits.
  • multi-phase clock generator 102 is a delay-locked loop (DLL) that is capable of selectively generating either 16 clock signals (separated by phase-offset increments of about 22.5 degree) or 8 clock signals (separated by phase-offset increments of about 45 degrees).
  • a received reference clock (REFCLK) is applied to the first delay element in delay chain 204 , where each delay element in the chain delays the reference clock by an incremental amount of time, which corresponds to a reasonably predictable amount of phase for a given clock rate.
  • Each clock signal 106 corresponds to the output of (a different) one of the delay elements in delay chain 204 , as selected using a corresponding multiplexer (not shown) in delay chain 204 .
  • the number of delay elements in delay chain 204 and the number of clock signals output from delay chain 204 are metal mask programmable.
  • delay chain 204 receives, from PD/ALU 202 , 16 DelNumber values, each of which dictates the number of delay elements in delay chain 204 between a different pair of successive clock signals 106 .
  • reference clock REFCLK has a period of 100 nsec
  • each delay element in delay chain 204 delays the reference clock by 1 nsec (i.e., corresponding to a phase shift of about 3.6 degrees)
  • clock generator 102 is configured to generate 16 clock signals.
  • the sixteen clock signal 106 would be selected to be the output from the 100 th (i.e., 6+6+7+6+6+6+7+6+6+6+7+6+6+6+7+6+6+7+6) delay element in delay chain 204 , where that sixteenth clock signal corresponds to reference clock REFCLK delayed by 100 nsec (i.e., one complete 360-degree clock cycle of REFCLK).
  • the 8 clock signals 106 could be generated using (12, 13, 12, 13, 12, 13, 12, 13) as the 8 DelNumber values, where the eighth clock signal would correspond to reference clock REFCLK delayed by one complete clock cycle.
  • the values used in these examples are for purposes of explanation only; actual values may be larger or smaller.
  • the last selected clock (i.e., either the sixteenth clock signal or the eighth clock signal, depending on whether clock generator 102 is configured to generate 16 or 8 clock signals) is fed back from delay chain 204 as feedback clock signal DelClk to PD/ALU 202 , which also receives reference clock REFCLK.
  • PD/ALU 202 generates the phase difference between REFCLK and DelClk and uses that phase difference to adjust the DelNumber values as necessary to ensure that those two clock signals are as close to being in phase (i.e., separated by one complete clock cycle of REFCLK) as possible.
  • PD/ALU 202 sets the 1-bit status signal MASTER LOCK to a value (e.g., 1) that indicates that clock signals 106 are valid.
  • CDR channel circuit 104 receives input data signal 108 and (up to) 16 clock signals 106 , referred to as CLK 0 -CLK 15 .
  • CDR channel circuit 104 has 16 data registers 206 (e.g., flip-flops, although other types of data registers are possible) arranged in two banks 208 and 210 , where input data signal 108 is applied to the clock input of each flip-flop.
  • each of the first eight clock signals CLK 0 -CLK 7 is applied to the data input of a different flip-flop.
  • bank 210 also has a (2 ⁇ 1) multiplexer (mux) 212 for each flip-flop, where one of the second eight clock signals CLK 8 -CLK 15 is applied to the “0” input of each mux 212 and a corresponding one of the first eight clock signals CLK 0 -CLK 7 is applied to the mux's “1” input.
  • the output of each mux 212 is applied to the data input of the corresponding flip-flop 206 , where the selection of which received clock signal to apply is dictated by control signal CLK_WIDTH.
  • both the first flip-flop (in bank 208 ) and the eighth flip-flop (in bank 210 ) receive clock signal CLK 0 , and analogously for clock signals CLK 1 -CLK 7 and the other seven pairs of flip-flops in banks 208 and 210 .
  • each flip-flop when CDR system 100 is configured in its 16-phase mode, a different one of the 16 clock signals CLK 0 -CLK 15 is applied to the data input of a different one of the 16 flip-flops 206 , while input data signal 108 is applied to the clock input of each flip-flop.
  • flip-flops 206 are triggered by rising edges (in alternative implementations, falling-edge-triggered flip-flops could be used)
  • input data signal 108 e.g., corresponding to a data transition from a “0” to a “1”
  • each flip-flop will (substantially) simultaneously present the current value of its received clock signal CLKi as its output value Qi.
  • clock signals CLK 0 -CLK 15 represent a sequence of increasingly phase-offset clock signals, eight consecutive clock signals 106 will be either high or low and the rest will be the opposite.
  • FIG. 3 shows an exemplary timing diagram illustrating the relationship between input data signal 108 and the sixteen clock signals CLK 0 -CLK 15 .
  • the portion of input data signal 108 shown in FIG. 3 corresponds to a bit sequence of (0 1 0 0 1) and has rising transitions at times t 1 and t 3 and a falling transition at time t 2 .
  • clocks CLK 0 -CLK 2 and CLK 11 -CLK 15 are high and eight consecutive clocks CLK 3 -CLK 10 are low.
  • clock selector logic 214 analyzes the 16 Qi values to select one of clock signals CLKi as selected clock 216 for input to processing block 218 .
  • clock selector logic 214 selects a clock 180 degrees away (e.g., CLK 11 ) for use as selected clock 216 . If the transition were a 0-to-1 transition, then clock selector logic 214 would select one of the clocks corresponding to the transition, rather than looking 180 degrees away.
  • processing block 218 receives input data signal 108 and control signal BIT_WIDTH.
  • processing block 218 samples input data signal 108 at every rising edge of selected clock 216 to generate sampled data.
  • processing block 218 is capable of outputting the sampled data as a serial or parallel data stream, where the parallelism of output data stream 112 is controlled by the value of control signal BIT_WIDTH, such that output data stream 112 can be up to 4 bits wide.
  • processing block 218 has a clock divider that divides selected clock 216 by the same value dictated by the BIT_WIDTH control signal to generate recovered clock signal 110 as a divided version of selected clock 216 .
  • downstream digital logic e.g., used to decode the output data
  • downstream digital logic is able to run at a lower frequency.
  • a first-in, first-out (FIFO) buffer can be used to re-time the data to make chip routing less of an issue.
  • CDR system 100 of FIG. 2 When CDR system 100 of FIG. 2 is configured in its 8-phase mode, only eight different clock signals CLK 0 -CLK 7 are generated by clock generator 102 and input to each CDR channel circuit 104 .
  • muxes 212 are controlled by CLK_WIDTH to select the “1” inputs for application to the data inputs of the flip-flops in bank 210 .
  • Q 0 and Q 8 provide substantially redundant information, which clock selector logic 214 can use to increase the reliability of its processing.
  • CDR channel circuit 104 can operate at a higher frequency than during the 16-phase mode.
  • the maximum frequency of the clock generator is a function of the number of phases and the intrinsic delay of each delay element. For example, if each delay element has a minimum delay of 1 ns, then the maximum frequency of clock generator 102 for the 16-phase mode would be 1/(16 ns) or about 62.5 MHz. For the 8-phase mode, however, the maximum frequency of the clock generator would be 1/(8 ns) or about 125 MHz.
  • the frequency of input data signal 108 is the same as the frequencies of clock signals CLK 0 -CLK 15 .
  • clock selector logic 214 may need to constantly change which clock signal is used for selected clock 216 .
  • clock selector logic 214 there are limits placed on which clock signals can be selected by clock selector logic 214 .
  • clock selector logic 214 can change the selected clock by at most one clock signal in either direction from the previously selected clock signal. If the desired change is greater than the specified limit, then the control loop is not correctly locked to the data, and lock signal LOCK is set low by clock selector logic 214 .
  • the present invention has been described in the context of a CDR system in which a multi-phase DLL is used to generate the phase-offset clock signals, in other embodiments, other types of multi-phase clock generators can be used, including multi-phase voltage-controlled oscillators (VCOs). Furthermore, although the present invention has been described in the context of a CDR system capable of generating either 8 or 16 different clock signals, other embodiments may generate other numbers of phase-offset clock signals, including only one number of clock signals or more than two different numbers of clock signals.
  • VCOs voltage-controlled oscillators
  • circuits including possible implementation as a single integrated circuit, a multi chip module, a single card, or a multi card circuit pack
  • present invention is not so limited.
  • various functions of circuit elements may also be implemented as processing blocks in a software program.
  • Such software may be employed in, for example, a digital signal processor, micro controller, or general purpose computer.
  • each numerical value and range should be interpreted as being approximate as if the word “about” or “approximately” preceded the value of the value or range.

Abstract

In one embodiment of the invention, a clock-and-data-recovery (CDR) system has a multi-phase clock generator that generates a plurality of phase-offset clock signals and one or more channel circuits, each receiving a (different) input data signal and all of the phase-offset clock signals and generates an output data stream and a recovered clock signal. Each channel circuit has a plurality of data registers (e.g., flip-flops), each receiving the input data signal at its clock input port and a different one of the phase-offset clock signals at its data input port, such that the flip-flop is triggered at each (rising) edge in the input data signal. The channel circuit processes the outputs from the different flip-flops to select an appropriate phase-offset clock signal for use in sampling the input data signal to generate the output data stream, where the recovered clock signal is generated from the selected phase-offset clock signal.

Description

TECHNICAL FIELD
The present invention relates to electronics, and, in particular, to clock-and-data-recovery circuits.
BACKGROUND
In non-clock-forwarded communications systems, data streams are transmitted to receivers without transmitting separate, distinct clock signals. In such systems, a receiver can perform clock-and-data-recovery (CDR) processing to recover a clock signal from each data stream, where the clock signal is derived based on the timing of the data represented in the data stream. A typical CDR circuit comprises a sampling clock generator, such as a phase-locked loop (PLL) or a delay-locked loop (DLL), that generates one or more sampling clocks used to sample the received data stream. In some communications systems, a single receiver may receive multiple, different data streams, potentially having different data rates. Such a receiver will typically have a different CDR circuit for each different data stream. Implementing multiple CDR circuits, each with its own sampling clock generator can require too much layout area and/or operating power for some integrated circuit applications.
SUMMARY
In one embodiment, the present invention is a clock-and-data recovery system, comprising a clock generator and one or more channel circuits. The clock generator generates a plurality of phase-offset clock signals, and each channel circuit generates an output data stream and a recovered clock signal based on an input data signal. Each channel circuit comprises a data for each phase-offset clock signal, a logic circuit, and a data sampler. Each data register generates an output signal based on the level of the corresponding phase-offset clock signal at a transition in the input data signal. The logic circuit processes the output signals from the data registers to select one of the phase-offset clock signals as a sampling clock signal, and the data sampler samples the input data signal based on the sampling clock signal to generate the output data stream and generates the recovered clock signal based on the sampling clock signal.
In another embodiment, the present invention is a clock-and-data recovery system, comprising a clock generator and two or more channel circuits coupled to the clock generator. The clock generator generates a plurality of phase-offset clock signals. Each channel circuit generates an output data stream and a recovered clock signal based on an input data signal and the plurality of phase-offset clock signals.
BRIEF DESCRIPTION OF THE DRAWINGS
Other aspects, features, and advantages of the present invention will become more fully apparent from the following detailed description, the appended claims, and the accompanying drawings in which like reference numerals identify similar or identical elements.
FIG. 1 is a block diagram of a clock-and-data-recovery system, according to one embodiment of the present invention;
FIG. 2 is a more-detailed block diagram of one possible implementation of the CDR system of FIG. 1; and
FIG. 3 shows an exemplary timing diagram illustrating the relationship between the input data signal and the sixteen clock signals of FIG. 2.
DETAILED DESCRIPTION
FIG. 1 is a block diagram of a clock-and-data-recovery system 100, according to one embodiment of the present invention. CDR system 100 has a multi-phase clock generator 102 and N CDR channel circuits 104, where N≧1.
Clock generator 102 generates a multi-phase set of clock signals 106 (i.e., multiple versions of a clock signal sequentially separated from each other in phase over one clock period by a specified phase-offset increment). For example, in one implementation, clock generator 102 generates 16 clock signals, each having the same frequency, but separated in phase from the previous clock signal by about 22.5 degrees. Clock signals 106 are all applied to each CDR channel circuit 104, which uses the set of clock signals to generate a (different) recovered clock signal 110 and a (different) output data stream 112 from a corresponding (different) input data signal 108, potentially having different data rates.
FIG. 2 is a more-detailed block diagram of one possible implementation of CDR system 100 of FIG. 1. Although FIG. 2 shows only one CDR channel circuit 104, the implementation may include other, similar CDR channel circuits.
In this particular implementation, multi-phase clock generator 102 is a delay-locked loop (DLL) that is capable of selectively generating either 16 clock signals (separated by phase-offset increments of about 22.5 degree) or 8 clock signals (separated by phase-offset increments of about 45 degrees). Clock generator 102 comprises a phase detector/arithmetic logic unit (PD/ALU) 202 and a delay chain 204 (i.e., a chain of series-connected delay elements (not shown)), where the value of 1-bit control signal CLK_WIDTH dictates whether clock generator 102 generates 16 clock signals (e.g., CLK_WIDTH=0) or 8 clock signals (e.g., CLK_WIDTH=1). A received reference clock (REFCLK) is applied to the first delay element in delay chain 204, where each delay element in the chain delays the reference clock by an incremental amount of time, which corresponds to a reasonably predictable amount of phase for a given clock rate. Each clock signal 106 corresponds to the output of (a different) one of the delay elements in delay chain 204, as selected using a corresponding multiplexer (not shown) in delay chain 204. In one embodiment, the number of delay elements in delay chain 204 and the number of clock signals output from delay chain 204 are metal mask programmable.
In addition to the reference clock, delay chain 204 receives, from PD/ ALU 202, 16 DelNumber values, each of which dictates the number of delay elements in delay chain 204 between a different pair of successive clock signals 106. Assume, for example, that reference clock REFCLK has a period of 100 nsec, that each delay element in delay chain 204 delays the reference clock by 1 nsec (i.e., corresponding to a phase shift of about 3.6 degrees), and that clock generator 102 is configured to generate 16 clock signals. In that case, the 16 DelNumber values may be (6, 6, 7, 6, 6, 6, 7, 6, 6, 6, 7, 6, 6, 6, 7, 6), where the first of the 16 clock signals 106 is selected to be the output from the 6th delay element in delay chain 204, where that first clock signal corresponds to reference clock REFCLK delayed by 6 nsec, where (6/100)*360 degrees=21.6 degrees (which is as close to the desired 22.5 degrees as can be achieved by delay chain 204). The second clock signal 106 would be selected to be the output from the 12th (i.e., 6+6) delay element in delay chain 204, where that second clock signal corresponds to reference clock REFCLK delayed by 12 nsec, where (12/100)*360 degrees=43.2 degrees (which is as close to the desired 45 degrees as can be achieved by delay chain 204). The third clock signal 106 would be selected to be the output from the 19th (i.e., 12+7) delay element in delay chain 204, where that third clock signal corresponds to reference clock REFCLK delayed by 19 nsec, where (19/100)*360 degrees=68.4 degrees (which is as close to the desired 67.5 degrees as can be achieved by delay chain 204). And so on, for the remaining 13 clock signals 106. Note that the sixteen clock signal 106 would be selected to be the output from the 100th (i.e., 6+6+7+6+6+6+7+6+6+6+7+6+6+6+7+6) delay element in delay chain 204, where that sixteenth clock signal corresponds to reference clock REFCLK delayed by 100 nsec (i.e., one complete 360-degree clock cycle of REFCLK). Note further that, when clock generator 102 is configured to generate 8, instead of 16, clock signals, the 8 clock signals 106 could be generated using (12, 13, 12, 13, 12, 13, 12, 13) as the 8 DelNumber values, where the eighth clock signal would correspond to reference clock REFCLK delayed by one complete clock cycle. The values used in these examples are for purposes of explanation only; actual values may be larger or smaller.
The last selected clock (i.e., either the sixteenth clock signal or the eighth clock signal, depending on whether clock generator 102 is configured to generate 16 or 8 clock signals) is fed back from delay chain 204 as feedback clock signal DelClk to PD/ALU 202, which also receives reference clock REFCLK. PD/ALU 202 generates the phase difference between REFCLK and DelClk and uses that phase difference to adjust the DelNumber values as necessary to ensure that those two clock signals are as close to being in phase (i.e., separated by one complete clock cycle of REFCLK) as possible. When those clock signals are in phase (e.g., to within a specified threshold), PD/ALU 202 sets the 1-bit status signal MASTER LOCK to a value (e.g., 1) that indicates that clock signals 106 are valid.
As shown in FIG. 2, CDR channel circuit 104 receives input data signal 108 and (up to) 16 clock signals 106, referred to as CLK0-CLK15. CDR channel circuit 104 has 16 data registers 206 (e.g., flip-flops, although other types of data registers are possible) arranged in two banks 208 and 210, where input data signal 108 is applied to the clock input of each flip-flop. In bank 208, each of the first eight clock signals CLK0-CLK7 is applied to the data input of a different flip-flop.
In addition to eight flip-flops, bank 210 also has a (2×1) multiplexer (mux) 212 for each flip-flop, where one of the second eight clock signals CLK8-CLK15 is applied to the “0” input of each mux 212 and a corresponding one of the first eight clock signals CLK0-CLK7 is applied to the mux's “1” input. The output of each mux 212 is applied to the data input of the corresponding flip-flop 206, where the selection of which received clock signal to apply is dictated by control signal CLK_WIDTH. In particular, if CLK_WIDTH=0, then CDR system 100 is configured in its 16-phase mode, and muxes 212 apply the second eight clock signals CLK8-CLK15 to flip-flops 206 of bank 210. If CLK_WIDTH=1, then CDR system 100 is configured in its 8-phase mode, and muxes 212 apply the first eight clock signals CLK0-CLK7 to flip-flops 206 of bank 210. Note that, in this latter configuration, both the first flip-flop (in bank 208) and the eighth flip-flop (in bank 210) receive clock signal CLK0, and analogously for clock signals CLK1-CLK7 and the other seven pairs of flip-flops in banks 208 and 210.
As just described, when CDR system 100 is configured in its 16-phase mode, a different one of the 16 clock signals CLK0-CLK15 is applied to the data input of a different one of the 16 flip-flops 206, while input data signal 108 is applied to the clock input of each flip-flop. Assuming, for example, that flip-flops 206 are triggered by rising edges (in alternative implementations, falling-edge-triggered flip-flops could be used), when a rising edge occurs in input data signal 108 (e.g., corresponding to a data transition from a “0” to a “1”), each flip-flop will (substantially) simultaneously present the current value of its received clock signal CLKi as its output value Qi.
In general, when reference clock REFCLK (and each clock signal 106) has a 50% duty cycle, at any given instant (other than those instants corresponding to clock transitions), the values of half of clock signals 106 will be high, and the values of the rest will be low. Moreover, since clock signals CLK0-CLK15 represent a sequence of increasingly phase-offset clock signals, eight consecutive clock signals 106 will be either high or low and the rest will be the opposite.
FIG. 3 shows an exemplary timing diagram illustrating the relationship between input data signal 108 and the sixteen clock signals CLK0-CLK15. The portion of input data signal 108 shown in FIG. 3 corresponds to a bit sequence of (0 1 0 0 1) and has rising transitions at times t1 and t3 and a falling transition at time t2. At time t1, for example, clocks CLK0-CLK2 and CLK11-CLK15 are high and eight consecutive clocks CLK3-CLK10 are low. Since the transition at time t1 is a rising edge, at time t1, all 16 flip-flops will be triggered, the values of flip-flop outputs Q0-Q2 and Q11-Q15 will be high, and the values of flip-flop outputs Q3-Q10 will be low. The same will be true at time t3. Note that, since the transition at time t2 is a falling transition, the rising-edge-triggered flip-flops will not be triggered, and the Q values will not be updated.
Referring again to FIG. 2, the sixteen flip-flop output values Q1-Q15 are applied to clock selector logic 214 along with the sixteen clock signals CLK0-CLK15. Clock selector logic 214 analyzes the 16 Qi values to select one of clock signals CLKi as selected clock 216 for input to processing block 218. In particular, clock selector logic 214 looks for transitions in the Q values received from the flip-flops and selects one of the clock signals CLKi based clock signals corresponding to that transition. For example, clock selector logic 214 could look for the first Q-value transition and then, depending on whether the transition was from Q=0 to Q=1 or from Q=1 to Q=0, select an appropriate clock signal. For example, in the example of FIG. 3, the first Q-value transition occurs between CLK2 to CLK3. Since that transition is a 1-to-0 transition, clock selector logic 214 selects a clock 180 degrees away (e.g., CLK11) for use as selected clock 216. If the transition were a 0-to-1 transition, then clock selector logic 214 would select one of the clocks corresponding to the transition, rather than looking 180 degrees away.
In addition to selected clock 216, processing block 218 receives input data signal 108 and control signal BIT_WIDTH. In one implementation, processing block 218 samples input data signal 108 at every rising edge of selected clock 216 to generate sampled data. In this particular embodiment, processing block 218 is capable of outputting the sampled data as a serial or parallel data stream, where the parallelism of output data stream 112 is controlled by the value of control signal BIT_WIDTH, such that output data stream 112 can be up to 4 bits wide. In addition, processing block 218 has a clock divider that divides selected clock 216 by the same value dictated by the BIT_WIDTH control signal to generate recovered clock signal 110 as a divided version of selected clock 216. By parallelizing the output data and dividing the selected clock signal, downstream digital logic (e.g., used to decode the output data) is able to run at a lower frequency. A first-in, first-out (FIFO) buffer can be used to re-time the data to make chip routing less of an issue.
When CDR system 100 of FIG. 2 is configured in its 8-phase mode, only eight different clock signals CLK0-CLK7 are generated by clock generator 102 and input to each CDR channel circuit 104. In this case, muxes 212 are controlled by CLK_WIDTH to select the “1” inputs for application to the data inputs of the flip-flops in bank 210. In that case, Q0 and Q8 provide substantially redundant information, which clock selector logic 214 can use to increase the reliability of its processing. In an alternative embodiment, muxes 212 are omitted and the flip-flop outputs Qi of bank 210 are ignored by clock selector logic 214 if CDR system 100 is configured in its 8-phase mode (i.e., CLK_WIDTH=1).
Since the 8-phase mode uses only eight muxes in delay chain 204, CDR channel circuit 104 can operate at a higher frequency than during the 16-phase mode. In general, when clock generator 102 is implemented as a DLL, as in FIG. 2, the maximum frequency of the clock generator is a function of the number of phases and the intrinsic delay of each delay element. For example, if each delay element has a minimum delay of 1 ns, then the maximum frequency of clock generator 102 for the 16-phase mode would be 1/(16 ns) or about 62.5 MHz. For the 8-phase mode, however, the maximum frequency of the clock generator would be 1/(8 ns) or about 125 MHz.
In the exemplary timing diagram of FIG. 3, the frequency of input data signal 108 is the same as the frequencies of clock signals CLK0-CLK15. In general, that need not be true. As a result, clock selector logic 214 may need to constantly change which clock signal is used for selected clock 216.
In some implementations, there are limits placed on which clock signals can be selected by clock selector logic 214. For example, in one possible implementation, at each cycle of the control loop, clock selector logic 214 can change the selected clock by at most one clock signal in either direction from the previously selected clock signal. If the desired change is greater than the specified limit, then the control loop is not correctly locked to the data, and lock signal LOCK is set low by clock selector logic 214.
Although the present invention has been described in the context of a CDR system in which a multi-phase DLL is used to generate the phase-offset clock signals, in other embodiments, other types of multi-phase clock generators can be used, including multi-phase voltage-controlled oscillators (VCOs). Furthermore, although the present invention has been described in the context of a CDR system capable of generating either 8 or 16 different clock signals, other embodiments may generate other numbers of phase-offset clock signals, including only one number of clock signals or more than two different numbers of clock signals.
While the exemplary embodiments of the present invention have been described with respect to processes of circuits, including possible implementation as a single integrated circuit, a multi chip module, a single card, or a multi card circuit pack, the present invention is not so limited. As would be apparent to one skilled in the art, various functions of circuit elements may also be implemented as processing blocks in a software program. Such software may be employed in, for example, a digital signal processor, micro controller, or general purpose computer.
Unless explicitly stated otherwise, each numerical value and range should be interpreted as being approximate as if the word “about” or “approximately” preceded the value of the value or range.
It will be further understood that various changes in the details, materials, and arrangements of the parts which have been described and illustrated in order to explain the nature of this invention may be made by those skilled in the art without departing from the scope of the invention as expressed in the following claims.

Claims (11)

1. A clock-and-data recovery (CDR) system, comprising:
a clock generator adapted to generate a plurality of phase-offset clock signals; and
one or more channel circuits, each channel circuit adapted to generate an output data stream and a recovered clock signal based on an input data signal, wherein each channel circuit comprises:
a data register for each phase-offset clock signal, the data register adapted to generate an output signal based on the level of the corresponding phase-offset clock signal at a transition in the input data signal;
a logic circuit adapted to process the output signals from the data registers to select one of the phase-offset clock signals as a sampling clock signal; and
a data sampler adapted to sample the input data signal based on the sampling clock signal to generate the output data stream and generate the recovered clock signal based on the sampling clock signal, wherein:
each channel circuit comprises first and second banks of data registers;
the CDR system is adapted to be selectively configured to operate in one of a first mode and a second mode;
in the first mode, the CDR system is selectively configured such that:
the clock generator generates a first set of phase-offset clock signals;
the first set of phase-offset clock signals is applied to both the first and second banks of data registers; and
the logic circuit selects a data register output signal corresponding to a phase-offset clock signal of the first set of phase-offset clock signals as the sampling clock signal; and
in the second mode, the CDR system is selectively configured such that:
the clock generator generates the first set of phase-offset clock signals and a second set of phase-offset clock signals;
the first set of phase-offset clock signals is applied to the first bank of data registers;
the second set of phase-offset clock signals is applied to the second bank of data registers; and
the logic circuit selects a data register output signal corresponding to a phase-offset clock signal of the first and second sets of phase-offset clock signals as the sampling clock signal.
2. The clock-and-data recovery system of claim 1, further comprising a clock divider adapted to divide the sampling clock signal by a specified divisor value to generate the recovered clock signal.
3. The clock-and-data recovery system of claim 2, wherein the data sampler is adapted to generate the output data stream as a parallelized data stream.
4. The clock-and-data recovery system of claim 1, wherein:
each data register is an edge-triggered flip-flop, having a data input port, a clock input port, and a data output port;
each flip-flop is connected to receive the corresponding phase-offset clock signal at its data input port and the input data signal at its clock input port; and
each flip-flop is adapted to present values of the phase-offset clock signal at its data output port at certain transitions in the input data signal.
5. The clock-and-data recovery system of claim 4, wherein the flip-flops are triggered by rising edges in the input data signal.
6. The clock-and-data recovery system of claim 1, wherein the clock generator is a delay-locked loop (DLL).
7. The clock-and-data recovery system of claim 6, wherein:
the DLL comprises a phase detector and a delay chain;
the plurality of phase-offset clock signals are output from different selected delay elements along the delay chain; and
the phase detector is adapted to control the selection of the different delay elements based on a phase difference between a received reference clock and one of the phase-offset clock signals.
8. The clock-and-data recovery system of claim 7, wherein the number of delay elements in the delay chain and the number of phase-offset clock signals output from the delay chain are metal mask programmable.
9. The invention of claim 1, wherein the CDR system further comprises a multiplexer for each data register in the second bank of data registers, wherein:
the multiplexer is connected to receive a phase-offset clock signal of the first set and a corresponding phase-offset clock signal of a second set; and
the multiplexer is adapted to provide one of the received phase-offset clock signals to the corresponding data register in the second bank of data registers depending on whether the CDR system is configured to operate in the first mode or the second mode.
10. The clock-and-data recovery system of claim 1, comprising two or more of the channel circuits.
11. The clock-and-data recovery system of claim 10, wherein the input data signals associated with at least two of the channel circuits have different data rates.
US11/199,287 2005-08-08 2005-08-08 Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits Active 2027-09-30 US7599457B2 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US11/199,287 US7599457B2 (en) 2005-08-08 2005-08-08 Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits
PCT/US2006/030501 WO2007019339A2 (en) 2005-08-08 2006-08-07 Clock-and-data-recovery system

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US11/199,287 US7599457B2 (en) 2005-08-08 2005-08-08 Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits

Publications (2)

Publication Number Publication Date
US20070030936A1 US20070030936A1 (en) 2007-02-08
US7599457B2 true US7599457B2 (en) 2009-10-06

Family

ID=37717592

Family Applications (1)

Application Number Title Priority Date Filing Date
US11/199,287 Active 2027-09-30 US7599457B2 (en) 2005-08-08 2005-08-08 Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits

Country Status (2)

Country Link
US (1) US7599457B2 (en)
WO (1) WO2007019339A2 (en)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090080584A1 (en) * 2007-09-21 2009-03-26 Hitachi, Ltd. Semiconductor system
US20100142967A1 (en) * 2008-12-10 2010-06-10 Ronald Edward Perez Reference Clock Rate Detection for Variable Rate Transceiver Modules
US8564330B1 (en) * 2012-06-05 2013-10-22 Xilinx, Inc. Methods and systems for high frequency clock distribution
US9191020B2 (en) 2014-02-05 2015-11-17 Waveworks, Inc. Traveling-wave based high-speed sampling systems
TWI559684B (en) * 2012-11-20 2016-11-21 輝達公司 A matrix phase detector
US10225068B2 (en) * 2016-10-28 2019-03-05 Fujitsu Limited Clock recovery circuit, semiconductor integrated circuit device and radio frequency tag

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8718087B1 (en) 2006-10-24 2014-05-06 Marvell International Ltd. Processing architecture for passive optical network
US8014481B1 (en) * 2006-11-13 2011-09-06 Marvell International Ltd. Upstream data recovery and data rate detection
US9178713B1 (en) 2006-11-28 2015-11-03 Marvell International Ltd. Optical line termination in a passive optical network
WO2008104958A2 (en) * 2007-03-01 2008-09-04 Nxp B.V. Data recovery system and method
US7586344B1 (en) 2007-10-16 2009-09-08 Lattice Semiconductor Corporation Dynamic delay or advance adjustment of oscillating signal phase
US8634503B2 (en) * 2011-03-31 2014-01-21 Avago Technologies General Ip (Singapore) Pte. Ltd. Fast lock clock-data recovery for phase steps
TWI637186B (en) * 2017-03-28 2018-10-01 奇景光電股份有限公司 Method and circuit for detecting abnormal clock
CN108037332B (en) * 2017-12-29 2023-11-07 陕西海泰电子有限责任公司 Multi-channel reference clock generation module
JP2022132859A (en) * 2021-03-01 2022-09-13 富士通株式会社 Optical transmission device and optical transmission system

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5920897A (en) * 1996-08-07 1999-07-06 Seeq Technology, Incorporated Apparatus and method for providing multiple channel clock-data alignment
US6215737B1 (en) * 1997-05-05 2001-04-10 Wea Manufacturing, Inc. Using different sampling rates to record multi-channel digital audio on a recording medium and playing back such digital audio
US6266799B1 (en) 1997-10-02 2001-07-24 Xaqti, Corporation Multi-phase data/clock recovery circuitry and methods for implementing same
US6292116B1 (en) * 1999-05-17 2001-09-18 Altera Corporation Techniques and circuitry for accurately sampling high frequency data signals input to an integrated circuit
US20020080899A1 (en) * 2000-11-10 2002-06-27 Fyvie Clifford D. Arrangement for capturing data
US20030188235A1 (en) * 2002-02-21 2003-10-02 Minoru Kozaki Multi-phase clock generation circuit and clock multiplication circuit
US20040017243A1 (en) * 2002-07-19 2004-01-29 Nec Corporation Multi-phase clock generation circuit
US6711716B1 (en) * 2002-09-26 2004-03-23 Agilent Technologies, Inc. Metal programmable clock distribution for integrated circuits
US6753712B2 (en) * 2002-05-17 2004-06-22 Nec Electronics Corporation Clock and data recovery circuit and clock control method thereof
US6856661B2 (en) 2001-03-08 2005-02-15 Texas Instruments Incorporated Using phase interpolator information to detect a loss of lock condition during recovery of a clock signal from a received data stream

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5920897A (en) * 1996-08-07 1999-07-06 Seeq Technology, Incorporated Apparatus and method for providing multiple channel clock-data alignment
US6215737B1 (en) * 1997-05-05 2001-04-10 Wea Manufacturing, Inc. Using different sampling rates to record multi-channel digital audio on a recording medium and playing back such digital audio
US6266799B1 (en) 1997-10-02 2001-07-24 Xaqti, Corporation Multi-phase data/clock recovery circuitry and methods for implementing same
US6292116B1 (en) * 1999-05-17 2001-09-18 Altera Corporation Techniques and circuitry for accurately sampling high frequency data signals input to an integrated circuit
US20020080899A1 (en) * 2000-11-10 2002-06-27 Fyvie Clifford D. Arrangement for capturing data
US6856661B2 (en) 2001-03-08 2005-02-15 Texas Instruments Incorporated Using phase interpolator information to detect a loss of lock condition during recovery of a clock signal from a received data stream
US20030188235A1 (en) * 2002-02-21 2003-10-02 Minoru Kozaki Multi-phase clock generation circuit and clock multiplication circuit
US6753712B2 (en) * 2002-05-17 2004-06-22 Nec Electronics Corporation Clock and data recovery circuit and clock control method thereof
US20040017243A1 (en) * 2002-07-19 2004-01-29 Nec Corporation Multi-phase clock generation circuit
US6711716B1 (en) * 2002-09-26 2004-03-23 Agilent Technologies, Inc. Metal programmable clock distribution for integrated circuits

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
"Data Recovery," by Nick Sawyer, Xilinx, XAPP224, v2.4, Jan. 24, 2005.

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090080584A1 (en) * 2007-09-21 2009-03-26 Hitachi, Ltd. Semiconductor system
US20100142967A1 (en) * 2008-12-10 2010-06-10 Ronald Edward Perez Reference Clock Rate Detection for Variable Rate Transceiver Modules
US8005370B2 (en) * 2008-12-10 2011-08-23 Applied Micro Circuits Corporation Reference clock rate detection for variable rate transceiver modules
US8564330B1 (en) * 2012-06-05 2013-10-22 Xilinx, Inc. Methods and systems for high frequency clock distribution
TWI559684B (en) * 2012-11-20 2016-11-21 輝達公司 A matrix phase detector
US9191020B2 (en) 2014-02-05 2015-11-17 Waveworks, Inc. Traveling-wave based high-speed sampling systems
US10225068B2 (en) * 2016-10-28 2019-03-05 Fujitsu Limited Clock recovery circuit, semiconductor integrated circuit device and radio frequency tag

Also Published As

Publication number Publication date
US20070030936A1 (en) 2007-02-08
WO2007019339A3 (en) 2008-01-03
WO2007019339A2 (en) 2007-02-15

Similar Documents

Publication Publication Date Title
US7599457B2 (en) Clock-and-data-recovery system having a multi-phase clock generator for one or more channel circuits
US7366267B1 (en) Clock data recovery with double edge clocking based phase detector and serializer/deserializer
US8559582B2 (en) Techniques for varying a periodic signal based on changes in a data rate
US7826583B2 (en) Clock data recovery apparatus
US8315349B2 (en) Bang-bang phase detector with sub-rate clock
US6937685B2 (en) Apparatus and method for counting high-speed early/late pulses from a high speed phase detector using a pulse accumulator
US8798223B2 (en) Clock and data recovery unit without an external reference clock
CN112042125A (en) Method and circuit for fine control of phase/frequency offset in phase locked loop
JP2005005999A (en) Clock and data recovery circuit
EP1746724A1 (en) Equiphase polyphase clock signal generator circuit and serial digital data receiver circuit using the same
JP2007215213A (en) System and method for multiple-phase clock generation
US8023605B2 (en) Oversampling circuit and oversampling method
JP2014222872A (en) System and method for tracking received data signal with clock data recovery circuit
US7157953B1 (en) Circuit for and method of employing a clock signal
US9438272B1 (en) Digital phase locked loop circuitry and methods
US6477657B1 (en) Circuit for I/O clock generation
US6933761B2 (en) Techniques for dynamically selecting phases of oscillator signals
US8355478B1 (en) Circuit for aligning clock to parallel data
CN111817712B (en) Phase-based frequency divider, phase-locked loop, chip, electronic device and clock generation method
JP2014225874A (en) System and method for obtaining reception data signal with clock data recovery circuit
JPH09149018A (en) Bit phase synchronization circuit
US7151810B2 (en) Data and clock synchronization in multi-channel communications
US8406258B1 (en) Apparatus and methods for low-jitter transceiver clocking
KR100189773B1 (en) Digital phase synchronous circuit

Legal Events

Date Code Title Description
AS Assignment

Owner name: LATTICE SEMICONDUCTOR CORPORATION, OREGON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:JOHNSON, PHILLIP;CHEN, ZHENG;BRITTON, BARRY;REEL/FRAME:016672/0735;SIGNING DATES FROM 20050722 TO 20050805

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
CC Certificate of correction
FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: JEFFERIES FINANCE LLC, NEW YORK

Free format text: SECURITY INTEREST;ASSIGNORS:LATTICE SEMICONDUCTOR CORPORATION;SIBEAM, INC.;SILICON IMAGE, INC.;AND OTHERS;REEL/FRAME:035223/0001

Effective date: 20150310

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: DVDO, INC., OREGON

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFERIES FINANCE LLC;REEL/FRAME:049827/0326

Effective date: 20190517

Owner name: SILICON IMAGE, INC., OREGON

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFERIES FINANCE LLC;REEL/FRAME:049827/0326

Effective date: 20190517

Owner name: LATTICE SEMICONDUCTOR CORPORATION, OREGON

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFERIES FINANCE LLC;REEL/FRAME:049827/0326

Effective date: 20190517

Owner name: SIBEAM, INC., OREGON

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFERIES FINANCE LLC;REEL/FRAME:049827/0326

Effective date: 20190517

Owner name: WELLS FARGO BANK, NATIONAL ASSOCIATION, AS ADMINIS

Free format text: SECURITY INTEREST;ASSIGNOR:LATTICE SEMICONDUCTOR CORPORATION;REEL/FRAME:049980/0786

Effective date: 20190517

Owner name: WELLS FARGO BANK, NATIONAL ASSOCIATION, AS ADMINISTRATIVE AGENT, COLORADO

Free format text: SECURITY INTEREST;ASSIGNOR:LATTICE SEMICONDUCTOR CORPORATION;REEL/FRAME:049980/0786

Effective date: 20190517

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12