US20070162792A1 - Method for increasing the manufacturing yield of programmable logic devices - Google Patents
Method for increasing the manufacturing yield of programmable logic devices Download PDFInfo
- Publication number
- US20070162792A1 US20070162792A1 US11/275,536 US27553606A US2007162792A1 US 20070162792 A1 US20070162792 A1 US 20070162792A1 US 27553606 A US27553606 A US 27553606A US 2007162792 A1 US2007162792 A1 US 2007162792A1
- Authority
- US
- United States
- Prior art keywords
- section
- pld
- fpga
- functional
- sections
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 43
- 238000004519 manufacturing process Methods 0.000 title claims abstract description 16
- 230000007547 defect Effects 0.000 claims abstract description 39
- 238000012360 testing method Methods 0.000 claims description 22
- 230000002950 deficient Effects 0.000 claims description 20
- 238000011990 functional testing Methods 0.000 claims description 4
- 230000001419 dependent effect Effects 0.000 claims description 2
- 238000003491 array Methods 0.000 abstract description 6
- 238000013461 design Methods 0.000 description 11
- 238000013459 approach Methods 0.000 description 6
- 229910000679 solder Inorganic materials 0.000 description 6
- 238000012986 modification Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 239000004065 semiconductor Substances 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 230000002411 adverse Effects 0.000 description 1
- 230000007423 decrease Effects 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000000638 solvent extraction Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01R—MEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
- G01R31/00—Arrangements for testing electric properties; Arrangements for locating electric faults; Arrangements for electrical testing characterised by what is being tested not provided for elsewhere
- G01R31/28—Testing of electronic circuits, e.g. by signal tracer
- G01R31/317—Testing of digital circuits
- G01R31/31718—Logistic aspects, e.g. binning, selection, sorting of devices under test, tester/handler interaction networks, Test management software, e.g. software for test statistics or test evaluation, yield analysis
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K19/00—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
- H03K19/02—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
- H03K19/173—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
- H03K19/177—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
- H03K19/17748—Structural details of configuration resources
- H03K19/17764—Structural details of configuration resources for reliability
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K19/00—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits
- H03K19/02—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components
- H03K19/173—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components
- H03K19/177—Logic circuits, i.e. having at least two inputs acting on one output; Inverting circuits using specified components using elementary logic circuits as components arranged in matrix form
- H03K19/1778—Structural details for adapting physical parameters
- H03K19/17796—Structural details for adapting physical parameters for physical disposition of blocks
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C17/00—Read-only memories programmable only once; Semi-permanent stores, e.g. manually-replaceable information cards
- G11C17/14—Read-only memories programmable only once; Semi-permanent stores, e.g. manually-replaceable information cards in which contents are determined by selectively establishing, breaking or modifying connecting links by permanently altering the state of coupling elements, e.g. PROM
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/70—Masking faults in memories by using spares or by reconfiguring
- G11C29/88—Masking faults in memories by using spares or by reconfiguring with partially good memories
Definitions
- the present invention relates to the manufacture of field programmable gate arrays, and other programmable logic devices. Specifically, a process is described which increases the manufacturing yield of semiconductor field programmable gate arrays.
- FPGAs field programmable gate arrays
- PLDs programmable logic devices
- the size of an FPGA or other PLD is determined by the manufacturing process. Manufacturing processes often have a very low yield, wherein only a small percentage of the manufactured FPGAs are good. The low yield increases the manufactured price for the FPGAs or other PLDs. The reason for such low yields is that devices must be defect-free to be fully functional. That is, if a single defect in one of the devices of the array occurs, the array itself is considered to be defective.
- a method and field programmable gate array (FPGA) or other programmable logic device (PLD) which will increase manufacturing yield for FPGAs or other PLDs.
- the invention relies upon a strategy for manufacturing FPGAs or other PLDs in sections, where each section may have its own power bus, input/output (I/O) bus and configuration bus. If defects can be isolated to a particular section of the FPGAs or other PLDs, the remaining sections can be used standalone, or otherwise configured to be a usable circuit. Partially good FPGAs or other PLDs can be sorted and assigned a unique FPGA product identification number. Partially good FPGAs or other PLDs may then be sold with software which only configures the section of the FPGA or other PLD which does not contain defects or has an acceptable number of defects.
- One embodiment of the invention is a method for increasing the manufacturing yield of a programmable logic device (PLD) integrated circuit comprising: configuring the FPGA or other PLD in a first section and a second section, each section having independent power and input/output (I/O) connections; testing the FPGA or other PLD in the first section and the second section to identify defects and characterize each section as at least one of a functional section and a non-functional section; sorting the FPGA or other PLD in accordance with the functional and non-functional test results; and assigning a code to the FPGA or other PLD corresponding to the functional and non-functional test results.
- PLD programmable logic device
- Another embodiment of the invention is a method for increasing the manufacturing yield of a field programmable logic array (FPGA) or other programmable logic device (PLD) comprising: dividing said FPGA into sections, each section having separate power busses and I/O busses; testing each section of the FPGA to determine if one or more sections have an unacceptable level of defects; and when one of the sections has an unacceptable level of defects, bonding external connections to said power bus and I/O bus of only the one or more sections that have an acceptable level of defects.
- FPGA field programmable logic array
- PLD programmable logic device
- Yet another embodiment of the invention is a method for increasing the manufacturing yield of a field programmable gate arrays (FPGA) or other programmable logic device (PLD) with a configuration port when the second section is defective; and configuring the second section with a configuration port when the first section is defective.
- FPGA field programmable gate arrays
- PLD programmable logic device
- Yet another embodiment of the invention is a method for improving the usability of a field programmable logic array (FPGA) or other programmable logic device (PLD) by constructing the FPGA or other PLD in such a manner that connections to external circuitry for a given orientation are the same as when the FPGA or other PLD is rotated 180° or smaller increments, wherein the increments are dependent on hardware implementation requirements.
- FPGA field programmable logic array
- PLD programmable logic device
- a software technique as well as a hardware technique can be provided to sort the tested FPGAs or other PLDs.
- a partial reconfiguration software package is provided so that only the region of the FPGA or other PLD that have no defects or that have an acceptable number of defects is programmed.
- power and I/O connections can be changed so that the configuration bit stream, power, and I/O connections are confined to the region containing no defects. Fuses may be used to route the bit stream and I/O connections so that only the partially good region is available for use.
- FIG. 1 illustrates the decision flow for testing and binning or sorting partially good FPGAs or PLDs
- FIG. 2 illustrates the partitioning of an FPGA or PLD into regions, so that defective regions may be identified and sections that are available for use may be implemented;
- FIG. 3 shows an example where the FPGA or PLD array is not divided into regions
- FIG. 4 shows how power and I/O connections are modified in a hardware solution for using partially good FPGAs or PLDs
- FIG. 5 shows the hardware connections when the full chip is found to be usable
- FIG. 6 shows how a partially good FPGA or PLD can be implemented with appropriate hardware connections
- FIG. 7 shows an approach for isolating regions which are functional from regions that are defective in an FPGA or PLD, using programmable or fusable links to direct signals to the functional region of the circuitry;
- FIG. 8 shows another approach for an implementation of using partially good FPGAs
- FIG. 9 shows the configuration connections of a device having two configuration inputs for each half of an FPGA or PLD, and the concept of positioning connection points for configuration of other signals appropriately such that these connections point to outside circuitry and remain constant when rotating the FPGA or PLD array 180°;
- FIG. 10 shows an alternate configuration input that is implemented by rotating the FPGA 180° and/or using fused connections to good/functional sections of the FPGA or PLD;
- FIG. 11 illustrates an exemplary hardware approach to flip-chip power or I/O connections in FPGAs or PLDs
- FIG. 12 illustrates an exemplary hardware approach to flip-chip power or I/O connections in FPGAs or PLDs with an east vs. west configuration
- FIG. 13 illustrates an example of an FPGA or PLD configuration where the west half of the FPGA or PLD has been determined to be defective and the east half is functional.
- FIG. 1 illustrates an exemplary test decision flow diagram for implementing a partially good FPGA or PLD system of production.
- the FPGA or PLD is placed in a test fixture in step 10 where each of the circuit elements comprising the FPGAs or PLDs is tested.
- the FPGA or PLD rows of logic elements are arranged in columns and rows.
- a configured logic element may comprise a flip-flop, multiplexer, etc. that is configured from a data file created by circuit designers.
- the FPGA or PLD is tested and it is determined whether it is 100% good in step 11 , partially good in step 16 or insufficiently good in step 13 .
- the number of bins is scalable, depending on the desired number of subsection or regions of the FPGA or PLD that are available for use in a partially good strategy, potentially including unique software versions which would accompany each binned FPGA or PLD so that it could be programmed to operate only in regions containing circuit element which are all functional.
- step 11 When the FPGA or PLD tests in step 11 are 100% good, meaning that all logic elements are functional, they are shipped in step 12 with appropriate configuration software for configuring the entire FPGA or PLD in accordance with a desired circuit design. In the event that the FPGA or PLD does not contain any one region that has passed the test, as determined in step 13 , these devices are identified as defective and scrapped as unusable in step 14 .
- Step 16 illustrates a partially good strategy wherein one or more regions of an FPGA or PLD have tested well with all its respective components operable.
- the test verifies access to all the components by the configuration bus, the integrity of the power supply bus and input/output (I/O) connections for the tested region of the FPGA or PLD.
- Those sections of the partially good FPGA or PLD that pass the required tests are identified in step 17 .
- These partially good FPGAs or PLDs are then assigned to bins, based on their test data.
- a program code is assigned in step 19 to the partially good FPGA or PLD in accordance with their assigned bin(s). The assigned unique bin codes are used by the configuration software to identify and configure the partially good sections of the FPGA or PLD.
- FIG. 2 The concept of defining regions of a FPGA or PLD for partially good implementation is illustrated in FIG. 2 .
- the array is divided into an east 24 and west 25 half of the FPGA 22 array. While the tests of the entire array may illustrate one or more defects in the west array 25 , the east array 24 may pass the test.
- the FPGA or PLD is assigned a bin number which is used by the supplied configuration software to program the east half 24 of the FPGA 22 . Shown generally are the peripheral input/output connections 23 and power bus connections which are used to configure one or the other or both halves of a FPGA 22 .
- the FPGA or PLD can be sectioned along other dimensions as long as input/output, and power bus connections can be maintained to the individual sections, or alternate connections can be defined using steering logic, fuses, or other means. Test strategies may be developed for parallel testing of a different section of the FPGA or PLD to facilitate their implementation.
- the advantage of the foregoing software method of configuring partially good FPGAs or PLDs is the avoidance of any hardware modification by the FPGA or PLD developer (and in certain cases, the customer as well).
- Non-functional areas are identified and in the simplest partially good implementation, can be treated as though they are a pre-existing configuration by the FPGA or PLD configuration software based on the assigned bin programming code. Localized circuitry or routing defects, specific input/output or long route defects may be tolerable in this process since they are confined to a specific region.
- FIG. 3 the conceptual FPGA 22 layout is shown wherein an array of circuit components is accessed by a clock or signal pads 26 , 27 and power or input/output pads 31 , 33 .
- the clock pad 27 , power or I/O pad 33 and I/O pads 26 , 31 are connected to out board connections of the PLD or FPGA 22 .
- Wire bonds 28 , 29 , 32 and 34 connect respective pads of the FPGA array 25 to the external terminals of the component. Wirebonds are shown here as a representative example. However, other connection methods can also be employed. If there is a failure in one or more components of the FPGA array 25 , the entire chip may be scrapped depending on whether or not it is possible to design around the specific defects.
- FIG. 4 shows how the array can be arranged in east and west halves.
- the FPGA 25 includes an array of components 40 connected to pads 41 - 44 and 46 - 49 .
- FIG. 4 shows simple examples of this concept, where connection 27 in FIG. 3 is split into 42 and 49 in FIG. 4 .
- Other connections in FIG. 3 are similarly split in FIG. 4 .
- This concept can be extended to more complex bus structures. It can also be extended to more complex means/mechanisms for splitting or joining connections using, for example, fuses, programmable steering logic or other well known connecting means. Further, even more complex connecting means can include, but are not limited to, multi-dimensional splitting, division of signals into rotational quadrants or other physical divisions.
- the bonding to the chip may be completed by duplicate bonds.
- Each of the pads 41 - 44 and 46 - 49 has wire bonds. These bonds go to external connections of the FPGA or PLD, or can serve as jumpers between each of the east and west sides of the FPGA 25 which has tested 100% good. Additional connecting means besides wirebonds (e.g., fuses, programmable connections, solder bumps, etc.) can also be employed as mentioned previously.
- FIG. 6 illustrates the circumstance where the west half of the FPGA 25 has been determined to contain a defect.
- the east half is functional and can be programmed to operate in accordance with a specific configuration code without the remaining west half that contains the defect.
- a similar process can be used for cases where the west half of the array is defect-free. This concept can be applied to other more complex partially good subsections as well.
- FIG. 7 illustrates the use of steering logic to control configuration of one or the other halves of a tested FPGA 25 .
- programmable or fusible links 52 or 53 can isolate the configuration and control signals 55 to each of the halves of the FPGA 25 .
- a single configuration bit stream may be generated for either partially good FPGA or PLD sections/regions, since the hardware controls will steer those signals to the “good/functional” half, while avoiding the defective half of the FPGA.
- FIG. 8 illustrates a similar situation, where the FPGA may be organized along vertical configuration and control busses 61 , 60 .
- Programmable fusible links 58 and 59 can be operated when a defect is determined in one-half of the FPGA or PLD to isolate the defective portion from the good/functional portion.
- Other layouts may be utilized to provide a variety of other orientation of the configuration and control busses, corresponding to other more complex methods of dividing the circuitry into partially good regions.
- the foregoing hardware components can be used to steer the bit stream and I/O connections with fusible links. In this way only a good/functional portion of the FPGA or PLD is configured. I/O connections can be formed into subsets, and connected by fuses or bonded out as necessary to only include operable I/O sections.
- bit stream control bits will establish routing paths for configuration bits to the good/functional sections, as well as route I/O signals to operable I/O inputs of the device.
- Separate setup programming bit streams or a variety of other potential implementations are also possible using this concept.
- partially good FPGAs or PLDs does not require redundant elements.
- the method is scalable, in that the granularity of bins versus the number of software versions or hardware complexity is also selectable.
- the partially good FPGAs or PLDs are all identified by a particular assigned program code.
- the assigned program code will be used by the configuration logic to program those sections which are good/functional.
- I/O connections and configuration bit stream connections can be controlled with fuses or programmable steering logic minimizing any changes in software or use considerations by the customer.
- FIGS. 9 and 10 illustrate still another scenario for using a portion of a FPGA or PLD that has tested good.
- Two configuration inputs 63 and 64 are provided so that the alternative configuration port 64 is only used when a defect is found in one-half of the FPGA or PLD.
- FIG. 9 illustrates the use of configuration port 63 , which enables programming of the east half of the array.
- the array is rotated 180°.
- the alternate configuration port 64 is used, programming the west side of the array (which now is rotated to the east side). In this way, the two halves of the FPGA or PLD can appear to be identical even though only one is being used. This concept enables the location of connections from the FPGA or PLD array to outside circuitry to remain constant, by rotating the array.
- FIG. 11 illustrates an exemplary hardware approach to a flip-chip power or I/O connections in FPGAs or PLDs.
- Flip-chip and other semiconductor packaging implementations can be similarly implemented by selectively adding or deleting solder bumps or other chip-to-package connection methods.
- FIG. 11 illustrates an exemplary FPGA 72 layout for an FPGA array 75 wherein an array of circuit components access contiguous power or I/O busses 74 , 78 , 79 , 80 .
- solder bumps or signal pads 76 , 77 and power or input/output solder bumps or pads 71 , 73 connect to these contiguous busses. It should be noted, that using the contiguous bussing of FIG. 11 comes the risk of defects in the FPGA due to shorts/opens in the bus. If there is a failure in one or more components of the FPGA array 75 , the entire chip may be scrapped depending on whether or not it is possible to design around the specific defects.
- FIG. 12 illustrates an alternative exemplary hardware approach to flip-chip power or I/O connections to that shown in FIG. 11 that instead uses an east vs. west configuration.
- Each of the solder bumps or pads 81 - 84 and 86 - 89 are connected to busses that provide symmetric global wiring (e.g., separate east vs. west power busses). This configuration enables full and/or partial chip implementation and provides additional tolerance for potential shorting defects, as discussed above in connection with FIG. 11 .
- FIG. 13 illustrates an example of a circumstance where the west half of the FPGA 75 has been determined to be defective.
- the east half is functional and can be programmed to operate in accordance with a specific configuration code without the remaining half that contains the defect.
- a similar process can be used for cases where the west half of the array is defect-free. This concept can be applied to other more complex partial-good subsections as well.
- solder bumps or other chip-to-package connection methods
- connections to the functional or “good” portions of the circuitry e.g., the east half
- connections to defective subsets of circuitry e.g., the west half
- These connections can be achieved by using unique flip-chip carrier bump patterns for each combination of functional and defective areas of the FPGA or PLD.
- the symmetrical concepts described in this invention can us use to enable a single bump pattern to be used for several functional sections, using symmetrical positions of the chip connections to enable rotating the chip fro connecting to several unique functional sections.
Landscapes
- Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- General Physics & Mathematics (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
- Logic Circuits (AREA)
Abstract
Description
- The present invention relates to the manufacture of field programmable gate arrays, and other programmable logic devices. Specifically, a process is described which increases the manufacturing yield of semiconductor field programmable gate arrays.
- The design of large-scale electronic systems has been facilitated through the use of field programmable gate arrays (FPGAs) and other programmable logic devices (PLDs). These arrays comprise generic logic devices that are configurable under control of configuration software to generate virtually any circuit design. FPGAs and PLDs offer a number of benefits, including relatively short design cycles, reduced costs as well as flexible reprogrammability.
- As is the case with most semiconductor devices, the size of an FPGA or other PLD is determined by the manufacturing process. Manufacturing processes often have a very low yield, wherein only a small percentage of the manufactured FPGAs are good. The low yield increases the manufactured price for the FPGAs or other PLDs. The reason for such low yields is that devices must be defect-free to be fully functional. That is, if a single defect in one of the devices of the array occurs, the array itself is considered to be defective.
- Various techniques have been developed to deal with isolated defects of an FPGA or other PLD. In one example, spare components are made available on the device which can be substituted for failed components. However, there is a penalty in that the device size must increase to accommodate the space required for spare components. This adversely affects yield.
- Software techniques have been developed to design around individual components that have failed. When a failed component is discovered in the FPGA or other PLD during testing, the device may be marked as “in use” to make sure, when programming the FPGA or other PLD, the device is not programmed. Such a technique is shown in U.S. Pat. No. 6,530,071. In accordance with the subject matter of this reference, defect tolerance is addressed at the logic core/application level. In programming FPGAs or other PLDs, a design program is executed which includes executable code that both specifies a circuit design and generates a configuration bit file to implement the circuit design. The design program includes codes that selectively skip the configurable logic elements and resources that contain defects. However, as the number of defects increase, the ability to program the device decreases since more consideration must be given to avoid particular circuit elements that contain defects.
- In accordance with the invention, a method and field programmable gate array (FPGA) or other programmable logic device (PLD) are disclosed which will increase manufacturing yield for FPGAs or other PLDs. The invention relies upon a strategy for manufacturing FPGAs or other PLDs in sections, where each section may have its own power bus, input/output (I/O) bus and configuration bus. If defects can be isolated to a particular section of the FPGAs or other PLDs, the remaining sections can be used standalone, or otherwise configured to be a usable circuit. Partially good FPGAs or other PLDs can be sorted and assigned a unique FPGA product identification number. Partially good FPGAs or other PLDs may then be sold with software which only configures the section of the FPGA or other PLD which does not contain defects or has an acceptable number of defects.
- One embodiment of the invention is a method for increasing the manufacturing yield of a programmable logic device (PLD) integrated circuit comprising: configuring the FPGA or other PLD in a first section and a second section, each section having independent power and input/output (I/O) connections; testing the FPGA or other PLD in the first section and the second section to identify defects and characterize each section as at least one of a functional section and a non-functional section; sorting the FPGA or other PLD in accordance with the functional and non-functional test results; and assigning a code to the FPGA or other PLD corresponding to the functional and non-functional test results.
- Another embodiment of the invention is a method for increasing the manufacturing yield of a field programmable logic array (FPGA) or other programmable logic device (PLD) comprising: dividing said FPGA into sections, each section having separate power busses and I/O busses; testing each section of the FPGA to determine if one or more sections have an unacceptable level of defects; and when one of the sections has an unacceptable level of defects, bonding external connections to said power bus and I/O bus of only the one or more sections that have an acceptable level of defects.
- Yet another embodiment of the invention is a method for increasing the manufacturing yield of a field programmable gate arrays (FPGA) or other programmable logic device (PLD) with a configuration port when the second section is defective; and configuring the second section with a configuration port when the first section is defective.
- Yet another embodiment of the invention is a method for improving the usability of a field programmable logic array (FPGA) or other programmable logic device (PLD) by constructing the FPGA or other PLD in such a manner that connections to external circuitry for a given orientation are the same as when the FPGA or other PLD is rotated 180° or smaller increments, wherein the increments are dependent on hardware implementation requirements.
- Both a software technique as well as a hardware technique can be provided to sort the tested FPGAs or other PLDs. In accordance with the software method for sorting partially defective FPGAs or other PLDs, a partial reconfiguration software package is provided so that only the region of the FPGA or other PLD that have no defects or that have an acceptable number of defects is programmed.
- In accordance with a hardware method, power and I/O connections can be changed so that the configuration bit stream, power, and I/O connections are confined to the region containing no defects. Fuses may be used to route the bit stream and I/O connections so that only the partially good region is available for use.
-
FIG. 1 illustrates the decision flow for testing and binning or sorting partially good FPGAs or PLDs; -
FIG. 2 illustrates the partitioning of an FPGA or PLD into regions, so that defective regions may be identified and sections that are available for use may be implemented; -
FIG. 3 shows an example where the FPGA or PLD array is not divided into regions; -
FIG. 4 shows how power and I/O connections are modified in a hardware solution for using partially good FPGAs or PLDs; -
FIG. 5 shows the hardware connections when the full chip is found to be usable; -
FIG. 6 shows how a partially good FPGA or PLD can be implemented with appropriate hardware connections; -
FIG. 7 shows an approach for isolating regions which are functional from regions that are defective in an FPGA or PLD, using programmable or fusable links to direct signals to the functional region of the circuitry; -
FIG. 8 shows another approach for an implementation of using partially good FPGAs; -
FIG. 9 shows the configuration connections of a device having two configuration inputs for each half of an FPGA or PLD, and the concept of positioning connection points for configuration of other signals appropriately such that these connections point to outside circuitry and remain constant when rotating the FPGA or PLD array 180°; -
FIG. 10 shows an alternate configuration input that is implemented by rotating the FPGA 180° and/or using fused connections to good/functional sections of the FPGA or PLD; -
FIG. 11 illustrates an exemplary hardware approach to flip-chip power or I/O connections in FPGAs or PLDs; -
FIG. 12 illustrates an exemplary hardware approach to flip-chip power or I/O connections in FPGAs or PLDs with an east vs. west configuration; and -
FIG. 13 illustrates an example of an FPGA or PLD configuration where the west half of the FPGA or PLD has been determined to be defective and the east half is functional. -
FIG. 1 illustrates an exemplary test decision flow diagram for implementing a partially good FPGA or PLD system of production. The FPGA or PLD is placed in a test fixture instep 10 where each of the circuit elements comprising the FPGAs or PLDs is tested. In accordance with one exemplary arrangement of an FPGA or PLD, the FPGA or PLD rows of logic elements are arranged in columns and rows. A configured logic element may comprise a flip-flop, multiplexer, etc. that is configured from a data file created by circuit designers. - In accordance with known testing techniques for FPGAs or PLDs, the FPGA or PLD is tested and it is determined whether it is 100% good in
step 11, partially good instep 16 or insufficiently good instep 13. This constitutes a binning or sorting of the manufactured product into the three different bins. The number of bins is scalable, depending on the desired number of subsection or regions of the FPGA or PLD that are available for use in a partially good strategy, potentially including unique software versions which would accompany each binned FPGA or PLD so that it could be programmed to operate only in regions containing circuit element which are all functional. When the FPGA or PLD tests instep 11 are 100% good, meaning that all logic elements are functional, they are shipped instep 12 with appropriate configuration software for configuring the entire FPGA or PLD in accordance with a desired circuit design. In the event that the FPGA or PLD does not contain any one region that has passed the test, as determined instep 13, these devices are identified as defective and scrapped as unusable instep 14. -
Step 16 illustrates a partially good strategy wherein one or more regions of an FPGA or PLD have tested well with all its respective components operable. The test verifies access to all the components by the configuration bus, the integrity of the power supply bus and input/output (I/O) connections for the tested region of the FPGA or PLD. Those sections of the partially good FPGA or PLD that pass the required tests are identified instep 17. These partially good FPGAs or PLDs are then assigned to bins, based on their test data. A program code is assigned instep 19 to the partially good FPGA or PLD in accordance with their assigned bin(s). The assigned unique bin codes are used by the configuration software to identify and configure the partially good sections of the FPGA or PLD. - The concept of defining regions of a FPGA or PLD for partially good implementation is illustrated in
FIG. 2 . InFIG. 2 , the array is divided into an east 24 and west 25 half of theFPGA 22 array. While the tests of the entire array may illustrate one or more defects in thewest array 25, theeast array 24 may pass the test. In accordance with the invention, the FPGA or PLD is assigned a bin number which is used by the supplied configuration software to program theeast half 24 of theFPGA 22. Shown generally are the peripheral input/output connections 23 and power bus connections which are used to configure one or the other or both halves of aFPGA 22. While the foregoing illustrates a vertical sectioning of the FPGA or PLD, it is clear that the FPGA or PLD can be sectioned along other dimensions as long as input/output, and power bus connections can be maintained to the individual sections, or alternate connections can be defined using steering logic, fuses, or other means. Test strategies may be developed for parallel testing of a different section of the FPGA or PLD to facilitate their implementation. - The advantage of the foregoing software method of configuring partially good FPGAs or PLDs is the avoidance of any hardware modification by the FPGA or PLD developer (and in certain cases, the customer as well). Non-functional areas are identified and in the simplest partially good implementation, can be treated as though they are a pre-existing configuration by the FPGA or PLD configuration software based on the assigned bin programming code. Localized circuitry or routing defects, specific input/output or long route defects may be tolerable in this process since they are confined to a specific region.
- The foregoing methodology may also be used in a hardware-oriented design. Referring now to
FIG. 3 , theconceptual FPGA 22 layout is shown wherein an array of circuit components is accessed by a clock orsignal pads output pads 31, 33. During fabrication, theclock pad 27, power or I/O pad 33 and I/O pads FPGA 22.Wire bonds FPGA array 25 to the external terminals of the component. Wirebonds are shown here as a representative example. However, other connection methods can also be employed. If there is a failure in one or more components of theFPGA array 25, the entire chip may be scrapped depending on whether or not it is possible to design around the specific defects. -
FIG. 4 shows how the array can be arranged in east and west halves. TheFPGA 25 includes an array of components 40 connected to pads 41-44 and 46-49. By arranging a symmetric design of internal connections, wherein power, clock and other signal routes are split into separate sections, with discrete sections in each region of the PLD or FPGA that is to be considered for partial good binning or sorting.FIG. 4 shows simple examples of this concept, whereconnection 27 inFIG. 3 is split into 42 and 49 inFIG. 4 . Other connections inFIG. 3 are similarly split inFIG. 4 . This concept can be extended to more complex bus structures. It can also be extended to more complex means/mechanisms for splitting or joining connections using, for example, fuses, programmable steering logic or other well known connecting means. Further, even more complex connecting means can include, but are not limited to, multi-dimensional splitting, division of signals into rotational quadrants or other physical divisions. - Referring to
FIG. 5 , when the entire chip tests good, the bonding to the chip may be completed by duplicate bonds. Each of the pads 41-44 and 46-49 has wire bonds. These bonds go to external connections of the FPGA or PLD, or can serve as jumpers between each of the east and west sides of theFPGA 25 which has tested 100% good. Additional connecting means besides wirebonds (e.g., fuses, programmable connections, solder bumps, etc.) can also be employed as mentioned previously. -
FIG. 6 illustrates the circumstance where the west half of theFPGA 25 has been determined to contain a defect. In this scenario, only the pads of the east side ofFPGA 25 are connected to the external connections. Accordingly, the east half is functional and can be programmed to operate in accordance with a specific configuration code without the remaining west half that contains the defect. A similar process can be used for cases where the west half of the array is defect-free. This concept can be applied to other more complex partially good subsections as well. -
FIG. 7 illustrates the use of steering logic to control configuration of one or the other halves of a testedFPGA 25. In this scenario, programmable orfusible links FPGA 25. In this scenario, a single configuration bit stream may be generated for either partially good FPGA or PLD sections/regions, since the hardware controls will steer those signals to the “good/functional” half, while avoiding the defective half of the FPGA. -
FIG. 8 illustrates a similar situation, where the FPGA may be organized along vertical configuration and control busses 61, 60. Programmablefusible links - The foregoing hardware components can be used to steer the bit stream and I/O connections with fusible links. In this way only a good/functional portion of the FPGA or PLD is configured. I/O connections can be formed into subsets, and connected by fuses or bonded out as necessary to only include operable I/O sections.
- As a second option, programmable links used with the FPGA or PLD header section of the bit stream may setup internal steering logic. These bit stream control bits will establish routing paths for configuration bits to the good/functional sections, as well as route I/O signals to operable I/O inputs of the device. Separate setup programming bit streams or a variety of other potential implementations are also possible using this concept.
- Although this may be useful in certain situations, using partially good FPGAs or PLDs does not require redundant elements. The method is scalable, in that the granularity of bins versus the number of software versions or hardware complexity is also selectable. The partially good FPGAs or PLDs are all identified by a particular assigned program code. The assigned program code will be used by the configuration logic to program those sections which are good/functional. By using a split power and contiguous I/O bus throughout, it is possible to enable independent subsection use. I/O connections and configuration bit stream connections can be controlled with fuses or programmable steering logic minimizing any changes in software or use considerations by the customer.
-
FIGS. 9 and 10 illustrate still another scenario for using a portion of a FPGA or PLD that has tested good. Twoconfiguration inputs alternative configuration port 64 is only used when a defect is found in one-half of the FPGA or PLD.FIG. 9 illustrates the use ofconfiguration port 63, which enables programming of the east half of the array. InFIG. 10 , the array is rotated 180°. Thealternate configuration port 64 is used, programming the west side of the array (which now is rotated to the east side). In this way, the two halves of the FPGA or PLD can appear to be identical even though only one is being used. This concept enables the location of connections from the FPGA or PLD array to outside circuitry to remain constant, by rotating the array. -
FIG. 11 illustrates an exemplary hardware approach to a flip-chip power or I/O connections in FPGAs or PLDs. Flip-chip and other semiconductor packaging implementations can be similarly implemented by selectively adding or deleting solder bumps or other chip-to-package connection methods. In particular,FIG. 11 illustrates anexemplary FPGA 72 layout for anFPGA array 75 wherein an array of circuit components access contiguous power or I/O busses 74, 78, 79, 80. In addition, solder bumps orsignal pads pads FIG. 11 comes the risk of defects in the FPGA due to shorts/opens in the bus. If there is a failure in one or more components of theFPGA array 75, the entire chip may be scrapped depending on whether or not it is possible to design around the specific defects. -
FIG. 12 illustrates an alternative exemplary hardware approach to flip-chip power or I/O connections to that shown inFIG. 11 that instead uses an east vs. west configuration. Each of the solder bumps or pads 81-84 and 86-89 are connected to busses that provide symmetric global wiring (e.g., separate east vs. west power busses). This configuration enables full and/or partial chip implementation and provides additional tolerance for potential shorting defects, as discussed above in connection withFIG. 11 . -
FIG. 13 illustrates an example of a circumstance where the west half of theFPGA 75 has been determined to be defective. In this scenario, only thepads FPGA 75 are connected. Accordingly, the east half is functional and can be programmed to operate in accordance with a specific configuration code without the remaining half that contains the defect. A similar process can be used for cases where the west half of the array is defect-free. This concept can be applied to other more complex partial-good subsections as well. Thus, by selectively adding or deleting solder bumps (or other chip-to-package connection methods) to achieve connections to the functional or “good” portions of the circuitry (e.g., the east half) of the FPGA or PLD, one can eliminate connections to defective subsets of circuitry (e.g., the west half). These connections can be achieved by using unique flip-chip carrier bump patterns for each combination of functional and defective areas of the FPGA or PLD. Alternatively, the symmetrical concepts described in this invention can us use to enable a single bump pattern to be used for several functional sections, using symmetrical positions of the chip connections to enable rotating the chip fro connecting to several unique functional sections. - The foregoing description of the invention illustrates and describes the present invention. Additionally, the disclosure shows and describes only the preferred embodiments of the invention in the context of a method for increasing the yield of programmable logic devices, but, as mentioned above, it is to be understood that the invention is capable of use in various other combinations, modifications, and environments and is capable of changes or modifications within the scope of the inventive concept as expressed herein, commensurate with the above teachings and/or the skill or knowledge of the relevant art. The embodiments described herein above are further intended to explain best modes known of practicing the invention and to enable others skilled in the art to utilize the invention in such, or other, embodiments and with the various modifications required by the particular applications or uses of the invention.
- Accordingly, the description is not intended to limit the invention to the form or application disclosed herein. Also, it is intended that the appended claims be construed to include alternative embodiments.
Claims (20)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/275,536 US7793251B2 (en) | 2006-01-12 | 2006-01-12 | Method for increasing the manufacturing yield of programmable logic devices |
US12/875,517 US20100333058A1 (en) | 2006-01-12 | 2010-09-03 | Method for increasing the manufacturing yield of programmable logic devices |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/275,536 US7793251B2 (en) | 2006-01-12 | 2006-01-12 | Method for increasing the manufacturing yield of programmable logic devices |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/875,517 Division US20100333058A1 (en) | 2006-01-12 | 2010-09-03 | Method for increasing the manufacturing yield of programmable logic devices |
Publications (2)
Publication Number | Publication Date |
---|---|
US20070162792A1 true US20070162792A1 (en) | 2007-07-12 |
US7793251B2 US7793251B2 (en) | 2010-09-07 |
Family
ID=38234136
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/275,536 Expired - Fee Related US7793251B2 (en) | 2006-01-12 | 2006-01-12 | Method for increasing the manufacturing yield of programmable logic devices |
US12/875,517 Abandoned US20100333058A1 (en) | 2006-01-12 | 2010-09-03 | Method for increasing the manufacturing yield of programmable logic devices |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/875,517 Abandoned US20100333058A1 (en) | 2006-01-12 | 2010-09-03 | Method for increasing the manufacturing yield of programmable logic devices |
Country Status (1)
Country | Link |
---|---|
US (2) | US7793251B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10402521B1 (en) * | 2017-01-19 | 2019-09-03 | Xilinx, Inc. | Programmable integrated circuits for emulation |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
DE102010043706A1 (en) * | 2010-07-05 | 2012-01-05 | Endress + Hauser Gmbh + Co. Kg | Field device for determining or monitoring a physical or chemical process variable |
US9012245B1 (en) * | 2014-09-22 | 2015-04-21 | Xilinx, Inc. | Methods of making integrated circuit products |
US10831507B2 (en) | 2018-11-21 | 2020-11-10 | SambaNova Systems, Inc. | Configuration load of a reconfigurable data processor |
US11188497B2 (en) | 2018-11-21 | 2021-11-30 | SambaNova Systems, Inc. | Configuration unload of a reconfigurable data processor |
US11385287B1 (en) * | 2019-11-14 | 2022-07-12 | Xilinx, Inc. | Method for adaptively utilizing programmable logic devices |
US11556494B1 (en) | 2021-07-16 | 2023-01-17 | SambaNova Systems, Inc. | Defect repair for a reconfigurable data processor for homogeneous subarrays |
US11327771B1 (en) | 2021-07-16 | 2022-05-10 | SambaNova Systems, Inc. | Defect repair circuits for a reconfigurable data processor |
US11409540B1 (en) | 2021-07-16 | 2022-08-09 | SambaNova Systems, Inc. | Routing circuits for defect repair for a reconfigurable data processor |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6530071B1 (en) * | 2000-09-28 | 2003-03-04 | Xilinx, Inc. | Method and apparatus for tolerating defects in a programmable logic device using runtime parameterizable cores |
US6817005B2 (en) * | 2000-05-25 | 2004-11-09 | Xilinx, Inc. | Modular design method and system for programmable logic devices |
US7111213B1 (en) * | 2002-12-10 | 2006-09-19 | Altera Corporation | Failure isolation and repair techniques for integrated circuits |
US7216277B1 (en) * | 2003-11-18 | 2007-05-08 | Xilinx, Inc. | Self-repairing redundancy for memory blocks in programmable logic devices |
US7228521B1 (en) * | 2005-02-01 | 2007-06-05 | Xilinx Inc. | System for operating a programmable logic device having a defective region |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4558234B2 (en) * | 2000-04-26 | 2010-10-06 | アルテラ コーポレイション | Programmable logic device |
US7143295B1 (en) * | 2002-07-18 | 2006-11-28 | Xilinx, Inc. | Methods and circuits for dedicating a programmable logic device for use with specific designs |
US7424655B1 (en) * | 2004-10-01 | 2008-09-09 | Xilinx, Inc. | Utilizing multiple test bitstreams to avoid localized defects in partially defective programmable integrated circuits |
US7498192B1 (en) * | 2005-11-01 | 2009-03-03 | Xilinx, Inc. | Methods of providing a family of related integrated circuits of different sizes |
-
2006
- 2006-01-12 US US11/275,536 patent/US7793251B2/en not_active Expired - Fee Related
-
2010
- 2010-09-03 US US12/875,517 patent/US20100333058A1/en not_active Abandoned
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6817005B2 (en) * | 2000-05-25 | 2004-11-09 | Xilinx, Inc. | Modular design method and system for programmable logic devices |
US6530071B1 (en) * | 2000-09-28 | 2003-03-04 | Xilinx, Inc. | Method and apparatus for tolerating defects in a programmable logic device using runtime parameterizable cores |
US7111213B1 (en) * | 2002-12-10 | 2006-09-19 | Altera Corporation | Failure isolation and repair techniques for integrated circuits |
US7216277B1 (en) * | 2003-11-18 | 2007-05-08 | Xilinx, Inc. | Self-repairing redundancy for memory blocks in programmable logic devices |
US7228521B1 (en) * | 2005-02-01 | 2007-06-05 | Xilinx Inc. | System for operating a programmable logic device having a defective region |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10402521B1 (en) * | 2017-01-19 | 2019-09-03 | Xilinx, Inc. | Programmable integrated circuits for emulation |
US10956638B1 (en) * | 2017-01-19 | 2021-03-23 | Xilinx, Inc. | Programmable integrated circuits for emulation |
Also Published As
Publication number | Publication date |
---|---|
US20100333058A1 (en) | 2010-12-30 |
US7793251B2 (en) | 2010-09-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20100333058A1 (en) | Method for increasing the manufacturing yield of programmable logic devices | |
US9887203B2 (en) | 3D semiconductor device and structure | |
US8492886B2 (en) | 3D integrated circuit with logic | |
US7949916B1 (en) | Scan chain circuitry for delay fault testing of logic circuits | |
EP2585842B1 (en) | Integrated circuit for and method of testing die-to-die bonding | |
JP4187022B2 (en) | Semiconductor device, semiconductor integrated circuit, and bump resistance measuring method | |
US6157213A (en) | Layout architecture and method for fabricating PLDs including multiple discrete devices formed on a single chip | |
US9106229B1 (en) | Programmable interposer circuitry | |
US9509313B2 (en) | 3D semiconductor device | |
US8258810B2 (en) | 3D semiconductor device | |
US8373439B2 (en) | 3D semiconductor device | |
US20120193806A1 (en) | 3d semiconductor device | |
US7301836B1 (en) | Feature control circuitry for testing integrated circuits | |
JPH05198683A (en) | Latch support fuse test circuit and latch support fuse testing method | |
US20120194216A1 (en) | 3D Semiconductor Device | |
US20180122686A1 (en) | 3d semiconductor device and structure | |
US8427200B2 (en) | 3D semiconductor device | |
US6791355B2 (en) | Spare cell architecture for fixing design errors in manufactured integrated circuits | |
US7310758B1 (en) | Circuit for and method of implementing programmable logic devices | |
US7317327B1 (en) | Adjustable data loading circuit with dynamic test mode switching for testing programmable integrated circuits | |
KR20160029106A (en) | Monolithic integrated circuit die having modular die regions stitched together | |
KR20210151963A (en) | Reconfigurable System-on-Chip | |
US11281195B2 (en) | Integrated circuits with in-field diagnostic and repair capabilities | |
US7131033B1 (en) | Substrate configurable JTAG ID scheme | |
KR20220004818A (en) | Electronic components and systems with integrated self-test functionality |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GOODNOW, KENNETH J.;OGLIVIE, CLARENCE R.;REYNOLDS, CHRISTOPHER B.;AND OTHERS;REEL/FRAME:017398/0867;SIGNING DATES FROM 20051212 TO 20051213 Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GOODNOW, KENNETH J.;OGLIVIE, CLARENCE R.;REYNOLDS, CHRISTOPHER B.;AND OTHERS;SIGNING DATES FROM 20051212 TO 20051213;REEL/FRAME:017398/0867 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
REMI | Maintenance fee reminder mailed | ||
LAPS | Lapse for failure to pay maintenance fees | ||
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: 20140907 |
|
AS | Assignment |
Owner name: GLOBALFOUNDRIES U.S. 2 LLC, NEW YORK Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTERNATIONAL BUSINESS MACHINES CORPORATION;REEL/FRAME:036550/0001 Effective date: 20150629 |
|
AS | Assignment |
Owner name: GLOBALFOUNDRIES INC., CAYMAN ISLANDS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GLOBALFOUNDRIES U.S. 2 LLC;GLOBALFOUNDRIES U.S. INC.;REEL/FRAME:036779/0001 Effective date: 20150910 |