The following description relates to analyzing signal timing and relationships.
Designing complex circuits such as semiconductor integrated circuits entails lengthy testing and debugging. During such debugging, it is useful for designers to view visual representations of various circuit signals over time. Hardware and software for this purpose are widely available, referred to as logic analyzers, logic analysis software, waveform viewers, waveform editors, etc. In some cases, signal waveforms are captured by attaching probes to physical devices and recording voltage within the devices. In other situations, representations of waveforms are generated by circuit emulators, which predict hardware operation through mathematical analysis.
Waveforms are often presented to users in the form of a graph, with time on the horizontal axis and voltage or logic levels on the vertical axis. Multiple waveforms are often displayed in a vertical arrangement, along a common timeline so that interactions between signals can be studied. The waveform can be scrolled horizontally along the time axis, and the user can specify different scales for the time axis. Waveform viewers sometimes have additional functions that allow a user to search for a particular type of event, such as a signal transition. Such functions might include, for example, a Zoom-In/Zoom-Out function to make the waveforms smaller/larger depending on viewing preferences, a print function, functions to move and put waveforms into logical groups to facilitate visual comparisons of waveforms, and so forth.
However, even with tools such as these, it can be difficult and tedious to determine specific cause and effect relationships between various signals.
Waveform generation/capture/storage component 102 comprises circuit or logic emulation software that generates digital representations of one or more waveforms in response to a simulated electrical or logic circuit specification. Alternatively, generation/capture/storage component 102 can comprise a probe system that connects physically to an in-test circuit and that measures circuit values during actual operation of the circuit. In either case, component 102 includes waveform storage 110 that stores representations of one or more waveforms—whether those waveforms result from circuit simulation or measurement of physical circuit signals. Furthermore, the stored waveforms or waveform representation need not necessarily originate from system 100 itself. Instead, they may be generated or captured using some different mechanism, then transferred to or stored in waveform storage 110. Typically, waveform representations are stored as one or more digital computer files, using conventional file storage techniques and devices such as magnetic and/or optical storage media.
User interface 106 comprises a graphical display and user input components, such as a monitor, keyboard, mouse, touch-sensitive monitor, and/or other types of components commonly used for interaction between a computer and a human user of a computer-based system. The user interface includes images that are presented to the user such as visual waveform representations, prompts, menus, and other information. In particular, user interface 106 includes a program entry component or element 112, which interacts with a user to allow the user to create or enter programs that reference and analyze stored waveforms.
Analysis component 104, alternatively referred to as execution logic, is a program or logic component that is programmable by the user to analyze one or more waveforms stored by waveform generation/capture/storage component 102.
Conventionally, analysis component 104 has predefined functions that an operator can select to perform different measurements or other operations with respect to the stored waveforms. In accordance with the techniques described herein, however, execution logic 104 also includes a C-language interpreter 114 that can be instructed to execute user programs created and/or designated by the user. Specifically, analysis component 104 operates in conjunction with user interface 106 to accept designations—from the user—of user-defined programs to analyze stored waveforms. As will be described below, the user can create custom programs, using an extension of the C programming language, to analyze and detect specific waveform events and inter-relationships between waveforms. Such programs are entered or designated by way of user interface 106, and then executed by analysis component 104 at the request of the user to produce information about the waveforms as defined by the program with reference to the waveforms. Results generated by the program are then displayed by user interface 106. This allows the user to perform many different types of analyses, not limited to the predefined functions that might be provided by a conventional analyzer.
Although the example described herein uses a C-language interpreter, similar functionality can also be implemented using other programming languages such as BASIC, C++, Java, and others.
In addition to the components specifically shown in
Processor 122 is a conventional microprocessor such as found in typical desktop computers. Computer-readable storage media 124 comprises various types of memory, such as volatile electronic read/write memory, non-volatile electronic read-only memory, magnetic media such as a hard disk, and removable storage media such as diskettes, CD-ROMs, etc. Generally, software is distributed on removable media and installed from there onto a computer hard disk or other memory (possibly remote) that is readily accessible by computer system 120. At or during execution, the software is loaded from the hard disk to electronic memory for execution. During execution, processor 122 retrieves instructions from the electronic memory and executes them. The computer typically runs under the supervision of an operating system, which coordinates these operations, in addition to facilitating user I/O.
I/O components 26 typically comprise a monitor, a keyboard, and a pointing device such as a mouse, although other components might be used for interaction with the user of the computer. In addition, I/O components typically include various communications ports for use with printers, networks, and so forth. Such I/O components might optionally include hardware for measuring actual signal or logic levels within an external in-test circuit, or might include a communication port for receiving waveform files from other computers or instruments. Waveform files might also be transferred to computer 120 by way of portable storage media such as CD-ROMs.
Software components of computer 120 are shown as blocks within computer-readable memory 124, although it is recognized that such software resides in various different types of memory within computer 120 at various times, and is actually executed by processor 122. In this example, the software includes an operating system 130 and logic analysis software 132, although other types of software are likely co-exist on computer 120. Note also that logic analysis software might initially reside on some type of portable media, such as a CD-ROM, before it is installed on non-removable media of computer 120. The functionality described above with reference to
Note that although the system is described as being implemented on a conventional desktop computer, other forms of implementation are also contemplated. For example, many different types of computers or computer-based devices can be used to implement the described logic analysis system. Furthermore, such a system might be implemented as a dedicated purpose test instrument rather than in conjunction with a general-purpose computer.
In addition to the waveform area, user interface 130 includes a user-program area 136. In contrast to more conventional analyzers which limit users to predefined measurement functions or sequences, program area 136 interacts with the user to define, identify, or accept user specified programs to be executed with reference to the stored and/or or displayed waveforms 134. In this example, programs are created and formatted by the user of the logic analyzer in accordance with an extension of the C programming language created and defined by the inventors. Special syntax is defined that allows the program to reference the waveforms, such as accessing waveform values by time and identifying specified waveform events. The extended C language in this embodiment allows conditional flow statements, and such conditional flow statements can reference the displayed or stored waveforms so that program operation and logic is dependent on characteristics of the waveforms. In addition, results of any programmatic analysis can be output to the user interface 130.
User interface 130 includes a program results area 138. Results of output statements in user-specified programs are displayed in this area. Alternatively, such results can be displayed in a pop-up window or balloon that overlays waveform 132 or some other area of the user interface. Note that these are only examples of how such program output might be handled, and many other arrangements of user interface 130 are possible and may be desirable. Most implementations will involve many more controls and display components in order to impart the desired functionality to logic analyzer 100: to load waveforms, set display options, execute programs, initiate emulation, etc. In relation to the user programmability discussed herein, the user interface is likely to have controls that allow a user to save and retrieve user-specified programs, and possibly to manipulate or deal with such programs in other ways. Furthermore, the controls will provide a way for the user to request execution of the currently loaded program.
As noted above, analysis component 104 in this implementation comprises or includes a C-language interpreter, configured to accept C-language programs with extensions, and to execute those programs with reference to the currently displayed or stored waveforms. Programs can be created and entered by a user directly into the user-program area 136. Alternatively, programs can be created using some other tool or editor, then loaded and executed by logic analyzer 100 at the user's request, by use of control elements (not shown) of user interface 130.
Having described the general concepts and functional characteristics of logic analyzer 100, the following discussion relates to C language extensions defined by the inventors and utilized to allow user-specified programs to reference waveforms and to output analysis results.
In the described implementation, user-defined programs can utilize a variable t, which is predefined by execution logic 104 as an integer representing time, corresponding to the horizontal axis of waveform area 132. Variable t may be configured to use a convenient time scale, such as nanoseconds, microseconds, or milliseconds. The desired time scale will often depend on how the waveform file was captured. When used as an argument, t specifies the point along the horizontal axis of the stored waveforms at which the specified measurements or other analysis will be performed.
Displayed waveforms are named in accordance with normal operation of the logic analyzer and/or the emulation logic that generates the waveforms. Execution logic 104 is configured to use variable names for the waveforms corresponding to the names of the waveforms as displayed on the user interface: any currently loaded waveform is treated as a global numeric variable when it appears in a C statement or expression. Thus, assuming a waveform is named CLK1, the value of the waveform is referenced within a user-specified program simply as variable CLK1. The following statement is used to print the value of CLK1:
print f(CLK1);
This outputs the value of signal CLK1 at a time equal to the current value of t.
The following C code outputs the value of CLK1 at every value of t from 0 to 199:
Execution logic 104 also recognizes a pre-defined operator “@”. Although this is not a standard C operator, the C interpreter of execution logic 104 recognizes this operator to evaluate a signal at a specific time, in accordance with the following syntax:
sig@time
where sig specifies a particular waveform by name and time specifies a time value relative to the waveform. As an example, the preceding example can be modified using this operator to print only those values of CLK1 that represent a change from the previous value:
The defined extensions to the C language allow user-defined, automated analysis of waveforms, including individual and relative timings of the waveforms. In addition, the C interpreter includes several pre-defined functions that make such analysis much easier to program. In combinations, these capabilities allow automation of many measurement procedures that were previously required to be accomplished strictly by visual inspection of the displayed waveforms.
One such predefined function, named “next_transition”, returns a time corresponding to the next waveform transition following a specified time value. It expects two arguments: a signal name and a time value. For example, the following statement outputs the time value of the first signal transition of CLK1 following t=100:
printf(next_transition(CLK1, 100));
Another predefined function, named “num_transitions”, returns the number of transitions of a specified waveform within a specified time period. It expects four arguments; a waveform name, a transition value, an end time, and a start time. It returns the number of transitions of the specified waveform to the transition value between the start and end times. For example, the following statement outputs the number of times signal CLK1 transitions to “1” from time 100 to time 200:
printf(num_transitions(CLK1, 1, 100, 200));
A predefined function named “find_transition” returns the time at which the last of a specified number of transitions occurs to a specified transition value. It expects four arguments: a waveform name, a transition value, a start time, and a number of transitions. For example, the following statement outputs the time at which signal CLK1 transitions to “1” for the 100th time, starting at t=50:
printf(find_transition(CLK1, 1, 50, 100));
In many instances, signal or waveforms can comprise multiple bits. In these situations, specific bit ranges can be specified by supplying two arguments to a waveform variable name, such as name(msb, lsb), where msb indicates the most significant bit of the desired bit range, and lsb indicates the least significant bit. Waveforms can exist as arrays, in which case three arguments are supplied with the variable name: name(array_index ,msb, lsb), where array_index is the array index. lsb is optional and defaults to the value supplied for msb. If neither lsb nor msb are supplied, the entire bit range of the waveform is assumed.
Other functions can of course be supplied to facilitate waveform analysis. For example, a particular implementation might include functions for determining the bit width of a named waveform; for associating different names with waveforms or bit fields of waveforms; for returning particular bits of a waveform, such as the most significant or least significant bit; for determining the maximum recorded time in a set of loaded waveforms, etc.
As another enhancement, the value t=0 can be set by the user relative to the actual start of the waveform, prior to actually executing a program. For example, the user may want to run a program that analyzes a waveform starting at a time 100 within the current waveform. If this is the case, the user can specify that for purposes of the program, t is considered equal to 0 at an actual time of 100 relative to the beginning of the waveform. Furthermore, variable t can be considered equal to 0 at a relative time along the waveform corresponding to position of a user-controlled cursor positioned graphically over the displayed waveforms. This allows a user to easily run the program multiple times, starting at different points along a displayed waveform or set of waveforms.
Note that the program examples and techniques described above are merely examples of what an end-user can do when using this technology. The defined syntax and functions can be used to accomplish many different types of automated analyses.
Block 202 comprises displaying a user interface to the user, which will typically include displaying the stored set of waveforms. The waveforms are displayed as described above, allowing the user to scroll through the waveforms horizontally, along a time axis. Other viewing options may be available depending on the particular implementation of the logic analyzer.
Block 204 comprises accepting a designation by a user of a program to be executed against the displayed and/or stored set of waveforms. This may comprise interacting with the user to actually create the program, or may comprise simply allowing the user to specify a location of a previously created program. The program can contain statements formatted in accordance with the C-language extensions described above, with other extensions, or using other programming languages.
Block 206 comprises executing the designated program at the user's request.
Block 208 comprises displaying output generated by the executed or executing program.
Although described in language more or less specific as to structural and methodical features, it is to be understood that the invention is not limited to the specific features described. The invention is, therefore, claimed in any of its forms or modifications within the proper scope of the appended claims appropriately interpreted in accordance with the doctrine of equivalents.