US20070035995A1 - Method of programming a four-level flash memory device and a related page buffer - Google Patents

Method of programming a four-level flash memory device and a related page buffer Download PDF

Info

Publication number
US20070035995A1
US20070035995A1 US11/460,835 US46083506A US2007035995A1 US 20070035995 A1 US20070035995 A1 US 20070035995A1 US 46083506 A US46083506 A US 46083506A US 2007035995 A1 US2007035995 A1 US 2007035995A1
Authority
US
United States
Prior art keywords
latch
vvfy
cells
logic value
voltage
Prior art date
Legal status (The legal status 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 status listed.)
Abandoned
Application number
US11/460,835
Inventor
Luca Crippa
Rino Micheloni
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
STMicroelectronics SRL
SK Hynix Inc
Original Assignee
STMicroelectronics SRL
Hynix Semiconductor Inc
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 EP20050106972 external-priority patent/EP1748445B1/en
Application filed by STMicroelectronics SRL, Hynix Semiconductor Inc filed Critical STMicroelectronics SRL
Assigned to HYNIX SEMICONDUCTOR INC., STMICROELECTRONICS S.R.L. reassignment HYNIX SEMICONDUCTOR INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: CRIPPA, LUCA, MICHELONI, RINO
Publication of US20070035995A1 publication Critical patent/US20070035995A1/en
Priority to US12/551,383 priority Critical patent/US8553462B2/en
Priority to US14/046,297 priority patent/US8971112B2/en
Abandoned legal-status Critical Current

Links

Images

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/10Programming or 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/5628Programming or writing circuits; Data input circuits

Definitions

  • the present invention relates in general to memory devices, and in particular, to a method of programming a four-level FLASH memory and to a related page buffer for a four-level FLASH memory.
  • a logic state is stored in a cell by programming its threshold voltage. In non-volatile memory devices this is done by transferring a certain electrical charge in a floating gate of the cell.
  • the storage capacity of memory devices can be multiplied by storing more than one bit of information in each single cell of the same physical structure as if destined to store a single information bit. This is in addition to increasing the integration density of arrays of cells individually addressable through wordlines and bit-lines of the array.
  • multi-level cells are carried out with techniques that differ from those used for cells that store a single bit (two-level cells).
  • a certain voltage is applied to the control gate (wordline) of the cell.
  • the value of such a reading voltage is between the threshold voltage of an erased cell and the threshold voltage of a programmed cell such that when the cell is programmed, the reading voltage is lower than its threshold voltage. As a consequence, no current flows through the cell. In contrast, when the cell is erased, the reading voltage is higher than its threshold voltage, and thus a current flows through the cell.
  • two bits of information may be stored by making the programming voltages of the different thresholds that may be set for one memory cell define four different intervals. Each interval is associated to a respective two-bit datum.
  • a reading operation is carried out by comparing an electrical parameter, correlated with the current that flows through the cell, with four distinct reference intervals.
  • the reference intervals are defined by the three different thresholds that may be programmed for each single cell. Each one is associated to a respective two-bit datum. The logic datum associated to the distinct interval of values (threshold voltage distributions) in which the measured electrical parameter falls is thus determined.
  • This approach for a multi-level operation of the cells is applicable to volatile memory cells, such as DRAMs, as well as to non-volatile memory devices, such as EEPROMs and FLASH-EPROMs.
  • FIG. 1 A basic circuit scheme of two memory array bitlines and a so-called page buffer of a four-level FLASH memory is depicted in FIG. 1 and it is described in great detail in European Patent Application No. 05106972.2. This application is assigned to the current assignee of the present invention, the contents of which are incorporated herein by reference in its entirety.
  • the page buffer manages the operations of reading the information stored in the memory cells of a selected memory page, or of writing new information in the cells.
  • the page buffer includes a buffer register of the same size (capacity) of that of a memory page, in which data read (in parallel mode) from the memory cells of a selected memory page are temporarily stored, before being serially output. Similarly, when data are to be written in a memory page, the page buffer is replenished with data that are thereafter written in parallel in the memory cells of a selected memory page. Therefore, a page buffer normally includes a relatively large number of volatile storage elements, typically bistable elements or latches, in a number corresponding to the number of memory cells of the memory page.
  • the basic operations that usually are performed on the memory cells are a page read (an operation involving reading data from a selected memory page), a page program (writing data into a selected memory page), and an erase operation, wherein the content of the memory cells is erased.
  • a two-bits datum may be stored in each cell by programming the latter in any one of four different states. Each one is associated with a corresponding logic value of the two-bits datum.
  • the programming state of a memory cell is defined by the threshold voltage value of the transistor structure that is included in the memory cell structure.
  • the threshold voltage values of the memory cells may assume one of four different values (or ranges of values).
  • a typical choice is to associate said logic values of the stored bit pair to the four different states according to a binary sequence 11, 10, 01, 00 as shown in FIG. 2 , corresponding to increasing threshold voltage values, with the logic value 11 being associated to the state of lowest threshold voltage value (erased state), and the others associated in succession to states of increased threshold voltage value.
  • a known approach for reducing the number of read accesses necessary to retrieve the stored data includes using a different association rule between logic values and states, that make use of the Gray code, as depicted in FIG. 2 .
  • the logic values are associated to the threshold states according to the binary sequence 11, 10, 00, 01 with the logic value 11 being associated to the erased state, and the others associated in succession to states of increased threshold voltage values.
  • Gray code The main feature of using the Gray code is the fact that adjacent programmed states (in terms of threshold voltage values) have corresponding logic values that differ from each other by only one bit.
  • the read voltages Vread 0 , Vread 1 and Vread 2 should be sufficiently distant from the upper and lower bounds of the distributions of the threshold voltages of the cells, as depicted in FIG. 3 .
  • the cells of a memory page are programmed in parallel by incrementing stepwise their threshold voltage. They do not reach at the same time the desired distributions because there are cells that are faster than the others and require fewer program pulses to reach the programmed threshold. After each program pulse, the cells are read for verifying whether they have been correctly programmed or not. When a cell is found to have a threshold voltage comprised in the desired distribution, it is considered programmed and a configuration switch associated to it is opened so that the programmed cell will not receive any further program pulse.
  • the threshold voltage of the fastest cells that is, the cells that reached first the desired distribution have decreased while the remaining cells were given additional program pulses.
  • the read margins that is the difference between the lower bound voltage of the distribution corresponding to the state 10 and a pre-established read voltage Vread 0 be smaller than the design value.
  • FIG. 5 What happens is schematically illustrated in FIG. 5 .
  • the cell is initially erased (a) and must be programmed in the state 10 while ensuring a certain read margin.
  • Program pulses are provided to the cell (b) and a threshold voltage greater than the level VVER 1 is eventually verified.
  • VVER 1 the threshold voltage of the cell appears to have shifted to the left (c) and the read margin may become smaller than the designed safe value (d).
  • the current I SECTOR nullifies, the voltage V S becomes negligible and it is then observed that the threshold voltage of the cell MC 31 is no longer correctly comprised in the distribution corresponding to the state 10 . This could explain why it appears that the threshold voltage of cells that first reach the desired program distribution becomes smaller while other cells of the same page are programmed.
  • the applicants have found a method for overcoming and providing a reliable approach to this problem.
  • the cell is read using a test read voltage smaller than or equal to the program voltage. In this situation the voltage V S on the source node is negligible, and the programmed state of the cell may be correctly verified.
  • An architecture of a page buffer particularly suitable for implementing the method of the invention is also provided.
  • FIG. 1 depicts a page buffer of a four-level FLASH memory according to the prior art.
  • FIG. 2 illustrates the Gray code of a two-bit datum stored in a four level memory cell according to the prior art.
  • FIG. 3 shows the read margins of a memory cell storing a two-bit datum according to the Gray code according to the prior art.
  • FIG. 4 is a simplified view of a page of a FLASH memory device according to the prior art.
  • FIG. 5 illustrates the apparent shift of the programmed threshold voltage of a cell of a four level FLASH memory according to the prior art.
  • FIGS. 6 to 11 show method steps for programming and verifying the least significant bit of a two-bit datum to be stored in the memory cell according to a first embodiment of the invention.
  • FIGS. 12 to 19 show method steps for programming and verifying the most significant bit of a two-bit datum to be stored in the memory cell according to the first embodiment of the invention.
  • FIGS. 20 to 25 show method steps for programming and verifying the least significant bit of a two-bit datum to be stored in the memory cell according to a second embodiment of the invention.
  • FIGS. 26 to 32 show method steps for programming and verifying the most significant bit of a two-bit datum to be stored in the memory cell according to the second embodiment of the invention.
  • FIGS. 33 to 38 show method steps for programming and verifying the least significant bit of a two-bit datum to be stored in the memory cell according to a preferred embodiment of the invention.
  • FIGS. 39 to 45 show method steps for programming and verifying the most significant bit of a two-bit datum to be stored in the memory cell according to the preferred embodiment of the invention.
  • FIG. 46 depicts the page buffer disclosed in European Patent Application No. 05106972.2.
  • FIG. 47 depicts a page buffer for implementing the method steps according to the first and second embodiments of the invention.
  • each cell is associated with at least a pair of latches a MSB LATCH and a LSB LATCH of the page buffer for storing the bits of the two-bit datum to be written in the cell, and for inhibiting program operations on an already programmed cell.
  • the least significant bit of a two-bit datum to be stored in a cell is loaded into the respective latch LSB LATCH of the page buffer. According to a common practice, but not necessarily, it is first stored in the latch dedicated for the most significant bit MSB LATCH, and then it is transferred to the latch LSB LATCH as schematically illustrated in FIG. 6 .
  • Program pulses are applied to the cell (in parallel to all other cells to be programmed) for increasing its threshold voltage up to surpass the first program voltage VVFY 1 ( FIG. 7 ). After each program pulse, it is verified whether the cell has been correctly programmed or not. In the former case, a 1 is stored in the LSB LATCH ( FIG. 8 ) for inhibiting application of further program pulses to the cell.
  • the programmed cell is read using a test read voltage for verifying if effectively the threshold of the programmed cell has reached the desired value by ascertaining that the design read voltage margin has not become reduced because of the above discussed effect on the programming verification of a significant voltage present on the source node V S .
  • the least significant bit still stored in the MSB LATCH is transferred into the LSB LATCH ( FIG. 9 ), and the cells are read using a first test read voltage VVFY 1 - ⁇ smaller than or equal to the program voltage VVFY 1 ( FIG. 10 ).
  • a 1 is loaded in the respective LSB LATCH for inhibiting further program pulses from being applied to the cell ( FIG. 11 ).
  • a 0 in the LSB LATCH means that the corresponding cell has not yet been correctly programmed, and further program pulses need to be applied to it up to make its threshold surpass the program voltage VVFY 1 .
  • MSB most significant bit
  • LSB least significant bit stored in the cell is read from the cell using the read voltage Vread 0 ( FIG. 12 ) and is transferred to an auxiliary latch THIRD LATCH ( FIG. 13 ).
  • the cell is or is not programmed depending on the most significant bit and the least significant bit respectively stored in MSB LATCH and in the LSB LATCH.
  • the program voltage VVFY 2 or VVFY 3 that is used depends on the bits of the two-bit datum to be stored in the cell ( FIG. 14 ). Once the desired threshold voltage has been attained, a 1 is loaded in both latches MSB LATCH and LSB LATCH ( FIG. 15 ).
  • the auxiliary latch THIRD LATCH stores the least significant bit that was to be stored in the cell, and its content is copied into the latch dedicated to the least significant bit LSB LATCH ( FIG. 16 ).
  • the most significant bit to be programmed in the cell is established by reading the cell with a second read voltage Vread 1 ( FIG. 17 ), and the read MSB is copied into the dedicated latch MSB LATCH. Therefore, the latches LSB LATCH and MSB LATCH now store the pair of bits that should have been stored into the memory cell.
  • Correctness of the programming is tested by reading the cell with a second VVFY 2 - ⁇ or a third test read voltage VVFY 3 - ⁇ smaller than or equal to the respective program voltage VVFY 2 or VVFY 3 ( FIG. 18 ).
  • a 1 is loaded in the latches LSB LATCH and MSB LATCH for inhibiting further program pulses from being applied to the cell ( FIG. 19 ). Should a 0 be stored in the MSB LATCH and/or in the LSB LATCH, it means that the cell has not yet been correctly programmed. Further program pulses are applied to it up to achieve a threshold beyond the respective program voltage: VVFY 2 or VVFY 3 .
  • the method comprises two procedures for correctly programming the least significant bit and the most significant bit of a two-bit datum, respectively.
  • the procedure for programming the least significant bit (LSB) comprises the following steps:
  • the LSB is programmed in the cell (FIGS. 6 to 8 );
  • the LSB programming is tested by reading the cell with a first test read voltage equal to the program voltage decreased by a certain quantity VVFY 1 - ⁇ ( FIG. 10 );
  • the procedure for programming the most significant bit comprises the following steps:
  • the procedure for programming the least significant bit LSB comprises substantially the same steps A1 to A4 of the first embodiment.
  • the method steps illustrated in FIGS. 20 to 25 correspond to that illustrated in FIGS. 6 to 11 , with the sole difference that the auxiliary latch THIRD LATCH plays the role of the latch MSB LATCH.
  • the procedure for programming the most significant bit is slightly different from that of the first embodiment because the auxiliary latch THIRD LATCH is used for storing the most significant bit and not the least significant bit.
  • step B1 The most significant bit is first written into the auxiliary latch THIRD LATCH and then it is transferred to the corresponding latch MSB LATCH ( FIG. 26 ), then the step B1 is carried out.
  • the step B3 is executed through the operations illustrated in FIGS. 27 and 28 that correspond to FIGS. 14 and 15 . Then the following steps are carried out:
  • the least significant bit is read at step B5.
  • the steps B6 and B7 are carried out as in the first embodiment, as illustrated in FIGS. 31 and 32 , respectively, which correspond to FIGS. 18 and 19 .
  • Both embodiments require an auxiliary latch THIRD LATCH used for storing the least significant bit in the first embodiment, or the most significant bit in the second embodiment.
  • the other bit not stored into the auxiliary latch is read using an appropriate read voltage.
  • the step B1 is the same as in the first embodiment as illustrated in FIG. 39 .
  • the step B2 is not carried out because there is no auxiliary latch, and the step B3 is identical as in the first embodiment as illustrated in FIGS. 40 and 41 .
  • the least and the most significant bit are retrieved by executing the steps B5 of the first embodiment as illustrated in FIG. 42 , and the step B5 of the second embodiment as illustrated in FIG. 43 , The steps B6 and B7 are carried out as in the first embodiment as illustrated in FIGS. 44 and 45 , respectively.
  • the third embodiment may be implemented by the page buffer circuit disclosed in European Patent Application No 05106972.2, which is assigned to the current assignee of the present invention. This embodiment is schematically depicted in FIG. 46 . The meaning of each label is made clear in the above referenced application.
  • FIG. 47 A novel page buffer suitable for implementing the first and second embodiments is depicted in FIG. 47 , in which the same elements in common with FIG. 46 are identified by the same labels.
  • This novel page buffer includes the additional latch THIRD LATCH and a switch M 23 controlled by the signal TRANSFER for transferring the bit stored in the THIRD LATCH to the LSB LATCH and vice versa.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Read Only Memory (AREA)

Abstract

A four-level FLASH memory device includes an array of singularly addressable preliminarily erased memory cells, with each memory cell capable of storing a two-bit datum. When the threshold voltage of a memory cell is verified to have reached the desired distribution, the cell is read using a test read voltage smaller than or equal to the program voltage. In this situation the voltage VS on the source node is negligible, and the programmed state of the cell may be correctly verified.

Description

    FIELD OF THE INVENTION
  • The present invention relates in general to memory devices, and in particular, to a method of programming a four-level FLASH memory and to a related page buffer for a four-level FLASH memory.
  • BACKGROUND OF THE INVENTION
  • A logic state is stored in a cell by programming its threshold voltage. In non-volatile memory devices this is done by transferring a certain electrical charge in a floating gate of the cell.
  • The storage capacity of memory devices can be multiplied by storing more than one bit of information in each single cell of the same physical structure as if destined to store a single information bit. This is in addition to increasing the integration density of arrays of cells individually addressable through wordlines and bit-lines of the array.
  • Though based on the same physical mechanisms, the programming and reading of cells that store more than one bit (multi-level cells) are carried out with techniques that differ from those used for cells that store a single bit (two-level cells).
  • To read a two-level memory array cell, a certain voltage is applied to the control gate (wordline) of the cell. The value of such a reading voltage is between the threshold voltage of an erased cell and the threshold voltage of a programmed cell such that when the cell is programmed, the reading voltage is lower than its threshold voltage. As a consequence, no current flows through the cell. In contrast, when the cell is erased, the reading voltage is higher than its threshold voltage, and thus a current flows through the cell.
  • In four-level cells, two bits of information may be stored by making the programming voltages of the different thresholds that may be set for one memory cell define four different intervals. Each interval is associated to a respective two-bit datum. A reading operation is carried out by comparing an electrical parameter, correlated with the current that flows through the cell, with four distinct reference intervals. The reference intervals are defined by the three different thresholds that may be programmed for each single cell. Each one is associated to a respective two-bit datum. The logic datum associated to the distinct interval of values (threshold voltage distributions) in which the measured electrical parameter falls is thus determined.
  • This approach for a multi-level operation of the cells is applicable to volatile memory cells, such as DRAMs, as well as to non-volatile memory devices, such as EEPROMs and FLASH-EPROMs.
  • Of course, incrementing the number of information bits that may be stored in a single memory cell makes certain functioning characteristics of the memory array cells more critical, such as their immunity to disturbances (noise), to the spread of information retention characteristics, and to ensure appropriate tolerance ranges of the biasing voltages at which each cell is programmed and read.
  • A basic circuit scheme of two memory array bitlines and a so-called page buffer of a four-level FLASH memory is depicted in FIG. 1 and it is described in great detail in European Patent Application No. 05106972.2. This application is assigned to the current assignee of the present invention, the contents of which are incorporated herein by reference in its entirety. The page buffer manages the operations of reading the information stored in the memory cells of a selected memory page, or of writing new information in the cells.
  • The page buffer includes a buffer register of the same size (capacity) of that of a memory page, in which data read (in parallel mode) from the memory cells of a selected memory page are temporarily stored, before being serially output. Similarly, when data are to be written in a memory page, the page buffer is replenished with data that are thereafter written in parallel in the memory cells of a selected memory page. Therefore, a page buffer normally includes a relatively large number of volatile storage elements, typically bistable elements or latches, in a number corresponding to the number of memory cells of the memory page.
  • The basic operations that usually are performed on the memory cells are a page read (an operation involving reading data from a selected memory page), a page program (writing data into a selected memory page), and an erase operation, wherein the content of the memory cells is erased.
  • In four-level memory devices, a two-bits datum may be stored in each cell by programming the latter in any one of four different states. Each one is associated with a corresponding logic value of the two-bits datum. Usually, the programming state of a memory cell is defined by the threshold voltage value of the transistor structure that is included in the memory cell structure.
  • In a memory cell adapted to store two bits, the threshold voltage values of the memory cells may assume one of four different values (or ranges of values). A typical choice is to associate said logic values of the stored bit pair to the four different states according to a binary sequence 11, 10, 01, 00 as shown in FIG. 2, corresponding to increasing threshold voltage values, with the logic value 11 being associated to the state of lowest threshold voltage value (erased state), and the others associated in succession to states of increased threshold voltage value.
  • Naturally, for writing data into a two-bit memory cell or for reading data therefrom, it might be necessary to perform up to three read accesses to the memory cells using different read voltage references.
  • A known approach for reducing the number of read accesses necessary to retrieve the stored data includes using a different association rule between logic values and states, that make use of the Gray code, as depicted in FIG. 2. In this way, the logic values are associated to the threshold states according to the binary sequence 11, 10, 00, 01 with the logic value 11 being associated to the erased state, and the others associated in succession to states of increased threshold voltage values.
  • The main feature of using the Gray code is the fact that adjacent programmed states (in terms of threshold voltage values) have corresponding logic values that differ from each other by only one bit.
  • In the ensuing description reference will be made to embodiments that employ such a coding, but the same considerations that will be made apply to any kind of coding for storing a two-bit datum in a cell of a four-level memory device.
  • In order to discriminate the value stored in the cell, the read voltages Vread0, Vread1 and Vread2 should be sufficiently distant from the upper and lower bounds of the distributions of the threshold voltages of the cells, as depicted in FIG. 3.
  • The cells of a memory page are programmed in parallel by incrementing stepwise their threshold voltage. They do not reach at the same time the desired distributions because there are cells that are faster than the others and require fewer program pulses to reach the programmed threshold. After each program pulse, the cells are read for verifying whether they have been correctly programmed or not. When a cell is found to have a threshold voltage comprised in the desired distribution, it is considered programmed and a configuration switch associated to it is opened so that the programmed cell will not receive any further program pulse.
  • After having programmed and verified the cells, it is often found that some cells inexplicably no longer have a threshold voltage comprised in the distribution to which they were programmed, and therefore the datum stored therein is not the correct one. More precisely, it appears that the threshold voltage of the fastest cells, that is, the cells that reached first the desired distribution have decreased while the remaining cells were given additional program pulses.
  • For better understanding the problem, let us refer to the circuit of FIG. 4 and consider a sample case in which all the cells of the wordline WL<31> should be programmed to the logic state 10. All the cells are initially in the erased state, that is, in the state 11. The cell MC31 is subjected to program pulses until its threshold voltage surpasses the voltage VVFY1.
  • This is carried out by applying the voltage VVFY1 on the wordline WL<31> and stopping to apply further program pulses to the cell MC31 when there is not anymore current flowing through the cell. In this situation, the cell MC31 is considered to have been programmed to the binary logic state 10.
  • Unfortunately, it may happen that the read margins, that is the difference between the lower bound voltage of the distribution corresponding to the state 10 and a pre-established read voltage Vread0 be smaller than the design value.
  • What happens is schematically illustrated in FIG. 5. The cell is initially erased (a) and must be programmed in the state 10 while ensuring a certain read margin. Program pulses are provided to the cell (b) and a threshold voltage greater than the level VVER1 is eventually verified. When other cells of the same bitline have been programmed, it seems as the threshold voltage of the cell appears to have shifted to the left (c) and the read margin may become smaller than the designed safe value (d).
  • SUMMARY OF THE INVENTION
  • Extensive investigations carried out by the applicant have lead to the conclusion that the above described effect is probably due to the fact that the source line voltage VS of the circuit of FIG. 4 is not constant nor negligible. As a matter of fact, when the cells of other bitlines of the same page are being programmed, the total current ISECTOR flowing through these bitlines flows also through the source line transistor MTSRCTOGND and through the two resistors RSL1 and RSL2. Thus, the voltage on the VS node is not negligible and the cell MC31 is incorrectly verified as having reached the desired programmed state.
  • When the other cells have been programmed, the current ISECTOR nullifies, the voltage VS becomes negligible and it is then observed that the threshold voltage of the cell MC31 is no longer correctly comprised in the distribution corresponding to the state 10. This could explain why it appears that the threshold voltage of cells that first reach the desired program distribution becomes smaller while other cells of the same page are programmed.
  • The applicants have found a method for overcoming and providing a reliable approach to this problem. According to the invention, when the threshold voltage of a cell is verified to have reached the desired distribution, the cell is read using a test read voltage smaller than or equal to the program voltage. In this situation the voltage VS on the source node is negligible, and the programmed state of the cell may be correctly verified.
  • An architecture of a page buffer particularly suitable for implementing the method of the invention is also provided.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 depicts a page buffer of a four-level FLASH memory according to the prior art.
  • FIG. 2 illustrates the Gray code of a two-bit datum stored in a four level memory cell according to the prior art.
  • FIG. 3 shows the read margins of a memory cell storing a two-bit datum according to the Gray code according to the prior art.
  • FIG. 4 is a simplified view of a page of a FLASH memory device according to the prior art.
  • FIG. 5 illustrates the apparent shift of the programmed threshold voltage of a cell of a four level FLASH memory according to the prior art.
  • FIGS. 6 to 11 show method steps for programming and verifying the least significant bit of a two-bit datum to be stored in the memory cell according to a first embodiment of the invention.
  • FIGS. 12 to 19 show method steps for programming and verifying the most significant bit of a two-bit datum to be stored in the memory cell according to the first embodiment of the invention.
  • FIGS. 20 to 25 show method steps for programming and verifying the least significant bit of a two-bit datum to be stored in the memory cell according to a second embodiment of the invention.
  • FIGS. 26 to 32 show method steps for programming and verifying the most significant bit of a two-bit datum to be stored in the memory cell according to the second embodiment of the invention.
  • FIGS. 33 to 38 show method steps for programming and verifying the least significant bit of a two-bit datum to be stored in the memory cell according to a preferred embodiment of the invention.
  • FIGS. 39 to 45 show method steps for programming and verifying the most significant bit of a two-bit datum to be stored in the memory cell according to the preferred embodiment of the invention.
  • FIG. 46 depicts the page buffer disclosed in European Patent Application No. 05106972.2.
  • FIG. 47 depicts a page buffer for implementing the method steps according to the first and second embodiments of the invention.
  • DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
  • In a four-level memory device, each cell is associated with at least a pair of latches a MSB LATCH and a LSB LATCH of the page buffer for storing the bits of the two-bit datum to be written in the cell, and for inhibiting program operations on an already programmed cell. Three alternate embodiments of the method of the invention will now be described.
  • First Embodiment
  • The least significant bit of a two-bit datum to be stored in a cell is loaded into the respective latch LSB LATCH of the page buffer. According to a common practice, but not necessarily, it is first stored in the latch dedicated for the most significant bit MSB LATCH, and then it is transferred to the latch LSB LATCH as schematically illustrated in FIG. 6.
  • Program pulses are applied to the cell (in parallel to all other cells to be programmed) for increasing its threshold voltage up to surpass the first program voltage VVFY1 (FIG. 7). After each program pulse, it is verified whether the cell has been correctly programmed or not. In the former case, a 1 is stored in the LSB LATCH (FIG. 8) for inhibiting application of further program pulses to the cell.
  • According to the method, the programmed cell is read using a test read voltage for verifying if effectively the threshold of the programmed cell has reached the desired value by ascertaining that the design read voltage margin has not become reduced because of the above discussed effect on the programming verification of a significant voltage present on the source node VS.
  • Accordingly, the least significant bit still stored in the MSB LATCH is transferred into the LSB LATCH (FIG. 9), and the cells are read using a first test read voltage VVFY1-Δ smaller than or equal to the program voltage VVFY1 (FIG. 10).
  • If a cell read confirm to be correctly programmed, a 1 is loaded in the respective LSB LATCH for inhibiting further program pulses from being applied to the cell (FIG. 11). A 0 in the LSB LATCH means that the corresponding cell has not yet been correctly programmed, and further program pulses need to be applied to it up to make its threshold surpass the program voltage VVFY1.
  • Then the most significant bit (MSB) is loaded in the MSB LATCH. The least significant bit (LSB) stored in the cell is read from the cell using the read voltage Vread0 (FIG. 12) and is transferred to an auxiliary latch THIRD LATCH (FIG. 13).
  • The cell is or is not programmed depending on the most significant bit and the least significant bit respectively stored in MSB LATCH and in the LSB LATCH. The program voltage VVFY2 or VVFY3 that is used depends on the bits of the two-bit datum to be stored in the cell (FIG. 14). Once the desired threshold voltage has been attained, a 1 is loaded in both latches MSB LATCH and LSB LATCH (FIG. 15).
  • The auxiliary latch THIRD LATCH stores the least significant bit that was to be stored in the cell, and its content is copied into the latch dedicated to the least significant bit LSB LATCH (FIG. 16).
  • The most significant bit to be programmed in the cell is established by reading the cell with a second read voltage Vread1 (FIG. 17), and the read MSB is copied into the dedicated latch MSB LATCH. Therefore, the latches LSB LATCH and MSB LATCH now store the pair of bits that should have been stored into the memory cell.
  • Correctness of the programming is tested by reading the cell with a second VVFY2-Δ or a third test read voltage VVFY3-Δ smaller than or equal to the respective program voltage VVFY2 or VVFY3 (FIG. 18).
  • If the cell, read with the respective test read voltage, results to be programmed, a 1 is loaded in the latches LSB LATCH and MSB LATCH for inhibiting further program pulses from being applied to the cell (FIG. 19). Should a 0 be stored in the MSB LATCH and/or in the LSB LATCH, it means that the cell has not yet been correctly programmed. Further program pulses are applied to it up to achieve a threshold beyond the respective program voltage: VVFY2 or VVFY3.
  • In brief, according to this first embodiment, the method comprises two procedures for correctly programming the least significant bit and the most significant bit of a two-bit datum, respectively.
  • The procedure for programming the least significant bit (LSB) comprises the following steps:
  • A1. The LSB is programmed in the cell (FIGS. 6 to 8);
  • A2. The LSB value is recovered from the MSB LATCH were it is still stored (FIG. 9);
  • A3. The LSB programming is tested by reading the cell with a first test read voltage equal to the program voltage decreased by a certain quantity VVFY1-Δ (FIG. 10); and
  • A4. If the test fails, further program pulses are applied in parallel also to the failed cell as far as making its threshold surpass the first program voltage VVFY1 (FIG. 11).
  • The procedure for programming the most significant bit (MSB) comprises the following steps:
  • B1. Retrieving the value of the programmed LSB by reading the cell using a first read voltage Vread0 (FIG. 12);
  • B2. Storing in an auxiliary latch the bit read in the previous step (FIG. 13);
  • B3. Applying program pulses to the cell up to make its threshold surpass a respective program voltage VVFY2 or VVFY3 depending on the LSB and the MSB (FIGS. 14 and 15);
  • B4. Copying in the LSB LATCH the bit stored in the auxiliary latch (FIG. 16);
  • B5. Retrieving the value of the programmed MSB by reading the cell with a second read voltage Vread1 and loading the read bit into the dedicated latch MSB LATCH (FIG. 17);
  • B6. Testing the reliability of the programming by reading the cell with a second VVFY2-Δ or a third test read voltage VVFY3-Δ smaller than or equal to the respective second or third program voltage VVFY2 or VVFY3 (FIG. 18); and
  • B7. If the test at the previous step fails, programming pulses are supplied in parallel to the failed cell up to surpass the respective program voltage (FIG. 19).
  • Second Embodiment
  • In the second embodiment, the procedure for programming the least significant bit LSB comprises substantially the same steps A1 to A4 of the first embodiment. The method steps illustrated in FIGS. 20 to 25 correspond to that illustrated in FIGS. 6 to 11, with the sole difference that the auxiliary latch THIRD LATCH plays the role of the latch MSB LATCH.
  • The procedure for programming the most significant bit is slightly different from that of the first embodiment because the auxiliary latch THIRD LATCH is used for storing the most significant bit and not the least significant bit.
  • The most significant bit is first written into the auxiliary latch THIRD LATCH and then it is transferred to the corresponding latch MSB LATCH (FIG. 26), then the step B1 is carried out. The step B3 is executed through the operations illustrated in FIGS. 27 and 28 that correspond to FIGS. 14 and 15. Then the following steps are carried out:
  • B4. Copying in the MSB LATCH the bit stored in the auxiliary latch (FIG. 29); and
  • B5. Retrieving the least significant bit by reading the cell with a first read voltage Vread0 and a third read voltage Vread2 and loading the read bit into the latch LSB LATCH (FIG. 30).
  • In the second embodiment the least significant bit is read at step B5.
  • The steps B6 and B7 are carried out as in the first embodiment, as illustrated in FIGS. 31 and 32, respectively, which correspond to FIGS. 18 and 19.
  • Both embodiments require an auxiliary latch THIRD LATCH used for storing the least significant bit in the first embodiment, or the most significant bit in the second embodiment. The other bit not stored into the auxiliary latch is read using an appropriate read voltage.
  • Third Embodiment
  • In this embodiment no auxiliary latch is required because both the least significant bit and the most significant bit are read using appropriate read voltages. As shown in FIGS. 33 to 38, the steps A1 to A4 of the procedure for programming the least significant bit are exactly the same as in the first embodiment.
  • As far as the procedure for programming the most significant bit is concerned, the step B1 is the same as in the first embodiment as illustrated in FIG. 39. The step B2 is not carried out because there is no auxiliary latch, and the step B3 is identical as in the first embodiment as illustrated in FIGS. 40 and 41.
  • The least and the most significant bit are retrieved by executing the steps B5 of the first embodiment as illustrated in FIG. 42, and the step B5 of the second embodiment as illustrated in FIG. 43, The steps B6 and B7 are carried out as in the first embodiment as illustrated in FIGS. 44 and 45, respectively.
  • The third embodiment may be implemented by the page buffer circuit disclosed in European Patent Application No 05106972.2, which is assigned to the current assignee of the present invention. This embodiment is schematically depicted in FIG. 46. The meaning of each label is made clear in the above referenced application.
  • A novel page buffer suitable for implementing the first and second embodiments is depicted in FIG. 47, in which the same elements in common with FIG. 46 are identified by the same labels. This novel page buffer includes the additional latch THIRD LATCH and a switch M23 controlled by the signal TRANSFER for transferring the bit stored in the THIRD LATCH to the LSB LATCH and vice versa.
  • Another difference between the novel page buffer of the invention and the page buffer disclosed in the cited prior European patent application is that the latch MSB LATCH is not directly connected to the switches M7 and M8 controlled by the signal DATALOAD_N and DATALOAD. This is due to the fact that, when the DATALOAD signal is asserted, a bit must be loaded into the auxiliary latch THIRD LATCH and not in the latch MSB LATCH, before being transferred to the latch LSB LATCH.

Claims (7)

1. A method of programming a four-level FLASH memory device including an array of singularly addressable preliminarily erased memory cells, each capable of storing a two-bit datum, by programming first the least significant bit in all the cells and then the most significant bit in all the cells, comprising the following steps:
a) applying program pulses in parallel to all the cells in which a least significant bit of a certain logic value (0) must be stored, increasing stepwise the threshold voltage up to make it surpass a first program voltage (VVFY1), and leaving in the erased state the other cells in which a least significant bit of opposite logic value (1) must be stored,
b) applying program pulses in parallel to all the cells in which a least significant bit of said certain logic value (0) must be stored, increasing stepwise the threshold voltage up to make it surpass a second program voltage (VVFY2) to all the cells in which the least significant bit equals said certain logic value (0), or a third program voltage (VVFY3) to all the cells in which the least significant bit differs from said certain logic value, and leaving all the cells, in which a most significant bit of opposite logic value (1) must be stored, as they are at the end of step a),
characterized in that the method comprises performing after step a) the following additional steps before step b):
a1) testing the least significant bit programming by reading the array cells using a first test read voltage (VVFY1-Δ ) smaller than or equal to said first program voltage (VVFY1);
a2) if any cell fails the test, applying program pulses in parallel to all the failed cells increasing stepwise their threshold voltage up to make it surpass said first program voltage (VVFY1).
2. The method of claim 1, further comprising performing after step b) the following additional steps:
b1) testing the most significant bit programming carried out in step b) by reading the array cells either using a second test read voltage (VVFY2-Δ ) or a third test read voltage (VVFY3-Δ ), respectively, said second and third test read voltages (VVFY2-Δ , VVFY3-Δ ) being smaller than or equal to said second program voltage (VVFY2) or third program voltage (VVFY3), respectively;
b2) if any cell fails the test, applying program pulses in parallel to all the failed cells increasing stepwise their threshold voltage up to make it surpass the second program voltage (VVFY2) or the third program voltage (VVFY3), respectively.
3. The method of claim 1, wherein said FLASH memory comprises a page buffer including at least a first latch (LSB LATCH) and a second latch (MSB LATCH) for each memory cell for temporarily storing the least significant bit and the most significant bit, respectively, wherein said step a) is carried out through the following operations:
aa) loading in both said latches the least significant bit of a two-bit string to be written in the memory cell,
ab) applying program pulses in parallel to all the cells in which the bit stored in the respective first latch (LSB LATCH) equals said certain logic value (0), increasing step by step the threshold voltage of all the cells to be programmed up to make it surpass said first program voltage (VVFY1), and leaving in the erased state the other cells,
ac) as soon as the threshold voltage of each cell surpasses said first program voltage (VVFY1), loading the inverse of said certain logic value (1) in the respective first latch (LSB LATCH);
wherein step a1) is carried out through the following operations:
a1a) copying the value stored in each of said second latches (MSB LATCH) in the corresponding first latch (LSB LATCH),
a1b) testing the least significant bit programming by reading the array cells the respective first latch (LSB LATCH) of which stores a bit of said certain logic value (0) using said first test read voltage (VVFY1-Δ ), and loading the inverse of said certain logic value (1) in the first latch (LSB LATCH) if said test is verified;
wherein step a2) is carried out through the following operations:
a2a) applying program pulses in parallel to all the cells the first latch (LSB LATCH) of which stores said certain logic value (0),
a2b) as soon as the threshold voltage of each cell surpasses said first program voltage (VVFY1), loading the inverse of said certain logic value (1) in the respective first latch (LSB LATCH).
4. The method of claim 2, wherein said page buffer comprises an auxiliary latch (THIRD LATCH) for each memory cell, said step b) being carried out through the following operations:
ba) reading the array cells using a first read voltage (Vread0) for discriminating programmed cells from erased cells and loading in said first latch (LSB LATCH) a bit of said certain logic value (0) or its inverse (1), respectively,
bb) loading in said second latches (MSB LATCH) the respective most significant bits,
bc) copying in said auxiliary latches (THIRD LATCH) the bits stored in the respective first latch (LSB LATCH),
bd) applying program pulses in parallel to all the cells the second latch (MSB LATCH) of which stores said certain logic value (0), by increasing stepwise the threshold voltage of all the cells the first latch (LSB LATCH) of which stores said certain logic value (0) up to make it surpass the second program voltage (VVFY2) or of all the cells the first latch (LSB LATCH) of which stores the inverse logic value (1) up to make it surpass the third program voltage (VVFY3),
be) as soon as the threshold voltage of each cell surpasses said second (VVFY2) or third program voltage (VVFY3), respectively, loading said inverse logic value (1) in the respective first latch (LSB LATCH) and in the second latch (MSB LATCH);
wherein step b1) is carried out through the following operations:
b1a) copying the value stored in said auxiliary latches (THIRD LATCH) in the corresponding first latches (LSB LATCH),
b1b) reading the array cells using a second read voltage (Vread1) smaller than said second program voltage (VVFY2) and loading in said second latches (MSB LATCH) the most significant bits that have been read,
b1c) testing the most significant bit programming by reading the array cells the second latch (MSB LATCH) of which stores said certain logic value (0) using a second test read voltage (VVFY2-Δ ) if the least significant latch (LSB LATCH) stores said certain logic value (0) or a third test read voltage (VVFY3-Δ ) if the least significant latch (LSB LATCH) stores said inverse logic value (1), smaller than or equal to said second program voltage (VVFY2) or third program voltage (VVFY3), respectively, and loading said inverse logic value (1) in the second latch (MSB LATCH) and in the first latch (LSB LATCH) if the read most significant bit equals said certain logic value (0);
wherein step b2) is carried out through the following operations:
b2a) applying program pulses in parallel to all the cells the second latch (MSB LATCH) of which and the first latch (LSB LATCH) of which store said inverse logic value (1),
b2b) as soon as the threshold voltage of each cell surpasses said second program voltage (VVFY2) or third program voltage (VVFY3), loading said inverse logic value (1) in the second latch (MSB LATCH) and in the first latch (LSB LATCH).
5. The method of claim 2, wherein said page buffer comprises an auxiliary latch (THIRD LATCH) for each memory cell, the auxiliary latch (THIRD LATCH) being used for carrying out steps aa) to a2b) instead of the second latch (MSB LATCH), said step b) being carried out through the following operations:
ba) loading in said auxiliary latch (THIRD LATCH) the most significant bit of the two-bit string to be stored therein,
bb) copying in second latch (MSB LATCH) the bit stored in said auxiliary latch (THIRD LATCH),
bc) reading the array cells using a first read voltage (Vread0) for discriminating programmed cells from erased cells and loading in said first latch (LSB LATCH) a bit of said certain logic value (0) or its inverse (1), respectively,
bd) applying program pulses in parallel to all the cells the second latch (MSB LATCH) of which stores said certain logic value (0), by increasing stepwise the threshold voltage of all the cells the first latch (LSB LATCH) of which stores said certain logic value (0) up to make it surpass the second program voltage (VVFY2) or of all the cells the first latch (LSB LATCH) of which stores the inverse logic value (1) up to make it surpass the third program voltage (VVFY3),
be) as soon as the threshold voltage of each cell surpasses said second (VVFY2) or third program voltage (VVFY3), respectively, loading said inverse logic value (1) in the respective first latch (LSB LATCH) and in the second latch (MSB LATCH);
wherein step b1) is carried out through the following operations:
b1a) copying the value stored in said auxiliary latches (THIRD LATCH) in the corresponding second latches (MSB LATCH),
b1b) reading the array cells using a first read voltage (Vread0) or a third read voltage (Vread2), that are smaller than said first program voltage (VVFY1) or said third program voltage (VVFY3), respectively, and loading in said first latches (LSB LATCH) the least significant bits that have been read,
b1c) testing the most significant bit programming by reading the array cells the second latch (MSB LATCH) of which stores said certain logic value (0) using a second test read voltage (VVFY2-Δ ) if the least significant latch (LSB LATCH) stores said certain logic value (0) or a third test read voltage (VVFY3-Δ ) if the least significant latch (LSB LATCH) stores said inverse logic value (1), smaller than or equal to said second program voltage (VVFY2) or third program voltage (VVFY3), respectively, and loading said inverse logic value (1) in the second latch (MSB LATCH) and in the first latch (LSB LATCH) if the read most significant bit equals said certain logic value (0);
wherein step b2) is carried out through the following operations:
b2a) applying program pulses in parallel to all the cells the second latch (MSB LATCH) of which and the first latch (LSB LATCH) of which store said inverse logic value (1),
b2b) as soon as the threshold voltage of each cell surpasses said second program voltage (VVFY2) or third program voltage (VVFY3), loading said inverse logic value (1) in the second latch (MSB LATCH) and in the first latch (LSB LATCH).
6. The method of claim 2, wherein said step b) is carried out through the following operations:
ba) loading in said second latches (MSB LATCH) the respective most significant bits,
bb) reading the array cells using a first read voltage (Vread0) for discriminating programmed cells from erased cells and loading in said first latch (LSB LATCH) a bit of said certain logic value (0) or its inverse (1), respectively,
bc) applying program pulses in parallel to all the cells the second latch (MSB LATCH) of which stores said certain logic value (0), by increasing stepwise the threshold voltage of all the cells the first latch (LSB LATCH) of which stores said certain logic value (0) up to make it surpass the second program voltage (VVFY2) or of all the cells the first latch (LSB LATCH) of which stores the inverse logic value (1) up to make it surpass the third program voltage (VVFY3),
bd) as soon as the threshold voltage of each cell surpasses said second (VVFY2) or third program voltage (VVFY3), respectively, loading said inverse logic value (1) in the respective first latch (LSB LATCH) and in the second latch (MSB LATCH);
wherein step b1) is carried out through the following operations:
b1a) reading the array cells using a second read voltage (Vread1) smaller than said second program voltage (VVFY2) and loading in said second latches (MSB LATCH) the most significant bits that have been read,
b1b) reading the array cells using a first read voltage (Vread0) or a third read voltage (Vread2), that are smaller than said first program voltage (VVFY1) or said third program voltage (VVFY3), respectively, and loading in said first latches (LSB LATCH) the least significant bits that have been read,
b1c) testing the most significant bit programming by reading the array cells the second latch (MSB LATCH) of which stores said certain logic value (0) using a second test read voltage (VVFY2-Δ ) if the least significant latch (LSB LATCH) stores said certain logic value (0) or a third test read voltage (VVFY3-Δ ) if the least significant latch (LSB LATCH) stores said inverse logic value (1), smaller than or equal to said second program voltage (VVFY2) or third program voltage (VVFY3), respectively, and loading said inverse logic value (1) in the second latch (MSB LATCH) and in the first latch (LSB LATCH) if the read most significant bit equals said certain logic value (0);
wherein step b2) is carried out through the following operations:
b2a) applying program pulses in parallel to all the cells the second latch (MSB LATCH) of which and the first latch (LSB LATCH) of which store said inverse logic value (1),
b2b) as soon as the threshold voltage of each cell surpasses said second program voltage (VVFY2) or third program voltage (VVFY3), loading said inverse logic value (1) in the second latch (MSB LATCH) and in the first latch (LSB LATCH).
7. A page buffer for a four-level FLASH memory device including an array of singularly addressable preliminarily erased memory cells, each capable of storing a two-bit datum, said FLASH memory comprising a page buffer including at least a first latch (LSB LATCH) and a second latch (MSB LATCH) for each memory cell for temporarily storing the least significant bit and the most significant bit, respectively, characterized in that it comprises
an auxiliary latch (THIRD LATCH) for each memory cell;
controlled circuit means for coupling the auxiliary latch (THIRD LATCH) to said first latch (LSB LATCH) or to said second latch (MSB LATCH) for implementing the method of claim 4, respectively.
US11/460,835 2005-07-28 2006-07-28 Method of programming a four-level flash memory device and a related page buffer Abandoned US20070035995A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US12/551,383 US8553462B2 (en) 2005-07-28 2009-08-31 Method of programming a multi-level memory device
US14/046,297 US8971112B2 (en) 2005-07-28 2013-10-04 Method of programming a multi-level memory device

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
EP05106972.2 2005-07-28
EP20050106972 EP1748445B1 (en) 2005-07-28 2005-07-28 Page buffer for multi-level NAND programmable memories
EP06115106A EP1750278B1 (en) 2005-07-28 2006-06-07 Method of programming a four-level flash memory device and a related page buffer
EP06115106.4 2006-06-07

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US12/551,383 Division US8553462B2 (en) 2005-07-28 2009-08-31 Method of programming a multi-level memory device

Publications (1)

Publication Number Publication Date
US20070035995A1 true US20070035995A1 (en) 2007-02-15

Family

ID=37574991

Family Applications (3)

Application Number Title Priority Date Filing Date
US11/460,835 Abandoned US20070035995A1 (en) 2005-07-28 2006-07-28 Method of programming a four-level flash memory device and a related page buffer
US12/551,383 Active 2027-12-22 US8553462B2 (en) 2005-07-28 2009-08-31 Method of programming a multi-level memory device
US14/046,297 Active US8971112B2 (en) 2005-07-28 2013-10-04 Method of programming a multi-level memory device

Family Applications After (2)

Application Number Title Priority Date Filing Date
US12/551,383 Active 2027-12-22 US8553462B2 (en) 2005-07-28 2009-08-31 Method of programming a multi-level memory device
US14/046,297 Active US8971112B2 (en) 2005-07-28 2013-10-04 Method of programming a multi-level memory device

Country Status (2)

Country Link
US (3) US20070035995A1 (en)
EP (1) EP1750278B1 (en)

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080008008A1 (en) * 2006-07-06 2008-01-10 Elite Semiconductor Memory Technology Inc. Methods for programming and reading nand flash memory device and page buffer performing the same
US20080074928A1 (en) * 2006-09-22 2008-03-27 Choi Jin-Hyeok Nonvolatile memory system and associated programming methods
US20080175048A1 (en) * 2007-01-23 2008-07-24 Samsung Electronics Co., Ltd. Memory cell programming method and semiconductor memory device
US20090196111A1 (en) * 2006-09-29 2009-08-06 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
CN101930343A (en) * 2009-06-22 2010-12-29 三星电子株式会社 Data storage systems and methods using data attribute-based data transfer
US20100329014A1 (en) * 2009-06-29 2010-12-30 Kyu Hee Lim Semiconductor memory device and method of reading the same
US20110157999A1 (en) * 2009-12-31 2011-06-30 Hynix Semiconductor Inc. Method of operating semiconductor memory device
US20110182120A1 (en) * 2007-06-28 2011-07-28 Samsung Electronics Co., Ltd. Non-volatile memory devices and systems including multi-level cells using modified read voltages and methods of operating the same
US8681549B2 (en) * 2007-08-06 2014-03-25 Apple Inc. Programming schemes for multi-level analog memory cells
US8902651B2 (en) 2011-10-13 2014-12-02 Samsung Electronics Co., Ltd. Nonvolatile memory device, programming method of nonvolatile memory device and memory system including nonvolatile memory device
CN104424134A (en) * 2013-08-22 2015-03-18 旺宏电子股份有限公司 Memory device and manufacturing method
CN105103235A (en) * 2013-01-31 2015-11-25 惠普发展公司,有限责任合伙企业 Non-volatile multi-level-cell memory with decoupled bits for higher performance and energy efficiency
US10401938B1 (en) * 2017-04-10 2019-09-03 Apple Inc. Single power plane dynamic voltage margin recovery for multiple clock domains

Families Citing this family (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1750278B1 (en) * 2005-07-28 2009-11-11 STMicroelectronics S.r.l. Method of programming a four-level flash memory device and a related page buffer
KR102096285B1 (en) 2013-07-30 2020-04-02 삼성전자주식회사 Memory system and programming method thereof
KR102282196B1 (en) 2015-04-28 2021-07-27 삼성전자 주식회사 Non-volatile memory device, memory system and operating method thereof
US11086716B2 (en) 2019-07-24 2021-08-10 Microchip Technology Inc. Memory controller and method for decoding memory devices with early hard-decode exit
US11587919B2 (en) 2020-07-17 2023-02-21 Micron Technology, Inc. Microelectronic devices, related electronic systems, and methods of forming microelectronic devices
US11393845B2 (en) 2020-08-28 2022-07-19 Micron Technology, Inc. Microelectronic devices, and related memory devices and electronic systems
US11398291B2 (en) 2020-11-20 2022-07-26 Microchip Technology Inc. Method and apparatus for determining when actual wear of a flash memory device differs from reliability states for the flash memory device
US11514992B2 (en) 2021-02-25 2022-11-29 Microchip Technology Inc. Method and apparatus for reading a flash memory device
US11934696B2 (en) 2021-05-18 2024-03-19 Microchip Technology Inc. Machine learning assisted quality of service (QoS) for solid state drives
US11699493B2 (en) 2021-05-24 2023-07-11 Microchip Technology Inc. Method and apparatus for performing a read of a flash memory using predicted retention-and-read-disturb-compensated threshold voltage shift offset values
US11514994B1 (en) 2021-05-28 2022-11-29 Microchip Technology Inc. Method and apparatus for outlier management
CN117280328A (en) 2021-06-01 2023-12-22 微芯片技术股份有限公司 Memory address protection
US11562785B1 (en) 2021-08-30 2023-01-24 Micron Technology, Inc. Microelectronic devices, and related memory devices and electronic systems
DE112022002131T5 (en) 2021-09-28 2024-04-11 Microchip Technology Inc. LDPC DECODING WITH TRAPPED BLOCK MANAGEMENT

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5894436A (en) * 1996-10-29 1999-04-13 Nec Corporation Nonvolatile semiconductor memory having memory cells each storing multi-bits information
USRE37611E1 (en) * 1996-01-22 2002-03-26 Micron Technology, Inc. Non-volatile memory system having internal data verification test mode
US20020126531A1 (en) * 2000-03-08 2002-09-12 Koji Hosono Non-volatile semiconductor memory
US20040027901A1 (en) * 2002-06-18 2004-02-12 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device
US20040170062A1 (en) * 2002-12-05 2004-09-02 Stmicroelctronics S.R.L Method and device for programming an electrically programmable non-volatile semiconductor memory

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH1196774A (en) 1997-09-25 1999-04-09 Sharp Corp Data writing method for non-volatile semiconductor memory cell
JP4184586B2 (en) * 2000-09-28 2008-11-19 株式会社東芝 Semiconductor memory device
DE60139670D1 (en) 2001-04-10 2009-10-08 St Microelectronics Srl Method for programming non-volatile memory cells with programming and test algorithm using step-shaped voltage pulses with variable step spacing
US7042770B2 (en) 2001-07-23 2006-05-09 Samsung Electronics Co., Ltd. Memory devices with page buffer having dual registers and method of using the same
KR100496866B1 (en) * 2002-12-05 2005-06-22 삼성전자주식회사 Flash memory device having uniform threshold voltage distribution without under-programed or over-programed flash cells and program verify method thereof
JP3920768B2 (en) * 2002-12-26 2007-05-30 株式会社東芝 Nonvolatile semiconductor memory
KR100512181B1 (en) 2003-07-11 2005-09-05 삼성전자주식회사 Flash memory device having multi-level cell and method for its reading operation and program operation
US7242620B2 (en) * 2004-10-05 2007-07-10 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device and an operation method thereof
US7206230B2 (en) * 2005-04-01 2007-04-17 Sandisk Corporation Use of data latches in cache operations of non-volatile memories
EP1750278B1 (en) * 2005-07-28 2009-11-11 STMicroelectronics S.r.l. Method of programming a four-level flash memory device and a related page buffer

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USRE37611E1 (en) * 1996-01-22 2002-03-26 Micron Technology, Inc. Non-volatile memory system having internal data verification test mode
US5894436A (en) * 1996-10-29 1999-04-13 Nec Corporation Nonvolatile semiconductor memory having memory cells each storing multi-bits information
US20020126531A1 (en) * 2000-03-08 2002-09-12 Koji Hosono Non-volatile semiconductor memory
US20040027901A1 (en) * 2002-06-18 2004-02-12 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device
US20040170062A1 (en) * 2002-12-05 2004-09-02 Stmicroelctronics S.R.L Method and device for programming an electrically programmable non-volatile semiconductor memory

Cited By (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7359248B2 (en) * 2006-07-06 2008-04-15 Elite Semiconductor Memory Technology Inc Methods for programming and reading NAND flash memory device and page buffer performing the same
US20080008008A1 (en) * 2006-07-06 2008-01-10 Elite Semiconductor Memory Technology Inc. Methods for programming and reading nand flash memory device and page buffer performing the same
US7554859B2 (en) * 2006-09-22 2009-06-30 Samsung Electronics Co., Ltd. Nonvolatile memory system and associated programming methods
US20080074928A1 (en) * 2006-09-22 2008-03-27 Choi Jin-Hyeok Nonvolatile memory system and associated programming methods
US7852684B2 (en) 2006-09-29 2010-12-14 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
US20090196111A1 (en) * 2006-09-29 2009-08-06 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
US20090196099A1 (en) * 2006-09-29 2009-08-06 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
US20090207669A1 (en) * 2006-09-29 2009-08-20 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
US7668023B2 (en) * 2006-09-29 2010-02-23 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
US7848157B2 (en) 2006-09-29 2010-12-07 Hynix Semiconductor Inc. Page buffer circuit of memory device and program method
USRE45051E1 (en) 2006-09-29 2014-07-29 SK Hynix Inc. Page buffer circuit of memory device and program method
US7864571B2 (en) * 2007-01-23 2011-01-04 Samsung Electronics Co., Ltd. Memory cell programming method and semiconductor memory device
US20080175048A1 (en) * 2007-01-23 2008-07-24 Samsung Electronics Co., Ltd. Memory cell programming method and semiconductor memory device
US20110182120A1 (en) * 2007-06-28 2011-07-28 Samsung Electronics Co., Ltd. Non-volatile memory devices and systems including multi-level cells using modified read voltages and methods of operating the same
US8243514B2 (en) * 2007-06-28 2012-08-14 Samsung Electronics Co., Ltd. Non-volatile memory devices and systems including multi-level cells using modified read voltages and methods of operating the same
US10056135B2 (en) 2007-08-06 2018-08-21 Apple Inc. Programming schemes for multi-level analog memory cells
US8681549B2 (en) * 2007-08-06 2014-03-25 Apple Inc. Programming schemes for multi-level analog memory cells
US9449705B2 (en) 2007-08-06 2016-09-20 Apple Inc. Programming schemes for multi-level analog memory cells
CN101930343A (en) * 2009-06-22 2010-12-29 三星电子株式会社 Data storage systems and methods using data attribute-based data transfer
US20100329014A1 (en) * 2009-06-29 2010-12-30 Kyu Hee Lim Semiconductor memory device and method of reading the same
US8264883B2 (en) * 2009-06-29 2012-09-11 Hynix Semiconductor Inc. Semiconductor memory device and method of reading the same
US20110157999A1 (en) * 2009-12-31 2011-06-30 Hynix Semiconductor Inc. Method of operating semiconductor memory device
KR101829208B1 (en) 2009-12-31 2018-02-20 에스케이하이닉스 주식회사 Method of operating a semiconductor memory device
US8395944B2 (en) * 2009-12-31 2013-03-12 SK Hynix Inc. Method of operating semiconductor memory device
US9412456B2 (en) 2011-10-13 2016-08-09 Samsung Electronics Co., Ltd. Nonvolatile memory device, programming method of nonvolatile memory device and memory system including nonvolatile memory device
US8902651B2 (en) 2011-10-13 2014-12-02 Samsung Electronics Co., Ltd. Nonvolatile memory device, programming method of nonvolatile memory device and memory system including nonvolatile memory device
CN105103235A (en) * 2013-01-31 2015-11-25 惠普发展公司,有限责任合伙企业 Non-volatile multi-level-cell memory with decoupled bits for higher performance and energy efficiency
US20150364191A1 (en) * 2013-01-31 2015-12-17 Hewlett-Packard Development Company, L.P. Non-volatile multi-level-cell memory with decoupled bits for higher performance and energy efficiency
US9852792B2 (en) * 2013-01-31 2017-12-26 Hewlett Packard Enterprise Development Lp Non-volatile multi-level-cell memory with decoupled bits for higher performance and energy efficiency
CN104424134A (en) * 2013-08-22 2015-03-18 旺宏电子股份有限公司 Memory device and manufacturing method
US10401938B1 (en) * 2017-04-10 2019-09-03 Apple Inc. Single power plane dynamic voltage margin recovery for multiple clock domains

Also Published As

Publication number Publication date
US20140036588A1 (en) 2014-02-06
EP1750278A1 (en) 2007-02-07
US8553462B2 (en) 2013-10-08
US8971112B2 (en) 2015-03-03
US20090316482A1 (en) 2009-12-24
EP1750278B1 (en) 2009-11-11

Similar Documents

Publication Publication Date Title
EP1750278B1 (en) Method of programming a four-level flash memory device and a related page buffer
US7596022B2 (en) Method for programming a multi-level non-volatile memory device
US7508705B2 (en) Method for programming a multi-level non-volatile memory device
US7499332B2 (en) Circuit and method for electrically programming a non-volatile semiconductor memory via an additional programming pulse after verification
JP5266389B2 (en) Nonvolatile memory and method for ramp-down programming
KR100525004B1 (en) Multi-level cell flash memory device and program method thereof
JP3153730B2 (en) Nonvolatile semiconductor memory device
US8514629B2 (en) Method for memory cell erasure with a programming monitor of reference cells
US7382660B2 (en) Method for accessing a multilevel nonvolatile memory device of the flash NAND type
US5982663A (en) Nonvolatile semiconductor memory performing single bit and multi-bit operations
US7336532B2 (en) Method for reading NAND memory device and memory cell array thereof
US20030214853A1 (en) Non-volatile semiconductor memory device
US20080144370A1 (en) Method of programming multi-level cells and non-volatile memory device including the same
US7639529B2 (en) Non-volatile memory devices that utilize mirror-image programming techniques to inhibit program coupling noise and methods of programming same
US7773427B2 (en) Non-volatile memory device and method of operating
US7522452B2 (en) Non-volatile semiconductor storage device
US7724576B2 (en) Soft programming method of non-volatile memory device
US8880964B2 (en) Block and page level bad bit line and bits screening methods for program algorithm
US20050213388A1 (en) Semiconductor device and method for writing data into the semiconductor device
US20080298134A1 (en) Method of reading configuration data in flash memory device
US8750048B2 (en) Memory device and method for operating the same

Legal Events

Date Code Title Description
AS Assignment

Owner name: HYNIX SEMICONDUCTOR INC., KOREA, REPUBLIC OF

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CRIPPA, LUCA;MICHELONI, RINO;REEL/FRAME:018389/0233

Effective date: 20060919

Owner name: STMICROELECTRONICS S.R.L., ITALY

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CRIPPA, LUCA;MICHELONI, RINO;REEL/FRAME:018389/0233

Effective date: 20060919

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION