An integrated circuit (“IC”) includes one or more semiconductor devices. The recent trend in miniaturizing ICs has resulted in smaller devices (comprised of smaller components), e.g., memory ICs, which operate at lower voltages and consume less power yet provide the same or increased functionality at higher speeds. With such miniaturization, memory ICs have become more susceptible to thermally induced errors, radiation induced errors, or the like. Types of damage to a semiconductor device caused by radiation include persistent lattice displacement (which typically is persistent) and/or ionization effects (which typically is transient). Types of errors in the operation of the semiconductor device (operational errors) include hard/permanent errors and soft/one-time errors. Lattice displacement tends to induce hard/permanent operational errors. Ionization effects tend to produce soft/one-time operational errors. Thermally induced operational errors tend to be soft/one-time operational errors.
Aspects of the present disclosure are best understood from the following detailed description when read with the accompanying figures. It is noted that, in accordance with the standard practice in the industry, various features are not drawn to scale. In fact, the dimensions of the various features may be arbitrarily increased or reduced for clarity of discussion.
The following disclosure provides many different embodiments, or examples, for implementing different features of the provided subject matter. Specific examples of components, values, operations, materials, arrangements, etc., are described below to simplify the present disclosure. These are, of course, merely examples and are not intended to be limiting. Other components, values, operations, materials, arrangements, etc., are contemplated. For example, the formation of a first feature over or on a second feature in the description that follows may include embodiments in which the first and second features are formed in direct contact, and may also include embodiments in which additional features may be formed between the first and second features, such that the first and second features may not be in direct contact. In addition, the present disclosure may repeat reference numerals and/or letters in the various examples. This repetition is for the purpose of simplicity and clarity and does not in itself dictate a relationship between the various embodiments and/or configurations discussed.
Further, spatially relative terms, such as “beneath,” “below,” “lower,” “above,” “upper” and the like, may be used herein for ease of description to describe one element or feature's relationship to another element(s) or feature(s) as illustrated in the figures. The spatially relative terms are intended to encompass different orientations of the device in use or operation in addition to the orientation depicted in the figures. The apparatus may be otherwise oriented (rotated 90 degrees or at other orientations) and the spatially relative descriptors used herein may likewise be interpreted accordingly.
According to at least one embodiment of the present disclosure, in the context of decoding an original address, an error in the address-decoding is detected by comparing a recreated version of the original address against the original address. In some embodiments, an encoder recodes the original address to form the recreated version of the original address. The recoded address is compared against the original address and an error flag is set if the recoded address and the original address are not the same. According to another approach, an error in the address-decoding is detected by: using first and second redundant address decoders to generate corresponding first and second redundant decoded addresses; comparing the first and second redundant decoded addresses; and setting an error flag if the first and second redundant decoded addresses are not the same. In contrast to using first and second redundant decoded addresses, a benefit of using an encoder to recode the decoded address (in accordance with at least one embodiment of the present disclosure) is that the footprint of the encoder is smaller than the footprint of the redundant second address decoder, which results in an address-decoding error detection system having a smaller footprint than the address-decoding error detection system of the other approach. Decreasing the size of components which comprise a semiconductor device, e.g., by using the encoder instead of a redundant second decoder, provides one or more of the following benefits: faster operation; a reduction in the overall size of the IC; reduced cost of materials; or the like.
In
In some embodiments, macro 102 is a memory macro. In some embodiments, macro 102 is a non-volatile memory macro. In some embodiments, macro 102 is a Read Only Memory (ROM) system macro. In some embodiments, macro 102 is a memory system macro other than a ROM system macro. Macro 102 includes, among other things, an array 104 of memory cells, a read/write (R/W) circuit 106 and an address-decoding error detection system 108 (see
In
In some embodiments, address-decoding error-handling system 203 is not a macro but instead is implemented as one or more components (not shown) in memory system 202. In some embodiments in which semiconductor device 200 is itself included in a system 200′ (not shown), address-decoding error-handling system 203 is not a system included in semiconductor device 200 but instead is implemented as one or more devices (not shown) in system 200′.
Address-decoding error detection system 208 includes: an address decoder 210; an encoder 212 and a comparator 214. In the context of a memory access operation by which one or more memory cells in memory cell array 204 are to be accessed, address-decoding error detection system 208 receives an original address identifying one or more cells in memory cell array 204. In
For address-decoding error detection system 208, the 2N bit decoded address is also provided to encoder 212. Encoder 212 implements a mapping of a first set of possible values for the decoded address to a second set of corresponding possible values for the recoded address. In some embodiments, encoder 212 implements a look-up table (LUT). In some embodiments, encoder 212 is a Read Only Memory (ROM). In some embodiments, encoder 212 is a non-volatile memory other than a LUT or a ROM. In some embodiments, the mapping which encoder 212 provides is fixed at the time of manufacture of address-decoding error detection system 208.
In
In some embodiments, if comparator 214 sets an error flag ERR_FLAG to an error-indicative state, then address-decoding error-handling system 203 handles/responds-to the responds to the error (which caused the error flag ERR_FLAG to be set to an error-indicative state) as follows: system 203 resets the operation of memory system 202; system 203 determines if the error is a soft/one-time type of error or a hard/permanent type of error; and repeats, if the error is a soft/one-time type of error, the operation which caused the error. In some embodiments, if the error is a hard/permanent type of error, then error-handling system 203 outputs a hard/permanent error signal external to memory system 202. In some embodiments, error-handling system 203 outputs the hard/permanent error signal externally to semiconductor device 200. In some embodiments in which semiconductor device 200 is itself included in system 200′ (again, not shown), the generation of the hard/permanent error signal by address-decoding error-handling system 203 identifies semiconductor device 200 as being defective and triggers a maintenance operation on system 200′ by which the defective instance of semiconductor device 200 is replaced with a non-defective instance of semiconductor device 200.
In contrast to another approach which uses first and second redundant decoded addresses where the second redundant decoded address is obtained through use of a second redundant address decoder, a benefit of using encoder 212 to recode the decoded address is that the footprint of encoder 212 is smaller than the footprint of the redundant second address decoder. As a result, address-decoding error detection system 208 has a smaller footprint than the address-decoding error detection system of the other approach (which uses redundant first and second decoders). Decreasing the size of components which comprise a semiconductor device, e.g., by using encoder 212 instead of a redundant second decoder, provides one or more of the following benefits: faster operation; a reduction in the overall size of the IC; reduced cost of materials; or the like.
Memory system 302 of
In
In
In contrast to another approach which uses first and second redundant decoded addresses, a benefit of using encoder 312 to recode the decoded address is that the footprint of encoder 312 is smaller than the footprint of the redundant second address decoder. As a result, address-decoding error detection system 308 has a smaller footprint than the address-decoding error detection system of the other approach (which uses redundant first and second decoders). Decreasing the size of components which comprise a semiconductor device, e.g., by using encoder 312 instead of a redundant second decoder, provides one or more of the following benefits: faster operation; a reduction in the overall size of the IC; reduced cost of materials; or the like.
In some embodiments, the one bit memory cell of
In
In some embodiments, the pair of one bit memory cells is used in memory cell array 304 in cooperation with bit line BL and a bit_bar line BLB. The pair of one bit memory cells of each of
In
Memory system 402 of
In
In addition to mapping, encoder 412 translates second set 413B of corresponding possible values for the recoded address into a predefined X format. A given instance of the X formatted version of the recoded address is different than a corresponding unformatted version of the recoded address. An example of the unformatted version of the recoded address is the format for second set 313B which is used by encoder 312. In some embodiments, the X format (discussed in more detail below) is a low power (LP) format. In contrast to system 308 of
In
In contrast to another approach which uses first and second redundant decoded addresses, a benefit of using encoder 412 to recode the decoded address is that the footprint of encoder 412 and LP format detranslator 430, taken together, is smaller than the footprint of the redundant second address decoder. As a result, address-decoding error detection system 408 has a smaller footprint than the address-decoding error detection system of the other approach (which uses redundant first and second decoders). Decreasing the size of components which comprise a semiconductor device, e.g., by using encoder 412 instead of a redundant second decoder, provides one or more of the following benefits: faster operation; a reduction in the overall size of the IC; reduced cost of materials; or the like.
An example of an encoder by which the LP format translation of table 450 can be implemented is encoder 412 of
In
As an example drawn from table 450, consider the row of table 450 in which the unformatted recoded address bits b3:b0=0110, for which Σ1=2 and Σ0=2 such that Σ0≥Σ1. Accordingly, bits b3:b0 are inverted from their state in the unformatted version of the recoded address and the flag bit b4 is set to 0 such that the corresponding row of LP formatted recoded address bits b4:b0=01001.
As another example drawn from table 450, consider the row of table 450 in which the unformatted recoded address bits b3:b0=0111, for which Σ1=3 and Σ0=1 such that Σ1>Σ0. Accordingly, no change is made to bits b3:b0 and the flag bit b4 is set to one such that the corresponding row of LP formatted recoded address bits b4:b0=10111.
In
An example of an LP format detranslator by which the LP format detranslation of table 450 can be implemented is LP format detranslator 430 of
In
As an example drawn from table 460, consider the row of table 460 in which the LP formatted recoded address bits b3:b0=0110 and the flag bit b4=0. Accordingly, bits b3:b0 of the LP formatted recoded address are inverted to produce bits b3:b0 of the unformatted recoded address such that bits b3:b0 of the unformatted recoded address are b3:b0=1001, and the flag bit b4 is discarded.
As another example drawn from table 460, consider the row of table 460 in which the LP formatted recoded address bits b3:b0=0111 and the flag bit b4=1. Accordingly, bits b3:b0 of the LP formatted recoded address are not changed such that bits b3:b0 of the unformatted recoded address are b3:b0=0111, and the flag bit b4 is discarded.
Memory system 502 of
In
In
In contrast to another approach which uses first and second redundant decoded addresses, a benefit of using encoder 512 to recode the decoded address is that the footprint of encoder 512 and QBR format detranslator 530, taken together, is smaller than the footprint of the redundant second address decoder. As a result, address-decoding error detection system 508 has a smaller footprint than the address-decoding error detection system of the other approach (which uses redundant first and second decoders). Decreasing the size of components which comprise a semiconductor device, e.g., by using encoder 512 instead of a redundant second decoder, provides one or more of the following benefits: faster operation; a reduction in the overall size of the IC; reduced cost of materials; or the like.
An example of a semiconductor device to which method 600 is applicable is semiconductor device 100 of
In
At block 606, the decoded address is recoded to form a recoded address using an encoder of the semiconductor device. Examples of the encoder include encoder 212 of
At block 608 of
In
In
At block 634, the X formatted version of the recoded address is detranslated using a detranslator of the semiconductor device. Examples of the detranslator include LP format detranslator 430 of
In
At block 644, the LP formatted version of the recoded address is detranslated. An example of the detranslator is LP format detranslator 430 of
If the result of the decision at block 646 is yes (namely, the flag bit is set to logical zero), then flow proceeds to block 648. At block 648, the N bits of the LP formatted version of the recoded address are inverted and the flag bit is discarded. As an example of a circumstance in which the N bits of the LP formatted version of the recoded address are inverted, consider the row of table 460 in which the LP formatted recoded address bits b3:b0=0110 and the flag bit b4=0. Accordingly, bits b3:b0 of the LP formatted recoded address are inverted to produce bits b3:b0 of the unformatted recoded address such that bits b3:b0 of the unformatted recoded address become b3:b0=1001, and the flag bit b4 is discarded. From block 648, flow proceeds to block 650. At block 650, the inverted N bits are treated as the unformatted version of the recoded address. From block 650, flow proceeds to block 652. At block 652, the unformatted version of the recoded address is output.
If the result of the decision at block 646 is no (namely, the flag bit is NOT set to logical zero), then flow proceeds to block 654. At block 654, the N bits of the LP formatted version of the recoded address are NOT changed and the flag bit is discarded. As an example of a circumstance in which the N bits of the LP formatted version of the recoded address are NOT inverted, consider the row of table 460 in which the LP formatted recoded address bits b3:b0=0111 and the flag bit b4=1. Accordingly, bits b3:b0 of the LP formatted recoded address are not changed such that bits b3:b0 of the unformatted recoded address become b3:b0=0111, and the flag bit b4 is discarded. From block 654, flow proceeds to block 652, discussed above.
From block 644, flow proceeds outside block 606 to block 608. In
In an embodiment, a method (of detecting an address decoding error of a semiconductor device) includes: decoding an original address, with an address decoder of the semiconductor device, to form a corresponding decoded address; recoding the decoded address, with an encoder of the semiconductor device, to form a recoded address; making a comparison, with a comparator of the semiconductor device, of the recoded address and the original address; and detecting an address decoding error based on the comparison. In an embodiment, each of the original address and the recoded address has N bits, where N is a positive integer; and the decoded address has 2N bits. In an embodiment, the recoding the decoded address includes: using the decoded address as an index; and accessing, according to the index, a mapping stored in a non-volatile memory of the semiconductor device, the mapping relating a first set of possible values for the decoded address to a second set of corresponding possible values for the recoded address. In an embodiment, the recoding the decoded address includes: using the decoded address as an index; and accessing, according to the index, a mapping stored in a non-volatile memory of the semiconductor device; the mapping relates a first set of possible values for the decoded address to a second set of corresponding possible values for the recoded address; the mapping represents the second set of corresponding possible values for the recoded address in an X format, a given instance of an X-formatted version of the recoded address being different than an unformatted version of the recoded address; the accessing identifies a corresponding X-formatted version of the recoded address; the recoding the decoded address further includes: detranslating the X-formatted version of the recoded address into a corresponding unformatted version of the recoded address; and the making a comparison includes: using the unformatted version of the recoded address. In an embodiment, the X format is a low power format; the unformatted version of the recoded address includes N bits, where N is a positive integer; a low-power-formatted version of the recoded address includes the N bits of the unformatted version of the recoded address plus a flag bit for a total of N+1 bits; and the detranslating includes: for a first circumstance in which the flag bit of the identified low-power-formatted version of the recoded address is set to zero: inverting the N bits of the identified low-power-formatted version of the recoded address; and outputting the inverted N bits as the unformatted version of the recoded address; and for a second circumstance in which the flag bit of the identified low-power-formatted version of the recoded address is set to one: outputting the N bits of the identified low-power-formatted version of the recoded address as the unformatted version of the recoded address. In an embodiment, the unformatted version of the recoded address includes N bits, where N is a positive integer; and the X format is a Q-bit-ROM-formatted version of the recoded address includes N/Q bits, where Q is a positive integer such that N/Q=U, where U is a positive integer. In an embodiment, the making a comparison includes: bitwise comparing the recoded address and the original address. In an embodiment, the decoded address has a greater number of bits than each of the original address and the recoded address.
In an embodiment, a method (of detecting an address decoding error of a semiconductor device) includes: decoding an original address, with an address decoder of the semiconductor device, to form a corresponding decoded address; recoding the decoded address, with an encoder of the semiconductor device, to form a recoded address, the recoding including: using the decoded address as an index; and accessing, according to the index, a mapping stored in a non-volatile memory of the semiconductor device, the mapping relating a first set of possible values for the decoded address to a second set of corresponding possible values for the recoded address; making a comparison, with a comparator of the semiconductor device, of the recoded address and the original address; and detecting an address decoding error based on the comparison. In an embodiment, each of the original address and the recoded address has N bits, where N is a positive integer; and the decoded address has 2N bits. In an embodiment, the mapping represents the second set of corresponding possible values for the recoded address in an X format, a given instance of an X-formatted version of the recoded address being different than an unformatted version of the recoded address; the accessing identifies a corresponding X-formatted version of the recoded address; the recoding the decoded address further includes: detranslating the X-formatted version of the recoded address into a corresponding unformatted version of the recoded address; and the making a comparison includes: using the unformatted version of the recoded address. In an embodiment, the X format is a low power format; the unformatted version of the recoded address includes N bits, where N is a positive integer; a low-power-formatted version of the recoded address includes the N bits of the unformatted version of the recoded address plus a flag bit for a total of N+1 bits; and the detranslating includes: for a first circumstance in which the flag bit of the identified low-power-formatted version of the recoded address is set to zero: inverting the N bits of the identified low-power-formatted version of the recoded address; and outputting the inverted N bits as the unformatted version of the recoded address; and for a second circumstance in which the flag bit of the identified low-power-formatted version of the recoded address is set to one: outputting the N bits of the identified low-power-formatted version of the recoded address as the unformatted version of the recoded address. In an embodiment, the unformatted version of the recoded address includes N bits, where N is a positive integer; and the X format is a Q-bit-ROM-formatted version of the recoded address which includes N/Q bits, where Q is a positive integer such that N/Q=U, where U is a positive integer. In an embodiment, the making a comparison includes: bitwise comparing the recoded address and the original address. In an embodiment, the decoded address has a greater number of bits than each of the original address and the recoded address.
In an embodiment, a method of detecting an address decoding error of a semiconductor device) includes: decoding an original address, with an address decoder of the semiconductor device, to form a corresponding decoded address; recoding the decoded address, with an encoder of the semiconductor device, to form a recoded address, the recoding including: using the decoded address as an index; and accessing, according to the index, a mapping stored in a non-volatile memory of the semiconductor device; the mapping relating a first set of possible values for the decoded address to a second set of corresponding possible values for the recoded address; the mapping representing the second set of corresponding possible values for the recoded address in an X format, a given instance of an X-formatted version of the recoded address being different than an unformatted version of the recoded address; the accessing including: identifying a corresponding X-formatted version of the recoded address; detranslating the X-formatted version of the recoded address into a corresponding unformatted version of the recoded address; and making a comparison, with a comparator of the semiconductor device, of the recoded address and the original address, the making including: using the unformatted version of the recoded address; and detecting an address decoding error based on the comparison. In an embodiment, at least one of a first scenario, a second scenario and a third scenario is true; the first scenario includes each of the original address and the recoded address having N bits, where N is a positive integer, and the decoded address having 2N bits; the second scenario includes the making a comparison including bitwise comparing the recoded address and the original address; and the third scenario includes the decoded address having a greater number of bits than each of the original address and the recoded address. In an embodiment, the X format is a low power format; the unformatted version of the recoded address includes N bits, where N is a positive integer; a low-power-formatted version of the recoded address includes the N bits of the unformatted version of the recoded address plus a flag bit for a total of N+1 bits; and the detranslating includes: for a first circumstance in which the flag bit of the identified low-power-formatted version of the recoded address is set to zero, inverting the N bits of the identified low-power-formatted version of the recoded address, and outputting the inverted N bits as the unformatted version of the recoded address; and for a second circumstance in which the flag bit of the identified low-power-formatted version of the recoded address is set to one, outputting the N bits of the identified low-power-formatted version of the recoded address as the unformatted version of the recoded address. In an embodiment, the X format is a Q-bit-ROM format. In an embodiment, the unformatted version of the recoded address includes N bits, where N is a positive integer; and a Q-bit-ROM-formatted version of the recoded address includes N/Q bits, where Q is a positive integer such that N/Q=U, where U is a positive integer.
The foregoing outlines features of several embodiments so that those skilled in the art may better understand the aspects of the present disclosure. Those skilled in the art should appreciate that they may readily use the present disclosure as a basis for designing or modifying other processes and structures for carrying out the same purposes and/or achieving the same advantages of the embodiments introduced herein. Those skilled in the art should also realize that such equivalent constructions do not depart from the spirit and scope of the present disclosure, and that they may make various changes, substitutions, and alterations herein without departing from the spirit and scope of the present disclosure.
The present application is a divisional application of U.S. application Ser. No. 15/902,838, filed Feb. 22, 2018, which claims the benefit of U.S. Provisional Application No. 62/517,757, filed Jun. 9, 2017, which are incorporated herein by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
62517757 | Jun 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15902838 | Feb 2018 | US |
Child | 16777566 | US |