Embodiments of the present disclosure generally relate to a method for writing data to a NAND block multiple times prior to erasing the block.
Flash memory based solid-state drives (SSD) have advantages over traditional hard disk drives (HDDs) in that SDDs have a high throughput, low read/write latency, low power consumption and the ability to tolerate high pressure and temperature. NAND flash in particular has a low price and a large capacity compared to other non-volatile memories (NVMs). Flash memories using floating gates (or charge trap) transistors to trap charge and the data represented by the amount of charge, called cell levels, trapped in a group of cells. One of the key features of NAND flash is the asymmetry of programming and erasing. The unit of programming (increasing cell levels) is called a page and consists of 103 to 104 cells, while the unit of erasing (decreasing cell levels) is a block containing hundreds of pages. A block erasure is time and energy consuming, and degrades the physical cells.
NAND flash has a disadvantage, however, NAND flash can only be written once. The data can be read multiple times, but if the data location is to be used again to store new data, the old data must be erased. As noted above, erasure occurs by blocks and thus, many pages of data are erased at a time. Furthermore, NAND erasure decreases the lifetime of the NAND device.
There is a need in the art to increase the lifetime of NAND devices.
In this disclosure, data mapping based on three dimensional lattices that have an improved sum rate (i.e., lifetime capacity) with low read latency is disclosed. During the write, a memory location is written to multiple times prior to erasure. Specifically, for the first write, there are 4/3 bits per cell available for writing, which is about 10.67 kB per cell are used for data storage. Then, for the second write, there is one bit per cell, which is 8 kB per cell for data storage. If considering a block with 128 different cells and writing 32 kB of data, the first write results in 42.66 data writes while the second write results in 32 writes for a total of 74.66 writes. Previously, the number of writes for 32 kB would be 64 writes. Thus, by writing twice prior to erasure, more data can be stored.
In one embodiment, a system comprises a host device; a memory system coupled to the host device. The memory system includes: means to write data to a memory location multiple times prior to erasure; means to read data from the memory location; and means to erase data from the memory location. The system additionally comprises controller coupled to the host device and the memory system.
In another embodiment, a method comprises writing a first set of data to a NAND flash block in a first memory location; writing a second set of data to the first memory location; and erasing the first memory location, wherein writing the second set of data occurs prior to erasing the first set of data. Additionally, a system is disclosed that comprises a processor and a memory system storing instructions that, when executed by the processor, cause the system to perform the method. Additionally, a non-transitory computer readable storage medium is disclosed that contains instructions that, when executed by a processor, causes a computer system to burn files after a read process has been completed, by performing the method.
So that the manner in which the above recited features of the present disclosure can be understood in detail, a more particular description of the disclosure, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this disclosure and are therefore not to be considered limiting of its scope, for the disclosure may admit to other equally effective embodiments.
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures. It is contemplated that elements disclosed in one embodiment may be beneficially utilized on other embodiments without specific recitation.
In the following, reference is made to embodiments of the disclosure. However, it should be understood that the disclosure is not limited to specific described embodiments. Instead, any combination of the following features and elements, whether related to different embodiments or not, is contemplated to implement and practice the disclosure. Furthermore, although embodiments of the disclosure may achieve advantages over other possible solutions and/or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the disclosure. Thus, the following aspects, features, embodiments and advantages are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s). Likewise, reference to “the disclosure” shall not be construed as a generalization of any inventive subject matter disclosed herein and shall not be considered to be an element or limitation of the appended claims except where explicitly recited in a claim(s).
In this disclosure, data mapping based on three dimensional lattices that have an improved sum rate (i.e., lifetime capacity) with low read latency is disclosed. During the write, a memory location is written to multiple times prior to erasure. Specifically, for the first write, there are 4/3 bits per cell available for writing, which is about 10.67 kB per cell are used for data storage. Then, for the second write, there is one bit per cell, which is 8 kB per cell for data storage. If considering a block with 128 different cells and writing 32 kB of data, the first write results in 42.66 data writes while the second write results in 32 writes for a total of 74.66 writes. Previously, the number of writes for 32 kB would be 64 writes. Thus, by writing twice prior to erasure, more data can be stored.
In this disclosure, data mapping based on three dimensional lattices that have an improved sum rate (i.e., lifetime capacity) with low read latency is disclosed. During the write, an assumption is used that all logical pages are available at the encoder. During the read, the mapping has advantages that for each logical page, only a subset of read thresholds are needed to decode the data in the corresponding page, and thus the read latency is largely reduced. To be more specific, low read latency data mappings are used for a four level MLC and eight level TLC flash memories. For MLCs, the mapping achieves 17% improvement in total data stored. The code is defined by encoding and decoding maps. For TLC, in order to comply with Gray codes used in current NAND technology, similar, yet separate from MLC design, designs of mapping can achieve 11% to 24% improvement lifetime capacity.
Rewriting codes can improve the lifetime capacity of NAND flash. All existing rewriting codes for NAND flash assume that the exact cell levels are known to decoders and thus, the number of reads needed is q−1. Current NAND technology enables low latency page reads by dividing a physical page into log q logical pages so that the average number of reads per page is (q−1)/log q. As discussed herein two write rewriting codes can be used to enable low latency page reads for multi-level NAND flash memories. The codes enable 17% capacity improvement for the NAND flash memory while maintaining 1.5 reads per page for a four level multiple level cells (MLCs). For eight level triple level cells (TLCs) with the Gray code used in current NAND technology, the codes enable 11% and 24% capacity improvement with 2 and 2.5 reads per page respectively.
Rewriting codes are a generalization of write-once memory (WOM) codes and are an effective means to write more data into the NAND flash between erasures. 3D NAND flash reduces the coupling effect induced inter-cell interference (ICI) such that rewriting codes can be practical. However, all existing rewriting codes necessitate reading exact cell levels to be decoded, which forfeits the low read latency advantages. For example, for four level NAND flash, two binary logical pages (lower and upper pages) are mapped to one quaternary physical page of the same size. Suppose the four symbols are represented by a Gray code (11), (10), (00), (01), from low to high, where the purpose of using Gray codes is to reduce the bit error rate for logical pages. Then reading the lower page is performed by applying one read threshold between level (10) and (00) to identify the left bit (called LSB). Similarly, reading the upper page is performed by applying two read thresholds, one between (11) and (10) and the other between (00) and (01), to identify the right bit (called MSB). Compared to reading the exact cell level using three read thresholds to distinguish all four symbols, the number of reads per page is 1.5 (reduced from 3) on average.
Thus, the parameters that are of primary interest are sum-rate Rsum bits/cell and average number of reads per page tave. For example, a non-rewriting scheme enabling low latency read for cells can be represented as (Rsum, tave)=(log q, ((q−1)/(log q)) and a capacity achieving rewriting code requiring to read exact cell levels for a q-level NAND flash is
In particular, (Rsum, tave)=(3.32, 3) and (Rsum, tave)=(5.17, 7) for capacity achieving two write WOM codes for four level MLCs and eight level TLCs flash respectively. Since read latency helps determine SSD performance, codes can be constructed with
to maintain low read latency and improve Rsum.
The rewriting codes disclosed herein improve the sum-rate (i.e., lifetime capacity) with low read latency. The coding schemes use the current Gray mapping between logical data and physical cell levels, which avoids hardware and circuit redesign inside the chip. During the writing, an assumption in the current NAND programming technology is made. The assumption is that all logical pages are available at the encoder. During the read, the rewriting codes have advantages that for each logical page, only a subset of q−1 read thresholds are needed to decode the data in the corresponding page, and thus the read latency is largely reduced. To be more specific, low read latency rewriting codes for four level MLC and eight level TLC flash memories are disclosed herein. For MLCs, the proposed codes archives (Rsum, tave)=(2.33, 1.5) with 17% improvement in sum-rate over current (2, 1.5) non-rewriting schemes. The code is defined by encoding and decoding maps for each write and each logical page and it can also be visualized by a labeling of a three dimensional cube. For TLC, similar yet separate from MLC designs of rewriting codes can achieve (Rsum, tave)=(3.33, 2) with improvement of both sum-rate and read latency over current (3, 2.33) non-rewriting schemes.
Suppose the number of cells is n and let c1, . . . , cn be the cell levels of those n cells. Assuming each cell has q levels, (0, 1, . . . , q−1), the integer set (0, 1, . . . , n−1) will be denoted by [n]. Let xi denote the ith element in array x=(x1, . . . , xn), xij=(xi, xi+1, . . . , xj) denote the subvector of x, for 1≤i≤j≤n. For two vectors x1n and y1n, x1ny1n if ∀i∈{1, . . . , n}, xi≥yi. For a mapping f: A→B, the image of f is denoted by Im(f) and denoted the image of Ã⊂A under f by f(Ã)⊂B. The discussion below will focus on two writes where on the second write, cell levels can only increase in the ordered set (0, 1, . . . , q−1).
A read corresponds to applying a read threshold to all n cells and a length-n Boolean vector that describes whether the ith cell is above or below the read threshold is returned, for i∈{1, . . . , n}. Thus, if t reads (r1, . . . , rt) are performed to one page, the ordered set (0, 1, . . . , q−1) is partitioned into t+1 intervals. Note that if t=q−1, then the exact symbol in (0, 1, . . . , q−1) is read at the cost of read latency.
Two-Write Low Read Latency Rewriting Codes for MLC Flash Memories
In this section, the low latency rewriting codes are modeled mathematically. Additionally, a code construction that enables low latency reads for four level MLC flash memories is provided. The Gray mapping 2 is shown in Table I, which is consistent with the current NAND technology and thus does not require hardware/circuit redesign in NAND chips.
Definition on Low Latency Rewriting Codes for Four Level MLC NAND Flash
Let the bijection between cell levels to (LSB, MSB) pairs be denoted by the Gray code 2. Let ψn: {0, 1, 2, 3}n{0, 1}n denote the LSB read of a page by applying one threshold between cell levels (1, 2). Let ϕn: {0, 1, 2, 3}n{0, 1}n denote the MSB read of a page by applying two thresholds between cell levels (0, 1) and (2, 3). The mappings 2, ψ1 and ϕ1 used in current NAND technology are defined in Table I. The following is denoted: ψn(c1n)=(ψ1(c1) . . . ψ1(cn)), ϕn(c1n)=(ϕ1(c1) . . . ϕ1(cn)), ∀c1n∈{0, 1, 2, 3}n.
The subscripts of ψn and ϕn will be omitted if arguments of ψ(⋅) and ϕ(⋅) have explicit length from context.
An [n;(2nR
ε1:[2nR
ε2:[2nR
such that
∀(mψ,mϕ,c1n)∈[2nR
The page decoders are mappings:
Diψ: ψ(Im(εi))[2nR
Diϕ: ϕ(Im(εi))[2nR
such that:
∀i∈{1,2},miψ∈[2nR
D1ψ(ψ(ε1(m1ψ,m1ϕ)))=m1ψ,
D1ϕ(ϕ(ε1(m1ψ,m1ϕ)))=m1ϕ,
D2ψ(ψ(ε2(m2ψ,m2ϕ,ε1(m1ψ,m1ϕ)))=m2ψ,
D2ϕ(ϕ(ε2(m2ψ,m2ϕ,ε1(m1ψ,m1ϕ)))=m2ϕ.
The rate of logical page corresponding to LSBs on each write is R1ψ and R2ψ, and the rate of logical page corresponding to MSBs on each write is R1ϕ and R2ϕ. The sum rate is Σi=12Riψ+Σi=12Riϕ.
In the definition discussed above, there are two logical pages storing data corresponding to LSBs and MSBs of a physical page. Note that the difference between the definition for low read latency rewriting cores and the definition of regular multi-level WOM codes lies in that the page decoders D1ψ, D2ψ (or D1ϕ, D2ϕ) only have information of LSBs read by ψ (or MSBs read by ϕ) from a physical page, and nevertheless need to decode correctly their own logical page regardless of the data in the other logical page. The number of read thresholds to decode LSB-represented and MSB-represented logical pages is 1 and 2 respectively, which is equivalent to conventional non-rewriting schemes that require 1.5 reads per logical page.
Consider n=3 cells (c1, c2, c3) where ci∈{0, 1, 2, 3} is the level of the ith cell. If a physical page contains a multiple of three cells, then the cells are concatenated and each set of consecutive three cells store data according to the proposed rewriting codes.
Let q=4 (MLC) be the number of levels in a physical cell. Let the bijection (Gray code) between cell levels to (LSB, MSB) pairs, the LSB reads function ψ, and the MSB read function ϕ: be defined in the definition above.
Let n=3. An [n;(22/3n,22/3n);(22/3n,21/3n)]=[3;(4,4);(4,2)] two write low read latency rewriting code for MLC is constructed by defining the set of encoders and decoders as follows. On the first write, let S[0]={111}, S[1]={011}, S[2]={101}, S[3]={110} be four sets each containing one element. Let Let S−1(x), x∈{0,1}3 denote the set index {0, 1, 2, 3} that contains x. Let (m1ψμm1ϕ)∈[4]×[4] be the data for each page on the first write, then c13=ε1(m1ψμm1m) encodes by choosing α∈S[m1ψ],β∈S[m1ϕ] such that:
ci=2−1(αiβi), i=1,2,3 (1)
The decoders D1ψ, D1ϕ for each page on the first write are:
{circumflex over (m)}1ψ=D1ψ(c13)=S−1(ψ(c13)) (2)
{circumflex over (m)}1ϕ=D1ϕ(c13)=S−1(ϕ(c13)) (3)
On the second write, let Sψ[0]={100, 011}, Sψ[1]={000}, Sψ[2]={110, 001}, Sψ[3]={101, 010}, and Sϕ[0]={011, 101, 110}, Sϕ[1]={001, 100, 010}. Let Sψ−1(x), Sϕ−1(x) be the set index that contains x and Sψ and Sϕ, respectively. Let c13 be the cell levels after first write, (m2ψμm2ϕ)∈[4]×[2] be the data for each page on the second write, then ε2(m2ψμm2ϕ) encodes by choosing α∈S[m2ψ],β∈S[m2ϕ] such that:
ci=2−1(αiβi)≥{tilde over (c)}i, i=1,2,3 (4)
The decoders for each page on the second write are:
{circumflex over (m)}2ψ=D2ψ(c13)=Sψ−1(ψ(c13)) (5)
{circumflex over (m)}2ϕ=D2ϕ(c13)=Sϕ−1(ϕ(c13)) (6)
On the second write, it is possible to find more than one pair of (α, β) such that 2−1(αiβi)≥{tilde over (c)}i, ∀i=1, 2, 3 is satisfied. The encoder is allowed to pick any pair.
For all m2ψ∈[4], m2ϕ∈[2], {tilde over (c)}13∈Im(ε1) there exists at least one pair (α, β), where α∈S|m2ψ|, β∈S|m2ϕ|, such that 2−1(αiβi)≥{tilde over (c)}i, i=1, 2, 3.
The above discuss provides two write low latency (1.5 reads per logical page) rewriting codes for MLC with sum rate 7/3 bits/cell.
Let n=3 and all cell levels are 0(c13=000) before first write. Supposed the data for both pages needed to store on both writes are ((m1ψμm1ϕ)=(3,2)∈[4]×[4] and (m2ψμm2ϕ)=(1,1)∈[4]×[2]. On the first write, choose α=110∈S[m1ψ]=S[3] and β=101∈S[m1ϕ]=S[2], then according to equation (1),
To decode the data in LSB for the first write, apply one threshold for LSB read and have ψ(013)=110, the data is then decoded according to equation (2), {circumflex over (m)}1ψ=S−1(110)=3.
To decode the data in MSB for the first write, two thresholds are applied for MSB read and have ϕ(013)=101, the data is then decoded according to equation (3), {circumflex over (m)}1ϕ=S−1(101)=2.
On the second write, choose α=000=Sψ[m2ψ]=S[1], β=001∈Sϕ[m2ϕ]=S[1], then according to equation (4), c13=(2−1(α1β1)2−1(α2β2)2−1(α3β3))=(223)(013).
To decode the data in LSB for the second write, one threshold for LSB read is applied and have ψ(223)=000, the data is then decoded according to equation (5), {circumflex over (m)}2ψ=Sψ−1(000)=1.
To decode the data in MSB for the second write, two thresholds for MSB read are applied and have ϕ(223)=001, the data is then decoded according to equation (6), {circumflex over (m)}2ϕ=Sϕ−1(001)=1.
The above construction achieves (Rsum, tave)=(7/3, 1.5). Compared to non-rewriting codes (2, 1.5) for MLC, the improvement is 17%. Note also that the sum capacity of two write four level WOM is log2 10≈3.32 bits per cell. The gap between the above construction and the sum capacity of regular WOM is due to low read latency requirements. A simple analysis would show that the above construction provides the optimal two write low read latency codes based on encoding/decoding of three cells. Code constructions based on larger numbers of cells (n>3) might achieve better sum rate at the cost of design complexity (computer search) and encoding/decoding complexity.
Two Write Low Read Latency Rewriting Code for TLC Flash Memories
Code constructions for TLC flash will now be discussed. The Gray code 3 used in current TLC NAND technology that maps the LSB, central significant bit (CSB), and MSB to cell level {0, 1, . . . , 7} denoted by a triplet of functions applied during read (ψl, ψc, ψm) is in Table III. Note that to read LSB, CSB and MSB pages, (ψl(i), ψc(i), ψm(i)) requires (2, 3, 2) read thresholds, respectively, applied at the transitions between 0 and 1 for each page.
An [n=3; (22, 22, 22); (22, 22)] low latency rewriting code of length n=3, where three logical pages of size 2 bits each are stored in (LSB, CSB, MSB) on the first write and 2 logical pages of size 2 bits each are stored in (LSB, MSB) on the second write, is constructed by a set of encoders and decoders. On the first write, let S[0]={000}, S[1]={001}, S[2]={010}, S[3]={100}, let S−1(x) denote the set index that contains x∈{0, 1}3. Let (m1l,m1c,m1m)∈[4]×[4]×[4] be the data for each page, then c13=ε1(m1l,m1c,m1m):[4]×[4]×[4]→Im(ε1)⊂[8]3 encodes by choosing α∈S[m1l], β∈S[m1c], γ∈S[m1m] such that:
ci=3−1(αiβiγi), i=1,2,3 (7)
The decoders for each page on the first write is defined by:
{circumflex over (m)}1i=D1i(c13)=S−1(ψi(c13), i=l,c,m (8)
On the second write, 2 is used instead of 3. Let Sψl[0]={101, 010}, Sψl[1]={100, 011}, Sψl[2]={000}, Sψl[3]={110, 001} and Sψm[0]={111}, Sψm[1]={001, 110}, Sψm[2]={011, 100}, Sψm[3]={101, 010}. Let Sψl−1(x),Sψm−1(x) be the set index in {0, 1, 2, 3} that contains x. Let {tilde over (c)}13 be the cell levels after first write, (m2ψ
ci=2−1(αiβi)+4{tilde over (c)}i, ∀i=1,2,3 (9)
The decoders D2l, D2m for each page on the second write are:
{circumflex over (m)}2i=D2i(c13)=Sψ
In the above construction, for all (m2ψ
Moreover, the number of reads for D1ψ
reads per page. The sum rate is 10/3 bits per cell. Therefore, the above construction is an (Rsum, tave)=(10/3, 2) code, which improves both sum rate and read latency comparing to non-rewriting (3, 7/3) scheme.
A close look at the code design process (determining the contents of S, Sψ, Sϕ for MLC and S, Sψl, Sψm for TLC) would reveal that the encoders/decoder is a labeling problem on the n-dimensional cube. The labeling for n=3 in the above constructions are manually designed on three dimensional cubes. For example,
For TLC, with n>3, the first write can be designed similarly as n=3, but the second write needs a computer search for good codes. In order to achieve a better sub rate, tradeoffs are made by using three thresholds for the second write, and thus
reads per page. Table III lists the sum rate and the number of reads on both writes, where column with n=1 is the conventional non-rewriting schemes.
The low ready latency rewriting codes discussed herein are based on three dimensional lattices to enable fast read as current NAND technology supports. Separate designs for MLC and TLC flash improve the sum rate, or lifetime capacity, by 17%, 11% and 24%, with 1.5, 2 and 2.5 reads per page respectively.
The present disclosure relates to data mapping based on three dimensional lattices that have an improved sum rate (i.e., lifetime capacity) with low read latency. During the write, an assumption is used that all logical pages are available at the encoder. During the read, the mapping has advantages that for each logical page, only a subset of read thresholds are needed to decode the data in the corresponding page, and thus the read latency is largely reduced. To be more specific, low read latency data mappings are used for a four level MLC and eight level TLC flash memories. For MLCs, the mapping achieves 17% improvement in total data stored. The code is defined by encoding and decoding maps. For TLC, in order to comply with Gray codes used in current NAND technology, similar, yet separate from MLC design, designs of mapping can achieve 11% to 24% improvement lifetime capacity.
The basic premise of NAND flash memory is that the memory can only be written one time and then, if the memory is to be written again, the memory will need to be erased. As discussed herein, rather than erasing the memory, it is possible to write in the memory locations again prior to erasure and thus, the lifetime of the NAND flash memory is increased, as is the storage capacity.
The memory system 104 includes a memory controller 108 and multiple CPUs or processors 110A-110N. The memory system 104 also includes a memory device 112. The memory device 112 is coupled to all of the CPUs 110A-110N as well as the memory controller 108. In one embodiment, the memory device 112 is a NAND storage device. In another embodiment, the memory device 112 is a HDD storage device. It is to be understood that the memory device 112 is not to be limited to either a NAND storage device or a HDD storage device. Rather, the memory device 112 is applicable to any storage device capable of storing data that may be retrieved by one or more CPUs.
As will be discussed herein, there are 4/3 bits per cell for the first writing and 1 bit per cell on the second writing (or update writing). Because there are 4/3 bits per cell for the first writing, then there is only 10.67 kB of data exposed to the user for the first write represented by arrows “C” in
During the rewrite, only 8 kB of data is exposed to the user as shown by arrows “D” in
In Example 2, code mapping for 3 MLC cells with minimum changes will be discussed. L is low (0 or 1); H is high (2 or 3); I is in (level 1 or 2); and O is out (level 0 or 3). The current mapping for a 4-level MLC is {E, P1, P2, P3}={11, 10, 00, 01}. During the first write process, {0, 1, 2, 3} translates to the following: {111, 011, 101, 110}. For LSB, 0→LLL {111}; 1→HLL {011}; 2→LHL {101}; and 3→LLH {110}. For MSB, 0→OOO {111}; 1→IOO {011}; 2→OIO {101}; and 3→OOI {110}. For the first write process, (LSB, MSB), the LSB=3={110} and MSB=2={101}. The first update is programmed to (0,1,3); when the LSB is read, the pattern=(L,L,H), and all (L,L,H)-pattern corresponds to LSB=3. When reading the MSB, the pattern=(O,I,O), and all (O,I,O) patterns correspond to MSB=2. Considering the digits in order of the LSB and MSB together (LSB first followed by MSB), the resulting pairs are (11, 10, 01) which, according to the mapping noted above, equals (E, P1, P3)=C13.
For the second writing, or updated writing, both the LSB and MSB depend upon C13. For LSB, 00 (or 0)→LHH {100}, HLL {011}; 01 (or 1)→HHH {000}; 10 (or 2)→LLH {110}, HHL {001}; 11 (or 3)→LHL {101}, HLH {010}. For MSB, 0→IOO {011}, OIO {101}, OOI {110}; 1→IIO {001}, OII {100}, IOI {010}. For the second writing (or update), (LSB, MSB)=(3,0) and is programmed to (3,1,3). When the LSB is read, the pattern is (H,L,H), and all (H,L,H) patterns correspond to LSB=3. When reading MSB, the pattern is (O,I,O), and all (O,I,O) patterns correspond to MSB=0.
If LSB=(101) and MSB=(101) are chosen, then considering the digits in order of the LSB and MSB together (LSB first followed by MSB), the resulting pairs are (01, 10, 01) which, according to the mapping noted above, equals (P3, P1, P3)=(3,1,3)=C13. For Example 2, there are 2 bits LSB and 2 bits MSB on the first write. Then, there are 2 bits LSB and 1 bit MSB on the second write (or update) for a total of 7 bits for 3 cells. Note that the 3 MLC cells can store 6 bits conventionally. Therefore, the 7 bits represent a 17% increase. The average reads per page is 1.5 which equals the conventional reads per page. Thus, the read latency does not suffer, yet the amount of data that can be stored has increased.
In Example 3, code mappings for 3 TLC cells with minimum changes will be discussed. The current mapping for an 8-level MLC is {E, P1, P2, P3, P4, P5, P6, P7}={111, 110, 100, 000, 010, 011, 001, 101}. During the first write process, {0, 1, 2, 3} translates to the following: {000, 001, 010, 011}. The LSB=1={001}, the CSB=2={010} and MSB=1={001}. Considering the digits in order of the LSB, CSB and MSB together (LSB first followed by CSB and then MSB), the resulting groups are (000, 010, 101) which, according to the mapping noted above, equals (P3, P4, P7)=C13. For the second writing, or updated writing, only the LSB and MSB are used and depend upon C13. Additionally, P4, P5, P6, P7)={11, 10, 00, 01}. For LSB, 0→101, 010; 1→100, 011; 2→000; 3→110, 001. For MSB, 0→111; 1→001, 110; 2→011, 100; 3→101, 010. For the second writing (or update), LSB=3=(110) or (001). MSB=0=(111). If LSB=(110) and MSB=(111) are chosen, then considering the digits in order of the LSB and MSB together (LSB first followed by MSB), the resulting pairs are (11, 11, 01) which, according to the mapping noted above, equals (P4, P4, P7)=(4,4,7)=C13. For Example 3, there are 2 bits LSB, 2 bits CSB and 2 bits MSB on the first write. Then, there are 2 bits LSB and 2 bits MSB on the second write (or update) for a total of 10 bits for 3 cells. Note that the 3 TLC cells can store 9 bits conventionally. Therefore, the 10 bits represent an 11% increase. The average reads per page is 2 which is less than the 2.33 conventional reads per page. Thus, the read latency is reduced and the amount of data that can be stored has increased.
Writing data once and then erasing does not maximize resources. Doing so leads to short device life and eventual device failure. By writing twice to the same memory location prior to erasing the memory location, not only can more data be stored, but the device life is increased (relative to storing once and then erasing) because the data will not be erased until the memory location is used twice for storage.
While the foregoing is directed to embodiments of the present disclosure, other and further embodiments of the disclosure may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.
This application claims benefit of U.S. Provisional Patent Application Ser. No. 62/438,821, filed Dec. 23, 2016, which is herein incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5815434 | Hasbun | Sep 1998 | A |
7388781 | Litsyn et al. | Jun 2008 | B2 |
8879319 | Cassuto et al. | Nov 2014 | B1 |
9070427 | Sharon et al. | Jun 2015 | B2 |
20070101096 | Gorobets | May 2007 | A1 |
20120218827 | Baek | Aug 2012 | A1 |
20130301352 | Shim | Nov 2013 | A1 |
20130304966 | Joo | Nov 2013 | A1 |
20130311715 | Abraham | Nov 2013 | A1 |
20140122773 | Abraham | May 2014 | A1 |
20150193156 | Patel | Jul 2015 | A1 |
20150248325 | Calderbank et al. | Sep 2015 | A1 |
20150363105 | Nakao | Dec 2015 | A1 |
20150378613 | Koseki | Dec 2015 | A1 |
20160155495 | Oh | Jun 2016 | A1 |
20160364141 | Yeh | Dec 2016 | A1 |
Number | Date | Country |
---|---|---|
20160023633 | Mar 2016 | KR |
2016116930 | Jul 2016 | WO |
Entry |
---|
Jagmohan, et al.; Adaptive Endurance Coding for NAND Flash; date unknown; 5 total pages. |
Brian M. Kurkoski; IEEE Globecom 2010 Workshop on Application of Communication Theory to Emerging Memory Technologies; Rewriting Codes for Flash Memories Based Upon Lattices, and an Example Using the E8 Lattice; dated 2010; 5 total pages. |
Wang, et al.; 3D-FlashMap: A physical-location-aware block mapping strategy for 3D NAND flash memory; 2012 Design, Automation & Test in Europe Conference & Exhibition; Dresden; dated 2012; 1 page. |
Jaeyong, et al.; USENIX; The Advanced Computing Systems Association; Lifetime Improvement of NAND Flash-based Storage Systems Using Dynamic Program and Erase Scaling; dated Feb. 17-20, 2014; 15 total pages. |
Office Action for Korean Application No. 10-2017-0117260 dated Nov. 22, 2018. |
Number | Date | Country | |
---|---|---|---|
20180182453 A1 | Jun 2018 | US |
Number | Date | Country | |
---|---|---|---|
62438821 | Dec 2016 | US |