The invention is directed, in general, to a serializer-deserializer (SerDes) and, more specifically, to a SerDes having a predominantly digital architecture and a method of deserializing data.
As technology continues to advance at an unprecedented rate, the transfer of information (“data”) has remained a high priority. In addition, as processing speeds continue to increase, the speed at which information is transferred remains key in increasing overall system speed. Traditionally, parallel busses or cables have been coupled between multiple devices to transfer information during a processing function. However, problems that may degrade the data transferred, such as signal loss when transmitted over long distances, have led to improvements in the manner in which such data is transferred. In addition, the multitude of wires or cables necessary for parallel connection may become cumbersome, especially in larger systems. In the past, however, alternatives to parallel connections often led to information bottlenecks, leaving parallel lines as the only viable choice.
As the need for bandwidth expands in the various networks now existing, or even those later developed, serial busses have become the ideal alternative for solving these problems. Typically, serial busses employ a serializer at a transmitting end to convert and transmit data in serial order and a deserializer at a receiving end to convert the data back to parallel form once received. Such serializer/deserializer (“SerDes”) receivers have become the benchmark for asynchronous communication and have provided clear advantages over parallel busses. For example, SerDes receivers include transmitters and receivers, and use simplified wiring harnesses (often only a single wire per channel) that typically consume less power than their parallel-coupled counterparts. Higher performance may also be achieved because SerDes receivers reduce the crosstalk that often occurs between parallel wires. In addition, SerDes receivers may be employed to transmit data over long distances without the signal degradation experienced with parallel busses ultimately offering increased reliability and fidelity over parallel busses.
Although a tremendous improvement over parallel busses, serial connections employing SerDes receivers are not without problems. Since a separate clock signal for component and signal synchronizing is not used (typical of asynchronous communication), the receiving and transmitting ends of a SerDes are synchronized by monitoring the transmitted data. Within a conventional serial bus, each line of communication includes a separate SerDes transceiver, each having a SerDes receiver and transmitter, for serializing and deserializing each frame of data. As a result, each SerDes receiver includes its own phase-locked loop (PLL) circuit, each typically employing a voltage controlled oscillator (VCO) to generate the clock at the receiving end of the data transmission and to synchronize the clock with the timing of the data signal at the transmitting end. Without this synchronization, the data transmitted would likely be corrupted or lost.
To address the above-discussed deficiencies of the prior art, one aspect of the invention provides a SerDes. In one embodiment, the SerDes includes: (1) an analog-to-digital converter (ADC) configured to receive a serial data stream and provide a digital output based thereon, (2) a digital comparator coupled to the ADC and configured to compare the digital output to an output table to yield candidate output bits, (3) a digital feedback equalizer (DFE) coupled to the digital comparator and configured to generate the output table based on the candidate output bits and (4) a multiplexer coupled to the digital comparator and configured to select output bits from among the candidate output bits to form a discrete bit sequence.
In another embodiment, the SerDes includes: (1) an ADC configured to receive a serial data stream and provide a digital output based thereon and including: (1a) an analog comparator matrix configured to compare a voltage of the serial data stream to various analog reference voltages, (1b) a deserializer coupled to the analog comparator matrix and configured to deserialize an output thereof and (1c) a compactor coupled to the deserializer and configured to compact an output thereof, (2) a digital comparator pipelined with the ADC and configured to compare the digital output to an output table to yield candidate output bits, (3) a DFE coupled to the digital comparator and configured to generate the output table based on the candidate output bits and (4) a multiplexer pipelined with the digital comparator and configured to select output bits from among the candidate output bits to form a discrete bit sequence.
Another aspect of the invention provides a method of deserializing data. In one embodiment, the method includes: (1) providing a digital output based on a received serial data stream, (2) employing a digital comparator to compare the digital output to an output table to yield candidate output bits, (3) employing a DFE to generate the output table based on the candidate output bits and (4) selecting output bits from among the candidate output bits to form a discrete bit sequence.
The foregoing has outlined certain aspects and embodiments of the invention so that those skilled in the pertinent art may better understand the detailed description of the invention that follows. Additional aspects and embodiments will be described hereinafter that form the subject of the claims of the invention. Those skilled in the pertinent art should appreciate that they can readily use the disclosed aspects and embodiments as a basis for designing or modifying other structures for carrying out the same purposes of the invention. Those skilled in the pertinent art should also realize that such equivalent constructions do not depart from the scope of the invention.
For a more complete understanding of the invention, reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
Describe herein are various embodiments of a novel architecture for a SerDes, i.e., a circuit that transforms serial continuous data stream to a sequence of discrete bits. The novel architecture is mostly digital. The SerDes is formed of stages that operate sequentially, one after another.
The SerDes 100 receives a serial data stream 110 into an analog-to-digital converter (ADC) 120. For purposes of this description, the salient parameters of the ADC 120 are is output number width, D, its interleaving width, M1, and its deserialization width, M2. M=M1·M2. INPt is the instantaneous value of the serial data stream 110 taken at a time t. The period of INPt is τ. The maximum voltage of INPt is Vmax, and the minimum voltage is 0.
The ADC 120 includes an analog comparator matrix 130. The analog comparator matrix 130 is configured to compare the voltage of the serial data stream 110 to various analog reference voltages. If the output of the analog comparator matrix 130 is clocked with a period M1·τ, the output of the analog comparator matrix 130 at the tth clock is:
ACMPt(i,j), i=0, . . . , 2D−2, j=0, . . . , M1−1,
and
The output of the analog comparator matrix 130 is provided on a plurality of lines (defined as two or more but three being shown in
DSERt(i,j)=ACMPt·M
The output of the deserializer 140 is provided on a plurality of lines to a compactor 150. The compactor 150 is configured to compact the output of the deserializer 140. The output of the compactor 150 is the ADC 120 output. In one embodiment, the same clock drives both the compactor 150 and the deserializer 140. If T=M·τ=M1·M2·τ, the output at the tth clock is a vector of D-bit numbers:
The output of the compactor 150 is the output of the ADC 120. The output of the ADC 120 is provided on a plurality of lines to a digital comparator 160. The digital comparator 160 is configured to compare the output of the ADC 120 to an output table to yield candidate output bits. In one embodiment, the same clock drives the digital comparator 160, the compactor 150 and the deserializer 140. For purposes of this description, the salient parameters of the digital comparator 160 are its output number width, D, and its number of taps, K. Again, M=M1·M2. K is assumed to be less than or equal to M.
A digital feedback equalizer (DFE) 170 provides the reference digital values to the digital comparator 160. The digital comparator 160 provides the candidate output bits as an input A to the DFE 170:
OUTt(j), j=0, 1, . . . , M−1.
In one embodiment, the same clock drives the DFE 170, the digital comparator 160, the compactor 150 and the deserializer 140. The DFE 170 has an internal register that is R[M−1:0] bits wide and corresponding output lines W[M−1:0] leading to the digital comparator 160. The current register value Rt is therefore the output of the DFE 170 at the tth clock.
In the illustrated embodiment, the DFE 170 is configured to carry out the following functions:
R0=0,
Wt+1[j]=MUXK(St+1(j),At+1(j)), and
Rt+1=W,
where
At+1(j)=(DCt(2K−1,j), . . . , DCt(1,j), DCt(0,j)), and
As
EQT(i), i=0, 1, . . . , 2K−1.
In response, the outputs of the digital comparator 160 are:
DCt(i,j)=(ADCt(j)>EQT(i)), i=0, . . . , 2K−1, j=0, . . . , M−1.
The digital comparator 160 also provides the candidate output bits to a multiplexer 180. The multiplexer 180 is configured to select output bits from among the candidate output bits. The output bits form a discrete bit sequence 190 that constitutes the output of the SerDes 100. In one embodiment, the same clock drives the multiplexer 180, the DFE 170, the digital comparator 160, the compactor 150 and the deserializer 140. In one embodiment, the multiplexer 180 is configured to carry out a function MUXP(S[P−1:0],A└2P−1:0┘) as follows:
MUX1(S[0:0]A[1:0])=S[0]−A[1]:A[0], and
MUXp+1(S[p:0],A[2p+1−1:0])=S[p]−U1:U0,
where
U1=MUXp(S[p−1:0],A└2p+1−1:2p┘), and
U0=MUXp(S[p−1:0],A[2p−1:0]).
The circuit MUXP depth from port Si to output is (P−i). In the illustrated embodiment, this depth is important for timing.
All stages in the SerDes 100 except the DFE 170 may be pipelined. In the illustrated embodiment, M1 is selected such a way that the deserializer 140 does not have timing problems. In one embodiment, deserialization is skipped (M2=1) The DFE 170 contains a loop and so should be timed appropriately to avoid problems.
The depth of the path from Rt[M−1−i] to Rt+1[j] has a length (j+i+1) of cells in the multiplexer 180. The depth from Rt[M−K+r] to Rt+1[j] is:
j+((M−1)−(M−K+r))+1=j+K−r.
Assuming the clock for the Rt[M−K+r]th bit occurs later than the clock for R[0:M−K]th bit on r·ε, that μ represents the delay of the multiplexer 180 and that φs and φd are the setup and the delay for a flip-flop in the DFE 170, the arrival time from Rt[M−K+r] to R[j] is:
r·ε+φd+(j+K−r)·μ.
The expected time for R[j] is:
Let j=(M−K)+J, where −(M−K)≦J≦K−1. The arrival time may then be rewritten as follows:
r·ε+φd+(j+M−r)·μ.
The expected time for R[j] may likewise be rewritten:
The following system of timing restrictions results:
If φ==φd+φs, the following system of timing restrictions results:
If these timing restrictions are true for J=0, they are also true for J<0. Because the first and second equations of the timing restrictions are the same for J=0, only the second line of the system needs to be considered. Accordingly:
r·ε+φ+(J+M−r)·μ−J·ε≦M·τ, r=0, 1, . . . , K−1, J=0, 1, . . . , K−1, and:
(J−r)·(μ−ε)+φ+M+μ≦M·τ, r=0, 1, . . . , K−1, J=0, 1, . . . , K−1.
This system is equivalent to one equation:
(K−1)·|μ−ε|+φ+M·μ≦M·τ.
If ε=μ, the following results:
φ+M·μ≦M·τ.
Alternatively:
Those skilled in the art to which the invention relates will appreciate that other and further additions, deletions, substitutions and modifications may be made to the described embodiments without departing from the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
6031473 | Kubinec | Feb 2000 | A |
6341142 | Ducaroir et al. | Jan 2002 | B2 |
6525571 | Green | Feb 2003 | B2 |
7064690 | Fowler et al. | Jun 2006 | B2 |
7362797 | Chan et al. | Apr 2008 | B2 |
7486721 | Chan et al. | Feb 2009 | B2 |