WO2007058846A1 - Reverse coupling effect with timing information - Google Patents

Reverse coupling effect with timing information Download PDF

Info

Publication number
WO2007058846A1
WO2007058846A1 PCT/US2006/043483 US2006043483W WO2007058846A1 WO 2007058846 A1 WO2007058846 A1 WO 2007058846A1 US 2006043483 W US2006043483 W US 2006043483W WO 2007058846 A1 WO2007058846 A1 WO 2007058846A1
Authority
WO
WIPO (PCT)
Prior art keywords
volatile storage
storage elements
data
timing information
neighboring
Prior art date
Application number
PCT/US2006/043483
Other languages
English (en)
French (fr)
Inventor
Jian Chen
Original Assignee
Sandisk Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US11/271,241 external-priority patent/US7289344B2/en
Priority claimed from US11/272,335 external-priority patent/US7289348B2/en
Application filed by Sandisk Corporation filed Critical Sandisk Corporation
Priority to JP2008540159A priority Critical patent/JP4938020B2/ja
Priority to EP06827629A priority patent/EP1946325A1/en
Priority to CN2006800419108A priority patent/CN101317235B/zh
Publication of WO2007058846A1 publication Critical patent/WO2007058846A1/en

Links

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/26Sensing or reading circuits; Data output circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/56Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
    • G11C11/5621Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency using charge storage in a floating gate
    • G11C11/5628Programming or writing circuits; Data input circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/56Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
    • G11C11/5621Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency using charge storage in a floating gate
    • G11C11/5642Sensing or reading circuits; Data output circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/04Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS
    • G11C16/0483Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS comprising cells having several storage transistors connected in series
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/10Programming or data input circuits
    • G11C16/12Programming voltage switching circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/34Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
    • G11C16/3418Disturbance prevention or evaluation; Refreshing of disturbed memory data
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/34Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
    • G11C16/3436Arrangements for verifying correct programming or erasure

Definitions

  • Non-volatile semiconductor memory has become more popular for use in various electronic devices.
  • non-volatile semiconductor memory is used in cellular telephones, digital cameras, personal digital assistants, mobile computing devices, non-mobile computing devices and other devices.
  • Electrical Erasable Programmable Read Only Memory (EEPROM) and flash memory are among the most popular non-volatile semiconductor memories.
  • Both EEPROM and flash memory utilize a floating gate that is positioned above and insulated from a channel region in a semiconductor substrate.
  • the floating gate is positioned between the source and drain regions.
  • a control gate is provided over and insulated from the floating gate.
  • the threshold voltage of the transistor is controlled by the amount of charge that is retained on the floating gate. That is, the minimum amount of voltage that must be applied to the control gate before the transistor is turned on to permit conduction between its source and drain is controlled by the level of charge on the floating gate.
  • Some EEPROM and flash memory devices have a floating gate that is used to store two ranges of charges and, therefore, the memory cell can be programmed/erased between two states (an erased state and a programmed state).
  • Such a flash memory device is sometimes referred to as a binary flash memory device.
  • a multi-state flash memory device is implemented by identifying multiple distinct allowed/valid programmed threshold voltage ranges separated by forbidden ranges. Each distinct threshold voltage range corresponds to a predetermined value for the set of data bits encoded in the memory device.
  • Shifts in the apparent charge stored on a floating gate can occur because of the coupling of an electric field based on the charge stored in adjacent or nearby floating gates.
  • This floating gate to floating gate coupling phenomena is described in U.S. Patent 5,867,429, which is incorporated herein by reference in its entirety.
  • Floating gates that may cause coupling to a target floating gate may include floating gates that are on the same bit line, floating gates on the same word line, or floating gates that are across from the target floating gate because they are on both another bit line and another word line.
  • the floating gate to floating gate coupling phenomena occurs most pronouncedly between sets of memory cells that have been programmed at different times. For example, a first memory cell is programmed to add a level of charge to its floating gate that corresponds to one set of data. Subsequently, one or more neighboring memory cells are programmed to add a level of charge to their floating gates that correspond to a second set of data. After the one or more of the neighboring memory cells are programmed, the charge level read from the first memory cell appears to be different than programmed because of the effect of the charge on the neighboring memory cells being coupled to the first memory cell The coupling from neighboring memory cells can shift the apparent charge level being read a sufficient amount to lead to an erroneous reading of the data stored.
  • the read process for a given memory cell will take into account the programmed state of an neighbor memory cell if the neighbor memory cell was programmed subsequent to the given memory cell.
  • Techniques for determining whether the neighbor memory cell was programmed before or after the given memory cells are disclosed.
  • One embodiment includes accessing stored timing information that is customized for a set of data stored in one or more non-volatile storage elements and reading the set of data from the one or more non-volatile storage elements. The reading of the data includes selectively compensating for one or more potential errors in the set of data based on the timing information.
  • One example implementation includes a plurality of non-volatile storage elements, a set of word lines connected to the non-volatile storage elements, and one or more managing circuits in communication with said non- volatile storage elements.
  • the one or more managing circuits program data to the non-volatile storage elements in a word line order that is not predefined.
  • the programming includes storing timing information for the data.
  • the one or more managing circuits read the data from the non- volatile storage system including compensating for coupling between non-volatile storage elements if the stored timing information indicates that neighboring non-volatile storage elements were potentially programmed later in time than non- volatile storage elements storing the data.
  • Figure 1 is a top view of a NAND string.
  • Figure 2 is an equivalent circuit diagram of the NAND string.
  • Figure 3 is a cross-sectional view of the NAND string.
  • Figure 4 is a block diagram of a non- volatile memory system.
  • Figure 5 is a block diagram of a non- volatile memory array.
  • Figure 6 depicts an example set of threshold voltage distributions.
  • Figure 7 depicts an example set of threshold voltage distributions.
  • Figures 8A-C show various threshold voltage distributions and describe a process for programming non- volatile memory.
  • Figure 9 is a flow chart describing one embodiment of a process for programming non-volatile memory.
  • Figure 10 is a flow chart describing one embodiment of a process for reading non- volatile memory.
  • Figure 11 is a block diagram depicting one page (or other unit) of data.
  • Figure 12 is a flow chart describing one embodiment of a process for programming non- volatile memory.
  • Figure 13 is a flow chart describing one embodiment of a process for reading non- volatile memory.
  • Figure 14 is a flow chart describing one embodiment of a process for reading memory cells on a word line, without using offsets to compensate for coupling.
  • Figure 15 A is a flow chart describing one embodiment of a process for reading memory cells on a word line, using offsets to compensate for coupling.
  • Figure 15B is a flow chart describing one embodiment of a process for reading memory cells on a word line, using offsets to compensate for coupling.
  • Figure 16 is a block diagram depicting one page (or other unit) of data.
  • Figure 17 is a chart describing history data.
  • Figure 18 is a flow chart describing one embodiment of a process for programming non-volatile memory.
  • Figure 19 is a flow chart describing one embodiment of a process for determining history data.
  • Figure 20 is a flow chart describing one embodiment of a process for reading non- volatile memory.
  • Figure 21 is a flow chart describing one embodiment of a process for performing read operations that take into account coupling from neighboring memory cells.
  • Figure 22 is a flow chart describing one embodiment of a process for performing read operations that take into account coupling from neighboring memory cells.
  • Non-volatile memory system suitable for implementing the present invention uses the NAND flash memory structure, which includes arranging multiple transistors in series between two select gates.
  • the transistors in series and the select gates are referred to as a NAND string.
  • Figure 1 is a top view showing one NAND string.
  • Figure 2 is an equivalent circuit thereof.
  • the NAND string depicted in Figures 1 and 2 includes four transistors, 100, 102, 104 and 106, in series and sandwiched between a first select gate 120 and a second select gate 122.
  • Select gate 120 connects the NAND string to bit line contact 126.
  • Select gate 122 connects the NAND string to source line contact 128.
  • Select gate 120 is controlled by applying the appropriate voltages to control gate 120CG.
  • Select gate 122 is controlled by applying the appropriate voltages to control gate 122CG.
  • Each of the transistors 100, 102, 104 and 106 has a control gate and a floating gate.
  • Transistor 100 has control gate IOOCG and floating gate 100FG.
  • Transistor 102 includes control gate 102CG and floating gate 102FG.
  • Transistor 104 includes control gate 104CG and floating gate 104FG.
  • Transistor 106 includes a control gate 106CG and floating gate 106FG.
  • Control gate IOOCG is connected to word line WL3, control gate 102CG is connected to word line WL2, control gate 104CG is connected to word line WLl, and control gate 106CG is connected to word line WLO.
  • transistors 100, 102, 104 and 106 are each memory cells. In other embodiments, the memory cells may include multiple transistors or may be different than that depicted in Figures 1 and 2.
  • Select gate 120 is connected to select line SGD.
  • Select gate 122 is connected to select line
  • FIG. 3 provides a cross-sectional view of the NAND string described above.
  • the transistors of the NAND string are formed in p-well region 140.
  • Each transistor includes a stacked gate structure that consists of a control gate (IOOCG, 102CG, 104CG and 106CG) and a floating gate (100FG 3 102FG, 104FG and 106FG).
  • the floating gates are formed on the surface of the p-well on top of an oxide or other dielectric film.
  • the control gate is above the floating gate, with an inter-polysilicon dielectric layer separating the control gate and floating gate.
  • the control gates of the memory cells (100, 102, 104 and 106) form the word lines.
  • N+ doped layers 130, 132, 134, 136 and 138 are shared between neighboring cells, whereby the cells are connected to one another in series to form a NAND string. These N+ doped layers form the source and drain of each of the cells.
  • N+ doped layer 130 serves as the drain of transistor 122 and the source for transistor 106
  • N+ doped layer 132 serves as the drain for transistor 106 and the source for transistor 104
  • N+ doped layer 134 serves as the drain for transistor 104 and the source for transistor 102
  • N+ doped layer 136 serves as the drain for transistor 102 and the source for transistor 100
  • N+ doped layer 138 serves as the drain for transistor 100 and the source for transistor 120.
  • N+ doped layer 126 connects to the bit line for the NAND string
  • N+ doped layer 128 connects to a common source line for multiple NAND strings.
  • Figures 1-3 show four memory cells in the NAND string, the use of four transistors is provided only as an example.
  • a NAND string used with the technology described herein can have less than four memory cells or more than four memory cells.
  • some NAND strings will include 8 memory cells, 16 memory cells, 32 memory cells, 64 memory cells, etc. The discussion herein is not limited to any particular number of memory cells in a NAND string.
  • Each memory cell can store data represented in analog or digital form.
  • the range of possible threshold voltages of the memory cell can be divided into two ranges, which are assigned logical data "1" and "0.”
  • the voltage threshold is negative after the memory cell is erased, and defined as logic "1.”
  • the threshold voltage is positive after a program operation, and defined as logic "0.”
  • the threshold voltage is negative and a read is attempted by applying 0 volts to the control gate, the memory cell will turn on to indicate logic one is being stored.
  • the threshold voltage is positive and a read operation is attempted by applying 0 volts to the control gate, the memory cell will not turn on, which indicates that logic zero is stored.
  • a memory cell can also store multiple states, thereby storing multiple bits of digital data.
  • the threshold voltage window is divided into the number of states. For example, if four states are used, there will be four threshold voltage ranges assigned to the data values "11,” “10,” “01,” and “00.”
  • the threshold voltage after an erase operation is negative and defined as "11.” Positive threshold voltages are used for the states of "10,” “01,” and "00.”
  • the data values e.g., logical states
  • Another type of memory cell useful in flash EEPROM systems utilizes a non-conductive dielectric material in place of a conductive floating gate to store charge in a non-volatile manner.
  • a non-conductive dielectric material in place of a conductive floating gate to store charge in a non-volatile manner.
  • Such a cell is described in an article by Chan et al., "A True Single-Transistor Oxide-Nitride-Oxide EEPROM Device," IEEE Electron Device Letters, Vol. EDL-8, No. 3, March 1987, pp. 93-95.
  • a triple layer dielectric formed of silicon oxide, silicon nitride and silicon oxide (“ONO”) is sandwiched between a conductive control gate and a surface of a semi-conductive substrate above the memory cell channel.
  • the cell is programmed by injecting electrons from the cell channel into the nitride, where they are trapped and stored in a limited region. This stored charge then changes the threshold voltage of a portion of the channel of the cell in a manner that is detectable.
  • the cell is erased by injecting hot holes into the nitride. See also Nozaki et al., "A 1-Mb EEPROM with MONOS Memory Cell for Semiconductor Disk Application," IEEE Journal of Solid-State Circuits, Vol. 26, No. 4, April 1991, pp. 497-501, which describes a similar cell in a split-gate configuration where a doped polysilicon gate extends over a portion of the memory cell channel to form a separate select transistor.
  • FIG. 4 is a block diagram of one embodiment of a flash memory system.
  • Memory cell array 202 is controlled by column control circuit 204, row control circuit 206, c-source control circuit 210 and p-well control circuit 208.
  • Column control circuit 204 is connected to the bit lines of memory cell array 202 for reading data stored in the memory cells, for determining a state of the memory cells during a program operation, and for controlling potential levels of the bit lines to promote the programming or to inhibit the programming.
  • Row control circuit 206 is connected to the word lines to select one of the word lines, to apply read voltages, to apply program voltages and to apply an erase voltage. For example, program voltage levels used in EPROM and flash memory circuits are higher than the voltages normally used in memory circuits.
  • CMOS complementary metal-oxide-semiconductor
  • CMOS complementary metal-oxide-semiconductor
  • V voltage
  • n voltage
  • V 0Ut voltage
  • the voltage output is supplied to a load, for example the word line of an EPROM memory circuit.
  • a feedback signal from the load to the charge pump.
  • the conventional prior art pump turns off in response to a signal indicating that the load has reached a predetermined voltage.
  • C-source control circuit 210 controls a common source line (labeled as "C-source” in Fig. 5) connected to the memory cells.
  • P-well control circuit 208 controls the p-well voltage.
  • the data stored in the memory cells are read out by the column control circuit 204 and are output to external I/O lines via data input/output buffer 212.
  • Program data to be stored in the memory cells are input to the data input/output buffer 212 via the external I/O lines, and transferred to the column control circuit 204.
  • the external I/O lines are connected to controller 218.
  • Command data for controlling the flash memory device is input to controller 218.
  • the command data informs the flash memory of what operation is requested.
  • the input command is transferred to state machine 216, which controls column control circuit 204, row control circuit 206, c-source control 210, p-well control circuit 208 and data input/output buffer 212.
  • State machine 216 can also output status data of the flash memory such as READY/BUSY or PASS/FAIL.
  • state machine 216 is responsible for managing the programming process, verify process and the read process, including the processes depicted in the flow charts described below.
  • Controller 218 is connected or connectable with a host system such as a personal computer, a digital camera, personal digital assistant, etc. Controller 218 communicates with the host in order to receive commands from the host, receive data from the host, provide data to the host and provide status information to the host. Controller 218 converts commands from the host into command signals that can be interpreted and executed by command circuits 214, which is in communication with state machine 216. Controller 218 typically contains buffer memory for the user data being written to or read from the memory array. In some embodiments, the programming process can be managed by the controller.
  • One exemplar memory system comprises one integrated circuit that includes controller 218, and one or more integrated circuit chips that each contain a memory array and associated control, input/output and state machine circuits.
  • the trend is to integrate the memory arrays and controller circuits of a system together on one or more integrated circuit chips.
  • the memory system may be embedded as part of the host system, or may be included in a memory card (or other package) that is removably inserted into the host systems.
  • a removable card may include the entire memory system (e.g. including the controller) or just the memory array(s) and associated peripheral circuits (with the Controller being embedded in the host).
  • the controller or control capability
  • one or more of the components of Figure 4 can be combined.
  • one or more of the components of Fig 4 (alone or in combination), other than memory cell array 202, can be thought of as a managing circuit.
  • one or more managing circuits may include any one of or a combination of a command circuit, a state machine, a row control circuit, a column control circuit, a well control circuit, a source control circuit or a data I/O circuit.
  • FIG. 5 shows four memory cells connected in series to form a NAND string. Although four cells are shown to be included in each NAND string, more or less than four memory cells can be used. One terminal of the NAND string is connected to corresponding bit line via a select transistor SGD, and another terminal is connected to c-source via a second select transistor SGS.
  • bit lines are simultaneously selected.
  • the memory cells selected have the same word line and the same kind of bit line (e.g. even bit lines or odd bit lines). Therefore, 532 bytes of data can be read or programmed simultaneously. These 532 bytes of data that are simultaneously read or programmed form a logical page. Therefore, one block can store at least eight logical pages (four word lines, each with odd and even pages).
  • each memory cell stores two bits of data (e.g., multi-state memory cells), wherein each of these two bits are stored in a different page, one block stores 16 logical pages.
  • Other sized blocks and pages can also be used with the present invention.
  • architectures other than that of Figs. 4 and 5 can also be used to implement the present invention. For example, in one embodiment the bit lines are not divided into odd and even bit lines so that all bit lines are programmed and read concurrently (or not concurrently).
  • Memory cells are erased by raising the p-well to an erase voltage (e.g. 20 volts) and grounding the word lines of a selected block.
  • the source and bit lines are floating. Erasing can be performed on the entire memory array, separate blocks, or another unit of cells. Electrons are transferred from the floating gate to the p-well region and the threshold voltage becomes negative (in one embodiment).
  • the select gates (SGD and SGS) and the unselected word lines (e.g., WLO, WL2 and WL3) are raised to a read pass voltage (e.g. 4.5 volts) to make the transistors operate as pass gates.
  • the selected word line (e.g. WLl) is connected to a voltage, a level of which is specified for each read and verify operation in order to determine whether a threshold voltage of the concerned memory cell is above or below such level. For example, in a read operation for a two level memory cell, the selected word line WLl may be grounded, so that it is detected whether the threshold voltage is higher than OV.
  • the selected word line WLl is connected to 0.8V, for example, so that it is verified whether or not the threshold voltage has reached at least 0.8V.
  • the source and p-well are at zero volts.
  • the selected bit lines (BLe) are pre- charged to a level of, for example, 0.7V. If the threshold voltage is higher than the read or verify level on the word line, the potential level of the bit line (BLe) associated with the cell of interest maintains the high level because of the non- conductive memory cell.
  • the threshold voltage is lower than the read or verify level, the potential level of the concerned bit line (BLe) decreases to a low level, for example less than 0.5 V, because of the conductive memory cell discharging the bitline.
  • the state of the memory cell is thereby detected by a voltage comparator sense amplifier that is connected to the bit line.
  • each block can be divided into a number of pages.
  • a page is a unit of programming.
  • the individual pages may be divided into segments and the segments may contain the fewest number of cells that are written at one time as a basic programming operation.
  • One or more pages of data are typically stored in one row of memory cells.
  • a page can store one or more sectors.
  • a sector includes user data and overhead data.
  • Overhead data typically includes an Error Correction Code (ECC) that has been calculated from the user data of the sector.
  • ECC Error Correction Code
  • ECCs and/or other overhead data are stored in different pages, or even different blocks, than the user data to which they pertain.
  • other parts of the memory device e.g., state machine
  • a sector of user data is typically 512 bytes, corresponding to the size of a sector in magnetic disk drives.
  • Overhead data is typically an additional 16-20 bytes.
  • a large number of pages form a block, anywhere from 8 pages, for example, up to 32, 64 or more pages.
  • Figure 6 illustrates threshold voltage distributions for the memory cell array when each memory cell stores two bits of data.
  • Figure 6 shows a first threshold voltage distribution E for erased memory cells. Three threshold voltage distributions, A, B and C for programmed memory cells, are also depicted. In one embodiment, the threshold voltages in the E distribution are negative and the threshold voltages in the A, B and C distributions are positive.
  • Each distinct threshold voltage range of Figure 6 corresponds to predetermined values for the set of data bits.
  • the specific relationship between the data programmed into the memory cell and the threshold voltage levels of the cell depends upon the data encoding scheme adopted for the cells.
  • One example assigns "11" to threshold voltage range E (state E), “10” to threshold voltage range A (state A), “00” to threshold voltage range B (state B) and "01” to threshold voltage range C (state C).
  • other schemes are used.
  • Figure 6 also shows three read reference voltages, Vra, Vrb and Vrc, for reading data from memory cells. By testing whether the threshold voltage of a given memory cell is above or below Vra, Vrb and Vrc, the system can determine what state the memory cell is in.
  • Figure 6 also shows three verify reference voltages, Vva, Vvb and Vvc.
  • Vva verify reference voltages
  • Vvb verify reference voltages
  • memory cells can be programmed from the erase state E directly to any of the programmed states A 5 B or C (as depicted by the curved arrows). For example, a population of memory cells to be programmed may first be erased so that all memory cells in the population are in erased state E. While some memory cells are being programmed from state E to state A, other memory cells are being programmed from state E to state B and/or from state E to state C.
  • Figure 7 illustrates an example of a two-pass technique of programming a multi-state memory cell that stores data for two different pages: a lower page and an upper page.
  • states are depicted: state E (11), state A (10), state B (00) and state C (01).
  • state E both pages store a "1.”
  • state A the lower page stores a "0" and the upper page stores a "1.”
  • state B both pages store "0.”
  • state C the lower page stores "1" and the upper page stores "0.”
  • bit patterns may also be assigned.
  • the cell's threshold voltage level is set according to the bit to be programmed into the lower logical page.
  • the threshold voltage is not changed since it is in the appropriate state as a result of having been earlier erased. However, if the bit to be programmed is a logic "0,” the threshold level of the cell is increased to be state A, as shown by arrow 230. That concludes the first programming pass.
  • the cell's threshold voltage level is set according to the bit being programmed into the upper logical page. If the upper logical page bit is to store a logic "1,” then no programming occurs since the cell is in one of the states E or A, depending upon the programming of the lower page bit, both of which carry an upper page bit of "1.” If the upper page bit is to be a logic "0,” then the threshold voltage is shifted. If the first pass resulted in the cell remaining in the erased state E 5 then in the second phase the cell is programmed so that the threshold voltage is increased to be within state C 5 as depicted by arrow 234.
  • the memory cell is further programmed in the second pass so that the threshold voltage is increased to be within state B, as depicted by arrow 232.
  • the result of the second pass is to program the cell into the state designated to store a logic "0" for the upper page without changing the data for the lower page.
  • a system can be set up to perform full sequence writing if enough data is written to fill up an entire page. If not enough data is written for a full page, then the programming process can program the lower page with the data received. When subsequent data is received, the system will then program the upper page. In yet another embodiment, the system can start writing in the mode that programs the lower page and convert to full sequence programming mode if enough data is subsequently received to fill up an entire (or most of a) word line's memory cells. More details of such an embodiment are disclosed in U.S. Patent Application titled "Pipelined Programming of Non- Volatile Memories Using Early Data," Serial No. 11/013,125, filed on 12/14/04, inventors Sergy Anatolievich Gorobets and Yan Li, incorporated herein by reference in its entirety.
  • Figures 8A-C disclose another process for programming nonvolatile memory that reduces floating gate to floating gate coupling by, for any particular memory cell, writing to that particular memory cell with respect to a particular page subsequent to writing to adjacent memory cells for previous pages.
  • the non-volatile memory cells store two bits of data per memory cell, using four data states. For example, assume that state E is the erased state and states A, B and C are the programmed states. State E stores data 11. State A stores data 01. State B stores data 10. State C stores data 00. This is an example of non-Gray coding because both bits change between adjacent states A & B. Other encodings of data to physical data states can also be used.
  • Each memory cell stores two pages of data. For reference purposes these pages of data will be called upper page and lower page; however, they can be given other labels. With reference to state A for the process of Figure 8, the upper page stores bit 0 and the lower page stores bit 1. With reference to state B, the upper page stores bit 1 and the lower page stores bit 0. With reference to state C, both pages store bit data 0.
  • the programming process of Figures 8A-C is a two-step process.
  • the first step the lower page is programmed. If the lower page is to remain data 1, then the memory cell state remains at state E. If the data is to be programmed to 0, then the threshold of voltage of the memory cell is raised such that the memory cell is programmed to state B'.
  • Figure 8A therefore shows the programming of memory cells from state E to state B'. State B' depicted in Figure 8 A is an interim state B; therefore, the verify point is depicted as Vvb', which is lower than Vvb.
  • FIG. 8C depicts the process of programming the upper page. If the memory cell is in erased state E and the upper page is to remain at 1, then the memory cell will remain in state E.
  • the threshold voltage of the memory cell will be raised so that the memory cell is in state A. If the memory cell was in intermediate threshold voltage distribution 250 and the upper page data is to remain at 1, then the memory cell will be programmed to final state B. If the memory cell is in intermediate threshold voltage distribution 250 and the upper page data is to become data 0, then the threshold voltage of the memory cell will be raised so that the memory cell is in state C.
  • Figures 8A-C reduces the effect of floating gate to floating gate coupling because only the upper page programming of neighbor memory cells will have an effect on the apparent threshold voltage of a given memory cell.
  • An example of an alternate state coding is to move from distribution 250 to state C when the upper page data is a 1, and to move to state B when the upper page data is a 0.
  • Figures 9A-C provide an example with respect to four data states and two pages of data, the concepts taught by Figures 8A-C can be applied to other implementations with more or less than four states and different than two pages. More detail about various programming schemes and floating gate to floating gate coupling can be found in U.S. Patent Application No.
  • neighboring memory cells may cause coupling which can affect the apparent threshold voltage of a memory cell.
  • a neighboring memory cell could be on an adjacent word line, an adjacent bit line, a bit line that may not be adjacent but is close-by, or a word line that may not be adjacent but is close-by.
  • the system will selectively compensate for coupling between neighboring floating memory cells by first determining whether there is potential for coupling because the memory cell (or floating gate) being read was programmed prior to the neighboring memory cell (or floating gate) being programmed. If the memory cell being read was programmed prior to the neighboring memory cell, then a process can be used to compensate for the coupling based on the level of programming of the neighboring memory cell.
  • Fig. 9 is a flow chart describing one embodiment of a high level process for programming that includes making use of the timing information.
  • Fig. 10 is a flow chart describing one embodiment of a process for reading that makes use of the timing information programmed in order to determine whether there's a potential for coupling and then selectively compensating based therein.
  • step 300 of Fig. 9 a request to write data is received.
  • This request can be received at the controller, the state machine, or another device.
  • data one or more bits of information
  • step 302. data (one or more bits of information) is written to the flash memory array in step 302.
  • timing information is stored in step 304.
  • the timing information is customized for the data written in step 302.
  • the timing information is stored with the data stored in step 302. In other embodiments, the timing information is stored separately.
  • Steps 302 and 304 can be performed concurrently or separately (in either order). Note that in all of the flow charts included with this document, the order of steps depicted in the flow chart is not necessarily a requirement, and in many cases other suitable orders may also be performed.
  • timing information there are many examples of timing information that can be used.
  • a time stamp is used. This time stamp can be an absolute time stamp that is read from the system clock for the host device.
  • the memory system could include an internal battery and store its own clock.
  • a relative time stamp can be used.
  • a system can maintain a cycle count. The cycle count "will number each programming cycle. The cycle count can be maintained by the state machine, the controller or another device. The cycle count can be stored as timing information in step 304. If a first set of data has a cycle count that is greater than a second set of data, then the first set of data was programmed after the second set of data.
  • Another embodiment of timing information could include an indication of whether data is programmed before or after neighboring memory cells.
  • Fig. 10 provides a flow chart describing a process for reading data.
  • a request to read data is received by the controller, state machine, or other device.
  • timing information for the data is accessed. This is the timing information that was stored in step 304.
  • the system determines whether the timing information indicates that the memory cells storing the data associated with the read request were programmed before neighboring memory cells. If so, then there is a potential for coupling between memory cells. If the memory cells storing the data associated with the read request were programmed after programming the neighboring cells, there is not likely to be a potential for coupling.
  • step 344 determines that there is a potential for coupling, there still may not be any actual coupling if the level of programming of the neighboring cells is not sufficient to create the requisite coupling. If there's no potential for coupling (step 346), then the read process is performed without taking into account coupling in step 348. Note that the read process includes determining the information stored in the non-volatile memory and reporting that information. If it is determined that there is a potential for coupling (step 346), then a read process is performed that takes into account potential coupling in step 350. In one ' embodiment, step 350 includes compensating for the coupling, if necessary. There are many different schemes for compensating for coupling between memory cells. Any suitable scheme can be used with the technology described herein.
  • Fig. 11 is a block diagram describing one embodiment of a page of data.
  • the page of data includes header 380, timing information 382, user data 384, and error correction codes (ECC) 386.
  • Header information 380 can include any set of data known in the art to be used in headers. Some examples of header information include address information, bit and/or sector mapping related information, counts of number of writes to the sector, etc. Other information can also be stored in the header.
  • Timing information 382 is the timing information stored in step 304.
  • User data 384 includes the data written in step 302.
  • ECC 386 includes error correction codes known in the art. Note that some write requests may require writing to multiple pages. In that case, one or more than one set of timing information can be used.
  • Fig. 12 is a flow chart describing one embodiment of a process for writing data.
  • the process of Fig. 12 is one embodiment for performing steps 302 and 304 of Fig. 9.
  • the system will select the appropriate portions of memory to program in response to receiving a request to write data. This may include selecting a block and/or page and/or sector to write to.
  • the process of Fig. 12 writes data to a page, which includes writing data to memory cells connected to a common word line.
  • step 404 the selected portion of memory is pre-programmed, which provides for even wearing of the flash memory.
  • AU memory cells in the chosen sector or page are programmed to the same threshold voltage range.
  • Step 404 is an optional step.
  • step 406 the memory cells to be programmed are then erased.
  • step 406 can include moving old memory cells to state E (see Fig. 6-8).
  • step 406 also includes performing a soft programming process. During the erase process, it is possible that some of the memory cells have their threshold voltages lowered to a value that is below the distribution E (see Fig. 6-8). The soft programming process will apply program voltage pulses to memory cells so that their threshold voltages will increase to be within threshold voltage distribution E.
  • the system will acquire a time stamp.
  • the time stamp can be an absolute time.
  • the memory system could request the date/time from the host via the controller.
  • the memory system could include a battery and an internal clock so that the memory system can provide its own time stamp.
  • the memory system could maintain a cycle count. Each time the system programs a page, the cycle count will be incremented.
  • the time stamp acquired in step 408 would be the current cycle count. While the cycle count does not provide absolute time, it does provide relative time. With cycle counts, it is possible to determine which of two or more pages were programmed first.
  • step 410 data to be programmed is stored in the appropriate latches/registers.
  • the process of Fig. 12 will be used to program one page of data. All of the memory cells being programmed are on the same word line. Each memory cell will have its own bit line and a set of latches associated with that bit line. These latches will store indications of the data to be programmed for the associated memory cell.
  • Step 410 also includes storing the time stamp data into the latches associated with the bit lines for the memory cells that will store the time stamp.
  • step 412 the magnitude of the first program pulse is set.
  • the voltage applied to the word lines is a set of program pulses, with each pulse increasing in magnitude from the previous pulse by a step size (e.g., .2v-.4v).
  • the program count PC will be set to initially be zero.
  • step 416 a program pulse is applied to the appropriate word line(s).
  • step 428 the process of Fig. 12 continues at step 416 and the next program pulse is applied.
  • Fig. 13 provides one example of a process for reading data that has been written according to the process of Fig. 12, or according to other processes.
  • Fig. 13 is an embodiment of the process of Fig. 10.
  • a request to read data is received.
  • a read process is performed for the page requested. In one embodiment, this includes reading data from a set of memory cells connected to the same word line. In some embodiments, each word line will have two adjacent word lines (e.g., one word line above and one word line below, or one word line to the left and one word line to the right).
  • step 504 one of the adjacent word lines is read.
  • step 506 the other adjacent word line is read.
  • step 506 can be skipped.
  • steps 502, 504, and 506 include reading the associated timing information in addition to the user data. That is the entire page depicted in Fig. 11 is read, and that page includes timing information 382.
  • the embodiment of Fig. 13 assumes that the timing information is some type of time stamp such as an absolute time or relative time (e.g., cycle count).
  • step 508 it is determined whether there's a potential for coupling based on comparing the various time stamps.
  • step 510 the data read in step 502 is stored and reported to the user without taking into account any compensation for coupling. If it is determined that there is a potential for coupling (step 510), then in step 514 additional read processes are performed that compensate for the coupling in step 514.
  • Figure 14 is a flow chart describing one embodiment of a process for performing a read operation for a page of data (see step 502 of Fig. 13).
  • the embodiment of Fig. 14 pertains to reading a page of data from a set of memory cells connected to a common word line.
  • the specific embodiment of Fig. 14 pertains to multi-state memory including four states such as states E, A, B, and C of Figs. 6-8.
  • the technology of Fig. 14 can also apply to other configurations.
  • step 540 read reference voltage Vra is applied to the appropriate word line associated with the page.
  • the bit lines associated with the page are sensed to determine whether the addressed memory cells conduct or do not conduct based on the application of Vra to their control gates.
  • bit lines that conduct indicate that the memory cells were turned on; therefore, the threshold voltages of those memory cells are below Vra (e.g., in state E).
  • the result of the sensing for the bit lines is stored in the appropriate latches for the bit lines.
  • read reference voltage Vrb is applied to the word line associated with the page being read.
  • the bit lines are sensed as described above, hi step 550, the results are stored in the appropriate latches for the bit lines, hi step 552, read reference voltage Vrc is applied to the word line associated with the page.
  • the bit lines are sensed to determine which memory cells conduct, as described above.
  • the results from the sensing step are stored in the appropriate latches for the bit lines.
  • the data values for each bit line are determined. For example, if a memory cell conducts at Vra, then the memory cell is in state E. If a memory cell conducts at Vrb and Vrc but not at Vra, then the memory cell is in state A. If the memory cell conducts at Vrc but not at Vra and Vrb, then the memory cell is in state B. If the memory cell does not conduct at Vra, Vrb or Vrc, then the memory cell is in state C. In one embodiment, the data values are determined by a processing unit associated with the sense amps. In step 560, the determined data values are stored in the appropriate latches for each bit line, or elsewhere, to be used by the state machine, controller or other device. In other embodiments, sensing the various levels (Vra, Vrb, and Vrc) may occur in different orders.
  • Fig. 15A provides a flowchart describing one embodiment of a process for performing additional read processes that compensate for potential coupling.
  • Fig. 15A provides one embodiment of step 514 of Fig. 13.
  • the embodiment of Fig. 15A assumes that there is a potential coupling from two neighboring word lines.
  • step 600 the system determines offsets based on each of the neighbors. There are many different types of offsets and values for the offsets that can be used. In one embodiment, if a neighbor memory cell was programmed to State A (see Fig.
  • the offset is 0.1 volts, if the neighbor memory cell was programmed to State B, then the offset will be 0.2 volts, and if the neighbor memory cell was programmed to State C 5 then the offset will be 0.3 volts.
  • other values or schemes can be used.
  • the system has read the values stored in the neighboring word lines in steps 504 and 506 and, therefore, can determine which offsets to use.
  • the system will determine a set of offsets for each of the neighboring word lines and then add the two offsets together. In this scheme, there are six possible offsets.
  • a given memory cell has two neighbors.
  • the first neighbor is programmed to State B.
  • the second neighbor is programmed to State C.
  • the offsets from the first neighbor is 0.2 volts and the offset from the second neighbor is 0.3 volts.
  • the total offset for that particular memory cell is 0.5 volts.
  • the offsets may include a zero volt offset.
  • zero volt offset can be used when the neighboring memory cells remains in state E.
  • step 602 of Fig. 15 A those memory cells that are not to receive any offsets store the previously read data from step 502. For example, if a memory cell has neighbors that are in State E, no offsets (or Ov Offsets) are used.
  • a read process is performed using the first offset with the read points. For example, the process of Fig. 14 can be performed. However, instead of using Vra, Vrb, and Vrc as read compare points, the read process uses Vra + first offset, Vrb + first offset, and Vrc + first offset.
  • step 606 data for the bit lines associated with the first offset is stored. That is, those memory cells that have one neighbor in State E and another neighbor in State A will have the data stored from step 604.
  • a read process is performed using the second set of offsets with the read compare points.
  • the process of Fig. 14 will be used with Vra + second offset, Vrb + second offset, and Vrc + second offset for the read compare points.
  • the bit lines associated with the second offset will store the data from step 608. For example, those memory cells that have one neighbor in State E and another neighbor in State B, or both neighbors in State A, will have stored the data from step 608.
  • a read process performed using the third offset with the read compare points.
  • data is stored for those bit lines associated with the third offset.
  • the read process is performed using the fourth offset with the read compare points.
  • step 618 data from step 616 is stored for those bit lines associated with the fourth offset.
  • step 620 the read process performed using the fifth offset with the read compare points.
  • step 622 data is stored for those bit lines associated with the fifth offset.
  • step 624 a read process is performed using the sixth offset with the read compare points.
  • step 626 data from step 624 is stored for those bit lines that are associated with the sixth offset.
  • the first offset is 0.1 volts
  • the second offset is 0.2 volts
  • the third offset is 0.3 volts
  • the fourth offset is 0.4 volts
  • the fifth offset is 0.5 volts
  • the sixth offset is 0.6 volts. More information about compensating for coupling can be found in U.S. Patent Application number 11/099,133, filed April 5, 2005, "Compensating for Coupling During Read Operations On Non- Volatile Memory," by Jian Chen, incorporated herein by reference in its entirety.
  • Fig. 15A The process of Fig. 15A is performed when there is potential coupling from two neighbors. If it is determined in step 508 that there is only potential coupling from one neighbor, then in step 514 the process of Fig. 15B will be performed.
  • step 630 the system will determine the offsets based on the one neighbor.
  • step 632 previously read data for those bit lines associated with no offsets is stored in step 632.
  • step 634 a read process is performed using the first offsets with the read compare points.
  • step 636 data for those bit lines associated with the first offset is stored.
  • a read process is performed using the second offset with the read compare points.
  • step 640 data for those bit lines associated with the second offset is stored.
  • step 642 a read process is performed using the third offset with the read/compare points.
  • step 644 data for those bit lines associated with the third offset is stored.
  • the timing information will store in indication as to whether the particular page was programmed after or potentially before data on the neighboring word lines (or other neighbors). The reason the information only tells whether the page was written potentially before is because it is possible that the page was written while the neighbor was erased and that the neighbor was never written.
  • Fig. 16 provides another example of a page of data.
  • the depicted page includes header 650, timing information 652, user data 654, timing information 656 and ECC 658.
  • Timing information 652 provides history with respect to a previous word line (History Previous Word Line - HPWL).
  • Timing information 656 provides history with respect to the next word line (History Next Word Line - HNWL).
  • the use of the terms previous and next is not meant to describe time or order. Rather, previous or next is used to identify two different neighbors. For example, looking back at Fig. 5, word line WL2 has at least two neighbors: WL3, and WLl.
  • the neighbor word line closest to the source will be referred to as the previous word line and the neighbor word line closest to the drain will be referred to as the next word line.
  • the previous word line is WLl
  • the next word line is WL2.
  • the technology described herein for determining the potential for coupling and compensating when appropriate can be used with many different programming schemes, including a programming scheme that programs data in an order that is not predefined. That is, in some embodiments words lines are programmed from WLO to WL3. In other embodiments, the system can randomly choose a word line and program the word lines in any order.
  • the technology described herein can work with either embodiment.
  • Fig. 17 is a chart which describes the data values that can be stored in HPWL 652 and HNWL 656.
  • the data stored includes 2 bits: 11, 10, and 00. If HPWL 652 or HNWL 656 stores 11, then the page, sector or word line storing the history is erased. If HPWL 652 or HNWL 656 store 10, then the word line storing that history value has been programmed before the respective neighbor word line. If HPWL 652 or HNWL 656 stores 00, then the respective neighboring word line was programmed before the word line storing the history.
  • HNWL erased
  • the system when writing to WL2 of Fig. 5, the system will first read HPWL of word line WL3 and based thereon, determine what value should be stored in HNWL for word line WL2.
  • the data for programming header 650, HPWL 652, user data 654, HNWL 656 and EC 658 are stored in the appropriate latches for each of the bit lines in step 684. Steps 412-428 of Fig. 17 are the same as in Fig. 12.
  • Fig. 19 is a flow chart describing one embodiment of the process for reading the history information from the next or previous word line and determining the appropriate HPWL or HNWL.
  • Fig. 19 provides one embodiment of steps 680 or 682.
  • a read process is performed by applying voltage Vra to the appropriate word line.
  • the bit lines are sensed to determine whether the memory cell turned on or not.
  • Step 702 need only be performed on those memory cells that are storing the history value (HPWL or HNWL). In other embodiments, step 702 is performed on all (or a different bigger set of) memory cells connected to a word line. Note that if the history value is 11 (State E), then the memory cells will turn on.
  • the memory cells storing the history will not turn on in response to the Vra. If the memory cells storing the history turn on, then it is assumed that the memory cells connected to the neighbor word line are erased; therefore, the current memory cells being programmed are being programmed potentially before the neighbor word line is being programmed. If the memory cells storing the history do not turn on, then it is assumed that the memory cells on the neighbor word line are already programmed and the current word line is being programmed subsequent to the neighbor word line being programmed. Results from step 702 are stored in step 704. Based on whether the memory cells storing the history information turned on or off, (step 706), the appropriate value is stored in the history for the current word line.
  • step 710 the value 10 is stored in the appropriate history value for the current word line indicating that the current word line is programmed before the neighbor. If the history value for the nieghbor is 10, then 00 is stored for the history in the current word line to indicate that the current word line is programmed after the neighbor.
  • Fig. 20 is a flow chart describing one embodiment of a read process for reading data programmed according to the process of Fig. 18. Note that Fig. 20 is another embodiment for the process of Fig. 10.
  • step 800 of Fig. 20 a request to read data is received.
  • step 802 a read process is performed for the word line, without using any offsets.
  • the process of Fig. 14 is performed.
  • step 804 the history is accessed for the word line being read.
  • the history data is read in step 802 as part of the read process of the entire page. That data is then accessed by a processor, state machine, etc. at step 804. In other embodiments, the history data can be accessed before or after step 802.
  • HNWL HNWL
  • HPWL HPWL
  • Fig. 21 is a flow chart describing one embodiment of a process for performing additional read operations that compensate for coupling from one neighbor.
  • the process of Fig. 21 can be performed as part of step 814 or step 816 of Fig. 20.
  • hi step 904 data is read from the neighboring word line using the read compare point Vra provided at the control gate or word line.
  • step 906 it is determined whether the entire word line or page is erased. If all of the memory cells are in State E, then all of the memory cells will turn on in response to Vra. If all the memory cells are erased (step 906), then data is reported without performing any compensation for coupling from the neighbor word line at step 908.
  • step 906 If the neighboring word line is not erased (step 906), then the read process continues with doing a read operation using read compare point Vrb and a read operation using compare point Vrc in step 910. Based on the three read operations, the data stored in the neighbor can be determined (see discussion of Fig. 14). After step 910, an additional read process is performed that compensates for potential coupling in light of the data stored in the neighbor. For example, the process of Fig. 15B can be performed.
  • Fig. 22 is a flow chart describing one embodiment of a process for performing additional read operations that take into account coupling from two neighbors.
  • the process of Fig. 22 can be performed as part of step 818 of Fig. 20.
  • step 930 both neighbor word lines are read using the read compare point Vra. If both neighbors are determined to be erased (step 932), then at step 934 the data is reported without compensating for coupling.
  • step 950 If one neighbor is determined to be erased (e.g., one neighbor word line or page has all of its memory cells turn on, while the other neighbor does not have all its memory cells turned on in response to Vra), then at step 950 that one neighbor will be the subject of read processes performed using the read compare points of Vrb and Vrc (similar to step 910 of Fig. 21). In step 952, additional read processes are performed that compensate for potential coupling at step 952 (similar to step 912 of Fig. 21). If at step 932 it is determined that neither neighbor is erased, then at step 936 both neighbors will have read processes performed using the read compare points of Vrb and Vrc. At step 938, additional read processes will be performed that compensate for potential coupling from both word lines, and that data will be reported. In one embodiment, step 938 includes performing a process of Fig. 15 A.

Landscapes

  • Engineering & Computer Science (AREA)
  • Microelectronics & Electronic Packaging (AREA)
  • Computer Hardware Design (AREA)
  • Read Only Memory (AREA)
  • Non-Volatile Memory (AREA)
  • Semiconductor Memories (AREA)
PCT/US2006/043483 2005-11-10 2006-11-08 Reverse coupling effect with timing information WO2007058846A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2008540159A JP4938020B2 (ja) 2005-11-10 2006-11-08 タイミング情報による逆結合効果
EP06827629A EP1946325A1 (en) 2005-11-10 2006-11-08 Reverse coupling effect with timing information
CN2006800419108A CN101317235B (zh) 2005-11-10 2006-11-08 用于具有定时信息的反向耦合效应的方法和系统

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US11/272,335 2005-11-10
US11/271,241 2005-11-10
US11/271,241 US7289344B2 (en) 2005-11-10 2005-11-10 Reverse coupling effect with timing information for non-volatile memory
US11/272,335 US7289348B2 (en) 2005-11-10 2005-11-10 Reverse coupling effect with timing information

Publications (1)

Publication Number Publication Date
WO2007058846A1 true WO2007058846A1 (en) 2007-05-24

Family

ID=37831516

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2006/043483 WO2007058846A1 (en) 2005-11-10 2006-11-08 Reverse coupling effect with timing information

Country Status (5)

Country Link
EP (1) EP1946325A1 (ko)
JP (1) JP4938020B2 (ko)
KR (1) KR101016432B1 (ko)
TW (1) TWI315068B (ko)
WO (1) WO2007058846A1 (ko)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010530112A (ja) * 2007-06-15 2010-09-02 マイクロン テクノロジー, インク. ソリッドステートメモリ内での粗密プログラミング
JP2011504277A (ja) * 2007-11-21 2011-02-03 マイクロン テクノロジー, インク. Mビットメモリセル用のm+nビットプログラミングおよびm+lビット読出し
JP2011504276A (ja) * 2007-11-21 2011-02-03 マイクロン テクノロジー, インク. フラッシュメモリからデータを読み出す方法および装置

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101411976B1 (ko) * 2007-07-09 2014-06-27 삼성전자주식회사 플래시 메모리 시스템 및 그것의 에러 정정 방법
KR101368694B1 (ko) * 2008-01-22 2014-03-03 삼성전자주식회사 메모리 프로그래밍 장치 및 방법
WO2010002943A1 (en) * 2008-07-01 2010-01-07 Lsi Corporation Methods and apparatus for interfacing between a flash memory controller and a flash memory array
US7983078B2 (en) * 2008-09-24 2011-07-19 Sandisk Technologies Inc. Data retention of last word line of non-volatile memory arrays
KR20100093885A (ko) 2009-02-17 2010-08-26 삼성전자주식회사 불휘발성 메모리 장치, 그것의 동작 방법, 그리고 그것을 포함하는 메모리 시스템
KR101212387B1 (ko) 2011-01-03 2012-12-13 에스케이하이닉스 주식회사 반도체 메모리 소자의 독출 방법
US10910061B2 (en) * 2018-03-14 2021-02-02 Silicon Storage Technology, Inc. Method and apparatus for programming analog neural memory in a deep learning artificial neural network

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1329898A2 (en) * 2002-01-18 2003-07-23 SanDisk Corporation Techniques of recovering data from memory cells affected by field coupling with adjacent memory cells
US20050162913A1 (en) * 2004-01-26 2005-07-28 Jian Chen Method of reading NAND memory to compensate for coupling between storage elements

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3913704B2 (ja) * 2003-04-22 2007-05-09 株式会社東芝 不揮発性半導体記憶装置及びこれを用いた電子装置

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1329898A2 (en) * 2002-01-18 2003-07-23 SanDisk Corporation Techniques of recovering data from memory cells affected by field coupling with adjacent memory cells
US20050162913A1 (en) * 2004-01-26 2005-07-28 Jian Chen Method of reading NAND memory to compensate for coupling between storage elements

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2010530112A (ja) * 2007-06-15 2010-09-02 マイクロン テクノロジー, インク. ソリッドステートメモリ内での粗密プログラミング
JP2011504277A (ja) * 2007-11-21 2011-02-03 マイクロン テクノロジー, インク. Mビットメモリセル用のm+nビットプログラミングおよびm+lビット読出し
JP2011504276A (ja) * 2007-11-21 2011-02-03 マイクロン テクノロジー, インク. フラッシュメモリからデータを読み出す方法および装置
US8499229B2 (en) 2007-11-21 2013-07-30 Micro Technology, Inc. Method and apparatus for reading data from flash memory
US8719680B2 (en) 2007-11-21 2014-05-06 Micron Technology, Inc. Method and apparatus for reading data from non-volatile memory
US9197251B2 (en) 2007-11-21 2015-11-24 Micron Technology, Inc. Method and apparatus for reading data from non-volatile memory

Also Published As

Publication number Publication date
TWI315068B (en) 2009-09-21
TW200737207A (en) 2007-10-01
KR101016432B1 (ko) 2011-02-21
EP1946325A1 (en) 2008-07-23
JP2009516318A (ja) 2009-04-16
KR20080080529A (ko) 2008-09-04
JP4938020B2 (ja) 2012-05-23

Similar Documents

Publication Publication Date Title
US7289344B2 (en) Reverse coupling effect with timing information for non-volatile memory
EP1886319B1 (en) Starting program voltage shift with cycling of non-volatile memory
US7170788B1 (en) Last-first mode and apparatus for programming of non-volatile memory with reduced program disturb
US7218552B1 (en) Last-first mode and method for programming of non-volatile memory with reduced program disturb
US7295473B2 (en) System for reducing read disturb for non-volatile storage
US7495956B2 (en) Reducing read disturb for non-volatile storage
EP2030205B1 (en) Method for non-real time reprogramming of non-volatile memory to achieve tighter distribution of threshold voltages
EP1946323B1 (en) Method for programming of multi-state non-volatile memory using smart verify
EP1991989A1 (en) Read operation for non-volatile storage with compensation for floating gate coupling
EP2078303B1 (en) Reading of a nonvolatile memory cell by taking account of the stored state of a neighboring memory cell
KR101016432B1 (ko) 타이밍 정보를 이용한 리버스 커플링 효과
US7583531B2 (en) Reverse coupling effect with timing information
WO2007143398A2 (en) Verify operation for non-volatile storage using different voltages
EP1943652B1 (en) Last-first mode and method for programming of non-volatile memory of nand type with reduced program disturb
EP1946324B1 (en) Method for controlled programming of non-volatile memory exhibiting bit line coupling
EP2256748B1 (en) Reducing read disturb for non-volatile storage
WO2008042605A1 (en) Reverse reading in non-volatile memory with compensation for coupling

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 200680041910.8

Country of ref document: CN

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2006827629

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2008540159

Country of ref document: JP

Kind code of ref document: A

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 1020087013971

Country of ref document: KR