The present invention relates generally to the data processing field, and more particularly, relates to a method and circuit for implementing enhanced diagnostics with intelligent pattern combination in automatic test pattern generation (ATPG), and a design structure on which the subject circuit resides.
As Application Specific Integrated Circuit (ASIC) and Processor chips continue to get larger, test data volume and test time naturally increase as well. It continually becomes even more important to increase test efficiency.
Automated Test Pattern Generation, or ATPG, is the standard methodology to generate test patterns for ASIC and processor designs. ATPG can be conceptualized as two independent steps. First, generate patterns; second, simulate those patterns and determine what faults are covered. Afterward, patterns are combined and selected in such a way to maximize overall test coverage while minimizing pattern count. However, the method of generating new patterns is generally done based on previous patterns fault elimination, but independently of patterns themselves that have already been generated.
A need exists for an effective mechanism for implementing enhanced diagnostics with intelligent pattern combination in automatic test pattern generation (ATPG). It is desirable to generate new ATPG patterns that combine well with already-generated patterns in an attempt to maximize fault coverage per pattern.
Principal aspects of the present invention are to provide a method and circuit for implementing enhanced diagnostics with intelligent pattern combination in automatic test pattern generation (ATPG), and a design structure on which the subject circuit resides. Other important aspects of the present invention are to provide such method, circuit and design structure substantially without negative effects and that overcome many of the disadvantages of prior art arrangements.
In brief, a method and circuit for implementing enhanced diagnostics with intelligent pattern combination in ATPG, and a design structure on which the subject circuit resides are provided. A random fault is selected in the design. A test pattern is generated and applied the test pattern to a design under test to test the selected random fault. The test is re-simulated to determine faults that are covered by the applied test pattern. A next iteration of test pattern generation includes selecting a fault that is based upon the previous test pattern generation for generating new test patterns.
In accordance with features of the invention, in the next iterations of test pattern generation where selecting the fault that is based upon the previous test pattern generation for generating new test patterns include selecting a fault which is already controllable by the current pattern, or has not been stimulated to a value at all yet, that is to say, a fault that is not blocked from testing by the current pattern. Using this selected fault, the process of generating test patterns is repeated.
In accordance with features of the invention, in a case where a contradiction occurs where targeting the fault in question is not fully possible with the current pattern, as values at the current control or observe points may change. If the patterns are compatible, they are combined and re-simulated as before, then another fault is picked. If the patterns are not compatible and the decision is made to try again, another non-blocked fault is picked and the process is started over again. This try again condition, in practice, uses an iteration counter that aborts after too many unsuccessful attempts to add another fault to the current pattern.
In accordance with features of the invention, a stop condition is based on either overall test coverage or on test coverage per pattern.
In accordance with features of the invention, instead of selecting a random fault in the design to target at each iteration, a fault is picked that is compatible with the pattern that has already been generated. In this way, the chosen fault will not create a pattern that is definitely incompatible with the current pattern under evaluation.
The present invention together with the above and other objects and advantages may best be understood from the following detailed description of the preferred embodiments of the invention illustrated in the drawings, wherein:
In the following detailed description of embodiments of the invention, reference is made to the accompanying drawings, which illustrate example embodiments by which the invention may be practiced. It is to be understood that other embodiments may be utilized and structural changes may be made without departing from the scope of the invention.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
In accordance with features of the invention, a method and circuit for implementing enhanced diagnostics with intelligent pattern combination in automatic test pattern generation (ATPG), and a design structure on which the subject circuit resides are provided.
Having reference now to the drawings, in
Computer test system 100 together with circuit 200 implements intelligent pattern combination in ATPG. As shown in
Computer test system 100 is shown in simplified form sufficient for understanding the present invention. The illustrated computer test system 100 is not intended to imply architectural or functional limitations. The present invention can be used with various hardware implementations and systems and various other internal hardware devices, for example, multiple main processors.
In accordance with features of the invention, a fault is picked that is compatible with the pattern that has already been generated. In this way, the chosen fault will not create a pattern that is definitely incompatible with the current pattern under evaluation.
Referring now to
As indicated at a decision block 412, checking for contradiction is performed. In a case where a contradiction occurs, that is, where targeting the fault in question may not be fully possible with the current pattern, as values at the current control or observe points may change. If the patterns are compatible, the patterns are combined and re-simulated as before in block 414, then another fault is picked that is controllable by this new combined pattern at block 408.
As indicated at a decision block 416, checking for a try again condition is performed. When the decision is made to try again, another non-blocked fault is picked and the process is started over again. The try again condition, in practice, includes an iteration counter that aborts after too many unsuccessful attempts to add another fault to the current pattern.
As indicated at a decision block 418, checking for a stop condition is performed. The stop condition is the same stop condition as in the prior art process of
Referring now to
A sequence of program instructions or a logical assembly of one or more interrelated modules defined by the recorded program means 504, 506, 508, and 510, direct the computer system 500 for implementing enhanced diagnostics with intelligent pattern combination in ATPG of the preferred embodiments.
Design process 604 may include using a variety of inputs; for example, inputs from library elements 608 which may house a set of commonly used elements, circuits, and devices, including models, layouts, and symbolic representations, for a given manufacturing technology, such as different technology nodes, 32 nm, 45 nm, 60 nm, and the like, design specifications 610, characterization data 612, verification data 614, design rules 616, and test data files 618, which may include test patterns and other testing information. Design process 604 may further include, for example, standard circuit design processes such as timing analysis, verification, design rule checking, place and route operations, and the like. One of ordinary skill in the art of integrated circuit design can appreciate the extent of possible electronic design automation tools and applications used in design process 604 without deviating from the scope and spirit of the invention. The design structure of the invention is not limited to any specific design flow.
Design process 604 preferably translates an embodiment of the invention as shown in
While the present invention has been described with reference to the details of the embodiments of the invention shown in the drawing, these details are not intended to limit the scope of the invention as claimed in the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
6804803 | Barnhart | Oct 2004 | B2 |
10024910 | Kusko | Jul 2018 | B2 |
20020147559 | Barnhart | Oct 2002 | A1 |
20050240887 | Rajski | Oct 2005 | A1 |
20060041808 | Yamamura | Feb 2006 | A1 |
20060066338 | Rajski et al. | Mar 2006 | A1 |
20070168816 | Hiraide et al. | Jul 2007 | A1 |
20150135030 | Zou et al. | May 2015 | A1 |
Number | Date | Country |
---|---|---|
1475644 | Nov 2004 | EP |
WO2004107402 | Dec 2004 | WO |
WO2008013340 | Jan 2008 | WO |
Entry |
---|
Parthasarathy G, et al; “Combining ATPG and symbolic simulation for efficient validation of embedded array systems.” Proceedings. International 2002 (pp. 203-212). IEEE. |
Machouat A, et al;“Scan-based ATPG diagnostic and optical techniques combination: A new approach to improve accuracy of defect isolation in functional logic failure”2008 IEEE. |
Number | Date | Country | |
---|---|---|---|
20180267102 A1 | Sep 2018 | US |