Error correction methods that use soft information have been widely adopted to obtain the low levels of Uncorrectable Bit Error Rate (UBER) required for client and enterprise Solid State Drives (SSD's). Error correction methods that use soft information typically require testing sample flash memory devices in a lab to identify Log Likelihood Ratio (LLR) values that indicate the Bit Error Rate (BER) of the tested devices. The LLR's are then stored in tables in each SSD that are used by the memory controller for decoding reads of NAND flash memory chips.
The process of characterizing NAND flash memory chips is expensive and time consuming. In addition, the characteristics of NAND flash memory chips change during the lifetime of the NAND flash memory device, making accurate characterization difficult and requiring the storage of numerous LLR tables. Also, the storage space required for storing the LLR tables adds expense to the SSD.
Accordingly, there is a need for a method and apparatus that will allow for error correction using soft information that does not require lab testing of exemplary NAND flash memory chips and that will provide LLR values that accurately indicate the BER of the NAND flash memory chips.
A method for identifying log likelihood ratio (LLR) values and for decoding codewords using the identified LLR values is disclosed. The method includes programming codewords into nonvolatile memory devices in response to receiving host-requested write instructions and performing background reads of at least one codeword of the programmed codewords in a block of the nonvolatile memory devices at a default threshold voltage, at one or more threshold voltage offset that is less than the default threshold voltage and at one or more threshold voltage offset that is greater than the default threshold voltage. The results of the background reads are stored and at least one of the background reads is decoded to identify the codeword(s). A set of LLR values are identified using the stored read results and the identified codeword(s) and the process of performing background reads, storing, decoding and the identifying is repeated to identify a set of LLR values for each block of the nonvolatile memory devices and to identify updated sets of LLR values. Host-requested reads are performed and the host-requested reads are decoded using LLR values from the updated set of LLR values corresponding to the block that was read in the host-requested read.
A nonvolatile memory controller includes a write circuit coupled to a plurality of nonvolatile memory devices, the write circuit configured to program codewords into each of the nonvolatile memory devices in response to receiving host-requested write instructions. A read circuit is configured to perform background reads of at least one of the programmed codewords in a block of the nonvolatile memory devices at a default threshold voltage, at one or more threshold voltage offset that is less than the default threshold voltage and at one or more threshold voltage offset that is greater than the default threshold voltage. A decoder circuit is configured to decode at least one of the background reads to identify the codeword(s). A LLR circuit is configured to identify a set of LLR values corresponding to the default threshold voltage using the read results and the identified codeword(s). The nonvolatile memory controller continues to perform the background reads, to decode at least one of the background reads, and to identify sets of LLR values, to identify a set of LLR values for each block of the nonvolatile memory devices and to identify updated sets of LLR values during the lifetime of the nonvolatile memory system. A read circuit is configured to perform host-requested reads of the nonvolatile memory devices and a decoder circuit decodes the results of the host-requested read using LLR values from the updated set of LLR values corresponding to the block that was read in the host-requested read.
A nonvolatile memory system is disclosed that includes a plurality of nonvolatile memory devices, a nonvolatile memory controller that is coupled to the nonvolatile memory devices, a write circuit, a read circuit, and a log likelihood ratio (LLR) circuit. The write circuit is configured to program the nonvolatile memory devices to store the user data in the nonvolatile memory devices in response to receiving host-requested write instructions that include user data. The read circuit is configured to perform background reads of representative pages of a page group at a default threshold voltage within each threshold voltage region required to read the representative pages, at one or more threshold voltage offset that is less than the default threshold voltage within each threshold voltage region required to read the representative pages and at one or more threshold voltage offset that is greater than the default threshold voltage within each threshold voltage region required to read the representative pages. The decoder circuit is configured to decode the results from some of the background reads of representative pages to identify codewords stored in the representative pages. The LLR circuit is configured to identify a set of LLR values corresponding to each threshold voltage region required to read the representative pages using the read results and the identified codewords. The read circuit is configured to continue to perform the background reads and to decode the results from some of the background reads, and the LLR circuit is configured to continue to identify sets of LLR values, to identify a set of LLR values corresponding to each threshold voltage region required to read the representative pages of each page group and is further configured to continue to perform the background reads and to identify updated sets of LLR values. The read circuit is configured to perform host-requested reads of the nonvolatile memory devices and the decoder circuit is configured to decode the results of the host-requested reads using LLR values from the updated set of LLR values corresponding to the page group of the page that was read in the host-requested read.
The method and apparatus of the present invention allows for error correction using soft information obtained during operation of the nonvolatile memory system and does not require lab testing of sample NAND flash memory chips to generate LLR tables for different time periods during the lifetime of the nonvolatile memory devices. In addition, by performing LLR calculations on the actual NAND device being used, and by continuing to perform background testing as the NAND device ages, the methods and apparatus of the present invention provide LLR values that accurately indicate the error probability during the entire lifetime of the nonvolatile memory system. This reduces bit error rate (BER) and extends the useful life of the NAND flash memory chips. In addition, the number of read errors is reduced, resulting in reduced read latency.
The accompanying drawings are included to provide a further understanding of the invention, and are incorporated in and constitute a part of this specification. The drawings illustrate embodiments of the invention and, together with the description, serve to explain the principles of the invention.
A nonvolatile memory system 1 is shown in
Nonvolatile memory controller 11 is configured to receive read and write instructions from a host computer through host connector receptacle 12 of
Each nonvolatile memory device 20 may be a packaged semiconductor die or “chip” that is coupled to nonvolatile memory controller 11 by conductive pathways that couple instructions, data and other information between each nonvolatile memory device 20 and nonvolatile memory controller 11. In the embodiment shown in
Referring now to
In the embodiment shown in
Threshold voltage shift reads are performed by sending a threshold voltage shift read instruction to a NAND device 20 that includes one or more read offset value that is to be used by the NAND device 20 in performing the read. Read offset values, which may also be referred to hereinafter as simply “offset values” or “offsets,” indicate the amount by which the threshold voltage that is used to perform the read is to be offset from a corresponding default threshold voltage specified by the manufacturer of the NAND device 20. The term “default threshold voltage,” as used in the present application is a threshold voltage established by the manufacturer of nonvolatile memory device 20 for performing a conventional read operation such as a READ instruction or a READ PAGE instruction. Typically this is identical with the threshold voltage of a threshold voltage shift read at an offset of 0. For MLC or TLC nonvolatile memory devices 20, there will be multiple default threshold voltages.
In the present embodiment NAND devices 20 are capable of performing a wide range of threshold voltage shift reads, including reads specified by whole number offset values such as −2, −1, 0, +1, +2, without limitation. For multi-level cell (MLC) NAND devices and triple level cell (TLC) NAND devices, reads are required at more than one threshold voltage to identify the value of a particular bit. Therefore, threshold voltage shift read instructions for MLC NAND or TLC NAND devices 20 will include two or more read offset values, one read offset value for each threshold voltage region required to identify the particular bit being read. In response to receiving a threshold voltage shift read instruction that includes the required read offset values, NAND device 20 is operable to perform reads at threshold voltages corresponding to the indicated read offset values to generate output that indicates the read results.
An erased block of a NAND 20 may be referred to as a “free block.” When data is programmed into a block the block is referred to as an “open block” until all pages of the block have been programmed. Once all pages of the block have been programmed the block is referred to as a “closed block” until it is erased.
Nonvolatile memory controller 11 includes write circuit 2, memory storage 4, a status circuit 3 that is coupled to a read circuit 9, a background reference positioning (BRP) circuit 6 that is coupled to status circuit 3 and to read circuit 9, a decoder circuit 8 that is coupled to read circuit 9 and a Log Likelihood Ratio (LLR) circuit 7. LLR circuit 7 is coupled to BRP circuit 6, to read circuit 9 and to memory storage 4 and is operable to calculate LLR's that are used by decoder circuit 8 for decoding reads of nonvolatile memory devices 20. For clarity the various couplings are not shown.
Status circuit 3 is configured to determine usage characteristics of nonvolatile memory devices 20. The determined usage characteristics may be stored in memory storage 4 of nonvolatile memory controller 11. Alternatively, the determined usage characteristics can be stored in one or more nonvolatile memory devices 20 or in a separate volatile memory device 13. The term “usage characteristic” as used in the present invention is a value determined during usage of a nonvolatile memory device that indicates the historical usage of the nonvolatile memory device up to a particular point in time which may be, without limitation, the number of program and erase cycles or the bit error rate (BER) of a block or a group of blocks of a nonvolatile memory device 20.
Read circuit 9 is configured to perform background reads of at least one of the programmed codewords in a block of the nonvolatile memory devices at a default threshold voltage, at one or more threshold voltage offset that is less than the default threshold voltage and at one or more threshold voltage offset that is greater than the default threshold voltage. Decoder circuit 8 is configured to decode at least one of the background reads to identify at least one codeword. LLR circuit 7 is configured to identify a set of LLR values corresponding to the default threshold voltage using the read results and the identified codeword(s). Read circuit 9 is configured to perform host-requested reads of the nonvolatile memory devices and decoder circuit 8 is configured to decode the results of the host-requested reads using LLR values from the updated set of LLR values corresponding to the block that was read in the host-requested read.
A plurality of background reads of a codeword are performed 109. The term “background read,” as used in the present invention, is any read performed in such a manner so as to not interfere with host-requested operations that are currently pending at nonvolatile memory controller 11 and the term specifically includes reads performed in such a manner so as to not delay pending host-requested reads (e.g., those reads that do not affect latency), and the term specifically includes reads that are assigned a priority that is less than the priority assigned to host-requested reads so that priority is given to any pending host-requested read (e.g., the pending host-requested read is performed first), and specifically includes reads performed at a time at which there are no pending host-requested reads. It is appreciated that host-requested write operations and host-requested erase operations can be stored by nonvolatile memory controller 11 and performed at a later time without affecting latency of SSD 1. Accordingly, in embodiments of the present invention, “background reads” are reads that are performed so as to not delay performance of host-requested reads, without consideration of pending host-requested write operations or pending host-requested erase operations unless storage of pending host-requested write operations or pending host-requested erase operations is near storage capacity.
In the present embodiment, once a codeword is identified to be read in step 109, a plurality of background reads are performed within each threshold voltage region that is required for reading the codeword, including a read at a default threshold voltage, a read at a threshold voltage offset that is less than the default threshold voltage, and a read at a threshold voltage offset that is greater than the default threshold voltage. The results of the background reads are then stored. The programmed codeword is identified using the background reads as shown by step 110. The codeword may be identified by decoding one of the background reads of step 109.
Referring now to
In the embodiment shown in
In the embodiment shown in
A set of LLR values is identified 111 for each default threshold voltage using the stored read results and the identified CW. The identified set of LLR values is then stored 112. In the example shown in
Following is an example in which the LLR for region A (LLR_A) is calculated using the equation:
which may be calculated using a logic function, where ˜ indicates bitwise NOT and where & indicates bitwise AND, and in which the numerator bit values=(˜(CW) & R_N) and the denominator bit values=(CW & R_N). A count of bits having a value of 1 in the calculated numerator bit values, shown as step 206, gives a numerical value that may be represented by the logic: NUM=count (˜(CW) & R_N). A count of bits having a value of 1 in the calculated denominator bit values, shown as step 207, gives a numerical value that may be represented by the logic: DEN=count (CW & R_N). As shown by step 208 the count of step 206 is divided by the count of step 207. The log of the results of the division of step 208 is calculated as shown by step 209.
As shown by steps 210, 211, 213 Z is incremented and the process is repeated to calculate the LLR for region B LLR_B using the equation:
which may be calculated using a logic function in which the numerator N=count (˜(CW) & R & ˜(R_N)) and the denominator DEN=count (CW & R & ˜(R_N)).
The LLR for region C LLR_C may be calculated using the equation:
which may be calculated using a logic function in which the numerator NUM=count (˜(CW) & ˜(R) & R_P) and the denominator DEN=count (CW & ˜(R) & R_P).
As shown by steps 210, 211, 213 Z is incremented and the LLR for region D LLR_D may be calculated using the equation:
which may be calculated using the logic function: NUM=count (˜(CW) & ˜(R_P)) and DEN=count (CW & ˜(R_P)). At step 211 Z=3, indicating that all LLR values have been calculated so the process ends 212.
In one embodiment that is illustrated in
Following is an exemplary calculation of LLR_A in which the read at the default threshold voltage 15 produces read results R, a codeword CW, R_N and R_P.
CW=00010101011111000
R=00110101111110000
R_N=00110101111110110
R_P=00110101100010000.
In this example, the numerator bit values=(˜(CW) & R_N)=00100000100000110 and the count of 1's in the numerator bit values NUM=4. The denominator bit values=(W & R_N)=00010101011111000 and the count of 1's in the denominator bit values DEN=8, giving a LLR_A=log(4/8).
In embodiments of the present invention more than one codeword is read in step 109 of
In embodiments of the present invention blocks are divided into logical pages and a logical page is the smallest amount of data that can be programmed. In this embodiment, each codeword is a logical page or a part of it. Accordingly, the set of LLR values used to decode each read of a page will be the set of LLR values for the block that includes the page being read. In particular, step 109 will perform background reads of one or more representative page of each block and steps 110-111 will identify a set of LLR values for each default threshold voltage region required to read the representative pages of the block.
In one exemplary embodiment in which SSD 1 includes 128 nonvolatile memory devices 20, each of which includes 2048 blocks, blocks may be assigned block numbers 0 through 262,143. In this embodiment, LLR table 10 may include block numbers and a set of LLR values corresponding to each block number, with the LLR values to be used in decoding determined by indexing the LLR table with the block number of the page that is being decoded.
The steps of performing background reads 109 and storing the results, decoding of at least one of the background reads to identify a codeword 110, and the identifying a set of LLR values 111 are continued in order to identify a set of LLR values for each block of the nonvolatile memory devices. The identified sets of LLR values may be stored 112 in LLR table 10 along with the corresponding block number. Accordingly, in the embodiment in which SSD 1 includes 128 nonvolatile memory devices 20, each of which includes 2048 blocks, the table includes 262,144 sets of LLR values and corresponding block number indexes from 0 to 262,143.
The process of steps 109-112 continues throughout the lifetime of SSD 1, identifying updated sets of LLR values. As each updated set of LLR values is identified it is stored in LLR table 10 by overwriting any previously stored corresponding set of LLR values. For example, when an updated set of LLR values is identified for a particular block, the previously determined set of LLR values for that block that was stored in LLR table 10 is overwritten by the updated set of LLR values. Accordingly, LLR table 10 will always include the most recently determined set of LLR values for each block.
In one embodiment, steps 109-112 are only performed on blocks that are closed (while the blocks are closed). In another embodiment steps 109-112 are only performed on blocks that are closed and only on the occurrence of one or more of an endurance event, a retention timer event and a read disturb event. Thereby, background reads are performed frequently enough to maintain accurate sets of LLR values for each block, but not so often as to negatively impact latency of the SSD 1.
In an embodiment of the present invention, when SSD 1 is assembled and operation of SSD 1 is first initiated, no LLR table is stored in SSD 1. In this embodiment, nonvolatile memory controller 11 is operable to identify the characteristics of each nonvolatile memory device 20 that it is coupled to and is operable to determine, in an automated fashion (without any user input) the number of blocks on each nonvolatile memory device 20, and is operable to assign a unique number to each block (block number). The process of steps 109-112 is also performed in an automated manner (without user input) after assembly of SSD 1, during operation of SSD 1 by a user of SSD 1, to create and update a single LLR table 10. In this embodiment, the values in LLR table 10 are calculated after assembly of SSD 1, after the first initialization of SSD 1, and LLR table 10 is constructed in its entirety after the first initialization of SSD 1, which may be after SSD 1 has been shipped to a user of SSD 1.
When no host-requested reads are pending 103, 123, normal operation of the nonvolatile memory device is continued, with steps 109-112 performed in the background so as not to affect the latency of nonvolatile memory system 1. When a host-requested read instruction is received and a LLR has been calculated for the block to be read, the host-requested read is performed 105. The host-requested read may be performed using a threshold voltage shift read instruction at different offset values to obtain the hard-read results and soft information. The term “soft information,” as used in the present application, is information indicating the results of one or more reads at a threshold voltage less than the default threshold voltage and one or more reads at a threshold voltage greater than the default threshold voltage. In the present embodiment step 105 is performed by read circuit 9. The results of the host-requested read are decoded 106 using LLR values from the updated set of LLR values corresponding to the block that was read in the host-requested read. Accordingly, when nonvolatile memory devices are SLC devices, each codeword is decoded using LLR values from the sets of LLR values corresponding to the default threshold voltage used to perform the host-requested read. In the present embodiment step 106 is performed by decoder circuit 8, which will use the most recently determined set of LLR values in LLR table 10 to perform the decoding (i.e., either the initial set of LLR values calculated for the block that was read or the most recently updated set of LLR values for the block that was read).
During the early life of SSD 1, reads may be required for a codeword for which the LLR has not yet been calculated 104, 107. In that event, the read is performed using a conventional read instruction such as a READ PAGE instruction (a hard read) and decoding is performed using a default set of LLR values. Since this will only be required during early in the lifetime of the SSD 1, reads at the default threshold voltage are not likely to result in read errors, even when inaccurate LLR values are used. It has been found that, during this period, as long as LLR values that are close to 0 are not used, decoding is successful. In one embodiment, for LLR regions to the left of the default threshold voltage any negative number from −6 to −15 can be used to perform decoding and for LLR regions to the right of the default threshold voltage any positive number from +6 to +15 can be used to perform decoding. In one exemplary embodiment in which 2 LLR regions are used, in step 108 the default set of LLR values is LLR_A=−6, LLR_B=+6.
Alternatively, a threshold voltage shift read can be used to perform the read of step 107 to obtain the hard-read results and soft information. In an embodiment in which 4 LLR regions are used, in step 108 the default set of LLR values is LLR_A=−6, LLR_B=−6, LLR_C=+6 and LLR_D=+6. In this embodiment, all host-requested reads are performed using a threshold voltage shift read instruction. Thereby, specialized logic is not required for determining whether a LLR has been calculated for the block of the page that is being read.
Accordingly, in an embodiment in which nonvolatile memory device system 1 includes 128 SLC nonvolatile memory devices and 2048 blocks per nonvolatile memory device, system 1 will include 262,144 (128×2048) sets of LLR values. In the embodiment of
Method 100 calculates sets of LLR values during the life of each nonvolatile memory device 20, these sets of LLR values being specific to the nonvolatile memory device itself, and the sets of LLR values are continually updated during the entire lifespan of the nonvolatile memory device 20. Therefore, an accurate set of LLR values is always available for use in decoding. In addition, because a set of LLR values is calculated and repeatedly updated for each block and is used for decoding codewords stored in that particular block, variations between the error characteristics of the different blocks are taken into account during the entire lifetime of the nonvolatile memory system, giving superior uncorrectable bit error rate (UBER) than is obtained using prior art methods. In addition, by calculating LLR values during the operation of the nonvolatile memory device 20, and after the nonvolatile memory controller 11 has been sold to a customer and integrated into a nonvolatile memory system 1, the need for testing test chips similar to nonvolatile memory devices 20 in a test lab to generate LLR tables for different periods of the lifetime of the nonvolatile memory devices 20 is avoided, and the need to store pre-generated LLR tables for different periods of the lifetime of the SSD 1 on the nonvolatile memory system is avoided. Though the above embodiments calculated LLR values for only four regions it is appreciated that LLR values could be calculated for more regions. In the example shown in
In one alternate embodiment in which all host-requested reads 105, 107 are performed using a threshold voltage shift read instruction to obtain soft information, after initialization of SSD 1 a LLR table 10 is automatically generated in which all LLR values are set to an identical default set of LLR values. In an embodiment in which 4 LLR regions are used, the default set of LLR values for each block is LLR_A=−6, LLR_B=−6, LLR_C=+6 and LLR_D=+6. In an embodiment in which 6 LLR regions are used, the default set of LLR values for each block is LLR_A=−6, LLR_B=−6, LLR_C=−6, LLR_D=+6, LLR_E=+6 and LLR_F=+6. These initial LLR values are then updated during the lifetime of SSD 1 using method 100.
Multi-Level Cell (MLC) and Triple-Level Cell (TLC) nonvolatile memory devices 20 require reads at more than one threshold voltage region to identify the value of a bit. When nonvolatile memory devices 20 are MLC or TLC devices, in step 109 background reads of representative pages of a block are performed at a default threshold voltage within each threshold voltage region required to read the representative pages, at one or more threshold voltage offset that is less than the default threshold voltage within each threshold voltage region required to read the representative pages and at one or more threshold voltage offset that is greater than the default threshold voltage within each threshold voltage region required to read the representative pages. In this embodiment, in step 111, a set of LLR values corresponding to each threshold voltage region required to read the representative pages is identified using the stored read results and the identified codeword(s). The process of steps 109-111 is continued to identify a set of LLR values corresponding to each threshold voltage region required to read the representative pages of each block (e.g., to create an initial LLR table 10), and the process of steps 109-112 is continued throughout the lifetime of SSD 1 to identify an updated set of LLR values corresponding to each threshold voltage region required to read the representative pages. Host-requested reads are performed 105 using the most recent updated set of LLR values corresponding to the block that was read in the host-requested read.
In the exemplary embodiment shown in
In the present example, the default threshold voltage for region 1 and the default threshold voltage for region 5 are the default threshold voltages for regions 1 and 5 corresponding to a threshold voltage offset of 0. Threshold voltage region 5 is selected first for calculating LLR values. In the example shown in
Referring now to
The following are exemplary equations that may be used for calculating 4-region LLR values for a lower page of a TLC NAND for region 1:
Following are exemplary equations that may be used for calculating LLR for a lower page of a TLC NAND for region 5:
In the above example, a single set of LLR values is obtained and updated for each block and is stored along with the block number of the exemplary page that was used to calculate LLR values.
Though maintaining an updated set of LLR values for each block using method 100 provides superior UBER as compared to conventional methods, it has been found that there is often variation in BER within blocks, with certain pages of each block having common BER characteristics. Accordingly, in embodiments of the present invention pages of each block are divided into page groups, with the pages within each page group having similar BER characteristics.
In one embodiment, each block 22 of each nonvolatile memory device 20 is divided into page groups that include pages having similar error characteristics. The LLR table 10 may include an index that identifies each page group, which may be, for example a numerical value from 1 to 3,145,728 (128×2048×12), which will identify both the page group and the block and the nonvolatile memory device 20 (since all page groups within all nonvolatile memory devices 20 of SSD 1 will have a unique index). The page group index is stored in LLR table 10 along with the corresponding LLR values for each voltage region required to read the pages of the page group. When the nonvolatile memory devices 20 are SLC devices, step 109 includes performing background reads of representative pages of a page group at a default threshold voltage, at one or more threshold voltage offset that is less than the default threshold voltage and at one or more threshold voltage offset that is greater than the default threshold voltage. In step 110 one or more codeword is identified 110 and step 111 is performed by identifying a set of LLR values for each page group using the read results and the codeword(s) identified in step 110. In step 106, the results of the host-requested reads are decoded using LLR values from the set of updated LLR values corresponding to the page group of the page that was read. In this embodiment method 100 may include generating LLR table 10 and storing 112 each of the identified sets of LLR values in LLR table 10 along with an index identifying the corresponding page group. Each time that an updated set of LLR values is identified in step 111, the updated set of LLR values is stored in LLR table 10 by overwriting the corresponding set of LLR values previously stored in the LLR table. Thus, the decoding of step 106 may include indexing the LLR table using an index value corresponding to the page group of the page that was read.
When nonvolatile memory devices 20 are MLC or TLC devices, page groups may be identified by splitting wordlines into topological types (upper pages, middle pages and lower pages) and in categories according to their topological behavior, i.e. error characteristics vs physical position inside the block. In the present embodiment, topological behavior is categorized by assigning different wordlines to different categories. Categories may be determined in a flash lab during a characterization phase where topological position vs error behavior is studied. In one illustrative embodiment wordlines are grouped into the following categories:
It can be seen that different wordline groups do not necessarily include the same number of wordlines or the same number of memory cells. In the present embodiment wordline groups are determined by analyzing the characteristics of NAND devices in a lab to identify groupings that have similar error behavior. In the present illustrative embodiment, nonvolatile memory devices 20 are TLC NAND devices in which each memory cell can store three different bits of information. Since there are three page types in a TLC NAND device, this gives the following page groups:
Accordingly, in an embodiment in which nonvolatile memory device system 1 includes 128 nonvolatile memory devices and 2048 blocks per nonvolatile memory device, system 1 will include 3,145,728 (128×2048×12) page groups (when blocks are not grouped into block groups as will be subsequently described).
When nonvolatile memory devices 20 are MLC or TLC devices, in step 109 background reads of representative pages of a page group are performed at a default threshold voltage within each threshold voltage region required to read the representative pages, at one or more threshold voltage offset that is less than the default threshold voltage within each threshold voltage region required to read the representative pages and at one or more threshold voltage offset that is greater than the default threshold voltage within each threshold voltage region required to read the representative pages. In this embodiment, in step 111, a set of LLR values corresponding to each threshold voltage region required to read the representative pages is identified using the stored read results and the identified codeword(s). The process of steps 109-112 is repeated to identify a set of LLR values corresponding to each threshold voltage region required to read the representative pages of each page group (e.g., to create a complete initial LLR table 10), and the process of steps 109-112 is continued throughout the lifetime of SSD 1 to identify updated sets of LLR values corresponding to each threshold voltage region required to read the representative pages. Host-requested reads are performed 105 using the most recent updated set of LLR values corresponding to the page group of the page that was read in the host-requested read.
In one embodiment, for MLC and TLC nonvolatile memory devices, the LLR values for each voltage region required to read a page of the page group are concatenated and stored in the LLR table so that each of the sets of concatenated LLR values is associated with a single page group index. In step 106 each codeword is decoded using LLR values from the sets of LLR values corresponding to the page group of the page being read. For example, if a page within the first page group of the second block is being read and decoded that requires reads in threshold voltage regions 1 and 5 (a lower page), the index for the first page group of the block is identified and is used to index the LLR table (e.g., index 2049) to obtain the sets of LLR values LLR_1A, LLR_1B, LLR_1C, LLR_1D, LLR_5A, LLR_5B, LLR_5C, LLR_5D.
In the above example, 4 LLR regions are calculated for each threshold voltage region. When 6 voltage regions are used to calculate LLR, as shown in
In one alternate embodiment, in addition to grouping pages, blocks are grouped to reduce the number of page groups that need to be managed. For example, the blocks of each nonvolatile memory device may be divided into 32 block groups that may correspond to channels of nonvolatile memory system 1, reducing the number of page groups of each nonvolatile memory device 20 to 768 and reducing the number of page groups in nonvolatile memory system 1 to 98,304. In
When blocks are open the time that the block is open is determined and the open block is closed if the block open time exceeds a predetermined threshold (e.g., 1 hour) to make sure that blocks do not stay open too long. The block may be closed by programming all unprogrammed pages of the open block with dummy data. Also, in embodiments of the present invention, if the block read count exceeds a predetermined open-block read count threshold (e.g., 150,000 reads) the block is sent to reclamation and is copied and erased to prevent read errors in the open block.
When a block is closed 313 a block retention timer is started 314. In the embodiment shown in
Upon the occurrence of one or more of an endurance event 315, a retention timer event 316 and a read disturb event 317 at the closed block, a LLR operation is performed as shown by steps 309-312. In the embodiment shown in
Once a page is identified to be read, for MLC and TLC nonvolatile memory devices 20, background reads of representative pages of each page group of a closed block are performed 309 by read circuit 6 at one or more default threshold voltages, at one or more threshold voltage offset that is less than each of the default threshold voltages and at one or more threshold voltage offset that is greater than each of the default threshold voltages. The codewords in the representative pages are identified 310, decoder circuit 8 is configured to decode one of the reads of the exemplary pages of each page group to identify at least one codeword in each page group, and LLR circuit 7 is configured to identify at least one set of updated LLR values for each page group 311 using the read results and the identified codeword(s) in each page group, and the calculated sets of LLR values are stored 312.
Background LLR operations 309-312 continue to be performed on endurance, retention timer and read disturb events as long as a block is closed as shown by line 323, calculating an initial set of LLR values for each page group and continuing to perform steps 309-312 to identify updated sets of LLR values during the lifetime of SSD 1. When the block becomes free 320, such as when the block is erased, background LLR operations 309-312 are no longer performed as shown by line 322 until the block is again closed 313. Host-requested reads 318 are performed by read circuit 9, and decoder circuit 8 decodes 308 the results of each host-requested read using LLR values from the updated set of updated LLR values corresponding to the page group of the page that was read in the host-requested read.
In the present embodiment, a single set of LLR values is calculated for each threshold voltage region required to read a page of a page group and the single set of LLR values is updated during the lifetime of the SSD 1 by overwriting the previously stored LLR values for the particular page group as updated LLR values are calculated. This can be a single LLR table 10 that is repeatedly updated during the lifetime of the SSD 1. For example, the single LLR table 10 of method 100 may include, for each block of SSD 1, a block index and a single set of concatenated LLR values that includes all of the sets of LLR values required to decode a page of the corresponding block. The single LLR table 10 of method 300 includes, for each page group of the SSD 1, a page group index and a single set of concatenated LLR values that includes all of the sets of LLR values required to decode a page of the corresponding page group. The single LLR table 10 for an embodiment that uses block groups and page groups will include, for each page group, a page group index and a single set of concatenated LLR values that includes all of the sets of LLR values required to decode a page of the corresponding page group. The methods and apparatus of the present invention do not store sets of LLR values for different points in the lifetime of the nonvolatile memory devices as is required in prior art systems. Therefore, the method and apparatus of the present invention requires less storage space than prior art SSD's that store multiple sets of LLR values that are used at different points in the lifetime of the SSD.
In one alternate embodiment in which all host-requested reads (steps 105, 107, 307) are performed using a threshold voltage shift read instruction to obtain soft information (or any other type of read instruction that provides soft information), after assembly of SSD 1, and upon initialization of nonvolatile memory controller 11 a LLR table is automatically generated (without user input) by querying the nonvolatile memory devices 20 to identify the characteristics of nonvolatile memory devices 20 to generate and store in the LLR table a unique page group index for each page group and a default set of LLR values for the page group. In an embodiment in which 4 LLR regions are used, the default set of LLR values for each page group is LLR_A=−6, LLR_B=−6, LLR_C=+6 and LLR_D=+6, with all page groups including an identical set of default values when the table is initially generated. In an embodiment in which 6 LLR regions are used, the default set of LLR values for each page group is LLR_A=−6, LLR_B=−6, LLR_C=−6, LLR_D=+6, LLR_E=+6 and LLR_F=+6. In this embodiment, as new LLR values are generated the default sets of LLR values are replaced by the updated LLR values.
In the present embodiment, the host-requested reads of steps 105, 107 and 307 are performed using a threshold voltage shift read instruction. However, it is appreciated that some nonvolatile memory devices 20 may be capable of performing soft reads using other types of instructions. In these embodiments, the soft read instruction for the particular type of nonvolatile memory device 20 of SSD 1 can be used to generate read output plus soft information to be used in the decoding process.
At least one set of updated offsets are identified 414 for each block (or each page group) of each nonvolatile memory device 20 using the errors identified in each read. This may be done by adding the errors from each read at an offset to a threshold voltage to obtain an error sum and determining for each threshold voltage an error sum having the least number of errors. The updated offset value in each set of updated offsets is then identified to be equal to the value of the offset of the error sum having the least number of errors. Because the updated offset value is identified using background reads using a process that may be referred to as “a reference positioning process,” the updated offset value may also be referred to hereinafter as a “background reference positioning offset value” or “BRP offset value” and a set of updated offsets may be referred to hereinafter as “set of background reference positioning offsets” or “set of BRP offsets.” In the present embodiment step 414 is performed by BRP circuit 6.
A set of LLR values is identified 416 for each BRP offset value in the set of BRP offsets for each block (or page group) of each nonvolatile memory device 20 using the stored read results from step 412 and the codeword identified in step 413. In the present embodiment step 416 is performed by LLR circuit 7 shown in
When no host-requested reads are pending as shown by step 403, normal operation of the nonvolatile memory device is continued, with steps 411-416 performed in the background so as not to affect the latency of nonvolatile memory system 1. When a host-requested read instruction is received and a LLR has been calculated for the block (or page group) to be read, the host-requested read is performed using a threshold voltage shift read instruction at the identified offset producing the lowest total number of errors corresponding to the block (or page group) of the codeword being read. The host-requested read may be performed using a threshold voltage shift read instruction at an offset value equal to each BRP offset value in the set of BRP offsets corresponding to the block (or page group) being read and with soft information offset values centered around the BRP offset value (e.g., reads at BRP offset −1, at BRP offset 0 and at BRP offset +1). In the present embodiment step 405 is performed by read circuit 9.
The codeword is decoded 406 using LLR values from the sets of LLR values calculated in step 416. Thus, each codeword is decoded using LLR values from the sets of LLR values corresponding to the BRP offset used to perform the host-requested read. In the present embodiment step 406 is performed by decoder circuit 8. During the early life of SSD 1 reads may be required for a codeword for which the LLR has not yet been calculated 404, 407. In that event, the read is performed using a conventional read instruction such as a READ PAGE instruction (a hard read) and decoding is performed using a default set of LLR values. Alternatively, the read is performed using threshold voltage shift read instructions centered around the BRP offset value to obtain read results and soft information at the BRP offset value. Since this will only be required during early in the lifetime of the SSD 1, reads at the default threshold voltage are not likely to result in read errors, even when inaccurate LLR values are used. It has been found that, during this period, as long as LLR values close to 0 are not used, decoding is successful. In one embodiment, for LLR regions to the left of the BRP any negative number from −6 to −15 can be used to perform decoding and for LLR regions to the right of the BRP any positive number from +6 to +15 can be used to perform decoding. In one exemplary embodiment, in step 408 the default set of LLR values is LLR_A=−6, LLR_B=−6, LLR_C=+6 and LLR_D=+6.
In an embodiment in which page groups are used, BRP circuit 6 performs background reads of a codeword at offsets to the threshold voltages required to read the codeword to identify the offset producing the lowest total number of errors and is configured to set the BRP offset value to equal the corresponding offset producing the lowest total number of errors so as to identify a single of BRP offset for each page group and a single set of LLR values for each page group when nonvolatile memory devices 20 are SLC devices. When the nonvolatile memory device 20 is a MLC or TLC nonvolatile memory device, in step 414 there will be more than one BRP offset for each page group and step 416 will identify more than one set of corresponding LLR values, which may be concatenated and stored as a combined LLR value set. Accordingly, each combined LLR value set will include all LLR values required to decode a MLC or TLC codeword. In the embodiment shown in
When no host-requested reads are pending, normal operation of the nonvolatile memory device is continued, with steps 411-417 performed in the background so as not to affect the latency of nonvolatile memory system 1. When one or more host-request read instruction is received at host connector receptacle 12, a host-requested read of a codeword stored in the nonvolatile memory device 20 is performed using a threshold voltage shift read instruction at offset values equal to the BRP offset value(s) in the set of BRP offsets corresponding to the block (or page group) being read. In one embodiment BRP circuit 6 is configured to store, in memory storage 4, each identified offset producing the lowest total number of errors as a BRP offset value in a BRP table that includes each identified BRP offset value and corresponding index values (e.g., a block number or page group number), and the read circuit 9 is configured to identify BRP offset values to be used in the host-requested reads by indexing the BRP table using an index value corresponding to the block (or page group) of the page being read. In one embodiment steps 411-417 are repeated to store a BRP offset value for each block (or page group) of nonvolatile memory devices 20, and are further repeated to identify updated BRP offset values. Each time that an updated BRP offset value is identified, the updated BRP offset value may be stored in the BRP table by overwriting any previously stored BRP offset value for the corresponding block (or page group). When nonvolatile memory devices are MLC or SLC devices steps 411-417 are repeated to store more than one BRP offset value for each block (or page group) of nonvolatile memory devices 20 (as a set of BRP offsets), and are further repeated to identify updated offset values.
The codeword is decoded 406 using LLR values from the sets of LLR values calculated in step 416. Each codeword may be decoded using LLR values from the sets of LLR values corresponding to the block of the page being read. In one embodiment LLR circuit 7 is configured to store, in the memory storage 4, a single LLR table 10 that includes each of the identified sets of LLR values and corresponding index values, and decoder circuit 6 is configured to identify LLR values to be used in the host-requested reads by indexing the LLR table using an index value corresponding to the block (or page group) of the page being read.
In embodiments of the present invention, steps 411-417 of method 400 are only performed on blocks that are closed, while the particular block is closed, so as to incrementally update BRP offset values and LLR values during the lifetime of the SSD 1. Steps 411-417 may be performed upon the occurrence of particular events, such as upon the occurrence of a certain time period or number of program and erase cycles. In one embodiment, steps 411-417 are only performed upon the occurrence of one or more of an endurance event, a retention timer event and a read disturb event at a closed block and are only performed on the block that is closed during the time period in which the block is closed. Thereby, BRP offset values and LLR values are updated frequently enough so as to maintain accurate sets of BRP offset values and accurate sets of LLR values, but not so often as to negatively impact latency of SSD 1. In one embodiment that is illustrated in
When read requests are received from the host 305, 318, host-requested reads are performed 507 using a threshold voltage shift read instruction and using the set of updated read offset values corresponding to the page group of the page being read. The reads are decoded 508 using the LLR values corresponding to the threshold voltage region and page group of the page being read. When a LLR has not yet been calculated for the page group of the page being read a default set of LLR values can be used in the same manner as discussed in method 400.
Background reads of representative pages of each page group of a closed block are performed 511, at offsets within each threshold voltage region that is required for reading the representative pages of the closed block. Errors in the background reads of representative pages are identified and BRP offset values are identified 514 to identify an updated set of BRP offset values for each page group of the closed block. In the SLC case, since each updated set of BRP offset values will include a single BRP offset value so a single set of LLR values is identified in step 516. Steps 511-517 continue to be performed on endurance, retention timer and read disturb events as long as a block is closed as shown by line 323, incrementally identifying BRP offset values and sets of LLR values until BRP offset values and LLR values have been identified for all page groups, and steps 511-517 are continued during the operational lifetime of SSD 1 to identify updated BRP offset values and updated sets of LLR values. When the block becomes free 319, 323, such as when the block is erased, steps 511-517 are no longer performed as shown by line 322 until the block is again closed 313.
Offsets to threshold voltages required to read the representative pages are set 602 to the offset determined in a previous background reference positioning operation. If no previous background reference positioning operation has been performed, all threshold voltage offsets are set to zero. One of the threshold voltages required to read the representative pages is then identified to be updated 603. In one embodiment, the page that is to be updated is selected by updating pages in a predetermined order, with the page to be updated being the next page in the predetermined order (e.g., start with the representative page with the lowest page number and updating the next-lowest page number in the following step 603) A background read of a representative page is performed 604 using a threshold voltage shift read instruction at an offset to the identified threshold voltage. In one embodiment BRP circuit 6 is operable to perform steps 601-603 and is operable to perform step 604 by sending a background read instruction to read circuit 9 that is operable to send a threshold voltage shift read instruction to the NAND device 20 being read.
Errors in the read of step 604 are identified 605. The total number of errors in each page is counted 606 to obtain an error sum that indicates the total number of errors in the page. In the embodiment shown in
This process is repeated for all representative pages 608, 616 and offset values are changed 607 and the process is continued 609, 617 until all representative pages have been read at all offsets values for the threshold voltage identified in step 603 (with other threshold voltage offsets remaining at the values determined in step 602 until selected in step 603). After the representative pages have been read at all offset values the threshold voltage offset producing the least number of errors is determined 610. In one embodiment step 610 includes determining the error sum from the summing of errors from each read at an offset voltage 606 and identifying the threshold voltage offset corresponding to the error sum determined to have the least number of errors. The updated threshold voltage offset is stored 611 as the updated BRP offset value for the identified threshold voltage. After the BRP offset values have been updated for a selected threshold voltage the process is repeated 618 at different identified threshold voltage 603 and using the updated BRP offset stored in step 611 (instead of the corresponding threshold voltage offset from step 602) in subsequent reads 604 of the background reference positioning operation 600, until all threshold voltages have been updated 612 and the process ends 613. In the present embodiment BRP circuit 6 is operable to perform steps 607-612.
In embodiments of the present invention BRP circuit 6 and/or LLR circuit 7 are operable to perform background reads of steps 109, 201, 511 and 604 by sending read instructions to read circuit 9 that, upon receiving the background read instructions, is operable to perform the background reads by assigning a lower priority to the background read instructions than the priority assigned to read instructions generated in response to read requests from a host computing device. In another embodiment read circuit 9 is operable to assign priority values to read instructions including a high priority value, a medium priority value and a low priority value and is operable to assign a high priority value to read instructions generated in response to read requests from a host computing device, and is further operable to prioritize between background read instructions performed in step 511 and read instructions for housekeeping operations by assigning either the medium priority value or the low priority value to a particular one of those read instructions. In the exemplary embodiment shown in
In the present example, the page group that is being read in step 604, which is identified as exemplary page group 501, is a lower-page page group consisting of only lower pages. Accordingly, the set of threshold voltages that will be required to read each of the pages in the background read 604 will be lower page threshold voltages in regions 1 and 5. Therefore, each threshold voltage shift read instruction for a lower page will include two threshold voltage offsets, and the threshold voltage shift read instruction may be represented as BRPREAD (VO1, VO5), where “VO1” is the threshold voltage offset for reading region 1 and “VO5” is the threshold voltage offset for reading region 5.
In the present example, the threshold voltage offset for region 1 and the threshold voltage offset for region 5 are both set at 0 in step 602 based on updated threshold voltage offsets calculated in a previous background reference positioning operation 600. Threshold voltage 45 of region 5 is selected first for updating in step 603. In the example shown in
Threshold voltage 41 of region 1 is identified next to be updated 603 and reads are performed at different offsets in region 1 until all five pages have been read at all offsets that are to be read, as shown by lines 616-617, while maintaining the threshold voltage offsets to all other regions at the updated threshold offset from step 611 or at the value set in step 602 if the particular threshold voltage has not yet been selected 603 for updating. In the example shown in
In the above example the number of errors were identified by decoding the results of each read. In another embodiment, a first read is used to identify the stored codeword (or a known codeword is read) and subsequent read results are compared to the identified codeword to determine the total number of errors in each read, which is summed to obtain error sums SV1-1, SV1-2, SV1-3, SV1-4 and SV1-5. It has been found that this is faster than decoding each read 604, but requires a known codeword to be stored at least in some blocks.
In the event that data from read 604 is uncorrectable or the determined number of errors 605 exceeds a specific threshold, the closed block may be marked as a “weak block” and the retention time threshold is reduced, in one embodiment halved, the endurance threshold is reduced, in one embodiment halved and the block read threshold is reduced, in one embodiment halved for subsequent steps 605-607 on the weak block. Alternatively, the closed block may be marked as a bad block.
Each time that an updated read offset value is determined based on the occurrence of an endurance event it is stored as VBRPENDURANCE for the page group (which represents the most recently determined endurance read offset value for the page group) in BRP table 5. Each time that an updated read offset value is determined based on the occurrence of a retention timer event or a read disturb event, the updated read offset value is stored as VBRPRET_RD for the page group. When the next endurance event occurs, the calculated VBRP for the page group is stored as VBRPENDURANCE (e.g., by overwriting the previous VBRPENDURANCE value). Each time that VBRPENDURANCE is calculated, it is also stored as VBRPRET_RD for the page group (e.g., by overwriting the previous VBRPRET_RD value). Each time that an updated threshold voltage offset is determined based on the occurrence of a retention timer event or a read disturb event it is stored as VBRPRET_RD for the page group (e.g., by overwriting the previous VBRPRET_RD value). The read offset value stored as VBRPRET_RD for the page group thus represents the most recently determined updated read offset value for the page group, and may be from an endurance event, a retention timer event or a read disturb event, and is a temporary voltage threshold offset value that takes into account the changes to the threshold voltage while the block is closed.
In one embodiment that is illustrated in
At endurance events the VBRP calculated in the most recent endurance event (VBRPENDURANCE) for the page group is used as the starting reference threshold voltage offset in step 602. Accordingly, upon the second endurance event 74 (at 1,000 P/E cycles) VBRPENDURANCE from the 500 P/E event 70 is used as the starting reference threshold voltage offset in step 602.
Upon the occurrence of a retention timer event, the most recently calculated updated read offset value is used as the starting reference threshold voltage offset in step 602, which can be an updated VBRP calculated in response to the occurrence of an endurance event, a retention timer event or a read disturb event. Since each VBRP calculated from an endurance event is stored as both VBRPRET_RD and VBRPENDURANCE, the value VBRPRET_RD always reflects the most recent updated threshold voltage offset for the page group. Accordingly, upon the occurrence of a retention timer event 75 (12-hour retention timer event), VBRPRET_RD from 1K P/E event 74 is used as the starting reference threshold voltage offset in step 602. Upon the occurrence of a second retention timer event 76 (24-hour retention timer event), VBRPRET_RD (from the 12-hour retention timer event 75) is used as the starting reference threshold voltage offset in step 602. Similarly, upon the occurrence of a third retention timer event 77 (36-hour retention timer event), VBRPRET_RD (from the 24-hour retention timer event 76) is used as the starting reference threshold voltage offset in step 602.
Upon the occurrence of a read disturb event 79, the most recently calculated updated read offset value is used as the starting reference threshold voltage offset in step 602, which can be an updated VBRP calculated in response to the occurrence of an endurance event, a retention timer event or a read disturb event. Since each VBRP calculated from an endurance event is stored as both VBRPRET_RD and VBRPENDURANCE, the value VBRPRET_RD always reflects the most recent updated threshold voltage offset for the page group. Accordingly, at an exemplary 50,000 read-count read disturb event 79, VBRPRET_RD (1K, 36, 0) is used as the starting threshold voltage offset in step 602 and the resulting VBRP (1K, 36, 50K) is stored as VBRPRET_RD.
When performing background reference positioning operations for endurance events, it has been found that better results are obtained when the read count is not too high. Accordingly, in embodiments of the present invention, a limit on the number of read counts is applied when determining whether or not a background reference positioning operation should be performed. In one such embodiment, when the number of P/E cycles constitutes an endurance event, the calculation of background reference positioning step 603-612 is not performed when the read count exceeds a quality threshold (e.g., 25,000 reads).
When a block is free 63, previously determined values of VBRPRET_RD are no longer useful for determining voltage threshold correction. Therefore, the background reference positioning operation immediately following the block erase will use the VBRP calculated in the most recent endurance event (VBRPENDURANCE) for the page group as the starting reference threshold voltage offset in step 602, whether it is a VBRP calculation for an endurance event, a retention timer event or a read disturb event. If an endurance event is not determined to have occurred at close block event 65 and a retention or read disturb event 78 is determined to have occurred, VBRPENDURANCE from the 1,000 P/E event 74 is used as the starting reference threshold voltage in step 602 and the calculated VBRP is stored as VBRPRET_RD.
As previously discussed, after a block is free 63, previously determined values of VBRPRET_RD are no longer useful. Accordingly, in embodiments of the present invention, when reads are performed after a block is closed and before a first VBRPRET_RD is determined for the closed block, reads continue to be performed using the VBRP calculated in the most recent endurance event (VBRPENDURANCE) for the page group until the first VBRPRET_RD is determined following the closed block event.
The use of both background reference positioning and background LLR calculation results in fewer decode errors and hence fewer read retry operations, providing a nonvolatile memory system 1 with reduced latency as compared to systems that use conventional read operations. Moreover, BER is reduced, extending the lifetime of nonvolatile memory system 1.
In the example shown in
Since in the present example VBRP1, is +1, shown as line 56 in
Since in the present example VBRP5, is −1, which is shown as line 50 in
In alternate embodiment, all BRP offset values are set to 0 and all LLR values are set to default values (e.g., −6, +6) after nonvolatile memory controller 11 is initialized to obtain an initial BRP table 5 and LLR table 10. In this embodiment, each calculated set of BRP offsets will be an updated set of BRP offsets and each identified set of LLR values will be an updated set of LLR values.
By performing testing on the actual NAND device being used, and by continuing to perform background testing as the NAND device ages, the methods and apparatus of the present invention provide LLR values that accurately indicate the error probability of soft reads. This reduces BER and extends the useful life of the NAND flash memory chips. In addition, the number of read errors is reduced, resulting in reduced read latency.
In various embodiments, the system of the present invention may be implemented in a Field Programmable Gate Array (FPGA) or Application Specific Integrated Circuit (ASIC).
Although the invention has been described with reference to particular embodiments thereof, it will be apparent to one of ordinary skill in the art that modifications to the described embodiment may be made without departing from the spirit of the invention. Accordingly, the scope of the invention will be defined by the attached claims and not by the above detailed description.
Number | Name | Date | Kind |
---|---|---|---|
815137 | Beecher | Mar 1906 | A |
5615235 | Kakuishi et al. | Mar 1997 | A |
5732092 | Shinohara | Mar 1998 | A |
5822244 | Hansen et al. | Oct 1998 | A |
5875343 | Binford et al. | Feb 1999 | A |
6115788 | Thowe | Sep 2000 | A |
6148360 | Leak et al. | Nov 2000 | A |
6412041 | Lee et al. | Jun 2002 | B1 |
6539515 | Gong | Mar 2003 | B1 |
6567313 | Tanaka et al. | May 2003 | B2 |
6633856 | Richardson et al. | Oct 2003 | B2 |
6725409 | Wolf | Apr 2004 | B1 |
6789227 | De Souza et al. | Sep 2004 | B2 |
6871168 | Tanaka et al. | Mar 2005 | B1 |
6895547 | Eleftheriou et al. | May 2005 | B2 |
6934804 | Hashemi | Aug 2005 | B2 |
6963507 | Tanaka et al. | Nov 2005 | B2 |
6976194 | Cypher | Dec 2005 | B2 |
6976197 | Faust et al. | Dec 2005 | B2 |
7032081 | Gefen et al. | Apr 2006 | B1 |
7050334 | Kim et al. | May 2006 | B2 |
7116732 | Worm et al. | Oct 2006 | B2 |
7206992 | Xin et al. | Apr 2007 | B2 |
7209527 | Smith et al. | Apr 2007 | B2 |
7237183 | Xin | Jun 2007 | B2 |
7324559 | McGibney | Jan 2008 | B2 |
7376015 | Tanaka et al. | May 2008 | B2 |
7450668 | Ghosh et al. | Nov 2008 | B2 |
7457906 | Pettey et al. | Nov 2008 | B2 |
7472331 | Kim et al. | Dec 2008 | B2 |
7484158 | Sharon et al. | Jan 2009 | B2 |
7529215 | Osterling | May 2009 | B2 |
7567472 | Gatzemeier et al. | Jul 2009 | B2 |
7620784 | Panabaker et al. | Nov 2009 | B2 |
7650480 | Jiang et al. | Jan 2010 | B2 |
7694047 | Alston | Apr 2010 | B1 |
7708195 | Yoshida et al. | May 2010 | B2 |
7739472 | Guterman et al. | Jun 2010 | B2 |
7752346 | Talayco et al. | Jul 2010 | B2 |
7801233 | Chow et al. | Sep 2010 | B1 |
7860930 | Freimuth et al. | Dec 2010 | B2 |
7904793 | Mokhlesi et al. | Mar 2011 | B2 |
7930623 | Pisek et al. | Apr 2011 | B2 |
7937641 | Amidi | May 2011 | B2 |
7945721 | Johnsen et al. | May 2011 | B1 |
7958430 | Kolokowsky et al. | Jun 2011 | B1 |
7975193 | Johnson | Jul 2011 | B2 |
8094508 | Gatzemeier et al. | Jan 2012 | B2 |
8140930 | Maru | Mar 2012 | B1 |
8176367 | Dreifus et al. | May 2012 | B2 |
8219894 | Au et al. | Jul 2012 | B2 |
8223745 | Johnsen et al. | Jul 2012 | B2 |
8228728 | Yang et al. | Jul 2012 | B1 |
8244946 | Gupta et al. | Aug 2012 | B2 |
8245112 | Hicken et al. | Aug 2012 | B2 |
8245117 | Wu | Aug 2012 | B1 |
8250286 | Yeh et al. | Aug 2012 | B2 |
8254112 | Yang et al. | Aug 2012 | B2 |
8255770 | Park et al. | Aug 2012 | B2 |
8259498 | Yogev et al. | Sep 2012 | B2 |
8259506 | Sommer et al. | Sep 2012 | B1 |
8261136 | D'Abreu et al. | Sep 2012 | B2 |
8281217 | Kim et al. | Oct 2012 | B2 |
8281227 | Inskeep et al. | Oct 2012 | B2 |
8286004 | Williams | Oct 2012 | B2 |
8307258 | Flynn et al. | Nov 2012 | B2 |
8327220 | Borchers et al. | Dec 2012 | B2 |
8335977 | Weingarten et al. | Dec 2012 | B2 |
8341502 | Steiner et al. | Dec 2012 | B2 |
8351258 | Yang et al. | Jan 2013 | B1 |
8359522 | Gunnam et al. | Jan 2013 | B2 |
8392789 | Biscondi et al. | Mar 2013 | B2 |
8402201 | Strasser et al. | Mar 2013 | B2 |
8418023 | Gunnam et al. | Apr 2013 | B2 |
8429325 | Onufryk et al. | Apr 2013 | B1 |
8429497 | Tu et al. | Apr 2013 | B2 |
8473812 | Ramamoorthy et al. | Jun 2013 | B2 |
8493791 | Karakulak et al. | Jul 2013 | B2 |
8504885 | Haratsch et al. | Aug 2013 | B2 |
8504887 | Varnica et al. | Aug 2013 | B1 |
8555140 | Gunnam et al. | Oct 2013 | B2 |
8621318 | Micheloni et al. | Dec 2013 | B1 |
8638602 | Horn et al. | Jan 2014 | B1 |
8640005 | Wilkerson et al. | Jan 2014 | B2 |
8645613 | Tan et al. | Feb 2014 | B2 |
8656257 | Micheloni et al. | Feb 2014 | B1 |
8665648 | Mun et al. | Mar 2014 | B2 |
8694849 | Micheloni et al. | Apr 2014 | B1 |
8694855 | Micheloni et al. | Apr 2014 | B1 |
8706956 | Cagno et al. | Apr 2014 | B2 |
8707122 | Micheloni et al. | Apr 2014 | B1 |
8737141 | Melik-Martirosian | May 2014 | B2 |
8739008 | Liu et al. | May 2014 | B2 |
8755229 | Visconti et al. | Jun 2014 | B1 |
8762620 | Prins et al. | Jun 2014 | B2 |
8769374 | Franceschini et al. | Jul 2014 | B2 |
8775913 | Haratsch et al. | Jul 2014 | B2 |
8787428 | Dai et al. | Jul 2014 | B2 |
8856622 | Ramamoorthy et al. | Oct 2014 | B2 |
8898372 | Yeh | Nov 2014 | B2 |
8917734 | Brown | Dec 2014 | B1 |
8924824 | Lu | Dec 2014 | B1 |
8953373 | Haratsch et al. | Feb 2015 | B1 |
8958247 | Asaoka et al. | Feb 2015 | B2 |
8959280 | Ma et al. | Feb 2015 | B2 |
8984216 | Fillingim | Mar 2015 | B2 |
8995197 | Steiner et al. | Mar 2015 | B1 |
8995302 | Brown et al. | Mar 2015 | B1 |
9025495 | Onufryk et al. | May 2015 | B1 |
9058289 | Tai et al. | Jun 2015 | B2 |
9142314 | Beltrami et al. | Sep 2015 | B2 |
9164891 | Karamcheti et al. | Oct 2015 | B2 |
9244763 | Kankani et al. | Jan 2016 | B1 |
9251909 | Camp et al. | Feb 2016 | B1 |
9257182 | Grunzke | Feb 2016 | B2 |
9268531 | Son et al. | Feb 2016 | B1 |
9292428 | Kanamori et al. | Mar 2016 | B2 |
9294132 | Peleato-Inarrea | Mar 2016 | B1 |
9397701 | Micheloni | Jul 2016 | B1 |
9444655 | Sverdlov et al. | Sep 2016 | B2 |
9590656 | Micheloni | Mar 2017 | B2 |
9886214 | Micheloni et al. | Feb 2018 | B2 |
9916906 | Wu et al. | Mar 2018 | B2 |
20020051501 | Demjanenko et al. | May 2002 | A1 |
20020129308 | Kinoshita et al. | Sep 2002 | A1 |
20020181438 | McGibney | Dec 2002 | A1 |
20030033567 | Tamura et al. | Feb 2003 | A1 |
20030104788 | Kim | Jun 2003 | A1 |
20030225970 | Hashemi | Dec 2003 | A1 |
20040088636 | Cypher | May 2004 | A1 |
20040123230 | Lee et al. | Jun 2004 | A1 |
20040136236 | Cohen et al. | Jul 2004 | A1 |
20040181735 | Xin | Sep 2004 | A1 |
20040234150 | Chang | Nov 2004 | A1 |
20040252791 | Shen et al. | Dec 2004 | A1 |
20040268015 | Pettey et al. | Dec 2004 | A1 |
20050010846 | Kikuchi et al. | Jan 2005 | A1 |
20050226355 | Kibune et al. | Oct 2005 | A1 |
20050248999 | Tamura et al. | Nov 2005 | A1 |
20050252791 | Pechtold et al. | Nov 2005 | A1 |
20050286511 | Johnsen et al. | Dec 2005 | A1 |
20060039370 | Rosen et al. | Feb 2006 | A1 |
20060050694 | Bury et al. | Mar 2006 | A1 |
20060126728 | Yu et al. | Jun 2006 | A1 |
20060206655 | Chappell et al. | Sep 2006 | A1 |
20060282603 | Onufryk et al. | Dec 2006 | A1 |
20070050688 | Thayer | Mar 2007 | A1 |
20070089031 | Huffman et al. | Apr 2007 | A1 |
20070101225 | Moon et al. | May 2007 | A1 |
20070118743 | Thornton et al. | May 2007 | A1 |
20070136628 | Doi et al. | Jun 2007 | A1 |
20070147489 | Sun et al. | Jun 2007 | A1 |
20070217253 | Kim et al. | Sep 2007 | A1 |
20070233939 | Kim | Oct 2007 | A1 |
20070239926 | Gyl et al. | Oct 2007 | A1 |
20080005382 | Mimatsu | Jan 2008 | A1 |
20080016425 | Khan et al. | Jan 2008 | A1 |
20080049869 | Heinrich et al. | Feb 2008 | A1 |
20080077843 | Cho et al. | Mar 2008 | A1 |
20080148129 | Moon et al. | Jun 2008 | A1 |
20080229079 | Flynn et al. | Sep 2008 | A1 |
20080229164 | Tamura et al. | Sep 2008 | A1 |
20080256280 | Ma | Oct 2008 | A1 |
20080256292 | Flynn et al. | Oct 2008 | A1 |
20080263265 | Litsyn et al. | Oct 2008 | A1 |
20080267081 | Roeck | Oct 2008 | A1 |
20080276156 | Gunnam et al. | Nov 2008 | A1 |
20080320214 | Ma et al. | Dec 2008 | A1 |
20090027991 | Kaizu et al. | Jan 2009 | A1 |
20090067320 | Rosenberg et al. | Mar 2009 | A1 |
20090077302 | Fukuda | Mar 2009 | A1 |
20090164694 | Talayco et al. | Jun 2009 | A1 |
20090290441 | Gatzemeier et al. | Nov 2009 | A1 |
20090296798 | Banna et al. | Dec 2009 | A1 |
20090303788 | Roohparvar et al. | Dec 2009 | A1 |
20090307412 | Yeh et al. | Dec 2009 | A1 |
20090327802 | Fukutomi et al. | Dec 2009 | A1 |
20100085076 | Danilin et al. | Apr 2010 | A1 |
20100162075 | Brannstrom et al. | Jun 2010 | A1 |
20100185808 | Yu et al. | Jul 2010 | A1 |
20100199149 | Weingarten et al. | Aug 2010 | A1 |
20100211737 | Flynn et al. | Aug 2010 | A1 |
20100211852 | Lee et al. | Aug 2010 | A1 |
20100226422 | Taubin et al. | Sep 2010 | A1 |
20100262979 | Borchers et al. | Oct 2010 | A1 |
20100293440 | Thatcher et al. | Nov 2010 | A1 |
20110010602 | Chung et al. | Jan 2011 | A1 |
20110055453 | Bennett et al. | Mar 2011 | A1 |
20110055659 | Tu et al. | Mar 2011 | A1 |
20110066902 | Sharon et al. | Mar 2011 | A1 |
20110072331 | Sakaue et al. | Mar 2011 | A1 |
20110119553 | Gunnam et al. | May 2011 | A1 |
20110161678 | Niwa | Jun 2011 | A1 |
20110209031 | Kim et al. | Aug 2011 | A1 |
20110225341 | Satoh et al. | Sep 2011 | A1 |
20110246136 | Haratsch et al. | Oct 2011 | A1 |
20110246842 | Haratsch et al. | Oct 2011 | A1 |
20110246853 | Kim et al. | Oct 2011 | A1 |
20110296084 | Nango | Dec 2011 | A1 |
20110307758 | Fillingim et al. | Dec 2011 | A1 |
20120008396 | Park et al. | Jan 2012 | A1 |
20120051144 | Weingarten et al. | Mar 2012 | A1 |
20120054413 | Brandt | Mar 2012 | A1 |
20120096192 | Tanaka et al. | Apr 2012 | A1 |
20120140583 | Chung et al. | Jun 2012 | A1 |
20120141139 | Bakhru et al. | Jun 2012 | A1 |
20120166690 | Regula | Jun 2012 | A1 |
20120167100 | Li et al. | Jun 2012 | A1 |
20120179860 | Falanga et al. | Jul 2012 | A1 |
20120203986 | Strasser et al. | Aug 2012 | A1 |
20120239991 | Melik-Martirosian et al. | Sep 2012 | A1 |
20120254515 | Melik-Martirosian et al. | Oct 2012 | A1 |
20120311388 | Cronin et al. | Dec 2012 | A1 |
20120311402 | Tseng et al. | Dec 2012 | A1 |
20130013983 | Livshitz et al. | Jan 2013 | A1 |
20130024735 | Chung et al. | Jan 2013 | A1 |
20130060994 | Higgins et al. | Mar 2013 | A1 |
20130086451 | Grube et al. | Apr 2013 | A1 |
20130094286 | Sridharan et al. | Apr 2013 | A1 |
20130094290 | Sridharan et al. | Apr 2013 | A1 |
20130117616 | Tai et al. | May 2013 | A1 |
20130117640 | Tai et al. | May 2013 | A1 |
20130145235 | Alhussien et al. | Jun 2013 | A1 |
20130163327 | Karakulak et al. | Jun 2013 | A1 |
20130163328 | Karakulak et al. | Jun 2013 | A1 |
20130176779 | Chen et al. | Jul 2013 | A1 |
20130185598 | Haratsch et al. | Jul 2013 | A1 |
20130198451 | Hyun et al. | Aug 2013 | A1 |
20130205085 | Hyun et al. | Aug 2013 | A1 |
20130314988 | Desireddi et al. | Nov 2013 | A1 |
20130315252 | Emmadi et al. | Nov 2013 | A1 |
20130318422 | Weathers et al. | Nov 2013 | A1 |
20140029336 | Venkitachalam et al. | Jan 2014 | A1 |
20140040704 | Wu et al. | Feb 2014 | A1 |
20140053037 | Wang et al. | Feb 2014 | A1 |
20140068368 | Zhang et al. | Mar 2014 | A1 |
20140068382 | Desireddi et al. | Mar 2014 | A1 |
20140072056 | Fay | Mar 2014 | A1 |
20140085982 | Asaoka et al. | Mar 2014 | A1 |
20140101510 | Wang et al. | Apr 2014 | A1 |
20140164881 | Chen et al. | Jun 2014 | A1 |
20140181426 | Grunzke et al. | Jun 2014 | A1 |
20140181617 | Wu et al. | Jun 2014 | A1 |
20140185611 | Lie et al. | Jul 2014 | A1 |
20140198569 | Kim et al. | Jul 2014 | A1 |
20140198581 | Kim et al. | Jul 2014 | A1 |
20140215175 | Kasorla et al. | Jul 2014 | A1 |
20140219003 | Ebsen et al. | Aug 2014 | A1 |
20140229774 | Melik-Martirosian et al. | Aug 2014 | A1 |
20140281767 | Alhussien et al. | Sep 2014 | A1 |
20140281771 | Yoon et al. | Sep 2014 | A1 |
20140281800 | Micheloni | Sep 2014 | A1 |
20140281808 | Lam et al. | Sep 2014 | A1 |
20140281822 | Wu et al. | Sep 2014 | A1 |
20140281823 | Micheloni et al. | Sep 2014 | A1 |
20150039952 | Goessel et al. | Feb 2015 | A1 |
20150043286 | Park et al. | Feb 2015 | A1 |
20150046625 | Peddle et al. | Feb 2015 | A1 |
20150127883 | Chen et al. | May 2015 | A1 |
20150131373 | Alhussien et al. | May 2015 | A1 |
20150149871 | Chen et al. | May 2015 | A1 |
20150169468 | Camp et al. | Jun 2015 | A1 |
20150186055 | Darragh | Jul 2015 | A1 |
20150221381 | Nam | Aug 2015 | A1 |
20150242268 | Wu et al. | Aug 2015 | A1 |
20150332780 | Kim et al. | Nov 2015 | A1 |
20150371718 | Becker et al. | Dec 2015 | A1 |
20160034206 | Ryan et al. | Feb 2016 | A1 |
20160049203 | Alrod et al. | Feb 2016 | A1 |
20160071601 | Shirakawa et al. | Mar 2016 | A1 |
20160072527 | Tadokoro et al. | Mar 2016 | A1 |
20160155507 | Grunzke | Jun 2016 | A1 |
20160179406 | Gorobets et al. | Jun 2016 | A1 |
20160247581 | Yoshida et al. | Aug 2016 | A1 |
20160293259 | Kim et al. | Oct 2016 | A1 |
20170147135 | Higashibeppu | May 2017 | A1 |
20170213597 | Micheloni et al. | Jul 2017 | A1 |
20180033490 | Marelli et al. | Feb 2018 | A1 |
Entry |
---|
NVM Express, revision 1.0; Intel Corporation;, Jul. 12, 2011, pp. 103-106 and 110-114. |
NVM Express, Revision 1.0; Intel Corporation, Mar. 1, 2011, pp. 1-122. |
RapidIO, PCI Express, and Gigabit Ethernet Comparison: Pros and Cons of Using Three Interconnects in Embedded Systems; RapidIO Trade Association, Technical White Paper, Revision 03,, May 2005, 1-36. |
PCI Express Base Specification Revision 3.0 (PCI Express Base Expression, PCISIG, hereinafter “PCIExpress”), Nov. 10, 2010, 1-860. |
RFC 793: Transmission Control Protocol, RFC 793, University of Southern California, IETF,, Sep. 1981, pp. 1-89. |
Cai, et al., “Data Retention in MLC NAND Flash Memory: Characterization, Optimization, and Recovery”, 2015 IEEE 21st International Symposium on High Performance Computer Architecture (HPCA); Carnegie Mellon University, LSI Corporation, 2015, pp. 551-563. |
Chen, et al., “Increasing flash memory lifetime by dynamic voltage allocation for constant mutual information”, 2014 Information Theory and Applications Workshop (ITA), 2014, pp. 1-5. |
Peleato, et al., “Probabilistic graphical model for flash memory programming”, Statistical Signal Processing Workshop (SSP), 2012 IEEE, 2012, pp. 1-4. |
Wu, et al., “Reducing SSD Read Latency via NAND Flash Program and Erase Suspension”, Proceedings of FAST'2012; Department of Electrical and Computer Engineering Virginia Commonwealth University, Richmond, VA 23284, 2012, pp. 117-123. |
International Search Report and Written Opinion of the International Searching Authority dated Oct. 23, 2017 International application No. PCTUS2017/044037. |
International Search Report and Written Opinion of the International Searching Authority dated Jun. 10, 2017, International application No. PCT/US2017/043799. |
Number | Date | Country | |
---|---|---|---|
20180034485 A1 | Feb 2018 | US |
Number | Date | Country | |
---|---|---|---|
62488215 | Apr 2017 | US | |
62367789 | Jul 2016 | US |