This application is based upon and claims the benefit of priority from the prior Japanese Patent Applications No. 2019-166519 filed on Sep. 12, 2019 and No. 2020-104833 filed on Jun. 17, 2020, the entire contents of which are incorporated herein by reference.
Embodiments described herein relate generally to a memory system.
In a NAND flash memory, multi-level data configured of multiple bits is generally written into memory cells, and a triple level cell (TLC) technology for writing multi-level data configured of three bits into memory cells has been put into practical use. In the future, a quadruple level cell (QLC) technology for writing multi-level data configured of four bits will be the mainstream.
In the QLC, in order to avoid inter-cell interference, a method has been studied in which 4-bit data is written simultaneously to the first memory cell, 4-bit data also is written simultaneously to the adjacent cells similarly, and then 4-bit data is rewritten simultaneously to the first memory cell. However, in this method, in order to rewrite the 4-bit data, it is necessary to hold the 4-bit data in the write buffer in the memory controller until the rewriting is completed.
In recent years, the NAND memory has been made three-dimensional, and there is a problem that the memory capacity of the required write buffer increases, and the cost of the memory controller incorporating the write buffer increases. For this reason, even in a three-dimensional nonvolatile memory, a measure for reducing the write buffer amount of the memory controller is necessary.
As the measure for reducing the write buffer amount of the memory controller while avoiding the inter-cell interference, a method is known in which when each bit of data is written to the memory cell, it is not necessary to rewrite all bit data by writing the data in two stages in a dividing manner.
However, this method has a problem that the bit error rate is largely biased when each bit data is written in the memory cell.
To improve the reliability of the QLC technology, it is necessary to avoid the inter-cell interference, reduce the capacity of the write buffer in the memory controller, and suppress the bias of the bit error rate at the time of writing each bit data.
According to one embodiment, a memory system has a nonvolatile memory which comprises a plurality of memory cells capable of storing 4-bit data of first to fourth bits by sixteen threshold regions including a first threshold region indicating an erased state for erasing data and second to sixteenth threshold regions having higher voltage levels than a voltage level of the first threshold region and indicating a written state for writing data, and a controller configured to cause the nonvolatile memory to execute a first program for writing data of the first bit and the second bit and then cause the nonvolatile memory to execute a second program for writing data of the third bit and the fourth bit. Among fifteen boundaries existing between adjacent threshold regions among the first to sixteenth threshold regions, the number of first boundaries used for determining a value of the data of the first bit, the number of second boundaries used for determining a value of the data of the second bit, the number of third boundaries used for determining a value of the data of the third bit, and the number of fourth boundaries used for determining a value of the data of the fourth bit are 1, 4, 5, 5 or 4, 1, 5, 5 in order, the controller is configured to cause the nonvolatile memory to execute the first program such that the threshold region in the memory cell is any threshold region of a seventeenth threshold region indicating an erased state for erasing data and eighteenth to twentieth threshold regions having higher voltage levels than a voltage level of the seventeenth threshold region and indicating a written state for writing data according to the data of the first bit and the second bit, the n-th threshold region has a higher voltage level than the (n−1)-th threshold region (n is a natural number of two or more and sixteen or less), the k-th threshold region has a higher voltage level than the (k−1)-th threshold region (k is a natural number of eighteen or more and twenty or less), the controller is configured to cause the nonvolatile memory to execute the second program such that the threshold region in the memory cell is any threshold region of four threshold regions among the first to sixteenth threshold regions from any threshold region of the seventeenth to twentieth threshold regions according to the data of the third bit and the fourth bit, and the number of threshold regions between a threshold region having a lowest voltage level and a threshold region having a highest voltage level among the four threshold regions is four or less.
Hereinafter, an embodiment of a memory system will be described with reference to the drawings. In the following, the main components of the memory system will be mainly described. However, the memory system may include components and functions that are not illustrated or described.
The nonvolatile memory 3 is a memory that stores data in a nonvolatile manner, and includes, for example, a NAND flash memory (hereinafter also referred to as a NAND memory) 5. In this embodiment, an example will be described in which the nonvolatile memory 3 is a 4-bit/Cell (QLC: Quad Level Cell) NAND memory 5 having memory cells capable of storing 4-bit data per memory cell. The nonvolatile memory 3 according to this embodiment has a three-dimensional structure in which memory cells are stacked three-dimensionally. The nonvolatile memory 3 includes a plurality of memory cells capable of storing the first to fourth bit data by a threshold region indicating an erased state in which data is erased, and fifteen threshold regions which have higher voltage levels than a voltage level of the threshold region indicating the erased state and indicate a written state in which data is written.
The memory controller 2 controls the writing of data to the nonvolatile memory 3 in accordance with a write command from the host 4. The memory controller 2 controls the reading of data from the nonvolatile memory 3 in accordance with a read command from the host 4. The memory controller 2 includes a random access memory (RAM) 6, a read only memory (ROM) 7, a processor 8, a host interface 9, an error check and correct (ECC) circuit 10, and a memory interface 11. The RAM 6, the processor 8, the host interface 9, the ECC circuit 10, and the memory interface 11 are connected by a common internal bus 12.
The host interface 9 outputs the command, the user data (write data), and the like received from the host 4 to the internal bus 12. In addition, the host interface 9 transmits the user data read from the nonvolatile memory 3, the response from the processor 8, and the like to the host 4.
The memory interface 11 controls processing of writing user data and the like to the nonvolatile memory 3 and processing of reading from the nonvolatile memory 3 based on instructions from the processor 8.
The processor 8 controls the memory controller 2 in an integrated manner. The processor 8 is, for example, a central processing unit (CPU), a micro processing unit (MPU), or the like. When receiving a command from the host 4 via the host interface 9, the processor 8 performs control according to the command. For example, the processor 8 instructs the memory interface 11 to write user data and parity to the nonvolatile memory 3 in accordance with the command from the host 4. Further, the processor 8 instructs the memory interface 11 to read the user data and the parity from the nonvolatile memory 3 in accordance with a command from the host 4.
The user data is stored in the RAM 6 via the internal bus 12. The processor 8 determines a storage region (memory region) on the nonvolatile memory 3 for the user data stored in the RAM 6. The processor 8 determines a memory region on the nonvolatile memory 3 for page unit data (page data) that is a write unit. In this specification, the user data stored in one page of the nonvolatile memory 3 is defined as unit data. The unit data is generally encoded and stored as a code word in the nonvolatile memory 3, but the encoding is not essential. The memory controller 2 may store the unit data in the nonvolatile memory 3 without encoding, but
The processor 8 determines the memory region of the nonvolatile memory 3 to be a writing destination for each unit data. A physical address is assigned to the memory region of the nonvolatile memory 3. The processor 8 manages the memory region to be a writing destination of unit data using the physical address. The processor 8 specifies the determined memory region (physical address) and instructs the memory interface 11 to write the user data to the nonvolatile memory 3.
On the other hand, the host 4 manages data with a logical address. For this reason, the processor 8 manages the correspondence between the logical address and the physical address of the user data. When the processor 8 receives a read command including a logical address from the host 4, the processor 8 specifies a physical address corresponding to the logical address and specifies the physical address to instruct the memory interface 11 to read user data.
In this specification, a plurality of memory cells commonly connected to one word line are defined as a memory cell group MG. One memory cell group MG is a unit for writing (programming). In this embodiment, the nonvolatile memory 3 is a NAND memory 5 of 4 bits/cell, and one memory cell group MG has a data amount of 4 bits×the number of bits. Each bit written to each memory cell corresponds to a different page.
In this embodiment, the four pages of one memory cell group MG are referred to as a Lower page (first page), a Middle page (second page), an Upper page (third page), and a Top page (fourth page).
The ECC circuit 10 encodes user data stored in the RAM 6 to generate a code word. Further, the ECC circuit 10 decodes the code word read from the nonvolatile memory 3. The ECC circuit 10 corrects a bit error included in the code word read from the nonvolatile memory 3 and then decodes the bit error into user data.
The RAM 6 temporarily stores the user data received from the host 4 until the user data is stored in the nonvolatile memory 3, and temporarily stores the data read from the nonvolatile memory 3 until the data is transmitted to the host 4. The RAM 6 is a general-purpose memory such as a static random access memory (SRAM) or a dynamic random access memory (DRAM).
When a write request is received from the host 4, the memory system 1 operates as follows. The processor 8 temporarily stores the write data in the RAM 6. The processor 8 reads the data stored in the RAM 6 and inputs the data to the ECC circuit 10. The ECC circuit 10 encodes the input data and inputs the code word to the memory interface 11. The memory interface 11 writes the input code word into the nonvolatile memory 3.
When the read request is received from the host 4, the memory system 1 operates as follows. The memory interface 11 inputs the code word read from the nonvolatile memory 3 to the ECC circuit 10. The ECC circuit 10 decodes the input code word and temporarily stores the decoded data in the RAM 6. The processor 8 transmits the data stored in the RAM 6 to the host 4 via the host interface 9. Note that the nonvolatile memory 3 may be configured of a plurality of chips, and the nonvolatile memory 3 and the memory interface 11 can be connected by a through via (TSV: Through Silicon Via).
Note that the configuration of the memory controller 2 illustrated in
The control unit 22 controls the operation of the nonvolatile memory 3 based on the command from the memory controller 2 via the NAND I/O interface 21. Specifically, when a write request is input, the control unit 22 performs control to write the data requested to be written to a specified address on the NAND memory cell array 23. In addition, when a read request is input, the control unit 22 reads the data requested to be read from the NAND memory cell array 23 and outputs the data to the memory controller 2 via the NAND I/O interface 21. The page buffer 24 is a buffer that temporarily stores the data input from the memory controller 2 when writing to the NAND memory cell array 23 and temporarily stores the data read from the NAND memory cell array 23.
The control unit 22 includes an oscillator 31, a sequencer 32, a command user interface 33, a voltage supply unit 34, a column counter 35, and a serial access controller 36. The NAND memory cell array 23 includes a row decoder 37 and a sense amplifier 38.
The NAND I/O interface 21 is a circuit for transmitting and receiving JO signals and control signals to and from the memory controller 2. The command user interface 33 acquires the command and the address among the command, the address, and the data received from the memory controller 2 via the JO signal line based on the control signal. The command user interface 33 passes the acquired command and address to the sequencer 32.
The oscillator 31 is a circuit that generates a clock. The clock generated by the oscillator 31 is supplied to each component including the sequencer 32. The sequencer 32 is a state machine driven by the clock supplied from the oscillator 31. The sequencer 32 executes control such as access to the NAND memory cell array 23. For example, the sequencer 32 issues commands for controlling various internal voltages, operation timings, and the like in accordance with commands received from the command user interface 33. Further, the sequencer 32 supplies the block address and page address included in the address received from the command user interface 33 to the row decoder 37. Further, the sequencer 32 supplies the column counter 35 with the column address included in the address received from the command user interface 33.
The voltage supply unit 34 generates various internal voltages supplied to the word lines and various internal voltages supplied to the bit lines, and supplies the internal voltages to the row decoder 37 and the sense amplifier 38. The column counter 35 sequentially advances the column address according to the control signal supplied from the serial access controller 36 with the column address supplied from the sequencer 32 as the head during the program operation or the read operation.
The page buffer 24 sequentially stores the data received from the serial access controller 36 in the column address region designated by the column counter 35 during the program operation. Further, during the read operation, the page buffer 24 sequentially sends the data at the column address specified by the column address among the stored data to the serial access controller 36 during the read operation.
The serial access controller 36 stores the data received serially from the NAND I/O interface 21 for each bit width of the IO signal line in the page buffer 24 during the program operation. Further, the serial access controller 36 sends the data received serially from the page buffer 24 for each bit width of the IO signal line to the NAND I/O interface 21 during the read operation.
The row decoder 37 decodes a block address and a page address during the program operation and the read operation, and selects a word line corresponding to a page to be accessed included in the access destination block BLK. Each row decoder 37 applies an appropriate voltage to the selected word line and the unselected word line.
In the program operation, the sense amplifier 38 transfers the corresponding data stored in the page buffer 24 to the memory cell transistor. In the read operation, the sense amplifier 38 senses data read from the selected word line to the bit line and stores the obtained data in the page buffer 24. The data stored in the page buffer 24 is sent to the memory controller 2 via the serial access controller 36 and the NAND I/O interface 21.
As illustrated in
Note that the number of memory cell transistors MT in the NAND string NS is not limited to eight. The memory cell transistor MT is arranged between the select transistors ST1 and ST2 such that the current path thereof is connected in series. The current path of the memory cell transistor MT7 on one end side of the series connection is connected to one end of the current path of the select transistor ST1, and the current path of the memory cell transistor MT0 on the other end side is connected to one end of the current path of the select transistor ST2.
The gates of the select transistors ST1 of the fingers FNG0 to FNG3 are commonly connected to select gate lines SGD0 to SGD3, respectively. On the other hand, the gates of the select transistors ST2 are commonly connected to the same select gate line SGS between the plurality of fingers FNG. The control gates of the memory cell transistors MT0 to MT7 in the same block BLK are commonly connected to the word lines WL0 to WL7, respectively. That is, the word lines WL0 to WL7 and the select gate line SGS are connected in common between a plurality of fingers FNG0 to FNG3 in the same block BLK, whereas the select gate line SGD is independent for each of the fingers FNG0 to FNG3 even in the same block BLK.
The word lines WL0 to WL7 are connected to the control gate electrodes of the memory cell transistors MT0 to MT7 configuring the NAND string NS, respectively, and the i-th memory cell transistor MTi (i=0 to n) in each NAND string NS in the same finger FNG is commonly connected by the same word line WLi (i=0 to n). That is, the control gate electrodes of the memory cell transistors MTi in the same row in the block BLK are connected to the same word line WLi.
Each NAND string NS is connected to the word line WLi and also to the bit line. Each memory cell in each NAND string NS can be identified by an address for identifying the word line WLi and select gate lines SGD0 to SGD3 and an address for identifying the bit line. As described above, the data in the memory cells (memory cell transistors MT) in the same block BLK are erased collectively. On the other hand, data reading and writing are performed in units of physical sectors MS. One physical sector MS includes a plurality of memory cells connected to one word line WLi and belonging to one finger FNG.
The memory controller 2 performs writing (programming) in units of all NAND strings NS connected to one word line in one finger. For this reason, the unit of the amount of data to be programmed by the memory controller 2 is 4 bits×the number of bit lines.
During the read operation and the program operation, one word line WLi and one select gate line SGD are selected according to the physical address, and the physical sector MS is selected. In this specification, writing data to a memory cell is called a program as necessary.
A memory hole 45 that penetrates through the wiring layers 42, 43, and 44 and reaches the p-type well region 41 is formed. A block insulating film 46, a charge storage layer 47, and a gate insulating film 48 are sequentially formed on the side surface of the memory hole 45, and a conductive film 49 is embedded in the memory hole 45. The conductive film 49 functions as a current path of the NAND string NS, and is a region where a channel is formed during the operation of the memory cell transistor MT and the select transistors ST1 and ST2.
In each NAND string NS, the select transistor ST2, the plurality of memory cell transistors MT, and the select transistor ST1 are sequentially stacked on the p-type well region 41. On the upper end of the conductive film 49, a wiring layer functioning as the bit line BL is formed.
Furthermore, an n+-type impurity diffusion layer and a p+-type impurity diffusion layer are formed in the surface of the p-type well region 41. A contact plug 50 is formed on the n+-type impurity diffusion layer, and a wiring layer functioning as a source line SL is formed on the contact plug 50. A contact plug 51 is formed on the p+-type impurity diffusion layer, and a wiring layer functioning as a well wiring CPWELL is formed on the contact plug 51. The well wiring CPWELL is used for applying an erasing voltage.
A plurality of NAND memory cell arrays 23 illustrated in
In
In this embodiment, the region where the threshold voltage is less than or equal to Vr1 is called a region S0, the region where the threshold voltage is greater than Vr1 and less than or equal to Vr2 is called a region S1, the region where the threshold voltage is greater than Vr2 and less than or equal to Vr3 is called a region S2, and the region where the threshold voltage is greater than Vr3 and less than or equal to Vr4 is called a region S3. In this embodiment, the region where the threshold voltage is greater than Vr4 and less than or equal to Vr5 is referred to as a region S4, the region where the threshold voltage is greater than Vr5 and less than or equal to Vr6 is referred to as a region S5, the region where the threshold voltage is greater than Vr6 and less than or equal to Vr7 is referred to as a region S6, and the region where the threshold voltage is greater than Vr7 and less than or equal to Vr8 is referred to as a region S7. In this embodiment, the region where the threshold voltage is greater than Vr8 and less than or equal to Vr9 is referred to as a region S8, the region where the threshold voltage is greater than Vr9 and less than or equal to Vr10 is referred to as region S9, the region where the threshold voltage is greater than Vr10 and less than or equal to Vr11 is referred to as a region S10, and the region where the threshold voltage is greater than Vr11 and less than or equal to Vr12 is referred to as a region S11. In this embodiment, the region where the threshold voltage is greater than Vr12 and less than or equal to Vr13 is referred to as a region S12, the region where the threshold voltage is greater than Vr13 and less than or equal to Vr14 is referred to as a region S13, the region where the threshold voltage is greater than Vr14 and less than or equal to Vr15 is referred to as a region S14, and the region where the threshold voltage is greater than Vr15 is referred to as a region S15.
The threshold distributions corresponding to the regions S0 to S15 are referred to as first to sixteenth distributions. Vr1 to Vr15 are threshold voltages that serve as boundaries between the threshold regions.
In the nonvolatile memory 3, a plurality of data values are respectively associated with a plurality of threshold regions of the memory cell. This correspondence is called data coding. This data coding is determined in advance, and when data is written (programmed), charges are injected into the charge storage layer 47 in the memory cell so as to be within the threshold region corresponding to the data value stored in accordance with the data coding. At the time of reading, a read voltage is applied to the memory cell, and the data logic is determined depending on whether the threshold of the memory cell is lower or higher than the read voltage.
When data is read, the logic of the data is determined depending on whether the threshold is lower or higher than the read level at the boundary to be read. A case where the threshold is the lowest means the “erased” state, and all bits of data are defined as “1”. When the threshold is higher than the “erase” state, it is in a “programmed” state, and the data is defined as “1” or “0” according to the coding.
A memory cell of which the threshold voltage is in the S0 region is in a state of storing “1111”.
A memory cell of which the threshold voltage is in the S1 region is in a state of storing “0111”.
A memory cell of which the threshold voltage is in the S2 region is in a state of storing “0101”.
A memory cell of which the threshold voltage is in the S3 region is in a state of storing “0001”.
A memory cell of which the threshold voltage is in the S4 region is in a state of storing “0011”.
A memory cell of which the threshold voltage is in the S5 region is in a state of storing “1011”.
A memory cell of which the threshold voltage is in the S6 region is in a state of storing “1001”.
A memory cell of which the threshold voltage is in the S7 region is in a state of storing “1101”.
A memory cell of which the threshold voltage is in the S8 region is in a state of storing “1100”.
A memory cell of which the threshold voltage is in the S9 region is in a state of storing “1000”.
A memory cell of which the threshold voltage is in the S10 region is in a state of storing “0000”.
A memory cell of which the threshold voltage is in the S11 region is in a state of storing “0100”.
A memory cell of which the threshold voltage is in the S12 region is in a state of storing “0110”.
A memory cell of which the threshold voltage is in the S13 region is in a state of storing “1110”.
A memory cell of which the threshold voltage is in the S14 region is in a state of storing “1010”.
A memory cell of which the threshold voltage is in the S15 region is in a state of storing “0010”.
Thus, the logic of 4-bit data in each memory cell can be expressed for each threshold voltage region. When the memory cell is in an unwritten state (“erased” state), the threshold voltage of the memory cell is in the S0 region. In the codes shown here, only one bit of data changes between any two adjacent states such that data “1111” is stored in the S0 (erase) state, and data “0111” is stored in the S1 state. As described above, the coding illustrated in
In the coding of this embodiment illustrated in
The threshold voltages that serve as boundaries for determining the bit value of the Top page are Vr1, Vr5, Vr10, Vr13, and Vr15.
The threshold voltages that serve as boundaries for determining the bit value of the Upper page are Vr3, Vr7, Vr9,
Vr11, and Vr14.
The threshold voltages that serve as boundaries for determining the bit value of the Middle page are Vr2, Vr4, Vr6, and Vr12.
The threshold voltage that serves as a boundary for determining the bit value of the Lower page is Vr8.
In this way, the numbers (hereinafter referred to as a boundary number) of the threshold voltages for determining the bit value are 1, 4, 5, and 5 on the Lower page, Middle page, Upper page, and Top page, respectively. Hereinafter, such coding is referred to as 1-4-5-5 coding by using the respective boundary numbers of the Lower page, Middle page, Upper page, and Top page.
The first characteristic feature here is that the maximum number of boundaries at which the bit value of each page changes is five. When sixteen states are expressed by 4 bits, the minimum value of the maximum boundary number is four, and the coding in
The second characteristic feature is that the number of the boundaries of the Lower page is one, and the number of the boundaries of the Middle page is four. The program can be made in two stages of the first stage program that combines the Lower page and the Middle page and the second stage program that combines the Upper page and the Top page. In addition, the third characteristic feature is that the change width from the threshold region generated by the first stage program to the threshold region generated by the second stage program is small. That is, the change width of the threshold voltage is small. These features will be described in detail later.
The control unit 22 of the nonvolatile memory 3 controls the program to the NAND memory cell array 23 and the reading from the NAND memory cell array 23 based on the coding illustrated in
In the three-dimensional memory cell, the miniaturization of the memory cell does not progress as much as the two-dimensional memory cell. For this reason, in the three-dimensional memory cell, the inter-cell interference is small if the generation is such that the interval between adjacent memory cells is wide. In this case, generally, a method is employed in which all bits of each memory cell are programmed simultaneously, for example, all pages are programmed simultaneously if all bits are allocated to different pages.
When all the bits of each memory cell are programmed simultaneously, combination of the data coding is not particularly limited. The positioned region among the sixteen threshold regions may be determined based on the data of all bits, and the region of S0 in the erased state may be programmed to become the determined threshold region. In this case, generally, data coding such as 4-4-3-4 coding in which the maximum number of boundaries becomes a minimum value is employed. In the 4-4-3-4 coding, when fifteen boundaries between sixteen threshold regions are distributed to four pages, four boundaries are distributed to the Lower page, four boundaries are distributed to the Middle page, three boundaries are distributed to the Upper page, and four boundaries are distributed to the Top page. In this coding, since the deviation in the number of boundaries between pages is small, as a result, the deviation in the bit error rate between pages is reduced. This is because most of the causes of bit errors are caused by the threshold shifting to the adjacent threshold region, and the number of bit errors increases as the number of boundaries in the page increases. This is also effective for suppressing deterioration in response performance of the memory system 1 in response to the write request from the host 4, cost, and power consumption since the ECC correction capability necessary to correct the page data error must be strengthened even if the error rate as a memory cell is the same. Also, the reading speed bias caused by the bias of the boundary number is reduced.
In addition, in the 4-bit/Cell NAND memory 5, the interval between adjacent threshold regions is narrowed, so the influence of inter-cell interference is greater than that of the 1-bit/Cell or 2-bit/Cell NAND memory 5. For this reason, in the NAND memory 5 of the generation that has advanced recently in miniaturization, generally, a program method (Foggy-Fine program) is employed which gradually injects charges into the charge storage layer 47 of the memory cell by using a plurality of program stages, for example, two program stages (hereinafter sometimes simply referred to as stages) in order to suppress inter-cell interference. In this Foggy-Fine program, the memory cell is written in the first stage (Foggy stage), and then the neighboring cell is written. Then, the second stage (Fine stage) is written after returning to the first memory cell. Each stage in this case is a program execution unit, and the program of the memory cell corresponding to one word line WLi is completed by executing two program stages.
In both the first stage program and the second stage program, the program is executed using sixteen threshold regions. The threshold distribution in the threshold region at the end of the first stage program has a wider width than the threshold distribution of the threshold region in the final data coding. That is, in the Foggy stage, Foggy (rough) writing is performed. The Foggy stage program requires all four pages of input data. Since the threshold distribution after programming of the Foggy stage is in the intermediate state in which adjacent distributions overlap each other, data cannot be read out. In the program of the Fine stage which is the second stage, the threshold region after the Foggy stage program is moved to the threshold region in the final data coding. In other words, Fine writing is performed in the Fine stage. The Fine stage program also requires all four pages of input data. Since the threshold distribution after programming the Fine stage is in the final state in which adjacent distributions are separated, data can be read after programming the Fine stage.
In the case of 4-4-3-4 coding, the deviation in the number of boundaries is small, but data input for the Foggy-Fine program requires data input for four pages at each stage. This increases the time required for data input and deteriorates the response performance of the memory system 1 in response to the write request from the host 4. In addition, in the memory system 1, the buffer amount (write buffer amount) of the write buffer for holding data for input to the NAND memory 5 is increased. The write buffer is generally assigned with a partial region of the RAM 6 in the memory system 1.
As a measure for these, in this embodiment, the memory system 1 employs 1-4-5-5 coding for the nonvolatile memory 3 having a three-dimensional structure, and further writes in page units (page by page) in two stages. Thereby, in this embodiment, even in the nonvolatile memory 3 having a three-dimensional structure, the write buffer amount of the memory controller 2 is reduced while suppressing the inter-cell interference between cells and the deviation of the bit error rate between pages.
Here, the interference between adjacent memory cells will be described. The charge stored in the charge storage layer 47 of one memory cell disturbs the electric field of the adjacent memory cell, and as a result, gives noise that fluctuates the threshold when reading the adjacent memory cell. When programming and verifying are performed under a certain electric field condition and the programming is completed, the adjacent memory cells are programmed to different charges, resulting in deterioration in reading accuracy. This interference between adjacent memory cells becomes more prominent as the memory device manufacturing technology becomes fine and the memory cell interval is reduced. The interference between adjacent memory cells is largely generated between adjacent memory cells connected to different bit lines on the same word line WLi.
The interference between adjacent memory cells can be mitigated by reducing the difference in the electric field condition between the memory cells during programming and verifying and during reading after the adjacent memory cells are programmed. As one method for reducing the interference between adjacent memory cells between adjacent memory cells connected to different bit lines on the same word line WLi, a method is provided which divides the program into a plurality of stages, and executes the program such that a large change in charge amount in the charge storage layer 47 does not occur between the stages.
In the program sequence in this embodiment, 4 bits on one word line WLi are programmed by two program stages, that is, a first stage and a second stage. Each program stage is a program execution unit, and the memory system 1 of this embodiment completes the writing of 4-bit data to the memory cell by executing the two program stages. In this embodiment, any one page of 4 bits is allocated to each of the two program stages. Specifically, Lower page data and Middle page data are allocated to the first stage program, and Upper page and Top page data are allocated to the second stage program.
As illustrated in (T1) of
Here, the threshold regions S8 and S12 may be coarsely programmed by increasing the width of the threshold region so that the threshold voltage is somewhat lowered. This is because the threshold region may be finally moved by the second stage program so that the interval between adjacent threshold regions becomes wide.
As a result, the memory cell is programmed to four values of levels by the data of the Lower page and the Middle page. It should be noted here that data writing in the first stage program (first program) is data writing of only the Lower page and Middle page data. The page data required for this execution may be only the Lower page and the Middle page. In addition, the threshold region after the first stage program is finally reprogrammed in the subsequent second stage program (second program), so there is no need to finely shape the threshold distribution, and high speed programming is possible. Since the data after the first stage program is seen as binary, the Lower page and Middle page data can be read out.
Further, as illustrated in (T3) of
In the second stage program, the greater the change width of the memory cell threshold from the end of the first stage program, the greater the interference between adjacent cells. Therefore, when the threshold region of the first stage changes to the threshold region of the second stage, it is preferable that the maximum value of the change width is minimized. In the example of
Typically, writing (programming) to the memory cell is performed by applying one or more program voltage pulses to the corresponding word line. After applying each program voltage pulse, reading is performed to confirm whether or not the memory cell moves beyond the threshold boundary level. By repeating this application and reading, it is possible to move the threshold of the memory cell within a threshold region having a predetermined threshold distribution.
More specifically, when a plurality of pages are written as in the second stage, the threshold voltages of the corresponding memory cells are determined from the data of all pages to be written (in this case, the Middle page, Upper page, and Top page), and the voltage values of the plurality of program pulses are gradually increased so as to be the determined threshold voltages. The memory cells that have reached the target threshold voltages are excluded from the write targets. As described above, writing to the memory cell is not performed for each page, but is performed together for all pages to be written.
Note that the control unit 22 may continuously execute the first stage program and the second stage program for one word line WLi, but in order to reduce the influence of interference between adjacent memory cells, the program may be executed in a discontinuous order across a plurality of word lines WLi.
On the left side from the boundary position between 1 and 0 on the Lower page in
When writing is started, the control unit 22 advances each program stage while straddling the word lines WLi in a predetermined discontinuous order. That is, the first stage and the second stage for the same word line are not continuously executed. The programming is performed in the first stage for a certain word line, and then the programming is performed in the second stage for a different word line.
When the programming is completed up to the second stage for a certain word line, and programming of the first stage and the second stage is continuously performed for the adjacent word lines, the amount of fluctuation in the threshold voltage increases. When the fluctuation amount of the threshold voltage of the adjacent word line is large, the interference between adjacent memory cells between the word lines becomes large. Therefore, in order to reduce the interference between adjacent memory cells between the word lines, it is effective to reduce the fluctuation amount of the threshold voltage of the adjacent word line after the word line is completely programmed to the second stage. In the sequence of
In a case where the programming is performed on the NAND memory 5 having the three-dimensional structure in the program order of
(1) First, the control unit 22 executes a program ST11 of the first stage of the word line WL0.
(2) Next, the control unit 22 executes a program ST12 of the first stage of the word line WL1.
(3) Next, the control unit 22 executes a program ST13 of the second stage of the word line WL0.
(4) Next, the control unit 22 executes a program ST14 of the first stage of the word line WL2.
(5) Next, the control unit 22 executes a program ST15 of the second stage of the word line WL1.
(6) Next, the control unit 22 executes a program ST16 of the first stage of the word line WL3.
(7) Next, the control unit 22 executes a program ST17 of the second stage of the word line WL2.
(8) Next, the control unit 22 executes a program ST18 of the first stage of the word line WL4.
(9) Next, the control unit 22 executes a program ST19 of the second stage of the word line WL3.
Similarly, the control unit 22 proceeds the process obliquely upward from the lower left to the upper right in
In a case where the programming is performed on the NAND memory 5 having the three-dimensional structure in the program order of
(11) First, the control unit 22 executes a program ST21 of a first stage of a string St0_word line WL0.
(12) Next, the control unit 22 executes a program ST22 of a first stage of a string St1_word line WL0.
(13) Next, the control unit 22 executes a program ST23 of a first stage of a string St2_word line WL0.
(14) Next, the control unit 22 executes a program ST24 of a first stage of a string St3_word line WL0.
(15) Next, the control unit 22 executes a program ST25 of a first stage of a string St0_word line WL1.
(16) Next, the control unit 22 executes a program ST26 of a second stage of the string St0_word line WL0.
(17) Next, the control unit 22 executes a program ST27 of a first stage of a string St1_word line WL1.
(18) Next, the control unit 22 executes a program ST28 of a second stage of the string St1_word line WL0.
(19) Next, the control unit 22 executes a program ST29 of a first stage of a string St2_word line WL1.
(20) Next, the control unit 22 executes a program ST210 of a second stage of the string St2_word line WL0.
(21) Next, the control unit 22 executes a program ST211 of a first stage of a string St3_word line WL1.
(22) Next, the control unit 22 executes a program ST212 of a second stage of the string St3_word line WL0.
(23) Next, the control unit 22 executes a program ST213 of a first stage of a string St0_word line WL2.
(24) Next, the control unit 22 executes a program ST214 of a second stage of the string St0_word line WL1.
Similarly, the control unit 22 proceeds the process obliquely upward from the lower left to the upper right in
In a case where the programming is performed on the NAND memory 5 having the three-dimensional structure in the program order of
(31) First, the control unit 22 executes a program ST31 of the first stage of the string St0_word line WL0.
(32) Next, the control unit 22 executes a program ST32 of the first stage of the string St1_word line WL0.
(33) Next, the control unit 22 executes a program ST33 of the first stage of the string St2_word line WL0.
(34) Next, the control unit 22 executes a program ST34 of the first stage of the string St3_word line WL0.
(35) First, the control unit 22 executes a program ST35 of the first stage of the string St0_word line WL1.
(36) Next, the control unit 22 executes a program ST36 of the first stage of the string St1_word line WL1.
(37) Next, the control unit 22 executes a program ST37 of the first stage of the string St2_word line WL1.
(38) Next, the control unit 22 executes a program ST38 of the first stage of the string St3_word line WL1.
(39) Next, the control unit 22 executes a program ST39 of the second stage of the string St0_word line WL0.
(40) Next, the control unit 22 executes a program ST310 of the second stage of the string St1_word line WL0.
(41) Next, the control unit 22 executes a program ST311 of the second stage of the string St2_word line WL0.
(42) Next, the control unit 22 executes a program ST312 of the second stage of the string St3_word line WL0.
(43) Next, the control unit 22 executes a program ST313 of the first stage of the string St0_word line WL2.
(44) Next, the control unit 22 executes a program ST314 of the first stage of the string St1_word line WL2.
(45) Next, the control unit 22 executes a program ST315 of the first stage of the string St2_word line WL2.
(46) Next, the control unit 22 executes a program ST316 of the first stage of the string St3_word line WL2.
(47) Next, the control unit 22 executes a program ST317 of the second stage of the string St0_word line WL1.
(48) Next, the control unit 22 executes a program ST318 of the second stage of the string St1_word line WL1.
(49) Next, the control unit 22 executes a program ST319 of the second stage of the string St2_word line WL1.
(50) Next, the control unit 22 executes a program ST320 of the second stage of the string St3_word line WL1.
In
As described above, even when there are a plurality of strings St, the program order of each program stage of the word line WLi in one string St is the same as that in the case of one string St. In the case of the nonvolatile memory 3 having a three-dimensional structure in which a plurality of strings St exist in a block, in the program of the combination position of the word line WLi and the string St, generally, the same word line number in different strings St is programmed first, and then the procedure proceeds to the next word line number. When
Here, an example of a writing procedure according to the program order according to the first embodiment will be described with reference to
As illustrated in
Further, the control unit 22 executes the program of the first stage of the string St0_word line WL1 (step S40). Next, the control unit 22 executes the program of the second stage of the string St0_word line WL0 (step S50). Next, the control unit executes the program of the first stage of the string St1_word line WL1 (step S60). Thereafter, the control unit 22 repeats the processes such as steps S40, S50, and S60 for each word line WLi of each string St.
Then, the control unit 22 executes the program of the first stage of the string St0_word line WLn (step S70). Next, the control unit 22 executes the program of the second stage of the string St0_word line WLn−1 (step S80). Thereafter, the control unit 22 repeats the processes such as steps S70 and S80 for each word line WLi of each string St.
Then, the control unit 22 executes the program of the second stage of the string St3_word line WLn−1 (step S90). Next, the control unit 22 executes the program of the second stage of the string St0_word line WLn (step S100). Next, the control unit 22 executes the program of the second stage of the string St1_word line WLn (step S110). Thereafter, the control unit 22 performs the same process as steps S100 and S110 on each string St. Then, the control unit 22 executes the program of the second stage of the string St3_word line WLn (step S120).
At the time of data writing, one or more program voltage pulses are applied (step S270). Then, data reading is performed to confirm whether or not the memory cell moves beyond the threshold boundary level (step S280).
Furthermore, it is confirmed whether or not the number of data fail bits in the Lower page and the Middle page is smaller than the criterion (judgment criterion) (step S290). If the number of data fail bits is greater than or equal to the criterion (No in step S290), the processes of steps S250 to S270 are repeated. When the number of data fail bits becomes smaller than the criterion (Yes in step S290), the chip is ready (step S300). In this manner, by repeating the application, reading, and confirmation, it becomes possible to move the threshold of the memory cell within a predetermined threshold distribution range.
Next, the input start command of the Top page data is input from the memory controller 2 to the nonvolatile memory 3 (step S330). Then, the Top page data is input from the memory controller 2 to the nonvolatile memory 3 (step S340). Next, the program execution command of the second stage is input from the memory controller 2 to the nonvolatile memory 3 (step S350), and thereby the chip is busy (step S360).
Thereafter, the control unit 22 reads the Lower page data and the Middle page data which are IDL (Internal Data Load) (step S370). The Vth (threshold voltage) of the program destination of the Upper page and the Top page is determined based on the data of the Lower page and the Middle page (step S380). Thereafter, the data writing to the Upper page and the Top page is performed using the determined Vth. As described above, in steps S370 and S380, the control unit 22 in the nonvolatile memory 3 reads the data programmed by the first program, and determines the threshold voltage in the second program based on the read data. Alternatively, the control unit 22 in the nonvolatile memory 3 reads the first bit data and the second bit data programmed by the first program in response to the execution request of the second program from the memory controller 2, and performs the second program based on the read data and the third bit and fourth bit data.
Furthermore, in order to increase the reliability of the IDL read data, the control unit 22 can perform reading a plurality of times and use the majority decision of the read results in the page buffer 24 in the chip as next write data. Of course, the control unit 22 can perform reading a plurality of times during a normal reading operation and use the majority decision of the read results in the chip as the read data to the outside.
In each bit, it is determined that the majority result is “wrong” (a) when “wrong” is made three times and (b) when “wrong” is made twice. If p is the probability that each bit is wrong, when p=0.2, (a) the probability of three times of “wrong” is p×p×p=0.2×0.2×0.2, and (b) the probability of two times of “wrong” is (1−p)×p×p=(1−0.2)×0.2×0.2.
Therefore, it is determined that the result of the three-times majority decision is “wrong” with the probability of (p×p×p)+3×(1−p)×p×p=0.104. Thus, the control unit 22 can improve the reliability of read data by performing the process of the majority processing of the plurality of read results in the page buffer 24 in the chip.
At the time of data writing to the Upper page and the Top page, one or more program voltage pulses are applied (step S390). Then, in order to confirm whether or not the memory cell moves beyond the threshold boundary level, data reading of the Upper page and the Top page is performed (step S400).
Further, it is confirmed whether or not the number of data fail bits in the Upper page and the Top page is smaller than the criterion (step S410). When the number of data fail bits in the Upper page and the Top page is greater than or equal to the criterion (No in step S410), the processes of steps S390 to S410 are repeated. Then, when the number of data fail bits becomes smaller than the criterion (Yes in step S410), the chip is ready (step S420).
Here, a modification of the writing procedure illustrated in
In the case of the process procedure shown in
Thereafter, the control unit 22 reads the Lower page data at the threshold voltage of Vr7. Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltage of Vr7 (step S3003). Thereafter, the chip is ready (step S3004).
When the Lower page data read by the control unit 22 is output (step S3005), the Lower page data is transmitted to the ECC circuit 10 (step S3006). As a result, the ECC circuit 10 performs ECC correction on the Lower page data (step S3007).
Next, the read command of the Middle page is input from the memory controller 2 to the nonvolatile memory 3 (step S3008), and thereby the chip is busy (step S3009).
Thereafter, the control unit 22 reads the Middle page data at the threshold voltage of Vr7. Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr2 and Vr11 (step S3010). Thereafter, the chip is ready (step S3011).
When the Middle page data read by the control unit 22 is output (step S3012), the Middle page data is transmitted to the ECC circuit 10 (step S3013). Accordingly, the ECC circuit 10 performs ECC correction on the Middle page data (step S3014).
Then, the input start command of the Lower page data is input from the memory controller 2 to the nonvolatile memory 3 (step S3015). As a result, the ECC circuit 10 inputs the Lower page data to the nonvolatile memory 3 (step S3016). Next, the input start command of the Middle page data is input from the memory controller 2 to the nonvolatile memory 3 (step S3017). Thereby, the ECC circuit 10 inputs the data of the Middle page to the nonvolatile memory 3 (step S3018).
Thereafter, the processes of steps S310 to S420 are performed. In step S380, the Vth of the program destination of the Upper page and the Top page is determined based on the Lower page data/Middle page data from the ECC circuit 10.
In the above-described second stage program, the data input to the nonvolatile memory 3 is performed in only two pages of the Upper page and the Top page. However, in this second stage, Vth, which is the destination of the memory cell program, requires data for four pages including the Lower page and the Middle page (Vth before starting the second stage). For this reason, in the program at this stage, as a preprocess, the control unit 22 performs the operation of reading the Lower page data and Middle page data first and synthesizing the data with the input Upper page and Top page to determine the Vth of the program destination.
Note that the read level before the second stage writing may be slightly different from the read level after the second stage writing. Further, the process procedure illustrated in
The reason why the Lower page data or the Middle page data can be read out is because 1-4-5-5 coding is adopted in which the number of the Lower page boundaries is 1 and the number of the Middle page boundaries is 2. By reading the Lower page data and Middle page data at the second stage, it is not necessary to input the Lower page data and the Middle page data at the second stage. That is, since 1-4-5-5 coding is adopted and the Vth of the program destination is determined based on the Lower page data and the Middle page data, the interference between adjacent memory cells between word lines WLi can be reduced, and one page data only needs to be input once.
As a result, when 1-4-5-5 coding is adopted and the Foggy-Fine program is executed in two stages, the memory amount required for the write buffer of the memory controller 2 is a plurality of word lines (maximum eight pages). On the other hand, in this embodiment, the memory amount required for the write buffer of the memory controller 2 is at most two pages.
Here, a comparison between the process procedure of the Foggy-Fine program adopting 1-4-5-5 coding and the program process procedure of this embodiment will be described.
In
In the case of the Foggy-Fine program with the 1-4-5-5 coding, the data input for four pages and the program for four pages (Foggy stage program) are performed in the Foggy stage which is the first stage. In addition, in the case of the Foggy-Fine program with 1-4-5-5 coding, the data input for four pages and the program for four pages (Fine stage program) are performed also in the Fine stage which is the second stage.
For each of the word lines WL0, WL1, WL2, and so on, it is necessary to store the data for four pages written in the Foggy stage in the write buffer until the program is started in the Fine stage.
Even in the Foggy-Fine program, the data for four Lower/Middle/Upper/Top pages is not written continuously in order to reduce the interference between adjacent memory cells. For example, after the Foggy stage to the word line WL0 is executed, the Foggy stage to the word line WL1 adjacent to the word line WL0 is executed before the Fine stage to the word line WL0 is executed. Further, after the Foggy stage to the word line WL0 is executed, the Foggy stage to the word line WL2 adjacent to the word line WL1 is executed before the Fine stage to the word line WL1 is executed. In the case of this method, it is necessary to hold the data for four Lower/Middle/Upper/Top pages in the write buffer until the data input of the final second Fine stage is completed. Further, in order to reduce the interference between adjacent memory cells, it is necessary to hold the data for a plurality of word lines WLi in the write buffer. For example, when the Foggy stage is executed for the word line WL2, it is necessary to hold the data for four pages for the word line WL1 and the data for four pages for the word line WL2 in the write buffer. Thus, in the case of the Foggy-Fine program with 1-4-5-5 coding, it is necessary to hold the data for maximum eight pages in the write buffer.
For each of the word lines WL0, WL1, WL2, and so on, the data may be stored at the time of data input of each stage in the write buffer. When the program is started, the data may be deleted from the write buffer. For example, when data is input in the first stage, this data is stored in the write buffer. When the program is started at the first stage, the data stored in the write buffer may be deleted. Similarly, when the data is input in the second stage, this data is stored in the write buffer. When the program is started at the second stage, the data stored in the write buffer may be deleted. For this reason, in the case of the program of this embodiment, the data that needs to be held in the write buffer is data for at most two pages.
Also in the program of this embodiment, the data for four pages of Lower/Middle/Upper/Top is not continuously written in order to reduce interference between adjacent memory cells. For example, after the first stage to the word line WL0 is executed, the first stage to the word line WL1 adjacent to the word line WL0 is executed before the second stage to the word line WL0 is executed. Similarly, after the first stage for the word line WL1 is executed, the first stage to the word line WL2 adjacent to the word line WL1 is executed before the second stage to the word line WL1 is executed.
As described above, in this embodiment, all the page data is necessary only for one stage of the program, and therefore the data in the write buffer can be discarded when the data input is completed. Therefore, in this embodiment, the number of pages that need to be simultaneously held in the write buffer can be reduced.
The page data to be programmed into the nonvolatile memory 3 is once held in a write buffer in the RAM 6 and then written into the nonvolatile memory 3 at the time of programming. In this embodiment, the required capacity of the RAM 6 can be reduced, so that the cost can be reduced.
Also, as illustrated in
Here, the page reading process will be described. The page reading method differs depending on whether the program for the word line WLi including the page to be read is before or after writing in the second stage.
Before the second stage writing, only the Lower page and Middle page are valid as recorded data. For this reason, the control unit 22 reads data from the memory cell only when the read page is the Lower page or the Middle page. Then, in the case of other pages, the control unit 22 performs control to all forcibly output “1” as read data without performing the memory cell read operation.
On the other hand, in the case of the word line WLi that is completed to the second stage, the control unit 22 reads the memory cell regardless of whether the read page is any one of the Top/Upper/Middle/Lower pages. In this case, since the necessary read voltage differs depending on which page is read, the control unit 22 executes only necessary read for the selected page.
According to the coding illustrated in
In addition, since there are four boundaries between threshold states where the data of the Middle page changes, the control unit 22 determines the data depending on the position of the threshold voltage in the five ranges separated by these boundaries.
In addition, since there are five boundaries between threshold states where the data of the Top page or Upper page changes, the control unit 22 determines the data depending on the position of the threshold voltage in the six ranges separated by these boundaries.
Hereinafter, a specific process procedure for page reading will be described.
As illustrated in
When the read page is the Middle page, the control unit 22 performs reading with two read voltages of Vr2′ (≤Vr2) and Vr12′ (≤Vr12) (steps S465 and S470). In the case of the word line before the second stage writing, as illustrated in
When the read page is the Upper page, the control unit 22 performs control to all forcibly output “1” as the output data of the memory cell (step S480). When the read page is the Top page, the control unit 22 performs control to all forcibly output “1” as the output data of the memory cell (step S485).
On the other hand, in the case of the word line WLi that is completely programmed up to the second stage, as illustrated in
When the read page is the Middle page, the control unit 22 performs reading with the threshold voltages of Vr2, Vr4, Vr6, and Vr12 (steps S515, S520, S525, and S530). Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr2, Vr4, Vr6, and Vr12 (step S535).
When the read page is the Upper page, the control unit 22 performs reading with threshold voltages of Vr3, Vr7, Vr9, Vr11, and Vr14 (steps S540, S545, S550, S555, and S560). Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr3, Vr7, Vr9, Vr11, and Vr14 (step S565).
When the read page is the Top page, the control unit 22 performs reading with the threshold voltages of Vr1, Vr5, Vr10, Vr13, and Vr15 (steps S570, S575, S580, S585, and S590). Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr1, Vr5, Vr10, Vr13, and Vr15 (step S595).
Note that the memory controller 2 can manage and identify whether the program for the word line WLi is before or after the completion of the second stage writing. Since the memory controller 2 performs program control, if the memory controller 2 records the progress, the memory controller 2 can easily grasp the address and the program state of the nonvolatile memory 3. In this case, when reading is performed from the nonvolatile memory 3, the memory controller 2 identifies the program state of the word line WLi including the target page address and issues a read command corresponding to the identified state. In addition, another method can be provided in which a flag cell is provided for each word line WLi, the flag cell is written at the time of second stage writing, and whether the program is before or after the completion of second stage writing is managed and identified in the memory according to the flag cell data. The flag cell is described in, for example, U.S. patent application Ser. No. 15/437,391 filed on Feb. 20, 2017, “Memory System and Programming Method”. This patent application is incorporated herein by reference in its entirety.
Note that the read level before the second stage writing and after the second stage writing may be slightly different from the read level after the second stage writing.
In summary, the memory controller 2 in this embodiment causes the nonvolatile memory 3 to execute the second program for writing the data of the third bit and the fourth bit after causing the nonvolatile memory 3 to execute the first program for writing the data of the first bit and the second bit. Among the fifteen boundaries between the sixteen threshold regions, the number of the boundaries with different first bit values between the adjacent threshold regions, the number of the boundaries with different second bit values, the number of the boundaries with different third bit values, and the number of the boundaries with different fourth bit values, that is, the number of the changes of the bit values at the time of writing the first to fourth bit data are 1, 4, 5, 5 or 4, 1, 5, 5 in order. The first program and the second program are performed in the nonvolatile memory 3 such that the number of changes from the threshold region at the end of the first program to the threshold region at the end of the second program is within five of the threshold regions at the time of ending the second program. That is, the memory controller 2 causes the nonvolatile memory 3 to execute the first program having four threshold regions, and then causes the nonvolatile memory 3 to execute the second program having a total of 16 threshold regions in which the number of changes from the four threshold regions is within five.
The memory controller 2 causes the nonvolatile memory 3 to execute the first program and the second program so that the bit values of the second bit to the fourth bit do not change at the voltage level at the boundary position where the bit value of the first bit changes. For example, in the example of
In addition, the memory controller 2 causes the nonvolatile memory 3 to execute the first program and the second program so that on one of the side where the voltage level is lower than the boundary position where the bit value of the first bit changes and the side where the voltage level is higher than the boundary position, at least a part of the order of change from the threshold region at the end of the first program to the threshold region at the end of the second program changes, and on the other side of the boundary position, the order of change from the threshold region at the end of the first program to the threshold region at the end of the second program does not change. That is, when the memory controller causes the nonvolatile memory to execute the second program, the memory controller 2 has any one of the transition to one threshold region of a plurality of second threshold regions from the first threshold region that is the threshold region at the end of the first program, the transition to one threshold region of a plurality of fourth threshold regions from the third threshold region that is the threshold region at the end of the first program and has a higher voltage level than the first threshold region and a lower voltage level than the boundary between threshold regions having different first bit values, the transition to one threshold region of a plurality of sixth threshold regions from the fifth threshold region that is the threshold region at the end of the first program and has a higher voltage level than the boundary between threshold regions having different first bit values, and the transition to one threshold region of a plurality of eighth threshold regions from the seventh threshold region that is the threshold region at the end of the first program and has a higher voltage level than the fifth threshold region. The voltage level of one threshold region of the plurality of second threshold regions is higher than the voltage level of one threshold region of the plurality of fourth threshold regions. The voltage levels of all the threshold regions of the plurality of sixth threshold regions are lower than the voltage levels of all the threshold regions of the plurality of eighth threshold regions, or the voltage levels of all the threshold regions of the plurality of second threshold regions are lower than voltage levels of all the threshold regions of the plurality of fourth threshold regions. The voltage level of one threshold region of the plurality of sixth threshold regions is higher than the voltage level of one threshold region of the plurality of eighth threshold regions.
The data coding in this embodiment can be considered in addition to 1-4-5-5 illustrated in
A memory cell of which the threshold voltage is in the S0 region is in a state of storing “1111”.
A memory cell of which the threshold voltage is in the S1 region is in a state of storing “1011”.
A memory cell of which the threshold voltage is in the S2 region is in a state of storing “0011”.
A memory cell of which the threshold voltage is in the S3 region is in a state of storing “0111”.
A memory cell of which the threshold voltage is in the S4 region is in a state of storing “0101”.
A memory cell of which the threshold voltage is in the S5 region is in a state of storing “1101”.
A memory cell of which the threshold voltage is in the S6 region is in a state of storing “1001”.
A memory cell of which the threshold voltage is in the S7 region is in a state of storing “0001”.
A memory cell of which the threshold voltage is in the S8 region is in a state of storing “0000”.
A memory cell of which the threshold voltage is in the S9 region is in a state of storing “0100”.
A memory cell of which the threshold voltage is in the S10 region is in a state of storing “0110”.
A memory cell of which the threshold voltage is in the S11 region is in a state of storing “1110”.
A memory cell of which the threshold voltage is in the S12 region is in a state of storing “1100”.
A memory cell of which the threshold voltage is in the S13 region is in a state of storing “1000”.
A memory cell of which the threshold voltage is in the S14 region is in a state of storing “1010”.
A memory cell of which the threshold voltage is in the S15 region is in a state of storing “0010”.
In
On the left side from the boundary position between 1 and 0 of the Lower page in
The data coding in this embodiment can be considered in addition to 1-4-5-5. As typical examples, 3-2-5-5 and 3-4-4-4 will be described below in order.
A memory cell of which the threshold voltage is in the S0 region is in a state of storing “1111”.
A memory cell of which the threshold voltage is in the S1 region is in a state of storing “1011”.
A memory cell of which the threshold voltage is in the S2 region is in a state of storing “0011”.
A memory cell of which the threshold voltage is in the S3 region is in a state of storing “0111”.
A memory cell of which the threshold voltage is in the S4 region is in a state of storing “0101”.
A memory cell of which the threshold voltage is in the S5 region is in a state of storing “1101”.
A memory cell of which the threshold voltage is in the S6 region is in a state of storing “1100”.
A memory cell of which the threshold voltage is in the S7 region is in a state of storing “1000”.
A memory cell of which the threshold voltage is in the S8 region is in a state of storing “1001”.
A memory cell of which the threshold voltage is in the S9 region is in a state of storing “0001”.
A memory cell of which the threshold voltage is in the S10 region is in a state of storing “0000”.
A memory cell of which the threshold voltage is in the S11 region is in a state of storing “0100”.
A memory cell of which the threshold voltage is in the S12 region is in a state of storing “0110”.
A memory cell of which the threshold voltage is in the S13 region is in a state of storing “1110”.
A memory cell of which the threshold voltage is in the S14 region is in a state of storing “1010”.
A memory cell of which the threshold voltage is in the S15 region is in a state of storing “0010”.
In the case of 3-2-5-5 data coding in
As illustrated in
In
A modification of the page read process will be described below in which the boundary position between 1 and 0 of the Upper page is interchanged with the boundary position between 1 and 0 of the Top page. The page read process according to the modification may be performed only when the program for the word line WLi including the page to be read is after the second stage writing. The page read process according the modification is effective when all data of the selected word line is read since the reading speed may be improved in such a case.
In the page read process according to the modification, the data is sequentially read with the voltage being changed from the voltage Vr15 to the voltage Vr6 (step S655), and then data of the Lower page is determined and may be outputted (step S660). In step S660, the data of the Lower page is determined based on the data read with the read voltages Vr6, Vr8, and Vr10.
When the reading operation proceeds to the read voltage Vr4 (step S670), data of the Middle page is determined (step S675). In step S675, the data of the Middle page is determined based on the data read with the read voltages Vr4 and Vr12.
When the reading operation proceeds to the read voltage Vr2 (step S685), data of the Upper page is determined (step S690). In step S690, the data of the Upper page is determined based on the data read with the read voltages Vr2, Vr5, Vr13 and Vr15.
When the reading operation proceeds to the read voltage Vr1 (step S695), data of the Top page is finally determined (step S700). In step S700, the data of the Top page is determined based on the data read with the read voltages Vr1, Vr3, Vr7, Vr11, and Vr14.
Although the latency for determining and outputting the data of an arbitrarily selected page in the page read process according to the modification is longer than that in the page read process where the pages are read one by one as described before, the total time for reading all of four pates is shorter. As shown in
Although the example of data coding shown in
A memory cell of which the threshold voltage is in the S0 region is in a state of storing “1111”.
A memory cell of which the threshold voltage is in the S1 region is in a state of storing “1101”.
A memory cell of which the threshold voltage is in the S2 region is in a state of storing “1001”.
A memory cell of which the threshold voltage is in the S3 region is in a state of storing “1011”.
A memory cell of which the threshold voltage is in the S4 region is in a state of storing “0011”.
A memory cell of which the threshold voltage is in the S5 region is in a state of storing “0111”.
A memory cell of which the threshold voltage is in the S6 region is in a state of storing “0110”.
A memory cell of which the threshold voltage is in the S7 region is in a state of storing “0010”.
A memory cell of which the threshold voltage is in the S8 region is in a state of storing “1010”.
A memory cell of which the threshold voltage is in the S9 region is in a state of storing “1000”.
A memory cell of which the threshold voltage is in the S10 region is in a state of storing “0000”.
A memory cell of which the threshold voltage is in the S11 region is in a state of storing “0001”.
A memory cell of which the threshold voltage is in the S12 region is in a state of storing “0101”.
A memory cell of which the threshold voltage is in the S13 region is in a state of storing “0100”.
A memory cell of which the threshold voltage is in the S14 region is in a state of storing “1100”.
A memory cell of which the threshold voltage is in the S15 region is in a state of storing “1110”.
In the case of 3-4-4-4 data coding in
As illustrated in
The boundary position between 1 and 0 can be arbitrarily interchanged between the pages in
For example,
As described above, various modifications of the QLC in which two pages of program are performed in each of the first stage and the second stage have been described, but various other modifications also can be considered. Below, the modification which is not described until now is listed collectively.
In any of
Thus, in the first embodiment, when programming a 4-bit/Cell NAND memory 5 having a three-dimensional structure or a two-dimensional structure, for example, 1-4-5-5 data coding as illustrated in
Further, in this embodiment, since the variation in the number of times the bit value changes in each page is small, the deviation of the bit error rate between pages of the nonvolatile memory 3 can be reduced. For this reason, it is not necessary to strengthen the error correction capability of the ECC circuit 10, and the cost required for the ECC circuit 10 can be reduced. Further, since data transfer is performed only once for each page, transfer time and power consumption can be suppressed. Further, since each program stage is executed while straddling the word line WLi, the amount of interference between adjacent cells with the adjacent word line WLi can be reduced.
Further, the number of changes at the time of changing from the threshold region of the first stage to the threshold region of the second stage can be suppressed by using 1-4-5-5 data coding in
Further, by using 1-4-5-5 data coding in
In any of
The programming of the Lower page and the Middle page can be sped up, for example, when the step voltage at the time of writing while stepping up the write voltage little by little is set to a larger value compared to the time of the second stage program when writing and verifying after the writing are repeated.
Next, a second embodiment will be described using
In the program flowchart illustrated in
For example, in the example illustrated in
In this way, by inputting program commands and program data together, the frequency of command input and polling (periodic check on whether or not chip busy has returned to ready) in the control performed by the memory controller 2 is reduced. Thus, the memory system 1 can be sped up, and the processing can be simplified.
Hereinafter, an example of a writing procedure according to the second embodiment will be described with reference to
As illustrated in
Further, the control unit 22 executes the first stage program of the string St0_word line WL1 and the second stage program of the string St0_word line WL0 (step S840). Next, the control unit 22 executes the first stage program of the string St1_word line WL1 and the second stage program of the string St1_word line WL0 (step S850). Next, the control unit 22 executes the first stage program of the string St2_word line WL1 and the second stage program of the string St2_word line WL0 (step S860). Thereafter, the control unit 22 repeats the processes of steps S840, S850, and S860 for each word line WLi of each string St.
Then, the control unit 22 executes the first stage program of the string St0_word line WLn and the second stage program of the string St0_word line WLn−1 (step S870). Next, the control unit 22 executes the first stage program of the string St1_word line WLn and the second stage program of the string St1_word line WLn−1 (step S880). Thereafter, the control unit 22 repeats the same processing as in steps S870 and S880 for each word line WLi of each string St.
Then, the control unit 22 executes the first stage program of the string St3_word line WLn and the second stage program of the string St3_word line WLn−1 (step S890). Next, the control unit 22 executes the processes of steps S900 to S920 which are the same processes as steps S100 to S120. As a result, the second stage program of the word lines WLn of the strings St0 to St3 is executed.
As described above, the program of only the first stage is executed at the beginning of the block as in the first embodiment, and the program of only the second stage is executed at the end of the block as in the first embodiment. In this case, the program of only the first stage is executed according to the procedure illustrated in
Next, the input start command of the Top page data of the word line WLn−1 is input from the memory controller 2 to the nonvolatile memory 3 (step S1030). Then, the Top page data of the word line WLn−1 is input from the memory controller 2 to the nonvolatile memory 3 (step S1040).
Next, the input start command of the Lower page data of the word line WLn is input from the memory controller 2 to the nonvolatile memory 3 (step S1050). Then, the Lower page data of the word line WLn is input from the memory controller 2 to the nonvolatile memory 3 (step S1060).
Next, the input start command of the Middle page data of the word line WLn is input from the memory controller 2 to the nonvolatile memory 3 (step S1070). Then, the Middle page data of the word line WLn is input from the memory controller 2 to the nonvolatile memory 3 (step S1080).
Next, the program execution commands of the first and second stages are input from the memory controller 2 to the nonvolatile memory 3 (step S1090), and thereby the chip is busy (step S1100).
Thereafter, one or more program voltage pulses are applied to the Lower page/Middle page of the word line WLn (step S1110). Then, in order to confirm whether or not the memory cell moves beyond the threshold boundary level, the data reading of the Lower page/Middle page of the word line WLn is performed (step S1120).
Furthermore, it is confirmed whether or not the number of data fail bits in the Lower page/Middle page is smaller than the criterion (step S1130). When the number of fail bits of data in the Lower page/Middle page is greater than or equal to the criterion (No in step S1130), the processes of steps S1110 to S1130 are repeated. When the number of data fail bits becomes smaller than the criterion (Yes in step S1130), the Lower page/Middle page data of the word line WLn−1 is read (step S1140).
Then, the Vth (threshold voltage) of the program destination of the Upper page and Upper page is determined based on the Lower/Middle page data of the word line WLn−1 (step S1150). Thereafter, the data writing to the Upper page and Top page of the word line WLn−1 is performed using the determined Vth.
At the time of writing data to the Upper page and Top page, one or more program voltage pulses are applied to the Upper page and Top page of the word line WLn−1 (step S1160). Then, in order to confirm whether or not the memory cell moves beyond the threshold boundary level, the data reading of the Upper page and Top page of word line WLn−1 is performed (step S1170).
Further, it is confirmed whether or not the number of data fail bits in the Upper page and the Top page is smaller than the criterion (step S1180). When the number of data fail bits in the Upper page and the Top page is greater than or equal to the criterion (No in step S1180), the processes of steps S1160 to S1180 are repeated. When the number of data fail bits becomes smaller than the criterion (Yes in step S1180), the chip is ready (step S1190).
Note that any of the processes of steps S1010, S1030, and S1050 may be performed first. In addition, any of the processes in steps S1020, S1040, and S1060 may be performed first. However, the process of step S1020 is performed after the process of step S1010, the process of step S1040 is performed after the process of step S1030, and the process of step S1060 is performed after the process of step S1050.
Note that the processes of steps S1140 to S1180 illustrated in
As described above, in
As described above, in this embodiment, the data for four pages including the data of the Upper page and the Top page of the word line WLn−1 and the data of the Lower page and the Middle page of the word line WLn is continuously input from the memory controller 2 to the nonvolatile memory 3 by one program command and program data.
As another modification, after the program command is input, the Lower page and Middle page data of the word line WLn−1 is first read as the IDL, and then the Lower page and Middle page of the word line WLn are programmed. Next, the Vth of the program destination of the Upper page and the Top page is determined, and the Upper page and the Top page of the word line WLn are programmed with the determined Vth. In this way, the Lower page and Middle page data of the word line WLn−1 of the IDL can be read before the interference between adjacent cells due to the writing of the word line WLn is received.
The actual execution order of the program by the collective command of the first stage of the word line WLn and the second stage of the word line WLn−1 in this embodiment can be modified. That is, either the program of the Lower page and Middle page of the word line WLn illustrated in
As described above, in the second embodiment, since the second stage program of the word line WLn−1 and the first stage program of the word line WLn are collectively performed, the frequency of command input and polling is reduced. Therefore, the memory system 1 can be sped up, and the process can be simplified.
Next, a third embodiment will be described with reference to
As illustrated in (T1) of
As illustrated in (T3) of
For example, the threshold region level when the first stage is programmed to the binary level is as follows. The threshold region having a higher voltage level among the two threshold regions programmed in the first stage is transitioned to one of the threshold regions S8 to S15 in the second stage. For this reason, the control unit 22 causes the threshold region with the higher voltage level among the two threshold regions programmed in the first stage to have the same threshold distribution as the threshold region S8 generated in the second stage or to have a threshold distribution having a sufficient interval from the threshold region S0 without reaching the threshold region S8 generated in the second stage. The first stage program only needs to be divided into two threshold regions, and the first stage program can be sped up by allowing the width of each threshold region to be widened. Even when the width of the two threshold regions generated at the first stage is wide, if the interval between the two threshold regions is wide, the widths of the 16 threshold regions can be narrowed by programming the second stage, and the interval between the threshold regions can be secured.
In the third embodiment, the programs are executed in the same order as the order illustrated in
The data coding in this embodiment is not necessarily limited to 1-4-5-5 as illustrated in
In all
Next, a writing procedure according to the third embodiment will be described. The writing procedure for the entire one block according to the third embodiment is the same as the writing procedure (
As illustrated in
Then, the program execution command of the first stage is input from the memory controller 2 to the nonvolatile memory 3 (step S1430), and thereby chip is busy (step S1440).
Thereafter, the data writing to the Lower page and the Middle page is performed by using the Vth determined based on the Lower page data.
At the time of data writing to the Lower page, one or more program voltage pulses are applied (step S1450). Then, reading is performed to confirm whether or not the memory cell moves beyond the threshold boundary level (step S1460). Furthermore, it is confirmed whether or not the number of data fail bits in the Lower page is smaller than the criterion (judgment criterion) (step S1470). If the number of data fail bits is greater than or equal to the criterion (No in step S1470), the processes of steps S1450 to S1470 are repeated. When the number of data fail bits becomes smaller than the criterion (Yes in step S1470), the chip is ready (step S1480).
In the second stage program illustrated in
Thereafter, the Lower page data as the IDL is read (step S1690). The Vth of the program destination of the Middle/Upper/Top pages is determined based on the Lower page data (step S1700). Thereafter, the data writing to the Middle/Upper/Top pages is performed using the determined threshold voltage Vth.
Furthermore, in order to increase the reliability of the IDL read data, the control unit 22 can perform reading a plurality of times and use the majority decision of the read results in the page buffer 24 in the chip as next write data. Of course, the control unit 22 can perform reading a plurality of times during a normal reading operation and use the majority decision of the read results in the chip as the read data to the outside.
At the time of data writing to the Upper page, one or more program voltage pulses are applied (step S1710). Then, in order to confirm whether or not the memory cell moves beyond the threshold boundary level, data reading of the Middle/Upper/Top pages is performed (step S1720).
Further, it is confirmed whether or not the number of data fail bits in the Middle/Upper/Top pages is smaller than the criterion (step S1730). When the number of data fail bits in the Middle/Upper/Top pages is greater than or equal to the criterion (No in step S1730), the processes of steps S1680 to S1700 are repeated. When the number of data fail bits becomes smaller than the criterion (Yes in step S1730), the chip is ready (step S1740).
Here, a modification of the writing procedure illustrated in
In the process procedure illustrated in
Thereafter, the control unit 22 reads the Lower page data at the threshold voltage of Vr5. Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltage of Vr5 (step S1603). Thereafter, the chip is ready (step S1604).
When the Lower page data read by the control unit 22 is output (step S1605), the Lower page data is transmitted to the ECC circuit 10 (step S1606). As a result, the ECC circuit 10 performs ECC correction on the Lower page data (step S1607).
Then, the input start command of the Lower page data is input from the memory controller 2 to the nonvolatile memory 3 (step S1608). As a result, the ECC circuit 10 inputs the data of the Lower page data to the nonvolatile memory 3 (step S1609).
Thereafter, the processes of steps S1610 to S1740 are performed. In step S1700, the Vth of program destinations of the Middle page, Upper page, and Top page is determined based on the Lower page data from the ECC circuit 10.
As described above, in this embodiment, the data input in the second stage program is performed in three pages of the Middle page, the Upper page, and the Top page. However, in order to determine the final threshold of the memory cell by this second stage program, data for four pages including the Lower page is required. Therefore, in this second stage program, the Lower page data is first read as a preprocess. Then, by synthesizing the read data with the input Middle page, Upper page, and Top page, the threshold voltage Vth of the program destination of the Middle page, the Upper page, and the Top page is determined. Note that the read level before the second stage writing and after the second stage writing may be slightly different from the read level after the second stage writing.
Next, the page reading process will be described. The page read method differs depending on whether the program for the word line WLi including the page to be read is before the second stage writing and after the second stage completion.
In the case of the word line WLi before the second stage writing, only the Lower page is valid as the recorded data. For this reason, the control unit 22 reads data from the memory cell when the read page is the Lower page. Then, in a case where the read page is the Middle page, the Upper page, and the Top page, the control unit 22 performs control to all forcibly output “1” as read data without performing the memory cell read operation.
On the other hand, in the case of the word line WLi that is completed to the second stage, the control unit 22 reads the memory cell regardless of whether the read page is any one of the Top/Upper/Middle/Lower pages. In this case, since the necessary read voltage differs depending on which page is read, the control unit 22 executes only necessary read for the selected page.
According to the coding illustrated in
Further, there are two to six boundaries between threshold states at which the data of the Middle page, Upper page, or Top page changes depending on the examples shown in
Hereinafter, a specific process procedure for page reading will be described.
As illustrated in
When the read page is the Middle page, the control unit 22 performs control to all forcibly output “1” as the output data of the memory cell (step S1840). When the read page is the Upper page, the control unit 22 performs control to all forcibly output “1” as the output data of the memory cell (step S1850). When the read page is the Top page (Top in step S1810), the control unit 22 performs control to all forcibly output “1” as the output data of the memory cell (step S1860).
On the other hand, in the case of the word line WLi that is completely programmed up to the second stage, as illustrated in
When the read page is the Middle page, the control unit 22 performs reading with the threshold voltages of Vr4, Vr10, Vr12, and Vr14 (steps S1940, S1950, S1960, and S1970). Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr4, Vr10, Vr12, and Vr14 (step S1980).
When the read page is the Upper page, the control unit 22 performs reading with threshold voltages of Vr2, Vr5, Vr7, Vr11, and Vr15 (steps S1990, S2000, S2010, S2020, and S2030). Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr2, Vr5, Vr7, Vr11, and Vr15 (step S2040).
When the read page is the Top page, the control unit 22 performs reading with the threshold voltages of Vr1, Vr3, Vr6, Vr9, and Vr13 (steps S2050, S2060, 52070, 52080, and S2090). Then, the control unit 22 determines the value of the read data as “0” or “1” based on the read result at the threshold voltages of Vr1, Vr3, Vr6, Vr9, and Vr13 (step S2100).
In this way, in the program control of the threshold as illustrated in
On the other hand, in the case of the word line WLi that is completely programmed up to the second stage, the memory cell is read even when the read page is any of Top/Upper/Middle/Lower, but the required read voltage differs depending on which page is read. Thus, only the reading required according to the selected page is executed.
Note that it is possible for the memory controller 2 to manage and identify whether the program for the word line WLi is completed up to the first stage or the second stage. Since the memory controller 2 performs program control, if the memory controller 2 records the progress, the memory controller 2 can easily refer to the address and the program state of the nonvolatile memory 3. In this case, when reading is performed from the nonvolatile memory 3, the memory controller 2 identifies the program state of the word line WLi including the target page address and issues a read command corresponding to the identified state.
Note that the read level before the second stage writing and after the second stage writing may be slightly different from the read level after the second stage writing.
The second embodiment may be applied to this embodiment. That is, also in this embodiment, the second stage program of the word line WLn−1 and the first stage program of the word line WLn may be performed together. In this case, the command input and data input for the programs related to the two programs described above are performed together.
Further, in this embodiment, the restriction that the number of the boundaries of the Middle page after the end of the first stage is two becomes unnecessary. For this reason, the data coding other than the data coding used in the first and second embodiments may be applied. Also in the modifications of this embodiment illustrated in
As described above, in the third embodiment, as in the first embodiment, when programming the nonvolatile memory 3 including the NAND memory 5 of 4 bits/Cell having a three-dimensional structure or a two-dimensional structure, 1-4-5-5 Data coding or the like was adopted, and the program stage is set to a two-stage system. Since the programming is performed in two stages, the amount of data input during data programming is reduced, and the amount of write buffer required for the memory controller 2 can be suppressed. In addition, since the deviation of the bit error rate between the pages of the nonvolatile memory 3 can be reduced, it is not necessary to increase the error correction capability of the ECC circuit 10, and thus the cost of the ECC circuit 10 can be reduced. Further, since data transfer is performed only once for each page, transfer time and power consumption can be suppressed.
Further, since each program stage is executed while straddling the word line WLi, the amount of interference between adjacent cells with the adjacent word line WLi can be reduced. Further, since the change width from the threshold region of the first stage to the threshold region of the second stage becomes small, the adjacent cell buffer effect amount can be suppressed. In addition, the IDL margin before the second stage can be expanded, and the reliability of the write sequence can be improved. In addition, when the first stage program ends, by setting one threshold boundary in the Lower page, it is possible to speed up the first stage program, that is, the Lower page program. The programming of the first page can be sped up, for example, when the step voltage at the time of writing while stepping up the write voltage little by little is set to a larger value compared to the time of ending the second stage program when writing and writing verification are repeated.
In summary, the memory controller 2 according to the third embodiment causes the nonvolatile memory 3 to execute the first program for writing the first bit data, and then execute the second program for writing the second bit, third bit, and fourth bit data. More specifically, the memory controller 2 causes the nonvolatile memory 3 to execute the first program and the second program so that the order of changing from the threshold region at the time of the first program to the threshold region at the end of the second program is not changed. For example, the memory controller 2 causes the nonvolatile memory 3 to execute the first program and the second program so that the number of changes of the bit values at the time of writing the first to fourth bits of data is 1, 4, 5, 5 or 1, 6, 4, 4, or 1, 2, 6, 6 or 1, 5, 5, 4 or 1, 5, 4, 5 or 1, 4, 6, 4 or 1, 4, 4, 6 or 1, 5, 6, 3 or 1, 5, 3, 6 or 1, 3, 6, 5 or 1, 3, 5, 6 or 1, 6, 5, 3 or 1, 6, 3, 5 in order. The first bit is the least significant bit of the 4-bit data.
As described above, various modifications of the QLC in which one page of program is performed in the first stage, and three pages of program are performed in the second stage have been described. However, in addition to the above data coding, various modifications of data coding can be considered. Below, the modifications of the data coding described above are listed collectively.
Also in any of
In the above description, in the first stage, writing is performed to the binary threshold distribution by the Lower page, writing is performed to the four-value threshold distribution by the Lower page and the Middle page, or writing is performed to the eight-value threshold distribution by the data of the Lower page, the Middle page, and the Upper page. Then, in the second stage, writing is performed to the sixteen-value threshold distribution by the remaining page data. However, partial or all input data of the Lower page, Middle page, or Upper page of the first stage may be input again in the second stage, and writing may be performed to the sixteen-value threshold distribution in the second stage. Alternatively, before writing in the second stage, the data written in the first stage may be read out and corrected by the ECC or the like, and then the data may be input again also in the second stage and written in the sixteen-value threshold distribution in the second stage.
As described above, in the third embodiment, in the first stage program (first program), only the first bit of the 4-bit data is programmed. Thus, the interval between the two threshold regions after the first stage program can be sufficiently widened. As a result, the first stage program can be performed at high speed. Also, during second stage program (second program), the program is performed such that the order of change from the threshold region at the first stage to the threshold region at the second stage does not change. Thus, the interference between adjacent cells can be suppressed.
In a fourth embodiment, the Lower page, Middle page, and Upper page programs are executed in the first stage, and the Top page program is executed in the second stage.
In the first stage in the fourth embodiment, one of the eight threshold regions is set for each memory cell according to the bit value written in the Lower page, the Middle page, and the Upper page. The control unit 22 of the nonvolatile memory 3 generates eight threshold regions by the first stage program.
Further, the control unit 22 generates a total of sixteen threshold regions shifted by one at a maximum from the eight threshold regions programmed in the first stage by the second stage program.
As described above, in this embodiment, when the second stage program is performed, the threshold region moves only slightly, and thus the interference between adjacent cells can be prevented. In the first stage, eight threshold regions are generated, but bit errors can also be prevented by programming so that the intervals between the threshold regions are evenly secured.
The data coding in the fourth embodiment is not necessarily limited to 2-3-2-8. For example,
In both the examples of
Thus, in the fourth embodiment, since the Lower page, Middle page, and Upper page programs are performed in the first stage, eight threshold regions are generated in the first stage. For this reason, the interval between the threshold regions is narrowed. However, when the Top page program is performed in the second stage, the change width from the threshold region of the first stage to the threshold region of the second stage can be suppressed to one threshold region, and there is no possibility that the change width changing from the threshold region of the first stage to the threshold region of the second stage intersects.
In summary, the memory controller 2 according to the fourth embodiment causes the nonvolatile memory 3 to execute the first program for writing the data of the first bit, the second bit, and the third bit, and then causes the nonvolatile memory 3 to execute the second program for writing the fourth bit data. More specifically, the memory controller 2 causes the nonvolatile memory 3 to execute the first program and the second program so that the order of changing from the threshold region at the end of the first program to the threshold region at the end of the second program is not changed. For example, the memory controller 2 causes the nonvolatile memory 3 to execute the first program and the second program so that the number of changes in the bit value at the time of writing the first to fourth bit data is 2, 3, 2, 8, 2, 2, 3, 8 or 3, 2, 2, 8 or 1, 3, 3, 8 or 3, 1, 3, 8 or 3, 3, 1, 8 or 1, 2, 4, 8 or 1, 4, 2, 8 or 2, 1, 4, 8 or 2, 4, 1, 8, or 4, 1, 2, 8 or 4, 2, 1, 8 in order. The first bit is the least significant bit, the second bit is the second least significant bit, and the third bit is the second most significant bit.
In
As described above, various examples of the QLC in which three pages of program are performed in the first page, and one page of program is performed in the second stage have been described, but other modifications can be considered.
In this way, according to the fourth embodiment, the first to third bits are programmed in the first stage and only the fourth bit is programmed in the second stage, and thus, the width of change from the threshold region after the program of the first stage to the threshold region after the program of the second stage is reduced, and the interference between adjacent cells can be suppressed.
In the first to fourth embodiments described above, the case where the nonvolatile memory 3 is configured using the NAND memory 5 has been described. However, other types of nonvolatile memory 3 such as a resistive random access memory (ReRAM6), a magneto-resistive random access memory (MRAM6), a phase change random access memory (PRAM6), and a ferroelectric random access memory (FeRAM6) may be used.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Number | Date | Country | Kind |
---|---|---|---|
2019-166519 | Sep 2019 | JP | national |
2020-104833 | Jun 2020 | JP | national |