SEMICONDUCTOR DEVICE
A semiconductor device includes a first sampling circuit for outputting a data value and an edge value corresponding to odd-numbered data of data contained in an input signal, using multiphase sampling clocks including a plurality of sampling clocks having different phases by 90 degrees; and a second sampling circuit for outputting a data value and an edge value corresponding to even-numbered data of data contained in the input signal, using the multiphase sampling clocks. One piece of data is sampled in one sampling period, and two sampling periods are included in one cycle of the sampling clock, the first sampling circuit and the second sampling circuit each including a first data sampling circuit which adds a negative offset to a signal level of the input signal, samples the input signal, and outputs a first data value.
The present application is a Continuation application of U.S. patent application Ser. No. 14/606,743, filed on Jan. 27, 2015, which is based on Japanese Patent Application No. 2014-022501 filed on Feb. 7, 2014, the entire contents of which are hereby incorporated by reference.
BACKGROUNDThe present invention relates to a semiconductor device, and more particularly, to a semiconductor device that extracts a clock signal and a data signal from a received high-speed serial signal.
In recent years, there has commonly been used serial communication with serial signals between electronic devices or between semiconductor devices. The serial communication is used in SATA (Serial ATA), USB (Universal Serial Bus), a wired LAN (Local Area Network), and the like. In the serial communication, the speed (frequency) of a transmission signal has recently been enhanced significantly, which disadvantageously causes a signal loss in a transmission line. For this reason, a reception circuit for serial communication receives a signal, using a correction circuit such as a decision feedback equalizer (DFE).
In the decision feedback equalizer, the stabilization result of a currently receiving data value needs to be fed back by the timing of determining the next value. That is, in the decision feedback equalizer, the time allowed for the process of feeding back the determination result is restricted within 1 UI (Unit Interval). For this reason, the decision feedback equalizer disadvantageously cannot deal with the enhanced speed of the transmission signal. Accordingly, to ease the restriction of the time required for feedback, a loop-unrolling-based decision feedback equalizer is proposed. The loop-unrolling equalizes an input signal speculatively without feeding back the first tap data value. Accordingly, by using the loop-unrolling-based decision feedback equalizer, it is possible to extend the time allowed for feedback to, e.g., 2 UI. Patent Document 1 and Non-patent Document 1 disclose examples of the loop-unrolling-based decision feedback equalizer.
The equalizer disclosed in Patent Document 1 includes first waveform equalization processing means and second waveform equalization processing means which alternately perform waveform equalization processing on a plurality of successively inputted signals. In the equalizer of Patent Document 1, the first waveform equalization processing means and the second waveform equalization processing means each add a value obtained by multiplying a value a indicating the determination result of the second last input signal and a value b indicating the determination result of the fourth last input signal by a constant w2 to the input signal subject to waveform equalization processing, thereby performing the waveform equalization processing. Further, Non-patent Document 1 discloses an example of performing equalization processing based on a value indicating the determination result of the second last or older input signal, as in Patent Document 1.
Patent Document 1
- Japanese Unexamined Patent Publication No. 2011-244284
- Brian S. Leibowitz' et al., A 7.5 Gb/s 10-Tap DFE Receiver with First Tap Partial Response, Spectrally Gated Adaptation, and 2nd-Order Data-Filtered CDR, ISSCC 2007
However, the use of the equalizer disclosed in Patent Document 1 or Non-patent Document 1 disadvantageously increases power consumption as to an edge sampling circuit for performing edge sampling.
The other problems and novel features will become apparent from the description of this specification and the accompanying drawings.
According to one embodiment, a semiconductor device has a first sampling circuit for outputting an odd-numbered data value and an edge value and a second sampling circuit for outputting an even-numbered data value and an edge value, and a first offset and a second offset used for determining the edge value in one sampling circuit are determined based on a data value acquired from a location other than between a selector for selecting one of a plurality of data values sampled with a different offset in a path for sampling the data value and a shift register for transferring the data value selected by the selector in the other sampling circuit.
Further, the replacement of the device according to the above embodiment with a method or a system, a program for causing a computer to execute processing of the device or part of the device, and the like are embraced as aspects of the invention.
According to the one embodiment, the semiconductor device can reduce the power consumption of a loop-unrolling decision feedback equalizer.
To clarify the description, appropriate omission and simplification are made in the following description and drawings. Hereinafter, embodiments will be described with reference to the drawings. First,
The semiconductor device 1 according to the first embodiment shown in
As shown in
The sampling circuit 10 extracts data values d0, d1 and edge values ea0, eb0, ea1, eb1 from the input signal Din in accordance with multiphase sampling clock signals CLK outputted from the phase shifter 50. In the semiconductor device 1 according to the first embodiment, four clock signals having different phases by 90 degrees are used as the multiphase sampling clocks. The sampling circuit 10 performs a sampling operation with 2 UI for one sampling clock. That is, the sampling circuit 10 outputs the odd-numbered data value d0 and the even-numbered data value d1 during one cycle of the sampling clock. Further, the sampling circuit 10 outputs the edge values ea0 and eb0 corresponding to the data value d0, and outputs the edge values ea1 and eb1 corresponding to the data value d1. In the description below, 1 UI is occasionally referred to as one sampling period.
The pattern filter 20 determines the validity or invalidity of the edge value, based on a temporal change of the data value. More specifically, based on the logic levels of data values outputted from the sampling circuit in successive sampling periods, the pattern filter 20 selects and outputs one of a first edge value and a second edge value included in the edge value, and outputs a flag value indicating the validity of the selected edge value. In the first embodiment, the pattern filter 20 determines the validity of the edge values ea0, eb0, ea1, eb1, based on the data values d0, d1 outputted from the sampling circuit 10, and outputs valid edge flags e0valid, e1valid and valid edge values e0, e1 along with the data values d0, d1, based on the determination result.
The phase detection circuit 30 determines the phase difference between one of the multiphase sampling clocks SMCLK and the input signal, based on the edge value determined to be valid by the pattern filter 20 and the data value. More specifically, the phase detection circuit 30 determines the advance or delay of a data phase, and outputs an up signal UP and a down signal DOWN, based on the determination result. The up signal UP is outputted if the phase of the multiphase sampling clock is delayed from that of the input signal. The down signal DOWN is outputted if the phase of the multiphase sampling clock is advanced from that of the input signal.
The phase control circuit 40 outputs a phase control signal PS for controlling the phase of the multiphase sampling clock SMCLK, in accordance with the determination result of the phase detection circuit 30. More specifically, the phase control circuit 40 filters phase information indicated by the up signal UP and the down signal DOWN, determines the phase of the multiphase sampling clock, and controls the phase shift unit 50.
The phase shift unit 50 generates multiphase clocks from a reference clock RCLK, and outputs the multiphase sampling clocks SMCLK selected from the multiphase clocks based on the phase control signal PS. The phase shift unit 50 shifts the phases of the multiphase sampling clocks SMCLK by changing and selecting clocks among the multiphase clocks generated from the reference clock outputted from the PLL circuit 60, and outputs the multiphase sampling clocks SMCLK for sampling data and edges. The PLL circuit 60 outputs the reference clock RCLK.
The semiconductor device 1 according to the first embodiment has the sampling circuit 10 as one of the features. Further, the pattern filter 20 according to the first embodiment has a feature for allowing the feature of the sampling circuit 10 to function effectively. Hereinafter, the sampling circuit 10 and the pattern filter 20 will be described in greater detail.
The sampling circuit 10 is comprised of a loop unrolling decision feedback equalizer (hereinafter simply referred to as a decision feedback equalizer). First, a problem caused in the decision feedback equalizer will be described in detail. In the decision feedback equalizer described below, by a half rate system, the data value and the edge value are sampled by the sampling clock of half the frequency of an input signal data rate.
The decision feedback equalizer 10a shown in
In the example shown in
Further, the mixer 101, the data sampler 102, and the D latch circuit 103 configure a first data sampling circuit of the first sampling circuit. The first data sampling circuit adds a negative offset to the signal level of the input signal Din, samples the input signal, and outputs a first data value. The mixer 104, the data sampler 105, and the D latch circuit 106 configure a second data sampling circuit of the first sampling circuit. The second data sampling circuit adds a positive offset to the signal level of the input signal Din, samples the input signal, and outputs a second data value. The mixer 140, the edge sampler 141, and the D latch circuits 142, 143 configure an edge sampling circuit of the first sampling circuit. The edge sampling circuit adds a first offset to the signal level of the input signal Din, and outputs a first edge value indicating the value of an edge part of the input signal Din.
The mixer 111, the data sampler 112, and the D latch circuit 113 configure a first data sampling circuit of the second sampling circuit. The first data sampling circuit adds a negative offset to the signal level of the input signal Din, samples the input signal, and outputs a first data value. The mixer 114, the data sampler 115, and the D latch circuit 116 configure a second data sampling circuit of the second sampling circuit. The second data sampling circuit adds a positive offset to the signal level of the input signal Din, samples the input signal, and outputs a second data value. The mixer 150, the edge sampler 151, and the D latch circuits 152, 153 configure an edge sampling circuit of the second sampling circuit. The edge sampling circuit adds a first offset to the signal level of the input signal Din, and outputs a first edge value indicating the value of an edge part of the input signal Din.
Further, as shown in
On the other hand, in the case of sampling the edge value based on the speculatively applied offset in the decision feedback equalizer 10a, there are needed an edge sampling circuit for sampling the edge value based on the positive offset and an edge sampling circuit for sampling the edge value based on the negative offset. The increased number of edge sampling circuits disadvantageously increases a circuit area and power consumption.
In the decision feedback equalizer 10a, the determined data values outputted from the selectors 107, 117 are fed back to the mixers 150, 140 through the buffers 118, 108. This reduces the number of edge sampling circuits in the decision feedback equalizer 10a, thereby reducing the circuit area and the power consumption.
That is, in the decision feedback equalizer 10b according to the first embodiment, the speculatively sampled data value is fed back to the edge sampling circuit. Such a configuration of the decision feedback equalizer 10b according to the first embodiment eases a timing restriction on a critical path formed as the feedback path for feeding back the data value to the edge sampling circuit. Hereinafter, a problem with this critical path will be described.
In the decision feedback equalizer 10a shown in
On the other hand, in the decision feedback equalizer 10b shown in
In
As shown in
Then, the data value outputted from the D latch circuit 103 is outputted from the selector 107. A delay time from when the D latch circuit 103 outputs the data value until when the selector 107 outputs the data value is Tpd(C). Then, the data value outputted from the selector 107 is transmitted to the mixer 150. A delay time until the mixer 150 causes the output to transition in accordance with the data value outputted from the selector 107 is Tpd(D).
In the edge sampling circuit, the edge sampler 151 samples the output value of the mixer 150 by the sampling clock SMCLK (270). Therefore, in the decision feedback equalizer 10a, a time Tsetup(E) obtained by subtracting the sum of the delay times Tpd(A), Tpd(B), Tpd(C), and Tpd(D) from a time Tm from the rising edge of the sampling clock SMCLK (0) to the rising edge of the sampling clock SMCLK (270) needs to be equal to or greater than the setup time of the edge sampler 151.
On the other hand, in the decision feedback equalizer 10b according to the first embodiment, the feedback path is formed without passing through the D latch circuit 103 and the selector 107, as shown in
As described above, in comparison with the decision feedback equalizer 10a, the decision feedback equalizer 10b according to the first embodiment can ease the timing restriction on the feedback path and reduce the power consumption of the decision feedback equalizer 10. However, in the decision feedback equalizer 10b, since the speculatively sampled data value is fed back to the edge sampling circuit, there might occur a problem with the validity of the output edge value. However, in the semiconductor device 1 according to the first embodiment, the problem with the validity of the edge value is solved by using the pattern filter 20 etc. Hereinafter, the details of the semiconductor device 1 according to the first embodiment including processing for determining the validity of the edge value will be described.
The decision feedback equalizer 10 shown in
In the example shown in
The mixer 100 provides the result of adding an offset w2 to the input signal Din to a first data sampling circuit, a second data sampling circuit, a first edge sampling circuit, and a second edge sampling circuit in the subsequent stages. The offset w2 is calculated from the second tap data value or an earlier one. As for the data value, a data value inputted in the last sampling period is referred to as the first tap data value, a data value inputted in the second last sampling period is referred to as the second tap data value, and a data value inputted in the third last sampling period is referred to as the third tap data value.
The mixer 101, the data sampler 102, and the D latch circuit 103 configure the first data sampling circuit of the first sampling circuit. The first data sampling circuit adds a negative offset to the signal level of the input signal Din, samples the input signal, and outputs a first data value. The mixer 101 adds the negative offset −w1 to the input signal Din outputted from the mixer 100, and outputs it to the data sampler 102. The data sampler 102 samples the input signal Din outputted from the mixer 101, in accordance with the sampling clock SMCLK (0), and outputs the first data value. The D latch circuit 103 latches the first data value outputted from the data sampler 102, in accordance with the sampling clock SMCLK (180). The negative offset −w1 added by the mixer 101 is the inverted value of an offset value generated based on the logic level of the first tap data.
The mixer 104, the data sampler 105, and the D latch circuit 106 configure the second data sampling circuit of the first sampling circuit. The second data sampling circuit adds a positive offset to the signal level of the input signal Din, samples the input signal, and outputs a second data value. The mixer 104 adds the positive offset w1 to the input signal Din outputted from the mixer 100, and outputs it to the data sampler 105. The data sampler 105 samples the input signal Din outputted from the mixer 104, in accordance with the sampling clock SMCLK (0), and outputs the second data value. The D latch circuit 106 latches the second data value outputted from the data sampler 105, in accordance with the sampling clock SMCLK (180). The positive offset w1 added by the mixer 104 is the offset value generated based on the logic level of the first tap data.
The mixer 140, the edge sampler 141, and the D latch circuits 142, 143 configure the first edge sampling circuit of the first sampling circuit. The first edge sampling circuit adds a first offset to the signal level of the input signal Din, and outputs a first edge value ea0 indicating the value of an edge part of the input signal Din. The mixer 140 adds the first offset w1 generated based on a data value outputted by the data sampler 112 to the input signal Din outputted by the mixer 100, and outputs it to the edge sampler 141. The edge sampler 141 samples the input signal Din outputted from the mixer 140, in accordance with the sampling clock SMCLK (90), and outputs the first edge value ea0. The D latch circuit 142 latches the first edge value ea0 outputted from the edge sampler 141, in accordance with the sampling clock SMCLK (270). The D latch circuit 143 latches the first edge value ea0 outputted from the D latch circuit 142, in accordance with the sampling clock SMCLK (90).
The mixer 144, the edge sampler 145, and the D latch circuits 146, 147 configure the second edge sampling circuit of the first sampling circuit. The second edge sampling circuit adds a second offset to the signal level of the input signal Din, and outputs a second edge value eb0 indicating the value of an edge part of the input signal Din. The mixer 144 adds the second offset whose value is zero to the input signal Din outputted from the mixer 100, and outputs it to the edge sampler 145. That is, the mixer 144 performs an adjustment for the delay between the first edge sampling circuit and the second edge sampling circuit. The edge sampler 145 samples the input signal Din outputted from the mixer 144, in accordance with the sampling clock SMCLK (90), and outputs the second edge value eb0. The D latch circuit 146 latches the second edge value eb0 outputted from the edge sampler 145, in accordance with the sampling clock SMCLK (270). The D latch circuit 147 latches the second edge value eb0 outputted from the D latch circuit 146, in accordance with the sampling clock SMCLK (90).
Further, the D latch circuits 120 to 124 configure a shift register. In this shift register, the odd-numbered registers operate based on the sampling clock SMCLK (0), and the even-numbered registers operate based on the sampling clock SMCLK (180). The D latch circuits 120 to 124 shift and output the data value d0 selected by the selector 107, based on the sampling clock SMCLK (0) and the sampling clock SMCLK (180).
The mixer 110 provides the result of adding the offset w2 to the input signal Din to a first data sampling circuit, a second data sampling circuit, a first edge sampling circuit, and a second edge sampling circuit in the subsequent stages. The offset w2 is calculated from the second tap data value or an earlier one.
The mixer 111, the data sampler 112, and the D latch circuit 113 configure the first data sampling circuit of the second sampling circuit. The first data sampling circuit adds a negative offset to the signal level of the input signal Din, samples the input signal, and outputs a first data value. The mixer 111 adds the negative offset −w1 to the input signal Din outputted from the mixer 110, and outputs it to the data sampler 112. The data sampler 112 samples the input signal Din outputted from the mixer 111, in accordance with the sampling clock SMCLK (180), and outputs the first data value. The D latch circuit 113 latches the first data value outputted from the data sampler 112, in accordance with the sampling clock SMCLK (0). The negative offset −w1 added by the mixer 101 is the inverted value of the offset value generated based on the logic level of the first tap data.
The mixer 114, the data sampler 115, and the D latch circuit 116 configure the second data sampling circuit of the second sampling circuit. The second data sampling circuit adds a positive offset to the signal level of the input signal Din, samples the input signal, and outputs a second data value. The mixer 114 adds the positive offset w1 to the input signal Din outputted from the mixer 110, and outputs it to the data sampler 115. The data sampler 115 samples the input signal Din outputted from the mixer 114, in accordance with the sampling clock SMCLK (180), and outputs the second data value. The D latch circuit 116 latches the second data value outputted from the data sampler 115, in accordance with the sampling clock SMCLK (0). The positive offset w1 added by the mixer 114 is the offset value generated based on the logic level of the first tap data.
The mixer 150, the edge sampler 151, and the D latch circuits 152, 153 configure the first edge sampling circuit of the second sampling circuit. The first edge sampling circuit adds a first offset to the signal level of the input signal Din, and outputs a first edge value ea1 indicating the value of an edge part of the input signal Din. The mixer 150 adds the first offset w1 generated based on a data value outputted by the data sampler 102 to the input signal Din outputted by the mixer 110, and outputs it to the edge sampler 151. The edge sampler 151 samples the input signal Din outputted from the mixer 150, in accordance with the sampling clock SMCLK (270), and outputs the first edge value ea1. The D latch circuit 152 latches the first edge value ea1 outputted from the edge sampler 151, in accordance with the sampling clock SMCLK (90). The D latch circuit 153 latches the first edge value ea1 outputted from the D latch circuit 152, in accordance with the sampling clock SMCLK (270).
The mixer 154, the edge sampler 155, and the D latch circuits 156, 157 configure the second edge sampling circuit of the second sampling circuit. The second edge sampling circuit adds a second offset to the signal level of the input signal Din, and outputs a second edge value eb1 indicating the value of an edge part of the input signal Din. The mixer 154 adds the second offset whose value is zero to the input signal Din outputted from the mixer 110, and outputs it to the edge sampler 155. That is, the mixer 154 performs an adjustment for the delay between the first edge sampling circuit and the second edge sampling circuit. The edge sampler 155 samples the input signal Din outputted from the mixer 154, in accordance with the sampling clock SMCLK (270), and outputs the second edge value eb1. The D latch circuit 156 latches the second edge value eb1 outputted from the edge sampler 155, in accordance with the sampling clock SMCLK (90). The D latch circuit 157 latches the second edge value eb1 outputted from the D latch circuit 156, in accordance with the sampling clock SMCLK (270).
Further, the D latch circuits 130 to 134 configure a shift register. In this shift register, the odd-numbered registers operate based on the sampling clock SMCLK (180), and the even-numbered registers operate based on the sampling clock SMCLK (0). The D latch circuits 130 to 134 shift the data value d1 selected by the selector 117, based on the sampling clock SMCLK (0) and the sampling clock SMCLK (180), and output the data value d1.
Further, in the first sampling circuit, the first data value outputted from the first data sampling circuit or the second data value outputted from the second data sampling circuit is selected based on the output value of the first shift register (e.g., the D latch circuit 130) in the second sampling circuit. That is, in the first sampling circuit, the data value in the current sampling period is determined based on the data value determined 1 UI ago based on the determination result in the last sampling period. In the second sampling circuit, the first data value outputted from the first data sampling circuit or the second data value outputted from the second data sampling circuit is selected based on the output value of the first shift register (e.g., the D latch circuit 120) in the first sampling circuit. That is, in the second sampling circuit, the data value in the current sampling period is determined based on the data value determined 1 UI ago based on the determination result in the last sampling period.
Further, the buffer circuits 125, 135 output the offset w2 based on the output of the shift register in the first sampling circuit and the output of the shift register in the second sampling circuit. Since the buffer circuit 125 is provided in the first sampling circuit corresponding to the odd-numbered data value, the buffer circuit 125 outputs the offset w2 based on the data value latched by the D latch with the sampling clock SMCLK (0) used for sampling the odd-numbered data value. Since the buffer circuit 135 is provided in the second sampling circuit corresponding to the even-numbered data value, the buffer circuit 135 outputs the offset w2 based on the data value latched by the D latch with the sampling clock SMCLK (180) used for sampling the even-numbered data value.
Further, in the decision feedback equalizer 10 shown in
Further, in the decision feedback equalizer 10 shown in
The circuits of the mixers 140, 144, 150, 154 in the decision feedback equalizer 10 will be described. The mixers have substantially the same configuration, and will therefore be described by way of example of the mixer 140.
The circuit diagram of
The NMOS transistors MN1, MN2 configure a differential pair. A positive signal INP of the input signal Din is provided to the gate of the NMOS transistor MN1. A negative signal INN of the input signal Din is provided to the gate of the NMOS transistor MN2. The current source supplies a current Imain through the differential pair. Further, the load resistor RL1 is coupled between the drain of the NMOS transistor MN1 and a power line to which a power supply voltage VDD is supplied. The load resistor RL2 is coupled between the drain of the NMOS transistor MN2 and the power line to which the power supply voltage VDD is supplied. Further, a first output terminal OUTN is coupled to the drain of the NMOS transistor MN1 through a first output line. A second output terminal OUTP is coupled to the drain of the NMOS transistor MN2 through a second output line.
Further, in the buffer circuit 108, the NMOS transistors MN11, MN12 configure a differential pair. A negative signal FBN of differential signals provided as the data value outputted from the data sampler 112 is provided to the gate of the NMOS transistor MN11. A positive signal FBP of the differential signals provided as the data value outputted from the data sampler 112 is provided to the gate of the NMOS transistor MN12. The current source supplies a current Iw1 through the differential pair. Further, the drain of the NMOS transistor MN11 is coupled to the first output line. The drain of the NMOS transistor MN12 is coupled to the second output line.
The mixer 140 selects whether to pass the current Imain of the current source through the load resistor RL1 or the load resistor RL2 in accordance with the level of the input signal Din, thereby switching the logic level of the output of the mixer 140. Further, the buffer circuit 108 selects whether to pass the current Iw1 through the load resistor RL1 or the load resistor RL2 in accordance with the logic level of the data value. That is, the buffer circuit 108 passes the current Iw1 through the first output line and the second output line, thereby providing the offset to the signal level of the mixer 140.
As described above, in the decision feedback equalizer 10 according to the first embodiment, the first data value outputted from the data samplers 102, 112 is fed back to the edge sampling circuit. That is, the decision feedback equalizer 10 according to the first embodiment determines the first offset to one sampling circuit in the current sampling period, based on the first data value outputted in the last sampling period. Thereby, the decision feedback equalizer 10 according to the first embodiment eases the timing restriction on the feedback path. Further, the decision feedback equalizer 10 according to the first embodiment alternately outputs odd data information including the data value d0, the first edge value ea0, and the second edge value eb0 and even data information including the data value d1, the first edge value eat, and the second edge value eb1 every half cycle of the sampling clock.
The pattern filter 20 determines the validity of the edge value, based on the successively outputted odd-numbered data d0 and even-numbered data d1. The pattern filter 20 selects one of the two edge values included in each of the odd data information and the even data information, based on the data values d0, d1. Hereinafter, the pattern filter 20 according to the first embodiment will be described in detail.
As shown in
The flip-flop circuits 200, 201 configure a shift register, which shifts and outputs the data value d0 in accordance with the sampling clock. The flip-flop circuits 202, 203 configure a shift register, which shifts and outputs the data value d1 in accordance with the sampling clock.
The flip-flop circuits 205, 206 configure a shift register, which shifts the first edge value ea0 in accordance with the sampling clock and outputs it to one terminal (e.g., a terminal selected when a selection signal is 0) of the selector 210. The flip-flop circuits 207, 208 configure a shift register, which shifts the second edge value eb0 in accordance with the sampling clock and outputs it to the other terminal (e.g., a terminal selected when the selection signal is 1) of the selector 210.
The flip-flop circuits 211, 212 configure a shift register, which shifts the first edge value ea1 in accordance with the sampling clock and outputs it to one terminal (e.g., a terminal selected when a selection signal is 0) of the selector 217. The flip-flop circuits 213, 214 configure a shift register, which shifts the second edge value eb1 in accordance with the sampling clock and outputs it to the other terminal (e.g., a terminal selected when the selection signal is 1) of the selector 217.
The edge validity determination circuit 209 outputs the validity flag e0valid indicating the validity of the first edge value ea0 or the second edge value eb0, based on the data values d1, d0. Further, the edge validity determination circuit 209 outputs the selection signal to the selector 217 based on the data values d1, d0.
The edge validity determination circuit 209 has data transition determination circuits 220, 221, 223, 224, 225 and NAND circuits 222, 226. The data transition determination circuits 220, 221, 223, 224, 225 output 0 only if two input values meet a predetermined condition. For example, the data transition determination circuits 220, 221, 223, 224, 225 output 0 only if one value is 1 and the other value is O.
The data transition determination circuit 220 outputs 0 only if the data value d0 outputted from the flip-flop circuit 200 is 0 and the data value d1 outputted from the flip-flop circuit 202 is 1. That is, the data transition determination circuit 220 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 0 to 1 or the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 1 to 0.
The data transition determination circuit 221 outputs 0 only if the data value d0 outputted from the flip-flop circuit 200 is 1 and the data value d1 outputted from the flip-flop circuit 202 is 0. That is, the data transition determination circuit 221 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 1 to 0 or the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 0 to 1.
The NAND circuit 222 outputs the inverted AND between the output of the data transition determination circuit 220 and the output of the data transition determination circuit 221, as the selection signal to the selector 217. The values inputted to the NAND circuit 222 both become 1 in two cases where the transition of three successive data values is 110 and 001. That is, in the two cases where the transition of three successive data values is 110 and 001, the edge validity determination circuit 209 outputs 0 as the selection signal, and the selector 217 outputs the first edge value eat as the edge value e1.
The data transition determination circuit 223 outputs 0 only if the data value d0 outputted from the flip-flop circuit 201 is 0 and the data value d1 outputted from the flip-flop circuit 203 is 1. That is, the data transition determination circuit 223 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 0 to 1 or if the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 1 to 0.
The data transition determination circuit 224 outputs 0 only if the data value d0 outputted from the flip-flop circuit 201 is 1 and the data value d1 outputted from the flip-flop circuit 203 is 0. That is, the data transition determination circuit 224 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 1 to 0 or the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 0 to 1.
The data transition determination circuit 225 outputs 0 only if the output value of the data transition determination circuit 220 is 1 and the output value of the data transition determination circuit 224 is 0. The NAND circuit 226 outputs the inverted AND between the output value of the data transition determination circuit 225 and the output value of the data transition determination circuit 223, as the validity flag e0valid. The validity flag e0valid indicates the validity of the edge value e0 outputted from the selector 210. The validity flag e0valid indicates that the edge value e0 is valid if the value is 1 for example. The details of cases where the validity flag e0valid indicates a valid state and indicates an invalid state will be described later.
The edge validity determination circuit 216 has data transition determination circuits 230, 231, 232, 234, and NAND circuits 233, 235. The data transition determination circuits 230, 231, 232, 234 output 0 only if two input values meet a predetermined condition. For example, the data transition determination circuits 230, 231, 232, 234 output 0 only if one value is 1 and the other value is 0.
The data transition determination circuit 230 outputs 0 only if the data value d0 inputted to the flip-flop circuit 200 is 1 and the data value d1 outputted from the flip-flop circuit 202 is 0. That is, the data transition determination circuit 230 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 1 to 0 or the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 0 to 1.
The data transition determination circuit 231 outputs 0 only if the data value d0 inputted to the flip-flop circuit 201 is 1 and the data value d1 outputted from the flip-flop circuit 203 is 0. That is, the data transition determination circuit 231 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 1 to 0 or the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 0 to 1.
The data transition determination circuit 232 outputs 0 only if the data value d0 inputted to the flip-flop circuit 201 is 0 and the data value d1 outputted from the flip-flop circuit 203 is 1. That is, the data transition determination circuit 232 outputs 0 if the transition of the data value from the odd-numbered data value d0 to the even-numbered data value d1 is from 0 to 1 or the transition of the data value from the even-numbered data value d1 to the odd-numbered data value d0 is from 1 to 0.
The NAND circuit 233 outputs the inverted AND between the output of the data transition determination circuit 231 and the output of the data transition determination circuit 232, as the selection signal to the selector 210. The values inputted to the NAND circuit 233 both become 1 in two cases where the transition of three successive data values is 110 and 001. That is, in the two cases where the transition of three successive data values is 110 and 001, the edge validity determination circuit 216 outputs 0 as the selection signal, and the selector 210 outputs the first edge value ea0 as the edge value e0.
The data transition determination circuit 234 outputs 0 only if the output value of the data transition determination circuit 230 is 1 and the output value of the data transition determination circuit 232 is 0. The NAND circuit 235 outputs the inverted AND between the output value of the data transition determination circuit 231 and the output value of the data transition determination circuit 234, as the validity flag e1valid. The validity flag e1valid indicates the validity of the edge value e1 outputted from the selector 217. The validity flag e1valid indicates that the edge value e1 is valid if the value is 1 for example. The details of cases where the validity flag e1valid indicates a valid state and indicates an invalid state will be described later.
Next, the operation of the pattern filter 20 according to the first embodiment will be described. The waveform shape of the serial signal provided as the input signal Din is degraded by inter-symbolic interference (ISI) due to the characteristics of a transmission line. The decision feedback equalizer 10 correctly receives the degraded waveform, using the offset.
First, the waveform degradation due to ISI will be described.
As shown in
Next,
In case 1 of
Further, in case 2 of
Thus, by providing the offset in accordance with the temporal change of successively inputted data values to determine the signal level, it is possible to increase a margin for reception level variation.
Next, the influence of ISI on the edge value sampled at the intermediate time between successive data values will be described. The edge value is influenced by a string of adjacent 3-bit data. More specifically, the influence of ISI on the edge value is classified into four cases by the string of adjacent 3-bit data.
In case 1 of
In case 2 of
In case 3 of
In case 4 of
As shown in
The validity of the edge value ea(n) in case 1 of
In case 1 of
In case 2 of
In case 3 of
In case 4 of
In the data patterns shown in
As described above, the pattern filter 20 has two functions. The first function is to determine whether to adopt and send to the phase detection circuit 30 the first edge value ea(n) sampled with the first offset provided based on the data value fed back in accordance with the data pattern of data values or the second edge value eb(n) sampled without providing the offset. The second function is to reject the invalid edge value in accordance with the data pattern of data values.
In the first function, the pattern filter 20 selects the second edge value eb(n) if x(n−1)̂x(n)=0, and selects the first edge value ea(n) if x(n−1)̂x(n)=1, where the symbol “̂” denotes an exclusive OR.
In the second function of the pattern filter 20, considering that if x(n)=x(n+1), there exists no edge and the edge value e(n) is invalid, the edge value e(n) is used as an edge under the condition that x(n)̂x(n+1)=1 and x(n−2:n+1)!=1001. This condition is expressed as a logical expression, i.e., e(n)valid=x(n)*˜x(n+1)+˜(x(n−2)*˜x(n−1))*˜x(n)*x(n+1). That is, the pattern filter 20 determines the value of the validity flag e(n)valid, based on the condition expressed by this logical expression. In the logical expression, the symbol “˜” denotes inverted logic, the symbol “*” denotes a logical AND, and the symbol “+” denotes a logical OR.
In the above description, the signal levels −w1, +w1 assumed as the remaining signal level of the data value in the last sampling period are provided as the first offset used for sampling the edge value. However, this is approximation, and in reality, the offset for sampling the edge value may be a value different from w1, e.g., +we1 or −we1. While this does not apply limitations on the decision feedback equalizer 10, the above description has been made in which w1=we1 for simplicity.
The input waveform as a premise in
Next, the phase detection circuit 30 of the semiconductor device 1 according to the first embodiment will be described. As described above, the pattern filter 20 outputs the edge value e(n) and the validity flag e(n)valid indicating the validity of the edge value e(n). Accordingly, the phase detection circuit 30 determines the advance or delay of the phase of the sampling clock based on the edge value e(n), and also has the function of not controlling the phase of the sampling clock for the invalid edge value e(n) based on the validity flag e(n)valid.
First, the relationship between the edge value sampled by the decision feedback equalizer 10 and the phase of the sampling clock will be described.
In the left chart of
In the semiconductor device 1 according to the first embodiment, since the edge value e(n) is 0 or 1, if the ratio between 0 and 1 of the edge value e(n) per unit time is about 1:1, it can be determined that the phase of the sampling clock coincides approximately with that of the input signal Din. In the semiconductor device 1, the phase control circuit 40 and the phase shift unit 50 control the phase of the sampling clock so that the ratio between 0 and 1 of the edge value e(n) per unit time becomes about 1:1.
Next, the configuration of the phase detection circuit 30 will be described.
The odd-numbered data value d0 and the edge value e0 corresponding to the data value d0 are inputted to the EXOR circuit 300. The EXOR circuit 300 outputs the exclusive OR between the two input values.
The output value of the EXOR circuit 300 and the validity flag e0valid indicating the validity of the edge value e0 are inputted to the AND circuit 302. The AND circuit 302 outputs the logical AND between the two input values. The output value of the AND circuit 302 is a down signal down0 which becomes 1 if the phase of the sampling clock used for sampling the odd-numbered data value is advanced. Further, the down signal down0 becomes 0 if the validity flag e0valid indicates the invalid state (e.g., 0).
A value obtained by inverting by the inverter 301 the output value of the EXOR circuit 300 and the validity flag e0valid indicating the validity of the edge value e0 are inputted to the AND circuit 303. The AND circuit 303 outputs the logical AND between the two input values. The output value of the AND circuit 303 is an up signal up0 which becomes 1 if the phase of the sampling clock used for sampling the odd-numbered data value is delayed. Further, the up signal up0 becomes 0 if the validity flag e0valid indicates the invalid state (e.g., 0).
The even-numbered data value d1 and the edge value e1 corresponding to the data value d1 are inputted to the EXOR circuit 310. The EXOR circuit 310 outputs the exclusive OR between the two input values.
The output value of the EXOR circuit 310 and the validity flag e1valid indicating the validity of the edge value e1 are inputted to the AND circuit 312. The AND circuit 312 outputs the logical AND between the two input values. The output value of the AND circuit 312 is a down signal down1 which becomes 1 if the phase of the sampling clock used for sampling the even-numbered data value is advanced. Further, the down signal down1 becomes 0 if the validity flag e1valid indicates the invalid state (e.g., 0).
A value obtained by inverting by the inverter 311 the output value of the EXOR circuit 310 and the validity flag e1valid indicating the validity of the edge value e1 are inputted to the AND circuit 313. The AND circuit 313 outputs the logical AND between the two input values. The output value of the AND circuit 313 is an up signal up1 which becomes 1 if the phase of the sampling clock used for sampling the even-numbered data value is delayed. Further, the up signal up1 becomes 0 if the validity flag e1valid indicates the invalid state (e.g., 0).
The majority circuit 320 refers to the up signals up0, up1 and the down signals down0, down1, determines which of the up and down signals having a value of 1 is larger in number, and determines the logic levels of the final up signal up and down signal down.
For example, the majority circuit 320 outputs 1 as the up signal up and 0 as the down signal down if both of the up signals up0, up1 are 1. The majority circuit 320 outputs 0, as the up signal up and 1 as the down signal down if both of the down signals down0, down1 are 1. The majority circuit 320 outputs 0 as the up signal up and 0 as the down signal down if either of the up signals up0, up1 is 1 and either of the down signals down0, down1 is 1. The majority circuit 320 outputs 0 as the up signal up and 0 as the down signal down if all of the up signals up0, up1 and the down signals down0, down1 are 0. Further, the majority circuit 320 outputs 1 as the up signal up and 0 as the down signal down if either of the up signals up0, up1 is 1 and both of the down signals down0, down1 are 0. The majority circuit 320 outputs 0 as the up signal up and 1 as the down signal down if both of the up signals up0, up1 are 0 and either of the down signals down0, down1 is 1. The majority circuit 320 includes OR circuits 321, 324, AND circuits 322, 325, and inverters 323, 326 to perform the above operation.
The up signals up0, up1 are inputted to the OR circuit 321. The OR circuit 321 outputs the logical OR between the two input signals. The down signals down0, down1 are inputted to the OR circuit 324. The OR circuit 324 outputs the logical OR between the two input signals.
The output value of the OR circuit 321 and a value obtained by inverting by the inverter 326 the output value of the OR circuit 324 are inputted to the AND circuit 322. The AND circuit 322 outputs the logical AND between the two input signals, as the up signal up. The output value of the OR circuit 324 and a value obtained by inverting by the inverter 323 the output value of the OR circuit 321 are inputted to the AND circuit 325. The AND circuit 325 outputs the logical AND between the two input signals, as the down signal down.
As described above, the semiconductor device 1 according to the first embodiment has the decision feedback equalizer 10 as one of the features, which reduces the circuit area and the power consumption. More specifically, in the decision feedback equalizer 10, by using the first data sampling circuit which samples the data value, using the negative offset (e.g., −w1) and the second data sampling circuit which samples the data value, using the positive offset (e.g., w1), the first tap data is loop-unrolled. Further, the output value of the data sampler of the first data sampling circuit is directly fed back to the mixer provided at the input of the edge sampling circuit, without passing through the selector. That is, in the decision feedback equalizer 10, logic in the feedback path to the edge sampling circuit is simplified.
Generally, in the case of loop-unrolling the first tap data, since the sampled data value is determined by being outputted as the output value of the selector, the data value outputted from the selector is fed back to the edge sampling circuit, as shown in
On the other hand, in the decision feedback equalizer 10 according to the first embodiment, the logic in the feedback path is simplified, which can ease the timing restriction on the feedback path, in comparison with the decision feedback equalizer 10a shown in
Further, as another circuit configuration of the decision feedback equalizer 10, the first and second sampling circuits each can include three edge sampling circuits having the positive offset (+w1), the negative offset (−w1), and zero without feedback, and the subsequent circuit such as the pattern filter selects the edge value. However, this increases the number of edge sampling circuits. The increased number of edge sampling circuits increases loads on the pipeline in the subsequent stage and the amplifier in the preceding stage, which disadvantageously increases the power consumption. Further, the increased number of edge sampling circuits disadvantageously increases the circuit area. However, in the decision feedback equalizer 10 according to the first embodiment, the first and second sampling circuits each include only the two edge sampling circuits, which can reduce the circuit area of the edge sampling circuit and the power consumption.
Further, in the decision feedback equalizer 10 according to the first embodiment, the data value sampled using the negative offset in the last sampling period is used as the data value fed back to the edge sampling circuit. By configuring such a feedback path in the decision feedback equalizer 10 according to the first embodiment, the data string pattern of the invalid edge value e(n) is only 1001, which can reflect the edge value e(n) in the phase control of the sampling clock with a high probability. This enables high phase tracking ability in the semiconductor device 1 according to the first embodiment as a CDR (clock and data recovery) circuit.
For example, in the technique described in Non-patent Document 1, only several data patterns can be adopted as the valid edge value e(n); accordingly, the phase tracking ability of the CDR circuit is inferior compared to the semiconductor device 1 according to the first embodiment.
Further, for example, the data value of the second data sampling circuit which samples data using the positive offset can be fed back to the edge sampling circuit. However, in this case, the valid edge value e(n) cannot be acquired in the case where the data pattern is 001. That is, the circuit for feeding back the data value of the second data sampling circuit disadvantageously increases the probability of occurrence of the invalid edge value e(n), in comparison with the semiconductor device 1 according to the first embodiment which can acquire the valid edge value e(n) in the case where the data pattern is 0001. Assuming that the data pattern is inputted in a random manner; by acquiring 0001 as the valid edge value, it is possible to reduce the probability of occurrence of the invalid edge value to half, in comparison with the case where the data string of 001 is all the invalid edge value.
Further, in the bang-bang CDR, several-adjacent-bit edge values e(n) (mostly 4 to 8 bits) are generally decimated in phase comparison. For example, in 4-bit decimation, first, two-adjacent-bit edge values undergo majority processing for 2:1 decimation for 1-bit output, and then the decimated edge values undergo majority processing for 2:1 decimation, thus finally leading to 4:1 decimation by tournament. Alternatively, four adjacent bits undergo majority processing. In either case, in 4:1 decimation, even if the edge value e(n) sampled in the input pattern of 1001 is discarded, edge value e(n−2) is valid, which exerts little influence on the phase tracking ability of the CDR circuit. That is, the semiconductor device 1 according to the first embodiment can extremely decrease the probability of occurrence of the invalid edge value e(n), which makes it possible to ensure the high phase tracking ability of the CDR circuit.
Second EmbodimentIn the second embodiment, description will be made on a decision feedback equalizer 11 having a different configuration from that of the decision feedback equalizer 10 according to the first embodiment. In the description of the second embodiment, components described in the first embodiment are denoted by the same reference numerals as in the first embodiment, and description thereof is omitted.
More specifically, the decision feedback equalizer 11 according to the second embodiment determines the first offset to the first edge sampling circuit of one sampling circuit in the current sampling period, based on the data value sampled in the second last sampling period and the data value sampled in the third last sampling period. Further, the decision feedback equalizer 11 according to the second embodiment determines the second offset to the second edge sampling circuit of one sampling circuit in the current sampling period, based on the data value sampled in the third last sampling period.
As shown in
The D latch circuits 160, 161 and the buffer circuit 162 configure a feedback path for feeding back to the mixer 140 the second tap data outputted from the D latch circuit 120, as the first offset. The D latch circuit 160 operates based on the sampling clock SMCLK (90). The D latch circuit 161 operates based on the sampling clock SMCLK (270). The buffer circuit 162 provides the offset of w1/2 to the mixer 140, based on the second tap data.
The D latch circuits 163, 164 and the buffer circuit 165 configure a feedback path for feeding back to the mixer 140 the third tap data outputted from the D latch circuit 131, as the first offset. Further, the D latch circuits 163, 164 and the buffer circuit 166 configure a feedback path for feeding back to the mixer 144 the third tap data outputted from the D latch circuit 131, as the second offset. The D latch circuit 163 operates based on the sampling clock SMCLK (90). The D latch circuit 164 operates based on the sampling clock SMCLK (270). The buffer circuit 165 provides the offset of w1/2 to the mixer 140, based on the third tap data. The buffer circuit 166 provides the offset of w1 to the mixer 144, based on the third tap data.
The D latch circuits 170, 171 and the buffer circuit 172 configure a feedback path for feeding back to the mixer 150 the second tap data outputted from the D latch circuit 130, as the first offset. The D latch circuit 170 operates based on the sampling clock SMCLK (90). The D latch circuit 171 operates based on the sampling clock SMCLK (270). The buffer circuit 172 provides the offset of w1/2 to the mixer 150, based on the second tap data.
The D latch circuits 173, 174 and the buffer circuit 175 configure a feedback path for feeding back to the mixer 150 the third tap data outputted from the D latch circuit 121, as the first offset. Further, the D latch circuits 173, 174 and the buffer circuit 176 configure a feedback path for feeding back to the mixer 154 the third tap data outputted from the D latch circuit 121, as the second offset. The D latch circuit 173 operates based on the sampling clock SMCLK (90). The D latch circuit 174 operates based on the sampling clock SMCLK (270). The buffer circuit 175 provides the offset of w1/2 to the mixer 150, based on the third tap data. The buffer circuit 176 provides the offset of w1 to the mixer 154, based on the third tap data.
In the decision feedback equalizer 11 according to the second embodiment, two pieces of w1/2 as the offset generated based on the tap data are provided to the mixers 140, 150.
In the circuit diagram shown in
The NMOS transistors MN1, MN2 configure a differential pair. A positive signal INP of the input signal Din is provided to the gate of the NMOS transistor MN1. A negative signal INN of the input signal Din is provided to the gate of the NMOS transistor MN2. The current source supplies a current Imain to the differential pair. Further, the load resistor RL1 is coupled between the drain of the NMOS transistor MN1 and a power line to which a power supply voltage VDD is supplied. The load resistor RL2 is coupled between the drain of the NMOS transistor MN2 and the power line to which the power supply voltage VDD is supplied. Further, a first output terminal OUTN is coupled to the drain of the NMOS transistor MN1 through a first output line. A second output terminal OUTP is coupled to the drain of the NMOS transistor MN2 through a second output line.
Next, the buffer circuit 162 will be described. A negative signal FB0N of differential signals provided as the data value outputted from the D latch circuit 161 is provided to the gate of the NMOS transistor MN21. A positive signal FB0P of the differential signals provided as the data value outputted from the D latch circuit 161 is provided to the gate of the NMOS transistor MN22. Further, the drain of the NMOS transistor MN21 is coupled to the first output line. The drain of the NMOS transistor MN22 is coupled to the second output line.
Next, the buffer circuit 165 will be described. A negative signal FB1N of differential signals provided as the data value outputted from the D latch circuit 164 is provided to the gate of the NMOS transistor MN23. A positive signal FB1P of the differential signals provided as the data value outputted from the D latch circuit 164 is provided to the gate of the NMOS transistor MN24. Further, the drain of the NMOS transistor MN23 is coupled to the first output line. The drain of the NMOS transistor MN24 is coupled to the second output line.
The current source supplies a current Iw1 to the differential pair of the buffer circuit 162 and the differential pair of the buffer circuit 165. That is, in the decision feedback equalizer 11, a current of Iw1/2 is supplied to the buffer circuit 162, and a current of Iw1/2 is supplied to the buffer circuit 165.
The mixer 140 selects whether to pass the current Imain of the current source through the load resistor RL1 or the load resistor RL2 in accordance with the level of the input signal Din, thereby switching the logic level of the output of the mixer 140. Further, the buffer circuits 162, 165 each select whether to pass the current Iw1/2 to the load resistor RL1 or the load resistor RL2 in accordance with the logic level of the data value. That is, the buffer circuits 162, 165 each pass the current Iw1/2 to the first output line and the second output line, thereby providing the offset to the signal level of the mixer 140.
Next, the operation of the decision feedback equalizer 11 according to the second embodiment will be described. The sampling of the data value in the decision feedback equalizer 11 is the same as in the decision feedback equalizer 10 according to the first embodiment; therefore, description thereof is omitted. On the other hand, the sampling of the edge value in the decision feedback equalizer 11 is different from that of the decision feedback equalizer 10 according to the first embodiment in terms of the feedback data value. Hereinafter, the sampling of the edge value in the decision feedback equalizer 11 according to the second embodiment will be described.
More specifically, if the data value x(n−3) is 0 and the data value x(n−2) is 0, the first offset used for sampling the first edge value ea(n) is −w1 and the second offset used for sampling the second edge value eb(n) is +w1. If the data value x(n−3) is 1 and the data value x(n−2) is 0, the first offset used for sampling the first edge value ea(n) is 0 and the second offset used for sampling the second edge value eb(n) is −w1. If the data value x(n−3) is 0 and the data value x(n−2) is 1, the first offset used for sampling the first edge value ea(n) is 0 and the second offset used for sampling the second edge value eb(n) is +w1. If the data value x(n−3) is 1 and the data value x(n−2) is 1, the first offset used for sampling the first edge value ea(n) is +w1 and the second offset used for sampling the second edge value eb(n) is −w1.
As described with reference to
First, in cases 1 to 4, since the pattern of the three later-inputted data values is 001, an expected offset value is −w1. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be −w1 in cases 1, 2, 4. That is, by selecting the edge value ea(n) in case 1 where the combination of the data value x(n−3) and the data value x(n−2) is 00, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value eb(n) in case 2 where the combination of the data value x(n−3) and the data value x(n−2) is 10, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value eb(n) in case 4 where the combination of the data value x(n−3) and the data value x(n−2) is 11, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 3 where the combination of the data value x(n−3) and the data value x(n−2) is 01, since there is no edge sampling circuit for outputting the edge value with the offset of −w1, the semiconductor device 1 cannot acquire the valid edge value e(n).
In cases 5 to 8, since the pattern of the three later-inputted data values is 101, an expected offset value is 0. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be 0 in cases 6, 7. That is, by selecting the edge value ea(n) in case 6 where the combination of the data value x(n−3) and the data value x(n−2) is 10, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 7 where the combination of the data value x(n−3) and the data value x(n−2) is 01, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 5 where the combination of the data value x(n−3) and the data value x(n−2) is 00 and in case 8 where the combination of the data value x(n−3) and the data value x(n−2) is 11, since there is no edge sampling circuit for outputting the edge value with the offset of 0, the semiconductor device 1 cannot acquire the valid edge value e(n).
In cases 9 to 12, since the pattern of the three later-inputted data values is 010, an expected offset value is 0. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be 0 in cases 10, 11. That is, by selecting the edge value ea(n) in case 10 where the combination of the data value x(n−3) and the data value x(n−2) is 10, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 11 where the combination of the data value x(n−3) and the data value x(n−2) is 01, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 9 where the combination of the data value x(n−3) and the data value x(n−2) is 00 and in case 11 where the combination of the data value x(n−3) and the data value x(n−2) is 11, since there is no edge sampling circuit for outputting the edge value with the offset of 0, the semiconductor device 1 cannot acquire the valid edge value e(n).
In cases 13 to 16, since the pattern of the three later-inputted data values is 110, an expected offset value is +w1. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be +w1 in cases 13, 15, 16. That is, by selecting the edge value eb(n) in case 13 where the combination of the data value x(n−3) and the data value x(n−2) is 00, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value eb(n) in case 15 where the combination of the data value x(n−3) and the data value x(n−2) is 01, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 16 where the combination of the data value x(n−3) and the data value x(n−2) is 11, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 14 where the combination of the data value x(n−3) and the data value x(n−2) is 10, since there is no edge sampling circuit for outputting the edge value with the offset of +w1, the semiconductor device 1 cannot acquire the valid edge value e(n).
Based on the table shown in
e(n)valid=(˜B*˜C+˜(ÂB̂C))*˜D*E+(B*C+ÂB̂C)*D*˜E (1)
where A denotes the data value x(n−3), B denotes the data value x(n−2), C denotes the data value x(n−1), and D denotes the data value x(n), and E denotes the data value x(n+1).
Further, based on the table shown in
e—sel(n)=A*˜C*˜D+˜A*C*D (2)
where A to E denote the data values x(n−3) to x(n+1) respectively as in expression (1).
By configuring logic circuits of the edge validity determination circuits 209, 216 based on expressions (1) and (2), the semiconductor device 1 according to the second embodiment can acquire the valid edge value in 10 of 16 input data patterns.
In input data patterns that are not included in
As shown in
Thus, in the semiconductor device 1 according to the second embodiment, although the number of input data patterns in which the invalid edge value e(n) is sampled is larger than that of the first embodiment, the valid edge value can be detected within a temporally close range of the invalid edge value e(n). Therefore, in the semiconductor device 1 according to the second embodiment, it is possible to maintain the phase tracking ability of the CDR circuit as in the first embodiment.
As described above, the decision feedback equalizer 11 according to the second embodiment generates the first offset and the second offset provided to the edge sampling circuits, based on the second tap data and the third tap data. Accordingly, the decision feedback equalizer 11 according to the second embodiment can ease the timing restriction on the feedback path, in comparison with the decision feedback equalizer 10 according to the first embodiment.
Further, in the semiconductor device 1 including the decision feedback equalizer 11 according to the second embodiment, the number of input data patterns that enable the acquisition of the valid edge value is smaller than that of the semiconductor device 1 according to the first embodiment. However, the valid edge value can be acquired within the temporally close range (e.g., 4 UI) of the invalid edge value e(n). Therefore, in the semiconductor device 1 according to the second embodiment, it is possible to ensure phase tracking ability equivalent to that of the semiconductor device 1 according to the first embodiment.
Further, in the semiconductor device 1 according to the second embodiment, the pattern filter 20 configured with a different logic circuit from that of the first embodiment is used, which increases the circuit area of the pattern filter 20. However, in the decision feedback equalizer 11 according to the second embodiment, the timing restriction on the feedback path is eased, which decreases the circuit area and consumption current in the feedback path of the decision feedback equalizer 11. The advantage of decreasing the circuit area and power consumption of the decision feedback equalizer 11 surpasses the disadvantage of increasing the circuit area of the pattern filter 20.
Third EmbodimentIn the third embodiment, description will be made on a decision feedback equalizer 12 having a different configuration from that of the decision feedback equalizer 10 according to the first embodiment. In the description of the third embodiment, components described in the first embodiment are denoted by the same reference numerals as in the first embodiment, and description thereof is omitted.
More specifically, the decision feedback equalizer 12 according to the third embodiment determines the first offset and the second offset to one sampling circuit in the current sampling period, based on the data value sampled in the second last sampling period and the data value sampled in the third last sampling period.
As shown in
The D latch circuits 160, 161, the buffer circuit 180, and the NAND circuit 182 configure a feedback path for feeding back to the mixer 140 the second tap data outputted from the D latch circuit 120 and the third tap data outputted from the D latch circuit 131, as the first offset. The NAND circuit 182 provides the inverted AND between the inverted value of the second tap data and the third tap data to the D latch circuit 160. The D latch circuit 160 operates based on the sampling clock SMCLK (90). The D latch circuit 161 operates based on the sampling clock SMCLK (270). The buffer circuit 180 provides to the mixer 140 the first offset of w1 or 0 based on the output value of the NAND circuit 182.
The D latch circuits 163, 164, the buffer circuit 181, and the NAND circuit 183 configure a feedback path for feeding back to the mixer 144 the second tap data outputted from the D latch circuit 120 and the third tap data outputted from the D latch circuit 131, as the second offset. The NAND circuit 183 provides the inverted AND between the inverted value of the third tap data and the second tap data to the D latch circuit 163. The D latch circuit 163 operates based on the sampling clock SMCLK (90). The D latch circuit 164 operates based on the sampling clock SMCLK (270). The buffer circuit 181 provides to the mixer 144 the second offset of −w1 or 0 based on the output value of the NAND circuit 183.
The D latch circuits 170, 171, the buffer circuit 190, and the NAND circuit 192 configure a feedback path for feeding back to the mixer 150 the second tap data outputted from the D latch circuit 130 and the third tap data outputted from the D latch circuit 121, as the first offset. The NAND circuit 192 provides the inverted AND between the inverted value of the second tap data and the third tap data to the D latch circuit 170. The D latch circuit 170 operates based on the sampling clock SMCLK (90). The D latch circuit 171 operates based on the sampling clock SMCLK (270). The buffer circuit 190 provides to the mixer 150 the first offset of w1 or 0 based on the output value of the NAND circuit 192.
The D latch circuits 173, 174, the buffer circuit 191, and the NAND circuit 193 configure a feedback path for feeding back to the mixer 154 the second tap data outputted from the D latch circuit 130 and the third tap data outputted from the D latch circuit 121, as the second offset. The NAND circuit 193 provides the inverted AND between the inverted value of the third tap data and the second tap data to the D latch circuit 173. The D latch circuit 173 operates based on the sampling clock SMCLK (90). The D latch circuit 174 operates based on the sampling clock SMCLK (270). The buffer circuit 191 provides to the mixer 154 the second offset of −w1 or 0 based on the output value of the NAND circuit 193.
In the decision feedback equalizer 12 according to the third embodiment, w1 or 0 as the offset generated based on the tap data is provided to the mixers 140, 150, and −w1 or 0 as the offset generated based on the tap data is provided to the mixers 144, 154.
In the circuit diagram shown in
The NMOS transistors MN1, MN2 configure a differential pair. A positive signal INP of the input signal Din is provided to the gate of the NMOS transistor MN1. A negative signal INN of the input signal Din is provided to the gate of the NMOS transistor MN2. The current source supplies a current Imain to the differential pair. Further, the load resistor RL1 is coupled between the drain of the NMOS transistor MN1 and a power line to which a power supply voltage VDD is supplied. The load resistor RL2 is coupled between the drain of the NMOS transistor MN2 and the power line to which the power supply voltage VDD is supplied. Further, a first output terminal OUTN is coupled to the drain of the NMOS transistor MN1 through a first output line. A second output terminal OUTP is coupled to the drain of the NMOS transistor MN2 through a second output line.
Next, the buffer circuit 180 will be described. The buffer circuit 180 has NMOS transistors MN31 to MN34 and a current source. The sources of the NMOS transistors MN31 to MN34 are coupled in common to the current source. The gate of the NMOS transistor MN31 is coupled to a power terminal to which the power supply voltage VDD is supplied. The drain of the NMOS transistor MN31 is coupled to the first output line. A negative signal FBN of differential signals provided as the data value outputted from the D latch circuit 161 is provided to the gate of the NMOS transistor MN32. The drain of the NMOS transistor MN32 is coupled to the first output line. A positive signal FBP of the differential signals provided as the data value outputted from the D latch circuit 161 is provided to the gate of the NMOS transistor MN33. The drain of the NMOS transistor MN33 is coupled to the second output line. The gate of the NMOS transistor MN34 is coupled to a ground terminal to which a ground voltage is supplied. The drain of the NMOS transistor MN34 is coupled to the second output line.
The mixer 140 selects whether to pass the current Imain of the current source to the load resistor RL1 or the load resistor RL2 in accordance with the level of the input signal Din, thereby switching the logic level of the output of the mixer 140. Further, the buffer circuit 180 passes the current Iw1 to the load resistor RL1 if the logic level of the fed-back data value is 1, and stops passing the current Iw1 to the load resistors RL1, RL2 if the logic level of the fed-back data value is 0. That is, the buffer circuit 180 provides the offset of w1 or 0 to the signal level of the mixer 140.
In the mixers 144, 154, the positive signal FBP is provided to the gate of the NMOS transistor MN32 shown in
Next, the operation of the decision feedback equalizer 12 according to the third embodiment will be described. The sampling of the data value in the decision feedback equalizer 12 is the same as in the decision feedback equalizer 10 according to the first embodiment; therefore, description thereof is omitted. On the other hand, the sampling of the edge value in the decision feedback equalizer 12 is different from that of the decision feedback equalizer 10 according to the first embodiment in terms of the feedback data value. Hereinafter, the sampling of the edge value in the decision feedback equalizer 12 according to the third embodiment will be described.
More specifically, if the data value x(n−3) is 0 and the data value x(n−2) is 0, the first offset used for sampling the first edge value ea(n) is −w1 and the second offset used for sampling the second edge value eb(n) is +w1. If the data value x(n−3) is 1 and the data value x(n−2) is 0, the first offset used for sampling the first edge value ea(n) is −w1 and the second offset used for sampling the second edge value eb(n) is 0. If the data value x(n−3) is 0 and the data value x(n−2) is 1, the first offset used for sampling the first edge value ea(n) is 0 and the second offset used for sampling the second edge value eb(n) is +w1. If the data value x(n−3) is 1 and the data value x(n−2) is 1, the first offset used for sampling the first edge value ea(n) is −w1 and the second offset used for sampling the second edge value eb(n) is +w1.
As described with reference to
First, in cases 1 to 4, since the pattern of the three later-inputted data values is 001, an expected offset value is −w1. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be −w1 in cases 1, 2, 4. That is, by selecting the edge value ea(n) in case 1 where the combination of the data value x(n−3) and the data value x(n−2) is 00, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 2 where the combination of the data value x(n−3) and the data value x(n−2) is 10, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 4 where the combination of the data value x(n−3) and the data value x(n−2) is 11, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 3 where the combination of the data value x(n−3) and the data value x(n−2) is 01, since there is no edge sampling circuit for outputting the edge value with the offset of −w1, the semiconductor device 1 cannot acquire the valid edge value e(n).
In cases 5 to 8, since the pattern of the three later-inputted data values is 101, an expected offset value is 0. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be 0 in cases 6, 7. That is, by selecting the edge value eb(n) in case 6 where the combination of the data value x(n−3) and the data value x(n−2) is 10, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 7 where the combination of the data value x(n−3) and the data value x(n−2) is 01, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 5 where the combination of the data value x(n−3) and the data value x(n−2) is 00 and in case 8 where the combination of the data value x(n−3) and the data value x(n−2) is 11, since there is no edge sampling circuit for outputting the edge value with the offset of 0, the semiconductor device 1 cannot acquire the valid edge value e(n).
In cases 9 to 12, since the pattern of the three later-inputted data values is 010, an expected offset value is 0. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be 0 in cases 10, 11. That is, by selecting the edge value eb(n) in case 10 where the combination of the data value x(n−3) and the data value x(n−2) is 10, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value ea(n) in case 11 where the combination of the data value x(n−3) and the data value x(n−2) is 01, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 9 where the combination of the data value x(n−3) and the data value x(n−2) is 00 and in case 11 where the combination of the data value x(n−3) and the data value x(n−2) is 11, since there is no edge sampling circuit for outputting the edge value with the offset of 0, the semiconductor device 1 cannot acquire the valid edge value e(n).
In cases 13 to 16, since the pattern of the three later-inputted data values is 110, an expected offset value is +w1. On the other hand, based on the data value x(n−3) and the data value x(n−2), the offset is determined to be +w1 in cases 13, 15, 16. That is, by selecting the edge value eb(n) in case 13 where the combination of the data value x(n−3) and the data value x(n−2) is 00, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value eb(n) in case 15 where the combination of the data value x(n−3) and the data value x(n−2) is 01, the semiconductor device 1 can acquire the valid edge value e(n). By selecting the edge value eb(n) in case 16 where the combination of the data value x(n−3) and the data value x(n−2) is 11, the semiconductor device 1 can acquire the valid edge value e(n). On the other hand, in case 14 where the combination of the data value x(n−3) and the data value x(n−2) is 10, since there is no edge sampling circuit for outputting the edge value with the offset of +w1, the semiconductor device 1 cannot acquire the valid edge value e(n).
In the semiconductor device 1 according to the third embodiment as well, the logic circuits of the pattern filter 20 are configured based on the combinations in
Further, as shown in
As described above, the decision feedback equalizer 12 according to the third embodiment performs substantially the same operation as the decision feedback equalizer 11 according to the second embodiment. Therefore, as in the decision feedback equalizers according to the first and second embodiments, the decision feedback equalizer 12 according to the third embodiment also can ease the timing restriction on the feedback path and reduce the circuit area and the power consumption.
Further, the valid edge values that can be acquired in the semiconductor device 1 according to the third embodiment are the same as in the second embodiment. Therefore, in the semiconductor device 1 according to the third embodiment as well, it is possible to ensure high phase tracking ability as in the semiconductor device 1 according to the second embodiment.
While the invention made above by the present inventors has been described specifically based on the illustrated embodiments, the present invention is not limited thereto. It is needless to say that various changes and modifications can be made thereto without departing from the spirit and scope of the invention.
For example, in the semiconductor devices according to the above embodiments, the conductivity type (p type or n type) of the semiconductor substrate, the semiconductor layer, the diffusion layer (diffusion region), and the like may be reversed. Therefore, assuming that one of the n type and the p type is a first conductivity type and the other is a second conductivity type, the first conductivity type can be the p type and the second conductivity type can be the n type, or the first conductivity type can be the n type and the second conductivity type can be the p type.
Further, while the above embodiments have been described, clearly expressing the logic levels of signals, the logic levels of signals can also be represented by a first logic level and a second logic level which is the inverse of the first logic level. That is, in the above description, the logic levels for operating the circuits are expressed by way of example, and the logic levels can be inversed and applied.
Claims
1. A semiconductor device comprising:
- a first sampling circuit for outputting a data value and an edge value corresponding to odd-numbered data of data contained in an input signal, using multiphase sampling clocks including a plurality of sampling clocks having different phases by 90 degrees; and
- a second sampling circuit for outputting a data value and an edge value corresponding to even-numbered data of data contained in the input signal, using the multiphase sampling clocks,
- wherein one piece of data is sampled in one sampling period, and two sampling periods are included in one cycle of the sampling clock,
- the first sampling circuit and the second sampling circuit each comprising:
- a first data sampling circuit which adds a negative offset to a signal level of the input signal, samples the input signal, and outputs a first data value;
- a second data sampling circuit which adds a positive offset to the signal level of the input signal, samples the input signal, and outputs a second data value;
- a selector for selecting and outputting the first data value or the second data value as the data value, based on a data value sampled in a last sampling period;
- a first edge sampling circuit which adds a first offset to the signal level of the input signal and outputs a first edge value indicating a value of an edge part of the input signal; and
- a second edge sampling circuit which adds a second offset to the signal level of the input signal and outputs a second edge value indicating a value of an edge part of the input signal,
- wherein at least one of the first offset and the second offset in one sampling circuit is determined based on a data value acquired from a location other than an output of the selector in the other sampling circuit.
2. The semiconductor device according to claim 1, wherein the first offset in the one sampling circuit in a current sampling period is determined based on the first data value outputted in the last sampling period.
3. The semiconductor device according to claim 2,
- wherein the first data sampling circuit of the other sampling circuit comprises
- a first sampler which outputs a data value corresponding to a logic level of data contained in the input signal, and
- a first latch circuit which latches the output of the first sampler, using one of the multiphase sampling clocks, and outputs the latched data as the first data value,
- wherein the first offset in the one sampling circuit is determined based on the data value outputted from the first sampler, and
- wherein the second offset in the one sampling circuit is provided as a preset fixed value.
4. The semiconductor device according to claim 1,
- wherein the first offset in the one sampling circuit in the current sampling period is determined based on a data value sampled in a second last sampling period and a data value sampled in a third last sampling period, and
- wherein the second offset in the one sampling circuit in the current sampling period is determined based on the data value sampled in the third last sampling period.
5. The semiconductor device according to claim 1, wherein the first offset and the second offset in the one sampling circuit in the current sampling period are determined based on a data value sampled in a second last sampling period and a data value sampled in a third last sampling period.
6. The semiconductor device according to claim 1, comprising:
- a sampling circuit which comprises the first sampling circuit and the second sampling circuit and outputs the data value and the edge value including the first edge value and the second edge value;
- a pattern filter which determines validity or invalidity of the edge value, based on a temporal change of the data value;
- a phase detection circuit which determines a phase difference between one of the multiphase sampling clocks and the input signal, based on the edge value determined to be valid by the pattern filter and the data value;
- a phase control circuit which outputs a phase control signal for controlling phases of the multiphase sampling clocks, in accordance with a determination result of the phase detection circuit; and
- a phase shift unit which generates multiphase clocks from a reference clock and outputs, as the multiphase sampling clocks, the multiphase clocks selected from the multiphase clocks based on the phase control signal.
7. The semiconductor device according to claim 6, wherein based on logic levels of data values outputted from the sampling circuit in successive sampling periods, the pattern filter selects and outputs one of the first edge value and the second edge value included in the edge value, and outputs a flag value indicating validity of the selected edge value.
Type: Application
Filed: Dec 7, 2015
Publication Date: Mar 24, 2016
Inventor: Katsuhiko Hata (Tokyo)
Application Number: 14/961,564