This invention relates to triggers in test-and-measurement instruments, and more particularly to creating triggers from a high-level description of a protocol with user configuration.
Triggering systems have been a part of test-and-measurement instruments for some time. But triggering systems typically depend on conditions associated with the underlying signal: for example, does the signal rise above (or drop below) a threshold voltage. When the data carried by the underlying signal is decoded and verified to match a particular protocol, establishing a trigger condition based on the data is a far more complicated situation, and cannot be done today easily, if at all.
Embodiments of the invention address this and other problems with the prior art.
Before explaining how the invention operates, it is useful to understand the relationship between regular expressions and state machines. Given a regular expression, a state machine can be constructed that represents that regular expression. The state machine can then be used to determine whether a particular input matches the regular expression. If the state machine processes to an acceptable end state, then the input matches the regular expression; otherwise, the input does not match the regular expression.
State machine 110 represents a simplified version of the actual state machine. For example, state machine 110 does not label the transitions between the various states, nor does state machine 110 show error states or transitions that are used when data does not match what is expected. A person skilled in the art would understand how state machine 110 operates, even without these details.
Formally, in mathematical terms, a state machine can be represented as a quintuple (Σ, S, s0, δ, F), where Σ is the alphabet (the set of symbols recognized by the state machine), S is the set of states in the state machine, s0 is the initial state, δ is the transition function, which maps from each state in S and each symbol in Σ to a state in S (which could be the same state as the input state), and F is the set of final states in S. Thus, state machine 110 could be more formally represented as (Σ, S, s0, δ, F), where:
Σ={S, 0, 1, . . . } (there could potentially be more symbols recognized than just the state S and binary values 0 and 1, even though these are the only symbols recognized by the state machine)
S={110, 115, 120, 125, 130, 135, 140, 145}
s0=110
δ (δ is not expressed in more detail here because expressing the complete transition function would be very cumbersome and of little value)
F={145}
In fact, this expression of state machine 110 is not necessarily complete. Transitions typically occur on individual symbols, rather than groups of symbols. Thus, transitioning from state 120 to 125 can actually involve three transitions (and therefore some intermediate states): one for each bit recognized for the field labeled “begin”. But as a simplification, a person skilled in the art would understand how state machine 110 operates.
A user might want to trigger some process if a particular value is read for a given state in state machine 110. For example, a user might want to trigger a process if the address field stores the value 10 (in binary, 1010; in hexadecimal, A).
Note that states 115 and 120 are the same in state machine 150 as in state machine 110: state 115 is a state in which the state machine starts, and state 120 matches state S from the bit stream. But state 165 is different from state 125, in that state 165 does not care about the particular field being read. Put another way, in state 165 all that matters is that three bits are read from the bit stream. State 155 is also different from state 130, as state 155 is concerned only with matching the particular bit pattern 1010, rather than matching the address field (as in state 130). Finally, once the user condition has been matched, no further matching needs to be done, so state machine 150 does not include analogs to states 135 and 140: the trigger can be issued immediately after the condition is met.
State machine 205 can be used as shown. But using state machine 205 as shown would require look-ahead or backtracking, which requires additional memory and can slow down processing of a bit stream. For example, assume that where multiple states can be reached given a particular input, the left-most (as
To avoid both backtracking and look-ahead, state machine 205 can be optimized. State machine 240 in
Optimization can be accomplished using the following procedure. Start by walking the tree from the start state and combining the nodes (that is, merge the nodes into a single node) that are equivalent and have the same parent. This process can be repeated until there are no more like nodes to combine. Then find the equivalent Success states, combine them, and then combine nodes that are equivalent and have the same children (again, repeating the process until there are no more like nodes to combine).
The above examples use a single trigger criterion, expressed as an equality. But there is no reason to limit the trigger condition to an equality. Aside from equality (==), examples of other trigger conditions can be inequality (!=), less than (<), less than or equal to (<=), greater than (>), or greater than or equal to (>=). In addition, the trigger condition might depend on only a subset of information from the field in the regular expression. For example, in
In addition, trigger conditions do not have to be limited to a single criterion (which can be termed a simple trigger condition). The user can specify multiple criteria (compound trigger conditions), combined using AND and OR operators, in any desired combination. Thus, the state machine might be testing for multiple conditions, any of which might involve a set of sub-conditions, and so on. A person skilled in the art would know how to simplify the user's provided condition into disjunctive normal form or conjunctive normal form, as desired, which might simplify the design of the state machine. (Disjunctive normal form refers to a logical formula expressed as a disjunction of conjunctive clauses: that is, an OR of ANDs. Conjunctive normal form similarly describes an AND of ORs.)
In
Now that trigger state machines have been described, a system that can use trigger state machines can be described.
Test-and-measurement instrument 405 can include memory 410. Memory 410 can store information, such as state machine 415. State machine 415 can be a state machine used to match a regular expression: in other words, a state machine such as state machines 110, 205, and 240 of
Test-and-measurement instrument 405 can also include receiver 420, which can receive input into test-and-measurement instrument 405. Input can be received in any number of ways. For example, receiver 420 can include a user interface for a user to input information, such as trigger condition 425, which itself can include, for example, user-selected value 430 for a particular bit field. Or, receiver 420 can include receive a signal that includes a bit stream, such as bit stream 435, to be analyzed. Receiver 420 can also receive regular expression 440 (for example, through an integrated development environment (IDE), which can identify the data the system should expect to receive in bit stream 435, and which can be used to construct state machine 415 (be it a state machine to recognize regular expression 440 or a trigger state machine).
Test-and-measurement instrument 405 can also include various other units. State machine modifier 445 can take an existing state machine (for example, one that matches data to regular expression 440) and modifies it to operate as a trigger state machine. As discussed above, this can include eliminating states that occur after the trigger condition is satisfied, and combining states whose values are not considered as part of the trigger condition, among other possibilities.
Processing engine 450 can process bit stream 435 using various state machines (including, for example, a state machine generated using regular expression 440 or a trigger state machine produced using state machine modifier 445). This processing can include updating the current state for each various state machine, as bits are read from bit stream 435.
Trigger system 455 can send a trigger when the trigger condition is met (that is, when the trigger state machine is satisfied. Trigger system 455 can send the trigger to any desired component of test-and-measurement instrument 405 to perform any action as a result of the trigger, as would be understood by person of ordinary skill in the art.
State machine generator 460 can generate a state machine from regular expression 440. As discussed above, this can include creating a sequential series of states that match fields in the order presented in the regular expression. This can also include combining various state machines that match different regular expressions into a single state machine, and optimizing a state machine to avoid look-ahead and backtracking problems.
Aside from generating and using trigger state machines, test-and-measurement instrument 405 can also be used to generate breadcrumbs. Breadcrumbs let a user recreate the operation of a state machine, to see how data was processed. Breadcrumbs, such as breadcrumb 465, are bits of data that can be stored in memory 410. Essentially, whenever a state in a state machine is entered, a breadcrumb can be saved. A breadcrumb can include data, such as the type of state (e.g., error state, packet start, packet end, or field), an ID for the state (that can identify the field or packet), and a time, such as the start and/or stop time of the data that caused the state entry. A person skilled in the art will recognize that “time” does not have to refer to the literal concept of time (as in seconds or fractions thereof since the start of the signal), but rather can refer to an index into a signal, among other possibilities. Breadcrumbs can also include additional data pertinent to analysis, as appropriate. Therefore, the identification of the data to be included in the breadcrumbs can be user-customized.
Breadcrumbs are usually generated using a trigger state machine. But a person skilled in the art will recognize that there is no reason why any other state machine cannot be used to generate breadcrumbs, and therefore breadcrumbs can be generated using any state machine.
To support breadcrumb generation, test-and-measurement instrument 405 can include analyzer 470. Analyzer 470 can analyze bit stream 435 using a state machine. In operation, analyzer 470 is similar to processing engine 450, but their objectives are different. Whereas processing engine 450 is concerned with matching bits from bit stream 435 to attempt to recognize regular expressions, analyzer 470 is concerned with determining when to save a breadcrumb to memory 410. Analyzer 470 and processing engine 450 also typically operate on different state machines: analyzer 470 usually uses (but does not have to use) a trigger state machine, whereas processor 450 uses a full state machine to match a regular expression.
Test-and-measurement instrument 405 can also include breadcrumb generator 475. When it is time to generate a breadcrumb (e.g., when a new state is entered as determined by analyzer 470), breadcrumb generator 475 can save the breadcrumb to memory 410.
Finally, test-and-measurement instrument 405 can include re-creator 480. Re-creator 480 permits a user to re-create the operation of the state machine (as processed by analyzer 470) on bit stream 435. This recreation enables the user to follow what happened.
Test-and-measurement instrument 405 as described can process either the trigger state machine or the breadcrumb generation, or both. Some test-and-measurement instruments include the necessary hardware and/or software to process multiple state machines. If a test-and-measurement instrument is capable of processing multiple state machines, then test-and-measurement instrument 405 can perform both processing for trigger conditions and breadcrumbs.
At block 720, the system can identify the state machine corresponding to a regular expression (which can be the same state machine generated in blocks 705-715). At block 725, the system can receive a trigger condition from the user. This can include, for example, a user-specified value (or part of a value) for a particular field in the regular expression, multiple such user-specified values, or even just a field to be reached, among other possibilities. At block 730, the system can identify a state (or more than one state) in the state machine that can be modified to implement the trigger condition.
At block 735 (
As discussed above, a trigger condition can be a compound trigger condition. In that case, the flowchart of the procedure can be modified to reflect the compound nature of the trigger condition.
In
The above flowcharts show some possible embodiments of the invention. But other embodiments of the invention can organize the blocks in different arrangements, and can include or omit different blocks as desired, or repeat a block (or multiple blocks) as needed. Embodiments of the invention are intended to include all such variations on the flowcharts.
Embodiments of the invention can extend to the following statements, without limitation:
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition; and a state machine modifier to modify the state machine to reflect the trigger condition.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a compound trigger condition; and a state machine modifier to modify the state machine to reflect the compound trigger condition.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a compound trigger condition; and a state machine modifier to modify the state machine to reflect the compound trigger condition, wherein the state machine modifier is operative to replicate the state machine for each value in the compound trigger condition, modify each replicated state machine to incorporate one value of the compound trigger condition, and combine the modified replicated state machines.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition and a bit stream; a state machine modifier to modify the state machine to reflect the trigger condition; a processing engine to process the bit stream using the state machine; and a trigger system to send a trigger if the trigger condition is met.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition; and a state machine modifier to modify the state machine to reflect the trigger condition, including a state machine optimizer.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition; and a state machine modifier to modify the state machine to reflect the trigger condition, including a state machine optimizer, wherein the state machine optimizer is operative to remove any states that occur after the trigger condition is met from the modified state machine.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition; and a state machine modifier to modify the state machine to reflect the trigger condition, including a state machine optimizer, wherein the state machine optimizer is operative to combine states that can be satisfied in the trigger condition by any value into a single state.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition; and a state machine modifier to modify the state machine to reflect the trigger condition, wherein the state machine modifier is operative to set the state machine to compare the bit stream with a user-selected value.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition and the regular expression; a state machine generator to generate the state machine from the regular expression; and a state machine modifier to modify the state machine to reflect the trigger condition.
An embodiment of the invention includes a system, comprising: a test-and-measurement instrument; a memory in the test-and-measurement instrument, the memory storing a state machine, the state machine corresponding to a regular expression; a receiver to receive from a user a trigger condition; a state machine modifier to modify the state machine to reflect the trigger condition; and a state machine optimizer to optimize the state machine.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user; modifying the identified state in the state machine to reflect the trigger condition received from the user; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a compound trigger condition; identifying a plurality of states in the state machine used in the compound trigger condition received from the user; replicating the state machine for each value in the compound trigger condition; modifying the identified state in the state machine to reflect the trigger condition received from the user, including replicating the state machine for each value in the compound trigger condition, modifying an identified state in the replicated state machine to reflect a corresponding value in the trigger condition received from the user, and combining the replicated state machines; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user; modifying the identified state in the state machine to reflect the trigger condition received from the user; storing the modified state machine in the test-and-measurement instrument; receiving a bit stream; processing the bit stream using the modified state machine; and if the state machine indicates that the trigger condition is met, applying a triggering system of the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user; modifying the identified state in the state machine to reflect the trigger condition received from the user including optimizing the modified state machine; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user; modifying the identified state in the state machine to reflect the trigger condition received from the user including optimizing the modified state machine including removing any states that occur after the trigger condition is met from the modified state machine; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user; modifying the identified state in the state machine to reflect the trigger condition received from the user including optimizing the modified state machine including merging adjacent states that can be satisfied in the trigger condition by any value into a single state; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user; modifying the identified state in the state machine to reflect the trigger condition received from the user including modifying the identified state to compare the bit stream with a user-selected value; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user including receiving the regular expression from the user and generating the state machine from the regular expression; modifying the identified state in the state machine to reflect the trigger condition received from the user; and storing the modified state machine in the test-and-measurement instrument.
An embodiment of the invention includes a method, comprising: identifying a state machine stored in a test-and-measurement instrument, the state machine corresponding to a regular expression; receiving from a user a trigger condition; identifying a state in the state machine used in the trigger condition received from the user including optimizing the state machine; modifying the identified state in the state machine to reflect the trigger condition received from the user; and storing the modified state machine in the test-and-measurement instrument.
The following discussion is intended to provide a brief, general description of a suitable machine in which certain aspects of the invention may be implemented. Typically, the machine includes a system bus to which is attached processors, memory, e.g., random access memory (RAM), read-only memory (ROM), or other state preserving medium, storage devices, a video interface, and input/output interface ports. The machine may be controlled, at least in part, by input from conventional input devices, such as keyboards, mice, etc., as well as by directives received from another machine, interaction with a virtual reality (VR) environment, biometric feedback, or other input signal. As used herein, the term “machine” is intended to broadly encompass a single machine, or a system of communicatively coupled machines or devices operating together. Exemplary machines include computing devices such as personal computers, workstations, servers, portable computers, handheld devices, telephones, tablets, etc., as well as transportation devices, such as private or public transportation, e.g., automobiles, trains, cabs, etc.
The machine may include embedded controllers, such as programmable or non-programmable logic devices or arrays, Application Specific Integrated Circuits, embedded computers, smart cards, and the like. The machine may utilize one or more connections to one or more remote machines, such as through a network interface, modem, or other communicative coupling. Machines may be interconnected by way of a physical and/or logical network, such as an intranet, the Internet, local area networks, wide area networks, etc. One skilled in the art will appreciated that network communication may utilize various wired and/or wireless short range or long range carriers and protocols, including radio frequency (RF), satellite, microwave, Institute of Electrical and Electronics Engineers (IEEE) 810.11, Bluetooth, optical, infrared, cable, laser, etc.
The invention may be described by reference to or in conjunction with associated data including functions, procedures, data structures, application programs, etc. which when accessed by a machine results in the machine performing tasks or defining abstract data types or low-level hardware contexts. Associated data may be stored on tangible computer-readable media as non-transitory computer-executable instructions. Associated data may be stored in, for example, the volatile and/or non-volatile memory, e.g., RAM, ROM, etc., or in other storage devices and their associated storage media, including hard-drives, floppy-disks, optical storage, tapes, flash memory, memory sticks, digital video disks, biological storage, etc. Associated data may be delivered over transmission environments, including the physical and/or logical network, in the form of packets, serial data, parallel data, propagated signals, etc., and may be used in a compressed or encrypted format. Associated data may be used in a distributed environment, and stored locally and/or remotely for machine access.
Having described and illustrated the principles of the invention with reference to illustrated embodiments, it will be recognized that the illustrated embodiments may be modified in arrangement and detail without departing from such principles. And, though the foregoing discussion has focused on particular embodiments, other configurations are contemplated. In particular, even though expressions such as “in one embodiment” or the like are used herein, these phrases are meant to generally reference embodiment possibilities, and are not intended to limit the invention to particular embodiment configurations. As used herein, these terms may reference the same or different embodiments that are combinable into other embodiments.
Embodiments of the disclosed technology provide a Serial Bus Trigger Declarative Trigger Language (DTL) System that speeds up, abstracts for developers, and simplifies oscilloscope serial bus trigger implementations. Embodiments include a few different components that work together to enable many aspects of bus trigger development.
As described above, some test and measurement instruments such as oscilloscopes provide bus trigger capability by way of one or more finite state machines, which may be controlled by two main pieces of op code known as the Phy op codes and the Packet op codes. In the past these Phy and Packet op codes have been hand written in a custom assembly language, and then assembled into machine code. Writing these op codes by hand can be time consuming, and requires intimate knowledge of the state machine workings and the custom assembly language.
One component of the Serial Bus Trigger DTL System, according to embodiments, is one or more code snippet compilers. The snippet compilers take short snippets of code as inputs, and output op codes for the state machines. A user of the system who is developing support for a custom bus trigger type therefore no longer needs to know the inner workings of the finite state machines, nor the custom assembly language, but only the code snippet language.
The Physical Layer snippet compiler takes snippets of code describing a serial bus physical layer (“Phy snippets”) and complies those snippets into state machine op codes to be used in a trigger hardware state machine. It uses a snippet language that is completely unrelated to the state machine, and allows human-readable snippets to be translated into machine code that can be implemented in hardware. It allows for real time setting changes and updates because Physical Layer code snippets can be compiled on the fly by the oscilloscope, instead of being prepackaged, i.e. hardcoded, into the oscilloscope's firmware.
The following is an example of a Phy snippet:
$ Phy Definition:
$ symbol S=((data==fall)&&((clk==0)&&prev(_s)))
$ symbol_s[S, 0, 1]=((data==rise)&&(clk==0))
$ symbol 1=((clk==fall)&&(data==1))
$ symbol 0=((clk==fall)&&(data==0))
The Packet Layer snippet compiler takes snippets of code describing a serial bus event and complies those snippets (“Packet snippets”) into state machine op codes to be used in the trigger hardware state machine. The Packet Layer snippet compiler is similar to the Physical Layer snippet compiler, but instead of describing a physical bus it describes an event that is the result of a series of tokens that were output from the Physical Layer state machine. It allows human-readable snippets that describe a series of bus events to be converted into machine code that can be used a trigger hardware state machine. It also allows for real time setting changes and updates because Packet Layer code snippets can be compiled on the fly by the oscilloscope, instead of being prepackaged, i.e. hardcoded, into the oscilloscope's firmware.
The following are examples of Packet snippets:
$ packet test {S, X:2=0, MA:2, X:8==27, P:1, X:1==0, (D:9) #10}
$ packet test {S, SA:4, X:4==3, X:1=1, N′:3′, P:1, RA:8, P:1, RA:8, P:1, X:1==0, (D:9) #N+1, X:1==0}
Another component of the Serial Bus Trigger DTL System, according to embodiments, is the DTL Expression Language. This is a custom definition language that is used to program the trigger hardware in addition to the finite state machines. It takes Phy and Packet Snippets as described above, and combines them with definitions for the pattern matchers and sequence matchers in the trigger system of the test and measurement instrument to create a fully customizable bus trigger type. Use of the DTL Expression Language allows a bus to be configured completely outside of assembled C code, opening up custom bus/protocol trigger definitions to be created easily by engineers not familiar with the underlying hardware. In other words, the DTL Expression Language dynamically programs pattern matchers and sequence matchers in the trigger system of the oscilloscope, and can dynamically connect those to the finite state machine in the trigger system of the oscilloscope, such that the DTL Expression Language provides a connection between the bus definition layer, and the hardware trigger implementation. In some embodiments, the DTL Expression Language may be Extensible Markup Language (XML)-based.
The following is one example of a code listing in an example embodiment of a DTL Expression Language:
In the example above, the Phy snippet is defined by the “DTL_Phy” line, and the Packet snippet is defined by the “DTL_Packet” line. Each “Pattern” line determines a definition for a trigger system pattern matcher, and the order in which the “Pattern” lines are listed determines a definition for a trigger system sequence matcher.
Embodiments of the disclosed technology also include a software-based Trigger Hardware Emulator, which allows for development, debugging, and evaluation of newly-created bus trigger definitions by engineers, such as those engineers in geographically-distributed teams who do not have physical access to instruments and their trigger hardware, and allows triggers to be created and validated without intimate knowledge of the state machines, thereby increasing productivity and reducing the expense of creating custom bus trigger definitions.
This application is a continuation-in-part of, and claims the benefit of, U.S. patent application Ser. No. 14/574,111, filed Dec. 17, 2014, now issued as U.S. Pat. No. 10,148,547, which is incorporated herein for all purposes.
Number | Date | Country | |
---|---|---|---|
Parent | 14574111 | Dec 2014 | US |
Child | 16209936 | US |