DYNAMICALLY ADJUSTING READ VOLTAGE IN A NAND FLASH MEMORY
A NAND flash memory device detects the occurrence of Cell Voltage Distribution Disruption Events (CVDDEs), such as a Partial Block Program (PBP) and Program-Read-Immediate (PRI), and provides a way to dynamically adjust read voltage to account for CVDDEs. A read command includes extended addressing bits that are used when a CVDDE has occurred to access registers that indicate an adjustment to read voltage that is needed to accommodate the CVDDE. The read voltage is then dynamically adjusted to accommodate the CVDDE. When the CVDDE is no longer an issue, the read voltage is adjusted to its previous value before the CVDDE.
1. Technical Field
This disclosure generally relates to flash memory, and more specifically relates to dynamically adjusting read voltage in a NAND flash memory.
2. Background Art
Flash memory is a particular type of non-volatile storage, meaning flash memory does not required power to retain data. NAND flash memory is a particular type of flash memory that defines blocks of data that can be written without writing the entire memory. While NOR flash memory typically provides the capability of writing much smaller blocks, even down to the byte level, NAND flash memory provides much greater density and therefore less cost per bit when compared to NOR flash memory. NAND flash memory has become very popular in applications such as MP3 audio players, digital cameras, and universal serial bus (USB) drives.
There are different types of NAND flash memory according to the storage capability of each flash memory cell. Single-Level per Cell (SLC) can store two distinct states per cell. Multi-Level per Cell (MLC) can store four distinct states per cell. Three-Level per Cell (TLC) can store eight distinct states per cell. The states of the cell are a function of voltage stored on the floating gates of the cell. Thus, a MLC NAND flash memory can store four distinct voltage levels on a cell that are each interpreted as values of two bits in the memory.
SUMMARYA NAND flash memory device detects the occurrence of Cell Voltage Distribution Disruption Events (CVDDEs), such as a Partial Block Program (PBP) and Program-Read-Immediate (PRI), and provides a way to dynamically adjust read voltage to account for CVDDEs. A read command includes extended addressing bits that are used when a CVDDE has occurred to access registers that indicate an adjustment to read voltage that is needed to accommodate the CVDDE. The read voltage is then dynamically adjusted to accommodate the CVDDE. When the CVDDE is no longer an issue, the read voltage is adjusted to its previous value before the CVDDE.
The foregoing and other features and advantages will be apparent from the following more particular description, as illustrated in the accompanying drawings.
The disclosure will be described in conjunction with the appended drawings, where like designations denote like elements, and:
The disclosure and claims herein relate to a NAND flash memory device that detects the occurrence of Cell Voltage Distribution Disruption Events (CVDDEs), such as a Partial Block Program (PBP) and Program-Read-Immediate (PRI), and provides a way to dynamically adjust read voltage to account for CVDDEs. A read command includes extended addressing bits that are used when a CVDDE has occurred to access registers that indicate an adjustment to read voltage that is needed to accommodate the CVDDE. The read voltage is then dynamically adjusted to accommodate the CVDDE. When the CVDDE is no longer an issue, the read voltage is adjusted to its previous value before the CVDDE.
Referring to
The VREAD adjustment mechanism 120 can make an adjustment to read voltage as a result of the page read decoder 126 processing a page read command 180 that includes an address 182 and a CVDDE offset 184. When the page read command 180 does not have a CVDDE offset 184 or when the page read command 180 has a CVDDE offset 184 with a null value, no additional adjustment to read voltage due to CVDDE is performed by the VREAD adjustment mechanism 120. When a page read command 180 includes a CVDDE offset 184 that is not null, the CVDDE offset 184 identifies one of the CVDDE registers 124 the VREAD adjustment mechanism 120 uses to adjust read voltage. Note the magnitude of adjustments needed due to CVDDEs is significantly greater than the magnitude of adjustments needed due to wear or differences in memory cells, typically many times greater. Thus, the CVDDE registers 124 preferably contain adjustments to VREAD that are many times greater in magnitude than the adjustments to VREAD in the VREAD shift registers 122. The values in the CVDDE registers 124 preferably include adjustments to VREAD that are at least twice the magnitude of values in the VREAD shift registers 122.
A memory controller 130 includes an error correction mechanism 140, a CVDDE detection mechanism 150, a VREAD management mechanism 160, a page read command generator 170 and a CVDDE VREAD configuration table 190. The error correction mechanism 140 checks data read from the memory cells 110 to determine whether the data contains any errors. When the data contains errors, the error correction mechanism 140 takes corrective action to correct errors in the data. Any suitable type of error detection and error correction could be performed by the error correction mechanism 140. The CVDDE detection mechanism 150 detects occurrence of Cell Voltage Distribution Disruption Events (CVDDEs), and logs the location of the CVDDE occurrence in a CVDDE occurrence table 152. Examples of known CVDDEs include a Partial Block Program (PBP) and Program-Read-Immediate (PRI). A partial block program occurs when part but not all of a defined block in the flash memory device is programmed. A Program-Read-Immediate occurs when a memory cell is programmed, then immediately followed by a read. Programming a memory cell requires some time for the charge on the floating gate to become evenly distributed on the floating gate. Reading immediately after programming can result in reading before the charge is evenly distributed on the floating gate, which thus requires a different value of VREAD for a read immediately after programming than a normal read. A CVDDE is broadly defined herein to mean any event or condition that can cause a needed adjustment to VREAD that is more than twice than the minor adjustments to VREAD due to wear or differing characteristics of memory cells across the device. The disclosure and claims herein expressly extend to any CVDDE, whether currently known or discovered in the future.
The VREAD management mechanism 160 programs the VREAD shift registers 122 and CVDDE registers 124 with appropriate values so the VREAD adjustment mechanism 120 can make the needed adjustments to read voltage based on the values stored in the VREAD shift registers 122 and CVDDE registers 124. The page read command generator 170 generates page read commands 180 that include an address 182 and may optionally include a CVDDE offset 184. The CVDDE offset 184 is considered an extended address. When the CVDDE detection mechanism 150 detects the occurrence of a CVDDE, the page read command generator 170 generates a page read command 180 that includes a CVDDE offset 184 that identifies which CVDDE register 124 to use for the page read command. When the page read command decoder 126 receives the page read command 180 from the memory controller 130, it reads the CVDDE offset 184. The VREAD adjustment mechanism 120 then knows to apply the adjustment to the read voltage specified in the CVDDE register 124 identified in the CVDDE offset 184.
The CVDDE offset 184 can be missing for page reads that do not need a CVDDE adjustment to VREAD. In the alternative, the CVDDE offset 184 can be present for all page reads, with some defined value, such as all zeroes or all ones, defining a null value that represents no adjustment to VREAD is needed, while other non-null values represent an adjustment that needs to be made to VREAD due to a CVDDE. In one specific implementation, the CVDDE offset 184, when not null, references one of the CVDDE registers 124. The CVDDE offset 184 is determined by reading the CVDDE VREAD configuration table 190. Thus, when a page read command is received by the memory controller 130, the memory controller 130 checks the CVDDE occurrence table 152 to determine whether the address referenced in the page read command has been affected by a CVDDE, and when it has, the memory controller 130 reads the CVDDE VREAD configuration table 190 to determine which CVDDE register 124 corresponds to the address of the page read command. The page read command generator 170 then generates a page read command 180 with the address 182 and the appropriate CVDDE register 124 specified in the CVDDE offset 184. In this manner a page read command 180 includes a CVDDE offset 184 that identifies a CVDDE register that specifies an adjustment to VREAD that needs to be made during the read. Different page read commands 180 can include different CVDDE offsets 184, thereby allowing customizing adjustments to VREAD according to the address of the memory cells being accessed by the page read command. When the memory array receives the page read command 180, the page read command decoder 126 determines whether the CVDDE offset 184 includes a non-null value, and if so, the VREAD adjustment mechanism 120 adjusts the read voltage according to the value in the CVDDE register 124 specified in the CVDDE offset 184 of the page read command 180.
Referring to
The number of programming cycles in a NAND flash memory device can cause the VREAD voltage to shift slightly as a function of the number of programming cycles, which is referred to as “wear” in a NAND flash memory device. However, CVDDEs can cause a more abrupt and drastic shift in the VREAD voltage, as shown by the dotted lines in
Referring to
Referring to
Referring to
Methods 400, 500 and 600 in
In the discussion above, when a page read command 180 has a CVDDE offset 184 that is not null, the VREAD adjustment mechanism 120 reads the CVDDE offset 184, which identifies one of the CVDDE registers 124, and uses the value in the identified CVDDE register 124 to adjust the read voltage. However, other implementations are possible within the scope of the disclosure and claims herein. For example, instead of using the value in the CVDDE register directly, the VREAD adjustment mechanism 120 could copy the value from the CVDDE register into a VREAD shift register 122. In this case, the value in the VREAD shift register would need to be saved before it is overwritten with the value from the identified CVDDE register so it can be restored after the page read command that includes the CVDDE offset has been processed. These and other variations are within the scope of the disclosure and claims herein.
Referring to
Referring to
A simple example is now provided to illustrate some of the concepts discussed above. We assume for this example a Partial Block Program (PBP) has occurred, which is a CVDDE event. We assume there are a total of 8192 pages in the flash memory device, as shown in
Wear is a well-known concept in NAND flash memory devices, which is a function of the number of program-erase cycles on the device. It is well-known that wear in a NAND flash memory device causes a shift in VREAD voltage. It is also well-known to adjust VREAD shift values to account for wear, as shown in
A NAND flash memory device detects the occurrence of Cell Voltage Distribution Disruption Events (CVDDEs), such as a Partial Block Program (PBP) and Program-Read-Immediate (PRI), and provides a way to dynamically adjust read voltage to account for CVDDEs. A read command includes extended addressing bits that are used when a CVDDE has occurred to access registers that indicate an adjustment to read voltage that is needed to accommodate the CVDDE. The read voltage is then dynamically adjusted to accommodate the CVDDE. When the CVDDE is no longer an issue, the read voltage is adjusted to its previous value before the CVDDE.
One skilled in the art will appreciate that many variations are possible within the scope of the claims. Thus, while the disclosure is particularly shown and described above, it will be understood by those skilled in the art that these and other changes in form and details may be made therein without departing from the spirit and scope of the claims.
Claims
1. A method for reading a flash memory device comprising a plurality of blocks of memory cells, each memory cell storing a plurality of voltage values that represent a plurality of bits, the method comprising:
- writing to first registers values that indicate how to change read voltage according to address of memory cells in the flash memory device;
- writing to second registers values that indicate how to change read voltage according to a plurality of Cell Voltage Distribution Disruption Events (CVDDEs);
- changing the values in the first registers and the second registers with detected wear of the flash memory device;
- adjusting read voltage according to the values in the first registers; and
- receiving an indication when a CVDDE has occurred, and in response, adjusting the read voltage according to the values in the second registers.
2. The method of claim 1 wherein the plurality of CVDDEs includes a partial block program when some but not all of the plurality of blocks of memory cells are programmed.
3. The method of claim 1 wherein the plurality of CVDDEs includes a Program-Read-Immediate where memory cells are read immediately after programming.
4. The method of claim 1 further comprising receiving a read command that includes an address of a set of memory cells to be read and an extended address that identifies which of the second registers to use to adjust the read voltage.
5. The method of claim 4 wherein the extended address contains a null value that indicates the extended address does not identify any of the second registers, resulting in not adjusting the read voltage due to CVDDE.
6. The method of claim 1 wherein the second registers contain values of voltage changes that are significantly greater than values of voltage changes in the first registers.
7. The method of claim 1 further comprising detecting wear in the flash memory device as a function of a number of times any of the plurality of blocks of memory cells has been programmed and as a function of bit error rate of any of the plurality of blocks of memory cells.
8. (canceled)
9. The method of claim 1 further comprising a CVDDE occurrence table that logs occurrence of CVDDEs for each of the plurality of blocks of memory cells, wherein detecting when a CVDDE has occurred is done by reading the CVDDE occurrence table.
Type: Application
Filed: Mar 9, 2016
Publication Date: Jun 15, 2017
Inventors: Thomas J. Griffin (Salt Point, NY), Steven J. Hnatko (Fishkill, NY)
Application Number: 15/065,779