This application claims priority under 35 U.S.0 §119 to Korean Patent Application No. 10-2011-0118923 filed on Nov. 15, 2011, the subject matter of which is hereby incorporated by reference.
The inventive concept relates generally to electronic memory technologies. More particularly, the inventive concept relates to memory systems comprising one or more nonvolatile memory devices and related methods of operation.
Semiconductor memory devices can be roughly divided into two categories according to whether they retain stored data when disconnected from power. These categories include volatile memory devices, which lose stored data when disconnected from power, and nonvolatile memory devices, which retain stored data when disconnected from power. Examples of volatile memory devices include dynamic random access memory (DRAM) and static random access memory (SRAM). Examples of nonvolatile memory include mask read only memory (MROM), programmable read only memory (PROM), erasable programmable read only memory (EPROM), and electrically erasable programmable read only memory (EEPROM).
Some nonvolatile memory devices are capable of storing more than one bit of data per memory cell. Such nonvolatile memory devices are commonly referred to as multi-bit nonvolatile memory devices or multi-level cell (MLC) nonvolatile memory devices. Nonvolatile memory devices that store more than one bit of data per memory cell may provide higher storage capacity than those that store only one bit of data per memory cell. However, they may suffer from slower operation and reduced reliability, among other things. Accordingly, researchers are engaged in ongoing efforts to improve these and other performance aspects of MLC nonvolatile memory devices.
According to an embodiment of the inventive concept, a method is provided for programming a nonvolatile memory device comprising a single-level cell area comprising memory cells each configured to store one bit of data and a multi-level cell area comprising memory cells each configured to store two or more bits of data. The method comprises receiving write data, detecting an address of the multi-level area associated with the write data, randomizing the write data using the address and programming the randomized data in the single-level cell area.
According to another embodiment of the inventive concept, a memory system comprises a nonvolatile memory device comprising a single-level cell area having memory cells each configured to store one bit of data and a multi-level cell area having memory cells each configured to store two or more bits of data, and a controller configured to control the nonvolatile memory device, wherein the controller randomizes write data using an address of the multi-level cell area and controls the nonvolatile memory device to program the randomized write data in the single-level cell area.
According to still another embodiment of the inventive concept, a method of programming a nonvolatile memory device comprises receiving write data and an address, randomizing the write data based on the address, programming the randomized write data in a first area of the nonvolatile memory device comprising memory cells configured to store m-bit data, and programming the randomized write data in a second area of the nonvolatile memory device comprising memory cells configured to store n-bit data, where m is less than n, and wherein the address indicates a location of the second area where the randomized write data is to be stored.
These and other embodiments of the inventive concept can potentially improve reliability and performance of MLC nonvolatile memory devices.
The drawings illustrate selected embodiments of the inventive concept. In the drawings, like reference numbers indicate like features.
Embodiments of the inventive concept are described below with reference to the accompanying drawings. These embodiments are presented as teaching examples and should not be construed to limit the scope of the inventive concept.
In the description that follows, the terms first, second, third, etc. may be used to describe various features, but the described features are not to be limited by these terms. These terms are used merely to distinguish between different features, so a first feature could alternatively be termed a second feature, and vice versa, without changing the meaning of the relevant description.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to limit the inventive concept. As used herein, the singular forms “a”, “an” and “the” are intended to encompass the plural forms as well, unless the context clearly indicates otherwise. The terms “comprises” and/or “comprising,” when used in this specification, indicate the presence of stated features but do not preclude the presence or addition of other features. As used herein, the term “and/or” indicates any and all combinations of one or more of the associated listed items.
Where a feature is referred to as being “on”, “connected to”, “coupled to”, or “adjacent to” another feature, it can be directly on, connected, coupled, or adjacent to the other feature, or intervening features may be present. In contrast, where a feature is referred to as being “directly on,” “directly connected to”, “directly coupled to”, or “immediately adjacent to” another feature, there are no intervening features present.
Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art. Terms such as those defined in commonly used dictionaries should be interpreted as having a meaning consistent with their meaning in the context of the relevant art and/or the present specification and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
Referring to
Nonvolatile memory device 1100 performs program, read, erase, and background operations under control of controller 1200. Nonvolatile memory device 1100 can be, for example, a NAND flash memory.
Nonvolatile memory device 1100 comprises a single-level cell area (SA) 1110 and a multi-level cell area (MA) 1120. Single-level cell area 1110 comprises a plurality of memory cells each configured to store 1-bit data. Multi-level cell area 1120 comprises a plurality of memory cells each configured to store two or more bits of data. Single-level cell area 1110 and multi-level cell area 1120 are divided into memory blocks.
Single-level cell area 1110 comprises a Least Significant Bit (LSB) area 1111, a Central Significant Bit (CSB) area 1113, and a Most Significant Bit (MSB) area 1115. One bit is stored in memory cells of areas 1111, 1113, and 1115, respectively. LSB, CSB, and MSB area 1111, 1113, and 1115 are divided into memory blocks.
Controller 1200 controls program, read, erase, and background operations of nonvolatile memory device 1100. Controller 1200 provides nonvolatile memory device 1100 with an address ADDR, data, metadata, and a control signal CTRL.
Address ADDR comprises an address associated with memory cells of nonvolatile memory device 1100 in which data is to be programmed, an address associated with memory cells of nonvolatile memory device 1100 from which data is to be read, or an address associated with memory cells of nonvolatile memory device 1100 to be erased.
The data comprises data to be programmed in nonvolatile memory device 1100 or data read out from nonvolatile memory device 1100. The data can include data randomized by controller 1200.
The metadata comprises metadata to be programmed in nonvolatile memory device 1100 or metadata read out from nonvolatile memory device 1100. The metadata typically comprises information used to control nonvolatile memory device 1100, such as information on data characteristics, information on statuses of nonvolatile memory device 1100, information for error correction, and so on. The metadata can include metadata randomized by controller 1200.
Control signal CTRL comprises various signals generated by controller 1200 to control nonvolatile memory device 1100. Controller 1200 comprises a single-level area/multi-level area (SA-MA) address table 1210 and a randomizer and de-randomizer 1220.
SA-MA address table 1210 comprises information on correlations between addresses of memory cells in multi-level cell area 1120 and addresses of memory cells in single-level cell area 1110. For example, addresses (e.g., page addresses) of memory cells connected to a word line of multi-level cell area 1120 may be associated with an address of memory cells connected to a word line of LSB area 1111, an address of memory cells connected to a word line of CSB area 1113, and an address of memory cells connected to a word line of MSB area 1115.
Memory cells connected to a word line of multi-level cell area 1120 typically store LSB data, CSB data, and MSB data. More specifically, they store a page of LSB data (an LSB page), a page of CSB data (a CSB page), and a page of MSB data (an MSB page). Different page addresses are assigned to the LSB, CSB, and MSB pages.
Memory cells connected to a word line of single-level cell area 1110 store one page of data. One page address is assigned to a page of memory cells connected to a word line.
An address of an LSB page in a word line of multi-level cell area 1120 is associated with a page address of a word line in LSB area 1111. An address of a CSB page in a word line of multi-level cell area 1120 is associated with a page address of a word line in CSB area 1113. An address of an MSB page in a word line of multi-level cell area 1120 is associated with a page address of a word line in MSB area 1115.
SA-MA address table 1210 comprises information on correlations between addresses of multi-level cell area 1120 and addresses of single-level cell area 1110.
Randomizer and de-randomizer 1220 is configured to randomize write data to be programmed in nonvolatile memory device 1100 in a program operation and to de-randomize data read out from nonvolatile memory device 1100 in a read operation. For example, in a program operation, randomizer and de-randomizer 1220 randomizes write data using an address of nonvolatile memory device 1100 at which the write data is to be programmed, as a seed. Randomizer and de-randomizer 1220 can perform randomization using addresses of multi-level cell area 1120. Data programmed in single-level cell area 1110 can be randomized according to addresses of multi-level cell area 1120.
An address of multi-level cell area 1120 related to a specific address may be accessed from SA-MA address table 1210 to randomize write data to be programmed in memory cells of the specific address. The write data to be programmed in memory cells of the specific address of single-level cell area 1110 may be randomized using the accessed address of multi-level cell area 1120 as a seed.
In a read operation, randomizer and de-randomizer 1220 de-randomizes read data using an address (e.g., a page address) of memory cells, from which data is read, as a seed.
Where data is read out from multi-level cell area 1120, randomizer and de-randomizer 1220 performs de-randomization using an address. Where data is read out from single-level cell area 1110, randomizer and de-randomizer 1220 detects an address of multi-level cell area 1120 associated with an address from SA-MA address table 1210 and performs de-randomization using the detected address. The de-randomized data is transferred to a host outside of controller 1200.
Randomizer and de-randomizer 1220 also randomizes and de-randomizes metadata with write data. Randomizer and de-randomizer 1220 randomize metadata generated in a program operation and sends the randomized metadata to nonvolatile memory device 1100 with randomized data. In a read operation, randomizer and de-randomizer 1220 reads data and metadata to de-randomize the read data and metadata.
Referring to
In operation S120, the write data is randomized using an address of multi-level cell area 1120. Even where the write data is data to be programmed in single-level cell area 1110, it may be randomized using an address of multi-level cell area 1120. This address can be identified in SA-MA address table 1210 and used as a seed. Metadata can be further randomized with the write data.
In operation S130, the randomized data is programmed in single-level cell area 1110 and multi-level cell area 1120. With the randomized data, the randomized metadata can be programmed in single-level cell area 1110 and multi-level cell area 1120.
Metadata and write data are typically randomized together, and randomized metadata is programmed with the randomized write data.
Memory cells of multi-level cell area 1120 store LSB data, CSB data, and MSB data. Programming of the LSB, CSB, and MSB data is performed using a 3-step programming approach. Where programming is performed with the 3-step programming approach, memory cells in single-level cell area 1110 are used as a buffer memory.
Referring to
In operation S220, the LSB data and the CSB data are randomized using an address of multi-level cell area 1120.
In operation S230, the randomized LSB and CSB data are programmed in multi-level cell area 1120. This programming can be referred to as first-step programming.
In operation S240, the randomized LSB data is programmed in LSB area 1111 of single-level cell area 1110, and the randomized CSB data is programmed in CSB area 1113 thereof.
The LSB data is programmed in memory cells at an address of LSB area 1111 associated with an address of multi-level cell area 1120. For example, the address of LSB area 1111 associated with the address of multi-level cell area 1120 may be acquired from SA-MA address table 1210. The LSB data may be programmed in memory cells of LSB area 1111 corresponding to the acquired address.
Similarly, the CSB data may be programmed in memory cells at an address of CSB area 1113 associated with an address of multi-level cell area 1120. For example, the address of CSB area 1113 associated with the address of multi-level cell area 1120 may be acquired from SA-MA address table 1210. The CSB data may be programmed in memory cells of CSB area 1113 corresponding to the acquired address.
Referring to
Referring to
In operation S320, the MSB data is randomized using an address of multi-level cell area 1120.
In operation S330, LSB data and CSB data are read from single-level cell area 1110. The LSB data is read from LSB area 1111, and the CSB data is read from CSB area 1113.
In operation S340, the randomized MSB data is programmed in multi-level cell area 1120 based on the read LSB and CSB data. This programming constitutes coarse programming.
In operation S350, the randomized MSB data is programmed in single-level cell area 1110. For example, an address of MSB area 1115 associated with an address of multi-level cell area 1120 may be acquired from SA-MA address table 1210. The MSB data may be programmed in memory cells of MSB area 1115 corresponding to the acquired address.
Referring to
Referring to
In operation S420, programming of multi-level cell area 1120 is performed based on the LSB, CSB, and MSB data. This programming constitutes fine programming.
Referring to
After programming is performed on a first word line of multi-level cell area 1120, programming is performed on a second word line adjacent to the first word line. The programming can be performed with respect to both of the first and second word lines using 1-step programming, coarse programming, or fine programming, for example. After the programming is performed on the second word line, memory cells of the first word line may experience coupling, which may widen their threshold voltage distributions.
Where memory cells of the first and second word lines are 1-step programmed, a threshold voltage distribution of memory cells in the first word line may widen. Where coarse programming is carried out on memory cells of the first word line, a threshold voltage distribution of the memory cells of the first word line may become narrow (refer to
Where coarse programming is performed on memory cells of the second word line, a threshold voltage distribution of the memory cells in the first word line may widen. Where fine programming is performed on the memory cell in the first word line, a threshold voltage distribution of the memory cells in the first word line may become narrow (refer to
Where the fine programming is performed on memory cells of the second word line, a threshold voltage distribution of the memory cells in the first word line may widen. However, referring to
As described above, where programming is performed using a 3-step programming approach, it is possible to minimize a coupling effect experienced by programmed memory cells in multi-level cell area 1120 (i.e., fine-programmed memory cells). Programming performed using the 3-step programming approach using single-level cell area 1110 as a buffer may be referred to as On-chip Buffered Programming (OBP).Coarse programming and fine programming of multi-level cell area 1120 may be performed based on data programmed in single-level cell area 1110. Where write data programmed in nonvolatile memory device 1100 is randomized according to an address (or, a page address), randomized data programmed in single-level cell area 1110 may be different in pattern from that programmed in multi-level cell area 1120. Where patterns of randomized data are different, a program error may happen when data read from single-level cell area 1110 is programmed in multi-level cell area 1120. As described above, OBP may be carried out without an error by randomizing data programmed in single-level cell area 1110 using an address (or, a page address) of multi-level cell area 1120.
Where data being programming in nonvolatile memory device 1100 has a specific pattern, the reliability of the programmed data may suffer. For example, where data having the same pattern is programmed in multiple pages, an electric field among memory cells may be reinforced, so that charges accumulated or trapped at memory cells are discharged. It is possible to prevent a specific pattern from being programmed in nonvolatile memory device 1100 by randomizing data (including write data and metadata) and programming the randomized data. Thus, the reliability of data programmed in nonvolatile memory device 1100 may be improved.
In another embodiment, the OBP may be executed in different ways. For example, the OBP may comprise a SA programming step and a MA programming step. Upon receiving LSB data, the controller 1200 may randomize the received LSB data using an address of MA 1120 and program the randomized LSB data into LSB area 1111. Upon receiving CSB data, the controller may randomize the received CSB data using the address of MA 1120 and program the randomized CSB data into CSB area 1113. Upon receiving MSB data, the controller may randomize the received MSB data using the address of MA 1120 and program the randomized MSB data into MSB area 1115. Programs of randomized LSB, CSB and MSB data into SA 1110 may form the SA programming step.
Then, the controller may read the randomized LSB, CSB and MSB data from SA 1110, and program them into MA 1120. Programs of randomized LSB, CSB and MSB data into MA 1120 may form the MA programming step. The MA programming step may be conducted when the controller 1200 or the nonvolatile memory device 1100 is at an idle state.
A programming of SA 1110 may be faster than that of MA 1120. According to another embodiment of the OBP, received data are programmed into SA 1110. The programmed data are copied to MA 1120 during an idle state. Thus, response time of the controller 1200 or the nonvolatile memory device 1100 is reduced.
As described above, the OBP may be executed to advance reliability or to reduce response time of the controller 1200 or the nonvolatile memory device 1100. Although the OBP is executed in different ways according to its purpose, the OBP commonly include randomizing received data using an address of MA, programming the randomized data into SA 1110, reading the randomized data from SA 1110, and programming the randomized data into MA 1120 regardless its purpose.
Referring to
In multi-level cell area 1120, three page addresses are assigned to a word line. For example, three page addresses may comprise an LSB page address, a CSB page address, an MSB page address. In each of LSB, CSB, and MSB areas 1111, 1113, and 1115 of single-level cell area 1110, a page address may be assigned to a word line.
A first page address (1) of a first word line (1) in multi-level cell area 1120 is associated with a page address (1) of a first word line (1) in LSB area 1111. A second page address (2) of the first word line (1) in multi-level cell area 1120 is associated with a page address (1) of a first word line (1) in CSB area 1113. A third page address (3) of the first word line (1) in multi-level cell area 1120 is associated with a page address (1) of a first word line (1) in MSB area 1115.
Page addresses (4 through 6) of a second word line (2) in multi-level cell area 1120 are associated with a page address (2) of a second word line (2) in LSB area 1111, a page address (2) of a second word line (2) in CSB area 1113, and a page address (2) of a second word line (2) in MSB area 1115, respectively.
Page addresses (3n-2 through 3n) of an n-th word line (n) in multi-level cell area 1120 is associated with a page address (n) of an n-th word line (n) in LSB area 1111, a page address (n) of an n-th word line (n) in CSB area 1113, and a page address (n) of an n-th word line (n) in MSB area 1115, respectively.
That is, page addresses of a word line in multi-level cell area 1120 are associated with a page address of a word line in LSB area 1111, a page address of a word line in CSB area 1113, and a page address of a word line in MSB area 1115, respectively.
Referring to
Controller 2200 comprises randomizer and de-randomizer 2220, which is similar to randomizer and de-randomizer 1220, except that it further comprises scrambler 2221. Controller 2200 further comprises an SA-MA address table 2210, which is similar to SA-MA address table 1210 of
Scrambler 2221 scrambles an address used as a seed. For example, scrambler 2221 may scramble an address of multi-level cell area 2120 used as a seed. Randomizer and de-randomizer 2220 perform randomizing or de-randomizing using an address scrambled by scrambler 2221 as a seed. Some addresses of addresses of multi-level cell area 2120 may have a simple pattern. For example, some addresses of addresses of multi-level cell area 2120 may have a simple pattern such as ‘00000001’, ‘00000010’, or ‘00000100’. An effect obtained by randomizing write data may be lowered by randomizing the write data using a simple pattern.
The scrambled seed may have a random property. Lowering an effect obtained by randomizing write data may be prevented by using a pattern with the random property that addresses of multi-level cell area 2120 are scrambled, as a seed.
Scrambler 2221 typically scrambles addresses of multi-level cell area 2120 using an operation between adjacent bits (e.g., AND, exclusive-OR, etc.), or bit-swapping between adjacent bits.
Although
Referring to
Controller 3200 comprises an SA-MA address table 3210 and a randomizer and de-randomizer 3220. Similar to embodiments described in relation to
In a variation of the embodiment of
Referring to
Similar to embodiments described in relation to
Connector 4300 electrically connects memory card 4000 with a host. Memory card 4000 can take various alternative forms, such as a PC or PCMCIA card, a CF card, an SM or SMC card, a memory stick, a multimedia card (e.g., MMC, RS-MMC, or MMCmicro), a security card (e.g., SD, miniSD, microSD, or SDHC), or a universal flash storage (UFS) device, for example.
Referring to
Each of nonvolatile memory devices 5100 comprises a single-level cell area and a multi-level cell area. Some of nonvolatile memory devices 5100 may be single-level cell devices, and others may be multi-level cell devices.
Controller 5200 comprises an SA-MA address table 5210 and a randomizer and de-randomizer 5220. Similar to embodiments described in relation to
Referring to
Memory system 3000 is connected electrically with elements 6100 through 6400 via a system bus 6500. Data provided via user interface 6300 or processed by central processing unit 6100 may be stored in memory system 3000.
In the embodiment of
Memory system 3000 of
As indicated by the foregoing, in a nonvolatile memory device comprising a single-level cell area storing 1-bit data per cell and a multi-level cell area storing two or more bits of data per cell, write data may be randomized at OBP in which the single-level cell area is used as an on-chip buffer. It is possible to prevent patterns, which may potentially decrease reliability of data from being programmed in the nonvolatile memory device by randomizing write data. Thus, a program method and a memory system with the improved reliability may be provided.
The above-disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments, which fall within the true spirit and scope. Thus, to the maximum extent allowed by law, the scope is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.
Number | Date | Country | Kind |
---|---|---|---|
10-2011-0118923 | Nov 2011 | KR | national |