This relates generally to automatic test equipment (ATE) technologies, and more particularly, to a method and apparatus for calibrating a time vernier with an input data signal, a reference signal and a third trigger signal, all of which have pre-defined related frequencies so as to allow for accurate determination of vernier delays and strobe placement in an ATE system.
In automatic test equipment (ATE) systems, a phase delay register is often used to control the placement of a clock signal or a strobe with respect to the input data signals. Sometimes the strobe signal is not available for direct measurement. The strobe position with respect to the input data waveform may be indirectly captured via placing strobes on a number of bits in a known input waveform and observing the number of errors produced, which gives a statistical indication when the strobe position coincides with the input bit transition time. In order to accurately determine the strobe positions, there is a need for time vernier calibration, or more precisely, a need for calibrating the actual delay of a strobe signal with respect to the programmed delay setting of a phase delay register.
Among the existing time vernier calibration methods, some require access to the input and output signals of the time vernier or time delay generator, or at least observability of periodic output signals from the time delay generator. For example, the time vernier can be placed in a feedback loop to make a ring oscillator so that the resulting signal frequency can be measured to determine the actual delay. Alternatively, the input and output signals from a timing generator can be observed by an oscilloscope or any other external time measurement instrument and the actual delay can be measured with the increase in the programmed time delay. However, these techniques are not applicable when the input and output signals of a time vernier or time delay generator are not accessible.
Time vernier calibration can also be accomplished through synchronizing an input signal with respect to the strobe signal and subsequently introducing known delays on the input signal. Under this approach, the strobe delay can be adjusted to find the edge transition of the delayed input signal and the known delay as compared to the programmed delay value. If the time verniers to be calibrated have pico-second step size, however, it is generally difficult and expensive to generate known delays with such sub-picosecond resolution and accuracy as necessary to calibrate the time verniers.
Another approach for time vernier calibration is to create accurate delay increments via “precession” or “walking” of two signals having closely spaced but not identical periods. The problem with this approach is the difficult alignment of two signals, namely, how to synchronize the two signals such that they can be consistently time aligned for repetitive measurements.
In light of the above, a need exists for an inexpensive and easy-to-implement method and apparatus for time vernier calibration that can greatly enhance existing ATE systems.
Embodiments of the present invention provide a method and apparatus for calibrating a time vernier with an input data signal, a reference signal and a third trigger signal, all of which have pre-defined related frequencies so as to allow for accurate determination of vernier delays and strobe placement in an ATE system. In one embodiment, a time vernier calibration method comprises generating a data signal and a reference signal whose periods differ by a small amount (dt); using precession of said data signal and reference signal to create accurate delay increments; and creating a trigger signal for BERT (Bit Error Rate Test) counting, said trigger signal having a select frequency such that an integer number (N) of triggers are generated within a precession period (TPREC), wherein upon occurrence of each trigger, a BERT is initiated for data measurement in determining strobe positions with respect to said data signal
In another embodiment, an apparatus comprises a data signal generator configured for generating a data signal; and a trigger signal generator configured for generating a trigger signal, wherein said data signal and a reference signal have close periods that differ by a small amount (dt) such that precession of said two signals creates accurate delay increments, and wherein said trigger signal has a select frequency such that an integer number (N) of triggers are generated within a precession period (TPREC), and upon occurrence of each trigger, a BERT is initiated for data measurement in determining strobe positions with respect to said data signal.
Yet another embodiment provides a time vernier calibration method comprising generating two closely spaced signals including a data signal and a reference signal from a common reference frequency; receiving said data signal in a time vernier, said time vernier configured to introduce delays upon said data signal or said reference signal; setting a programmed delay in a phase delay register to a first value, said phase delay register configured to control strobe placement with respect to said data signal; and generating an integer number of triggers in a precession period with a desired resolution, each of said triggers initiating a BERT count for determining strobe positions with respect to said data signal. The time vernier calibration method can further comprise generating a reference frame based on said BERT counts at each of said triggers; and determining from said reference frame a first trigger number corresponding to a pre-defined error count rate, said first trigger number corresponding to said first value of said programmed delay. The time vernier calibration method can also comprise setting said programmed delay to a second value; generating said triggers with said desired resolution to initiate BERT counts; generating a representation based on said BERT counts at each of said triggers; determining from said representation a second trigger number corresponding to said pre-defined error count rate, said second trigger number corresponding to said second value of said programmed delay; and determining an actual time vernier delay based on said first trigger number, said second trigger number and said desired resolution. Or the method can comprise setting said programmed delay to a second value; using said reference frame to estimate one or more trigger numbers associated with said second value of said programmed delay; measuring data at triggers within a time interval around said estimated trigger numbers; determining from said measured data a second trigger number corresponding to said second value of said programmed delay; and determining an actual time vernier delay based on said first trigger number, said second trigger number and said desired resolution.
In the following description of preferred embodiments, reference is made to the accompanying drawings which form a part hereof, and in which it is shown by way of illustration specific embodiments in which the invention can be practiced. It is to be understood that other embodiments can be used and structural changes can be made without departing from the scope of the embodiments of this invention.
Embodiments of the present invention relate to automatic test equipment (ATE) technologies, and more particularly, to a method and apparatus for calibrating a time vernier with an input data signal, a reference signal and a third trigger signal. The frequencies of all three signals are closely related and carefully chosen for accurate determination of vernier delays and strobe placement in an ATE system. In one embodiment, the data signal and reference signal are generated according to a system reference frequency such that their periods differ by a small amount. As a result, the precession of the two signals creates accurate delay increments. In addition, the trigger signal is created with a select frequency so that an integer number of triggers can be generated in one precession period, and upon occurrence of each trigger, a bit error rate test (BERT) count is initiated for measuring data to determine strobe positions with respect to said data signal.
Although embodiments of the invention may be described and illustrated herein using specific numbers, parameters, examples and flow diagrams to show the mathematical relationships between the input data signal, reference signal and trigger signal, the applicability of the present invention is not so limited. It should be understood that many variations can be implemented without departing from the spirit and scope of the present invention.
The system controller 112, as the primary point of interaction for users, provides the gateway to the site controllers and synchronization of site controllers in a multi-site or multi-DUT (device under test) environment. In general, user applications, tools and a GUI (graphical user interface) would run on the system controller. In some circumstances, the system controller also acts as a repository for all test program related information, including test plans, compiled patterns, test parameters, files, and so forth.
The site controller 114 can control one or multiple test sites, where each test site is comprised of a collection of modules servicing the testing of a single DUT. In one embodiment, the site controller 114 also communicates with the system controller 112 through a communications library (not shown) that not only enables the user applications, tools and GUI to access the tester and test objects, but also allows the site-controller-based module software (e.g., software for the test modules 124) to access and retrieve pattern data therefrom. Usually an ATE system can comprise one or more site controllers and each site controller can control one or more test sites. For each test site under its control, a site controller provides high-level synchronization among the modules that are testing the corresponding DUT. For example, the site controller 114 in
The test head 120, at a high level, comprises one or more test instrument modules 124 and a calibration loadboard 122. As shown in
A detailed view of the test head 120 is provided in
As seen in
Turning to
A time vernier 340 is employed to introduce time delays on the data signal 310 or the reference signal 320 before the delayed signals are received at the data receiver flip-flop 354. In
The data signal 310 has a data period 312 (TDAT), which is the period or time interval between any two neighboring repeats of the fundamental pattern of the data signal. The data period TDAT is determined by the signal frequency. As an example, if the data signal is a 1010 . . . clock signal, then its data period can be calculated as: TDAT=2UI=2/(Data Rate), where, as known in the art, UI (Unit Interval) represents one data period of a data signal, Data Rate represents a data speed measurement (e.g., data bytes per second), and their mathematical relationship is defined by UI=1/(Data Rate). Similarly, the reference signal 320 has a reference period 322 (TREF), which is the period or time interval between any two successive rising (or falling) edges of the reference signal. The trigger signal also has a trigger period (TTRIG), which is the time interval between successive BERT triggers. As will be described in detail below with reference to
In order to create accurate delay increments, the data period (TDAT) and reference period (TREF) are designed to differ by a small amount, as can be seen in
TREF=TDAT+dt (1)
As a result of such closely spaced periods, precession will occur between the data signal 410 and reference signal 420, with the lapse of time. After a complete precession period 402 (TPREC), namely, the period or time interval starting at one edge alignment of the two signals and ending at the next edge alignment of the two signals, the rising edges of two signals will be aligned again, as shown in
Assuming the re-alignment of the signals occurs at the time point when the reference signal has progressed m reference periods, where m is an integer >>1, then:
TPREC=m×TREF (2)
Further, based on the above equation (1), one precession period (TPREC) can also be calculated in the following equation:
TPREC=m×(TDAT+dt)=m×TDAT+m×dt (3)
Due to the small difference between TDAT and TREF, at the time of re-alignment of two signals, the data signal has progressed m data periods plus m×dt, which would comprise one complete data period, namely,
m×dt=TDAT (4)
Or,
m=TDAT/dt (5)
This means that within one complete precession period (TPREC), the data signal has progressed (m+1) data periods. In other words, the relationship between a data period and a reference period is defined as follows:
TPREC=m×TREF=(m+1)×TDAT (6)
Because m is typically >>1, equation (4) can be converted to:
TPREC=(m+1)×TDAT≈m×TDAT (7)
Further, m can be substituted by TDAT/dt according to equation (5), and thus TPREC can also be determined by:
TPREC=TDAT×TDAT/dt (8)
The relationship between the data signal and reference signal can also be defined in terms of signal frequency. The two closely-spaced signals have a very small frequency offset (dF) according to one embodiment of the present invention. The frequency relationship between the data and reference signals is defined by the following equations:
Based on equations (7)-(9), the frequency offset (df) can be also determined by:
dF=dt/(TDAT×TDAT)=1/TPREC (12)
Thus, a complete precession period (TPREC) will be:
TPREC=1/dF=(TDAT/TDAT)/dF=TDAT×(FDAT/dF) (13)
According to various embodiments of the invention, the trigger period (TTRIG) 532 can be set such that an integer number of trigger periods, e.g., trigger number N 536 in
TPREC=N×TTRIG (14)
Based on equation (8) and equation (14), dt can be determined from the following equation:
dt=TDAT×TDAT/(N×TTRIG) (15)
In equation (13), N represents the number of trigger periods in one precession period. It can be determined by the following equation, where a desired resolution for measurement, R, is first selected:
N=int[TDAT/R] (16)
Alternatively, N can be selected such that TDAT/N approximately equals the desired resolution R. As an example, if N is set to be 4096, meaning that 4096 trigger periods occur during one precession period, then the data period TDAT will be 384.615 ps using a 1010 . . . clock signal with 5.2 Gbps data rate, and the resolution R will be 0.0939 ps, meaning that approximately 0.1 ps of precession occurs per trigger period.
As seen in
DE=TDAT×(TBERT/TPREC) (17)
Using equations (12) and (14) for substitution, the drift error can also be:
DE=TDAT×(TBERT/(N×TTRIG)≈R×TBERT/TTRIG (18)
To ensure accuracy, drift error should be minimized or controlled within a certain range as compared to the resolution R. For example, if the requirement is DE<0.1×R, then, according to equation (18), the BERT duration TBERT should be less than 0.1 of the trigger period (TTRIG).
Specifically, the three example curves can be generated according to the assumptions and parameters set forth in the table below:
It should be understood that the assumptions and parameters in the above table are for illustration only, and embodiments of the present invention are not so limited, but can be implemented with many variations including different values of N, frequencies, data rates, phase delays, and so forth.
Using curve 610 as an example, a process for establishing a graphic reference frame works as follows: first, setting the Rx phase delay in the time vernier to a known delay value, e.g., 0; then, using the trigger signal to generate N (e.g., 4096) triggers, and upon occurrence of each trigger (Trigger 0, 1, 2, . . . 4095), initiating a BERT count. By plotting error counts versus the trigger number, a graphic curve, i.e., curve 610, can be generated, from which the trigger number corresponding to 50% error count rate can be identified. As shown in the diagram 600, the Y axis represents error count rate, and the X axis represents trigger numbers in the order from 0 to 4095, which also corresponds to time increments of approximately 0.1 ps (R=0.094 ps) per each trigger. It should be noted that the graph of BERT error count versus trigger number in any complete precession period is identical. Therefore, once an initial graph in one precession period, such as curve 610, is obtained, it becomes relatively easy to plot the graph of BERT error count versus trigger number in any other complete precession period, such as a fourth precession period comprising 4096 triggers from trigger number 12288 (=4096×3) to trigger number 16383 (=4096×4−1). As a result, with creation of an initial graph or a reference frame, other graphs showing subsequent strobe positions can be acquired by keeping track of the trigger numbers. Again, the advantage of the present invention is that no knowledge of the initial phase of the data signal to the reference signal is necessary for determining the trigger number or positions.
Curve 620 and curve 630 can be generated in a similar manner, and they correspond to two different Rx phase delay settings, i.e., 30 ps and 51 ps respectively, represented by two different trigger numbers, i.e., trigger number 622 and trigger number 632. As aforementioned, the time differences can be determined by a mere comparison of the new BERT error count plot graph with the reference frame, for example, curve 620 versus curve 610, or curve 630 versus curve 610. Therefore, embodiments of the present invention allow for determination of the strobe position or relative timing of each Rx phase delay setting by taking 4096 BERTs under each possible Rx phase delay setting, without stopping or resetting the input signal, reference signal or trigger signal. Once a reference frame is established to associate a trigger number with a phase delay setting (i.e., Rx phase delay=0), subsequent strobe positions or timing of different delay settings can be determined. In addition, based on the reference frame, trigger numbers corresponding to different delay settings can be estimated, which allows the data measurements to be performed at trigger numbers in a small interval surrounding the expected strobe position instead of each trigger number (e.g., from 0 to 4095, or 12288 to 16383 when N=4096). This can significantly reduce the measurement time. It should be understood that a reference frame and representations of different delay settings are not limited to the graphs shown in
In practice, the methods, processes or steps described herein may constitute one or more programs made up of machine-executable or computer-executable instructions. The above description, particularly with reference to the steps and flow charts in
Embodiments of the present invention may be described in the general context of processor-executable instructions. Processor-executable instructions may include programs, applications, coding, modules, objects, interfaces, components, data structures, frame organizations and/or preamble content, etc. that perform and/or enable the performance of particular tasks and/or implement particular data structures. Processor-executable instructions may be located in separate storage media, executed by different processors, and/or propagated over or extant on various transmission media. Moreover, processor-executable instructions may be embodied as software, firmware, hardware, fixed logic circuitry, some combination thereof, and so forth.
Although embodiments of this invention have been fully described with reference to the accompanying drawings, it is to be noted that various changes and modifications will become apparent to those skilled in the art. Such changes and modifications are to be understood as being included within the scope of embodiments of this invention as defined by the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
4719608 | Genat et al. | Jan 1988 | A |
4771309 | Ogihara et al. | Sep 1988 | A |
4908784 | Box et al. | Mar 1990 | A |
5214680 | Gutierrez, Jr. et al. | May 1993 | A |
6609077 | Brown et al. | Aug 2003 | B1 |
20060265161 | Querbach et al. | Nov 2006 | A1 |
20070033448 | Waschura et al. | Feb 2007 | A1 |
Number | Date | Country |
---|---|---|
WO-0192904 | Dec 2001 | WO |
WO-0192904 | Dec 2001 | WO |
Number | Date | Country | |
---|---|---|---|
20100229053 A1 | Sep 2010 | US |