US20140281662A1 - Dynamically adaptive bit-leveling for data interfaces - Google Patents
Dynamically adaptive bit-leveling for data interfaces Download PDFInfo
- Publication number
- US20140281662A1 US20140281662A1 US13/797,200 US201313797200A US2014281662A1 US 20140281662 A1 US20140281662 A1 US 20140281662A1 US 201313797200 A US201313797200 A US 201313797200A US 2014281662 A1 US2014281662 A1 US 2014281662A1
- Authority
- US
- United States
- Prior art keywords
- delay
- data bit
- delay line
- bit signal
- value
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
- 230000003044 adaptive effect Effects 0.000 title abstract description 4
- 238000000034 method Methods 0.000 claims abstract description 70
- 238000005070 sampling Methods 0.000 claims abstract description 66
- 230000003111 delayed effect Effects 0.000 claims description 54
- 238000012937 correction Methods 0.000 claims description 25
- 238000001514 detection method Methods 0.000 claims description 20
- 238000012935 Averaging Methods 0.000 claims 8
- 230000003247 decreasing effect Effects 0.000 claims 8
- 230000001934 delay Effects 0.000 abstract description 7
- 240000007320 Pinus strobus Species 0.000 description 29
- 238000010586 diagram Methods 0.000 description 19
- 238000012545 processing Methods 0.000 description 17
- 230000000630 rising effect Effects 0.000 description 16
- 230000015654 memory Effects 0.000 description 14
- 238000004458 analytical method Methods 0.000 description 13
- 230000006870 function Effects 0.000 description 8
- 238000005259 measurement Methods 0.000 description 6
- 238000010408 sweeping Methods 0.000 description 3
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical compound [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 2
- 229910052710 silicon Inorganic materials 0.000 description 2
- 239000010703 silicon Substances 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000011017 operating method Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 230000001052 transient effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K19/00—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
- H03K19/0175—Coupling arrangements; Interface arrangements
- H03K19/018—Coupling arrangements; Interface arrangements using bipolar transistors only
- H03K19/01806—Interface arrangements
-
- 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
- H04L7/0337—Selecting between two or more discretely delayed clocks or selecting between two or more discretely delayed received code signals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/04—Generating or distributing clock signals or signals derived directly therefrom
- G06F1/08—Clock generators with changeable or programmable clock frequency
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0751—Error or fault detection not based on redundancy
- G06F11/0763—Error or fault detection not based on redundancy by bit configuration check, e.g. of formats or tags
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/0703—Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
- G06F11/0793—Remedial or corrective actions
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K5/00—Manipulating of pulses not covered by one of the other main groups of this subclass
-
- 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/20—Arrangements for detecting or preventing errors in the information received using signal quality detector
- H04L1/205—Arrangements for detecting or preventing errors in the information received using signal quality detector jitter monitoring
Definitions
- DQ data bits can develop a skew problem with respect to the DQS strobe used to sample them. Jitter can also develop between data bits and strobes, and it would also be useful to resolve jitter issues while performing a bit-leveling function.
- jitter on the data bit signal may cause an ambiguity in the determination of a data value midpoint, and solutions are disclosed for detecting jitter and for resolving a midpoint for sampling a data bit even in the presence of jitter.
- a pattern of alternating “1s” and “0s” is read into a receiving data interface circuit and is processed according to the methods described herein.
- a strobe signal is delayed such that it will be nominally placed in the center of the delay line delay used to delay one or more data bit signals.
- a particular data value shown as a “0” for example in the description that follows, is expected when the strobe signal first samples a data bit signal. If the opposite value is recorded, according to a first embodiment of the invention this is considered an exception and is followed by special exception processing.
- circuits and methods are disclosed that accommodate the exception and provide an optimum sampling point in time and the corresponding appropriate delay line delay for the sampled data bit.
- a programmable delay line for delaying the sampled data bit is used to both advance and delay the data bit in time relative to a sampling strobe.
- the sampled data bit would typically be a programmably delayed version of DQ, while the sampling strobe is a delayed version of DQS.
- a programmable delay line for delaying the sampled data bit is used to incrementally sweep the delay of a sampled data bit in time relative to a sampling strobe, with sampled values recorded and/or analyzed at each increment, with an analysis also performed after completing the sweep to determine the best point in time to sample the data bit.
- the second embodiment may require a longer delay line for delaying the sampled data bit, additional time for the calibration operation, and additional controller storage capacity and control logic compared with the first embodiment.
- the second embodiment includes an analysis process where criteria for analyzing strings of consecutive sampled data bits having the same value is performed such that jitter detection is performed at the same time, and there is no specific need for exception handling.
- FIGS. 1A and 1B show exemplary and non-limiting embodiments for generalized circuit descriptions describing different aspects of the invention.
- FIG. 3 shows an exemplary flowchart for bit leveling according to the invention where an expected data value is initially sampled, and where no exception processing or jitter detection is required.
- FIG. 4 shows exemplary timing diagrams for bit leveling in accordance with the flowchart of FIG. 3 , where FIG. 4 a shows timing relationships before bit leveling and FIG. 4 b shows timing relationships after bit leveling.
- FIG. 6 shows an overall flowchart for an embodiment for bit leveling according to the invention including exception processing when a first sampled data bit is not an expected value, as well as jitter detection and correction.
- FIG. 8 shows diagrams describing timing relationships before and after exception processing plus a flow chart in FIG. 8 b showing steps to complete exception processing under a first condition, where FIG. 8 a shows timing relationships before bit leveling and FIG. 8 c shows timing relationships after bit leveling.
- FIG. 9 shows diagrams describing timing relationships before and after exception processing plus a flow chart in FIG. 9 b showing steps to complete exception processing under a second condition, where FIG. 9 a shows timing relationships before bit leveling and FIG. 9 c shows timing relationships after bit leveling.
- FIG. 11 shows timing diagrams for jitter detection and correction when the sampling point is in the vicinity of a falling edge of the sampled data bit, and jitter is present.
- FIG. 13 shows an exemplary flow chart for a generalized scenario where a data bit is sampled by incrementally sweeping a sampling point in time, and the results are analyzed to determine the best final sampling point.
- Bit leveling operations may be run at any time. However in some applications, bit leveling may be run after write leveling is performed and before a core clock capture synchronization operation is run when such a function is utilized. Examples of such core clock capture synchronization circuits and methods are described in U.S. Pat. No. 7,975,164 where such a function is termed SCL (Self-Configuring Logic), and also in US Patent Application Pub No 2011 / 0258475 where such a function is termed DSCL (Dynamic SCL).
- SCL Self-Configuring Logic
- Bit leveling according to the invention is able to be run dynamically at any point in time, preferably when the particular data interface is not being utilized such as for a dynamic memory data interface during a memory refresh operation.
- DQ dynamic memory controllers and data interfaces receiving data bits and strobes from dynamic memories
- bit-leveling aligns the rising edge with the center of the DQ data bit value. This is done in order to compensate for the unpredictable amount of delay on DQ and DQS that results in an undesirable skew between the DQ and DQS signals.
- the algorithm is implemented by reading a continuous pattern of alternating 1s and 0s from the DRAM on DQ and DQS.
- the alternating pattern may be either “1-0-1-0” or “0-1-0-1”, however for simplicity and consistency the pattern is described herein as 0-1-0-1.
- DQS is typically delayed by 90 degrees to align sampling edges of DQS with centers of DQ data bits.
- the rising edge of DQS is always sampling a “0” on DQ.
- the DQ data bit Prior to sampling, the DQ data bit is programmably delayed to allow advancing or delaying with respect to an edge of the DQS strobe. Therefore, in addition to the 90° delay of DQS mentioned above, DQS is additionally delayed by a programmable amount which is nominally equivalent to the amount DQ is initially programmably delayed. From this starting point, calibration processes determine further adjustment to the DQ the programmable delay line in order to place the center of each DQ data bit value in time aligned with the appropriate edge of the DQS strobe.
- FIG. 1 shows two generalized circuit diagrams for data interfaces according to the invention.
- data bit DQ 102 is programmably delayed in delay line 108 and thereafter is sampled at flip-flop 110 by a version of the DQS strobe 104 which has been delayed 106 by 90° to align its edge nominally with the center of a DQ data bit, and has also had a programmable delay added to position a delayed DQS strobe nominally centered relative to the delayed DQ data bit.
- FIG. 1 a data bit DQ 102 is programmably delayed in delay line 108 and thereafter is sampled at flip-flop 110 by a version of the DQS strobe 104 which has been delayed 106 by 90° to align its edge nominally with the center of a DQ data bit, and has also had a programmable delay added to position a delayed DQS strobe nominally centered relative to the delayed DQ data bit.
- bit leveling control circuit 112 is clocked by a core clock 116 , and a buffered version of the output of flip-flop 110 is synchronized with the same core clock 116 by synchronizing flip-flops 114 .
- Exemplary implementations shown herein focus in general on synchronizing with the positive edge of the sampling strobe (flip-flop 110 is has a positive edge clock input), with the assumption that if bit leveling is performed relative to the positive edge of a sampling strobe such as DQS 104 , the negative edge of such a sampling strobe will effectively align approximately in the center of the other half cycle of the data bit being sampled.
- FIG. 2 shows a more comprehensive example where the positive edge of DQS 104 , having been delayed 106 , samples delayed DQ data bit in flip-flop 110 , while the negative edge of the delayed DQS strobe samples the same delayed DQ data bit in flip-flop 202 .
- bit leveling calibration and synchronization function can be applied such that bit leveling for the delayed DQ data bit relative to the negative edge of the delayed DQS strobe is also performed. This would typically require additional instances of bit leveling control circuit 112 and an additional programmable delay line for each DQ data bit being bit leveled.
- bit-leveling operates by sampling DQ at the rising edge of DQS and then delays and advances DQ with respect to DQS so as to measure the distance (in delay line delay increments) to each edge of DQ. These distances, referred to as windows, are used to determine how far, or close, the rising edge of DQS is from the center of DQ and how much DQ needs to be delayed or advanced to center it.
- 3 and 4 demonstrate a scenario where DQ is being sampled too early, and the bit-leveling process therefore determines that a delay of (Ta ⁇ Tb)/2 QUOTE is to be added to DQ to align the center of a DQ data bit “0” value as close as possible with the rising edge of DQS.
- the bit leveling process determines if DQ is being sampled too early or too late, and therefore adjusts the delay on DQ to sample it correctly.
- a 0-1-0-1 pattern is installed such that it can be received by a data interface according to the invention during a calibration operation.
- a pattern is installed in a DRAM.
- step 304 while continuously receiving the 0-1-0-1 pattern, a programmably delayed version of a DQ data bit is sampled on the rising edge of DQS—where DQS has been delayed by 90° plus a suitable programmable delay as described previously. It is expected that given the data pattern received for this scenario, that when first sampled, a value of “0” will be sampled given the initial setting of the DQ programmable delay line.
- a value of “1” might instead be the expected value.
- DQ is subsequently delayed in time by some number of delay line increments until a “1” is sampled, and the total number of delay line increments required to achieve this point is recorded relative to the initial setting as Ta.
- DQ is advanced in time by incrementally adjusting the programmable delay line for DQ until a “1” is sampled, and the total number of increments advanced relative to the initial delay line setting is recorded as Tb.
- bit leveling is achieved by setting the programmable delay line delay value for DQ to be a delay value of (Ta ⁇ Tb)/2 from the initial sampling point. If however per step 312 , Tb is greater than Ta, bit leveling is achieved by setting the programmable delay line delay value for DQ to be an advance value of (Tb ⁇ Ta)/2 from the initial sampling point. If Ta is equal to Tb, then the strobe is centered within the data bit value for DQ, and no further adjustment beyond the initial setting of the delay line is required to achieve bit leveling.
- diagram 300 of FIG. 3 shows a simplified flow where when first sampled, the expected value is recorded as such no exception processing is required.
- Diagram 300 also includes no detection or compensation for jitter.
- FIG. 4 a shows the timing relationship between the DQS strobe 402 and the programmably delayed DQ data bit value 404 before bit leveling, where initial sampling point 406 is not properly centered within that portion of DQ having a “0” value 408 .
- the desired final sampling point is shown here as 410 .
- Timing measurement windows Ta 412 and Tb 414 are also shown where Ta is greater than Tb.
- FIG. 4 b shows the timing relationships after bit leveling where DQ has been additionally delayed by a value of (Ta ⁇ Tb)/2 from the initial sampling point such that sampling point 410 is now properly aligned to be at the center of that portion of DQ 404 where the data value is a “0”.
- Ta equals Tb as shown.
- a generalized circuit block diagram 500 for an exemplary and non-limiting embodiment of a bit leveling invention is shown in FIG. 5 .
- DQ 102 is delayed in programmable delay line 108 and sampled in flip-flop 110 by a strobe signal, in this case a delayed version 502 of DQS.
- a state machine 504 controls bit leveling calibration operations including counters 506 and 508 for advancing and delaying DQ as well as for storing counter values.
- delay measurements may be added or subtracted in block 512 , and compared in block 510 to determine “greater than”, “less than”, or “equal to” results.
- an implementation of the bit leveling controller circuit may require more storage capability for storing sampled data bit values at different delay increments, and/or for storing more counter values in order to facilitate the analysis process that is performed after and/or during the sweep process.
- Flowchart 600 of FIG. 6 shows an overall exemplary flow for an embodiment of the invention, including when exception handling is required and jitter detection and correction are performed.
- a 0-1-0-1 pattern has been installed such that it can be received by a data interface according to the invention during a calibration operation.
- such a pattern is installed in a DRAM.
- step 604 while continuously receiving the 0-1-0-1 pattern, a programmably delayed version of a DQ data bit is sampled on the rising edge of DQS—where DQS has been delayed by 90° plus a suitable programmable delay as described previously. It is expected in this scenario that when first sampled, a value of “0” will be sampled at the initial setting of the DQ programmable delay line.
- step 606 this determination is made, and if a value of “1” is detected, then exception handling is begun per step 608 .
- exception handling operations as described in FIGS. 7 , 8 , and 9 either bit leveling is completed or the process returns to step 604 as shown in FIG. 6 .
- step 610 DQ is delayed in time by increments from an initial starting point until a “1” is sampled, and the total delay relative to an initial starting point is recorded as Ta.
- step 612 DQ is advanced in time by increments from the initial starting point until a “1” is sampled, and the total delay relative to the initial starting point is recorded as Tb.
- jitter detection is performed per step 614 where (Ta+Tb) is compared with a jitter threshold value. If (Ta+Tb) is less than the jitter threshold value, then jitter compensation is performed 616 according to FIGS. 10 and 11 , after which the process returns to step 604 .
- Ta and Tb are compared.
- bit leveling is achieved by setting the programmable delay line for DQ to be a delay value of (Ta ⁇ Tb)/2 from the initial sampling point.
- Tb is greater than Ta
- bit leveling is achieved by setting the programmable delay line for DQ to be an advance value of (Tb ⁇ Ta)/2 from the initial sampling point. If Ta is equal to Tb, then according to the initial delay line setting the strobe is already centered within the data bit value for DQ, and no further adjustment beyond the initial setting of the delay line is required to achieve bit leveling.
- a first stage of exception processing is shown in flow-chart 700 of FIG. 7 where the process begins in step 702 having been preceded by step 608 of FIG. 6 .
- a “1” is initially sampled instead of a “0”
- DQ delay is too high or DQ delay is too small.
- the following steps are performed by the invention as shown in FIG. 7 .
- First per step 704 DQ is delayed from an initial starting point until a “0” is detected at the sample point, and this delay is recorded as Tc.
- step 706 DQ is advanced from the initial starting point until a “0” is detected at the sample point, and this delay is recorded as Td.
- step 708 it is appropriate to check for the presence of jitter according to step 708 . If the value (Tc+Td) is less than a Jitter Threshold value, then the process proceeds to step 710 for jitter correction where a Jitter Correction Offset value is added to the initial delay line setting, and the process moves 712 to step 604 of FIG. 6 where bit leveling starts again.
- the appropriate Jitter Threshold value and the Jitter Correction Offset value may vary from implementation to implementation, and proper and effective values will be chosen by the designer who understands all parameters involved in the decision.
- step 714 Tc and Td are compared. If per step 714 , Tc is not less than Td, the process proceeds 718 to step 810 of FIG. 8 b . If however per step 714 , Tc is less than Td, the process proceeds 716 to step 910 of FIG. 9 b .
- FIGS. 8 and 9 show timing diagrams and flow charts for completing the bit leveling process when exception handling is required.
- Diagrams and flow charts 800 of FIG. 8 show the completion of bit leveling when Tc 804 is greater than Td 806 .
- delayed DQ data bit 404 is sampled by strobe DQS 402 at an initial sampling point 802 where a “1” is detected which previously had initiated exception processing.
- the process continues in step 810 as a result of Tc being determined to be greater than Td according to step 716 of FIG. 7 .
- step 812 DQ is advanced from the initial delay line starting point until a “0” is detected (previously recorded as Td), and then further advanced until a “1” is detected, whereby the delay when the “1” is detected is recorded as Te.
- bit leveling is completed by setting the DQ delay line to advance DQ from the initial delay line starting point by a value of (Td+Te)/2, whereby a desired sampling point 808 is achieved.
- the timing diagram of FIG. 8C shows the timing relationships after bit leveling is completed. Delay value Te 816 is shown along with the final correction whereby DQ is advanced (delay is decremented) by a value equal to (Td+Te)/2 818 relative to the initial delay line starting point value.
- Diagrams and flow charts 900 of FIG. 9 show the completion of bit leveling when Tc 904 is less than Td 906 .
- delayed DQ data bit 404 is sampled by strobe DQS 402 at an initial sampling point 902 where a “1” is detected which previously had initiated exception processing.
- the process continues in step 910 as a result of Tc being determined to be less than Td according to step 718 of FIG. 7 .
- step 912 DQ is delayed from the initial delay line starting point until a “0” is detected (previously recorded as Tc), and then further delayed until a “1” is detected, whereby the delay when the “1” is detected is recorded as Tf.
- step 914 bit leveling is completed by setting the DQ delay line to delay DQ from the initial delay line starting point by a value of (Tc+Tf)/2, whereby a desired sampling point 908 is achieved.
- the timing diagram of FIG. 9C shows the timing relationships after bit leveling is completed. Delay value Tf 916 is shown along with the final correction whereby DQ is delayed (delay is incremented) by a value equal to (Tc+Tf)/2 918 relative to the initial delay line starting point value.
- Jitter on the DQS signal, and/or DQ signal may cause the sampled value of DQ to be taken incorrectly. This may happen when the initial sampling point is near a rising or falling edge of DQ.
- jitter has been shown on the DQS signal and not on the DQ signal. In reality jitter may exist on either signal or both, however to simplify the explanation and the drawings jitter is shown herein only on the DQS signal.
- a jitter scenario may arise when sampling DQ near either its rising or falling edge
- examples are shown for both edges with sampling near the rising edge of DQ shown in FIG. 10 and sampling near the falling edge of DQ shown in FIG. 11 .
- the rising edge of the DQS is shown with a jitter region between sample #1 edge 1002 and sample #2 & #3 edge 1004 .
- the initial sample, sample #1 may record a “0” 1006 . This is the expected value for an initial sample so the procedure of FIG. 6 continues initially as if no jitter is present. Subsequently due to jitter, sample #2 records a “1” 1008 defining Ta 1012 .
- jitter edge of DQS ( 1002 or 1004 ) will be positioned such that a “0” value will be detected when DQ is sampled.
- the rising edge of the DQS is shown with a jitter region between sample #1 edge 1102 and sample #2 & #3 edge 1104 .
- the initial sample, sample #1 may record a “0” 1106 . This is the expected value for an initial sample so the procedure of FIG. 6 continues initially as if no jitter is present. Subsequently, due to jitter, sample #2 records a “1” 1108 defining Ta 1112 . The procedure then continues and again due to jitter the next sample, sample #3, records a “1” 1110 defining Tb 1114 .
- DQ is first delayed from an initial position by number of increments which are swept as shown by sequence 1204 , and then subsequently swept in the opposite direction (advanced) by a number of increments shown as sequence 1206 .
- Each of these sweeps may continue for a predetermined number of delay line increments, or may continue until the end of the delay line is reached or until some other condition is satisfied.
- at each increment the value of DQ that is sampled is recorded.
- the recorded values of DQ for each delay line increments are analyzed to determine an optimum final sampling point 1208 .
- at least a portion of the analysis of the strings of sampled data bits is performed while the sweep of the delay line is executed, thereby requiring fewer data and counter values to be saved along the way for post-sweep analysis. For instance, only delay line increments where a sampled data bit value changes relative to its value at the previous delay line increment would be stored.
- a string of data bit values can be stored in successive memory or register locations within the bit-leveling controller circuit, with each location corresponding to an increment of the sweep. Then after the sweep is complete, these locations can be analyzed with the understanding that each successive bit location represents the data bit value at the next delay line increment.
- the optimum sampling point is determined by locating consecutive strings of sampled data bits having the same value, typically a “0”, and placing the final sampling point 1208 in the center of one of these consecutive strings.
- jitter is resolved in a different manner than described in FIGS. 10 and 11 .
- jitter occurs it becomes evident at the rising and falling edges of DQ such as falling edge 1210 shown for example in the enlarged diagram 1212 of FIG. 12 b where jitter zone 1214 is highlighted.
- an analysis method used with the sweep methodologies of FIGS. 12 and 13 when sweeping through a jitter zone sampled data values on successive samples may be different, and thus can be differentiated from a successive string of sample data bits having the same value, and where the string of sampled data values has a width of an appropriate size. Therefore in analyzing successive strings of sampled data bits having the same value, to be considered for placement of a final sampling point, a string of sample data bits having the same value must have a width greater than a jitter threshold value.
- FIG. 12 c shows initial sampling point 1216 and describes a scenario where a single sweep 1218 is performed from one delay position of the DQ delay line to another delay position of the DQ delay line. These positions may be the extreme settings of the delay line, or arbitrary start and finish positions as determined by the application.
- sampled data bits may be recorded for every increment while the sweep is performed, and successive strings of data bits having a “0” value are considered for possible placement of the final sampling point 1220 . Jitter is resolved in the same manner described above for FIG. 12 a .
- at least a portion of the analysis of the strings of sampled data bits may be performed while the sweep of the delay line is executed, thereby requiring fewer data and counter values to be saved along the way for post-sweep analysis.
- Flowchart 1300 of FIG. 13 shows a generalized description of a process encompassing the embodiments of FIG. 12 .
- a pattern of alternating “1”s and “0”s is received on a data bits signal, nominally DQ of FIGS. 12 a and 12 c .
- a programmable delay line is provided for delaying data received on the data bit signal, typically DQ for a dynamic memory interface, and a delayed data bit signal is produced.
- the delayed data bit signal is strobed by a data strobe signal, nominally a delayed version of DQS for dynamic memory interfaces. Strobing is performed at a regular interval to produce a sampled data bit signal value.
- the regular interval is typically at substantially the same frequency as the pattern of alternating “1”s and “0”s.
- the delay line delays are incrementally changed or swept until a condition is satisfied that indicates the changing should cease. This condition could be that a predetermined point along the delay line has been reached, or that the end of the delay line has been reached, or some other termination condition determined according to a specific application.
- the delay line is swept, at each increment the sampled data bits signal is recorded. Alternately, at least a portion of the analysis of the strings of sampled data bits is performed while the sweep of the delay line is executed, thereby requiring fewer data bit and counter values to be saved along the way for post-sweep analysis.
- step 1310 the recorded sampled data bit signal values are analyzed in order to determine the width and position of strings of consecutive sample data bits having the same signal values.
- Steps 1308 and 1310 can be combined in an alternative implementation such that at least a portion of the analysis of the strings of sampled data bits is performed while the sweep of the delay line is executed, thereby requiring fewer data and counter values to be saved along the way for post-sweep analysis.
- step 1312 a center point of one of the strings of consecutive sample data bits is chosen to be a desired sampling point.
- the programmable delay line for the data bit is set to a value that causes the data strobe signal to be aligned with the desired sampling point. If jitter is present, jitter is resolved by only considering consecutive strings of sampled data bits having the same value where the length of the string is greater than a jitter detection threshold.
- bit leveling has been completed for a particular data bit.
- a similar bit leveling capability is included for each data bit where system timing skews can affect the reliability of the data interface in question. This requires a reasonable amount of circuitry and if silicon real estate is an issue, bit leveling could be performed on a byte or nibble basis where a delay setting for one data bit of a byte or nibble is utilized for the other bits.
- bit leveling capabilities such as those described herein can be utilized for sampling data bits on the negative edge of a sampling strobe such as DQS in addition to the positive edge as focused on herein.
- the implementation may include the use of a computer system having a processor and a memory under the control of the processor, the memory storing instructions adapted to enable the processor to carry out operations as described hereinabove.
- the implementation may be realized, in a concrete manner, as a computer program product that includes a non-transient and tangible computer readable medium holding instructions adapted to enable a computer system to perform the operations as described above.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- General Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computing Systems (AREA)
- Mathematical Physics (AREA)
- Nonlinear Science (AREA)
- Dram (AREA)
- Synchronisation In Digital Transmission Systems (AREA)
- Dc Digital Transmission (AREA)
Abstract
Description
- A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
- The present invention relates generally to interface circuits, typically implemented on integrated circuits such as Processor chips, memory controller chips, and SOC (System On Chip) integrated circuits where such interface are required. One common example of such an interface would receive data read from dynamic memory chips that are located externally to a device containing the receiving interface.
- Given today's high clock rates and transmission line effects when signals must travel between integrated circuit chips, skew between different data bits in the same bus becomes a problem. As a system heats and cools during operation, and/or develops hot and cool spots, the skew between data bits can likewise change as data bit signals and strobe signals travel off chip and between chips through various system-level paths. Also, as these phenomenon dynamically change during operation, the skew between data bits can likewise change. Therefore, it would be useful to have a way to perform bit leveling from time to time during system operation, and to do so quickly, and to perform bit leveling independently for each data bit on a data bus.
- One application where a dynamic bit leveling capability is especially useful for compensating for variable system-level delays is that of dynamic memory interfaces where DQ data bits can develop a skew problem with respect to the DQS strobe used to sample them. Jitter can also develop between data bits and strobes, and it would also be useful to resolve jitter issues while performing a bit-leveling function.
- A circuit and method for implementing a adaptive bit-leveling function in an integrated circuit interface is disclosed. During a calibration operation, a pre-loaded data bit pattern is continuously sent from a sending device and is continuously read from an external bus by a receiving data interface on a receiving device. In the receiving interface, a programmable delay line incrementally delays or advances each individual data bit relative to a sampling point in time, and delays are recorded for different sampled data bit values, enabling a delay to be determined that best samples a data bit at its midpoint. During the bit leveling calibration process and the advancing and/or delaying of a data bit, jitter on the data bit signal may cause an ambiguity in the determination of a data value midpoint, and solutions are disclosed for detecting jitter and for resolving a midpoint for sampling a data bit even in the presence of jitter.
- To perform a calibration operation according to the invention a pattern of alternating “1s” and “0s” is read into a receiving data interface circuit and is processed according to the methods described herein. A strobe signal is delayed such that it will be nominally placed in the center of the delay line delay used to delay one or more data bit signals. As such, a particular data value, shown as a “0” for example in the description that follows, is expected when the strobe signal first samples a data bit signal. If the opposite value is recorded, according to a first embodiment of the invention this is considered an exception and is followed by special exception processing. When such an exception occurs, circuits and methods are disclosed that accommodate the exception and provide an optimum sampling point in time and the corresponding appropriate delay line delay for the sampled data bit.
- In a first embodiment of the invention a programmable delay line for delaying the sampled data bit is used to both advance and delay the data bit in time relative to a sampling strobe. In the case of data coming from a dynamic memory, the sampled data bit would typically be a programmably delayed version of DQ, while the sampling strobe is a delayed version of DQS.
- In a second embodiment of the invention, a programmable delay line for delaying the sampled data bit is used to incrementally sweep the delay of a sampled data bit in time relative to a sampling strobe, with sampled values recorded and/or analyzed at each increment, with an analysis also performed after completing the sweep to determine the best point in time to sample the data bit. The second embodiment may require a longer delay line for delaying the sampled data bit, additional time for the calibration operation, and additional controller storage capacity and control logic compared with the first embodiment. At the same time, the second embodiment includes an analysis process where criteria for analyzing strings of consecutive sampled data bits having the same value is performed such that jitter detection is performed at the same time, and there is no specific need for exception handling.
- The subject matter that is regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other objects, features, and advantages of the invention will be apparent from the following detailed description taken in conjunction with the accompanying drawings.
-
FIGS. 1A and 1B show exemplary and non-limiting embodiments for generalized circuit descriptions describing different aspects of the invention. -
FIG. 2 shows an exemplary and non-limiting embodiment for a generalized circuit description describing aspects of the invention. -
FIG. 3 shows an exemplary flowchart for bit leveling according to the invention where an expected data value is initially sampled, and where no exception processing or jitter detection is required. -
FIG. 4 shows exemplary timing diagrams for bit leveling in accordance with the flowchart ofFIG. 3 , whereFIG. 4 a shows timing relationships before bit leveling andFIG. 4 b shows timing relationships after bit leveling. -
FIG. 5 shows an exemplary and non-limiting circuit block diagram for a generalized bit leveling controller circuit according to the invention. -
FIG. 6 shows an overall flowchart for an embodiment for bit leveling according to the invention including exception processing when a first sampled data bit is not an expected value, as well as jitter detection and correction. -
FIG. 7 shows an exemplary flowchart for the first steps in a process for exception processing, also including jitter detection and correction. -
FIG. 8 shows diagrams describing timing relationships before and after exception processing plus a flow chart inFIG. 8 b showing steps to complete exception processing under a first condition, whereFIG. 8 a shows timing relationships before bit leveling andFIG. 8 c shows timing relationships after bit leveling. -
FIG. 9 shows diagrams describing timing relationships before and after exception processing plus a flow chart inFIG. 9 b showing steps to complete exception processing under a second condition, whereFIG. 9 a shows timing relationships before bit leveling andFIG. 9 c shows timing relationships after bit leveling. -
FIG. 10 shows timing diagrams for jitter detection and correction when the sampling point is in the vicinity of a rising edge of the sampled data bit, and jitter is present. -
FIG. 11 shows timing diagrams for jitter detection and correction when the sampling point is in the vicinity of a falling edge of the sampled data bit, and jitter is present. -
FIG. 12 shows exemplary timing diagrams for two scenarios where a data bit is sampled by incrementally sweeping a sampling point in time, and the results are analyzed to determine the best final sampling point, whereFIG. 12 a shows timing relationships before bit leveling,FIG. 12 b shows a jitter zone, andFIG. 12 c shows timing relationships after bit leveling. -
FIG. 13 shows an exemplary flow chart for a generalized scenario where a data bit is sampled by incrementally sweeping a sampling point in time, and the results are analyzed to determine the best final sampling point. - The embodiments disclosed by the invention are only examples of the many possible advantageous uses and implementations of the innovative teachings presented herein. In general, statements made in the specification of the present application do not necessarily limit any of the various claimed inventions. Moreover, some statements may apply to some inventive features but not to others. In general, unless otherwise indicated, singular elements may be in plural and vice versa with no loss of generality. In the drawings, like numerals refer to like parts through several views.
- Bit leveling operations, according to the exemplary and non-limiting embodiments described herein, may be run at any time. However in some applications, bit leveling may be run after write leveling is performed and before a core clock capture synchronization operation is run when such a function is utilized. Examples of such core clock capture synchronization circuits and methods are described in U.S. Pat. No. 7,975,164 where such a function is termed SCL (Self-Configuring Logic), and also in US Patent Application Pub No 2011/0258475 where such a function is termed DSCL (Dynamic SCL).
- Bit leveling according to the invention is able to be run dynamically at any point in time, preferably when the particular data interface is not being utilized such as for a dynamic memory data interface during a memory refresh operation. For the exemplary and non-limiting examples described herein for different embodiments of the invention, and in view of the fact that many common applications for the invention include dynamic memory controllers and data interfaces receiving data bits and strobes from dynamic memories, reference will typically be made to “DQ” for data bits being sampled and bit leveled, and to “DQS” as the corresponding sampling strobe. It should be understood however that the circuits and methods described herein are applicable to any data interface receiving data bits where skew and/or jitter develops and it is desirable to mitigate these problems in order to produce a more reliable data interface implementation.
- To ensure that the rising edge of DQS is sampling the respective DQ data accurately, bit-leveling aligns the rising edge with the center of the DQ data bit value. This is done in order to compensate for the unpredictable amount of delay on DQ and DQS that results in an undesirable skew between the DQ and DQS signals. The algorithm is implemented by reading a continuous pattern of alternating 1s and 0s from the DRAM on DQ and DQS. The alternating pattern may be either “1-0-1-0” or “0-1-0-1”, however for simplicity and consistency the pattern is described herein as 0-1-0-1. For exemplary embodiments described herein, DQS is typically delayed by 90 degrees to align sampling edges of DQS with centers of DQ data bits. Therefore ideally, the rising edge of DQS is always sampling a “0” on DQ. Prior to sampling, the DQ data bit is programmably delayed to allow advancing or delaying with respect to an edge of the DQS strobe. Therefore, in addition to the 90° delay of DQS mentioned above, DQS is additionally delayed by a programmable amount which is nominally equivalent to the amount DQ is initially programmably delayed. From this starting point, calibration processes determine further adjustment to the DQ the programmable delay line in order to place the center of each DQ data bit value in time aligned with the appropriate edge of the DQS strobe.
-
FIG. 1 shows two generalized circuit diagrams for data interfaces according to the invention. InFIG. 1 a,data bit DQ 102 is programmably delayed indelay line 108 and thereafter is sampled at flip-flop 110 by a version of theDQS strobe 104 which has been delayed 106 by 90° to align its edge nominally with the center of a DQ data bit, and has also had a programmable delay added to position a delayed DQS strobe nominally centered relative to the delayed DQ data bit.FIG. 1 a shows a more detailed exemplary implementation where bit levelingcontrol circuit 112 is clocked by acore clock 116, and a buffered version of the output of flip-flop 110 is synchronized with thesame core clock 116 by synchronizing flip-flops 114. - Exemplary implementations shown herein focus in general on synchronizing with the positive edge of the sampling strobe (flip-
flop 110 is has a positive edge clock input), with the assumption that if bit leveling is performed relative to the positive edge of a sampling strobe such asDQS 104, the negative edge of such a sampling strobe will effectively align approximately in the center of the other half cycle of the data bit being sampled.FIG. 2 shows a more comprehensive example where the positive edge ofDQS 104, having been delayed 106, samples delayed DQ data bit in flip-flop 110, while the negative edge of the delayed DQS strobe samples the same delayed DQ data bit in flip-flop 202. It should be noted that in another implementation, not shown, a similar bit leveling calibration and synchronization function can be applied such that bit leveling for the delayed DQ data bit relative to the negative edge of the delayed DQS strobe is also performed. This would typically require additional instances of bit levelingcontrol circuit 112 and an additional programmable delay line for each DQ data bit being bit leveled. - In an example demonstrating one exemplary embodiment, bit-leveling operates by sampling DQ at the rising edge of DQS and then delays and advances DQ with respect to DQS so as to measure the distance (in delay line delay increments) to each edge of DQ. These distances, referred to as windows, are used to determine how far, or close, the rising edge of DQS is from the center of DQ and how much DQ needs to be delayed or advanced to center it. The example of
FIGS. 3 and 4 demonstrate a scenario where DQ is being sampled too early, and the bit-leveling process therefore determines that a delay of (Ta−Tb)/2 QUOTE is to be added to DQ to align the center of a DQ data bit “0” value as close as possible with the rising edge of DQS. - In general, by determining the size of these delay measurement windows, the bit leveling process determines if DQ is being sampled too early or too late, and therefore adjusts the delay on DQ to sample it correctly.
- An
exemplary flowchart 300 for this process is shown inFIG. 3 . Instep 302, a 0-1-0-1 pattern is installed such that it can be received by a data interface according to the invention during a calibration operation. In this example, such a pattern is installed in a DRAM. According to step 304 while continuously receiving the 0-1-0-1 pattern, a programmably delayed version of a DQ data bit is sampled on the rising edge of DQS—where DQS has been delayed by 90° plus a suitable programmable delay as described previously. It is expected that given the data pattern received for this scenario, that when first sampled, a value of “0” will be sampled given the initial setting of the DQ programmable delay line. In an alternate embodiment, a value of “1” might instead be the expected value. Perstep 306, from the initial delay line setting for DQ, DQ is subsequently delayed in time by some number of delay line increments until a “1” is sampled, and the total number of delay line increments required to achieve this point is recorded relative to the initial setting as Ta. Perstep 308, DQ is advanced in time by incrementally adjusting the programmable delay line for DQ until a “1” is sampled, and the total number of increments advanced relative to the initial delay line setting is recorded as Tb. Subsequently perstep 310, if Ta is greater than Tb, bit leveling is achieved by setting the programmable delay line delay value for DQ to be a delay value of (Ta−Tb)/2 from the initial sampling point. If however perstep 312, Tb is greater than Ta, bit leveling is achieved by setting the programmable delay line delay value for DQ to be an advance value of (Tb−Ta)/2 from the initial sampling point. If Ta is equal to Tb, then the strobe is centered within the data bit value for DQ, and no further adjustment beyond the initial setting of the delay line is required to achieve bit leveling. - It should be noted that diagram 300 of
FIG. 3 shows a simplified flow where when first sampled, the expected value is recorded as such no exception processing is required. Diagram 300 also includes no detection or compensation for jitter. - Timing diagrams 400 for the scenario of
FIG. 3 are shown inFIG. 4 . Here,FIG. 4 a shows the timing relationship between theDQS strobe 402 and the programmably delayed DQ data bitvalue 404 before bit leveling, whereinitial sampling point 406 is not properly centered within that portion of DQ having a “0”value 408. The desired final sampling point is shown here as 410. Timingmeasurement windows Ta 412 andTb 414 are also shown where Ta is greater than Tb.FIG. 4 b shows the timing relationships after bit leveling where DQ has been additionally delayed by a value of (Ta−Tb)/2 from the initial sampling point such thatsampling point 410 is now properly aligned to be at the center of that portion ofDQ 404 where the data value is a “0”. After alignment, Ta equals Tb as shown. - A generalized circuit block diagram 500 for an exemplary and non-limiting embodiment of a bit leveling invention is shown in
FIG. 5 . In this example,DQ 102 is delayed inprogrammable delay line 108 and sampled in flip-flop 110 by a strobe signal, in this case a delayed version 502 of DQS. For this generalized description, a state machine 504 controls bit leveling calibration operations including counters 506 and 508 for advancing and delaying DQ as well as for storing counter values. According to different embodiments of the invention delay measurements may be added or subtracted in block 512, and compared in block 510 to determine “greater than”, “less than”, or “equal to” results. It should be noted that one skilled in the art could devise many different circuit implementations to implement the functionalities described herein, and that no one particular circuit implementation is defined according to the appended claims. Counters, comparators, and adder/subtractors may be used as described inFIG. 5 , however an equivalent functionality could be arrived at by simply having a much larger and more complex version of bit leveling state machine 504. - Note that for the alternative embodiment of
FIGS. 12 and 13 , an implementation of the bit leveling controller circuit may require more storage capability for storing sampled data bit values at different delay increments, and/or for storing more counter values in order to facilitate the analysis process that is performed after and/or during the sweep process. -
Flowchart 600 ofFIG. 6 shows an overall exemplary flow for an embodiment of the invention, including when exception handling is required and jitter detection and correction are performed. In step 602 a 0-1-0-1 pattern has been installed such that it can be received by a data interface according to the invention during a calibration operation. In this example, such a pattern is installed in a DRAM. According to step 604, while continuously receiving the 0-1-0-1 pattern, a programmably delayed version of a DQ data bit is sampled on the rising edge of DQS—where DQS has been delayed by 90° plus a suitable programmable delay as described previously. It is expected in this scenario that when first sampled, a value of “0” will be sampled at the initial setting of the DQ programmable delay line. Instep 606 this determination is made, and if a value of “1” is detected, then exception handling is begun perstep 608. During exception handling operations as described inFIGS. 7 , 8, and 9, either bit leveling is completed or the process returns to step 604 as shown inFIG. 6 . - If a “0” is sampled as expected per 606, the process proceeds to step 610 where DQ is delayed in time by increments from an initial starting point until a “1” is sampled, and the total delay relative to an initial starting point is recorded as Ta. Subsequently per
step 612, DQ is advanced in time by increments from the initial starting point until a “1” is sampled, and the total delay relative to the initial starting point is recorded as Tb. Next, jitter detection is performed perstep 614 where (Ta+Tb) is compared with a jitter threshold value. If (Ta+Tb) is less than the jitter threshold value, then jitter compensation is performed 616 according toFIGS. 10 and 11 , after which the process returns to step 604. Subsequently perstep 618, Ta and Tb are compared. Perstep 620, if Ta is greater than Tb, bit leveling is achieved by setting the programmable delay line for DQ to be a delay value of (Ta−Tb)/2 from the initial sampling point. If however perstep 622, Tb is greater than Ta, bit leveling is achieved by setting the programmable delay line for DQ to be an advance value of (Tb−Ta)/2 from the initial sampling point. If Ta is equal to Tb, then according to the initial delay line setting the strobe is already centered within the data bit value for DQ, and no further adjustment beyond the initial setting of the delay line is required to achieve bit leveling. - For the exemplary embodiment for data interface as applied to the dynamic memory controller application, it is typically expected that when first sampled at an initial DQ delay line setting, the sample data bit value will be a “0”. It is possible however that skews can develop in the system such that initial sampled value is instead a “1”. For these circumstances, a similar method as described above is used with some additional steps that provide for a third window measurement in order to position the delayed DQ data bit correctly with respect to sampling strobe DQS.
- A first stage of exception processing is shown in flow-
chart 700 ofFIG. 7 where the process begins instep 702 having been preceded bystep 608 ofFIG. 6 . When a “1” is initially sampled instead of a “0”, there are two possible scenarios that may exist —either DQ delay is too high or DQ delay is too small. To determine which might be the case, the following steps are performed by the invention as shown inFIG. 7 . First perstep 704, DQ is delayed from an initial starting point until a “0” is detected at the sample point, and this delay is recorded as Tc. Then perstep 706, DQ is advanced from the initial starting point until a “0” is detected at the sample point, and this delay is recorded as Td. At this point in the exception processing flow, it is appropriate to check for the presence of jitter according tostep 708. If the value (Tc+Td) is less than a Jitter Threshold value, then the process proceeds to step 710 for jitter correction where a Jitter Correction Offset value is added to the initial delay line setting, and the process moves 712 to step 604 ofFIG. 6 where bit leveling starts again. Note that the appropriate Jitter Threshold value and the Jitter Correction Offset value may vary from implementation to implementation, and proper and effective values will be chosen by the designer who understands all parameters involved in the decision. - If the value (Tc+Td) is not less than a Jitter Threshold value, then it is determined that jitter is not interfering with the bit leveling process and the flow proceeds to step 714 where Tc and Td are compared. If per
step 714, Tc is not less than Td, the process proceeds 718 to step 810 ofFIG. 8 b. If however perstep 714, Tc is less than Td, the process proceeds 716 to step 910 ofFIG. 9 b.FIGS. 8 and 9 show timing diagrams and flow charts for completing the bit leveling process when exception handling is required. - Diagrams and
flow charts 800 ofFIG. 8 show the completion of bit leveling whenTc 804 is greater thanTd 806. InFIG. 8 a, delayed DQ data bit 404 is sampled bystrobe DQS 402 at aninitial sampling point 802 where a “1” is detected which previously had initiated exception processing. In the flowchart ofFIG. 8 b, the process continues instep 810 as a result of Tc being determined to be greater than Td according to step 716 ofFIG. 7 . Instep 812, DQ is advanced from the initial delay line starting point until a “0” is detected (previously recorded as Td), and then further advanced until a “1” is detected, whereby the delay when the “1” is detected is recorded as Te. Then instep 814, bit leveling is completed by setting the DQ delay line to advance DQ from the initial delay line starting point by a value of (Td+Te)/2, whereby a desiredsampling point 808 is achieved. The timing diagram ofFIG. 8C shows the timing relationships after bit leveling is completed.Delay value Te 816 is shown along with the final correction whereby DQ is advanced (delay is decremented) by a value equal to (Td+Te)/2 818 relative to the initial delay line starting point value. - Diagrams and
flow charts 900 ofFIG. 9 show the completion of bit leveling whenTc 904 is less thanTd 906. InFIG. 9 a, delayed DQ data bit 404 is sampled bystrobe DQS 402 at aninitial sampling point 902 where a “1” is detected which previously had initiated exception processing. In the flowchart ofFIG. 9 b, the process continues instep 910 as a result of Tc being determined to be less than Td according to step 718 ofFIG. 7 . Instep 912, DQ is delayed from the initial delay line starting point until a “0” is detected (previously recorded as Tc), and then further delayed until a “1” is detected, whereby the delay when the “1” is detected is recorded as Tf. Then instep 914, bit leveling is completed by setting the DQ delay line to delay DQ from the initial delay line starting point by a value of (Tc+Tf)/2, whereby a desiredsampling point 908 is achieved. The timing diagram ofFIG. 9C shows the timing relationships after bit leveling is completed.Delay value Tf 916 is shown along with the final correction whereby DQ is delayed (delay is incremented) by a value equal to (Tc+Tf)/2 918 relative to the initial delay line starting point value. - Jitter on the DQS signal, and/or DQ signal, may cause the sampled value of DQ to be taken incorrectly. This may happen when the initial sampling point is near a rising or falling edge of DQ. In the exemplary and non-limiting embodiments that follow for jitter detection and correction, jitter has been shown on the DQS signal and not on the DQ signal. In reality jitter may exist on either signal or both, however to simplify the explanation and the drawings jitter is shown herein only on the DQS signal.
- Since a jitter scenario may arise when sampling DQ near either its rising or falling edge, examples are shown for both edges with sampling near the rising edge of DQ shown in
FIG. 10 and sampling near the falling edge of DQ shown inFIG. 11 . InFIG. 10 , the rising edge of the DQS is shown with a jitter region betweensample # 1edge 1002 andsample # 2 & #3edge 1004. When the sequence ofFIG. 6 is executed and jitter is present, the initial sample,sample # 1, may record a “0” 1006. This is the expected value for an initial sample so the procedure ofFIG. 6 continues initially as if no jitter is present. Subsequently due to jitter,sample # 2 records a “1” 1008 definingTa 1012. The procedure then continues and again due to jitter the next sample,sample # 3, records a “1” 1010 definingTb 1014. Consequently these measurements determine the size of the (Ta+Tb) window to be very small, or zero, when it should in fact be large, nearly a half cycle. To avoid utilizing this incorrect window value, a value of (Ta+Tb) is compared with a Jitter Correction Threshold value, and if the value (Ta+Tb) is less than this threshold value, a Jitter Correction Offset 1016 is added to the initial sampling point. Subsequently when the bit leveling process is restarted, and assuming a positive jitter correction offset is used to delay DQ from the initial sampling point, either jitter edge of DQS (1002 or 1004) will be positioned such that a “0” value will be detected when DQ is sampled. - Note that if jitter is present and the initial sampling point is near a rising or falling edge of DQ, but however the first sampled value is a “1”, then exception processing per
FIGS. 7-9 will be initiated and the jitter problem will be resolved through that procedure. - In
FIG. 11 , the rising edge of the DQS is shown with a jitter region betweensample # 1edge 1102 andsample # 2 & #3edge 1104. When the sequence ofFIG. 6 is executed and jitter is present, the initial sample,sample # 1, may record a “0” 1106. This is the expected value for an initial sample so the procedure ofFIG. 6 continues initially as if no jitter is present. Subsequently, due to jitter,sample # 2 records a “1” 1108 definingTa 1112. The procedure then continues and again due to jitter the next sample,sample # 3, records a “1” 1110 definingTb 1114. Consequently these measurements determine the size of the (Ta+Tb) window value to be very small, or zero, when it should in fact be large, nearly a half cycle. To avoid utilizing this incorrect window value, the value (Ta+Tb) is compared with a Jitter Correction Threshold value, and if the value (Ta+Tb) is less than this threshold value, a Jitter Correction Offset 1016 is added to the initial sampling point. Subsequently when the bit leveling process is restarted, and assuming a positive jitter correction offset is used to delay DQ from the initial sampling point, either jitter edge of DQS (1102 or 1104) will be positioned such that a “1” value will be detected when DQ is sampled. The detection of a “1” will initiate the exception processing sequence ofFIGS. 7-9 and bit leveling will be thus resolved. - The methods of the exemplary embodiments described by the methods of
FIGS. 6-11 utilize a relatively short delay line for delaying each DQ data bit, with exception processing and jitter detection/correction performed as required. These methods ofFIGS. 6-11 also require very little storage circuitry to implement a bit-leveling controller function. An alternative approach is shown in the exemplary and non-limiting embodiments ofFIGS. 12 and 13 , where the delay value of DQ is swept for a larger number of delay increments, either in two directions perFIG. 12 a or in a single direction perFIG. 12 c. As shown inFIG. 12 a, an initial sampling point might be timed to sample a “0” onDQ 404, however for the operational methods for the embodiments ofFIGS. 12 and 13 , it doesn't matter whether the initial sampled value for DQ is a “0” or a “1”. As shown inFIG. 12 a, DQ is first delayed from an initial position by number of increments which are swept as shown bysequence 1204, and then subsequently swept in the opposite direction (advanced) by a number of increments shown assequence 1206. Each of these sweeps may continue for a predetermined number of delay line increments, or may continue until the end of the delay line is reached or until some other condition is satisfied. In one exemplary and non-limiting embodiment, at each increment the value of DQ that is sampled is recorded. Subsequently aftersweeps final sampling point 1208. In an alternative implementation for the embodiment ofFIGS. 12 and 13 , at least a portion of the analysis of the strings of sampled data bits is performed while the sweep of the delay line is executed, thereby requiring fewer data and counter values to be saved along the way for post-sweep analysis. For instance, only delay line increments where a sampled data bit value changes relative to its value at the previous delay line increment would be stored. In yet another alternative embodiment for a sweep-based controller function, to avoid storing counter values a string of data bit values can be stored in successive memory or register locations within the bit-leveling controller circuit, with each location corresponding to an increment of the sweep. Then after the sweep is complete, these locations can be analyzed with the understanding that each successive bit location represents the data bit value at the next delay line increment. For all embodiments of a sweep-based methodology, the optimum sampling point is determined by locating consecutive strings of sampled data bits having the same value, typically a “0”, and placing thefinal sampling point 1208 in the center of one of these consecutive strings. - For embodiments per
FIGS. 12 and 13 , jitter is resolved in a different manner than described inFIGS. 10 and 11 . When jitter occurs it becomes evident at the rising and falling edges of DQ such as fallingedge 1210 shown for example in the enlarged diagram 1212 ofFIG. 12 b wherejitter zone 1214 is highlighted. According to an analysis method used with the sweep methodologies ofFIGS. 12 and 13 , when sweeping through a jitter zone sampled data values on successive samples may be different, and thus can be differentiated from a successive string of sample data bits having the same value, and where the string of sampled data values has a width of an appropriate size. Therefore in analyzing successive strings of sampled data bits having the same value, to be considered for placement of a final sampling point, a string of sample data bits having the same value must have a width greater than a jitter threshold value. - The diagram of
FIG. 12 c showsinitial sampling point 1216 and describes a scenario where asingle sweep 1218 is performed from one delay position of the DQ delay line to another delay position of the DQ delay line. These positions may be the extreme settings of the delay line, or arbitrary start and finish positions as determined by the application. As described above forFIG. 12 a, sampled data bits may be recorded for every increment while the sweep is performed, and successive strings of data bits having a “0” value are considered for possible placement of thefinal sampling point 1220. Jitter is resolved in the same manner described above forFIG. 12 a. Alternately, at least a portion of the analysis of the strings of sampled data bits may be performed while the sweep of the delay line is executed, thereby requiring fewer data and counter values to be saved along the way for post-sweep analysis. -
Flowchart 1300 ofFIG. 13 shows a generalized description of a process encompassing the embodiments ofFIG. 12 . Instep 1302, a pattern of alternating “1”s and “0”s is received on a data bits signal, nominally DQ ofFIGS. 12 a and 12 c. In step 1304 a programmable delay line is provided for delaying data received on the data bit signal, typically DQ for a dynamic memory interface, and a delayed data bit signal is produced. Instep 1306 the delayed data bit signal is strobed by a data strobe signal, nominally a delayed version of DQS for dynamic memory interfaces. Strobing is performed at a regular interval to produce a sampled data bit signal value. The regular interval is typically at substantially the same frequency as the pattern of alternating “1”s and “0”s. Instep 1308, from an initial delay setting for the delay line that delays the data bit (DQ), the delay line delays are incrementally changed or swept until a condition is satisfied that indicates the changing should cease. This condition could be that a predetermined point along the delay line has been reached, or that the end of the delay line has been reached, or some other termination condition determined according to a specific application. As the delay line is swept, at each increment the sampled data bits signal is recorded. Alternately, at least a portion of the analysis of the strings of sampled data bits is performed while the sweep of the delay line is executed, thereby requiring fewer data bit and counter values to be saved along the way for post-sweep analysis. - In
step 1310 the recorded sampled data bit signal values are analyzed in order to determine the width and position of strings of consecutive sample data bits having the same signal values. Note thatSteps - In step 1312 a center point of one of the strings of consecutive sample data bits is chosen to be a desired sampling point. In
step 1314 the programmable delay line for the data bit is set to a value that causes the data strobe signal to be aligned with the desired sampling point. If jitter is present, jitter is resolved by only considering consecutive strings of sampled data bits having the same value where the length of the string is greater than a jitter detection threshold. - At this point in the method of
FIG. 13 , bit leveling has been completed for a particular data bit. Typically, a similar bit leveling capability is included for each data bit where system timing skews can affect the reliability of the data interface in question. This requires a reasonable amount of circuitry and if silicon real estate is an issue, bit leveling could be performed on a byte or nibble basis where a delay setting for one data bit of a byte or nibble is utilized for the other bits. On the other hand, if silicon real estate is not an issue, bit leveling capabilities such as those described herein can be utilized for sampling data bits on the negative edge of a sampling strobe such as DQS in addition to the positive edge as focused on herein. - Thus, a circuit and operating method for adaptive bit-leveling for data interfaces has been described.
- It should be appreciated by a person skilled in the art that methods, processes and systems described herein can be implemented in software, hardware, firmware, or any combination thereof. The implementation may include the use of a computer system having a processor and a memory under the control of the processor, the memory storing instructions adapted to enable the processor to carry out operations as described hereinabove. The implementation may be realized, in a concrete manner, as a computer program product that includes a non-transient and tangible computer readable medium holding instructions adapted to enable a computer system to perform the operations as described above.
Claims (36)
Priority Applications (14)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/797,200 US20140281662A1 (en) | 2013-03-12 | 2013-03-12 | Dynamically adaptive bit-leveling for data interfaces |
PCT/US2014/024637 WO2014165169A2 (en) | 2013-03-12 | 2014-03-12 | Dynamically adaptive bit-leveling for data interfaces |
US14/273,455 US20140372787A1 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US14/273,416 US9300443B2 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
US14/273,438 US20150006980A1 (en) | 2013-03-12 | 2014-05-08 | Circuits for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US14/850,792 US9425778B2 (en) | 2013-03-12 | 2015-09-10 | Continuous adaptive data capture optimization for interface circuits |
US15/078,939 US9584309B2 (en) | 2013-03-12 | 2016-03-23 | Circuit for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
US15/237,473 US9898433B2 (en) | 2013-03-12 | 2016-08-15 | Continuous adaptive data capture optimization for interface circuits |
US15/853,568 US20180121382A1 (en) | 2013-03-12 | 2017-12-22 | Continuous adaptive data capture optimization for interface circuits |
US16/254,436 US20190286591A1 (en) | 2013-03-12 | 2019-01-22 | Continuous adaptive data capture optimization for interface circuits |
US17/074,403 US11334509B2 (en) | 2013-03-12 | 2020-10-19 | Continuous adaptive data capture optimization for interface circuits |
US17/724,221 US11714769B2 (en) | 2013-03-12 | 2022-04-19 | Continuous adaptive data capture optimization for interface circuits |
US18/209,083 US12019573B2 (en) | 2013-03-12 | 2023-06-13 | Continuous adaptive data capture optimization for interface circuits |
US18/665,365 US20240303209A1 (en) | 2013-03-12 | 2024-05-15 | Continuous adaptive data capture optimization for interface circuits |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/797,200 US20140281662A1 (en) | 2013-03-12 | 2013-03-12 | Dynamically adaptive bit-leveling for data interfaces |
Related Child Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/273,455 Continuation US20140372787A1 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US14/273,416 Continuation US9300443B2 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
US14/273,438 Continuation US20150006980A1 (en) | 2013-03-12 | 2014-05-08 | Circuits for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
Publications (1)
Publication Number | Publication Date |
---|---|
US20140281662A1 true US20140281662A1 (en) | 2014-09-18 |
Family
ID=51534155
Family Applications (5)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/797,200 Abandoned US20140281662A1 (en) | 2013-03-12 | 2013-03-12 | Dynamically adaptive bit-leveling for data interfaces |
US14/273,416 Active US9300443B2 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
US14/273,438 Abandoned US20150006980A1 (en) | 2013-03-12 | 2014-05-08 | Circuits for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US14/273,455 Abandoned US20140372787A1 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US15/078,939 Active US9584309B2 (en) | 2013-03-12 | 2016-03-23 | Circuit for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
Family Applications After (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/273,416 Active US9300443B2 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
US14/273,438 Abandoned US20150006980A1 (en) | 2013-03-12 | 2014-05-08 | Circuits for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US14/273,455 Abandoned US20140372787A1 (en) | 2013-03-12 | 2014-05-08 | Methods for dynamically adaptive bit-leveling by sweep sampling with automatic jitter avoidance |
US15/078,939 Active US9584309B2 (en) | 2013-03-12 | 2016-03-23 | Circuit for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling |
Country Status (2)
Country | Link |
---|---|
US (5) | US20140281662A1 (en) |
WO (1) | WO2014165169A2 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110098897A (en) * | 2019-04-25 | 2019-08-06 | 珠海格力电器股份有限公司 | Serial communication method, device, computer equipment and storage medium |
US10678295B2 (en) * | 2018-02-21 | 2020-06-09 | Au Optronics Corporation | Method and device of data capture |
US12051481B1 (en) * | 2021-12-07 | 2024-07-30 | Synopsys, Inc. | Automatic tracking for clock synchronization based on delay line adjustment |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9305622B1 (en) * | 2015-01-23 | 2016-04-05 | Apple Inc. | Data strobe to data delay calibration |
US9880263B2 (en) * | 2015-04-06 | 2018-01-30 | Waymo Llc | Long range steerable LIDAR system |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030154416A1 (en) * | 2002-02-11 | 2003-08-14 | Laberge Paul A. | Method and apparatus for data transfer |
US20070226529A1 (en) * | 2006-03-21 | 2007-09-27 | Mediatek Inc. | Memory controller and device with data strobe calibration |
US20100299644A1 (en) * | 2009-05-22 | 2010-11-25 | Fujitsu Semiconductor Limited | Timing adjustment device and method thereof |
US8134878B1 (en) * | 2009-01-31 | 2012-03-13 | Xilinx, Inc. | Signal calibration for memory interface |
WO2012145117A2 (en) * | 2011-04-22 | 2012-10-26 | Rambus Inc. | Memory components and controllers that calibrate multiphase synchronous timing references |
US8588014B1 (en) * | 2011-05-31 | 2013-11-19 | Altera Corporation | Methods for memory interface calibration |
Family Cites Families (48)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5157530A (en) | 1990-01-18 | 1992-10-20 | International Business Machines Corporation | Optical fiber system |
US6510503B2 (en) | 1998-07-27 | 2003-01-21 | Mosaid Technologies Incorporated | High bandwidth memory interface |
US6434081B1 (en) | 2000-05-12 | 2002-08-13 | Micron Technology, Inc. | Calibration technique for memory devices |
US6782459B1 (en) | 2000-08-14 | 2004-08-24 | Rambus, Inc. | Method and apparatus for controlling a read valid window of a synchronous memory device |
US6691214B1 (en) * | 2000-08-29 | 2004-02-10 | Micron Technology, Inc. | DDR II write data capture calibration |
US6442102B1 (en) | 2001-04-04 | 2002-08-27 | International Business Machines Corporation | Method and apparatus for implementing high speed DDR SDRAM read interface with reduced ACLV effects |
JP4067787B2 (en) | 2001-07-05 | 2008-03-26 | 富士通株式会社 | Parallel signal transmission device |
JP2003050738A (en) | 2001-08-03 | 2003-02-21 | Elpida Memory Inc | Calibration method and memory system |
US6788124B1 (en) | 2002-10-31 | 2004-09-07 | Xilinx, Inc. | Method and apparatus for reducing jitter in a delay line and a trim unit |
US7036053B2 (en) | 2002-12-19 | 2006-04-25 | Intel Corporation | Two dimensional data eye centering for source synchronous data transfers |
US7209531B1 (en) | 2003-03-26 | 2007-04-24 | Cavium Networks, Inc. | Apparatus and method for data deskew |
US7240249B2 (en) | 2003-06-26 | 2007-07-03 | International Business Machines Corporation | Circuit for bit skew suppression in high speed multichannel data transmission |
US7042296B2 (en) | 2003-09-25 | 2006-05-09 | Lsi Logic Corporation | Digital programmable delay scheme to continuously calibrate and track delay over process, voltage and temperature |
US7123051B1 (en) | 2004-06-21 | 2006-10-17 | Altera Corporation | Soft core control of dedicated memory interface hardware in a programmable logic device |
US7171321B2 (en) | 2004-08-20 | 2007-01-30 | Rambus Inc. | Individual data line strobe-offset control in memory systems |
US7366862B2 (en) | 2004-11-12 | 2008-04-29 | Lsi Logic Corporation | Method and apparatus for self-adjusting input delay in DDR-based memory systems |
US7543172B2 (en) | 2004-12-21 | 2009-06-02 | Rambus Inc. | Strobe masking in a signaling system having multiple clock domains |
US7215584B2 (en) | 2005-07-01 | 2007-05-08 | Lsi Logic Corporation | Method and/or apparatus for training DQS strobe gating |
JP4718933B2 (en) | 2005-08-24 | 2011-07-06 | 富士通株式会社 | Parallel signal skew adjustment circuit and skew adjustment method |
US8121237B2 (en) * | 2006-03-16 | 2012-02-21 | Rambus Inc. | Signaling system with adaptive timing calibration |
US7509223B2 (en) | 2006-04-21 | 2009-03-24 | Altera Corporation | Read-side calibration for data interface |
US7755402B1 (en) | 2006-04-28 | 2010-07-13 | Nvidia | Calibration of separate delay effects for multiple data strobe signals |
US7647467B1 (en) | 2006-05-25 | 2010-01-12 | Nvidia Corporation | Tuning DRAM I/O parameters on the fly |
US7685393B2 (en) | 2006-06-30 | 2010-03-23 | Mosaid Technologies Incorporated | Synchronous memory read data capture |
JP5013768B2 (en) | 2006-08-03 | 2012-08-29 | ルネサスエレクトロニクス株式会社 | Interface circuit |
US8122275B2 (en) * | 2006-08-24 | 2012-02-21 | Altera Corporation | Write-leveling implementation in programmable logic devices |
US7818528B2 (en) | 2006-09-19 | 2010-10-19 | Lsi Corporation | System and method for asynchronous clock regeneration |
US7405984B2 (en) | 2006-09-19 | 2008-07-29 | Lsi Corporation | System and method for providing programmable delay read data strobe gating with voltage and temperature compensation |
US7571396B2 (en) | 2006-09-19 | 2009-08-04 | Lsi Logic Corporation | System and method for providing swap path voltage and temperature compensation |
US7454303B2 (en) | 2006-12-21 | 2008-11-18 | Lsi Logic Corporation | System and method for compensating for PVT variation effects on the delay line of a clock signal |
US20080276133A1 (en) | 2007-05-02 | 2008-11-06 | Andrew Hadley | Software-Controlled Dynamic DDR Calibration |
US8108738B2 (en) * | 2007-06-26 | 2012-01-31 | International Business Machines Corporation | Data eye monitor method and apparatus |
US7979228B2 (en) | 2007-07-20 | 2011-07-12 | The Regents Of The University Of Michigan | High resolution time measurement in a FPGA |
US20090168563A1 (en) | 2007-12-31 | 2009-07-02 | Yueming Jiang | Apparatus, system, and method for bitwise deskewing |
US7924637B2 (en) | 2008-03-31 | 2011-04-12 | Advanced Micro Devices, Inc. | Method for training dynamic random access memory (DRAM) controller timing delays |
US7975164B2 (en) | 2008-06-06 | 2011-07-05 | Uniquify, Incorporated | DDR memory controller |
US8661285B2 (en) | 2008-06-06 | 2014-02-25 | Uniquify, Incorporated | Dynamically calibrated DDR memory controller |
US8139430B2 (en) | 2008-07-01 | 2012-03-20 | International Business Machines Corporation | Power-on initialization and test for a cascade interconnect memory system |
JP5384910B2 (en) | 2008-11-11 | 2014-01-08 | ルネサスエレクトロニクス株式会社 | Semiconductor integrated circuit and clock synchronization control method |
JP2012515376A (en) | 2009-01-12 | 2012-07-05 | ラムバス・インコーポレーテッド | Clock transfer low power signaling system |
TWI410982B (en) | 2009-03-18 | 2013-10-01 | Mstar Semiconductor Inc | Method and circuit of calibrating data strobe signal in memory controller |
US8269538B2 (en) | 2009-04-27 | 2012-09-18 | Mosys, Inc. | Signal alignment system |
US7957218B2 (en) | 2009-06-11 | 2011-06-07 | Freescale Semiconductor, Inc. | Memory controller with skew control and method |
US7965212B1 (en) * | 2010-02-12 | 2011-06-21 | Bae Systems Information And Electronic Systems Integration Inc. | DAC circuit using summing junction delay compensation |
US8300464B2 (en) | 2010-04-13 | 2012-10-30 | Freescale Semiconductor, Inc. | Method and circuit for calibrating data capture in a memory controller |
US8385144B2 (en) | 2011-02-25 | 2013-02-26 | Lsi Corporation | Utilizing two algorithms to determine a delay value for training DDR3 memory |
JP2012203515A (en) | 2011-03-24 | 2012-10-22 | Toshiba Corp | Semiconductor device |
US8780655B1 (en) * | 2012-12-24 | 2014-07-15 | Arm Limited | Method and apparatus for aligning a clock signal and a data strobe signal in a memory system |
-
2013
- 2013-03-12 US US13/797,200 patent/US20140281662A1/en not_active Abandoned
-
2014
- 2014-03-12 WO PCT/US2014/024637 patent/WO2014165169A2/en active Application Filing
- 2014-05-08 US US14/273,416 patent/US9300443B2/en active Active
- 2014-05-08 US US14/273,438 patent/US20150006980A1/en not_active Abandoned
- 2014-05-08 US US14/273,455 patent/US20140372787A1/en not_active Abandoned
-
2016
- 2016-03-23 US US15/078,939 patent/US9584309B2/en active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030154416A1 (en) * | 2002-02-11 | 2003-08-14 | Laberge Paul A. | Method and apparatus for data transfer |
US20070226529A1 (en) * | 2006-03-21 | 2007-09-27 | Mediatek Inc. | Memory controller and device with data strobe calibration |
US8134878B1 (en) * | 2009-01-31 | 2012-03-13 | Xilinx, Inc. | Signal calibration for memory interface |
US20100299644A1 (en) * | 2009-05-22 | 2010-11-25 | Fujitsu Semiconductor Limited | Timing adjustment device and method thereof |
WO2012145117A2 (en) * | 2011-04-22 | 2012-10-26 | Rambus Inc. | Memory components and controllers that calibrate multiphase synchronous timing references |
US8588014B1 (en) * | 2011-05-31 | 2013-11-19 | Altera Corporation | Methods for memory interface calibration |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10678295B2 (en) * | 2018-02-21 | 2020-06-09 | Au Optronics Corporation | Method and device of data capture |
CN110098897A (en) * | 2019-04-25 | 2019-08-06 | 珠海格力电器股份有限公司 | Serial communication method, device, computer equipment and storage medium |
US12051481B1 (en) * | 2021-12-07 | 2024-07-30 | Synopsys, Inc. | Automatic tracking for clock synchronization based on delay line adjustment |
Also Published As
Publication number | Publication date |
---|---|
US20150006980A1 (en) | 2015-01-01 |
US20160254903A1 (en) | 2016-09-01 |
WO2014165169A2 (en) | 2014-10-09 |
WO2014165169A3 (en) | 2014-11-27 |
US20140372787A1 (en) | 2014-12-18 |
US9300443B2 (en) | 2016-03-29 |
US20140281666A1 (en) | 2014-09-18 |
US9584309B2 (en) | 2017-02-28 |
WO2014165169A9 (en) | 2015-06-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9584309B2 (en) | Circuit for dynamically adaptive bit-leveling by incremental sampling, jitter detection, and exception handling | |
US8941423B2 (en) | Method for operating a circuit including a timing calibration function | |
US6509762B1 (en) | Method and apparatus for measuring the phase of captured read data | |
US8767471B2 (en) | Systems and methods for auto-calibration of a storage memory controller | |
TWI558150B (en) | Eye-width detector, memory storage device and eye-width detection method of data signal | |
KR100958902B1 (en) | Evaluation method of the phase adjusting function, an information processing apparatus, and a computer-readable information recording medium | |
US20240303209A1 (en) | Continuous adaptive data capture optimization for interface circuits | |
US10545866B1 (en) | Method and system for efficient re-determination of a data valid window | |
US11520940B2 (en) | Secured communication by monitoring bus transactions using selectively delayed clock signal | |
US9437261B2 (en) | Memory controller and information processing device | |
KR101217937B1 (en) | Adaptive digital phy for high speed external memory interface | |
US9213359B2 (en) | Interface for controlling the phase alignment of clock signals for a recipient device | |
KR102671708B1 (en) | Data storage device and operating method thereof | |
US10902896B2 (en) | Memory circuit and method thereof | |
US9552310B2 (en) | Signal control circuit, information processing apparatus, and signal control method | |
CN106419921B (en) | Eye width detector, memory storage device and eye width detection method of data signal | |
US8254189B2 (en) | Method for tuning control signal associated with at least one memory device | |
TWI411976B (en) | Video processing system and method for calibrating a sampling phase |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: UNIQUIFY, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GOPALAN, MAHESH;REEL/FRAME:029976/0603 Effective date: 20130307 |
|
AS | Assignment |
Owner name: MONTAGE CAPITAL II, L.P., CALIFORNIA Free format text: SECURITY INTEREST;ASSIGNOR:UNIQUIFY, INC.;REEL/FRAME:033887/0923 Effective date: 20141003 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: UNIQUIFY, INC., CALIFORNIA Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:MONTAGE CAPITAL II, L.P.;REEL/FRAME:043927/0747 Effective date: 20171020 |
|
AS | Assignment |
Owner name: UNIQUIFY, INC., CALIFORNIA Free format text: CERTIFICATE OF MERGER;ASSIGNOR:UNIQUIFY IP COMPANY, LLC;REEL/FRAME:057326/0887 Effective date: 20210630 Owner name: UNIQUIFY, INC., CALIFORNIA Free format text: MERGER;ASSIGNOR:UNIQUIFY IP COMPANY, LLC;REEL/FRAME:056725/0939 Effective date: 20210630 Owner name: NEWLIGHT CAPITAL LLC, AS SERVICER, CALIFORNIA Free format text: SHORT FORM INTELLECTUAL PROPERTY SECURITY AGREEMENT;ASSIGNOR:UNIQUIFY, INC.;REEL/FRAME:056728/0317 Effective date: 20210630 Owner name: NEWLIGHT CAPITAL LLC, AS SERVICER, CALIFORNIA Free format text: SHORT FORM INTELLECTUAL PROPERTY SECURITY AGREEMENT;ASSIGNOR:UNIQUIFY, INC.;REEL/FRAME:056729/0519 Effective date: 20210630 |