The invention relates generally to signal acquisition systems and, more particularly, to a method and apparatus for processing eye diagram data in a logic analyzer.
Signal acquisition devices such as logic analyzers (LAs) are instruments used for verifying and debugging digital circuits. Specifically, a logic analyzer verifies that a digital circuit is working and provides information for troubleshooting such a circuit. The logic analyzer is capable of capturing and displaying many signals of the digital circuit at one time and analyzing their timing relationships. Since timing relationships in digital circuits are paramount to their correct functioning, verifying these relationships (preferably by visual analysis) with an LA is highly useful. For example,
Creating a VTE diagram is a standard feature of many DSOs from companies such as Tektronix, Inc. of Beaverton, Oreg. and is used extensively throughout the electronics industry to characterize signal stability. Unfortunately, this feature does not exist in LA's; therefore, it is necessary to manually readjust DSO probes and somehow feed the captured VTE data of up to hundreds of signal channels to an LA to arrive at the desired analysis. For example, in a signal bus consisting of 32 signals available for VTE analysis, a user would have to connect probes from the DSO to each signal of the bus and have the DSO perform data acquisitions and produce the VTE data. Since most DSO's are limited to four input channels, performing analysis on a 32 signal bus would require the user to move each of the three probes being used for signal capture at least ten times (assuming there are four DSO channels and that one channel is reserved for clocking). When each set of VTE data for a group of three channels is captured, the user would have to save the data and export it to another viewing tool (for example, Microsoft Excel®). By such a process, the user could eventually capture VTE data for all 32 channels and export it to the external tool for aggregation and viewing but only after laborious and repetitive manual steps that can easily produce errors.
Various deficiencies in the prior art are addressed by the present invention of a method and apparatus for processing eye diagram data from a system under test. The method includes the steps of (a) mapping a first plurality of channels for eye diagram data signal acquisition to a plurality of DSO inputs, (b) acquiring a first plurality of signals from the first plurality of channels, (c) determining if there are additional channels for signal acquisition and (d) automatically mapping a second plurality of channels for eye diagram signal acquisition to the plurality of DSO inputs and acquiring at least a second plurality of data signals from the second plurality of channels. These steps are repeatable until all selected channels in a system under test are analyzed. The method further includes the step of analyzing the first plurality of signals and providing statistical data regarding the eye diagram data. The statistical data provides a determination of instances where the first and second pluralities of acquired signals did not conform to predefined user parameters. Such results are displayable on a user interface after each plurality of channels is analyzed. The mapping step includes dedicating at least one of the DSO inputs to data other than from the first plurality of channels and in one embodiment the dedication is to a clock signal against which the other signals are analyzed for VTE data.
An apparatus in accordance with the subject invention includes means for selecting a first plurality of channels for eye diagram signal acquisition and mapping the first plurality of channels to a plurality of DSO inputs, means for acquiring a first plurality of signals from the first plurality of channels, means for sending a completion of acquisition signal with respect to the first plurality of channels and means for automatically mapping a second plurality of channels for eye diagram signal acquisition to the plurality of DSO inputs. The means for selecting a first plurality of channels for eye diagram signal acquisition and mapping the first plurality of channels to a plurality of DSO inputs is an analog multiplexer in a logic analyzer acting in response to a set of user parameters. The means for automatically mapping a second plurality of channels for eye diagram signal acquisition to the plurality of DSO inputs is the analog multiplexer acting in response to the completion of acquisition signal. The apparatus also includes means for displaying analysis results of the signal acquisitions on the logic analyzer and in one embodiment is a user interface depicting an aggregate graphing of analysis results for all analyzed channels.
The teachings of the present invention can be readily understood by considering the following detailed description in conjunction with the accompanying drawings, in which:
a-2c depict a time lapse sequence view of VTE analysis in an apparatus in accordance with the subject invention;
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures.
The subject invention provides for improved circuitry and operational methods for processing eye diagram data captured from SUTs in an LA. Generally speaking, the invention performs automatic capturing of multiple channels of data, multiplexes the data and passes the data to a DSO for display. Accordingly, the basic problem of the physical channel limitations of most DSOs as well as the high degree of user interaction and manipulation of equipment is addressed. With the subject invention, multiple channels (above the number of input DSO channels) can be sampled by connecting a probe once, and the VTE data from all channels can be aggregated into the same data display where it can be further analyzed.
Also shown in
For example, consider that the user wants to obtain the analog representations of eight channels: a, b, c, d, e, f, g, and h in the LA 204 and there are only four LA analog outputs 214 and only four DSO channel inputs 218 available. Using the multiplexing feature, the user selects the channels to be analyzed and the invention maps a first plurality of channels (i.e., a, b and c) to LA analog outputs A1, A2 and A3 respectively while A4 is reserved for CK. Further, the subject invention maps analog outputs A1, A2, A3 and A4 to DSO channels DSO1, DSO2, DSO3 and DSO4 respectively. Thus, channel a is sampled by the DSO through its DSO1 channel, channel b through DSO2, and the like. After the DSO has completed its data acquisitions on the first plurality of channels, the LA 204 (through the connector 208) queries the DSO 206 for data from the first plurality of channels and displays it in a data view.
After the first plurality of channels have been sampled, the invention remaps the LA analog outputs 214 to gather data for a second plurality of channels. For example, this mapping can be: channel d to A1, e to A2, f to A3 and CK to A4. One skilled in the art appreciates that the specific mapping does not affect the results of the analysis nor narrow the scope of the invention as any combination of mappings is possible. No change needs to be made to the analog output cable connections 214 to DSO channel 218 mappings. The invention then directs the DSO 206 to sample the second plurality of channels. Once again, the data can be queried for and displayed on the LA 204. However, data from the second plurality of channels is aggregated to the existing data from the first plurality of channels to provide a display of all selected channels. Lastly, a third (and/or additional) plurality of channels (i.e., g and h) are analyzed in subsequent passes, with g connecting to A1 and h connecting to A2, and the CK connecting to A4 (connection A3 is not used) as shown in
a shows the first plurality of connections between the SUT, the LA 204 and the DSO 206. Data comes in through the LA probe channels 212, is redirected (multiplexed) onto the Analog channel outputs 214 and finally forwarded to the DSO channel inputs 218. The subject invention reroutes the analog channels 214 to different probe channels 212 automatically to cycle through all of the probe channels to be analyzed. Again, although not shown, the subject invention can reroute the analog channels connections to any of the DSO channels without affecting the result or scope of the invention. For example, the invention routes analog channel A1 to DSO3. The subject invention also makes the decision for this channel mapping as well, informing the user how the probes must be connected between the LA 204 and DSO 206. Therefore, the user does not have to decide how to do the channel mappings described above. The user needs only select the channels to be analyzed, the clock and/or qualifier channel to be used, connect both the LA probes and analog probes once, and allow the subject invention to cycle through all of the channels to be analyzed.
b depicts a second plurality of connections between the SUT, the LA 204 and the DSO 206. That is, probe channels d, e and f are now mapped to analog channels A1, A2 and A3 respectively (with A4 still being mapped to the trigger or Clock). This remapping occurs after a completion signal is sent by the DSO 206 indicating that all signal acquisition duties have been performed with respect to channels a, b and c. Similarly,
Such parameters afford the user with a broad range of control over the automated process. For example, the LA 204 represents a logical module to the user and it can be either a single physical LA acquisition module or a merged set of LA acquisition modules for selection purposes. Additionally and as indicated earlier there can be up to eight channels in a single LA (a, b, c, d, e, f, g, and h) subject to analysis. However, a single LA module can support up to 136 channels. Therefore, the subject invention can analyze up to that many channels for a single module (considering also that one of those channels must be used as a clock). If additional modules are logically merged, many hundreds more channels can be analyzed in a single analysis. Additionally, selecting a clock channel allows the user a degree of freedom in the automated mapping process and the edge transition is selectable from going high or going low. For the time range, one embodiment is in the range of approximately −10 ns to 10 n. Preset vertical ranges are selectable from the group consisting of TTL, CMOS and ECL, or the user may define his own range. For the presented example, assume the user has selected TTL. The stop condition is preferably expressed in minutes, and in one embodiment has a default value of 1 minute. The oscilloscope acquisition mode allows the user to take advantage of various features if supported in the connected scope.
The method then proceeds to step 306 where a first plurality of channels for VTE signal acquisition are selected and subsequently mapped to a plurality of oscilloscope inputs. In one embodiment where the oscilloscope is a 4 channel DSO and one channel is reserved for clock signaling, the first plurality of channels is three (a, b and c) and said first plurality of channels is mapped to the first three DSO inputs, and the clock is mapped to the fourth DSO input. After selection and mapping of the first plurality of channels, the method proceeds to step 308 where VTE signal data is acquired from the SUT. Specifically, commands are sent to the DSO so that data from the SUT enters the first plurality of LA channels and is passed (multiplexed) to the DSO inputs via analog channel outputs of the LA.
At step 310, acquisition of the VTE data of the first three (plurality) of channels is completed and a completion signal is sent by the DSO. This completion signal is recognized by other system components that, in turn, execute ancillary subroutines for managing and processing the acquired VTE data.
At step 312, the VTE data acquired from the first plurality of channels is displayed. That is, the LA 204 queries the DSO 206 for the VTE data acquisition results and then formats and displays such results. In one embodiment, the display is in the form of an aggregate graphical display of VTE “hit” data. That is, the result of performing the analysis of the subject invention is an aggregate VTE diagram of the data for all analyzed channels. During analysis, if the DSO detects that a channel's signal intercepts a voltage, time (VT) pair point, then it registers a “hit” on that point. Since the DSO captures thousands of waveforms per second, it can build up a very accurate statistical sampling of all data points in a VT grid. A VT hit of 100 for a particular channel means that the DSO recorded 100 occurrences of the channel waveform data having that particular VT value pair. In one embodiment depicted in the user interface 224 of
At step 314, a decision step is invoked. Specifically, a query is made as to whether there are more channels to be analyzed according to the user-defined parameters. If there are no more channels to be analyzed, the method proceeds to an ending step 320. If there are more channels to be analyzed, the method proceeds to step 316. At step 316, the method, having completed acquisition, analysis and display of the first plurality of channels and related data, automatically selects and maps a second plurality of channels for VTE signal acquisition without further instruction, input or activity by the user. That is, the method continues to run uninterrupted until all channels are analyzed by virtue of the initialization parameters entered at step 304. Specifically, steps 308, 310 and 312 are repeated for at least the second plurality of channels for VTE signal acquisition. Further, these steps are repeated for any and all additional pluralities of channels until all channels are analyzed and their “hit” results displayed at the user interface.
Additional considerations for the subject invention allow for other types of channel usage with certain provisions. If the user also selects a qualifier channel, then one of the four DSO channels must be committed to that qualifier. Accordingly, this leaves only two DSO channels to be used to cycle through all of the analysis channels. Thus, for eight analysis channels, there would be four (eight analysis channels divided by two DSO channels) instead of three analyses passes. A user might use a qualifier channel to “advise” the DSO that it is OK to sample data based on the specified clock transition. Not all rising clock transitions, for example, may be legitimate transitions upon which to sample data. The user may specify that the qualifier must have a high or low state to “qualify” the clock transition.
If the user is selecting analysis channels from a LA merged module set (in which both modules support the LA multiplexing feature), then analysis channels can be selected from any module in the set, and the clock and qualifier channels can also be selected from any module in that set. It is not possible to select analysis channels and clock and qualifier channels from different unmerged modules. For example, if there are two modules, M1 and M2, that are not logically merged, then the user must get all analysis, clock and qualifier channels from either M1 or M2. However, if M1 and M2 are merged to form the logical module M3, then the user may select some analysis channels from the physical module M1, some from M2, and the clock and qualifier channels from either M1 or M2.
The method of the subject invention is implemented by passing commands and data through a series of software layers between a user and module acquisition hardware.
An overview of the data and control paths from the user input to the final display of (iVerify) VTE results is depicted in
Once the user has entered parameter selections, they are sent to a Run Control Module 504. The Run Control Module 504 ensures that the proper setup is performed by three other modules: a System Interprobe Module 506, which manages analog channel to DSO channel mapping via a DSO instrument module 526 and an LA instrument module 528; an Analog Multiplexer Module 508, which is responsible for LA probe to analog channel mapping; and an External Scope Module driver 510, which sends setup and control commands to the DSO 206 to configure and initiate waveform acquisitions. These commands propagate down through a support library 512, an adapter driver 514, through adapter hardware 516 and finally to the DSO 206. In one embodiment of the invention, the library is a GPIB library and the adapter driver and hardware are USB-to-GPIB based devices. In one embodiment, the USB-to-GPIB adapter is part of the connector 208 of
When the DSO 206 completes acquisitions for one set of channels, it sends a completion event that propagates up through the adapter 516, the adapter driver 514, and the library 512. Subsequently, an event notification is sent to a LA event dispatcher 518. The LA event dispatcher 518 executes code in the Run Control Module 504, which sends the necessary commands down through the software layers to the DSO 206 asking for just-acquired VTE hit data. The DSO 206 passes the VTE hit data back up through the software layers to the External scope module driver 510.
Subsequently, the VTE hit data is passed through a series of structures. A LA channel structure 520 and a Channel Record structure 522 handle per channel data (as indicated by the fact that there are multiple instances of these objects). Although these two structures seemingly perform the same function, they are actually two sides of an interface defined by the LA's TPI.NET architecture. The structure of the TPI.NET architecture relies on Microsoft Windows .NET technology and is well-known to those skilled in the art.
Once the per channel data is collected, it is managed by an Acquisition Data object 524, which is used by the Service Module 502 to honor data requests by the user interface 224. Upon reaching the user interface 224, the data is graphed in aggregate fashion for all channels.
Multiplexing of the various channels to enable data from the SUT 202 to be sampled and routed to the correct DSO channels is accomplished by an LA module driver 530 and its supporting components. That is, all LA analog mapping commands generated by the LA module driver 530 and going to LA module hardware 538 must go through a VISA library module 532, a VXI-to-PCI bridge driver 534 and a VXI-to-PCI bridge 536. Such driver modules 534 (implemented as software) can be found on any operating system (Windows and Linux are two examples), although each operating system has its own requirements on how a driver should be designed. A VXI-to-PCI bridge is a piece of electronic hardware that must provide data transfer and event notification between a PCI bus and a VXI bus, which are two well-known computing bus standards.
Accordingly, the subject method and apparatus automatically detect the VTE hit data for signals of an SUT enabling the user to ultimately reduce skewing effects of those signals with respect to a clock transition. While the foregoing is directed to the preferred embodiment of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.