The subject matter relates generally to non-volatile memory devices, and more particularly, to reading and writing data in flash memory devices.
Non-volatile memory devices are becoming more and more popular in consumer electronics. An example of a non-volatile memory device is a flash memory device that stores information in a semiconductor device without the need for power to maintain the information.
There is a need for improved methods of reading and writing data in flash memory devices.
The embodiments described herein are merely illustrative. Therefore, the embodiments shown should not be considered as limiting of the claims.
According to various embodiments, the term pulse refers to the application of a selected voltage level to a terminal for a finite time period. Those skilled in the art will understand that a single pulse may be applied continuously for the finite time period, or may include a series of shorter discrete pulses applied in sequence and having a summed or total time period equal to the finite time period.
According to various embodiments, each transistor or floating gate transistor memory cell is described as being activated or switched on when it is rendered conductive by a voltage on its gate that exceeds its threshold voltage Vt, and the transistor or floating gate transistor memory cell is described as being in an inactive state or switched off when the voltage on its gate is below the threshold voltage Vt and the transistor or floating gate transistor memory cell is non-conductive.
According to various embodiments, a voltage is evaluated by comparing it with a reference voltage. According to various embodiments, a voltage is evaluated by coupling the voltage to an input of an inverter to compare the voltage with a threshold voltage of the inverter. The inverter may be in a latch circuit. A state of an output of the inverter may change depending on the voltage at its input and its threshold voltage.
All timing diagrams illustrated and described herein show voltages or signals v versus time t.
The controller 104 is a machine and may be a processor, a microprocessor, a state machine, or an application-specific integrated circuit that is a computer-readable medium, or is coupled to a computer-readable medium or a machine-accessible medium such as a memory, in a computer-based system to execute functions and methods according to various embodiments described herein. The memory may be the array 102 or may include electrical, optical, or electromagnetic elements. The computer-readable medium or a machine-accessible medium may contain associated information such as computer program instructions, data, or both which, when accessed, results in a machine performing the activities described herein.
Each flash memory cell 202 includes a source, a drain, a floating gate and a control gate. The flash memory cells 202 are coupled drain to source in each nandstring. The nandstring includes a source select transistor 204, an n-channel transistor coupled between a source of the first flash memory cell 202 and a ground voltage reference. At the other end of the nandstring, a drain select transistor 206 is an n-channel transistor coupled between a drain of the last flash memory cell 202 and the rest of the memory circuit 200. The drain select transistor 206 is coupled in series between the nandstring and a bit-line 208 with a bias transistor MO 210 and a load transistor 212. The bit-line 208 has a voltage BL and a capacitance CBL. The bias transistor 210 is an n-channel transistor having a source coupled to the drain select transistor 206 and a drain. The load transistor 212 is a p-channel transistor having a drain coupled to the drain of the bias transistor 210 and a source coupled to a voltage supply Vcc. A source select control signal SGS is coupled to a control gate of the source select transistor 204, and a drain select control signal SGD is coupled to a control gate of the drain select transistor 206. A control signal BLBIAS is coupled to a control gate of the bias transistor 210, and a control signal PLOAD is coupled to a control gate of the load transistor 212. The bias transistor 210 is one of multiple bias transistors 122 in the memory system 100 shown in
The bit-line 208 is coupled to the sense amplifier and latch 112 of the memory system 100 between the bias transistor 210 and the load transistor 212. The sense amplifier and latch 112 includes multiple latch transistors and inverters, one set of which is illustrated in
A second latch including a third inverter 240 and a fourth inverter 242 is coupled through the second latch transistor 222 to the data line 236. An input of the third inverter 240 and an output of the fourth inverter 242 are coupled to a source of the second latch transistor 222, and a drain of the second latch transistor 222 is coupled to the data line 236. An output of the third inverter 240 and an input of the fourth inverter 242 are coupled to a second data line 246 that is coupled to the controller 104 shown in
Each of the flash memory cells 202 is programmed according to various embodiments by coupling a program pulse to its gate to induce charge to be drawn to the floating gate to raise the threshold voltage Vt of the flash memory cell 202. Early in the programming, strong program pulses are applied to the gate resulting in a large change in the threshold voltage Vt. As the threshold voltage Vt of the flash memory cell 202 approaches a target, weaker program pulses are applied to the gate resulting in smaller changes in the threshold voltage Vt. After each program pulse, the threshold voltage Vt is verified twice before another program pulse is applied.
A selected flash memory cell 202 is read according to various embodiments by coupling a read voltage to its gate (WL0 to WL31), rendering the source select transistor 204 and the drain select transistor 206 conductive and switching on all the other floating gate cells 202 in the nandstring such that they are also conductive. The bias transistor 210 and the load transistor 212 are switched on such that the bit-line 208 is charged from the voltage Vcc. The load transistor 212 is then switched off and charge on the bit-line 208 will flow through the selected flash memory cell 202 if it is not programmed, such that the voltage BL on the bit-line 208 decreases once the load transistor 212 is switched off. However, if the selected flash memory cell has been programmed, then charge on the bit-line 208 will not be lost through the nandstring. The first and second latches including the inverters 230, 232, 240, and 242, and the first and second latch transistors 220 and 222 are capable of latching data from the bit-line 208 as will be described.
At time t1 in
At the end of the pulses 302, 304, the bias transistor 210 and the load transistor 212 are switched off, and the voltage BL on the bit-line 208 remains the same or falls depending on the state of the selected flash memory cell 202. If the threshold voltage Vt of the cell 202 is below a pre-program verify PPV level, the cell 202 will be rendered conductive and the bit-line 208 will discharge quickly. If the threshold voltage Vt of the cell 202 is above PPV and below PV, the cell 202 will be rendered conductive and the bit-line 208 will discharge at a more gradual slope. If the threshold voltage Vt of the cell 202 is above PV, the cell 202 will not be conductive and the bit-line 208 will hold its charge, remaining at a high voltage BL. The discharge of the bit-line 208 is influenced by its capacitance CBL.
The programming verify operation now proceeds to latch DATA0 and DATA1 across an interval to determine if the bit-line 208 is being discharged, and if so, what the rate of the discharge is. DATA1 is captured in the following manner. The signal BLBIAS rises to a voltage less than Vclamp for a short pulse 306 to switch on the bias transistor 210 to allow the voltage SEN to settle to the voltage BL of the bit-line 208. The voltage SEN is captured by the capacitance CSEN between the bias transistor 210 and the load transistor 212. The capacitance CSEN is much less than the capacitance CBL of the bit-line 208. The signals LAT1 and LAT2 go low for short pulses 308, 310 to switch off the inverters 230, 232, then the BLBIAS pulse 306 ends to switch off the bias transistor 210 and the first latch transistor 220 is switched on by a pulse 312 of the signal LATEN0 to allow the voltage SEN to transfer from the capacitance CSEN to the input of the inverter 230. The inverters 230, 232 are switched off to avoid disturbing the transfer and are switched on in sequence at the end of the pulses 308, 310 to latch DATA0. DATA0 is low if the threshold voltage Vt of the cell 202 is below PPV, and is high otherwise.
DATA0 is then transferred to DATA1 in the following manner. At the end of pulse 310 the inverter 232 is switched on and the signals LAT3 and LAT4 go low for short pulses 320, 322 to switch off the inverters 240, 242. The first latch transistor 220 is switched off at the end of the pulse 312 when DATA0 is latched, and the second latch transistor 222 is switched on by a pulse 324 of the signal LATEN1 to allow the inverted DATA0 to transfer from the output of the inverter 230 to the input of the inverter 240. The inverters 240, 242 are switched off to avoid disturbing the transfer, and are switched on in sequence at the end of the pulses 320, 322 to latch DATA1. DATA1 at the output of the inverter 240 is the same as the previously latched DATA0 at the input of the inverter 230. The second latch transistor 222 is switched off at the end of pulse 324 after DATA1 has been latched. DATA1 is low if the threshold voltage Vt of the cell 202 is below PPV, and DATA1 is high if the threshold voltage Vt of the cell 202 is above PPV.
At the end of pulse 312 when the first latch transistor 220 is switched off, the signal PLOAD goes low for a short pulse 330 to switch on the load transistor 212 to raise the SEN voltage between the load transistor 212 and the bias transistor 210. The capacitance CSEN rises to a high voltage during the pulse 330, but the bit-line 208 below the bias transistor 210 is unaffected and the voltage BL continues its trend.
At the end of the pulse 330, the signal BLBIAS rises to a voltage less than Vclamp for a short pulse 340 to switch on the bias transistor 210 to allow the voltage SEN to settle to the voltage BL of the bit-line 208. The signals LAT1 and LAT2 go low again for short pulses 340, 342 to switch off the inverters 230, 232, then the BLBIAS pulse 340 ends to switch off the bias transistor 210 and the first latch transistor 220 is switched on by a pulse 346 of the signal LATEN0 to allow the voltage SEN to transfer from the capacitance CSEN to the input of the inverter 230. The inverters 230, 232 are switched on in sequence at the end of the pulses 342, 344 to latch a new DATA0 that is possibly different from the first latched DATA0. The first latch transistor 220 is switched off at the end of pulse 346. DATA0 is low if the threshold voltage Vt of the cell 202 is below PV, and DATA0 is high if the threshold voltage Vt of the cell 202 is above PV.
In this manner the bit-line 208 is strobed twice to obtain two data points DATA0 and DATA1 separated by an interval while the same signal WL at the PV voltage is coupled to the gate of a selected flash memory cell 202 being programmed. According to various embodiments, the bit-line 208 is strobed three or more times to obtain three or more data points separated by intervals while the same signal WL at the PV voltage is coupled to the gate of a selected flash memory cell 202 being programmed.
The selected flash memory cell 202 may be read according to the timing diagram 300 according to various embodiments. The signal WL rises to a read voltage, and the bit-line 208 is strobed two or more times to obtain two or more data points representing two or more threshold voltages Vt of the cell 202 separated by intervals. The data points may be coupled directly to the data line 236 and the controller 104 shown in
At time t1 in
At the end of the pulses 502, 504, the bias transistor 210 and the load transistor 212 are switched off, and the voltage BL on the bit-line 208 remains the same or falls depending on the state of the selected flash memory cell 202. If the threshold voltage Vt of the cell 202 is far below the read voltage, the cell 202 will be rendered conductive and the bit-line 208 will discharge quickly. If the threshold voltage Vt of the cell 202 is just below the read level, the cell 202 will be rendered conductive and the bit-line 208 will discharge at a more gradual slope. If the threshold voltage Vt of the cell 202 is above the read voltage, the cell 202 will not be conductive and the bit-line 208 will hold its charge, remaining at a high voltage BL.
The signal BLBIAS rises to a voltage less than Vclamp for a short pulse 506 to switch on the bias transistor 210 to allow the voltage SEN to settle to the voltage BL of the bit-line 208. However, data is not latched during or after the pulse 506, but the pulse 506 is applied to mirror the pulse 306 described with respect to the programming verify operation illustrated in
Following the pulse 506, the signal PLOAD goes low for a short pulse 507 to switch on the load transistor 212 to raise the SEN voltage between the load transistor 212 and the bias transistor 210. The capacitance CSEN rises to a high voltage during the pulse 507, but the bit-line 208 below the bias transistor 210 is unaffected and the voltage BL continues its trend.
The read operation now proceeds to latch DATA0 to determine a state of the selected flash memory cell 202. The signal BLBIAS rises to a voltage less than Vclamp for a short pulse 508 to switch on the bias transistor 210 to allow the voltage SEN to settle to the voltage BL of the bit-line 208. The voltage SEN is captured by the capacitance CSEN between the bias transistor 210 and the load transistor 212. The signals LAT1 and LAT2 go low for short pulses 518, 520 to switch off the inverters 230, 232, then the BLBIAS pulse 508 ends to switch off the bias transistor 210 and the first latch transistor 220 is switched on by a pulse 522 of the signal LATEN0 to allow the voltage SEN to transfer from the capacitance CSEN to the input of the inverter 230. The inverters 230, 232 are switched off to avoid disturbing the transfer, and are switched on in sequence at the end of the pulses 518, 520 to latch DATA0. DATA0 is low if the threshold voltage Vt of the selected flash memory cell 202 is below the read voltage, and is high if the threshold voltage Vt of the selected flash memory cell 202 is above the read voltage. The signal LATEN1 is not active during the read operation because only one data value is latched.
As the signals begin in the timing diagram 700, the signal BLBIAS rises to a voltage Vclamp and the signal PLOAD goes low for significant pulses 702 and 704 to switch on the load transistor 212 and the bias transistor 210, respectively. The bit-line 208 is then coupled to the supply voltage Vcc through the load transistor 212 and the voltage BL on the bit-line 208 rises as the bit-line is charged to a voltage Vclamp less the threshold voltage Vt of the bias transistor 210. A read voltage (not shown) is coupled to a gate of a selected flash memory cell 202.
At the end of the pulses 702, 704 the bias transistor 210 and the load transistor 212 are switched off, and the voltage BL on the bit-line 208 remains the same or falls depending on the state of the selected flash memory cell 202. If the threshold voltage Vt of the cell 202 is below the read voltage, the cell 202 will be rendered conductive and the bit-line 208 will discharge. If the threshold voltage Vt of the cell 202 is above the read voltage, the cell 202 will not be conductive and the bit-line 208 will hold its charge, remaining at a high voltage BL.
Thereafter, the signal EQ goes high for a short pulse 730 to switch on the equalization transistor 602 to permit charge transfer between the input and the output of the inverter 230 to reduce a potential difference between them and remove data latched by the inverters 230, 232 to initialize the latch. At the same time the signals LAT1 and LAT2 are brought low for a longer pulse 728 to switch off the inverters 230 and 232.
Following the pulse 730 when the latch is initialized and the equalization transistor 602 is switched off, the signal BLBIAS rises to a voltage less than Vclamp for a short pulse 740 to switch on the bias transistor 210 to allow the voltage SEN to settle to the voltage BL of the bit-line 208. The voltage SEN is captured by the capacitance CSEN between the bias transistor 210 and the load transistor 212. At the same time the first latch transistor 220 is switched on by a pulse 750 of the signal LATEN0 to allow the voltage SEN to transfer from the capacitance CSEN to the input of the inverter 230. As a result, the bit-line 208 is coupled to the capacitance CSEN and to the input of the inverter 230 as the voltage BL is developing on the bit-line 208 and possibly discharging if the selected flash memory cell 202 is rendered conductive. The signal DATA0 is coupled directly from the voltage BL on the bit-line 208 during the pulses 728, 740, and 750.
The BLBIAS pulse 740, the LATEN0 pulse 750, and the LAT1/LAT2 pulse 728 all end at the same time to switch off the bias transistor 210 and the first latch transistor 220 and switch on the inverters 230, 232 to latch DATA0. DATA0 is low if the threshold voltage Vt of the selected flash memory cell 202 is below the read voltage and is high if the threshold voltage Vt of the selected flash memory cell 202 is above the read voltage. The signal DATA0B is the signal DATA0 inverted.
In 820, a flash memory cell is programmed.
In 830, a word-line voltage is applied to the flash memory cell.
In 840, a bit-line coupled to the flash memory cell is coupled to a sense capacitance at a first time to generate first data.
In 850, the bit-line is coupled to the sense capacitance at a second time to generate second data.
In 860, the first data is stored in a latch circuit.
In 870, the second data is stored in a latch circuit
In 880, the flash memory cell is read by applying pulses having the same duration and occurring at the same intervals, respectively, as pulses applied to verify a programming of the flash memory cell such that a bit-line coupled to the flash memory cell is coupled to a sense capacitance during the same intervals when the programming of the flash memory cell is being verified and when the flash cell is being read. In 890, the methods end.
In 920, a latch in a cache memory of a NAND flash memory is switched off.
In 930, the latch is initialized while the latch is switched off.
In 940, a read voltage is coupled to a gate of a selected flash memory cell in the NAND flash memory, the selected flash memory cell being coupled to a bit-line.
In 950, the bit-line is coupled to an input of the latch while a voltage on the bit-line is changing due to the read voltage coupled to the selected flash memory cell and the latch is switched off.
In 960, the latch is switched on to latch data based on the voltage on the bit-line. In 970, the methods end.
The central processor 1010 is a machine and may be a processor, a microprocessor, a state machine, or an application-specific integrated circuit that is a computer-readable medium, or is coupled to a computer-readable medium or a machine-accessible medium such as a memory, in a computer-based system to execute functions and methods according to various embodiments described herein. The memory may be the non-volatile memory 1020 or may include electrical, optical, or electromagnetic elements. The computer-readable medium or a machine-accessible medium may contain associated information such as computer program instructions, data, or both which, when accessed, results in a machine performing the activities described herein.
The machine 1000 is a wireless computing platform according to various embodiments. The machine 1000 may interact with one or more networks such as a WAN (Wireless Area Network), a WLAN (Wireless Local Area Network), and a WPAN (Wireless Personal Area Network). The machine 1000 may be hand-held or larger. The antenna 1040 may comprise a monopole, a dipole, a unidirectional antenna, an omnidirectional antenna, or a patch antenna, among others. A wireless computing platform may be any device capable of conducting wireless communication (e.g., infra-red, radio frequency, etc.) and executing a series of programmed instructions (e.g., a personal digital assistant, a laptop, a cellular telephone, etc.).
The various embodiments illustrated and described herein may be implemented in a NAND flash memory device or other types of memory devices. The various embodiments illustrated and described herein may be implemented with floating gate transistor memory cells that have one of two threshold voltages Vt, or with multi-state floating gate transistor memory cells holding one of four or more threshold voltages Vt.
Although specific embodiments have been illustrated and described herein, it should be appreciated that any arrangement calculated to achieve the same purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all adaptations or variations of various embodiments. It is to be understood that the above description has been made in an illustrative fashion, and not a restrictive one. Combinations of the above embodiments, and other embodiments not specifically described herein will be apparent to those of skill in the art upon reviewing the above description. Thus, the scope of various embodiments includes any other applications in which the above compositions, structures, and methods are used.
It is emphasized that the Abstract of the Disclosure is provided to comply with 37 C.F.R. § 1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate preferred embodiment. In the appended claims, the terms “including” and “in which” may be used as the plain-English equivalents of the respective terms “comprising” and “wherein,” respectively. Moreover, the terms “first,” “second,” and “third,” etc. are used merely as labels, and are not intended to impose numerical requirements on their objects.