US5745386A - Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram - Google Patents

Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram Download PDF

Info

Publication number
US5745386A
US5745386A US08/533,128 US53312895A US5745386A US 5745386 A US5745386 A US 5745386A US 53312895 A US53312895 A US 53312895A US 5745386 A US5745386 A US 5745386A
Authority
US
United States
Prior art keywords
cycle
timing diagram
interface screen
inputting
facility
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.)
Expired - Fee Related
Application number
US08/533,128
Inventor
Bruce Wile
Dean Gilbert Bair
Edward James Kaminski, Jr.
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Priority to US08/533,128 priority Critical patent/US5745386A/en
Assigned to INTERNATIONAL BUSINESS MACHINES CORPORATION reassignment INTERNATIONAL BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BAIR, DEAN GILBERT, KAMINSKI, EDWARD JAMES, JR., WILE, BRUCE
Priority to JP18786996A priority patent/JP3271522B2/en
Application granted granted Critical
Publication of US5745386A publication Critical patent/US5745386A/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/30Circuit design
    • G06F30/32Circuit design at the digital level
    • G06F30/33Design verification, e.g. functional simulation or model checking
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01RMEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
    • G01R31/00Arrangements for testing electric properties; Arrangements for locating electric faults; Arrangements for electrical testing characterised by what is being tested not provided for elsewhere
    • G01R31/28Testing of electronic circuits, e.g. by signal tracer
    • G01R31/317Testing of digital circuits
    • G01R31/31704Design for test; Design verification
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/22Detection or location of defective computer hardware by testing during standby operation or during idle time, e.g. start-up testing
    • G06F11/26Functional testing
    • G06F11/261Functional testing by simulating additional hardware, e.g. fault simulation

Definitions

  • This invention relates to an improved method for constructing a testcase to verify logic at the logic design level, and more particularly to a timing diagram, graphical user interface for constructing such testcases.
  • a prior art system proven effective for verification of large simulation models is to surround the logic under test with so-called irritator behaviorals (i.e. random simulation driver inputs) .
  • irritator behaviorals i.e. random simulation driver inputs
  • Another object of the invention is to use a simulation driver application to read a file created via a timing diagram user interface and generate therefrom a random simulation driver.
  • this invention contemplates the provision of a system (i.e. a tool set) to provide logic verification at the logic design level in which an external stimulus to the design is derived from a series of generalized timing diagrams that obey the interface protocols of the logic design under test.
  • a timing diagram editor provides a graphical user interface that allows the logic designer to describe his or her logic in a general timing diagram format incorporating permutations of the interface specification.
  • the output of the timing diagram editor is a file that describes the interfaces of the logic; this file can contain multiple timing diagrams that describe different interface interactions.
  • a suitable simulation driver reads the file created by the timing diagram editor, learns the interfaces described therein, and uses simulation randomization algorithms to drive the interfaces with legal scenarios for the interfaces described in the timing diagram.
  • the timing diagram editor includes a timing diagram limitor that describes the conditions that must be true for a timing diagram sequence to be initiated. Each timing diagram has its own limitor.
  • FIG. 1 is an overview flow diagram of the steps in building a testcase in accordance with the teachings of the invention.
  • FIG. 2 illustrates one embodiment of a timing diagram graphical user interface with an exemplary timing shown on the display screen.
  • FIG. 3 is a facilities input interface screen for the graphical user interface of FIG. 2.
  • FIG. 4 is a cycle input interface screen for the graphical user interface of FIG. 2.
  • FIG. 5 is a recurring cycle input interface screen for the graphical user interface of FIG. 2.
  • FIG. 6 is an illustration in part of the graphical user interface screen of FIG. 2, here depicting a novel presentation to the user of a recurring/looping cycle.
  • FIG. 7 illustrates a limiting condition graphical user interface screen.
  • FIG. 8 is a block diagram of a simple action example of a logic entity under test.
  • FIG. 10 is another example of a logic entity under test.
  • FIG. 12 is one timing diagram to model the example of FIG. 11.
  • FIG. 14 is a recurring cycle input interface for the diagram of FIG. 12.
  • FIG. 15 is another timing diagram for the example of FIG. 11.
  • FIG. 16 illustrates a graphical user interface screen to input limitors to the timing diagram of FIG. 15.
  • a logic designer via a work station 10, develops a logic design by means of a conventional computer automatic design program 12, such as the UHD hardware description application, which develops simulation model 14 of the logic.
  • a user e.g. a logic designer
  • a timing diagram editor 18 takes the graphical user interface inputs and generates a file that describes the logic interfaces.This file can contain multiple timing diagrams that describe different interface interactions.
  • a random simulation driver 17 reads the file, learns the interfaces described therein, and applies simulation randomization algorithms to drive the interfaces of the simulation model 16 with legal scenarios.
  • FIG. 2 shows a graphical user interface screen in accordance with the teachings of the invention, indicated by the general reference number 20.
  • the screen presents the user with a matrix of facilities versus cycles.
  • a facility is any signal or bus existing in the logic design.
  • facilities can be referenced, driven (e.g. to a set value), or checked (i.e. compared to a predicted value) during the simulation run.
  • the size of the matrix is dependent upon how many facilities there are and how many cycles are needed to represent the interface.
  • Key areas of the graphical user interface 20 are a facility description area 22, a cycle number area 24 and a value area 26.
  • the first field in FIG. 2 is an input/output descriptor, which is one character in length.
  • This input/output descriptor (e.g. I;O) designates the facility as either an input facility (I) or an output facility (O), and is entered adjacent the Facility Type in FIG. 3.
  • the second field is the facility name, which is entered adjacent Facility Name in FIG. 3.
  • the third field in the facility description area is the bit range for the facility, which is entered via the Facility Start bit and Facility End bit lines in FIG. 3. Once the "OK"button is pressed in FIG. 3, the facility is added to the facility description area of FIG. 2.
  • the cycle number area of FIG. 2 is a heading field with labels for each cycle of the timing diagram.
  • the labels go from CO through Cn, where n is the last cycle in the timing diagram.
  • a cycle input menu, FIG. 4, allows the user to add or delete cycles, copy cycle columns, and define recurringand looping cycles.
  • selecting a cycle causes that cycle's entire column of values to be highlighted.
  • a cycle is selected in order to add ordelete cycles. Adding one cycle to a timing diagram is accomplished by using the "Add One Cycle" selection in the pull-down menu, FIG. 4. Adding one cycle will add an entire column of values to the value area, one valuefor each facility. Each facility's new value for the added cycle will be zero. The placement of a new cycle depends upon the selected cycle and thecurrent insert option. If no cycle is selected when the "Add One Cycle" button is pressed, then the new cycle is added to the end of the timing diagram and becomes the last cycle. But if a cycle is selected, then the cycle will be inserted before or after the selected cycle, depending upon which insert options are chosen.
  • Adding N cycles to the timing diagram works similarly to adding one cycle, except that there is a prompt for thenumber of cycles to be added.
  • the "Add N Cycles" in the pull-down menu (FIG. 4) initiates the prompt. All new values for the added cycles are zero.
  • the placement of additional cycles is the same as the placement of asingle cycle.
  • the cycle headings (CO . . . Cn) in the cycle number area are automatically updated.
  • Deleting a cycle or cycles removes an entire cycle column (or columns) fromthe timing diagram.
  • the pull-down menu provides an option "Delete Last Cycle” that allows simple deletion of the last cycle. To delete multiple contiguous cycles, the first cycle to be deleted is identified, and the "Delete N Cycles" from the pull-down menu provides a prompt for the numberof cycles to be deleted starting with the selected cycle. After deletion, the cycle headings are automatically updated.
  • the Copy Cycles option in the pull-down menu allows duplication of entire columns of values into newcycles. One or more contiguous cycles can be copied at once by selecting the first cycle to be copied then selecting the Copy Cycles option from the menu, which provides a prompt for the number of cycles to be copied and the destination cycle number for the new block of cycles.
  • Recurring cycles can be added to a timing diagram at any cycle except cycleCO.
  • Recurring cycles represent a waiting or a looping state in the interface. If a waiting or looping state represents waiting for an event, such as returning data or a response, the recurring cycle will have two associated cycles; one representing the wait state and one representing the cycle in which the event has occurred. If the waiting or looping stateis defined by some number of cycles, the recurring cycle will have just onelooping state cycle associated with it.
  • the cycle where the recurring cycle is to be added is initially selected by selecting the cycle prior to or cycle afterthe cycle where the recurring cycle is to be added.
  • the recurring cycle to be updated is selected and the Update Recurring Cycle option is selected from the pull-down menu.
  • the end condition ofthe recurring cycle is specified.
  • the end condition is set in the add or update recurring cycle screen, FIG. 5.
  • Four types of end conditions are allowed. The first, "Wait for Condition" allows entry of a Boolean expression that states the end condition of the wait for event type of recurring cycle. For this type of end condition, an additional timeout value must be entered. The timeout value is used in the simulation to flaga hang condition.
  • the remaining three types of end conditions allow specification of the numbers of cycles in a loop. This number can be a fixed number, a random range, or a variable number based upon the value ofa facility or program variable in a previous cycle. As shown in FIG.
  • thegraphical user interface in accordance with this invention displays a recurring cycle with vertical bars on both sides of the cycle column. If the recurring cycle is a "Wait for Condition” type of cycle, the followingcycle will have a small diamond at the top of the column just below the cycle number area. In a "Wait for Condition” type of recurring cycle, no cycles may be inserted between the two cycle columns and deletion of the recurring cycle will remove both cycles from the timing diagram.
  • the value of every facility for every cycle in the timing diagram is specified in the value area.
  • the values specified are the values that will be given on the input facility and checked on theoutput facility during the simulation run.
  • the values can be specified in several different ways.
  • the values may be specified by a constant number, another facility or program variable, basic arithmetic and Boolean operations, a built-in function, or another function specific to the logicoperation.
  • Constant values may be entered in decimal, hexadecimal or binary.
  • Facility values or variable values can be entered in the edit cycle value window bytyping in the name of the facility or variable selected to express the desired value.
  • Both arithmetic operators and Boolean equations and equivalents operators can be entered as values in the cycle edit window.
  • Tables I and II illustrate respectively arithmetic operators and equivalents Boolean operators.
  • references to facilities and program variables in the cycle edit window specify a bit range, using a parenthesis and colon notation for bit ranges.
  • a don't care function represented by an X, disables checking for an output value or results in not driving an input value.
  • Each timing diagram has a limiting condition and a limitor probability thatcontrols the initiation of the sequences.
  • the timing diagram limitor describes the condition or conditions that must be true for a timing diagram sequence to be initiated.
  • Each timing diagram has its own limitor.There are three different limiting types used to describe the limitor condition.
  • a conditional limitor type uses an equivalents statement (i.e. evaluates to "true” or "false”).
  • a delay limitor type specifies a cycle delay count and prevents the timing diagram sequence from reinitiating until the clock cycle count has expired.
  • a maximum limitor type specifies the number of outstanding (pipelined) instances of this timing diagram that are allowed at any given time. When this limit is reached, new instances of the timing diagram will not be allowed until outstanding instances are completed.
  • the three limitor types can be used in combination to specify a given limiting condition.
  • Each timing diagram limitor has a limitor probability that allows a user toadjust the probability of a timing diagram instance being initiated during a simulation.
  • FIG. 7 shows limiting condition input user interface screen. The probability is controlled by the slide bar; if the probability is set to zero, the timing diagram sequence will never be initiated and if the probability is set to 100 the sequence will be initiated every time the limitor conditions are evaluated as true.
  • timing diagram interface In the use of the timing diagram interface in accordance with the teachingsof this invention, it should be noted that there are two basic timing diagram coding styles.
  • action oriented timing diagrams complete an entire interaction within one timing diagram. The timing diagram starts aninteraction, supplies all of the stimulus, and checks the responses throughout the sequence.
  • An action oriented timing diagram is generally appropriate for simpler interface protocols.
  • An interface oriented timing diagram has each timing diagram emulate a specific entity and not the entire surrounding logic. Using this approach, one timing diagram stimulusoften causes another timing diagram to initiate. In this case, the second timing diagram's limitor is used to kick off the instance based on outputscaused by the first timing diagram's stimulus.
  • FIG. 8 shows a simple action example in which entity A is the logic being tested. Entity B drives the lines to entity A and gets resultsback. In this example, entity A, the target of the simulation, is driven byentity B and when entity A finishes processing the command and data, it sends the results back to entity B.
  • entity A the target of the simulation
  • entity B the target of the simulation
  • FIG. 9 shows the interface lines to and from entity A and the timing associated with the facilities.
  • the "I” character that precedes the command and data facilities states that those facilities are inputs while the "O" before the results indicates an output facility.
  • the bit ranges for all three facilities are specified.
  • the timing diagram of FIG. 9 also inputs that it takes three cycles to complete the action; at cycle CO the command and data are drivenon the inputs to entity A, and the results are returned two cycles later.
  • FIG. 10 shows a second, simple action oriented interface example.
  • entity A of FIG. 8 sends each output to a third entity, entity C.
  • entity C For this example, no changes are needed to the model interface shown in FIG. 9.
  • a full understanding of how the inputs and outputs relate to each other is required to accurately describe the interfaces.
  • the specifics of the surrounding logic are not important to the model.
  • FIG. 11 shows a complex interface oriented example.
  • entity A is the logic being tested.
  • Entity B initiates the sequence, and entity C respondsto the stimulus from entity A.
  • each interface is represented by a separate timing diagram.
  • the first timing diagram might includesequences 1 and 4 from FIG. 11. This timing diagram would initiate the entire sequence, wait for some amount of time, then check the resulting outputs at the end. Initiation of this timing diagram would be random.
  • Thesecond timing diagram would include sequences 2 and 3 from FIG. 11. This timing diagram would be initiated by the events of interface action 2.
  • FIG. 12 illustrates the first timing diagram interface
  • FIG. 13 illustrates the limitor interface for the timing diagram of FIG. 12.
  • the limitor prevents the sequence from occurring whenever the sequence is already outstanding. That is, there will be no pipelining of the sequence because the "Max" outstanding counter is set to 1.
  • the probability slide bar is set to 50 percent so that the overall outcome is that the sequence will be initiatedabout 50 percent of the time that the sequence is not already active.
  • Cycles C2 and C3 of the timing diagram in FIG. 12 represent a recurring cycle where the entity D is waiting for a response from entity A.
  • the recurring cycle definition for this timing diagram is shown in FIG. 13.
  • Cycle C3 represents the cycle whenA -- 2 -- B -- final -- response(0:1) is not zero (i.e. theending condition).
  • the hang count which has been set to 100, puts a time out condition on the limitor. If the end condition is not met within 100 cycles a hang error would be flagged.
  • FIG. 15 represents the timing diagram for the interface between entity A and entity C.
  • This timing diagram shows query data and a query response.
  • the query data comes from entity A as a result of the timing diagram 1 being initiated.
  • the query response emulates what entity C might send backentity A as a result of the query.
  • FIG. 15 shows a limitor for the timing diagram in FIG. 14.
  • the limitor causes timing diagram 2 to act as a "slave" to entity A.
  • the limiting condition states that this timing diagram can only be initiated when A -- to -- C -- query -- valid(0) is on.
  • the "ignore quiesce” button is also set to insure that this timing diagram is run evenif GENRAND has started to quiesce the run.
  • a recurring cycle has been put in timing diagram 2 in order to add a randomdelay between the query data and the query response.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Evolutionary Computation (AREA)
  • Geometry (AREA)
  • Quality & Reliability (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

A. system (i.e. a tool set) provides logic verification at the logic design level in which an external stimulus to the design is derived from a series of generalized timing diagrams that obey the interface protocols of the logic design under test. A timing diagram editor provides a graphical user interface that allows the logic designer to describe his or her logic in a general timing diagram format incorporating permutations of the interface specification. The output of the timing diagram editor is a file that describes the interfaces of the logic; this file can contain multiple timing diagrams that describe different interface interactions. A suitable simulation driver reads the file created by the timing diagram editor, learns the interfaces described therein, and uses simulation randomization algorithms to drive the interfaces with legal scenarios for the interfaces described in the timing diagram.

Description

BACKGROUND OF THE INVENTION
1. Field of the Invention
This invention relates to an improved method for constructing a testcase to verify logic at the logic design level, and more particularly to a timing diagram, graphical user interface for constructing such testcases.
2. Description of the Prior Art
The task of verification of a logic design, particularly the logic design of a portion of a large system, is often the responsibility of the logic designer. In the prior art, in order to attempt to verify a logic design, the logic designer was required to write a program to simulate the logic design or to design language testcases (referred to in the art as behaviorals).
These prior art approaches to logic design verification are deficient in at least two respects. If the task of verification is the responsibility of the logic designer, as it often is, the format of the program or testcase which the logic designer must write is often unfamiliar to him or her. Further, existing testcase tools are not capable of generating complex permutations of inputs to drive the logic.
A prior art system proven effective for verification of large simulation models is to surround the logic under test with so-called irritator behaviorals (i.e. random simulation driver inputs) . However, with existing prior art technology, in order to verify a logic design with such a system, writing multiple random behavioral programs is required.
SUMMARY OF THE INVENTION
An object of this invention is the provision of a system for verifying logic designs which uses the concepts of irritator behaviorals but with a timing diagram input format, which is familiar to logic designers.
Another object of the invention is to use a simulation driver application to read a file created via a timing diagram user interface and generate therefrom a random simulation driver.
A further object of the invention is the provision of a user interface to simply describe the conditions that must exist for a timing diagram sequence to be legally initiated.
Briefly, this invention contemplates the provision of a system (i.e. a tool set) to provide logic verification at the logic design level in which an external stimulus to the design is derived from a series of generalized timing diagrams that obey the interface protocols of the logic design under test. A timing diagram editor provides a graphical user interface that allows the logic designer to describe his or her logic in a general timing diagram format incorporating permutations of the interface specification. The output of the timing diagram editor is a file that describes the interfaces of the logic; this file can contain multiple timing diagrams that describe different interface interactions. A suitable simulation driver reads the file created by the timing diagram editor, learns the interfaces described therein, and uses simulation randomization algorithms to drive the interfaces with legal scenarios for the interfaces described in the timing diagram. The timing diagram editor includes a timing diagram limitor that describes the conditions that must be true for a timing diagram sequence to be initiated. Each timing diagram has its own limitor.
BRIEF DESCRIPTION OF THE DRAWINGS
The foregoing and other objects, aspects and advantages will be better understood from the following detailed description of a preferred embodiment of the invention with reference to the drawings, in which:
FIG. 1 is an overview flow diagram of the steps in building a testcase in accordance with the teachings of the invention.
FIG. 2 illustrates one embodiment of a timing diagram graphical user interface with an exemplary timing shown on the display screen.
FIG. 3 is a facilities input interface screen for the graphical user interface of FIG. 2.
FIG. 4 is a cycle input interface screen for the graphical user interface of FIG. 2.
FIG. 5 is a recurring cycle input interface screen for the graphical user interface of FIG. 2.
FIG. 6 is an illustration in part of the graphical user interface screen of FIG. 2, here depicting a novel presentation to the user of a recurring/looping cycle.
FIG. 7 illustrates a limiting condition graphical user interface screen.
FIG. 8 is a block diagram of a simple action example of a logic entity under test.
FIG. 9 illustrates a timing diagram in accordance with the invention to model the example of FIG. 8.
FIG. 10 is another example of a logic entity under test.
FIG. 11 is still another example of a logic entity under test.
FIG. 12 is one timing diagram to model the example of FIG. 11.
FIG. 13 illustrates a limitor interface for the timing diagram of FIG. 12.
FIG. 14 is a recurring cycle input interface for the diagram of FIG. 12.
FIG. 15 is another timing diagram for the example of FIG. 11.
FIG. 16 illustrates a graphical user interface screen to input limitors to the timing diagram of FIG. 15.
DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT OF THE INVENTION
Referring now to FIG. 1, a logic designer, via a work station 10, develops a logic design by means of a conventional computer automatic design program 12, such as the UHD hardware description application, which develops simulation model 14 of the logic. In accordance with the teachingof this invention, a user (e.g. a logic designer) lays out and/or edits a general interface protocol for his or her logic design in the form of timing diagrams. A timing diagram editor 18 takes the graphical user interface inputs and generates a file that describes the logic interfaces.This file can contain multiple timing diagrams that describe different interface interactions. A random simulation driver 17 reads the file, learns the interfaces described therein, and applies simulation randomization algorithms to drive the interfaces of the simulation model 16 with legal scenarios.
Referring now to FIG. 2, it shows a graphical user interface screen in accordance with the teachings of the invention, indicated by the general reference number 20. The screen presents the user with a matrix of facilities versus cycles. As used herein, a facility is any signal or bus existing in the logic design. Via the interface, facilities can be referenced, driven (e.g. to a set value), or checked (i.e. compared to a predicted value) during the simulation run. The size of the matrix is dependent upon how many facilities there are and how many cycles are needed to represent the interface. Key areas of the graphical user interface 20 are a facility description area 22, a cycle number area 24 and a value area 26.
There are three fields in the facility description area 22. In these three fields all required information about each facility is inputted via a facility menu shown in FIG. 3. The first field in FIG. 2 is an input/output descriptor, which is one character in length. This input/output descriptor (e.g. I;O) designates the facility as either an input facility (I) or an output facility (O), and is entered adjacent the Facility Type in FIG. 3. The second field is the facility name, which is entered adjacent Facility Name in FIG. 3. The third field in the facility description area, is the bit range for the facility, which is entered via the Facility Start bit and Facility End bit lines in FIG. 3. Once the "OK"button is pressed in FIG. 3, the facility is added to the facility description area of FIG. 2.
The cycle number area of FIG. 2 is a heading field with labels for each cycle of the timing diagram. The labels go from CO through Cn, where n is the last cycle in the timing diagram. A cycle input menu, FIG. 4, allows the user to add or delete cycles, copy cycle columns, and define recurringand looping cycles.
As illustrated in FIG. 4, selecting a cycle causes that cycle's entire column of values to be highlighted. A cycle is selected in order to add ordelete cycles. Adding one cycle to a timing diagram is accomplished by using the "Add One Cycle" selection in the pull-down menu, FIG. 4. Adding one cycle will add an entire column of values to the value area, one valuefor each facility. Each facility's new value for the added cycle will be zero. The placement of a new cycle depends upon the selected cycle and thecurrent insert option. If no cycle is selected when the "Add One Cycle" button is pressed, then the new cycle is added to the end of the timing diagram and becomes the last cycle. But if a cycle is selected, then the cycle will be inserted before or after the selected cycle, depending upon which insert options are chosen. Adding N cycles to the timing diagram works similarly to adding one cycle, except that there is a prompt for thenumber of cycles to be added. The "Add N Cycles" in the pull-down menu (FIG. 4) initiates the prompt. All new values for the added cycles are zero. The placement of additional cycles is the same as the placement of asingle cycle. After adding new cycles, the cycle headings (CO . . . Cn) in the cycle number area are automatically updated.
Deleting a cycle or cycles removes an entire cycle column (or columns) fromthe timing diagram. The pull-down menu provides an option "Delete Last Cycle" that allows simple deletion of the last cycle. To delete multiple contiguous cycles, the first cycle to be deleted is identified, and the "Delete N Cycles" from the pull-down menu provides a prompt for the numberof cycles to be deleted starting with the selected cycle. After deletion, the cycle headings are automatically updated. The Copy Cycles option in the pull-down menu allows duplication of entire columns of values into newcycles. One or more contiguous cycles can be copied at once by selecting the first cycle to be copied then selecting the Copy Cycles option from the menu, which provides a prompt for the number of cycles to be copied and the destination cycle number for the new block of cycles.
Recurring cycles can be added to a timing diagram at any cycle except cycleCO. Recurring cycles represent a waiting or a looping state in the interface. If a waiting or looping state represents waiting for an event, such as returning data or a response, the recurring cycle will have two associated cycles; one representing the wait state and one representing the cycle in which the event has occurred. If the waiting or looping stateis defined by some number of cycles, the recurring cycle will have just onelooping state cycle associated with it.
To add a recurring cycle, the cycle where the recurring cycle is to be added is initially selected by selecting the cycle prior to or cycle afterthe cycle where the recurring cycle is to be added. To update an already existing recurring cycle, the recurring cycle to be updated is selected and the Update Recurring Cycle option is selected from the pull-down menu.
Referring now to FIG. 5, in defining a recurring cycle the end condition ofthe recurring cycle is specified. The end condition is set in the add or update recurring cycle screen, FIG. 5. Four types of end conditions are allowed. The first, "Wait for Condition" allows entry of a Boolean expression that states the end condition of the wait for event type of recurring cycle. For this type of end condition, an additional timeout value must be entered. The timeout value is used in the simulation to flaga hang condition. The remaining three types of end conditions allow specification of the numbers of cycles in a loop. This number can be a fixed number, a random range, or a variable number based upon the value ofa facility or program variable in a previous cycle. As shown in FIG. 6, thegraphical user interface in accordance with this invention displays a recurring cycle with vertical bars on both sides of the cycle column. If the recurring cycle is a "Wait for Condition" type of cycle, the followingcycle will have a small diamond at the top of the column just below the cycle number area. In a "Wait for Condition" type of recurring cycle, no cycles may be inserted between the two cycle columns and deletion of the recurring cycle will remove both cycles from the timing diagram.
Referring again to FIG. 2, the value of every facility for every cycle in the timing diagram is specified in the value area. The values specified are the values that will be given on the input facility and checked on theoutput facility during the simulation run. The values can be specified in several different ways. The values may be specified by a constant number, another facility or program variable, basic arithmetic and Boolean operations, a built-in function, or another function specific to the logicoperation.
Constant values may be entered in decimal, hexadecimal or binary. Facility values or variable values can be entered in the edit cycle value window bytyping in the name of the facility or variable selected to express the desired value. Both arithmetic operators and Boolean equations and equivalents operators can be entered as values in the cycle edit window. The following tables, Tables I and II, illustrate respectively arithmetic operators and equivalents Boolean operators.
              TABLE 1                                                     
______________________________________                                    
Arithmetic Operators                                                      
Operator                                                                  
        Function      Example Usage                                       
______________________________________                                    
+       Addition      fac.sub.-- name(0:2)+1                              
-       Subtraction   fac.sub.-- name (0:2)-another.sub.-- fac (2)        
*       Multiplication                                                    
                      2*fac.sub.-- name(0:2)                              
/       Division      fac.sub.-- name(0:2)/2                              
()      Order of Execution                                                
                      (fac.sub.-- name(0:2)*2)+1                          
||                                                      
        Concatenation fac.sub.-- name(0:2)||other.sub.--
                       fac(3:4)                                           
&       Bit And       fac.sub.-- name(0:2)&`101'X                         
|                                                                
        Bit Or        fac.sub.-- name(0:2)|other.sub.-- fac(0:2) 
                      3                                                   
        One's complement                                                  
                      fac.sub.-- name(0:2)                                
        (Use Shift-6 on                                                   
        USA keyboards)                                                    
&&      Exclusive Or  fac.sub.-- name(0:2)&&other.sub.-- fac(1:3)         
______________________________________                                    
              TABLE 2                                                     
______________________________________                                    
Equivalence Operators                                                     
Operator                                                                  
        Function      Example Usage                                       
______________________________________                                    
=       Equals        fac.sub.-- name (0:2) =`010`B                       
=       Not Equal     fac.sub.-- name (0:2) =`010`B                       
>=      Greater than or Equal                                             
                      fac.sub.-- name (0:2) >=1                           
<=      Less than or Equal                                                
                      fac.sub.-- name (0:2) <=`3`X                        
<       Less than     Fac.sub.-- name (0:2) <4                            
>       Greater than  fac.sub.-- name (0:2) >other.sub.-- fac             
______________________________________                                    
                      (2:4)                                               
References to facilities and program variables in the cycle edit window specify a bit range, using a parenthesis and colon notation for bit ranges. A don't care function, represented by an X, disables checking for an output value or results in not driving an input value.
Each timing diagram has a limiting condition and a limitor probability thatcontrols the initiation of the sequences. The timing diagram limitor describes the condition or conditions that must be true for a timing diagram sequence to be initiated. Each timing diagram has its own limitor.There are three different limiting types used to describe the limitor condition. A conditional limitor type uses an equivalents statement (i.e. evaluates to "true" or "false"). A delay limitor type specifies a cycle delay count and prevents the timing diagram sequence from reinitiating until the clock cycle count has expired. A maximum limitor type specifies the number of outstanding (pipelined) instances of this timing diagram that are allowed at any given time. When this limit is reached, new instances of the timing diagram will not be allowed until outstanding instances are completed. The three limitor types can be used in combination to specify a given limiting condition.
Each timing diagram limitor has a limitor probability that allows a user toadjust the probability of a timing diagram instance being initiated during a simulation. FIG. 7 shows limiting condition input user interface screen.The probability is controlled by the slide bar; if the probability is set to zero, the timing diagram sequence will never be initiated and if the probability is set to 100 the sequence will be initiated every time the limitor conditions are evaluated as true.
In the use of the timing diagram interface in accordance with the teachingsof this invention, it should be noted that there are two basic timing diagram coding styles. In action oriented timing diagrams complete an entire interaction within one timing diagram. The timing diagram starts aninteraction, supplies all of the stimulus, and checks the responses throughout the sequence. An action oriented timing diagram is generally appropriate for simpler interface protocols. An interface oriented timing diagram has each timing diagram emulate a specific entity and not the entire surrounding logic. Using this approach, one timing diagram stimulusoften causes another timing diagram to initiate. In this case, the second timing diagram's limitor is used to kick off the instance based on outputscaused by the first timing diagram's stimulus.
The operation of the invention can be illustrated by way of the following examples. FIG. 8 shows a simple action example in which entity A is the logic being tested. Entity B drives the lines to entity A and gets resultsback. In this example, entity A, the target of the simulation, is driven byentity B and when entity A finishes processing the command and data, it sends the results back to entity B. This example is easily modeled using the interfaces thus far described. The timing diagram of FIG. 2 inputted to model the example of FIG. 8 is shown in FIG. 9. FIG. 9 shows the interface lines to and from entity A and the timing associated with the facilities. Although simple, this timing diagram provides all of the needed inputs to model the interface interactions between entity A and entity B. The "I" character that precedes the command and data facilities states that those facilities are inputs while the "O" before the results indicates an output facility. The bit ranges for all three facilities are specified. The timing diagram of FIG. 9 also inputs that it takes three cycles to complete the action; at cycle CO the command and data are drivenon the inputs to entity A, and the results are returned two cycles later.
FIG. 10 shows a second, simple action oriented interface example. Here, thesame logic under test, entity A of FIG. 8, sends each output to a third entity, entity C. For this example, no changes are needed to the model interface shown in FIG. 9. Here it should be noted that a full understanding of how the inputs and outputs relate to each other is required to accurately describe the interfaces. The specifics of the surrounding logic are not important to the model.
FIG. 11 shows a complex interface oriented example. Here, entity A is the logic being tested. Entity B initiates the sequence, and entity C respondsto the stimulus from entity A. In this interface oriented model, each interface is represented by a separate timing diagram. In this example, the interfaces between entity A and B and entity A and C would both be coded in different timing diagrams. The first timing diagram might includesequences 1 and 4 from FIG. 11. This timing diagram would initiate the entire sequence, wait for some amount of time, then check the resulting outputs at the end. Initiation of this timing diagram would be random. Thesecond timing diagram would include sequences 2 and 3 from FIG. 11. This timing diagram would be initiated by the events of interface action 2. Thetiming diagram would check for correct data in the interface action 2, and respond to the action with interface action 3. This response would then cause the logic in entity A to complete the entire sequence with interfaceaction 4, thereby completing the first timing diagram. FIG. 12 illustrates the first timing diagram interface, and FIG. 13 illustrates the limitor interface for the timing diagram of FIG. 12. Here, the limitor prevents the sequence from occurring whenever the sequence is already outstanding. That is, there will be no pipelining of the sequence because the "Max" outstanding counter is set to 1. The probability slide bar is set to 50 percent so that the overall outcome is that the sequence will be initiatedabout 50 percent of the time that the sequence is not already active.
Cycles C2 and C3 of the timing diagram in FIG. 12 represent a recurring cycle where the entity D is waiting for a response from entity A. The recurring cycle definition for this timing diagram is shown in FIG. 13. This recurring cycle definition states that the timing diagram in FIG. 11 should loop until "A-- 2-- B-- final-- response(0:1)=0" during cycle 2. While waiting, the inputs in the timing diagram will be driven to the values in cycle C2, and the outputs will be checked against the values in cycle C2. Cycle C3 represents the cycle whenA-- 2-- B-- final-- response(0:1) is not zero (i.e. theending condition). The hang count, which has been set to 100, puts a time out condition on the limitor. If the end condition is not met within 100 cycles a hang error would be flagged.
FIG. 15 represents the timing diagram for the interface between entity A and entity C. This timing diagram shows query data and a query response. The query data comes from entity A as a result of the timing diagram 1 being initiated. The query response emulates what entity C might send backentity A as a result of the query. FIG. 15 shows a limitor for the timing diagram in FIG. 14.
The limitor causes timing diagram 2 to act as a "slave" to entity A. The limiting condition states that this timing diagram can only be initiated when A-- to-- C-- query-- valid(0) is on. The "ignore quiesce" button is also set to insure that this timing diagram is run evenif GENRAND has started to quiesce the run.
A recurring cycle has been put in timing diagram 2 in order to add a randomdelay between the query data and the query response.
In this case, the "Wait for Random Time" button was used, and low-bound andhigh-bound values were filled in the proper fields. After the randomly chosen waiting period, the timing diagram will continue with cycle C2.
If all goes well in the logic of Entity A, the query response from Entity Cwill evoke a response from Entity A back to Entity B. This response will trigger the end condition in the recurring cycle of timing diagram, allowing the timing diagram to complete, ending the whole sequence. After that, the limitor "Max" condition on timing diagram would allow GENRAND toinitiate a new instance of the sequence.
While the invention has been described in terms of a single preferred embodiment, those skilled in the art will recognize that the invention canbe practiced with modification within the spirit and scope of the appended claims.

Claims (13)

Having thus described our invention, what we claim as new and desire to secure by Letters Patent is as follows:
1. A method for inputting parameters via a graphical user interface into a data base in order to build a testcase for a computer simulation of a logic design, comprising the steps of:
inputting facility parameters of said logic design via a graphical user facility interface screen;
inputting cycle values for each facility via a graphical user cycle interface screen;
inputting recurring cycles via a graphical user recurring cycle interface screen;
inputting limiting conditions and a limitor probability for a timing diagram via a graphical user limitor interface screen;
generating an interface protocol to said computer simulation of a logic design via a timing diagram formatted graphical user interface screen, which timing diagram formatted graphical user interface screen lists facilities in a vertical column and cycle values for each facility in a horizontal row from said inputting steps and corresponding cycle values for each facility aligned in vertical columns.
2. A method for inputting parameters for a logic design as in claim 1 wherein said facility interface screen specifies inputs for an input/output descriptor, a facility name, and a facility bit range.
3. A method for inputting parameters for a logic design as in claim 1 wherein said cycle interface screen specifies for each selected cycle a cycle value for each facility.
4. A method for inputting parameters for a logic design as in claim 1 wherein said recurring cycle interface screen specifies inputs for end conditions for each recurring cycle.
5. A method for inputting parameters for a logic design as in claim 1 wherein said limitor cycle interface screen respectively specifies conditions for invocation of the cycle in a testcase and a probability that it will be invoked via a user interface screen.
6. A method for inputting parameters for a logic design as in claim 2 wherein said cycle interface screen specifies for each selected cycle a cycle value for each facility.
7. A method for inputting parameters for a logic design as in claim 2 wherein said recurring cycle interface screen specifies inputs for end conditions for each recurring cycle.
8. A method for inputting parameters for a logic design as in claim 2 via a user interface screen wherein said limitor cycle interface screen respectively specifies conditions for invocation of the cycle in a testcase and a probability that it will be invoked.
9. A method for inputting parameters via a graphical user interface into a data base in order to build a testcase for a computer simulation of a logic design, comprising the steps of:
inputting facility parameters of said logic design via a graphical user interface screen that specifies inputs for an input/output descriptor, a facility name, and a facility bit range;
inputting cycle values for each facility via a graphical user interface screen that specifies for each selected cycle a cycle value for each facility;
inputting recurring cycles via a graphical user interface screen that specifies inputs for end conditions for each recurring cycle;
inputting limiting conditions and a limitor probability for a timing diagram that respectively defines conditions for invocation of the timing diagram in a testcase and a probability that it will be invoked via a user interface screen;
generating an interface protocol to said computer simulation of a logic design via a timing diagram formatted graphical user interface screen from said inputting steps, which timing diagram graphical user interface screen lists facilities in a vertical column and cycle values for each facility in a horizontal row from said inputting steps and corresponding cycle values for each facility aligned in vertical columns.
10. A method for inputting parameters for a logic design as in claim 4 wherein said end condition includes a wait for a condition, a loop for a specific number of cycles, a loop for a bounded random number of cycles, and a loop for a variable number of cycles.
11. A method for inputting parameters for a logic design as in claim 10 wherein said timing diagram graphical user interface screen identifies a recurring loop cycle with vertical bars on either side of a vertical column in which said recurring loop cycle occurs.
12. A method for inputting parameters for a logic design as in claim 9 wherein said end condition includes a wait for a condition, a loop for a specific number of cycles, a loop for a bounded random number of cycles, and a loop for a variable number of cycles.
13. A method for inputting parameters for a logic design as in claim 12 wherein said timing diagram graphical user interface screen identifies a recurring loop cycle with vertical bars on either side of a vertical column in which said recurring loop cycle occurs.
US08/533,128 1995-09-25 1995-09-25 Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram Expired - Fee Related US5745386A (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US08/533,128 US5745386A (en) 1995-09-25 1995-09-25 Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram
JP18786996A JP3271522B2 (en) 1995-09-25 1996-07-17 Parameter input method for logic design verification

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US08/533,128 US5745386A (en) 1995-09-25 1995-09-25 Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram

Publications (1)

Publication Number Publication Date
US5745386A true US5745386A (en) 1998-04-28

Family

ID=24124610

Family Applications (1)

Application Number Title Priority Date Filing Date
US08/533,128 Expired - Fee Related US5745386A (en) 1995-09-25 1995-09-25 Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram

Country Status (2)

Country Link
US (1) US5745386A (en)
JP (1) JP3271522B2 (en)

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6181320B1 (en) 1998-08-19 2001-01-30 International Business Machines Corporation Method for converting timing diagram into timing graph and vice versa
US6253365B1 (en) 1998-10-06 2001-06-26 David P. Baldwin Automated design system for digital circuits
US6453446B1 (en) 1997-12-24 2002-09-17 Magma Design Automation, Inc. Timing closure methodology
US6453450B1 (en) 2000-02-02 2002-09-17 International Business Machines Corporation Timing diagram compiler and runtime environment for interactive generation of executable test programs for logic verification
US20030052880A1 (en) * 2001-09-17 2003-03-20 International Business Machines Corporation Several improvements for timing diagrams
US20030065975A1 (en) * 2001-10-01 2003-04-03 International Business Machines Corporation Test tool and methods for testing a computer structure employing a computer simulation of the computer structure
US20040226041A1 (en) * 2000-02-18 2004-11-11 Xsides Corporation System and method for parallel data display of multiple executing environments
US20050052473A1 (en) * 1997-11-21 2005-03-10 Xsides Corporation Secondary user interface
US6892172B1 (en) 2000-02-16 2005-05-10 Raj Kumar Singh Customizable simulation model of an ATM/SONET framer for system level verification and performance characterization
US20050251765A1 (en) * 2004-05-10 2005-11-10 International Business Machines Corporation Design verification of highly optimized synchronous pipelines via random simulation driven by critical resource scheduling
US20060190233A1 (en) * 2005-02-24 2006-08-24 International Business Machines Corporation Stimulus extraction and sequence generation for an electronic device under test
US20080077896A1 (en) * 2006-09-26 2008-03-27 Fujitsu Limited Method and apparatus for editing timing diagram, and computer product
DE10065417B4 (en) * 2000-12-27 2011-07-21 Siemens AG, 80333 Programming of cyclic machines
US20170278487A1 (en) * 2016-03-25 2017-09-28 Lsis Co., Ltd. Method for displaying monitoring viewer in hmi system
US20190104152A1 (en) * 2017-09-29 2019-04-04 Paypal, Inc. Blind injection attack mitigation
CN109857654A (en) * 2019-01-17 2019-06-07 珠海金山网络游戏科技有限公司 A kind of method, apparatus and system of the timing flow chart automatically generating test case
US10778266B2 (en) 2017-10-06 2020-09-15 Cable Television Laboratories, Inc. Smart taps
US11711138B1 (en) 2017-10-06 2023-07-25 Cable Television Laboratories, Inc. Mitigating satellite interference

Citations (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4364036A (en) * 1979-11-26 1982-12-14 Iwatsu Electric Co., Ltd. Composite logic analyzer capable of data display in two time-related formats
US4554536A (en) * 1983-03-23 1985-11-19 Tektronix, Inc. Logic timing diagram display apparatus
US4914568A (en) * 1986-10-24 1990-04-03 National Instruments, Inc. Graphical system for modelling a process and associated method
US5073853A (en) * 1986-11-03 1991-12-17 U.S. Philips Corporation Watchdog circuit for monitoring programs and detecting infinite loops using a changing multibit word for timer reset
US5173869A (en) * 1989-12-25 1992-12-22 Mazda Motor Corporation Method of simulating a sequential control for analyzing a production line in a production system
US5187677A (en) * 1991-08-23 1993-02-16 Hewlett-Packard Company Waveform synthesizer through simulating multiplication
US5210837A (en) * 1990-06-15 1993-05-11 Digital Equipment Corporation Methods and apparatus for transforming machine language program control into high-level language constructs by manipulating graphical program representations
US5313615A (en) * 1987-06-22 1994-05-17 Comdisco Systems, Inc. Block diagram simulator using a library for generation of a computer program
US5371851A (en) * 1989-04-26 1994-12-06 Credence Systems Corporation Graphical data base editor
US5375125A (en) * 1991-05-15 1994-12-20 Hitachi, Ltd. Method of displaying program execution for a computer
US5381524A (en) * 1991-11-12 1995-01-10 Chronology Corp. Automated development of timing diagrams for electrical circuits
US5384720A (en) * 1993-06-10 1995-01-24 Hitachi Micro Systems Inc. Logic circuit simulator and logic simulation method having reduced number of simulation events
US5623418A (en) * 1990-04-06 1997-04-22 Lsi Logic Corporation System and method for creating and validating structural description of electronic system

Patent Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4364036A (en) * 1979-11-26 1982-12-14 Iwatsu Electric Co., Ltd. Composite logic analyzer capable of data display in two time-related formats
US4554536A (en) * 1983-03-23 1985-11-19 Tektronix, Inc. Logic timing diagram display apparatus
US4914568A (en) * 1986-10-24 1990-04-03 National Instruments, Inc. Graphical system for modelling a process and associated method
US5073853A (en) * 1986-11-03 1991-12-17 U.S. Philips Corporation Watchdog circuit for monitoring programs and detecting infinite loops using a changing multibit word for timer reset
US5313615A (en) * 1987-06-22 1994-05-17 Comdisco Systems, Inc. Block diagram simulator using a library for generation of a computer program
US5371851A (en) * 1989-04-26 1994-12-06 Credence Systems Corporation Graphical data base editor
US5173869A (en) * 1989-12-25 1992-12-22 Mazda Motor Corporation Method of simulating a sequential control for analyzing a production line in a production system
US5623418A (en) * 1990-04-06 1997-04-22 Lsi Logic Corporation System and method for creating and validating structural description of electronic system
US5210837A (en) * 1990-06-15 1993-05-11 Digital Equipment Corporation Methods and apparatus for transforming machine language program control into high-level language constructs by manipulating graphical program representations
US5375125A (en) * 1991-05-15 1994-12-20 Hitachi, Ltd. Method of displaying program execution for a computer
US5187677A (en) * 1991-08-23 1993-02-16 Hewlett-Packard Company Waveform synthesizer through simulating multiplication
US5381524A (en) * 1991-11-12 1995-01-10 Chronology Corp. Automated development of timing diagrams for electrical circuits
US5381524B1 (en) * 1991-11-12 1996-10-29 Chronology Corp Automated development of timing diagrams for electrical circuits
US5381524B2 (en) * 1991-11-12 1997-07-08 Chronology Corp Automated development of timing diagrams for electrical circuits
US5384720A (en) * 1993-06-10 1995-01-24 Hitachi Micro Systems Inc. Logic circuit simulator and logic simulation method having reduced number of simulation events

Cited By (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050052473A1 (en) * 1997-11-21 2005-03-10 Xsides Corporation Secondary user interface
US6453446B1 (en) 1997-12-24 2002-09-17 Magma Design Automation, Inc. Timing closure methodology
US8621403B2 (en) 1997-12-24 2013-12-31 Synopsys, Inc. Timing closure methodology including placement with initial delay values
US6725438B2 (en) 1997-12-24 2004-04-20 Magma Design Automation, Inc. Timing closure methodology
US9811624B2 (en) 1997-12-24 2017-11-07 Synopsys, Inc. Timing closure methodology including placement with initial delay values
US20050120319A1 (en) * 1997-12-24 2005-06-02 Van Ginneken Lukas P. Timing closure methodology
US6181320B1 (en) 1998-08-19 2001-01-30 International Business Machines Corporation Method for converting timing diagram into timing graph and vice versa
US6253365B1 (en) 1998-10-06 2001-06-26 David P. Baldwin Automated design system for digital circuits
US6453450B1 (en) 2000-02-02 2002-09-17 International Business Machines Corporation Timing diagram compiler and runtime environment for interactive generation of executable test programs for logic verification
US6892172B1 (en) 2000-02-16 2005-05-10 Raj Kumar Singh Customizable simulation model of an ATM/SONET framer for system level verification and performance characterization
US20040226041A1 (en) * 2000-02-18 2004-11-11 Xsides Corporation System and method for parallel data display of multiple executing environments
US20100064245A1 (en) * 2000-02-18 2010-03-11 Xsides Corporation System and method for parallel data display of multiple executing environments
DE10065417B4 (en) * 2000-12-27 2011-07-21 Siemens AG, 80333 Programming of cyclic machines
US6745376B2 (en) * 2001-09-17 2004-06-01 International Business Machines Corporation Several improvements for timing diagrams
US20030052880A1 (en) * 2001-09-17 2003-03-20 International Business Machines Corporation Several improvements for timing diagrams
US6898735B2 (en) * 2001-10-01 2005-05-24 International Business Machines Corporation Test tool and methods for testing a computer structure employing a computer simulation of the computer structure
US20030065975A1 (en) * 2001-10-01 2003-04-03 International Business Machines Corporation Test tool and methods for testing a computer structure employing a computer simulation of the computer structure
US7426704B2 (en) 2004-05-10 2008-09-16 International Business Machines Corporation Design verification of highly optimized synchronous pipelines via random simulation driven by critical resource scheduling
US20050251765A1 (en) * 2004-05-10 2005-11-10 International Business Machines Corporation Design verification of highly optimized synchronous pipelines via random simulation driven by critical resource scheduling
US7739633B2 (en) 2004-05-10 2010-06-15 International Business Machines Corporation Verification of highly optimized synchronous pipelines via random simulation driven by critical resource scheduling system and program product
US20090132221A1 (en) * 2004-05-10 2009-05-21 International Business Machines Corporation Verification of Highly Optimized Synchronous Pipelines via Random Simulation Driven by Critical Resource Scheduling System and Program Product
US7444574B2 (en) * 2005-02-24 2008-10-28 International Business Machines Corporation Stimulus extraction and sequence generation for an electric device under test
US20060190233A1 (en) * 2005-02-24 2006-08-24 International Business Machines Corporation Stimulus extraction and sequence generation for an electronic device under test
US7911466B2 (en) * 2006-09-26 2011-03-22 Fujitsu Limited Method and apparatus for editing timing diagram, and computer product
US20080077896A1 (en) * 2006-09-26 2008-03-27 Fujitsu Limited Method and apparatus for editing timing diagram, and computer product
US20170278487A1 (en) * 2016-03-25 2017-09-28 Lsis Co., Ltd. Method for displaying monitoring viewer in hmi system
US10109259B2 (en) * 2016-03-25 2018-10-23 Lsis Co., Ltd. Method for displaying monitoring viewer in HMI system
US20190104152A1 (en) * 2017-09-29 2019-04-04 Paypal, Inc. Blind injection attack mitigation
US10805345B2 (en) * 2017-09-29 2020-10-13 Paypal, Inc. Blind injection attack mitigation
US10778266B2 (en) 2017-10-06 2020-09-15 Cable Television Laboratories, Inc. Smart taps
US11711138B1 (en) 2017-10-06 2023-07-25 Cable Television Laboratories, Inc. Mitigating satellite interference
CN109857654A (en) * 2019-01-17 2019-06-07 珠海金山网络游戏科技有限公司 A kind of method, apparatus and system of the timing flow chart automatically generating test case

Also Published As

Publication number Publication date
JP3271522B2 (en) 2002-04-02
JPH0991338A (en) 1997-04-04

Similar Documents

Publication Publication Date Title
US5745386A (en) Timing diagram method for inputting logic design parameters to build a testcase for the logic diagram
AU2003233316B2 (en) Automated software testing system and method
Wang et al. Formalizing and integrating the dynamic model within OMT
US20030005413A1 (en) Method for testing of software
US6976246B1 (en) Finite state model-based testing user interface
KAPETI et al. A design language and tool for X-machines specification
US6453450B1 (en) Timing diagram compiler and runtime environment for interactive generation of executable test programs for logic verification
US5130932A (en) Generating device for production system simulator
Srba Comparing the expressiveness of timed automata and timed extensions of Petri nets
EP1071014B1 (en) Adding code in an application during runtime to enrich object behavior
Ishiura et al. Coded time-symbolic simulation using shared binary decision diagram
Henderson Finite state modelling in program development
US7165201B2 (en) Method for performing testing of a simulated storage device within a testing simulation environment
Nielsen et al. Towards a notion of distributed time for Petri nets
US7013252B1 (en) Simulated circuit node initializing and monitoring
Ishiura et al. NES: the behavioral model for the formal semantics of a hardware design language UDL/I
CN114035767B (en) Instruction design method for TEC-XP16 combinational logic controller
Tapken Implementing hierarchical graph-structures
KR100408894B1 (en) The modeling method and apparatus for defining the sequence of multidisciplinary analysis and design optimization based on compound component
JPH1124911A (en) Method for automatically generating source program
Meinel et al. On the influence of the state encoding on OBDD-representations of finite state machines
EP0592076A2 (en) Compilation mechanism for a simulation model
JPH03222038A (en) Parameter input system in program
Armstrong Code generation in the Oregon speedcode universe
Rahardjo et al. Verification of speed-independent asynchronous circuits with protocol validation tools

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WILE, BRUCE;BAIR, DEAN GILBERT;KAMINSKI, EDWARD JAMES, JR.;REEL/FRAME:007671/0267

Effective date: 19950921

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FEPP Fee payment procedure

Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

FPAY Fee payment

Year of fee payment: 4

REMI Maintenance fee reminder mailed
LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20060428