WO2005072329A2 - Communication channel calibration for drift conditions - Google Patents
Communication channel calibration for drift conditions Download PDFInfo
- Publication number
- WO2005072329A2 WO2005072329A2 PCT/US2005/002301 US2005002301W WO2005072329A2 WO 2005072329 A2 WO2005072329 A2 WO 2005072329A2 US 2005002301 W US2005002301 W US 2005002301W WO 2005072329 A2 WO2005072329 A2 WO 2005072329A2
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- component
- calibration
- transmitter
- parameter
- calibration pattern
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/24—Testing correct operation
- H04L1/242—Testing correct operation by comparing a transmitted test signal with a locally generated replica
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/02—Detection or location of defective auxiliary circuits, e.g. defective refresh counters
- G11C29/022—Detection or location of defective auxiliary circuits, e.g. defective refresh counters in I/O circuitry
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/02—Detection or location of defective auxiliary circuits, e.g. defective refresh counters
- G11C29/025—Detection or location of defective auxiliary circuits, e.g. defective refresh counters in signal lines
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/02—Detection or location of defective auxiliary circuits, e.g. defective refresh counters
- G11C29/028—Detection or location of defective auxiliary circuits, e.g. defective refresh counters with adaption or trimming of parameters
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1051—Data output circuits, e.g. read-out amplifiers, data output buffers, data output registers, data output level conversion circuits
- G11C7/1057—Data output buffers, e.g. comprising level conversion circuits, circuits for adapting load
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1078—Data input circuits, e.g. write amplifiers, data input buffers, data input registers, data input level conversion circuits
- G11C7/1084—Data input buffers, e.g. comprising level conversion circuits, circuits for adapting load
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L25/00—Baseband systems
- H04L25/02—Details ; arrangements for supplying electrical power along data transmission lines
- H04L25/0264—Arrangements for coupling to transmission lines
- H04L25/0292—Arrangements specific to the receiver end
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L25/00—Baseband systems
- H04L25/02—Details ; arrangements for supplying electrical power along data transmission lines
- H04L25/12—Compensating for variations in line impedance
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L27/00—Modulated-carrier systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L7/00—Arrangements for synchronising receiver with transmitter
- H04L7/0016—Arrangements for synchronising receiver with transmitter correction of synchronization errors
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L7/00—Arrangements for synchronising receiver with transmitter
- H04L7/0079—Receiver details
- H04L7/0087—Preprocessing of received signal for synchronisation, e.g. by code conversion, pulse generation or edge detection
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L7/00—Arrangements for synchronising receiver with transmitter
- H04L7/0091—Transmitter details
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L7/00—Arrangements for synchronising receiver with transmitter
- H04L7/04—Speed or phase control by synchronisation signals
- H04L7/10—Arrangements for initial synchronisation
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C2207/00—Indexing scheme relating to arrangements for writing information into, or reading information out from, a digital store
- G11C2207/22—Control and timing of internal memory operations
- G11C2207/2254—Calibration
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/04—Arrangements for writing information into, or reading information out from, a digital store with means for avoiding disturbances due to temperature effects
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L7/00—Arrangements for synchronising receiver with transmitter
- H04L7/02—Speed or phase control by the received code signals, the signals containing no special synchronisation information
- H04L7/033—Speed or phase control by the received code signals, the signals containing no special synchronisation information using the transitions of the received signal to control the phase of the synchronising-signal-generating means, e.g. using a phase-locked loop
Definitions
- the present invention relates to the calibration of communication channel parameters in systems, including mesochronous systems, in which two (or more) components communicate via an interconnection link; and to the calibration needed to account for drift of conditions related to such parameters during operation of the communication channels.
- a reference clock provides frequency and phase information to the two components at either end of the link.
- a transmitter on one component and a receiver on another component each connect to the link.
- the transmitter and receiver operate in different clock domains, which have an arbitrary (but fixed) phase relationship to the reference clock.
- the phase relationship between transmitter and receiver is chosen so that the propagation delay seen by a signal wavefront passing from the transmitter to the receiver will not contribute to the timing budget when the signaling rate is determined. Instead, the signaling rate will be determined primarily by the drive window of the transmitter and the sample window of the receiver. The signaling rate will also be affected by a variety of second order effects.
- This system is clocked in a mesochronous fashion, with the components locked to specific phases relative to the reference clock, and with the drive-timing-point and sample-timing-point of each link fixed to the phase values that maximize the signaling rate.
- These fixed phase values may be determined in a number of ways.
- a sideband link may accompany a data link (or links), permitting phase information to be passed between transmitter and receiver.
- an initialization process may be invoked when the system is first given power, and the proper phase values determined by passing calibration information (patterns) across the actual link.
- the drive-timing-point and sample-timing-point of each link has been fixed, the system is permitted to start normal operations. [0004] However, during normal operation, system conditions will change.
- a channel parameter may be calibrated as a function of one or more changing operating conditions or programmed settings. In many cases, drifting parameters will be plotted in the form of a two-dimensional Schmoo plot for analysis.
- Examples of programmed settings which might be subject of calibration, or which might cause drift in other channel parameters, include transmitter amplitude, transmitter drive strength, transmitter common- mode offset, receiver voltage reference, receiver common-mode offset, and line termination values.
- transmitter amplitude As the conditions drift or change, the optimal timing points of the transmitter and receiver will change. If the timing points remain at their original values, then margin must be added to the timing windows to ensure reliable operation. This margin will reduce the signaling rate of the link.
- the present invention provides a system and method for calibrating a communication channel, which allows for optimizing timing windows and accounting for drift of properties of the channel.
- a communication channel includes a first component having a transmitter coupled to a normal data source, and at least a second component having a receiver coupled to a normal signal destination.
- a communication link couples the first and second components, and other components on the link.
- the present invention includes a method and system that provides for execution of calibration cycles from time to time during normal operation of the communication channel.
- a calibration cycle includes de-coupling the normal data source from the transmitter and supplying a calibration pattern in its place. The calibration pattern is transmitted on the link using the transmitter on the first component.
- the normal data source is re-coupled to the transmitter.
- the calibration pattern is received from the communication link using the receiver on the second component.
- a calibrated value of a parameter of the communication channel is determined in response to the received calibration pattern.
- the communication channel is bidirectional, so that the first component includes both a transmitter and a receiver, and second component likewise includes both a transmitter and receiver.
- the communication channel transmits data using the transmitter on the first component and receives data using the receiver on the second component with a first parameter of the communication channel, such as one of a receive and transmit timing point for the transmissions from the first to the second component, set to an operation value, and receives data using the receiver on the first component and transmits data using the transmitter on the second component with a second parameter of the communication channel, such as one of a receive and transmit timing point for the transmissions from the second to the first component, set to an operation value.
- a first parameter of the communication channel such as one of a receive and transmit timing point for the transmissions from the first to the second component, set to an operation value
- a second parameter of the communication channel such as one of a receive and transmit timing point for the transmissions from the second to the first component
- a method comprises: storing a value of a first edge parameter and a value of a second edge parameter, wherein an operation value of said parameter of the communication channel is a function of the first and second edge parameters; executing a calibration cycle; the calibration cycle including iteratively adjusting the value of the first edge parameter, transmitting a calibration pattern using the transmitter on the first component, receiving the calibration pattern using the receiver on the second component, and comparing the received calibration pattern with a stored calibration pattern, to determine an updated value for the first edge value; the calibration cycle also including iteratively adjusting the value of the second edge parameter, transmitting a calibration pattern using the transmitter on the first component, receiving the calibration pattern using the receiver on the second component, and comparing the received calibration pattern with a stored calibration pattern, to determine an updated value for the second edge value; and as a result of the calibration cycle, determining a new operation value for the parameter based on the function of the updated values of the first and second edge parameters.
- Some embodiments of the invention comprise a calibration method comprising: executing a calibration cycle including transmitting a calibration pattern using the transmitter on the first component and receiving the calibration pattern using the receiver on the second component with the first parameter set to a calibration value, and determining a calibrated value of the first parameter in response to the received calibration pattern; and prior to determining said calibrated value of said calibration cycle, transmitting data using the transmitter on the second component and receiving the data using the receiver on the first component with the second parameter set to the operation value.
- Methods according to some embodiments of the invention comprise executing calibration cycles from time to time, the calibration cycles comprising: de-coupling the data source from the transmitter; adjusting the parameter to a calibration value; supplying a calibration pattern to the transmitter; transmitting the calibration pattern on the communication link using the transmitter on the first component; receiving the calibration pattern on the communication link using the receiver on the second component; re-coupling the data source to the transmitter and setting the parameter to the operation value; and determining a calibrated value of the parameter of the communication channel in response to the received calibration pattern, wherein said re- coupling occurs prior to said determining.
- a variety of parameters of the communication channel can be calibrated according to the present invention.
- the parameter being calibrated is a transmit timing point for the transmitter of the first component. In some embodiments, the parameter being calibrated is a receive timing point for the receiver of the second component. In yet other embodiments including bidirectional links, the parameter being calibrated is a receive timing point for the receiver of the first component. Also, embodiments of the present invention including bidirectional links provide for calibration of both receive timing points and transmit timing points for the receiver and transmitter respectively of the first component. [0013] In some embodiments that include bidirectional links, calibration cycles are executed which include a step of storing received calibration patterns on the second component, and retransmitting such calibration patterns back to logic on the first component for use in calibrating receive or transmit timing points in the first component.
- the second component provides storage for holding the received calibration patterns for a time period long enough to allow the first component to complete transmission of a complete calibration pattern, or at least a complete segment of a calibration pattern.
- the storage can be embodied by special-purpose memory coupled with the receiver on the second component, or it can be provided by management of memory space used by the normal destination on the second component.
- the second component comprises an integrated circuit memory device in some embodiments, where the memory device includes addressable memory space. The storage provided for use by the calibration cycles is allocated from addressable memory space in the memory device in these embodiments.
- calibration patterns may be stored in the latch type sense amplifiers while decoupling the sense amplifiers from the normally addressable memory space.
- the second component comprises an integrated circuit memory having addressable memory space within a memory array
- a segment of the memory array outside of the normally addressable memory space is allocated for use by the calibration cycles.
- utilization of memory at the second component can be improved by providing cache memory or temporary memory on the first component. In such embodiments, accesses to the memory array in the second component attempted during a calibration cycle are directed to a cache memory on the first component.
- a segment of the addressable memory in the second component to be used for storage of the calibration pattern is copied into temporary storage on the first component for use during the calibration cycle.
- parameters which are updated by the calibration process are applied to the communication channel so that drift in properties of the communication channel can be tracked to improve reliability and increase operating frequency of the channel.
- the steps involved in calibration cycles are reordered to account for utilization patterns of the communication channel. For low latency processes, for example the step of applying the updated parameter is delayed, so that normal transmit and receive processes can be resumed as soon as the calibration pattern has been transmitted, and without waiting for computation of updated parameters. For example, the updated parameter calculated during one calibration cycle is not applied to the communication channel, until a next calibration cycle is executed.
- the calibration cycle includes a first segment in which calibration patterns are transmitted, and a second segment in which updated parameters calculated during the calibration cycle are applied, so that the time interval between completion of transmission of the calibration pattern and completion of the calculation of the updated parameters is utilized for normal transmission and receive operations.
- Fig. 1 is a simplified diagram of two components interconnected by a communication channel.
- Fig. 2 is a timing diagram illustrating timing parameters for a communication channel like that shown in Fig. 1.
- Fig. 3 illustrates an embodiment of the present invention where both a transmitter drive point and a receiver sample point are adjustable.
- Fig. 4 illustrates an embodiment of the present invention where only a receiver sample point is adjustable.
- Fig. 5 illustrates an embodiment of the present invention where only a transmitter drive point is adjustable.
- Fig. 6 is a flow chart illustrating calibration steps for a transmitter on a unidirectional link for a transmitter drive point.
- Fig. 7 illustrates timing for iteration steps for calibrating a transmitter drive point.
- Fig. 8 is a flow chart illustrating calibration steps for a receiver on a unidirectional link for a sample point.
- Fig. 9 illustrates timing for iteration steps for calibrating a receiver sample point.
- Fig. 10 illustrates an embodiment of the present invention where transmitter drive points and receiver sample points on components of a bidirectional link are adjustable.
- Fig. 11 illustrates an embodiment of the present invention where receiver sample points on components of a bidirectional link are adjustable.
- Fig. 12 illustrates an embodiment of the present invention where both components have adjustable transmitter drive points.
- Fig. 13 illustrates an embodiment of the present invention where a transmitter drive point and a receiver sample point of only one component on a bidirectional link are adjustable.
- Fig. 14 is a flow chart illustrating calibration steps for a transmitter drive point for a bidirectional link.
- Fig. 15 is a flow chart illustrating calibration steps for a receiver sample point for a bidirectional link.
- Figs. 16 and Fig. 17 illustrate time intervals for operation of components on a bidirectional link during calibration using a system like that of Fig. 13.
- Fig. 18 illustrates a first embodiment of the invention including storage for calibration patterns on one component.
- Fig. 19 illustrates a second embodiment of the invention including storage within a memory core used for storage of calibration patterns on one component sharing a bidirectional link.
- Fig. 20 illustrates a third embodiment of the invention including storage within a memory core for storage of calibration patterns on one component sharing a bidirectional link, and a cache supporting use of a region of the memory core for this purpose.
- Fig. 21 illustrates a fourth embodiment of the invention including storage within a memory core for storage of calibration patterns on one component sharing a bidirectional link, and temporary storage supporting use of the region of the memory core for this purpose.
- Fig. 22 illustrates a fifth embodiment of the invention including storage within sense amplifiers, which are used for storage of calibration patterns during calibration on one component sharing a bidirectional link.
- Fig. 23 is a flow chart illustrating calibration steps for a transmitter on a unidirectional link for a transmitter drive point, with re-ordered steps for improved throughput.
- Fig. 24A and 24B are flow charts illustrating calibration steps for a transmitter drive point for a bidirectional link, with re-ordered steps for improved throughput.
- Fig. 25 illustrates an embodiment of the present invention where a transmitter drive point and a receiver sample point of one component on a bidirectional link are adjustable with a plurality of parameter sets, and wherein the bidirectional link is coupled to a plurality of other components corresponding to the plurality of parameter sets.
- Fig. 1 shows two components 10, 11 connected with an interconnection medium, referred to as Link 12.
- One has a transmitter circuit 13 which drives symbols (bits) on Link 12 in response to rising-edge timing events on the internal CLKT signal 14. This series of bits forms signal DATAT.
- the other has a receiver circuit 15 which samples symbols (bits) on Link 12 in response to rising- edge timing events on the internal CLKR signal 16. This series of bits forms signal DATAR.
- Fig. 2 illustrates the timing parameters, including the transmit clock CLKT signal 14 on trace 20, the transmitter signal DATAT on trace 21, the receive clock CLKR signal 16 on trace 22, and the receiver signal DATAR on trace 23.
- the transmitter eye 24 and the receiver eye 25 are also illustrated.
- the transmitter eye 24 is a window during which the signal DATAT is transmitted on the link.
- the receiver eye is a sampling window defined by the ts setup time and tH hold time which surround the CLKR rising edge 35, 36 and define the region in which the value of DATAR must be stable for reliable sampling. Since the valid window of the DATAT signal is larger than this setup/hold sampling window labeled receiver eye 25, the receiver has timing margin in both directions.
- DATAT and DATAR signals are related; DATAR is an attenuated, time-delayed copy of DATAT.
- the attenuation and time-delay occur as the signal wavefronts propagate along the interconnection medium of Link 12.
- the transmitter circuit 13 will begin driving a bit (labeled "a") no later than a time to ,MA x after a rising edge 30 of CLKT, and will continue to drive it during transmitter eye 24 until at least a time tv,MN after the next rising edge 31.
- to,MAX and tvj ⁇ N are the primary timing parameters of the transmitter circuit 13. These two values are specified across the full range of operating conditions and processing conditions of the communication channel.
- IQ,MA X will be larger than tv,MiN > and the difference will represent the dead time or dead band 32 of the transmitter circuit 13.
- the transmitter dead band 32 (to EAD, ⁇ )is the portion of the bit timing window (also called bit time or bit window) that is consumed by the transmitter circuit 13: t ⁇ EAD,T """*" t ⁇ ,MAX " tv,MIN
- the receiver circuit 15 will sample a bit (labeled "a") during the receiver eye 25 no earlier than a time ts,MiN before a rising edge 35 of CLKR, and no later than a time tH,MiN after the rising edge 35.
- ts,MiN and t ⁇ ,MiN are the primary timing parameters of the receiver circuit. These two values are specified across the full range of operating conditions and processing conditions of the circuit.
- the sum of ts,MiN and tH,MiN will represent the dead time or dead band 37, 38 of the receiver.
- the bit timing window (receiver eye 25) is one tcycLE minus the tDEAD, ⁇ and toEAD,R values, each of which is about 1/3 of one tcyc E in this example.
- Fig. 3 shows two components 100 (transmit component) and 101 (receive component) connected with an interconnection medium referred to as Link 102.
- the link is assumed to carry signals in one direction only (unidirectional), so one component 100 has a transmitter circuit 103 coupled to a data source 110 labeled "normal path," and one component 101 has a receiver circuit 104 coupled to a destination 111 labeled "normal path".
- the transmitter component includes a block 105 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of transmit calibration patterns.
- the transmitter drive point can be adjusted by the block 107 labeled "adjust”.
- a sideband communication channel 113 is shown coupled between the component 101 and the component 100, by which the results of analysis of received calibration patterns at the component 101 are supplied to the adjust block 107 of the component 100.
- the receiver component 101 includes a block 108 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of expected patterns.
- a block 109 labeled “compare” enables the received pattern set to be compared to the expected pattern set, and causes an adjustment to be made to either the transmitter or receiver.
- the receiver sample point can be adjusted by the block 112 labeled "adjust".
- Fig. 4 shows two components 100, 101 connected with a unidirectional link 102, in which components of Fig. 3 are given like reference numerals.
- Fig. 4 only the receiver sample point can be adjusted; the transmitter drive point remains fixed during system operation.
- there is no adjust block 107 in the component 100 nor is there a need for sideband communication channel 113 of Fig. 4.
- Fig. 5 shows two components 100, 101 connected with a unidirectional link 102, in which components of Fig. 3 are given like reference numerals.
- Fig. 5 shows two components 100, 101 connected with a unidirectional link 102, in which components of Fig. 3 are given like reference numerals.
- only the transmitter drive point can be adjusted; the receiver sample point remains fixed during system operation.
- periodic timing calibration can be performed on all three examples, since timing variations due to condition drift can be compensated at either the transmitter end or the receiver end.
- system of Fig. 4 does not need to communicate information from the "compare" block 109 in the receiver component 101 back to the transmitter component 100, and thus might have implementation benefits over system of Fig. 5.
- Fig. 6 shows the example from Fig. 5, and also includes the steps needed to perform a timing calibration update.
- Step 601 Suspend normal transmit and receive operations, by completing transactions in progress and preventing new ones from beginning, or by interrupting transactions that are in progress.
- Step 602 Change the drive point of the transmit component from the "TX" operation value (used for normal operations) to either the "TXA” or "TXB" edge value (used for calibration operations) in the "adjust" block.
- the "TX" operation value may be a simple average of "TXA” and "TXB," i.e. a center value, or it may be another function of "TXA” and "TXB,” such as a weighted average. It may be necessary to impose a settling delay at this step to allow the new drive point to become stable.
- Step 603 Change "mux" block of the transmit component so that the "pattern” block input is enabled.
- Step 604 A pattern set is created in the "pattern" block of the transmit component and is transmitted onto the "link” using the TXA or TXB drive point.
- Step 605 The pattern set is received in the receive component. Note that the sample point of the receiver is fixed relative to the reference clock of the system.
- Step 606 The received pattern set is compared in the "compare” block to the expected pattern set produced by the "pattern” block in the receive component.
- the two pattern sets will either match or not match. As a result of this comparison (and possibly other previous comparisons) a pass or fail determination will be made.
- Step 607 Adjust either the "TXA” or “TXB” edge value in the transmit component as a result of the pass or fail determination.
- the "TX" operation value in the transmit component is also adjusted.
- This adjustment may only be made after a calibration sequence including transmission of two or more of calibration patterns has been executed, in order to ensure some level of repeatability.
- Step 608 Change the drive point of the transmitter from the "TXA” or “TXB” edge value (used for calibration operations) to "TX” operation value (used for normal operations) in the "adjust" block of the transmit component. It may be necessary to impose a settling delay at this step to allow the new drive point to become stable.
- Step 609 Change "mux" block of the transmit component so that the "normal path" input is enabled.
- Step 610 Resume normal transmit and receive operations.
- Fig. 7 includes the timing waveforms used by the calibration steps of Fig. 6 for a system like that of Fig. 5. These timing waveforms are similar to those from Fig. 2, except that the drive point is adjusted to straddle the sampling window of the receiver in order to track the edges of the valid window of the transmitter.
- the "adjust" block in the transmit component maintains three values in storage: TXA, TX, and TXB.
- the TX value is the operation value used for normal operation.
- the TXA and TXB are the "edge" values, which track the left and right extremes of the bit window of the transmitter.
- the TX value is derived from the average of the TXA and TXB values, but other relationships are possible.
- the TXA and TXB values are maintained by the calibration operations, which from time to time, and periodically in some embodiments, interrupt normal operations.
- the position of the rising edge of CLKT has an offset of tpHASE T relative to a fixed reference (typically a reference clock that is distributed to all components).
- the rising edge 702 of CLKT causes the DATAT window 703 containing the value "a" to be aligned so that the DATAR signal (not shown but conceptually overlapping with the DATAT signal) at the receiving component is aligned with the receiver clock, successfully received, and ideally centered on the receiver eye.
- the rising edge of CLKT is set to a time that causes the right edges of the DATAT window 706 (containing "a") and the receiver setup/hold window 710 (shaded) to coincide.
- the ts setup time and n hold time surround the CLKR rising edge, together define the setup/hold window 710 (not to be confused with the receiver eye of Fig. 2) in which the value of DATAR must be stable for reliable sampling around a given CLKR rising edge 704. Since the DATAT window, and the resulting DATAR window, are larger than this setup/hold window 710, the transmitter has timing margin.
- the calibration process for TXA will compare the received pattern set to the expected pattern set, and determine if they match. If they match (pass) then the TXA value will be decremented (the T PHASET(TXA ) offset becomes smaller shifting the transmit window 706 to the left in Fig. 7) or otherwise adjusted, so there is less margin for the ty timing parameter relative to the receiver window 710. If they do not match (fail) then the TXA value will be incremented (the T PHASET(TXA ) offset becomes larger shifting the transmit window 706 to the right in Fig. 7, or otherwise adjusted, so there is more margin for the ty timing parameter.
- the results of a sequence including transmission of two or more calibration patterns may be accumulated before the TXA value is adjusted. This would improve the repeatability of the calibration process.
- the calibration pattern could be repeated "N" times with the number of passes accumulated in a storage element. If all N passes match, then the TXA value is decremented. If any of the N passes does not match, then the TXA value is determined to have reached the edge of the window and is incremented. In another alternative, after the Nth pattern, the TXA value could be incremented if there are fewer than N/2 (or some other threshold number) passes, and decremented if there are N/2 or more passes.
- the TX value When TXA is updated, the TX value will also be updated. In this example, the TX value will updated by half the amount used to update TXA, since TX is the average of the TXA and TXB values. If TX has a different relationship to TXA and TXB, the TX update value will be different. Note that in some embodiments, the TX value will need slightly greater precision than the TXA and TXB values to prevent round-off error. In alternate embodiments, the TX value can be updated after pass/fail results of TXA and TXB values have been determined. In some cases, these results may cancel and produce no change to the optimal TX value.
- the calibration process will compare the received pattern set to the expected pattern set, and determine if they match. If they match (pass) then the TXB value will be incremented (the offset becomes larger) or otherwise adjusted, so there is less margin for the tQ timing parameter. If they do not match (fail) then the TXB value will be decremented (the offset becomes smaller) or otherwise adjusted, so there is more margin for the tQ timing parameter.
- the results of transmission of two or more calibration patterns may be accumulated before the TXB value is adjusted. For example, transmission of the patterns could be repeated "N" times with the number of passes accumulated in a storage element. After the Nth sequence the TXB value could be decremented if there are fewer than N/2 passes and incremented if there are N/2 or more passes. This would improve the repeatability of the calibration process.
- TXB When TXB is updated, the TX value will also be updated. In this example, the TX value will updated by half the amount used to update TXB, since TX is the average of the TXA and TXB values. If TX has a different relationship to TXA and TXB, the TX update value will be different. Note that the TX value will need slightly greater precision than the TXA and TXB values if it is desired to prevent round-off error.
- Fig. 8 shows the example from Fig. 4, and also includes the steps needed to perform a timing calibration update.
- the circuit blocks affected by each step are labeled with the step number.
- Step 801 Suspend normal transmit and receive operations, by completing transactions in progress and preventing new ones from beginning, or by interrupting transactions that are in progress.
- Step 802 Change the sample point of the receive component from the "RX” operation value (used for normal operations) to either the "RXA” or “RXB” edge value (used for calibration operations) in the “adjust” block.
- the "RX” operation value may be a simple average of "RXA” and “RXB,” i.e. a center value, or it may be another function of "RXA” and “RXB,” such as a weighted average. It may be necessary to impose a settling delay at this step to allow the new sample point to become stable.
- Step 803 Change "mux" block of the transmit component so that the "pattern” block input is enabled.
- Step 804 A pattern set is created in the "pattern" block of the transmit component and is transmitted onto the "link” using the TXA or TXB drive point.
- Step 805 The pattern set is received in the receive component. Note that the transmit point of the transmitter is fixed relative to the reference clock of the system.
- Step 806 The received pattern set is compared in the "compare” block to the expected pattern set produced by the "pattern” block in the receive component. The two pattern sets will either match or not match. As a result of this comparison (and possibly other previous comparisons) a pass or fail determination will be made.
- Step 807 Adjust either the "RXA” or “RXB” edge value in the receive component as a result of the pass or fail determination.
- the "RX” operation value in the transmit component is also adjusted.
- This adjustment may only be made after two or more of these calibration sequences have been executed, in order to ensure some level of repeatability.
- Step 808 Change the sample point of the receiver from the "RXA” or “RXB” edge value (used for calibration operations) to "RX” operation value (used for normal operations) in the "adjust" block of the receive component. It may be necessary to impose a settling delay at this step to allow the new sample point to become stable.
- Step 809 Change "mux" block of the transmit component so that the "normal path” input is enabled.
- Step 810 Resume normal transmit and receive operations.
- Fig. 9 shows includes the timing waveforms used by the receiver calibration steps of Fig.
- the "adjust" block in the receive component maintains three values in storage: RXA, RX, and RXB.
- the RX value is the operation value used for normal operation.
- the RXA and RXB are the "edge" values, which track the left and right extremes of the bit window.
- the RX value is derived from the average of the RXA and RXB values, but other relationships are possible.
- the RXA and RXB values are maintained by the calibration operations, which periodically or otherwise from time to time interrupt normal operations.
- the position of the rising edge of CLKR has an offset of tp HASE relative to a fixed reference (not shown, typically a reference clock that is distributed to all components). This offset is determined by the RXA, RX, and RXB values that are stored.
- the RX value is selected (I. PHASER(RX) in the middle trace 901 showing a CLKR timing waveform) for use in receiving data
- the rising edge 902 of CLKR is approximately centered in the receiver eye of the DATAR signal containing the value "a”.
- the DATAR signal is the DATAT signal transmitted at the transmitter after propagation across the link, and can be conceptually considered to be the same width as DATAT as shown in Fig. 9.
- the receiver eye is shown in Fig. 2.
- the ts setup time is the minimum time before the clock CLKR rising edge which must be within the DATAR window 903
- the I H hold time is the minimum time after the clock CLKR rising edge that must be within the DATAR window 903, together defining the setup/hold window 904 (not to be confused with the receiver eye of Fig. 2) in which the value of DATAR must be stable for reliable sampling around a given CLKR rising edge. Since the valid window 904 of the
- DATAR signal is larger than this setup/hold window 904, the receiver has timing margin in both directions.
- the rising edge of CLKR is approximately a time ts later than the left edge (the earliest time) of the DATAR window 903 containing the value "a".
- the CLKR rising edge is on the left edge of the receiver eye, and all the timing margin is on the right side of the setup/hold window 904, providing more room than is required by the t ⁇ timing parameter. This means that there will be essentially no margin for the ts timing parameter, defining the left edge of the calibration window.
- the calibration process will compare the received pattern set to the expected pattern set, and determine if they match. If they match (pass) then the RXA value will be decremented (the offset becomes smaller) or otherwise adjusted, so there is less margin for the ts timing parameter. If they do not match (fail) then the RXA value will be incremented (the offset becomes larger) or otherwise adjusted, so there is more margin for the ts timing parameter.
- the results of transmission and reception of two or more calibration patterns may be accumulated before the RXA value is adjusted.
- the patterns could be repeated "N" times with the number of passes accumulated in a storage element. After the Nth sequence the RXA value could be incremented if there are fewer than N/2 passes and decremented if there are N/2 or more passes. This would improve the repeatability of the calibration process.
- RXA When RXA is updated, the RX value will also be updated. In this example, the RX value will updated by half the amount used to update RXA, since RX is the average of the RXA and RXB values. If RX has a different relationship to RXA and RXB, the RX update value will be different. Note that in some embodiments, the RX value will need slightly greater precision than the RXA and RXB values to prevent round-off error. In alternate embodiments, the RX value can be updated after pass/fail results of RXA and RXB values have been determined. In some cases, these results may cancel and produce no change to the optimal RX value.
- the rising edge of CLKR is approximately a time t ⁇ earlier than the right edge (the latest time) of the DATAR window 903 containing the value "a".
- the CLKR rising edge is on the right edge of the receiver eye, and all the timing margin is on the left side of the window 904, providing more room that required by the ts timing parameter. This means that there will be essentially no margin for the t ⁇ timing parameter, defining the right edge of the calibration window.
- the calibration process will compare the received pattern set to the expected pattern set, and determine if they match. If they match (pass) then the RXB value will be incremented (the offset becomes larger) or otherwise adjusted, so there is less margin for the tH timing parameter. If they do not match (fail) then the RXB value will be decremented (the offset becomes smaller) or otherwise adjusted, so there is more margin for the t ⁇ timing parameter.
- the results of transmission and reception of two or more calibration patterns may be accumulated before the RXB value is adjusted.
- the sequence could be repeated "N" times with the number of passes accumulated in a storage element. After the Nth sequence the RXB value could be decremented if there are fewer than N/2 passes and incremented if there are N/2 or more passes. This would improve the repeatability of the calibration process.
- RXB When RXB is updated, the RX value will also be updated. In this example, the RX value will updated by half the amount used to update RXB, since RX is the average of the RXA and RXB values. If RX has a different relationship to RXA and RXB, the RX update value will be different. Note that the RX value will need slightly greater precision than the RXA and RXB values if it is desired to prevent round-off error.
- Fig. 10 shows an example of a bidirectional link.
- component A (1000) and component B (1001) each contain a transmitter and receiver connected to the link, so that information may be sent either from A to B or from B to A.
- the elements of the unidirectional example in Fig. 3 is replicated (two copies) to give the bidirectional example in Fig. 10.
- Fig. 10 shows two bidirectional components 1000, 1001 connected with an interconnection medium referred to as Link 1002.
- Normal path 1010 acts as a source of data signals for normal operation of component 1000 during transmit operations.
- Normal path 1031 acts as a destination of data signals for component 1000, during normal receive operations.
- normal path 1030 acts as a source of data signals for normal operation of component 1001 during transmit operations.
- Normal path 1011 acts as a destination of data signals for component 1001, during normal receive operations.
- the first bidirectional component includes a block 1005 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of transmit calibration patterns.
- the transmitter drive point can be adjusted by the block 1007 labeled "adjust”.
- a sideband communication channel 1013 is shown coupled between the component 1001 and the component 1000, by which the results of analysis of received calibration patterns at the component 1001 are supplied to the adjust block 1007 of the component 1000.
- Component 1000 also has support for calibrating receiver 1024, including a block 1028 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of expected patterns for comparison with received patterns.
- a block 1029 labeled “compare” enables the received pattern set to be compared to the expected pattern set, and causes an adjustment to be made to either the transmitter or receiver.
- the receiver sample point can be adjusted by the block 1032 labeled "adjust".
- the second bidirectional component 1001 includes complementary elements supporting transmitter 1023 and receiver 1004.
- a block 1009 labeled “compare” enables the received pattern set to be compared to the expected pattern set, and causes an adjustment to be made to either the transmitter or receiver.
- the receiver sample point can be adjusted by the block 1012 labeled "adjust”.
- the second bidirectional component 1001 supports transmission operations, with elements including a block 1025 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of transmit calibration patterns.
- the transmitter drive point can be adjusted by the block 1027 labeled "adjust”.
- a sideband communication channel 1033 is shown coupled between the component 1000 and the component 1001, by which the results of analysis of received calibration patterns at the component 1000 are supplied to the adjust block 1027 of the component 1001.
- the example of Fig. 10 allows both receive sample points and both transmit drive points to be adjusted. However, the benefit of adjustable timing can be realized if there is only one adjustable element in each direction.
- Fig. 11 shows an example in which only the receiver sample points are adjustable.
- elements 1007 and 1027 of Fig. 10 are not included in this embodiment. This is equivalent to two copies of the elements of example in Fig. 4.
- Fig. 12 shows an example in which only the transmitter drive points are adjustable.
- elements 1012 and 1032 of Fig. 10 are not included in this embodiment. This is equivalent to two copies of the elements of example in Fig. 5.
- Fig. 13 shows an example in which the receiver sample point and transmitter drive point of the first bidirectional component 1000 are adjustable.
- elements 1012, 1008, 1009, 1027, 1026, 1025 are not included in this embodiment.
- a storage block 1050 is added between the receiver and a "mux" block 1051.
- the "mux" block 1051 is used to select between a normal source of signals 1030 and the storage block 1050.
- the compare block 1052 is used for analysis of both transmit and receive calibration operations, and is coupled to both the adjust block 1007 for the transmitter, and adjust block 1032 for the receiver. This alternative is important because all the adjustment information can be kept within one component, eliminating the need for sideband signals for the calibration process. If component 1001 were particularly cost sensitive, this could also be a benefit, since only one of the components must bear the cost of the adjustment circuitry.
- Fig. 14 shows the example from Fig. 13, and also includes the steps needed to perform a timing calibration update.
- Step 1401 Suspend normal transmit and receive operations, by completing transactions in progress and preventing new ones from beginning, or by interrupting transactions that are in progress.
- Step 1402 Change the drive point of the transmit component (A) from the "TX" operation value
- Step 1403 Change "mux" block of the transmit component (A) so that the "pattern” block input is enabled.
- Step 1404 A pattern set is created in the "pattern” block of the transmit component (A) and is transmitted onto the "link” using the TXA or TXB drive point.
- Step 1405 The pattern set is received in the receive component (B). Note that the sample point of the receiver is fixed relative to the reference clock of the system. The received pattern set is held in the "storage" block in component B.
- Step 1406 The "mux" block input connected to the “storage” block in component B is enabled.
- the pattern set is re-transmitted onto the link by component B. (Step 1407) The pattern set is received by component A from the link.
- Step 1408 The received pattern set is compared in the "compare” block to the expected pattern set produced by the "pattern” block in the receive component (A). The two pattern sets will either match or not match. As a result of this comparison (and possibly other previous comparisons) a pass or fail determination will be made.
- Step 1409 Adjust either the "TXA” or “TXB” edge value in the transmit component (A) as a result of the pass or fail determination.
- the "TX" operation value in the transmit component (A) is also adjusted. This adjustment may only be made after two or more of these calibration sequences have been executed, in order to ensure some level of repeatability.
- Step 1410 Change the drive point of the transmitter from the "TXA” or “TXB” edge value (used for calibration operations) to "TX” operation value (used for normal operations) in the "adjust" block of the transmit component (A). It may be necessary to impose a settling delay at this step to allow the new drive point to become stable.
- Step 1411 Change "mux" block of the transmit component (A) so that the "normal path” input is enabled.
- Step 1412 Resume normal transmit and receive operations.
- Fig. 15 shows the example from Fig. 13, and also includes the steps needed to perform a timing calibration update.
- Step 1501 Suspend normal transmit and receive operations, by completing transactions in progress and preventing new ones from beginning, or by interrupting transactions that are in progress.
- Step 1502 Change the sample point of the receive component (A) from the "RX" operation value
- Step 1503 Change "mux" block of the transmit component (A) so that the "pattern" block input is enabled.
- Step 1504 A pattern set is created in the "pattern" block of the transmit component (A) and is transmitted onto the "link". The normal transmit drive point is used.
- Step 1505 The pattern set is received in the receive component (B). Note that the sample point of the receiver is fixed relative to the reference clock of the system and is not adjustable. The received pattern set is held in the "storage" block in component B.
- Step 1506 The "mux" block input connected to the “storage” block in component B is enabled.
- the pattern set is re-transmitted onto the link by component B.
- Step 1507 The pattern set is received by component A from the link using either the RXA or RXB value to determine the receiver sample point.
- Step 1508 The received pattern set is compared in the "compare” block to the expected pattern set produced by the "pattern” block in the receive component (A). The two pattern sets will either match or not match. As a result of this comparison (and possibly other previous comparisons) a pass or fail determination will be made.
- Step 1509 Adjust either the "RXA” or “RXB” edge value in the receive component (A) as a result of the pass or fail determination.
- the "RX" operation value in the receive component (A) is also adjusted. This adjustment may only be made after two or more of these calibration sequences have been executed, in order to ensure some level of repeatability.
- Step 1510 Change the sample point of the receiver from the "RXA” or “RXB” edge value (used for calibration operations) to "RX” operation value (used for normal operations) in the "adjust" block of the receive component (A). It may be necessary to impose a settling delay at this step to allow the new sample point to become stable.
- Step 1511 Change "mux" block of the transmit component (A) so that the "normal path” input is enabled.
- Step 1512 Resume normal transmit and receive operations.
- FIG. 13 utilizes a storage block 1050 as part of the calibration process.
- a storage block 1050 as part of the calibration process.
- Fig. 13 shows an option in which the storage block is implemented as part of the interface containing the transmit and receive circuits. This has the benefit that the circuitry used for normal operations (the "normal path") is not significantly impacted. The cost of this option is that the storage block will increase the size of the interface, and will thus increase the manufacturing cost of the component 1001.
- Figs. 16 and Fig. 17 show why a storage block is needed for the implementations of example of Fig. 13.
- the storage allows the received pattern set in component 1001 to be held (and delayed) prior to being re-transmitted.
- Fig.16 shows a gap 1600 between the interval 1601 in which the pattern set is being transmitted by A (and received by B) and the interval 1602 in which the pattern set being transmitted by B (and received by A). If no storage was present, there would be a relatively small delay between the start of each these two intervals resulting in an overlap of the intervals, as shown in Fig. 17.
- components on a bidirectional link are not allowed to transmit simultaneously, so some storage will be required with the configuration of Fig. 13 to prevent this.
- simultaneous bidirectional signaling requires additional signal levels to be supported. For example, if each of two transmitters can be signaling a bit, there are four possible combinations of two transmitters simultaneously driving one bit each. The four combinations are ⁇ 0/0, 0/1, 1/0, 1/1 ⁇ . Typically the 0/1 and 1/0 combinations will produce the same composite signal on the link. This requires that the transmitter circuits be additive, so that three signal levels are produced ⁇ 0, 1, 2 ⁇ . The receiver circuits will need to discriminate between these three signal levels.
- a final requirement of simultaneous bidirectional signaling is that a component must subtract the value it is currently transmitting from the composite signal that it is currently receiving in order to detect the actual signal from the other component. When these requirements are in place, the storage block requirement can be dropped. This is one of the benefits of this approach. The cost of this approach is the extra design complexity and reduced voltage margins of simultaneous bidirectional signaling.
- Fig. 18 shows option B in which the storage block is implemented from the storage elements 1801, 1802 that are normally present in the transmit and receive circuits. These storage elements are typically present for pipelining (delaying) the information flowing on the normal paths. Storage elements may also be present to perform serialization and deserialization. This would be required if the internal and external signal groups have different widths.
- the external link could consist of a single differential wire pair carrying information at the rate or 3200 Mb/s, and could connect to a set of eight single-ended internal wires carrying information at the rate of 400Mb/s. The information flow is balanced (no information is lost), but storage is still required to perform serial-to-parallel or parallel-to-serial conversion between the two sets of signals.
- This storage will create delay, which can be used to offset the two pattern sets in the option of Fig. 18.
- the benefit of this approach is that no extra storage must be added to component 1001.
- the cost is that the wiring necessary to connect the receiver to a "mux" block in the transmitter may be significant.
- Another cost is that the amount of storage naturally present in the receiver and transmitter may be relatively small, limiting the length of the pattern set which can be received and retransmitted with this approach.
- Fig. 19 shows an option in which the storage block is implemented from the storage cells that are normally present in a memory core 1900.
- component 1001 is assumed to be a memory component.
- the storage area 1901 labeled "region" is reserved for receiving the pattern set from component 1000, and for retransmitting the pattern set back to component 1000.
- This storage area may only be used by the calibration process, and should not be used by any normal application process. If this storage area were used by an application process, it is possible that application information could be overwritten by the pattern set information and thereby lost.
- the benefit of this approach is that no additional storage needs to be added to component 1001 (and no special path from receiver to transmitter).
- Fig. 20 shows an option in which the storage block is again implemented from the storage cells that are normally present in a memory core 1900.
- component B is assumed to be a memory component.
- the storage area 1901 labeled "region" is reserved for receiving the pattern set from component 1000, and for retransmitting the pattern set back to component 1000. This storage area may only be used by the calibration process, and should not be used by any normal application process.
- component 1000 adds a storage block 2001, labeled "cache”, which emulates the storage capability of the storage area 1901 "region”.
- a write is performed to the "region” of storage area 1901, it is intercepted and redirected to the "cache” in storage 2001.
- a read is performed to the "region” of storage area 1901, the read is intercepted and redirected, returning read data from "cache” via mux 2002.
- the application processes see no hole in the memory address space.
- the benefit of this option is that no additional storage needs to be added to component 1001 (and no special path from receiver to transmitter).
- Fig. 21 shows an option in which the storage block is again implemented from the storage cells that are normally present in a memory core 1900.
- component 1001 is assumed to be a memory component.
- the storage area 1901 labeled "region” is used for receiving the pattern set from component 1000, and for retransmitting the pattern set back to component 1000.
- This storage area 1901 may be used by both the calibration process and by the application processes, however.
- a temporary storage block 2101 labeled "temp” is provided in component 1000, along with a "mux” block 2102 for accessing it.
- temp a temporary storage block 2101
- the contents of "region” are read and loaded into “temp” storage block 2101.
- the calibration process steps may now be carried out using the storage area 1901.
- the contents of "temp" storage block 2101 are accessed and written back to the "region" of storage area 1901, and the application process allowed to restart. Again, the application processes see no hole in the memory address space.
- the benefit of this option is that no additional storage needs to be added to component 1001 (and no special path from receiver to transmitter).
- Fig. 22 shows an option in which the storage block is implemented from the latching sense amplifier circuit 2201 that is present in a memory component 1001.
- Latching sense amplifier circuit 2201 includes latches or other storage resources associated with sense amplifiers. Most memory components use such a latching sense amplifier circuit 2201 to access and hold a row 2202 of storage cells from the memory core 1900. Read operations are then directed to the sense amplifier which temporarily holds the contents of the row of storage cells. Write operations are directed to both the sense amplifier and to the row of storage cells so that the information held by these two storage structures is consistent. When another row of storage cells is to be accessed, the sense amplifier is precharged and reloaded with this different row.
- component 1001 is a memory component with such a latching sense amplifier circuit 2201
- the sense amplifier may be written by the receiver circuit 1004 and may read to the transmitter circuit 1023 without first being loaded from a row 2202 of storage cells in the memory core 1900.
- This second access mode would require a gating circuit 2204 between the memory core and the sense amplifier, which could be disabled during the calibration process.
- a benefit of this option is that no additional storage needs to be added to component 1001 (and no special path from receiver to transmitter).
- the cost of this approach is that a modification must be made to critical circuits in the core of a memory component.
- the transmitter calibration process may be performed in the following manner:
- Step 2301 Suspend normal transmit and receive operations, by completing transactions in progress and preventing new ones from beginning, or by interrupting transactions that are in progress.
- Step 2302 Control the "adjust" logic so the transmitter uses a calibrate (TXA/TXB) drive-timing- point according to the stored results of the previous comparison.
- Step 2303 Control the "adjust" logic so that the pattern block is coupled to the transmitter.
- Step 2304 A pattern sequence is read or created from the pattern block and is transmitted onto the interconnect using the selected calibrate drive-timing-point. (Step 2305) The pattern sequence is received using the normal (RX) sample-timing-point.
- Step 2306 Control the "adjust" logic so the transmitter uses a normal (TX) drive-timing-point.
- Step 2307) Control the "adjust" logic so that the "normal path" to the transmitter is enabled.
- Step 2308 Resume normal transmit and receive operations.
- Step 2309 The received pattern sequence is compared to the expected pattern sequence from the "pattern" block.
- Step 2310 The calibrate drive-timing-point (TXA/TXB, TX) is adjusted according to the results of the comparison.
- Step 2401a Suspend normal transmit operations, by completing transactions in progress and preventing new ones from beginning, or by interrupting transactions that are in progress
- Step 2402a Control the "adjust" logic so the transmitter uses a calibrate (TXA/TXB) drive-timing- point according to the stored results of the previous comparison.
- Step 2403a Control the "adjust" logic that the pattern block is coupled to the transmitter.
- Step 2404a A pattern sequence is created from the "pattern” block and is transmitted onto the interconnect using the selected calibrate drive-timing-point.
- Step 2405a The pattern sequence is received in the second component and placed in storage.
- Step 2406a Control the "adjust" logic so the transmitter uses a normal (TX) drive-timing-point.
- Step 2407a Control the "adjust” logic so that the "normal path” to the transmitter is enabled.
- Step 2408a Resume normal transmit operations.
- Step 2401b The pattern sequence in storage is transmitted onto the interconnect by the second component.
- Step 2402b The pattern sequence is received using the normal (RX) sample-timing-point.
- Step 2403b The received pattern sequence is compared to the expected pattern sequence from the "pattern" block.
- Step 2404b The calibrate drive-timing-point (TXA/TXB, TX) is adjusted according to the results of the comparison.
- a point to point bidirectional link of Fig. 13 is replaced with a multidrop link, coupling component 2500 to a plurality of components 2551, 2552.
- the multidrop link configuration can be applied in other configurations.
- a first bidirectional component 2500 and a plurality of other bidirectional components 2551, 2552 are connected in a point to multipoint configuration, or multipoint to multipoint configuration, with an interconnection medium referred to as Link 2502.
- Normal path 2510 acts as a source of data signals for normal operation of component 2500 during transmit operations.
- Normal path 2531 acts as a destination of data signals for component 2500, during normal receive operations.
- the calibration operations are interleaved, and re-ordered, in this embodiment with normal communications, as described above to improve throughput and utilization of the communication medium
- the first bidirectional component 2500 includes a block 2505 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of transmit calibration patterns.
- the transmitter drive point can be adjusted by the block 2507 labeled "adjust".
- the adjust block 2507 includes storage for multiple parameter sets which are applied depending on the one of the other components 2551, 2552, ...
- Component 2500 also has support for calibrating receiver 2524, including a block 2528 labeled "pattern”, which can consist of pattern storage or pattern generation circuitry, and which is used as a source of expected patterns for comparison with received patterns.
- a block 2529 labeled “compare” enables the received pattern set to be compared to the expected pattern set, and causes an adjustment to be made to either the transmitter or receiver.
- the receiver sample point can be adjusted by the block 2532 labeled "adjust”.
- the adjust block 2507 includes storage for multiple parameter sets which are applied depending on the one of the other components 2551, 2552, ... on the link from which the communication is being received.
- the compare block 2529 is used for analysis of both transmit and receive calibration operations, and is coupled to both the adjust block 2507 for the transmitter, and adjust block 2532 for the receiver.
- the receiver sample point and transmitter drive point of the first bidirectional component 2500 are adjustable.
- the other components 2551, 2552, ... are implemented as described with reference to Fig. 13 without adjustment resources, in this example, and not described here.
- the components 2551, 2552, ... on the link may be provided with adjustment and calibration resources, as described for other embodiments above.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Power Engineering (AREA)
- Synchronisation In Digital Transmission Systems (AREA)
- Mobile Radio Communication Systems (AREA)
- Communication Control (AREA)
- Dc Digital Transmission (AREA)
- Circuits Of Receivers In General (AREA)
- Radio Relay Systems (AREA)
Abstract
Description
Claims
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP19182020.8A EP3576091B1 (en) | 2004-01-28 | 2005-01-25 | Communication channel calibration for drift conditions |
EP05711973.7A EP1712013B1 (en) | 2004-01-28 | 2005-01-25 | Communication channel calibration for drift conditions |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/766,765 US7095789B2 (en) | 2004-01-28 | 2004-01-28 | Communication channel calibration for drift conditions |
US10/766,765 | 2004-01-28 |
Publications (2)
Publication Number | Publication Date |
---|---|
WO2005072329A2 true WO2005072329A2 (en) | 2005-08-11 |
WO2005072329A3 WO2005072329A3 (en) | 2006-02-23 |
Family
ID=34795736
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2005/002301 WO2005072329A2 (en) | 2004-01-28 | 2005-01-25 | Communication channel calibration for drift conditions |
Country Status (5)
Country | Link |
---|---|
US (7) | US7095789B2 (en) |
EP (2) | EP3576091B1 (en) |
CN (2) | CN1914818A (en) |
TW (1) | TW200536286A (en) |
WO (1) | WO2005072329A2 (en) |
Families Citing this family (39)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7490275B2 (en) | 2001-02-02 | 2009-02-10 | Rambus Inc. | Method and apparatus for evaluating and optimizing a signaling system |
US7095789B2 (en) * | 2004-01-28 | 2006-08-22 | Rambus, Inc. | Communication channel calibration for drift conditions |
US7400670B2 (en) | 2004-01-28 | 2008-07-15 | Rambus, Inc. | Periodic calibration for communication channels by drift tracking |
US8422568B2 (en) | 2004-01-28 | 2013-04-16 | Rambus Inc. | Communication channel calibration for drift conditions |
US6961862B2 (en) | 2004-03-17 | 2005-11-01 | Rambus, Inc. | Drift tracking feedback for communication channels |
US7171321B2 (en) * | 2004-08-20 | 2007-01-30 | Rambus Inc. | Individual data line strobe-offset control in memory systems |
US20060168379A1 (en) * | 2004-12-13 | 2006-07-27 | Tim Frodsham | Method, system, and apparatus for link latency management |
US7543172B2 (en) | 2004-12-21 | 2009-06-02 | Rambus Inc. | Strobe masking in a signaling system having multiple clock domains |
US7403746B2 (en) * | 2005-01-04 | 2008-07-22 | Mitsubishi Electric Research Laboratories, Inc. | Adaptive frame durations for time-hopped impulse radio systems |
US7164289B1 (en) | 2005-01-21 | 2007-01-16 | Altera Corporation | Real time feedback compensation of programmable logic memory |
US7688672B2 (en) * | 2005-03-14 | 2010-03-30 | Rambus Inc. | Self-timed interface for strobe-based systems |
US7509515B2 (en) * | 2005-09-19 | 2009-03-24 | Ati Technologies, Inc. | Method and system for communicated client phase information during an idle period of a data bus |
US8284881B2 (en) * | 2005-11-03 | 2012-10-09 | Nxp B.V. | Data interface and method of seeking synchronization |
US8121237B2 (en) | 2006-03-16 | 2012-02-21 | Rambus Inc. | Signaling system with adaptive timing calibration |
US8207976B2 (en) * | 2007-03-15 | 2012-06-26 | Qimonda Ag | Circuit |
TWI337492B (en) * | 2007-04-24 | 2011-02-11 | Realtek Semiconductor Corp | Digitally synchronized receiving device and associated signal processing method |
US8341450B2 (en) * | 2007-07-23 | 2012-12-25 | Rambus Inc. | Continuous timing calibrated memory interface |
DE102009000924A1 (en) * | 2008-12-30 | 2010-07-01 | Robert Bosch Gmbh | Device and method for time calibration between transmit / receive blocks |
EP2384474B1 (en) * | 2008-12-31 | 2015-08-12 | Rambus Inc. | Active calibration for high-speed memory devices |
US8742791B1 (en) * | 2009-01-31 | 2014-06-03 | Xilinx, Inc. | Method and apparatus for preamble detection for a control signal |
WO2010100685A1 (en) * | 2009-03-03 | 2010-09-10 | パナソニック株式会社 | Memory device and memory control device |
JP2011071852A (en) * | 2009-09-28 | 2011-04-07 | Fujitsu Ltd | Transmission system and transmission method |
DE102010007273A1 (en) * | 2009-11-18 | 2011-06-01 | Siemens Aktiengesellschaft | Method and arrangement for stabilizing a color coding method in an optical transmission of data |
PL2534773T3 (en) | 2010-05-17 | 2015-08-31 | Siemens Ag | Method and arrangement for stabilizing a colour coding method for optical transmission of data |
WO2012082274A2 (en) | 2010-11-19 | 2012-06-21 | Rambus Inc. | Timing-drift calibration |
US8743715B1 (en) * | 2011-01-24 | 2014-06-03 | OnPath Technologies Inc. | Methods and systems for calibrating a network switch |
US8774228B2 (en) | 2011-06-10 | 2014-07-08 | International Business Machines Corporation | Timing recovery method and apparatus for an input/output bus with link redundancy |
US9235537B2 (en) | 2011-10-26 | 2016-01-12 | Rambus Inc. | Drift detection in timing signal forwarded from memory controller to memory device |
US8941430B2 (en) * | 2012-09-12 | 2015-01-27 | Nvidia Corporation | Timing calibration for on-chip interconnect |
US9838082B2 (en) * | 2014-08-29 | 2017-12-05 | Freelinc Technologies | Proximity boundary based communication |
TWI554768B (en) * | 2014-10-21 | 2016-10-21 | Zeroplus Technology Co Ltd | Logic analyzer calibration method |
US10164685B2 (en) | 2014-12-31 | 2018-12-25 | Freelinc Technologies Inc. | Spatially aware wireless network |
WO2017100078A1 (en) | 2015-12-08 | 2017-06-15 | Rambus Inc. | Low power signaling interface |
US10749756B2 (en) * | 2016-06-24 | 2020-08-18 | Advanced Micro Devices, Inc. | Channel training using a replica lane |
US10352299B2 (en) * | 2016-08-05 | 2019-07-16 | General Electric Company | System and method for automatically updating wind turbine data based on component self-identification |
US10552169B2 (en) | 2017-03-17 | 2020-02-04 | Sandisk Technologies Llc | On-die signal calibration |
US11276443B2 (en) | 2018-10-16 | 2022-03-15 | Micron Technology, Inc. | Offset cancellation |
EP3748512B1 (en) * | 2019-06-06 | 2023-08-02 | Infineon Technologies AG | Method for a slave device for calibrating its output timing, method for a master device for enabling a slave device to calibrate its output timing, master device and slave device |
CN112394763A (en) * | 2019-08-15 | 2021-02-23 | 成都纳能微电子有限公司 | Automatic output amplitude calibration system of universal serial bus 2.0 high-speed driver |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6374375B1 (en) | 1997-05-09 | 2002-04-16 | Advanced Micro Devices, Inc. | Monitoring line conditions in the data transmission mode |
US20030087659A1 (en) | 2001-11-05 | 2003-05-08 | Zhenyu Wang | Training-while-working data communications |
US6606041B1 (en) | 2000-05-10 | 2003-08-12 | Micron Technology, Inc. | Predictive timing calibration for memory devices |
Family Cites Families (136)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3115102A (en) | 1959-10-14 | 1963-12-24 | Evans Prod Co | Freight bracing equipment |
US3638121A (en) | 1960-12-20 | 1972-01-25 | Lockheed Aircraft Corp | Nonperiodic energy communication system capable of operating at low signal-to-noise ratios |
US3155102A (en) | 1962-03-12 | 1964-11-03 | Jr Otto C Niederer | Egg cleaning equipment |
US3922491A (en) | 1972-05-08 | 1975-11-25 | Ericsson Telefon Ab L M | Telecommunication plant in which a wide-band channel if wanted is connected by the side of a telephone connection |
FR2377729A1 (en) | 1977-01-14 | 1978-08-11 | Thomson Csf | DEVICE FOR DECODING DIGITAL SIGNALS, AND SYSTEM INCLUDING SUCH A DEVICE |
US7137048B2 (en) | 2001-02-02 | 2006-11-14 | Rambus Inc. | Method and apparatus for evaluating and optimizing a signaling system |
GB2081913B (en) * | 1979-12-14 | 1983-08-03 | Hewlett Packard Ltd | Noise margin measurement and error probability prediction |
US4648133A (en) | 1984-08-07 | 1987-03-03 | The Unites States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration | Synchronization tracking in pulse position modulation receiver |
US5329489A (en) | 1988-03-31 | 1994-07-12 | Texas Instruments Incorporated | DRAM having exclusively enabled column buffer blocks |
US5111208A (en) * | 1989-02-23 | 1992-05-05 | Hazeltine Corporation | Calibration of plural - channel system |
US5122978A (en) * | 1989-09-07 | 1992-06-16 | Amdahl Corporation | Pulse width measurement technique |
US5758109A (en) | 1990-03-19 | 1998-05-26 | Thomas A. Gafford | Repeater/switch for distributed arbitration digital data buses |
US6751696B2 (en) | 1990-04-18 | 2004-06-15 | Rambus Inc. | Memory device having a programmable register |
US5243626A (en) | 1991-08-29 | 1993-09-07 | Apple Computer, Inc. | Method for clocks synchronization for receiving pulse position encoded signals |
US5265211A (en) | 1992-01-02 | 1993-11-23 | International Business Machines Corporation | Arbitration control logic for computer system having dual bus architecture |
US5621913A (en) | 1992-05-15 | 1997-04-15 | Micron Technology, Inc. | System with chip to chip communication |
US5485490A (en) | 1992-05-28 | 1996-01-16 | Rambus, Inc. | Method and circuitry for clock synchronization |
US5436908A (en) * | 1992-06-17 | 1995-07-25 | National Semiconductor Corporation | Common edge output skew detection circuit |
JP3522788B2 (en) | 1992-10-29 | 2004-04-26 | 株式会社ルネサステクノロジ | Semiconductor integrated circuit device |
FR2697955B1 (en) | 1992-11-06 | 1994-12-09 | Thomson Csf | Self-calibrating analog to digital conversion method and device. |
US5523760A (en) | 1993-04-12 | 1996-06-04 | The Regents Of The University Of California | Ultra-wideband receiver |
US5715409A (en) | 1993-05-24 | 1998-02-03 | I-Tech Corporation | Universal SCSI electrical interface system |
JPH06350654A (en) | 1993-06-14 | 1994-12-22 | Toshiba Corp | Clock synchronization control verification device |
JP3489147B2 (en) | 1993-09-20 | 2004-01-19 | 株式会社日立製作所 | Data transfer method |
US5554945A (en) | 1994-02-15 | 1996-09-10 | Rambus, Inc. | Voltage controlled phase shifter with unlimited range |
US5541967A (en) | 1994-03-09 | 1996-07-30 | National Semiconductor Corporation | Fast symbol synchronization for use in conditioning a receiving modem |
US5592120A (en) | 1994-09-07 | 1997-01-07 | Analog Devices, Inc. | Charge pump system |
US5771356A (en) | 1995-01-04 | 1998-06-23 | Cirrus Logic, Inc. | Apparatus for controlling FIFO buffer data transfer by monitoring bus status and FIFO buffer thresholds |
US5778436A (en) | 1995-03-06 | 1998-07-07 | Duke University | Predictive caching system and method based on memory access which previously followed a cache miss |
US5852640A (en) * | 1995-06-26 | 1998-12-22 | Kliza; Phillip S. | Clock distribution apparatus with current sensed skew cancelling |
WO1997025788A1 (en) * | 1996-01-03 | 1997-07-17 | International Business Machines Corporation | Robust method and apparatus enabling multi-mode wireless optical communication |
US5745011A (en) | 1996-06-05 | 1998-04-28 | Cypress Semiconductor Corporation | Data recovery phase locked loop |
US5859881A (en) * | 1996-06-07 | 1999-01-12 | International Business Machines Corporation | Adaptive filtering method and apparatus to compensate for a frequency difference between two clock sources |
US5742798A (en) | 1996-08-09 | 1998-04-21 | International Business Machines Corporation | Compensation of chip to chip clock skew |
US6005895A (en) * | 1996-12-20 | 1999-12-21 | Rambus Inc. | Apparatus and method for multilevel signaling |
US6125157A (en) * | 1997-02-06 | 2000-09-26 | Rambus, Inc. | Delay-locked loop circuitry for clock delay adjustment |
FI107688B (en) * | 1997-02-27 | 2001-09-14 | Nokia Networks Oy | Method for realizing dynamic channel assignment in a cellular radio system |
US6026125A (en) | 1997-05-16 | 2000-02-15 | Multispectral Solutions, Inc. | Waveform adaptive ultra-wideband transmitter |
WO1999007077A2 (en) | 1997-07-31 | 1999-02-11 | Stanford Syncom Inc. | Means and method for a synchronous network communications system |
US6442644B1 (en) * | 1997-08-11 | 2002-08-27 | Advanced Memory International, Inc. | Memory system having synchronous-link DRAM (SLDRAM) devices and controller |
WO1999019806A1 (en) * | 1997-10-10 | 1999-04-22 | Rambus Incorporated | Method and apparatus for fail-safe resynchronization with minimum latency |
US6047346A (en) * | 1998-02-02 | 2000-04-04 | Rambus Inc. | System for adjusting slew rate on an output of a drive circuit by enabling a plurality of pre-drivers and a plurality of output drivers |
US6154821A (en) | 1998-03-10 | 2000-11-28 | Rambus Inc. | Method and apparatus for initializing dynamic random access memory (DRAM) devices by levelizing a read domain |
US6163570A (en) * | 1998-05-11 | 2000-12-19 | Conexant Systems, Inc. | Methods and apparatus for verifying transmit power levels in a signal point limited transmission system |
US7035607B2 (en) * | 1998-05-29 | 2006-04-25 | Silicon Laboratories Inc. | Systems and methods for providing an adjustable reference signal to RF circuitry |
US6181166B1 (en) | 1998-06-19 | 2001-01-30 | Intel Corporation | Tristate driver for integrated circuit interconnects |
US6820234B2 (en) | 1998-06-29 | 2004-11-16 | Acuid Limited | Skew calibration means and a method of skew calibration |
US6243776B1 (en) | 1998-07-13 | 2001-06-05 | International Business Machines Corporation | Selectable differential or single-ended mode bus |
JP2000035831A (en) | 1998-07-21 | 2000-02-02 | Nec Corp | Low skew clock tree circuit using variable threshold voltage transistor |
US6510503B2 (en) * | 1998-07-27 | 2003-01-21 | Mosaid Technologies Incorporated | High bandwidth memory interface |
US6282210B1 (en) * | 1998-08-12 | 2001-08-28 | Staktek Group L.P. | Clock driver with instantaneously selectable phase and method for use in data communication systems |
US6496911B1 (en) | 1998-10-02 | 2002-12-17 | International Business Machines Corporation | Apparatus for memory bus tuning and methods therefor |
US6173345B1 (en) * | 1998-11-03 | 2001-01-09 | Intel Corporation | Method and apparatus for levelizing transfer delays for a channel of devices such as memory devices in a memory subsystem |
JP2000148656A (en) | 1998-11-09 | 2000-05-30 | Mitsubishi Electric Corp | Memory system |
US6421389B1 (en) | 1999-07-16 | 2002-07-16 | Time Domain Corporation | Baseband signal converter for a wideband impulse radio receiver |
US6463392B1 (en) * | 1999-08-16 | 2002-10-08 | Agilent Technologies, Inc. | System and method for adjusting a sampling time in a logic analyzer |
US6418070B1 (en) | 1999-09-02 | 2002-07-09 | Micron Technology, Inc. | Memory device tester and method for testing reduced power states |
KR100326939B1 (en) | 1999-09-02 | 2002-03-13 | 윤덕용 | Pipeline structure of memory can high-fast Row-cycle |
US6603818B1 (en) | 1999-09-23 | 2003-08-05 | Lockheed Martin Energy Research Corporation | Pulse transmission transceiver architecture for low power communications |
US6396329B1 (en) * | 1999-10-19 | 2002-05-28 | Rambus, Inc | Method and apparatus for receiving high speed signals with low latency |
US6321282B1 (en) * | 1999-10-19 | 2001-11-20 | Rambus Inc. | Apparatus and method for topography dependent signaling |
US6643787B1 (en) * | 1999-10-19 | 2003-11-04 | Rambus Inc. | Bus system optimization |
US6457089B1 (en) | 1999-10-21 | 2002-09-24 | International Business Machines Corporation | Microprocessor bus structure |
US6456221B2 (en) | 1999-10-28 | 2002-09-24 | The National University Of Singapore | Method and apparatus for signal detection in ultra wide-band communications |
US6560716B1 (en) * | 1999-11-10 | 2003-05-06 | Lsi Logic Corporation | System for measuring delay of digital signal using clock generator and delay unit wherein a set of digital elements of clock generator identical to a set of digital elements of delay unit |
US6662305B1 (en) | 1999-11-23 | 2003-12-09 | Intel Corporation | Fast re-synchronization of independent domain clocks after powerdown to enable fast system start-up |
US6657468B1 (en) | 1999-12-20 | 2003-12-02 | Rambus Inc. | Apparatus and method for controlling edge rates of digital signals |
US6810087B2 (en) | 2000-01-04 | 2004-10-26 | General Electric Company | Ultra-wideband communications system |
US6693918B1 (en) | 2000-04-28 | 2004-02-17 | Agilent Technologies, Inc. | Elastic buffers for serdes word alignment and rate matching between time domains |
US6889357B1 (en) * | 2000-05-10 | 2005-05-03 | Micron Technology, Inc. | Timing calibration pattern for SLDRAM |
US6434081B1 (en) * | 2000-05-12 | 2002-08-13 | Micron Technology, Inc. | Calibration technique for memory devices |
US6369652B1 (en) | 2000-05-15 | 2002-04-09 | Rambus Inc. | Differential amplifiers with current and resistance compensation elements for balanced output |
JP2004501554A (en) | 2000-05-22 | 2004-01-15 | アクイド コーポレーション リミテッド | Timing control means for automatically compensating for timing uncertainty |
US6535043B2 (en) | 2000-05-26 | 2003-03-18 | Lattice Semiconductor Corp | Clock signal selection system, method of generating a clock signal and programmable clock manager including same |
JP2002040108A (en) * | 2000-07-27 | 2002-02-06 | Advantest Corp | Semiconductor device testing apparatus and method for timing calibration of the same |
US6587804B1 (en) | 2000-08-14 | 2003-07-01 | Micron Technology, Inc. | Method and apparatus providing improved data path calibration for memory devices |
US6469555B1 (en) * | 2000-08-18 | 2002-10-22 | Rambus, Inc | Apparatus and method for generating multiple clock signals from a single loop circuit |
US6691214B1 (en) | 2000-08-29 | 2004-02-10 | Micron Technology, Inc. | DDR II write data capture calibration |
DE10047342A1 (en) | 2000-09-25 | 2002-05-08 | Siemens Ag | Method to compensate for channel quality differences in a WDM system |
US6448815B1 (en) * | 2000-10-30 | 2002-09-10 | Api Networks, Inc. | Low voltage differential receiver/transmitter and calibration method thereof |
US6735709B1 (en) * | 2000-11-09 | 2004-05-11 | Micron Technology, Inc. | Method of timing calibration using slower data rate pattern |
US6484232B2 (en) * | 2000-11-30 | 2002-11-19 | Compaq Information Technologies Group, L.P. | Adaptive calibration technique for high speed memory devices |
US6493836B2 (en) | 2000-11-30 | 2002-12-10 | Compaq Information Technologies Group, L.P. | Method and apparatus for scheduling and using memory calibrations to reduce memory errors in high speed memory devices |
US6675117B2 (en) | 2000-12-12 | 2004-01-06 | Teradyne, Inc. | Calibrating single ended channels for differential performance |
US6725304B2 (en) | 2000-12-19 | 2004-04-20 | International Business Machines Corporation | Apparatus for connecting circuit modules |
US6606576B2 (en) * | 2001-01-19 | 2003-08-12 | Koninklijke Philips Electronics N.V. | Real-time channel calibration method and arrangement |
US7196979B2 (en) | 2001-01-25 | 2007-03-27 | Dphi Acquisitions, Inc. | Calibration storage methods for a digital focus and tracking servo system with calibration |
US6873939B1 (en) | 2001-02-02 | 2005-03-29 | Rambus Inc. | Method and apparatus for evaluating and calibrating a signaling system |
US20020149824A1 (en) | 2001-02-27 | 2002-10-17 | Yves Beaulieu | Synchronization of an optical pulse stream with an electrical signal |
US6763444B2 (en) | 2001-05-08 | 2004-07-13 | Micron Technology, Inc. | Read/write timing calibration of a memory array using a row or a redundant row |
US6629225B2 (en) | 2001-05-31 | 2003-09-30 | Intel Corporation | Method and apparatus for control calibration of multiple memory modules within a memory channel |
US6717992B2 (en) | 2001-06-13 | 2004-04-06 | Time Domain Corporation | Method and apparatus for receiving a plurality of time spaced signals |
US6842816B1 (en) | 2001-07-31 | 2005-01-11 | Network Elements, Inc. | Configurable glueless microprocessor interface |
US6907062B2 (en) * | 2001-08-06 | 2005-06-14 | Broadcom Corporation | PRBS generator selection in modem communication |
US7099424B1 (en) | 2001-08-28 | 2006-08-29 | Rambus Inc. | Clock data recovery with selectable phase control |
US7227852B2 (en) | 2001-09-21 | 2007-06-05 | Sony Corporation | Wireless transmission system, wireless transmission method, wireless reception method, transmitting apparatus and receiving apparatus |
US6871248B2 (en) | 2001-09-29 | 2005-03-22 | Hewlett-Packard Development Company, L.P. | Isochronous transactions for interconnect busses of a computer system |
US7175940B2 (en) * | 2001-10-09 | 2007-02-13 | Asml Masktools B.V. | Method of two dimensional feature model calibration and optimization |
EP1446910B1 (en) | 2001-10-22 | 2010-08-11 | Rambus Inc. | Phase adjustment apparatus and method for a memory device signaling system |
KR100454126B1 (en) | 2002-01-15 | 2004-10-26 | 삼성전자주식회사 | Information processing system with separated clock line structure |
US6911874B2 (en) | 2002-02-04 | 2005-06-28 | Honeywell International Inc. | Ultra-wideband impulse generation and modulation circuit |
US7162731B2 (en) * | 2002-02-07 | 2007-01-09 | Advent Networks, Inc. | Radio frequency characterization of cable plant and corresponding calibration of communication equipment communicating via the cable plant |
US6639957B2 (en) | 2002-02-14 | 2003-10-28 | Itron, Inc. | Method and system for calibrating an oscillator circuit using a network based time reference |
US6968416B2 (en) | 2002-02-15 | 2005-11-22 | International Business Machines Corporation | Method, system, and program for processing transaction requests during a pendency of a delayed read request in a system including a bus, a target device and devices capable of accessing the target device over the bus |
US7099422B2 (en) | 2002-04-19 | 2006-08-29 | General Electric Company | Synchronization of ultra-wideband communications using a transmitted-reference preamble |
US7313127B2 (en) | 2002-04-19 | 2007-12-25 | General Electric Company | Method and apparatus for synchronizing a radio telemetry system by way of transmitted-reference, delay-hopped ultra-wideband pilot signal |
US7073022B2 (en) | 2002-05-23 | 2006-07-04 | International Business Machines Corporation | Serial interface for a data storage array |
US7221911B2 (en) | 2002-08-16 | 2007-05-22 | Wisair Ltd. | Multi-band ultra-wide band communication method and system |
US7003605B2 (en) | 2002-09-12 | 2006-02-21 | International Business Machines Corporation | Method and system for an improved differential form of transitional coding |
US7082153B2 (en) | 2002-09-23 | 2006-07-25 | Lucent Technologies Inc. | Variable spacing pulse position modulation for ultra-wideband communication links |
US6885959B2 (en) * | 2002-10-29 | 2005-04-26 | Intel Corporation | Circuit and method for calibrating DRAM pullup Ron to pulldown Ron |
US7099983B2 (en) | 2002-11-25 | 2006-08-29 | Lsi Logic Corporation | Multi-core communications module, data communications system incorporating a multi-core communications module, and data communications process |
DE10308027A1 (en) | 2003-02-24 | 2004-09-09 | Brinkhus, Hartmut B., Dr. | Interface circuit for process connections |
US7119549B2 (en) | 2003-02-25 | 2006-10-10 | Rambus Inc. | Output calibrator with dynamic precision |
US7046166B2 (en) * | 2003-04-29 | 2006-05-16 | Rockwell Scientific Licensing, Llc | Modular wireless integrated network sensor (WINS) node with a dual bus architecture |
US6996032B2 (en) * | 2003-07-28 | 2006-02-07 | Credence Systems Corporation | BIST circuit for measuring path delay in an IC |
US7072355B2 (en) | 2003-08-21 | 2006-07-04 | Rambus, Inc. | Periodic interface calibration for high speed communication |
US20050071707A1 (en) | 2003-09-30 | 2005-03-31 | Hampel Craig E. | Integrated circuit with bi-modal data strobe |
DE10349381B4 (en) | 2003-10-21 | 2005-08-25 | Groz-Beckert Kg | Weave with new corner connector |
US7031221B2 (en) | 2003-12-30 | 2006-04-18 | Intel Corporation | Fixed phase clock and strobe signals in daisy chained chips |
US7095789B2 (en) | 2004-01-28 | 2006-08-22 | Rambus, Inc. | Communication channel calibration for drift conditions |
US8422568B2 (en) | 2004-01-28 | 2013-04-16 | Rambus Inc. | Communication channel calibration for drift conditions |
US7400670B2 (en) | 2004-01-28 | 2008-07-15 | Rambus, Inc. | Periodic calibration for communication channels by drift tracking |
US6961862B2 (en) | 2004-03-17 | 2005-11-01 | Rambus, Inc. | Drift tracking feedback for communication channels |
JP2008097699A (en) | 2006-10-11 | 2008-04-24 | Nec Electronics Corp | Semiconductor memory device |
US8130858B1 (en) | 2007-05-30 | 2012-03-06 | Marvell International Ltd. | Method and apparatus for implementing transmit diversity in OFDM systems |
JP5627603B2 (en) | 2009-01-12 | 2014-11-19 | ラムバス・インコーポレーテッド | Clock transfer low power signaling system |
US8767531B2 (en) * | 2010-10-27 | 2014-07-01 | International Business Machines Corporation | Dynamic fault detection and repair in a data communications mechanism |
US9235537B2 (en) * | 2011-10-26 | 2016-01-12 | Rambus Inc. | Drift detection in timing signal forwarded from memory controller to memory device |
US20130148447A1 (en) * | 2011-12-07 | 2013-06-13 | Ian P. Shaeffer | Reducing Power Consumption in a Memory System |
KR102238706B1 (en) | 2014-11-28 | 2021-04-09 | 삼성전자주식회사 | Semiconductor memory device and memory system including the same |
US10691484B2 (en) * | 2017-05-15 | 2020-06-23 | Google Llc | Reducing commit wait in a distributed multiversion database by reading the clock earlier |
US10580476B2 (en) * | 2018-01-11 | 2020-03-03 | International Business Machines Corporation | Simulating a single data rate (SDR) mode on a dual data rate (DDR) memory controller for calibrating DDR memory coarse alignment |
US11381745B2 (en) * | 2019-03-07 | 2022-07-05 | Invensense, Inc. | Drift correction with phase and amplitude compensation for optical image stabilization |
US11165553B1 (en) * | 2020-09-11 | 2021-11-02 | Cadence Design Systems, Inc. | Static clock calibration in physical layer device |
JP2022107522A (en) * | 2021-01-08 | 2022-07-21 | 三星ディスプレイ株式會社 | Phase adjustment method and system |
-
2004
- 2004-01-28 US US10/766,765 patent/US7095789B2/en not_active Expired - Lifetime
-
2005
- 2005-01-17 TW TW094101309A patent/TW200536286A/en unknown
- 2005-01-25 CN CNA2005800033837A patent/CN1914818A/en active Pending
- 2005-01-25 WO PCT/US2005/002301 patent/WO2005072329A2/en not_active Application Discontinuation
- 2005-01-25 EP EP19182020.8A patent/EP3576091B1/en active Active
- 2005-01-25 EP EP05711973.7A patent/EP1712013B1/en active Active
- 2005-01-25 CN CN200910205259.9A patent/CN101692634B/en active Active
-
2006
- 2006-07-21 US US11/459,294 patent/US7415073B2/en not_active Expired - Lifetime
-
2007
- 2007-05-25 US US11/754,102 patent/US8144792B2/en active Active
-
2019
- 2019-04-08 US US16/378,084 patent/US10673582B2/en not_active Expired - Lifetime
-
2020
- 2020-04-28 US US16/861,164 patent/US11108510B2/en not_active Expired - Lifetime
-
2021
- 2021-07-27 US US17/386,111 patent/US11552748B2/en not_active Expired - Lifetime
-
2022
- 2022-12-10 US US18/078,936 patent/US20230224101A1/en not_active Abandoned
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6374375B1 (en) | 1997-05-09 | 2002-04-16 | Advanced Micro Devices, Inc. | Monitoring line conditions in the data transmission mode |
US6606041B1 (en) | 2000-05-10 | 2003-08-12 | Micron Technology, Inc. | Predictive timing calibration for memory devices |
US20030087659A1 (en) | 2001-11-05 | 2003-05-08 | Zhenyu Wang | Training-while-working data communications |
Also Published As
Publication number | Publication date |
---|---|
US20070280393A1 (en) | 2007-12-06 |
CN1914818A (en) | 2007-02-14 |
EP3576091B1 (en) | 2020-07-29 |
US20190305925A1 (en) | 2019-10-03 |
US20200351038A1 (en) | 2020-11-05 |
US11108510B2 (en) | 2021-08-31 |
EP3576091A1 (en) | 2019-12-04 |
TW200536286A (en) | 2005-11-01 |
US20220052802A1 (en) | 2022-02-17 |
US10673582B2 (en) | 2020-06-02 |
EP1712013A4 (en) | 2011-12-07 |
EP1712013A2 (en) | 2006-10-18 |
WO2005072329A3 (en) | 2006-02-23 |
US20050163203A1 (en) | 2005-07-28 |
CN101692634A (en) | 2010-04-07 |
US7095789B2 (en) | 2006-08-22 |
US8144792B2 (en) | 2012-03-27 |
US20230224101A1 (en) | 2023-07-13 |
CN101692634B (en) | 2016-04-27 |
US7415073B2 (en) | 2008-08-19 |
US11552748B2 (en) | 2023-01-10 |
US20060291574A1 (en) | 2006-12-28 |
EP1712013B1 (en) | 2019-07-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11552748B2 (en) | Communication channel calibration for drift conditions | |
US10305674B2 (en) | Communication channel calibration for drift conditions | |
US11664907B2 (en) | Periodic calibration for communication channels by drift tracking |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AK | Designated states |
Kind code of ref document: A2 Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW |
|
AL | Designated countries for regional patents |
Kind code of ref document: A2 Designated state(s): BW GH GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IS IT LT LU MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2005711973 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 200580003383.7 Country of ref document: CN |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
WWW | Wipo information: withdrawn in national office |
Country of ref document: DE |
|
WWP | Wipo information: published in national office |
Ref document number: 2005711973 Country of ref document: EP |