The present invention relates generally to electrical circuits and, more particularly, to memory, such as for example configuration memory within a programmable logic device.
A programmable logic device (PLD), such as for example a field programmable gate array (FPGA) or a complex programmable logic device (CPLD), typically uses configuration memory to store configuration data, which determines (e.g., programs or configures) the PLD's user-defined functions. As the logic capacity and complexity of PLDs increase, the number of configuration memory cells similarly increases and modern PLDs typically employ millions of configuration memory cells.
A drawback of a conventional PLD is that all of the configuration memory cells must operate properly or the PLD typically is deemed defective as it may not be able to perform a user's desired functions. Consequently, defective configuration memory cells may result in significant yield loss for PLD manufacturers. Alternatively, a conventional approach is to provide redundant portions (e.g., including logic blocks, interconnect, configuration memory, etc.) of the PLD that would be used in place of defective portions or provide the desired output signals to the defective portions, with the output signals bypassing the defective components (e.g., as disclosed in U.S. Pat. No. 5,831,907). However, this approach may add significantly to the overhead, requires significant die area to implement, and may reduce PLD performance.
As a result, there is a need for improved techniques directed to defective configuration memory cells within a PLD.
In one embodiment, a programmable logic device includes a plurality of configuration memory cells and at least one spare configuration memory cell adapted to store configuration data for a memory cell identified within the plurality of configuration memory cells (e.g., identified as a defective memory cell). An address shift register within the device is adapted to provide programming signals to the plurality of configuration memory cells via wordlines. A data shift register within the device is adapted to provide configuration data to the plurality of configuration memory cells via bitlines. The data shift register is further adapted to provide configuration data from the spare configuration memory cell to the identified configuration memory cell.
The data shift register may further be adapted to provide the configuration data from the spare configuration memory cell to the identified memory cell in response to a programming signal from the address shift register.
The data shift register may further be adapted to store configuration data intended for a configuration memory cell in the spare configuration memory cell in response to identification of the configuration memory cell.
The scope of the invention is defined by the claims, which are incorporated into this section by reference. A more complete understanding of embodiments of the present invention will be afforded to those skilled in the art, as well as a realization of additional advantages thereof, by a consideration of the following detailed description of one or more embodiments. Reference will be made to the appended sheets of drawings that will first be described briefly.
a shows a circuit diagram illustrating a configuration memory cell in accordance with an embodiment of the present invention.
b shows a circuit diagram illustrating an exemplary driver for the configuration memory cell of
Embodiments of the present invention and their advantages are best understood by referring to the detailed description that follows. It should be appreciated that like reference numerals are used to identify like elements illustrated in one or more of the figures.
I/O blocks 102 provide I/O functionality (e.g., supports one or more I/O and/or memory interface standards) for PLD 100. Logic blocks 104 (e.g., also referred to in the art as configurable logic blocks or logic array blocks) provide logic functionality for PLD 100, such as LUT-based logic typically associated with FPGAs or array-based logic typically associated with CPLDs.
Configuration memory 114 represents the memory that is distributed within PLD 100 and that stores the configuration data that determines the user-defined functionality of PLD 100. Configuration memory 114 typically is implemented as static random access memory (SRAM) cells (also referred to herein as configuration RAM (CRAM)) or as other types of volatile or non-volatile memory (e.g., fuses, anti-fuses, or other forms of memory suitable for the techniques discussed herein). Interconnect 116 would typically be distributed throughout PLD 100 to provide programmable routing resources, such as for logic blocks 104.
PLD 100 may also include reprogrammable non-volatile memory 106 (e.g., blocks of EEPROM or flash memory), volatile memory 108 (e.g., block SRAM), clock-related circuitry 110 (e.g., PLL or DLL circuits), and/or one or more data ports 112. Non-volatile memory 106, for example, may be used to store configuration data within PLD 100 for transfer to configuration memory 114 of PLD 100 upon power up or during reconfiguration of PLD 100. This may drastically reduce the time to reconfigure PLD 100 relative to an external bitstream (e.g., reduce the time from seconds to microseconds for loading of configuration data into configuration memory 114).
Data port 112 may be used for programming PLD 100, as would be understood by one skilled in the art. For example, data port 112(1) may represent a programming port such as a central processing unit (CPU) port (also referred to as a peripheral data port, a microprocessor interface, or a sysCONFIG programming port) and/or a serial peripheral interface (SPI) port. Data port 112(2) may represent, for example, a programming port such as a joint test action group (JTAG) port by employing standards such as Institute of Electrical and Electronics Engineers (IEEE) 1149.1 or 1532 standards. Data ports 112(1) and 112(2) are not both required, but one or the other or both may be included to receive configuration data and commands, depending upon the desired application and requirements as would be understood by one skilled in the art.
It should be understood that the number and placement of the various elements (some of which may be optional), such as I/O blocks 102, logic blocks 104, non-volatile memory 106, volatile memory 108, clock-related circuitry 110, data port 112, configuration memory 114, and interconnect 116 is not limiting and may depend upon the desired application. Furthermore, it should be understood that the elements are illustrated in block form for clarity and that certain elements, such as configuration memory 114 and interconnect 116 would typically be distributed throughout PLD 100 (e.g., in and between logic blocks 104) to perform their conventional functions (e.g., storing configuration data that configures PLD 100 and providing programmable routing resources, respectively).
In accordance with one or more embodiments of the present invention, systems and methods are disclosed to provide redundancy for memory cells of configuration memory 114. As noted above, one or more defective configuration memory cells may result in a conventional PLD being categorized as defective, resulting in yield-loss for the PLD manufacturer. However, if configuration memory redundancy is provided, the PLD manufacturer may produce higher density PLDs that may provide improved yield results, an improved cost structure, and the configuration memory density may scale in a similar fashion as other types of memory.
Configuration memory cells may fail for example due to hard failure defects or due to soft failure defects. An example of a hard failure may be a short between two power supply rails or an open circuit to a power supply rail, while a soft failure may be attributed for example to intra-chip transistor variations that result in the configuration memory cell falling below minimum performance thresholds.
As an example,
As another example,
For example, when memory cell 300 is being programmed, drivers 302 are switched off by a control signal on line 304 and memory cell 300 is programmed in a conventional fashion. However, when memory cell 300 is not being programmed, drivers 302 may be switched on by the control signal on line 304, with drivers 302 driving logical values of output 208 (e.g., output 208(1) and 208(2) for Q and QN, respectively) from memory cell 300 to corresponding bitlines 202, as shown in
Referring briefly to
As logic gate and configuration memory densities increase, simulation results indicate that a significant number of PLD defects will be due to one or more defective configuration memory cells. For example, potential soft failure defects due to intra-chip transistor variations within memory cell 200 may include a failure to be programmed to a logical zero or a logical one, a failure to maintain the programmed logical value, a failure to adequately drive bitlines 202 or switching to the opposite logical value during a read operation, and/or switching to the opposite logical value during signal transitions within the PLD.
Circuit 400 includes memory cells 200, bitlines 202, wordlines 204, memory cells 300 controlled by the control signal NP on line 304, an address shift register (ASR) 402, and a data shift register (DSR) 404. Memory cells 200 are typically arranged in a two-dimensional fashion (e.g., forming at least a portion of configuration memory 114 within interconnect 116, logic blocks 104, and other parts of PLD 100) and may number in the thousands or millions, but for clarity only a few rows and columns of memory cells 200 are shown. Memory cells 300 (e.g., spare memory cells) are included to provide a form of redundancy and compensate for defective ones of memory cells 200.
As an example, each wordline 204 is coupled to one column of memory cells (e.g., memory cells 200 or memory cells 300), while one set of bitlines 202 are coupled to one row of memory cells (e.g., memory cells 200 or memory cells 300). However, it should also be noted that the terms row and column are interchangeable and not limiting and that the term row may be used to describe a row or a column and likewise the term column may be used to describe a row or a column.
As a programming example with no defective memory cells 200, ASR 402 drives a logical low signal on wordlines 204, while DSR 404 drives (e.g., using bitline drivers 406) a data signal for one column on bitlines 202 (i.e., complementary data signals on B and BN). ASR 402 then drives a logical high signal on one wordline 204 (e.g., wordline 204(1)), while maintaining the logical low signal on the remaining wordlines 204 so that the data on bitlines 202 is written into a column of memory cells 200 associated with one wordline 204 (e.g., wordline 204(1)). After the data is written for the one column, ASR 402 drives a logical low signal on wordlines 204 and the process repeats for each column of data to be written (e.g., column by column programming). Thus, the programming is similar to a conventional programming operation and memory cells 300 are not used in this example (e.g., not programmed and the control signal NP on line 304 maintains drivers 302 in a switched off state) as there are no defective memory cells 200 (as explained further herein).
After the configuration data is programmed into memory cells 200, PLD 100 (which incorporates circuit 400 for this example) begins its normal operation (often referred to as “user mode”) to perform the logic functions and operate as intended for the particular design. Typically, during user mode, ASR 402 maintains a logical low signal on wordlines 204 and DSR 404 maintains a logical high signal on bitlines 202.
In accordance with one or more embodiments of the present invention, if one or more memory cells 200 are not operating properly, then memory cells 300 of circuit 400 may be employed. Memory cells 300 may be used, for example, to provide the proper configuration data values on bitlines 202 during the user mode of operation for memory cells 200 that are defective (i.e., not meeting operational specifications or requirements) so that these defective memory cells 200 can supply proper values on their output 208 (i.e., Q and/or QN signal values).
As a programming example, if memory cell 200(1) in
After the configuration data is programmed into memory cells 200 and memory cells 300, PLD 100 (which incorporates circuit 400 for this example) begins its normal user mode of operation to perform the logic functions and operate as intended for the particular design. During general user mode of operation, the control signal NP on line 304 (e.g., providing a logical high signal) maintains drivers 302 of memory cells 300 in a switched on state to drive bitlines 202 while ASR 402 maintains a logical high signal on wordline 204(1) (i.e., wordline 204 associated with one or more defective memory cells 200, such as memory cell 200(1) for this example). DSR 404 would not drive bitlines 202 during user mode of operation, but rather allow memory cells 300 to drive bitlines 202.
Consequently, memory cell 200(1) and the associated memory cells 200 in the same column are supplied with a logical high signal on wordline 204(1) and the appropriate data is driven on bitlines 202 by memory cells 300, which forces output 208 (Q and QN) of memory cells 200 of wordline 204(1) to their proper data values. Thus, memory cells 300 provide a form of redundancy by providing support to the column of memory cells 200 with one or more defective memory cells 200 (e.g., memory cell 200(1)) by providing the proper data values on bitlines 202 to maintain the proper values within the column having defective ones of memory cells 200 (e.g., the column of memory cells 300 supports the entire column of memory cells 200 having one or more defective memory cells 200).
During a readback operation for the data from circuit 400, ASR 402 and DSR 404 would control wordlines 204 and bitlines 202, respectively, in a conventional fashion, except that the data values are read from memory cells 300 rather than the column of memory cells 200 associated with memory cell 200(1). For example, ASR 402 provides a logical high signal on wordline 204 associated with memory cells 300 and the control signal NP on line 304 may also optionally switch on drivers 302 to drive out the data on bitlines 202 for the readback of the configuration data associated with memory cell 200(1).
During the readback operation of circuit 400, drivers 302 of memory cells 300 are switched off by the control signal NP on line 304, except for optionally during the readback of the column associated with memory cell 200(1). Thus, defective memory cell 200(1) is expected to hold its data value during the duration of the readback operation for circuit 400. Upon completion of the readback operation, the general user mode of operation would resume (e.g., the control signal NP maintains drivers 302 of memory cells 300 in a switched on state to drive bitlines 202 while ASR 402 maintains a logical high signal on wordline 204(1)).
Circuit 400 may provide certain advantages over conventional approaches. For example, defective memory cell 200(1) and the associated memory cells 200 in the defective column of wordline 204(1) will not need to provide (i.e., drive back) their data values during a readback operation and will not lose their data values over time because the column of memory cells 300 provides their data values on bitlines 202 to maintain the proper data values within memory cell 200(1) and associated memory cells 200 in the column. It should also be noted that memory cells 300, including drivers 302, may be sized appropriately (e.g., taking into account process variations) to write to the defective column.
In general, any defective memory cells 200 within circuit 400 would not have a hard defect failure (e.g., no structural defect) so that transistors 206 generally still function. The failure would typically be a soft defect failure (e.g., transistor variations and mismatches, such as for example associated with ION, IOFF, VTH, and/or other general transistor characteristics). Memory cells 200 that are defective should be associated with the same wordline (e.g., wordline 204(1)) so that these defective memory cells can be supported by the column of memory cells 300, as discussed above.
However, it should be understood that this is not limiting and that circuit 400 may represent or provide one section of configuration memory for PLD 100, with PLD 100 having a number of circuits 400 to provide configuration memory 114 and sufficient configuration memory redundancy using the techniques discussed herein (e.g., in reference to
PLD 100 may also store information (e.g., in non-volatile memory 106) regarding defective memory cells and/or the associated wordlines 204 (e.g., wordline address). For example, wordline addresses or other information may be stored in non-volatile memory 106 of PLD 100 to provide proper operation for the various modes of operation and to properly control ASR 402, DSR 404, wordlines 204, bitlines 202, and the control signal on line 304 to provide redundancy and support for defective ones of memory cells 200 in one or more circuits 400 within PLD 100.
Referring to
Circuit 500 is similar to circuit 400 (
As a programming example, ASR 502 and DSR 504 load memory cells 200 with the configuration data in a conventional fashion, but the configuration data for defective column 508 is stored in (or also stored in) column 506 (e.g., a shadow spare column). After the configuration data is programmed (e.g., loaded or configured) into memory cells 200, the configuration data stored by memory cells 200 within column 506 is provided to DSR 504. During a user mode of operation, ASR 502 provides a logical high signal on wordline 204(1) associated with column 508 and DSR 504 will provide (e.g., via its bitline drivers 406) on bitlines 202 the configuration data provided by column 506. Therefore, the proper values of configuration data will be maintained in memory cells 200 of column 508, including any defective memory cells 200 (e.g., memory cell 200(1)) within column 508.
During a readback operation, DSR 504 may read the configuration data from column 506 rather than from column 508 having defective memory cells 200. Memory cells 200 in column 506 may be viewed as functioning in a similar fashion as memory cells 300 (
Circuit 500 may provide advantages similar to those discussed above in reference to circuit 400 (
For example,
Sections 606 (e.g., eight are shown as an example but any number of sections may be implemented) represent sections of the memory cell array, with each section 606 having a spare column of memory cells (e.g., spare column 506) for providing support for a defective column of memory, such as discussed in reference to
As an example,
As another implementation example,
In general in reference to
As a specific example in reference to
Systems and methods are disclosed herein to provide techniques with respect to defective memory cells. For example, in accordance with an embodiment of the present invention, a programmable logic device is disclosed that provides a form of redundancy for configuration memory (e.g., configuration RAM (CRAM)). In one embodiment, a set of spare CRAM bits are provided to assist one or more CRAM bits, which do not meet expected functionality levels, to maintain proper configuration data values and operate in a desired fashion. The spare CRAM bits, for example, may include drivers or may utilize the drivers of the data shift register to provide proper configuration data values on the bitlines for the defective memory cells. It should be understood that embodiments of the present invention are not limited to CRAM bits and that other types of suitable configuration memory cells (volatile or non-volatile, as discussed herein) may be substituted for the spare CRAM bits and/or for the CRAM bits of the configuration memory.
The data shift register and the address shift register may be operated appropriately to provide conventional operations, such as the loading of the configuration data into the memory cells, but may also be operated to support redundancy operations as discussed herein. For example as illustrated in
Embodiments described above illustrate but do not limit the invention. It should also be understood that numerous modifications and variations are possible in accordance with the principles of the present invention. Accordingly, the scope of the invention is defined only by the following claims.
This application is a continuation of U.S. application Ser. No. 11/680,526, filed Feb. 28, 2007, which is incorporated herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
7254069 | Haraguchi et al. | Aug 2007 | B2 |
7505319 | Wu et al. | Mar 2009 | B2 |
Number | Date | Country | |
---|---|---|---|
Parent | 11680526 | Feb 2007 | US |
Child | 12564781 | US |