The present embodiments relate to communications systems circuits generally, and more particularly to obtaining an instantaneous measurement of a received signal voltage relative to a provided clock signal, as one component of detecting received communications signals from a high-speed multi-wire interface used for chip-to-chip communication.
In modern digital systems, digital information has to be processed in a reliable and efficient way. In this context, digital information is to be understood as information available in discrete, i.e., discontinuous values. Bits, collection of bits, but also numbers from a finite set can be used to represent digital information.
In most chip-to-chip, or device-to-device communication systems, communication takes place over a plurality of wires to increase the aggregate bandwidth. A single or pair of these wires may be referred to as a channel or link and multiple channels create a communication bus between the electronic components. At the physical circuitry level, in chip-to-chip communication systems, buses are typically made of electrical conductors in the package between chips and motherboards, on printed circuit boards (“PCBs”) boards or in cables and connectors between PCBs. In high frequency applications, microstrip or stripline PCB traces may be used.
Common methods for transmitting signals over bus wires include single-ended and differential signaling methods. In applications requiring high speed communications, those methods can be further optimized in terms of power consumption and pin-efficiency, especially in high-speed communications. More recently, vector signaling methods have been proposed to further optimize the trade-offs between power consumption, pin efficiency and noise robustness of chip-to-chip communication systems. In those vector signaling systems, digital information at the transmitter is transformed into a different representation space in the form of a vector codeword that is chosen in order to optimize the power consumption, pin-efficiency and speed trade-offs based on the transmission channel properties and communication system design constraints. Herein, this process is referred to as “encoding”. The encoded codeword is communicated as a group of signals from the transmitter to one or more receivers. At a receiver, the received signals corresponding to the codeword are transformed back into the original digital information representation space. Herein, this process is referred to as “decoding”.
Regardless of the encoding method used, the received signals presented to the receiving device is sampled (or their signal value otherwise recorded) at intervals best representing the original transmitted values, regardless of transmission channel delays, interference, and noise. The timing of this sampling or slicing operation is controlled by an associated Clock and Data Recovery (CDR) timing system, which determines the appropriate sample timing.
To reliably detect the data values transmitted over a communications system, a receiver accurately measures the received signal value amplitudes at carefully selected times. In some embodiments, the value of the received signal is first captured at the selected time using a known sample-and-hold or track-and-hold circuit (or known variants such as amplify-and-hold or integrate-and-hold), and then the resulting value is measured against one or more reference values using a known voltage comparator circuit. Other embodiments first use a comparator to “slice” the analog signal and obtain a digital result, then digitally sample the resulting binary value using a clocked digital latch. Further embodiments utilize circuits configured to apply both the time- and amplitude-domain constraints, producing a result that represents the input value at a particular time and relative to a provided reference level.
In many embodiments, a received signal source may be measured by multiple sampling circuits, either to facilitate data reception at rates greater than a single data processing system can sustain (so-called multiphase receiver architectures), or to support ancillary functions such as clock synchronization, test/diagnostic support, etc. In these embodiments, energy leakage such as from clock switching within one sampler may appear as transients at the sampler input (herein described as “kickback”), which may then perturb other sampler measurements of the common input signal. Sampler embodiments are described which produce extremely low levels of kickback energy, making them particularly desirable in such applications.
Methods and systems are described for receiving a signal to be sampled and responsively generating, at a pair of common nodes, a differential current representative of the received signal, receiving a plurality of sampling interval signals, each sampling interval signal received at a corresponding sampling phase of a plurality of sampling phases, for each sampling phase, pre-charging a corresponding pair of output nodes using a pre-charging field-effect transistor (FET) pair receiving the sampling interval signal, forming a differential output voltage by discharging the corresponding pair of output nodes via a discharging FET pair connected to the pair of common nodes, the FET pair receiving the sampling interval signal and selectively enabling the differential current to discharge the corresponding pair of output nodes, and latching the differential output voltage.
To reliably detect the data values transmitted over a communications system, a communications receiver accurately measures its received signal value amplitudes at carefully selected times, typically at or near the center of that received signal's period of stability between transitions. This point is commonly described as the “center of eye”, (referring to the well-known “eye diagram” of signal amplitude vs. clock intervals) and is typically determined by use of a local “receive clock” which is configured to occur at that desirable sampling time. Generation and ongoing control of such receive clock timing is well understood in the art, as Clock Data Alignment (CDA) systems measure and incrementally adjust sample timing versus receive signal stability time to optimize sample timing.
In some embodiments, the value of the received signal is first captured at the selected time using a sample-and-hold or track-and-hold circuit, and then the resulting value is measured against one or more reference values using a known voltage comparator circuit. In alternative embodiments, the signal amplitude is continuously measured using a voltage comparator, with the digital result then sampled in time using a clocked digital latch.
Other embodiments utilize circuits capable of applying both the time- and amplitude-domain constraints, producing a result that represents the input value at a particular time and relative to a provided reference level.
In particular, vector signaling codes of the type described in [Cronie I], [Cronie II], and [Shokrollahi II] may be efficiently decoded using so-called Multi-Input Comparators (MICs) as described in [Holden I] and [Tajalli I]. In one embodiment, each MIC performs an analog computation of the form
sign(a0*x0+ . . . +am-1*xm-1), Eqn. 1
where (x0, x1, . . . , xm-1) are the received vector signaling code values, and a0, a1, . . . , am-1 are “weighting factors” associated with each input, and the sign function is defined as:
sign(x)=+1 if x>0, sign(x)=−1 if x<0, and sign(x) is undefined if x=0.
[Holden I] also teaches that Eqn. 1 may be efficiently embodied in a differential amplifier structure having multiple positive and multiple negative inputs, each such input structure representing one element of Eqn. 1. [Ulrich I] further teaches that the weighting factors in such input structures may be efficiently represented as scaled transistor dimensions in an integrated circuit embodiment, or alternatively as paralleled multiple transistor instances where the set of weighting factors may be represented as integer values.
In vector signaling code receivers, each subchannel is composed of a MIC performing the mixing or weighted summation operations for decoding a subchannel, sampling of the resulting output, followed by implementation-specific data processing. At high data rates, four or more phases of data processing may be implemented to keep up with the received symbol rate of the decoders, with each phase typically utilizing its own sampler.
Thus, a single received signal source may be measured by multiple sampling circuits, either to facilitate data reception at rates greater than a single data processing system can sustain, or to support ancillary functions such as clock synchronization, test/diagnostic support, etc. In these embodiments, energy leakage such as from clock switching within one sampler may appear as transients at the sampler input (herein described as “kickback”), which may then perturb other sampler measurements of the common input signal. Sampler embodiments are described that produce extremely low levels of kickback energy, making them particularly desirable in such applications.
Low Kickback Sampler
In many embodiments, a received signal source may be measured by multiple sampling circuits, either to facilitate data reception at rates greater than a single data processing system can sustain (so-called multiphase receiver architectures), or to support ancillary functions such as clock synchronization, test/diagnostic support, etc. In such embodiments, energy leakage such as from clock switching within one sampler may appear as transients at the sampler input (herein described as “kickback”), which may then perturb other sampler measurements of the common input signal. Sampler embodiments are described below that produce extremely low levels of kickback energy, making them particularly desirable in such applications.
Sampler 100 is inherently two-phased, controlled by complementary clocks CK and (CK)
One of inputs VIP and VIN may alternatively be used as a reference voltage input and the other as a single-ended received signal input.
Referring to the example given in
The described architecture may be extended to support additional sampling phases within the same sampling circuit.
In some embodiments, the sampling interval signal generator may operate on a received symbol clock, which may be received on separate wires of the multi-wire bus, embedded in a sub-channel in orthogonal encoding embodiments, derived from signal transitions on the multi-wire bus, or various other ways of clock data recovery (CDR). In some embodiments, the symbol clock may be used directly, as in
In some embodiments, the received signal to be sampled is a differential input signal, such as VIN/VIP shown in
In some embodiments, the pair of common nodes are virtual ground for isolating the received signal to be sampled from the pair of output nodes.
In some embodiments, the method further includes injecting an offset voltage into the pair of common nodes, as shown for example in
In some embodiments, the plurality of sampling interval signals are non-overlapping, as shown in
Offset Voltage Compensation
The use of a single offset voltage correction circuit 200 for a single sampler 100 providing results to two processing phases results in a lower power utilization for the overall sampler system, compared to known art methods requiring one correction circuit per sampler per processing phase.
The corrective voltages may be used to adjust circuit parameters, such as to compensate for circuit imbalance caused by component mismatch or drift. Alternatively, in at least one embodiment the corrective voltages comprise signal measurement thresholds intentionally introduced to control the switching point for sampler output results. In a further embodiment the corrective voltages comprise communications network compensation values, such as produced by a Decision Feedback Compensation (DFE) system.
Combined Linear Decoder and Sampler
The clocked voltage sampler of
It should be noted that the term “circuit” may mean, among other things, a single component or a multiplicity of components, which are active and/or passive, and which are coupled together to provide or perform a desired function. The term “circuitry” may mean, among other things, a circuit, a group of such circuits, one or more processors, one or more state machines, one or more processors implementing software, one or more gate arrays, programmable gate arrays and/or field programmable gate arrays, or a combination of one or more circuits (whether integrated or otherwise), one or more state machines, one or more processors, one or more processors implementing software, one or more gate arrays, programmable gate arrays and/or field programmable gate arrays.
It should be further noted that the various circuits and circuitry disclosed herein may be described using computer aided design tools and expressed (or represented), as data and/or instructions embodied in various computer-readable media, for example, in terms of their behavioral, register transfer, logic component, transistor, layout geometries, and/or other characteristics. Formats of files and other objects in which such circuit expressions may be implemented include, but are not limited to, formats supporting behavioral languages such as C, Verilog, and HLDL, formats supporting register level description languages like RTL, and formats supporting geometry description languages such as GDSII, GDSIII, GDSIV, CIF, MEBES and any other suitable formats and languages. Computer-readable media in which such formatted data and/or instructions may be embodied include, but are not limited to, non-volatile storage media in various forms (e.g., optical, magnetic or semiconductor storage media) and carrier waves that may be used to transfer such formatted data and/or instructions through wireless, optical, or wired signaling media or any combination thereof. Examples of transfers of such formatted data and/or instructions by carrier waves include, but are not limited to, transfers (uploads, downloads, e-mail, etc.) over the Internet and/or other computer networks via one or more data transfer protocols (e.g., HTTP, FTP, SMTP, etc.). The embodiments described are also directed to such representation of the circuitry described herein, and/or techniques implemented thereby, and, as such, are intended to fall within the scope of the present embodiments.
Moreover, the various circuits and circuitry, as well as techniques, disclosed herein may be represented via simulations and simulation instruction-based expressions using computer aided design, simulation and/or testing tools. The simulation of the circuitry described herein, and/or techniques implemented thereby, may be implemented by a computer system wherein characteristics and operations of such circuitry, and techniques implemented thereby, are simulated, imitated, replicated, analyzed and/or predicted via a computer system. Simulations and testing of the devices and/or circuitry described herein, and/or techniques implemented thereby, and, as such, are intended to fall within the scope of the present embodiments. The computer-readable media and data corresponding to such simulations and/or testing tools are also intended to fall within the scope of the present embodiments.
This application is a continuation of U.S. application Ser. No. 15/494,436, filed Apr. 21, 2017, naming Armin Tajalli, entitled “Sampler with Low Input Kickback”, which claims the benefit of U.S. Provisional Application No. 62/326,596, filed Apr. 22, 2016, naming Armin Tajalli, entitled “Sampler with Low Input Kickback”, all of which are hereby incorporated herein by reference in their entirety for all purposes. The following prior applications are herein incorporated by reference in their entirety for all purposes: U. S. Patent Publication 2011/0268225 of application Ser. No. 12/784,414, filed May 20, 2010, naming Harm Cronie and Amin Shokrollahi, entitled “Orthogonal Differential Vector Signaling” (hereinafter “Cronie I”). U. S. Patent Publication 2011/0302478 of application Ser. No. 12/982,777, filed Dec. 30, 2010, naming Harm Cronie and Amin Shokrollahi, entitled “Power and Pin Efficient Chip-to-Chip Communications with Common-Mode Resilience and SSO Resilience” (hereinafter “Cronie II”). U.S. patent application Ser. No. 13/542,599, filed Jul. 5, 2012, naming Armin Tajalli, Harm Cronie, and Amin Shokrollhi entitled “Methods and Circuits for Efficient Processing and Detection of Balanced Codes” (hereafter called “Tajalli I”.) U.S. patent application Ser. No. 13/842,740, filed Mar. 15, 2013, naming Brian Holden, Amin Shokrollahi and Anant Singh, entitled “Methods and Systems for Skew Tolerance in and Advanced Detectors for Vector Signaling Codes for Chip-to-Chip Communication”, hereinafter identified as [Holden I]; U.S. Provisional Patent Application No. 61/946,574, filed Feb. 28, 2014, naming Amin Shokrollahi, Brian Holden, and Richard Simpson, entitled “Clock Embedded Vector Signaling Codes”, hereinafter identified as [Shokrollahi I]. U.S. patent application Ser. No. 14/612,241, filed Aug. 4, 2015, naming Amin Shokrollahi, Ali Hormati, and Roger Ulrich, entitled “Method and Apparatus for Low Power Chip-to-Chip Communications with Constrained ISI Ratio”, hereinafter identified as [Shokrollahi II]. U.S. patent application Ser. No. 13/895,206, filed May 15, 2013, naming Roger Ulrich and Peter Hunt, entitled “Circuits for Efficient Detection of Vector Signaling Codes for Chip-to-Chip Communications using Sums of Differences”, hereinafter identified as [Ulrich I]. U.S. patent application Ser. No. 14/816,896, filed Aug. 3, 2015, naming Brian Holden and Amin Shokrollahi, entitled “Orthogonal Differential Vector Signaling Codes with Embedded Clock”, hereinafter identified as [Holden II]. U.S. patent application Ser. No. 14/926,958, filed Oct. 29, 2015, naming Richard Simpson, Andrew Stewart, and Ali Hormati, entitled “Clock Data Alignment System for Vector Signaling Code Communications Link”, hereinafter identified as [Stewart I]. U.S. patent application Ser. No. 14/925,686, filed Oct. 28, 2015, naming Armin Tajalli, entitled “Advanced Phase Interpolator”, hereinafter identified as [Tajalli II]. U.S. Provisional Patent Application No. 62/286,717, filed Jan. 25, 2016, naming Armin Tajalli, entitled “Voltage Sampler Driver with Enhanced High-Frequency Gain”, hereinafter identified as [Tajalli III].
Number | Name | Date | Kind |
---|---|---|---|
3636463 | Ongkiehong | Jan 1972 | A |
3824494 | Wilcox | Jul 1974 | A |
3939468 | Mastin | Feb 1976 | A |
5459465 | Kagey | Oct 1995 | A |
5510736 | Van de Plassche | Apr 1996 | A |
5748948 | Yu | May 1998 | A |
6384758 | Michalski | May 2002 | B1 |
6462584 | Proebsting | Oct 2002 | B1 |
6563382 | Yang | May 2003 | B1 |
6624699 | Yin | Sep 2003 | B2 |
6839587 | Yonce | Jan 2005 | B2 |
6879816 | Bult | Apr 2005 | B2 |
7075996 | Simon | Jul 2006 | B2 |
7199728 | Dally | Apr 2007 | B2 |
7269212 | Chau | Sep 2007 | B1 |
7397302 | Bardsley | Jul 2008 | B2 |
7656321 | Wang | Feb 2010 | B2 |
7688102 | Bae | Mar 2010 | B2 |
7697915 | Behzad | Apr 2010 | B2 |
7804361 | Lim | Sep 2010 | B2 |
8000664 | Khorram | Aug 2011 | B2 |
8030999 | Chatterjee | Oct 2011 | B2 |
8159375 | Abbasfar | Apr 2012 | B2 |
8159376 | Abbasfar | Apr 2012 | B2 |
8183930 | Kawakami | May 2012 | B2 |
8547272 | Nestler | Oct 2013 | B2 |
8581824 | Baek | Nov 2013 | B2 |
8604879 | Mourant | Dec 2013 | B2 |
8643437 | Chiu | Feb 2014 | B2 |
8687968 | Nosaka | Apr 2014 | B2 |
8791735 | Shibasaki | Jul 2014 | B1 |
8841936 | Nakamura | Sep 2014 | B2 |
9069995 | Cronie | Jun 2015 | B1 |
9106465 | Walter | Aug 2015 | B2 |
9148087 | Tajalli | Sep 2015 | B1 |
9178503 | Hsieh | Nov 2015 | B2 |
9281785 | Sjoland | Mar 2016 | B2 |
9292716 | Winoto | Mar 2016 | B2 |
9300503 | Holden | Mar 2016 | B1 |
20010006538 | Simon | Jul 2001 | A1 |
20020149508 | Hamashita | Oct 2002 | A1 |
20020158789 | Yoshioka | Oct 2002 | A1 |
20020174373 | Chang | Nov 2002 | A1 |
20030016763 | Doi | Jan 2003 | A1 |
20030085763 | Schrodinger | May 2003 | A1 |
20030160749 | Tsuchi | Aug 2003 | A1 |
20030174023 | Miyasita | Sep 2003 | A1 |
20030184459 | Engl | Oct 2003 | A1 |
20030218558 | Mulder | Nov 2003 | A1 |
20040027185 | Fiedler | Feb 2004 | A1 |
20040169529 | Afghahi | Sep 2004 | A1 |
20050270098 | Zhang | Dec 2005 | A1 |
20060036668 | Jaussi | Feb 2006 | A1 |
20060097786 | Su | May 2006 | A1 |
20060103463 | Lee | May 2006 | A1 |
20070176708 | Otsuka | Aug 2007 | A1 |
20070182487 | Ozasa | Aug 2007 | A1 |
20070201546 | Lee | Aug 2007 | A1 |
20080001626 | Bae | Jan 2008 | A1 |
20080187037 | Bulzacchelli | Aug 2008 | A1 |
20090090333 | Spadafora | Apr 2009 | A1 |
20090115523 | Akizuki | May 2009 | A1 |
20090323864 | Tired | Dec 2009 | A1 |
20100148819 | Bae | Jun 2010 | A1 |
20100156691 | Taft | Jun 2010 | A1 |
20100219781 | Kuwamura | Sep 2010 | A1 |
20100235673 | Abbasfar | Sep 2010 | A1 |
20100271107 | Tran | Oct 2010 | A1 |
20110028089 | Komori | Feb 2011 | A1 |
20110032977 | Hsiao | Feb 2011 | A1 |
20110051854 | Kizer | Mar 2011 | A1 |
20110096054 | Cho | Apr 2011 | A1 |
20110103508 | Mu | May 2011 | A1 |
20110133816 | Wu | Jun 2011 | A1 |
20120044021 | Yeh | Feb 2012 | A1 |
20120133438 | Tsuchi | May 2012 | A1 |
20130106513 | Cyrusian | May 2013 | A1 |
20130114663 | Ding | May 2013 | A1 |
20130147553 | Iwamoto | Jun 2013 | A1 |
20130195155 | Pan | Aug 2013 | A1 |
20130215954 | Beukema | Aug 2013 | A1 |
20130259113 | Kumar | Oct 2013 | A1 |
20130334985 | Kim | Dec 2013 | A1 |
20140119479 | Tajalli | May 2014 | A1 |
20140177696 | Hwang | Jun 2014 | A1 |
20140203794 | Pietri | Jul 2014 | A1 |
20140266440 | Itagaki | Sep 2014 | A1 |
20140312876 | Hanson | Oct 2014 | A1 |
20150070201 | Dedic | Mar 2015 | A1 |
20150146771 | Walter | May 2015 | A1 |
20150198647 | Atwood | Jul 2015 | A1 |
20160013954 | Shokrollahi | Jan 2016 | A1 |
20160197747 | Ulrich | Jul 2016 | A1 |
Number | Date | Country | |
---|---|---|---|
20180302212 A1 | Oct 2018 | US |
Number | Date | Country | |
---|---|---|---|
62326596 | Apr 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15494436 | Apr 2017 | US |
Child | 16012646 | US |