The invention relates to semiconductor memory devices and, more particularly, to flash memory devices and methods of operating same.
Semiconductor memory devices are generally classified into volatile memory devices (e.g., DRAMs and SRAMs) and nonvolatile memory devices (e.g., EEPROMs, FRAMs, PRAMs, MRAMs, and flash memories). A volatile memory device loses data stored therein when power supply thereto is interrupted, whereas a nonvolatile memory device retains data stored therein even when power supply thereto is interrupted. In particular, a flash memory device is widely used as a storage medium in a computer system because of its high program speed, low power consumption and large data storage capacity.
In the flash memory device, data states storable in each memory cell may be determined according to the number of bits stored in the memory cell. A memory cell storing 1-bit data per cell is called a single-bit cell or a single-level cell (SLC), and a memory cell storing multi-bit data (i.e., at least 2-bit data) per cell is called a multi-bit cell, a multi-level cell (MLC) or a multi-state cell. The multi-bit cell is advantageous for high integration. However, as the number of bits programmed in each memory cell increase, the reliability decreases and the read failure rate increases.
For example, if k bits are to be programmed in a memory cell, one of 2k threshold voltages must be formed in the memory cell. Due to the minute difference between the electrical characteristics of memory cells, the threshold voltages of memory cells programmed with the same data may form a predetermined range of threshold voltage distribution. Threshold voltage distributions may correspond respectively to 2k data values that may be generated by k bits.
However, a voltage window available for threshold voltage distributions is limited. Therefore, as the value k increases, the distance between the threshold voltage distributions decreases and the adjacent threshold voltage distributions may overlap each other. As the adjacent threshold voltage distributions overlap each other, read data may include a number of error bits (e.g., several error bits or several tens of error bits). What is therefore required is a scheme for efficiently detecting/correcting a read error in data read from a flash memory device that stores multi-bit data.
The present disclosure provides a flash memory device and a read method thereof, which can efficiently provide additional information for error correction without an increase in the chip size.
Integrated circuit memory devices according to embodiments of the invention include an array of nonvolatile N-bit memory cells, where N is an integer greater than one. Control circuitry is also provided to reliably read data from the N-bit memory cells. This control circuitry, which is electrically coupled to the array, is configured to determine, among other things, a value of at least one bit of data stored in a selected N-bit memory cell in the array. This is done by decoding at least one hard data value and a plurality of soft data values (e.g., 6 data values) read from the selected N-bit memory cell using a corresponding plurality of unequal read voltages applied to the selected N-bit memory cell during a read operation.
According to some embodiments of the invention, the control circuitry represents determining means. This control circuitry includes circuitry for reading the hard data value from the selected N-bit memory cell by applying a read reference voltage to the selected N-bit memory cell. The control circuitry also includes circuitry for reading the plurality of soft data values from the selected N-bit memory cell by applying a plurality of read voltages, which are less than or greater than the read reference voltage, to the selected N-bit memory cell.
According to additional embodiments of the invention, the control circuitry includes circuitry for reading a first plurality of soft data values from the selected N-bit memory cell by applying a first plurality of read voltages that are less than the read reference voltage to the selected N-bit memory cell. This circuitry is also configured to read a second plurality of soft data values from the selected N-bit memory cell by applying a second plurality of read voltages that are greater than the read reference voltage to the selected N-bit memory cell.
In particular, the control circuitry may include a row select circuit electrically coupled to a plurality of word lines in the array, and a voltage generator configured to supply the row select circuit with read voltages (e.g., the read reference voltage and the first and second plurality of read voltages). The control circuitry may also include a page buffer circuit electrically coupled to a plurality of bit lines in the array and control logic. This control logic is electrically coupled to the voltage generator, the row select circuit and the page buffer circuit. The control circuitry may also include an error checking and correction (ECC) circuit configured to receive the at least one hard data value and a plurality of soft data values read from the selected N-bit memory cell during the read operation.
According to still further embodiments of the invention, the page buffer circuit may be configured to encode the plurality of soft data values into a multi-bit reliability data value that specifies a relative degree of accuracy of a corresponding hard data value. The control circuitry may also include an error checking and correction (ECC) circuit configured to receive the at least one hard data value and the multi-bit reliability data value. For example, if the N-bit memory cells are 3-bit memory cells, then the page buffer circuit may be configured to encode the plurality of soft data values into a 2-bit reliability data value that specifies a relative degree of accuracy of a corresponding hard data value.
The accompanying drawings are included to provide a further understanding of the inventive concept, and are incorporated in and constitute a part of this specification. The drawings illustrate exemplary embodiments of the inventive concept and, together with the description, serve to explain principles of the inventive concept. In the drawings:
Preferred embodiments of the inventive concept will be described below in more detail with reference to the accompanying drawings. The inventive concept may, however, be embodied in different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the inventive concept to those skilled in the art. Like reference numerals refer to like elements throughout. The circuit configurations and the read operations of a flash memory device according to the inventive concept, which will be described below, are merely exemplary and various changes in form and details may be made therein without departing from the spirit and scope of the inventive concept.
Referring to
The hard decision scheme corrects an error in data by using only an error correction code and data (hereinafter referred to as hard decision data) that are read according to the on/off characteristics of a memory cell when a predetermined reference voltage is applied thereto. The soft decision scheme corrects an error in data by using not only the error correction code and the hard decision data but also additional information (hereinafter referred to as soft decision data) about the reliability of the hard decision data. As an example, the inventive concept illustrates the case where the ECC 230 uses a soft decision scheme to perform more accurate error correction. The encoding/decoding scheme of an error correction code applicable to the ECC 230 is not limited to a specific embodiment but may vary according to various embodiments.
The flash memory 100 may provide hard decision data and a plurality of soft decision data to the ECC 230 for each reference voltage (e.g., Ref1 or Ref2) in a read operation. The hard decision data and the soft decision data may be read through a page buffer from the memory cells of the flash memory 100. A read operation of the page buffer on the hard decision data and the soft decision data may be performed under the control of a control logic circuit 150 in the flash memory 100. The hard decision data may be read by applying the reference voltage. The soft decision data may be read by applying a plurality of variable read voltages that vary from the reference voltage. The soft decision data read from the flash memory 100 may be provided to the ECC 230 without a change in the read data bits. Also, the soft decision data may be encoded into a predetermined data format (hereinafter referred to as reliability data) before being provided to the ECC 230.
As will be described below, the flash memory 100 of the inventive concept is configured to generate reliability data for error correction by the page buffer without using an additional circuit (e.g., an encoder) that encodes the soft decision data by a predetermined code. That is, the soft decision data, or the reliability data corresponding to the soft decision data may be outputted by the page buffer. Thus, the inventive concept makes it possible to increase the error correction efficiency in a read operation of the flash memory without an increase in the chip size and to improve the reliability of the read multi-bit data.
Referring to
As illustrated in
The control logic circuit 150 of
In response to the control of the control logic circuit 150, the row selector circuit 120 may select one of the memory blocks (or sectors) of the memory cell array 110 and may select one of the word lines of the selected memory block. In response to the control of the control logic circuit 150, the row selector circuit 120 may provide the word line voltages, generated by the voltage generator 160, respectively to the selected word line and the unselected word lines.
The page buffer circuit 130 may be controlled by the control logic circuit 150 to operate as a sense amplifier or a write driver according to an operation mode. For example, in a verify/normal read operation, the page buffer circuit 130 operates as a sense amplifier for reading data from the memory cell array 110. In a normal read operation, the column selector circuit 140 outputs data, read from the page buffer circuit 130, to an external device (e.g., the memory controller 200 or a host) in response to column address information Y-addr. In a verify read operation, the read data may be provided to a pass/fail verification circuit (not illustrated) in the flash memory 100 to determine the program pass/fail of the memory cells.
In a program operation, the page buffer circuit 130 operates as a write driver that drives the bit lines according to the data to be stored in the memory cell array 110. In a program operation, the page buffer circuit 130 receives data, which is to be written in the memory cell array 110, from a buffer (not illustrated) and drives the bit lines according to the received data. To this end, the page buffer circuit 130 may include a plurality of page buffers PB corresponding respectively to columns (or bit lines) or column pairs (or bit line pairs). Each of the page buffers PB may include a plurality of latches. The latches may perform an operation of latching a plurality of soft decision data and hard decision data sensed from the page buffer PB, and an operation of generating reliability data from the sensed soft decision data. As will be described below in detail, the reliability data may be generated through a toggling operation of the latches of each page buffer in a read operation.
The ideal data state of the programmed MLC must maintain a predetermined voltage interval with respect to an adjacent data state in order to secure a sufficient read margin. However, in a practical embodiment of the multi-bit flash memory, the threshold voltage distribution of each data state may change into an unideal form (See dotted-line sections) as illustrated in
Two reference voltages Ref1 and Ref2 may be used to read out the second bit value among the 3-bit data programmed in the memory cell. For example, the second bit value may be read out as ‘1’ or ‘0’ according to the on/off state of the memory cell when the first reference voltage Ref1 and the second reference voltage Ref2 are applied thereto. The reference voltage Ref1 for the data readout may be determined by the ideal threshold voltage distribution illustrated in
However, if the adjacent threshold voltage distributions overlap each other, the accuracy of the read operation and error correction cannot be secured solely by the hard decision data. For example, the memory cell with a threshold voltage within a region A may be determined as a memory cell of the state P2 having a data state ‘0’ in hard decision. However, the memory cell with a threshold voltage within the region A (a reference numeral 164 of
In order to perform more accurate data decision and error correction, the inventive concept performs a plurality of read operations by using a plurality of variable read voltages in addition to the reference voltages. Also, for error correction, a plurality of read data obtained from the read operations is provided from the page buffer PB directly to the ECC 230 without passing through an additional circuit (e.g., an encoder).
The read voltages V1˜V7 and V8˜V14 may be divided into reference voltages and variable read voltages. For example, two reference voltages Ref1 and Ref2 may be used to read the second bit value among the 3-bit data programmed in the memory cell. The first reference voltage Ref1 is denoted by V4 and the second reference voltage Ref2 is denoted by V11. The data read by applying the reference voltages Ref1 and Ref2 are referred to as hard decision data. In the inventive concept, a plurality of variable read voltages may correspond to each of the reference voltages Ref1 and Ref2. Variable read voltages V1˜V3 and V5˜V7 may correspond to the first reference voltage Ref1, and variable read voltages V8˜V10 and V12˜V14 may correspond to the second reference voltage Ref2. The data read by a plurality of variable read voltages are referred to as soft decision data. In an exemplary embodiment, 6 soft decision data may be obtained additionally with respect to 1 hard decision data so that a total of 7-bit data may be outputted as read data. Herein, the number of soft decision data corresponding to 1 hard decision data may vary according to various embodiments.
The ECC 230 may determine data on the basis of the 7-bit read data pattern received from the flash memory 100, and may perform error correction on the basis of the determination results. The probability of being determined as ‘0’ increases with an increase in the number of 0s among the 7-bit read data pattern received from the flash memory 100. Also, the probability of being determined as ‘1’ increases with an increase in the number of 1s among the 7-bit read data pattern.
For example, if the 7-bit read data pattern is “0, 0, 0, 0, 1, 1, 1”, the memory cell may be recognized as a memory cell included in the region A, which may mean a weak ‘0’ in soft decision. If the 7-bit read data pattern is “0, 0, 0, 1, 1, 1, 1”, the memory cell may mean a weak ‘1’ in soft decision. If the 7-bit read data pattern is “0, 0, 0, 0, 0, 0, 0”, the memory cell may be recognized as a memory cell included in the region B, which may mean a strong ‘0’ in soft decision. If the 7-bit read data pattern is “1, 1, 1, 1, 1, 1, 1”, the memory cell may be recognized as a memory cell included in the region C, which may mean a strong ‘1’ in soft decision. According to this configuration, by analyzing the 7-bit read data in a read operation, it can be accurately known whether the threshold voltage distribution of the memory cell is present in a certain region (e.g., 161˜166 of
Herein, each of the data constituting the 7-bit read data pattern may mean the data value that is sensed in the page buffer PB when each read voltage is applied thereto. This may mean that the page buffer PB generates additional information (e.g., a plurality of soft decision data) for error correction even when the flash memory 100 does not include an additional circuit such as an encoder.
Each of the read voltages V1˜V7 and V8˜V14 may be generated by the voltage generator 160 under the control of the control logic circuit 150 of
The 7-bit read data pattern illustrated in
Meanwhile, a plurality of read operations in each page buffer PB using a plurality of read voltages V1˜V7 and V8˜V14 may be implemented in various ways. For example, it may be obtained by sequentially repeating a precharge operation and a sensing operation or by performing a plurality of sensing operations with respect to one precharge operation. A plurality of read operations in each page buffer PB or a sensing operation for a plurality of data bits may be implemented in various modes.
In this embodiment, the form of a plurality of read voltages applied in a plurality of read operations may be configured in the same way as described with reference to
Referring to
For example, the read result sensed from the memory cell with a threshold voltage distribution within the interval 161 of
The read result sensed from the memory cell with a threshold voltage distribution within the interval 162 of
The read result sensed from the memory cell with a threshold voltage distribution within the interval 163 of
The read result sensed from the memory cell with a threshold voltage distribution within the interval 164 of
The read result sensed from the memory cell with a threshold voltage distribution within the interval 165 of
The read result sensed from the memory cell with a threshold voltage distribution within the interval 166 of
If the read result sensed from the memory cell has a pattern of “0, 0, 0, (0), 0, 0, 0”, the soft decision data include six 0s. If the soft decision data include five 0s, the reliability data have a value ‘01’. Therefore, if the soft decision data include six 0s, the latch L1 with a value ‘0’ toggles from ‘0’ to ‘1’ and the latch L2 maintains a state ‘1’. Therefore, if a data pattern, all data of which have a value ‘0’, is sensed, the output read data may include reliability data ‘11’ and hard decision data ‘0’. This may mean a strong ‘0’ in soft decision. Likewise, the read voltages V8˜V14 may be applied to output the data values corresponding to the data sensed in the page buffer PB. As described above, the reliability data outputted from the page buffer PB may have a value of “01, 00, 10 and 11”. The data reliability size may be 11>01>00>10.
The read method of the inventive concept described above may be controlled to be performed selectively with respect to the case where an erase/program cycle (#P/E cycle) (i.e., one of the indexes for determination of the lifetime of the flash memory 100) is more than a predetermined count, the case where more than a predetermined number of errors occur, or the case where an accurate read operation or an accurate error correction operation is required. The read method according to the inventive concept may also be applicable to various cases other than the above cases. Also, the read method of the inventive concept described above may be applicable not only to a read operation on the upper bits (e.g., one or more MSB bits) stored in multi-level cells, but also to a read operation on the lower bits (e.g., LSB bits).
The buffer memory 1220 may be configured using a synchronous DRAM (SRAM) in order to provide sufficient buffering in the SSD 1200. However, this is merely an example of the configuration of the buffer memory 1220. The configuration of the buffer memory 1220 is not limited to a specific embodiment but may vary according to various embodiments. The buffer memory 1220 may temporarily store write data received from the host 1100 or data read from the flash memory 100. At the read request of the host 1100, if data in the flash memory 100 is stored in the buffer memory 1220, the buffer memory 1220 may support a cache function of providing the stored data directly to the host 1100. Typically, the data transmission rate according to the bus format (e.g., SATA or SAS) of the host 1100 is much higher than the data transmission rate of a memory channel of the SSD 1200. If the interface rate of the host 1100 is much higher than that of the SSD 1200, a large-capacity buffer memory 1220 may be provided to minimize the performance degradation caused by the rate difference.
The flash memory 100 may be used as a main memory of the SSD 1200. To this end, the flash memory 100 may be configured using a NAND flash memory with a large storage capacity. However, the type of the flash memory 100 in the SSD 1200 is not limited to a NAND flash memory. For example, the flash memory 100 may also be configured using a NOR flash memory, a hybrid flash memory with a hybrid of at least two types of memory cells, or a One-NAND flash memory with a controller embedded in a memory chip. Also, a plurality of channels may be provided in the SSD 1200 and a plurality of flash memories 100 may be connected to the respective channels. Although a NAND flash memory has been exemplified as the main memory, other nonvolatile memories may be used as the main memory. For example, at least one of volatile memories (e.g., DRAMs and SRAMs) and nonvolatile memories (e.g., PRAMs, MRAMs, ReRAMs, and FRAMs) may be used as the main memory.
The flash memory 100 of
A combination of the flash memory 100 and the memory controller 2100 may be provided as a memory card or a solid state disk (SSD). An SRAM 2110 may be used as a working memory of a central processing unit (CPU) 2120. A host interface (I/F) 2130 may have a data exchange protocol of a host connected to the memory system 2000. An error correction circuit (ECC) 2140 in the memory controller 2100 may be configured to have substantially the same configuration as the ECC 230 of
The flash memory 100 may be provided as a multi-chip package including a plurality of flash memory chips. The memory system 2000 of the inventive concept may be provided as a high-reliability storage medium with a low error probability. In particular, the flash memory of the inventive concept may be provided in a memory system such as a solid state disk (SSD) that is under active research. In this case, the memory controller 2100 may be configured to communication with an external device (e.g., the host) through one of various interface protocols such as USB, MMC, PCI-E, SAS, SATA, PATA, SCSI, ESDI, and IDE. Also, the memory controller 2100 may further include a configuration for performing a random operation.
If the computing system 3000 is a mobile device, a battery (not illustrated) may be further provided to supply an operation voltage of the computing system 3000. Although not illustrated in
The nonvolatile memory device and/or the memory controller according to the inventive concept may be mounted in various types of packages. Examples of the packages of the flash memory device and/or the memory controller according to the inventive concept include Package on Package (PoP), Ball Grid Arrays (BGAs), Chip Scale Packages (CSPs), Plastic Leaded Chip Carrier (PLCC), Plastic Dual In-line Package (PDIP), Die in Waffle Pack, Die in Wafer Form, Chip On Board (COB), Ceramic Dual In-line Package (CERDIP), Plastic Metric Quad Flat Pack (MQFP), Thin Quad Flat Pack (TQFP), Small Outline Integrated Circuit (SOIC), Shrink Small Outline Package (SSOP), Thin Small Outline Package (TSOP), System In Package (SIP), Multi Chip Package (MCP), Wafer-level Fabricated Package (WFP), and Wafer-level Processed Stack Package (WSP).
As described above, the inventive concept can generate additional information (e.g., soft decision data or data reliability information) for error correction by using a read operation of the page buffer even without using an additional circuit such as an encoder. Thus, the inventive concept can increase the error correction efficiency in a read operation of the flash memory without an increase in the chip size and can improve the reliability of multi-bit data read from the flash memory device.
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 of the inventive concept. Thus, to the maximum extent allowed by law, the scope of the inventive concept 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-2010-0011554 | Feb 2010 | KR | national |
This application is a Continuation of U.S. Ser. No. 12/967,969, filed on Dec. 14, 2010, which claims priority to Korean Patent Application No. 10-2010-0011554, filed Feb. 8, 2010, the contents of all of which are hereby incorporated herein by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
6288936 | Kawamura | Sep 2001 | B1 |
6816409 | Tanaka | Nov 2004 | B2 |
7023735 | Ban et al. | Apr 2006 | B2 |
7447078 | Li | Nov 2008 | B2 |
7502254 | Murin et al. | Mar 2009 | B2 |
7526715 | Litsyn et al. | Apr 2009 | B2 |
7716538 | Gonzalez et al. | May 2010 | B2 |
7800943 | Ravasio et al. | Sep 2010 | B2 |
7975192 | Sommer et al. | Jul 2011 | B2 |
8230300 | Perlmutter et al. | Jul 2012 | B2 |
8477533 | Kang | Jul 2013 | B2 |
8582360 | Park et al. | Nov 2013 | B2 |
8947929 | Yang | Feb 2015 | B1 |
20050013165 | Ban | Jan 2005 | A1 |
20080055990 | Ishikawa et al. | Mar 2008 | A1 |
20080123408 | Honma et al. | May 2008 | A1 |
20080137412 | Ban | Jun 2008 | A1 |
20080151617 | Alrod et al. | Jun 2008 | A1 |
20080209111 | Kang | Aug 2008 | A1 |
20080244338 | Mokhlesi et al. | Oct 2008 | A1 |
20080320366 | Lin | Dec 2008 | A1 |
20090177931 | Song et al. | Jul 2009 | A1 |
20090201726 | Honma et al. | Aug 2009 | A1 |
20090234792 | Kim et al. | Sep 2009 | A1 |
20090235128 | Eun et al. | Sep 2009 | A1 |
20090235129 | Eun et al. | Sep 2009 | A1 |
20090244973 | Scheppler et al. | Oct 2009 | A1 |
20100223538 | Sakurada | Sep 2010 | A1 |
20100246289 | Vigoda et al. | Sep 2010 | A1 |
20110219284 | Uchikawa et al. | Sep 2011 | A1 |
20110231738 | Horisaki | Sep 2011 | A1 |
Number | Date | Country |
---|---|---|
2002025277 | Jan 2002 | JP |
2006527901 | Dec 2006 | JP |
2008016092 | Jan 2008 | JP |
2008-059679 | Sep 2008 | JP |
2011523159 | Aug 2011 | JP |
20080004374 | Jan 2008 | KR |
1020090075101 | Jul 2009 | KR |
1020090097673 | Sep 2009 | KR |
WO 2009113760 | Sep 2009 | WO |
WO 2009116718 | Sep 2009 | WO |
Number | Date | Country | |
---|---|---|---|
20130286732 A1 | Oct 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12967969 | Dec 2010 | US |
Child | 13920630 | US |