Generally, system on a chip (SOC) devices do not have bar codes or other physical attributes for unique identification. For testing groups of devices, a tester may allow the input of unique device identifiers (IDs) for each one of the individual results. For example, an automatic numbering system may be used during the testing devices within a lot. The system may assign a device ID of 1 to the first device in the lot. The subsequent device may be assigned a device ID of 2 by the system. Each subsequent device may be assigned a device ID of a predefined incremental value, such as 3 to N, in which N is the total number of tested devices.
A problem may occur in the middle of testing a group of devices. For example, a connection problem may occur on the tester. It may not be desirable to return to the first device and then test the entire lot of devices. The user may decide to start testing from a point of occurrence for the problem or from a point just prior to the occurrence of the problem. However, the user may also desire to have the results for the entire lot of devices reported in a single file. Also, the user may want to have the results of a second test procedure for the group (or partial group) correlate to the results of a first test procedure for the group (or partial group).
In an embodiment, there is provided a system for coordinating test results for devices within a group, the system comprising code to assign identifiers to test results of a first test execution, each one of the identifiers corresponding to one of the devices; code to receive a user-specified one of the identifiers as a beginning point for performing a second test execution on a portion of the devices; and code to assign identifiers to test results of the second test execution, each one of the identifiers corresponding to one of the portion of the devices, wherein test results for corresponding devices in the first test execution and the second test execution are assigned like ones of the identifiers.
In another embodiment, there is provided a method of coordinating test results for devices within a group, the method comprising assigning identifiers to test results of a first test execution, each one of the identifiers corresponding to one of the devices; receiving a user-specified one of the identifiers as a beginning point for performing a second test execution on a portion of the devices; and assigning identifiers to test results of the second test execution, each one of the identifiers corresponding to one of the portion of the devices, wherein test results for corresponding devices in the first test execution and the second test execution are assigned like ones of the identifiers.
Other embodiments are also disclosed.
Illustrative embodiments of the invention are illustrated in the drawings, in which:
Referring to
Typically, a test system will automatically number the devices from 1 to N when a user tests the lot of devices for the first time. For a retest of a portion of the devices in the lot, the system generally starts over to number the devices being tested from 1 to N. As shown in
In an embodiment, a user indicates to the system a starting point for assigning device identifiers, such as integers or other ID numbers. Referring to
Referring still to
It should be appreciated that a user may save a significant amount of time by only retesting part of a group. Furthermore, all test results for multiple test executions on a particular group of devices may be correlated and combined.
For example, the embodiments disclosed herein for systems and methods of testing devices may include, but are not limited to, testing a wafer 300 providing a group of N devices 305 (
In an embodiment, there is provided a system 700 for coordinating test results for devices within a group. System 700 may include code 705 for performing a first test execution on devices. System 700 may also include code 710 for assigning identifiers to test results of the first test execution, each one of the identifiers corresponding to one of the devices. System 700 may further include code 715 for allowing a user to specify one of the identifiers as a beginning point for performing a second test execution on a portion of the devices. System 700 may include code 720 for performing the second test execution starting at the one of the devices corresponding to the one of the identifiers specified as the beginning point. System 700 may include code 725 for assigning identifiers to test results of the second test execution, each one of the identifiers corresponding to one of the portion of the devices, wherein each one of the devices is assigned an identical identifier for the test results of the first test execution and for the test results of the second test execution.
As shown in table 800 of
Looking still at
Looking again at
Referring to
In one embodiment, code 705 for performing the first test execution on the devices, and the code 720 for performing the second test execution starting at the one of the devices corresponding to the one of the identifiers specified as the beginning point, may execute tests on the devices using automatic test equipment. The automatic test equipment may include, but is not limited to, an Agilent system or a Teradyne system.
In another embodiment, code 705 for performing the first test execution on the devices is executed on a first set of automatic test equipment, and code 720 for performing the second test execution on the devices is executed on a second set of automatic test equipment. In one embodiment, the first set of automatic test equipment and the second set of automatic test equipment may have distinct formats from one another. For example, and in an embodiment, an Agilent system may be either the first set of automatic test equipment or the second set of equipment. A Teradyne system may be the other set of automatic test equipment.
In an embodiment, code 710 for the assigning identifiers to the test results of the first execution assigns an integer to each one of the devices, starting the integer assignment at one, and increments the integer assignment by one for each subsequent assignment. In another embodiment, code 710 for assigning identifiers to the test results of the first test execution and the code 725 for assigning the identifiers to the second test execution includes assigns integers to the test results corresponding to the devices. Generally, code 710/725 for assigning integers to the test results corresponding to the devices increments the integers by one for each of the devices successively tested.
Alternatively, code 710/725 for assigning integers to the test results corresponding to the devices may increment the integers by a given multiple for each of the devices successively tested. For example, a given multiple of ten may be used such that the identifiers are assigned as 10, 20, 30, 40, and so on.
In another embodiment, each of the devices may be assigned a non-integer identifier. For example, the non-integer identifier may include alphanumeric identifiers such as abc1, abc2, abc3 . . . abcN.
In one embodiment, code 735 may optionally be provided for specifying one of the identifiers as an ending point for performing the second test execution on the portion of the devices.
For example, and as shown in table 900 of
Looking still at
Looking again to
As discussed hereinabove, code 705 and code 710 may perform test executions on groups of devices. For example, code 705 may be provided for performing the first test execution and code 720 may be provided for performing the second test execution on devices contained on a wafer. Code 705 may be provided for performing the first test execution and code 715 may be provided for performing the second test execution on devices contained within a lot. Code 705 may be provided for performing the first test execution and code 720 may be provided for performing the second test execution on devices contained on a plurality of wafers within the lot.
Code 705 may be provided for performing the first test execution and code 720 may be provided for performing the second test execution on devices contained on a plurality of wafers contained on a cassette. Code 705 may be provided for performing the first test execution and code 720 may be provided for performing the second test execution on devices on a plurality of wafers on a plurality of cassettes contained in a magazine.
Code 705 may be provided for performing the first test execution and code 720 may be provided for performing the second test execution on devices having no identifying indicia thereon. For example, devices used in research and development projects often possess no identifying indicia.
In an embodiment, code 710/725 for assigning the identifiers to the test results of the first test execution may create identifiers corresponding to physical indicia which may be present on the devices. Code 705/720 for performing the first test execution and performing the second test execution may be carried out by automatic test equipment unequipped to read physical indicia which may be present on the devices.
Referring to
Looking now at
Optionally, the performing 1005 the first test execution and the performing 1020 the second test execution may each be carried out by automatic test equipment. For example, performing 1005 the first test execution and performing 1020 the second test execution may each be carried out by an Agilent system or a Teradyne system.
The performing 1005 the first test execution may be carried out by a first set of automatic test equipment and the performing 1020 the second test execution may be carried out by a second set of automatic test equipment. The first set of automatic test equipment and the second set of automatic test equipment may have distinct formats from one another. For example, either the first set of automatic test equipment or the second set of equipment may be an Agilent system. The other set of automatic test equipment may be a Teradyne system or another system not manufactured by Agilent. In another embodiment, both sets of automatic test equipment may be systems other than those manufactured by Agilent.
In another embodiment, method 1000 may optionally include the step of merging 1030 the test results of the first test execution and the test results of the second test execution into a single output file. The merging 1030 the test results of the first test execution and the test results of the second test execution into the single output file may create an STDF file, an ASCII file, an XML file, or an EDL file.
The assigning 1010 identifiers to the test results of the first execution may optionally include assigning 1035 an integer to each one of the devices, starting 1040 the integer assignment at one, and incrementing 1045 the integer assignment by one for each subsequent assignment.
The assigning 1010 the identifiers to the test results of the first test execution and assigning 1025 the identifiers to the test results of the second test execution may include assigning integers to the test results corresponding to the devices. Assigning 1035 the integers to the test results corresponding to the devices may include incrementing the integers by one for each of the devices successively tested.
In an embodiment, method 1000 may optionally include the step of specifying 1050 one of the identifiers as an ending point for performing the second test execution on the portion of the devices.
In an embodiment, the performing 1005 the first test execution and the performing 1020 the second test execution may each test the devices contained on a wafer. In another embodiment, the performing 1005 the first test execution and the performing 1020 the second test execution each may each test the devices contained within a lot. In one embodiment, the performing 1005 the first test execution and the performing 1020 the second test execution may test the devices contained on a plurality of wafers within the lot. In an embodiment, the performing 1005 the first test execution and performing 1020 the second test execution may each test the devices contained on a plurality of wafers contained on a cassette. In another embodiment, the performing 1005 the first test execution and performing 1020 the second test execution may each test the devices on a plurality of wafers on a plurality of cassettes contained in a magazine.
In one embodiment, the performing 1005 the first test execution and the performing 1020 the second test execution may each test the devices having no identifying indicia thereon. In another embodiment, the assigning 1005 the identifiers to the test results of the first test execution may create identifiers corresponding to physical indicia on the devices.
For some test situations, the performing 1005 the first test execution and performing 1020 the second test execution may be carried out by automatic test equipment unequipped to read physical indicia which may be present on the devices. For example, the specifying 1015 one of the identifiers the beginning point may be based on physical indicia which may be present on the devices and these physical indicia may be unreadable by automatic test equipment performing 1020 the second test execution.
In an embodiment, method 1000 may optionally include specifying 1055 one of the identifiers as a beginning point for performing a third test execution on a portion of the devices. Method 1000 may optionally include a step of performing 1060 the third test execution starting at the one of the devices corresponding to the one of the identifiers specified as the beginning point. Method 1000 may also optionally include assigning 1065 identifiers to test results of the third test execution. Generally, each one of the identifiers corresponds to one of the devices. Each device is assigned an identical identifier for the test results of the first test execution, the second test execution, and the third test execution.