Field of the Invention
The present invention relates generally to the use of a non-volatile storage device, such as an electrically erasable programmable read only memory device (“EEPROM”), to store information regarding the location of failed parts on a multi-chip module such as a memory module. More particularly, the present invention relates to storing, in an on-module EEPROM, the identities of module output terminals, such as data query (“DQ”) terminals which, during testing of the module, have been determined to fail and are thus indicative of the locations of corresponding failed components.
State of the Art
Recent computer memory modules include a non-volatile storage device, such as an electrically erasable programmable read only memory device (“EEPROM”), an erasable programmable read only memory device (“EPROM”), a ferro-electronic device or a flash memory chip, on the memory module with other volatile storage devices such as random access memory (“RAM”), synchronous dynamic random access memory (“SDRAM”) and dynamic random access memory (“DRAM”). Volatile storage devices are those memory devices in which information stored in a memory cell in the device is completely lost when the power supply voltage applied to the memory cell is interrupted or turned off. In contrast, information stored in the cells of non-volatile storage devices is preserved when the power supply is turned off. A non-volatile storage device on a memory module is conventionally used to store valuable configuration information necessary for the processor to access the memory on the module. The configuration information stored on the non-volatile storage device includes such parameters as the latency and speed of the module components and the size and type of memory module, and is accessed by the processor during initialization of the system. The memory of the EEPROM is divided into sections, each section storing a different category of information.
Typically, however, the capacity of the EEPROM, or other long-term memory storage device, is greater than the memory requirements for the configuration information that needs to be stored. The industry has established a standard of a minimum of 128 bytes as the volume of configuration data to be stored on the non-volatile storage device. Therefore, any EEPROM memory (in excess of 128 bytes) remaining unused may be used to store additional information that is not material to the functionality of the module. The memory capacity of an EEPROM in excess of 128 bytes varies by the capacity of the EEPROM used.
U.S. Pat. No. 5,996,096 to Dell et al. (Nov. 30, 1999), the disclosure of which is hereby incorporated herein by reference, discloses using the excess memory capacity of an EPROM mounted on a memory module to store a map of the bad memory addresses of “reduced specification DRAM chips” (e.g., chips with nonfunctional memory addresses or partially defective DRAM chips) for use during operation of the memory module. According to the invention of Dell et al., each of a plurality of memory chips or dice is coded and marked with a unique identifier and tested in accordance with conventional testing methods.
Memory Corporation of the United Kingdom sells a dual-in-line memory module built with a number of partially defective SDRAM dice. The synchronous dynamic random access memory dice (“SDRAM”) used on the dual in-line memory module (“DIMM”) are selected to ensure that the total number of defects is within the mapping capabilities of the ASIC. A map of the defective locations is stored in a serial EEPROM mounted on the DIMM. The mapping data is loaded into the ASIC at power-up together with the configuration information to redirect the data for defective DRAM addresses to an alternate storage device.
U.S. Pat. No. 5,963,463 to Rondeau, II et al. (Oct. 5, 1999), the disclosure of which is hereby incorporated herein by reference, also discloses an example of a memory module and method employing an EEPROM. According to the method of Rondeau, II et al., an EEPROM is programmed with module information after completion of the memory module assembly.
Memory chip manufactures conventionally employ chip-testing systems to individually test each memory chip. These systems test the operability of each memory chip by writing a value into each memory cell within the chip and then reading the contents of that cell. An example of an individual chip testing system is described in U.S. Pat. No. 5,991,215 to Brunelle (Nov. 23, 1999), the disclosure of which is hereby incorporated herein by reference.
The DRAM dice of memory modules are tested subsequent to connection to the memory module's printed circuit board (“PCB”) in addition to testing the individual DRAM dice prior to connection because failures may be caused by connection of the dice to the PCB or by the combination of the particular module components. After module testing, the memory modules are reworked, repaired, scrapped, stripped, repinned, rebuilt onto a module, depopulated or “depopped” (memory chips are removed from a module to re-run through chip testing) or sold as a depop product as is well known to one of ordinary skill in the art. Presently, memory modules are tested one module at a time in a wide range of tests to evaluate such things as speed, margin, voltage ranges, output and input levels, data patterns, functionality and connectivity of printed circuits, as well as being performance tested by operation in personal computers produced by various manufacturers, etc. To identify which specific DRAMs on a module fail one or more in a series of memory tests, the operator must either closely watch the tester monitor and record the location of a failing DRAM on a display map while the tester is testing the next module, or retest a module identified as having a failed DRAM. Because performance requirements for memory modules are constantly increasing, module testing processes are likewise becoming more complex and, consequently, longer and more expensive. Understandably, the cost of equipment to perform these more complex tests is also increasing. Present module testers may cost anywhere from $1.2-3 million each. Including module handlers, a module tester system may cost anywhere from $1.7-3.5 million.
To help reduce overall cost in these more expensive testers, module tester designers have added the ability to test multiple memory modules in parallel rather than one at a time. Examples of such memory module testers are manufactured by Advantest America of Santa Clara, Calif., and Teradyne of Boston, Mass. Module testers that can test up to 16 modules at a time are presently in development, though this number and the cost of equipment for testing modules will certainly continue to increase as performance requirements increase.
To illustrate how the testing process may affect the cost of a memory module, consider the following example. A process which could test 16 memory modules in parallel through a five-minute test would produce 192 modules per hour. Assuming a 25% failure rate, which is not atypical, there would be 48 of the 192 memory modules tested that fail the test process. However, when testing 16 modules at a time in parallel, identifying and marking failures by watching a test monitor during testing is no longer feasible. The modules identified as failed are therefore retested, one at a time, to identify which parts failed for each module. Due to parallelism, the time it takes to test one module or 16 modules is the same (5 minutes). Therefore, it would take a minimum of 4 hours (48 modules×5 min./module) to find the defects on the 48 failing modules.
The depreciation cost alone on a $1.7 million module tester system is roughly $39 per hour. Thus, the initial module test cost resulting from the equipment alone is $0.20 per module. Contrarily, the cost to retest the 48 failures discovered during the initial test is $3.25 per module, a significant increase over the initial test cost. This results in an average module testing cost before rework of $1.02 per module, five times more expensive than without the retesting. It is thus desirable to have a method of testing memory modules that avoids the costly retesting of the memory modules.
The present invention addresses the problem of how to avoid the conventional, costly step of retesting memory modules identified as failing during the initial testing of the module by storing the identity of failed module components in a non-volatile memory device such as an EEPROM. Failed module components include such elements as data query (“DQ”) terminals and memory bits that require memory mapping of bad addresses. A plurality of memory dice may be placed on a memory module with other module components and the module then tested to identify any failed outputs. The locations of failed component parts, such as memory dice, are determinable from the failed output identifiers that are stored during testing in a non-volatile storage device for access after the testing process. By storing the failed output identities on the memory module itself, locations of specific defective parts may be easily identified and immediately repaired or replaced without the requirement of an additional memory module test, or a requirement of maintaining an association between a particular memory module and its test data. Other module or die information may also be stored on the memory module, such as lot identification numbers or other production information, for access at a later time.
The nature of the present invention as well as other embodiments of the present invention may be more clearly understood by reference to the following detailed description of the invention, to the appended claims, and to the several drawings herein, wherein:
According to an embodiment of the present invention, a plurality of DRAM dice or chips that have previously been individually tested and determined to be fully functional, or at least functional to an extent usable within a particular application, such as a partially good die is included on the DIMM 32. Additionally, more stringent tests may be performed prior to affixation of a given die to a module to establish that a die is also a “known good die” (“KGD”). The functional DRAMs 38, 40, 42, 44, 46, 48, 50 and 52 are then attached, by wire bonding, TAB bonding, flip-chip bonding or other method known in the art, to bond pads (not shown) on the PCB 34 to form the DIMM 32. The DIMM 32 is tested using conventional equipment known in the art such as that previously referenced herein. The identities of any outputs, such as data query (“DQ”) terminals, which fail any of the tests in a testing process are detected and recorded in the excess memory of the EEPROM through programming. The identities of the failed outputs may be recorded either immediately as each fails a test, or at some point subsequent to the test failure, such as at the completion of all tests involving a particular part or at completion of the module test process.
Upon completion of the module test process, unlike prior test methods, if a module is identified as having a failed output, rather than retesting the module to identify the specific module part which failed the test, the portion of the EEPROM storing the identities of the failed outputs may be accessed using methods known in the art to identify which DRAM, or other module component, needs to be replaced. In this way, the costly retesting step for identifying defective parts on failed modules is unnecessary.
One particular advantage of the present invention is that it may be implemented without costly additional equipment. By modifying the test process software to program the identities of failing outputs into unused portions of the memory in an EEPROM, the advantages of the invention may be achieved. Upon completion of the testing process, any modules that failed the test may then be placed in an inexpensive apparatus as known in the art where the EEPROM may be read for the identities or locations of terminals and a failure map displayed. From the identities of the failing terminals, the corresponding failing part may be identified and marked for repair or replacement. After repair or replacement, the memory module may again be tested and the process repeated until none of the module parts fail a test.
It is contemplated that the process of the present invention will be particularly beneficial to identifying failed DRAMs, as the failure rate of DRAMs is relatively high. However, as will be clear to one of ordinary skill in the art, the method and apparatus of the present invention may be applied to any testing process where it would be advantageous to have a data record indicative of failed part locations on-board the memory module. It will be understood by those having skill in the technical field of this invention that the invention is applicable to any multi-chip module including a non-volatile storage device including, for example, and without limitation thereto, DRAMs, SIMMs, DIMMs and Rambus in-line memory modules (“RIMM”).
By using the method and apparatus of the present invention for storing failing part locations in a module, expensive retesting of modules including failed parts may be avoided. Avoiding retesting of failed modules results in a significant cost savings over conventional methods and apparatus requiring such retesting as discussed herein.
Although the present invention has been shown and described with respect to an illustrated embodiment, various additions, deletions and modifications thereto will be apparent to a person of ordinary skill in the art to which the invention pertains and, even if not shown or specifically described herein, are deemed to lie within the scope of the invention as encompassed by the following claims.
Number | Name | Date | Kind |
---|---|---|---|
3714637 | Beausoleil | Jan 1973 | A |
3715735 | Moss | Feb 1973 | A |
3735368 | Beausoleil | May 1973 | A |
3772652 | Hilberg | Nov 1973 | A |
3781826 | Beausoleil | Dec 1973 | A |
3800294 | Lawlor | Mar 1974 | A |
3845476 | Boehm | Oct 1974 | A |
4355376 | Gould | Oct 1982 | A |
4376300 | Tsang | Mar 1983 | A |
4450560 | Conner | May 1984 | A |
4475194 | LaVallee et al. | Oct 1984 | A |
4479214 | Ryan | Oct 1984 | A |
4493075 | Anderson et al. | Jan 1985 | A |
4527251 | Nibby, Jr. et al. | Jul 1985 | A |
4646299 | Schinabeck et al. | Feb 1987 | A |
4807191 | Flannagan | Feb 1989 | A |
4837747 | Dosaka et al. | Jun 1989 | A |
4876685 | Rich | Oct 1989 | A |
4881200 | Urai | Nov 1989 | A |
4908798 | Urai | Mar 1990 | A |
4918662 | Kondo | Apr 1990 | A |
4935899 | Morigami | Jun 1990 | A |
4992984 | Busch et al. | Feb 1991 | A |
5051994 | Bluethman et al. | Sep 1991 | A |
5060197 | Park et al. | Oct 1991 | A |
5124948 | Takizawa et al. | Jun 1992 | A |
5126973 | Gallia et al. | Jun 1992 | A |
5134584 | Boler et al. | Jul 1992 | A |
5200959 | Gross et al. | Apr 1993 | A |
5208775 | Lee | May 1993 | A |
5233614 | Singh | Aug 1993 | A |
5243570 | Saruwatari | Sep 1993 | A |
5251174 | Hwang | Oct 1993 | A |
5268866 | Feng et al. | Dec 1993 | A |
5270974 | Reddy | Dec 1993 | A |
5270976 | Tran | Dec 1993 | A |
5315552 | Yoneda | May 1994 | A |
5327380 | Kersh, III et al. | Jul 1994 | A |
5331188 | Acovic et al. | Jul 1994 | A |
5332922 | Oguchi et al. | Jul 1994 | A |
5337277 | Jang | Aug 1994 | A |
5349556 | Lee | Sep 1994 | A |
5371866 | Cady | Dec 1994 | A |
5379415 | Papenberg et al. | Jan 1995 | A |
5390129 | Rhodes | Feb 1995 | A |
5392247 | Fujita | Feb 1995 | A |
5400263 | Rohrbaugh et al. | Mar 1995 | A |
5400342 | Matsumura et al. | Mar 1995 | A |
5406565 | MacDonald | Apr 1995 | A |
5410545 | Porter et al. | Apr 1995 | A |
5424989 | Hagiwara et al. | Jun 1995 | A |
5434792 | Saka et al. | Jul 1995 | A |
5465234 | Hannai | Nov 1995 | A |
5469390 | Sasaki et al. | Nov 1995 | A |
5475648 | Fujiwara | Dec 1995 | A |
5475695 | Caywood et al. | Dec 1995 | A |
5491664 | Phelan | Feb 1996 | A |
5497381 | O'Donoghue et al. | Mar 1996 | A |
5502333 | Bertin et al. | Mar 1996 | A |
5513135 | Dell et al. | Apr 1996 | A |
5513327 | Farmwald et al. | Apr 1996 | A |
5528553 | Saxena | Jun 1996 | A |
5535328 | Harari et al. | Jul 1996 | A |
5539697 | Kim et al. | Jul 1996 | A |
5544106 | Koike | Aug 1996 | A |
5548553 | Cooper et al. | Aug 1996 | A |
5553231 | Papenberg et al. | Sep 1996 | A |
5576999 | Kim et al. | Nov 1996 | A |
5588115 | Augarten | Dec 1996 | A |
5600258 | Graham et al. | Feb 1997 | A |
5602987 | Harari et al. | Feb 1997 | A |
5631868 | Termullo, Jr. et al. | May 1997 | A |
5633826 | Tsukada | May 1997 | A |
5636173 | Schaefer | Jun 1997 | A |
5654204 | Anderson | Aug 1997 | A |
5668763 | Fujioka et al. | Sep 1997 | A |
5717694 | Ohsawa | Feb 1998 | A |
5734621 | Ito | Mar 1998 | A |
5745673 | Di Zenzo et al. | Apr 1998 | A |
5754753 | Smelser | May 1998 | A |
5758056 | Barr | May 1998 | A |
5768173 | Seo et al. | Jun 1998 | A |
5798962 | Di Zenzo et al. | Aug 1998 | A |
5841710 | Larsen | Nov 1998 | A |
5862314 | Jeddeloh | Jan 1999 | A |
5896346 | Dell et al. | Apr 1999 | A |
5913020 | Rohwer | Jun 1999 | A |
5920512 | Larsen | Jul 1999 | A |
5920513 | Jacobson | Jul 1999 | A |
5956233 | Yew et al. | Sep 1999 | A |
5963463 | Rondeau, II et al. | Oct 1999 | A |
5966724 | Ryan | Oct 1999 | A |
5970008 | Zagar et al. | Oct 1999 | A |
5974564 | Jeddeloh | Oct 1999 | A |
5991215 | Brunelle | Nov 1999 | A |
5995409 | Holland | Nov 1999 | A |
5996096 | Dell et al. | Nov 1999 | A |
6009536 | Rohwer | Dec 1999 | A |
6035432 | Jeddeloh | Mar 2000 | A |
6058055 | Brunelle | May 2000 | A |
6115828 | Tsutsumi et al. | Sep 2000 | A |
6130442 | Di Zenzo et al. | Oct 2000 | A |
6141768 | Lin et al. | Oct 2000 | A |
6256756 | Faulk, Jr. | Jul 2001 | B1 |
6274395 | Weber | Aug 2001 | B1 |
6330693 | Lindsay | Dec 2001 | B1 |
6341090 | Hiraki et al. | Jan 2002 | B1 |
6345367 | Sinclair | Feb 2002 | B1 |
6418066 | Hidaka | Jul 2002 | B1 |
6438029 | Hiraki et al. | Aug 2002 | B2 |
6467054 | Lenny | Oct 2002 | B1 |
6467056 | Satou et al. | Oct 2002 | B1 |
6477672 | Satoh | Nov 2002 | B1 |
6567941 | Turnquist et al. | May 2003 | B1 |
6651202 | Phan | Nov 2003 | B1 |
6873555 | Hiraki et al. | Mar 2005 | B2 |