CN111009278B - Apparatus and method for determining data state of memory cell - Google Patents
Apparatus and method for determining data state of memory cell Download PDFInfo
- Publication number
- CN111009278B CN111009278B CN201910920281.5A CN201910920281A CN111009278B CN 111009278 B CN111009278 B CN 111009278B CN 201910920281 A CN201910920281 A CN 201910920281A CN 111009278 B CN111009278 B CN 111009278B
- Authority
- CN
- China
- Prior art keywords
- data
- state
- voltage level
- memory cells
- lines
- 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.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 67
- 241000287219 Serinus canaria Species 0.000 claims description 92
- 230000004044 response Effects 0.000 claims description 27
- 230000008859 change Effects 0.000 claims description 12
- 230000003247 decreasing effect Effects 0.000 claims description 7
- 238000010586 diagram Methods 0.000 description 20
- 238000004891 communication Methods 0.000 description 12
- 239000004065 semiconductor Substances 0.000 description 12
- 238000009826 distribution Methods 0.000 description 7
- 230000009471 action Effects 0.000 description 5
- 230000005669 field effect Effects 0.000 description 5
- 238000007667 floating Methods 0.000 description 5
- 230000004913 activation Effects 0.000 description 3
- 238000013500 data storage Methods 0.000 description 3
- 230000009849 deactivation Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 230000008569 process Effects 0.000 description 3
- 230000003213 activating effect Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 2
- 230000007423 decrease Effects 0.000 description 2
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical compound [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 1
- 230000006978 adaptation Effects 0.000 description 1
- 230000001174 ascending effect Effects 0.000 description 1
- 239000004020 conductor Substances 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 239000012212 insulator Substances 0.000 description 1
- 238000012804 iterative process Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 230000010287 polarization Effects 0.000 description 1
- 239000002243 precursor Substances 0.000 description 1
- 230000000630 rising effect Effects 0.000 description 1
- 229910052594 sapphire Inorganic materials 0.000 description 1
- 239000010980 sapphire Substances 0.000 description 1
- 229910052710 silicon Inorganic materials 0.000 description 1
- 239000010703 silicon Substances 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 239000010409 thin film Substances 0.000 description 1
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/34—Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
- G11C16/3418—Disturbance prevention or evaluation; Refreshing of disturbed memory data
- G11C16/3431—Circuits or methods to detect disturbed nonvolatile memory cells, e.g. which still read as programmed but with threshold less than the program verify threshold or read as erased but with threshold greater than the erase verify threshold, and to reverse the disturbance via a refreshing programming or erasing step
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/26—Sensing or reading circuits; Data output circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/34—Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C11/00—Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
- G11C11/56—Digital 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/5621—Digital 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/5642—Sensing or reading circuits; Data output circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C11/00—Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
- G11C11/56—Digital 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/5671—Digital 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 trapping in an insulator
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/08—Address circuits; Decoders; Word-line control circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/34—Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
- G11C16/3404—Convergence or correction of memory cell threshold voltages; Repair or recovery of overerased or overprogrammed cells
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/04—Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS
- G11C16/0483—Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS comprising cells having several storage transistors connected in series
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/32—Timing circuits
Landscapes
- Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Read Only Memory (AREA)
Abstract
The present invention relates to an apparatus and method for determining a data state of a memory cell. The method of operating a memory may include: sensing a state of each of the plurality of data lines while increasing a voltage level applied to each of a plurality of access lines commonly connected to the plurality of series-connected memory cell strings; determining a particular voltage level that has changed the state of each data line of a first subset of the plurality of data lines; reducing a voltage level applied to a particular access line of the plurality of access lines; and sensing a state of each data line of the second subset of the plurality of data lines while applying the particular voltage level to the particular access line.
Description
Technical Field
The present disclosure relates generally to memory, and in particular, in one or more embodiments, the present disclosure relates to apparatus and methods for determining a data state of a memory cell.
Background
Memory, such as memory devices, is typically provided as an internal semiconductor integrated circuit device in a computer or other electronic device. There are many different types of memory including Random Access Memory (RAM), read Only Memory (ROM), dynamic Random Access Memory (DRAM), synchronous Dynamic Random Access Memory (SDRAM), and flash memory.
Flash memory has evolved into a popular source of non-volatile memory for a wide range of electronic applications. Flash memory typically uses single transistor memory cells that allow for high memory density, high reliability, and low power consumption. The change in threshold voltage (Vt) of the memory cells determines the data state (e.g., data value) of each memory cell by programming (which is commonly referred to as writing) of a charge storage structure (e.g., a floating gate or charge trap) or other physical phenomenon (e.g., phase change or polarization). Common uses of flash memory and other non-volatile memory include: personal computers, personal Digital Assistants (PDAs), digital cameras, digital media players, digital recorders, games, appliances, vehicles, wireless devices, mobile telephones and removable memory modules, and the use of nonvolatile memory continues to expand.
NAND flash memory is a common type of flash memory device, and thus requires a logical form in which basic memory cell configurations are arranged. Typically, an array of memory cells of a NAND flash memory is arranged such that the control gates of each memory cell of a row of the array are connected together to form an access line, such as a word line. The columns of the array include strings of memory cells (commonly referred to as NAND strings) connected together in series between a pair of select gates, e.g., source select transistors and drain select transistors. Each source select transistor may be connected to a source, while each drain select transistor may be connected to a data line, such as a column bit line. Variations are known that use more than one select gate between a string of memory cells and the source and/or between the string of memory cells and the data line.
In programming a memory, the memory cells may be programmed as memory cells commonly referred to as single-level cells (SLC). SLC may use a single memory cell to represent one digit (e.g., one bit) of data. For example, in an SLC, a Vt of 2.5V or higher may indicate a programmed memory cell (e.g., representing a logic 0) while a Vt of-0.5V or lower may indicate an erased memory cell (e.g., representing a logic 1). Such a memory may achieve a higher level of storage capacity by including multi-level cells (MLC), tri-level cells (TLC), quad-level cells (QLC), etc., or a combination thereof, where the memory cells have multiple levels that enable more data digits to be stored in each memory cell. For example, an MLC may be configured to store two data digits per memory cell represented by four Vt ranges, a TLC may be configured to store three data digits per memory cell represented by eight Vt ranges, a QLC may be configured to store four data digits per memory cell represented by sixteen Vt ranges, and so on.
Sensing (e.g., reading or verifying) a data state of a memory cell typically involves detecting whether the memory cell is activated in response to a particular voltage applied to its control gate, for example, by detecting whether a data line connected to the memory cell experiences a voltage level change resulting from current flow through the memory cell. As memory operations progress to represent additional data states per memory cell, the margin between adjacent Vt ranges may become smaller. If the Vt of the sensed memory cell shifts over time, this may result in inaccurate determination of the data state of the sensed memory cell.
Disclosure of Invention
Aspects of the invention relate to a method of operating a memory, comprising: sensing a state of each of the plurality of data lines while increasing a voltage level applied to each of a plurality of access lines commonly connected to the plurality of series-connected memory cell strings; determining a particular voltage level that has changed the state of each data line of a first subset of the plurality of data lines; reducing a voltage level applied to a particular access line of the plurality of access lines; and sensing a state of each data line of the second subset of the plurality of data lines while applying the particular voltage level to the particular access line.
In another aspect of the invention, a method of operating a memory includes: for each data state of a plurality of data states, sensing a state of each canary data line of a respective subset of the plurality of canary data lines of the data state while increasing a voltage level applied to each access line of a plurality of access lines commonly connected to a plurality of series-connected strings of memory cells; for each data state of the plurality of data states, determining a respective voltage level of the data state that has changed the state of each canary data line of a respective subset of the plurality of canary data lines; reducing a voltage level applied to a particular access line of the plurality of access lines; and sensing a state of each of a plurality of primary data lines while applying the respective voltage level of a particular data state of the plurality of data states to the particular access line.
In another aspect of the invention, a method of operating a memory includes: determining a plurality of read voltages for a read operation during a precharge phase of the read operation; determining a pass voltage for the read operation during the precharge phase of the read operation; applying the pass voltage to each unselected access line of a plurality of access lines; and for each read voltage of the plurality of read voltages, applying the read voltage to a selected access line of the plurality of access lines and sensing a data state of a memory cell connected to the selected access line.
In yet another aspect of the present invention, a method of operating a memory includes: sensing a state of each of a plurality of data lines while increasing a voltage level applied to each of a plurality of access lines commonly connected to a plurality of series connected memory cell strings, wherein each series connected memory cell string corresponds to a respective data line of the plurality of data lines; determining a particular voltage level that has changed the state of each data line of a first subset of the plurality of data lines, wherein each corresponding series connected string of memory cells of each data line of the first subset of the plurality of data lines is programmed to contain a data pattern representing a particular data state of a plurality of data states; reducing the voltage level applied to a particular access line of the plurality of access lines without reducing the voltage level applied to each remaining access line of the plurality of access lines; sensing a state of each data line of a second subset of the plurality of data lines while applying the particular voltage level to the particular access line; and for each data line of the second subset of the plurality of data lines, if the data line first changes state in response to applying the particular voltage level to the particular access line after decreasing the voltage level applied to the particular access line, treating memory cells of the corresponding series-connected string of memory cells of the data line as programmed to the particular data state.
In yet another aspect of the present invention, a method of operating a memory includes: for each data state of a plurality of data states, sensing a state of each canary data line of a respective subset of the plurality of canary data lines of the data state while increasing a voltage level applied to each access line of a plurality of access lines commonly connected to a plurality of series-connected strings of memory cells; sensing a state of each of a plurality of primary data lines while increasing the voltage level applied to each of the plurality of access lines; for each data state of the plurality of data states, determining a respective voltage level of the data state that has changed the state of each canary data line of a respective subset of the plurality of canary data lines; determining a particular voltage level that has changed the state of each of the plurality of canary data lines and each of the plurality of primary data lines; reducing a voltage level applied to a particular access line of the plurality of access lines while applying the particular voltage level to each remaining access line of the plurality of access lines; for each data state of the plurality of data states, sensing a state of each primary data line of the plurality of primary data lines while applying the respective voltage level of the data state to the particular access line; and for each memory cell of the plurality of series connected strings of memory cells connected to the particular access line: if a corresponding one of the plurality of primary data lines for the memory cell first changes state in response to the respective voltage level applying a particular one of the plurality of data states after reducing the voltage level applied to the particular access line, determining that the data state programmed into the memory cell is the particular data state; and determining that the data state programmed into the memory cell is a higher data state than any of the plurality of data states if the corresponding primary data line for the memory cell does not change state in response to the respective voltage level applying any of the plurality of data states after reducing the voltage level applied to the particular access line.
In yet another aspect of the present invention, a memory includes: a memory cell array; and a controller for access of the array of memory cells, wherein the controller is configured to cause the memory to perform the above method.
Drawings
FIG. 1 is a simplified block diagram of a memory in communication with a processor that is part of an electronic system, according to an embodiment.
Fig. 2A-2C are schematic diagrams of portions of a memory cell array as may be used in a memory of the type depicted with reference to fig. 1.
FIG. 3 is a schematic block diagram of a portion of a memory cell array as may be used in a memory of the type depicted with reference to FIG. 1.
FIG. 4 is a conceptual depiction of threshold voltage distributions for multiple memory cells.
FIG. 5 is a depiction of incremental voltage levels for use with various embodiments.
FIG. 6 is a block diagram of a voltage generation system for generating incremental voltage levels of the type depicted in FIG. 5 for use with various embodiments.
FIG. 7 is a schematic block diagram depicting the connection of data lines with a sensing device and a page buffer for use with various embodiments.
FIG. 8 depicts a timing diagram of a method of operating a memory according to an embodiment.
FIG. 9 is a conceptual depiction of threshold voltage distributions of multiple memory cells according to an embodiment.
10A-10B are schematic block diagrams of decoding circuitry for use in determining read voltages using more than one canary NAND string for corresponding data states, according to an embodiment.
FIG. 11 is a schematic block diagram of a register set according to an embodiment.
Fig. 12 is a block diagram of a data line according to an embodiment.
Fig. 13 is a flow chart of a method of operating a memory according to an embodiment.
Fig. 14 is a flow chart of a method of operating a memory according to another embodiment.
FIG. 15 is a flow chart of a method of operating a memory according to additional embodiments.
Fig. 16 is a flow chart of a method of operating a memory according to yet additional embodiments.
Fig. 17 is a flow chart of a method of operating a memory according to yet additional embodiments.
Detailed Description
In the following detailed description, reference is made to the accompanying drawings which form a part hereof, and in which is shown by way of illustration specific embodiments. In the drawings, like reference numerals describe substantially similar components throughout the several views. Other embodiments may be utilized and structural, logical, and electrical changes may be made without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense.
The term "semiconductor" as used herein may refer to, for example, a layer of material, a wafer, or a substrate, and includes any base semiconductor structure. "semiconductor" should be understood to include silicon-on-sapphire (SOS) technology, silicon-on-insulator (SOI) technology, thin Film Transistor (TFT) technology, doped and undoped semiconductors, epitaxial layers of silicon supported by a base semiconductor structure, as well as other semiconductor structures well known to one skilled in the art. Furthermore, when referring to semiconductors in the following description, previous process steps may have been utilized to form regions/junctions in the base semiconductor structure, and the term semiconductor may include underlying layers that contain such regions/junctions. The term conductive (as used herein, and various forms thereof (e.g., conduct, conductively, conducting, conduction, conductivity, etc.) refers to conductive unless the context indicates otherwise. Similarly, the term connection (e.g., connect, connected, connection, etc.) as used herein and in various related forms thereof refers to electrical connection unless the context indicates otherwise.
Fig. 1 is a simplified block diagram of a first device (in the form of a memory (e.g., memory means) 100) in communication with a second device (in the form of a processor 130) as part of a third device (in the form of an electronic system) according to an embodiment. Some examples of electronic systems include personal computers, personal Digital Assistants (PDAs), digital cameras, digital media players, digital recorders, games, appliances, vehicles, wireless devices, mobile telephones and the like. Processor 130 (e.g., a controller external to memory device 100) may be a memory controller or other external host device.
The memory device 100 includes an array of memory cells 104 logically arranged in rows and columns. The memory cells of a logical row are typically connected to the same access line (collectively referred to as word lines), while the memory cells of a logical column are typically selectively connected to the same data line (collectively referred to as bit lines). A single access line may be associated with more than one logical row of memory cells and a single data line may be associated with more than one logical column. The memory cells (not shown in fig. 1) of at least a portion of the memory cell array 104 are capable of being programmed to one of at least two data states.
The row decode circuitry 108 and column decode circuitry 110 are provided to decode address signals. Address signals are received and decoded to access the memory cell array 104. Memory device 100 also includes input/output (I/O) control circuitry 112 to manage the input of commands, addresses, and data to memory device 100, and the output of data and status information from memory device 100. The address register 114 communicates with the I/O control circuitry 112 and the row decode circuitry 108 and the column decode circuitry 110 to latch address signals prior to decoding. The command register 124 communicates with the I/O control circuitry 112 and the control logic 116 to latch incoming commands. Register set 128 may be in communication with control logic 116. Register set 128 may represent volatile memory, latches, or other storage locations. For some embodiments, register set 128 may represent a portion of memory cell array 104. According to an embodiment, register set 128 may store information about the threshold voltages (e.g., highest threshold voltages) of the memory cell groupings. The control logic 116 may be configured to perform a method of operating a memory according to an embodiment.
A controller, such as control logic 116 internal to memory device 100, controls access to memory cell array 104 and generates state information for external processor 130 in response to commands, i.e., control logic 116 is configured to perform access operations (e.g., read operations, program operations, and/or erase operations) on memory cell array 104. Control logic 116 communicates with row decode circuitry 108 and column decode circuitry 110 to control row decode circuitry 108 and column decode circuitry 110 in response to addresses.
The control logic 116 also communicates with a cache register 118. The cache register 118 latches incoming or outgoing data as directed by the control logic 116 to temporarily store data while the memory cell array 104 is busy writing or reading, respectively, other data. During a programming operation (e.g., a write operation), data may be transferred from the cache register 118 to the data register 120 for transfer to the memory cell array 104; new data from the I/O control circuitry 112 may then be locked in the cache register 118. During a read operation, data may be passed from the cache register 118 to the I/O control circuitry 112 for output to the external processor 130; new data may then be transferred from the data register 120 to the cache register 118. The cache registers 118 and/or the data registers 120 may form (e.g., may form part of) a page buffer of the memory device 100. The page buffer may further include a sensing device (not shown in fig. 1) to sense a data state of the memory cells of the memory cell array 104, for example, by sensing a state of data lines connected to the memory cells. Status register 122 may be in communication with I/O control circuitry 112 and control logic 116 to latch status information for output to processor 130.
Memory device 100 receives control signals from processor 130 at control logic 116 via control link 132. The control signals may include chip enable CE#, command latch enable CLE, address latch enable ALE, write enable WE#, read enable RE#, and write protect WP#. Additional or alternative control signals (not shown) may be further received via control link 132, depending on the nature of memory device 100. The memory device 100 receives command signals (which represent commands), address signals (which represent addresses), and data signals (which represent data) from the processor 130 via a multiplexed input/output (I/O) bus 134 and outputs data to the processor 130 via the I/O bus 134.
For example, a command may be received at I/O control circuitry 112 via I/O pins [7:0] of input/output (I/O) bus 134 and may then be written into command register 124. Addresses may be received at I/O control circuitry 112 via I/O pins [7:0] of an input/output (I/O) bus 134 and may then be written into address registers 114. Data may be received at I/O control circuitry 112 via input/output (I/O) pins [7:0] of an 8-bit device or input/output (I/O) pins [15:0] of a 16-bit device and then may be written into cache register 118. The data may then be written into the data register 120 for programming the memory cell array 104. For another embodiment, the cache register 118 may be omitted and the data may be written directly into the data register 120. Data may also be output via input/output (I/O) pins of an 8-bit device [7:0] or input/output (I/O) pins of a 16-bit device [15:0 ].
Those skilled in the art will appreciate that additional circuitry and signals may be provided and that the memory device 100 of fig. 1 has been simplified. It should be recognized that the functionality of the various block components described with reference to fig. 1 may not necessarily need to be separated into different components or component portions of the integrated circuit device. For example, a single component or component portion of an integrated circuit device may be adapted to perform the functionality of more than one block component of fig. 1. Alternatively, one or more components or component parts of the integrated circuit device may be combined to perform the functionality of a single block component of fig. 1.
In addition, while particular I/O pins are described in accordance with popular conventions for receipt and output of the various signals, it is noted that other combinations or numbers of I/O pins (or other I/O node structures) may be used in the various embodiments.
Fig. 2A is a schematic diagram of a portion of a memory cell array 200A (e.g., a NAND memory array) as may be used in a memory of the type described with reference to fig. 1 (e.g., as part of memory cell array 104). The memory array 200A includes access lines (e.g., word lines 202) 0 To 202 N ) Data lines (e.g., bit line 204) 0 To 204 M ). Word line 202 may be connected to a global access line (e.g., global word line) in a many-to-one relationship, not shown in fig. 2A. For some embodiments, the memory array 200A may be formed, for example, may be conductively blended to have, for example, p-type conductivity Over a semiconductor of conductivity type that is electrically (e.g., to form a p-well) or n-type conductivity (e.g., to form an n-well).
The memory array 200A may be arranged in rows (each corresponding to a word line 202) and columns (each corresponding to a bit line 204). Each column may include a string of series-connected memory cells (e.g., non-volatile memory cells), such as NAND string 206 0 To 206 M One of them. Each NAND string 206 can be connected (e.g., selectively connected) to a common Source (SRC) 216 and can include memory cells 208 0 To 208 N . Memory unit 208 may represent a non-volatile memory unit used to store data. The memory cells 208 of each NAND string 206 can be connected in series, such as with a select gate 210 0 To 210 M Select gate 210 (e.g., field effect transistor) and, for example, select gate 212, which may be one of source select transistors, collectively referred to as select gate sources 0 To 212 M Between select gates 212 (e.g., field effect transistors), which may be, for example, one of the drain select transistors, collectively referred to as select gate drains. Select gate 210 0 To 210 M May be commonly connected to a select line 214, such as a source select line (SGS), and select gate 212 0 To 212 M May be commonly connected to a select line 215, such as a drain select line (SGD). Although depicted as conventional field effect transistors, select gates 210 and 212 may utilize a structure similar to (e.g., identical to) memory cell 208. Select gates 210 and 212 may represent multiple select gates connected in series, with each select gate in the series configured to receive the same or independent control signals.
The source of each select gate 210 may be connected to a common source 216. The drain of each select gate 210 may be connected to the memory cell 208 of the corresponding NAND string 206 0 . For example, select gate 210 0 May be connected to a corresponding NAND string 206 0 Is a memory cell 208 of (1) 0 . Thus, each select gate 210 may be configured to selectively connect a corresponding NAND string 206 to the common source 216. The control gate of each select gate 210 may be connected to a select line 214.
The drain of each select gate 212 may be connected toAnd bit line 204 corresponding to NAND string 206. For example, select gate 212 0 May be connected to the drain for the corresponding NAND string 206 0 Bit line 204 of (2) 0 . The source of each select gate 212 may be connected to the memory cell 208 of the corresponding NAND string 206 N . For example, select gate 212 0 May be connected to a corresponding NAND string 206 0 Is a memory cell 208 of (1) N . Thus, each select gate 212 may be configured to selectively connect a corresponding NAND string 206 to a corresponding bit line 204. The control gate of each select gate 212 may be connected to a select line 215.
The memory array in FIG. 2A may be a quasi-two-dimensional memory array and may have a generally planar structure, for example, with the common source 216, NAND strings 206, and bit lines 204 extending in substantially parallel planes. Alternatively, the memory array in FIG. 2A may be a three-dimensional memory array, for example, in which NAND strings 206 may extend substantially perpendicular to the plane containing common source 216 and perpendicular to the plane containing bit lines 204 (which may be substantially parallel to the plane containing common source 216).
A typical construction of memory cell 208 includes a data storage structure 234 (e.g., a floating gate, charge trap, etc.) and a control gate 236 that can determine the data state of the memory cell (e.g., by a change in threshold voltage), as shown in fig. 2A. Data storage structure 234 may include both conductive structures and dielectric structures, while control gate 236 is typically formed of one or more conductive materials. In some cases, the memory cell 208 may further have a defined source/drain (e.g., source) 230 and a defined source/drain (e.g., drain) 232. The memory cell 208 has its control gate 236 connected to (and in some cases formed by) the word line 202.
A column of memory cells 208 may be a NAND string 206 or multiple NAND strings 206 selectively connected to a given bit line 204. A row of memory cells 208 may be memory cells 208 that are commonly connected to a given word line 202. A row of memory cells 208 may, but need not, include all memory cells 208 commonly connected to a given word line 202. The row of memory cells 208 may generally be divided into one or more groups of physical pages of memory cells 208, and the objects of memory cells 208A page is typically comprised of every other memory cell 208 commonly connected to a given word line 202. For example, commonly connected to word line 202 N And selectively connected to even bit lines 204 (e.g., bit lines 204 0 、204 2 、204 4 Etc.) may be one physical page of memory cells 208 (e.g., even memory cells) that are commonly connected to word line 202 N And is selectively connected to odd bit lines 204 (e.g., bit lines 204 1 、204 3 、204 5 Etc.) may be another physical page of memory cells 208 (e.g., odd memory cells). Although bit line 204 is not explicitly depicted in FIG. 2A 3 To 204 5 It is illustrated that the bit lines 204 of the memory cell array 200A may be formed from the bit lines 204 0 To bit line 204 M Numbered consecutively. Other groupings of memory cells 208 commonly connected to a given word line 202 may also define physical pages of memory cells 208. For a particular memory device, all memory cells commonly connected to a given word line can be considered a physical page of memory cells. Memory cells that are read during a single read operation or programmed during a single program operation (in some embodiments or lower page) may be considered in memory, which may still be part of a physical page of an entire row (e.g., a logical page of upper page cells of memory cells). A block of memory cells may include those memory cells configured to be jointly erased, e.g., connected to word line 202 0 To 202 N For example, all NAND strings 206 sharing a common word line 202). Unless explicitly distinguished, references herein to a page of memory cells refer to memory cells of a logical page of memory cells.
Although the example of fig. 2A is discussed in connection with NAND flash, the embodiments AND concepts described herein are not limited to a particular array architecture or structure, AND may include other structures (e.g., SONOS, phase change, ferroelectric, etc.) AND other architectures (e.g., AND arrays, NOR arrays, etc.).
Figure 2B is a portion of a memory cell array 200B as may be used in a memory of the type described with reference to figure 1 (e.g.,as part of the memory cell array 104). Like numbered elements in fig. 2B correspond to the description as provided with respect to fig. 2A. FIG. 2B provides additional detail of one example of a three-dimensional NAND memory array structure. The three-dimensional NAND memory array 200B may incorporate vertical structures that may include semiconductor pillars, wherein a portion of the pillars may be used as channel regions for memory cells of the NAND strings 206. The NAND strings 206 may each be selectively connected to the bit line 204 by a select transistor 212 (which may be a drain select transistor, collectively referred to as a select gate drain, for example) 0 To 204 M And is selectively connected to a common source 216 through a select transistor 210 (which may be a source select transistor, for example, commonly referred to as a select gate source). Multiple NAND strings 206 may be selectively connected to the same bit line 204. A subset of NAND strings 206 can be formed by selecting lines 215 0 To 215 K Biased to selectively activate a particular select transistor 212, each located between a NAND string 206 and a bit line 204, to connect to its respective bit line 204. The select transistor 210 may be activated by biasing the select line 214. Each word line 202 may be connected to multiple rows of memory cells of the memory array 200B. Rows of memory cells commonly connected to each other by a particular word line 202 may be collectively referred to as a layer.
Fig. 2C is an additional schematic diagram of a portion of a memory cell array 200C (e.g., as part of memory cell array 104) as may be used in a memory of the type described with reference to fig. 1. Like numbered elements in fig. 2C correspond to the description as provided with respect to fig. 2A. The memory cell array 200C may include a series connection of a string of memory cells (e.g., a NAND string) 206, an access (e.g., word) line 202, a data (e.g., bit) line 204, a select line 214 (e.g., a source select line), a select line 215 (e.g., a drain select line), and a source 216 as depicted in fig. 2A. For example, a portion of memory cell array 200A may be a portion of memory cell array 200C. FIG. 2C depicts NAND strings 206 grouped into blocks 250 of memory cells. Memory cell block 250 may be a grouping of memory cells 208 that may be erased together in a single erase operation, sometimes referred to as an erase block. Each block 250 of memory cells may represent a common and single selection Line 215 (e.g., select line 215) 0 ) Those NAND strings 206 associated therewith. For memory cell block 250 0 May be used with the memory cell block 250 L Is the same source as source 216. For example, each memory cell block 250 0 To 250 L May be generally selectively connected to source 216. The access line 202 and the select lines 214 and 215 of one memory cell block 250 may not have a common voltage to the memory cell block 250, respectively 0 To 250 L The access line 202 and the select lines 214 and 215 of any other block of memory cells.
Data line 204 0 To 204 M May be connected (e.g., selectively connected) to the buffer portion 240, the buffer portion 240 may be part of a page buffer of a memory. Buffer portion 240 may correspond to a memory plane (e.g., memory cell block 250 0 To 250 L A collection). The buffer portion 240 may include sensing devices (not shown) for sensing data values indicated on the respective data lines 204 and corresponding registers (not shown) for storing sensed data values from their corresponding memory planes.
FIG. 3 is a schematic block diagram of a portion of a memory cell array as may be used in a memory of the type described with reference to FIG. 1. The memory cell array 300 is depicted as having four memory planes 350 (e.g., memory planes 350 0 To 350 3 ) Each memory plane is in communication with a respective buffer portion 240 that may collectively form a page buffer 352. Although four memory planes 350 are depicted, other numbers of memory planes 350 may also be in common communication with the page buffer 352. Each memory plane 350 is depicted as including l+1 blocks of memory cells 250 (e.g., blocks of memory cells 250 0 To 250 L )。
FIG. 4 is a conceptual depiction of threshold voltage ranges for a plurality of memory cells. Fig. 4 illustrates an example of a threshold voltage range and its distribution for a population of sixteen-level memory cells (commonly referred to as QLC memory cells). For example, such a memory cell may be programmed to belong to sixteen different threshold voltage ranges 430 0 To 430 15 Each threshold voltage range is used to represent a data state corresponding to a bit pattern of four bits. Threshold voltage range 430 0 Typically having a specific remaining threshold voltage range 430 1 To 430 15 Large width because the memory cells are generally all placed in the and threshold voltage range 430 0 In the corresponding data state, a subset of the memory cells are then subsequently programmed to have a voltage within threshold voltage range 430 1 To 430 15 A threshold voltage in one of the (c). Since the programming operation is generally more controlled than the erase operation, these threshold voltage ranges 430 1 To 430 15 May tend to have a tighter distribution.
Threshold voltage range 430 0 、430 1 、430 2 、430 3 、430 4 、430 5 、430 6 、430 7 、430 8 、430 9 、430 10 、430 11 、430 12 、430 13 、430 14 430, respectively 15 May each represent a respective data state, e.g., L0, L1, L2, L3, L4, L5, L6, L7, L8, L9, L10, L11, L12, L13, L14, and L15, respectively. As an example, if the threshold voltage of the memory cell is in the first one of sixteen threshold voltage ranges 430 0 Within, then in this case the memory cell may store a data state L0 having a data value of logic '1111' and is commonly referred to as the erased state of the memory cell. A second threshold voltage range 430 if the threshold voltage is in sixteen threshold voltage ranges 1 In this case, then, the memory cell may store data state L1 with the data value of logic '0111'. A third threshold voltage range 430 if the threshold voltage is in sixteen threshold voltage ranges 2 In which case the memory cell may store data state L2 with the data value of logic '0011', and so on. Table 1 provides one possible correspondence between data states and their corresponding logical data values. Other assignments of data states to logical data values are known. As used herein, remain in the lowest data state (e.g., via An erased state or an L0 data state) will be considered to be programmed to the lowest data state.
TABLE 1
Data state | Logical data value |
L0 | 1111 |
L1 | 0111 |
L2 | 0011 |
L3 | 1011 |
L4 | 1001 |
L5 | 0001 |
L6 | 0101 |
L7 | 1101 |
L8 | 1100 |
L9 | 0100 |
L10 | 0000 |
L11 | 1000 |
L12 | 1010 |
L13 | 0010 |
L14 | 0110 |
L15 | 1110 |
Fig. 5 is a depiction of incremental voltage levels 540 for use with various embodiments. Various embodiments may use incremental voltage levels applied to access lines (e.g., each access line) during a precharge phase of a read operation, and may use incremental voltage levels applied to selected access lines during a sense phase of a read operation. Incrementing the voltage level 540 may be responsive to the count. For example, as the value of the count increases, the voltage level of the incremental voltage level 540 may increase in response. Incrementing the voltage level 540 may approximate or more closely approximate a linear response by increasing the number of counts used to produce the same range of voltage levels.
FIG. 6 is a block diagram of a voltage generation system for generating incremental voltage levels of the type depicted in FIG. 5 for use with various embodiments. The voltage generation system of fig. 6 includes a counter 642 for generating a count. As an example, counter 642 may have an output 644 for providing a bit pattern representing the count. The counter 642 may be configured to receive the enable signal 641 to selectively enable or disable the counter, e.g., to keep the counter 642 up to date. The counter 642 may be further configured to receive a reset signal 643 to reset its counted value to an initial value, e.g., zero.
A voltage generation circuit 646, such as a digital-to-analog converter (DAC), may generate an analog voltage level in response to an output 644 of the counter 642, such as in response to a count. DAC 646 may provide this voltage level at output 648. The output 648 of the DAC 646 may be connected (e.g., selectively connected) to an access line (e.g., one or more access lines) of the memory cell array. For example, the output 648 of the DAC 646 may be selectively connected to the word line 202 of FIGS. 2A-2C. The output 644 of the counter 642 may also be connected (e.g., selectively connected) to a page buffer of memory, such as a portion of the data register 120 of FIG. 1. Multiple voltage generation systems may be used to provide differential voltage levels to different access lines.
FIG. 7 is a schematic block diagram depicting the connection of data lines to a sensing device and page buffer for use with various embodiments. In FIG. 7, NAND string 206 is selectively connected to data line 204 by select gate 212 and to source 216 by select gate 210. NAND string 206 can have the same structure as described with reference to FIG. 2A, with N+1 memory cells 208 0 To 208 N . In reading the memory cell 208 0 To 208 N With the data state of one of the select gates 210 and 212 activated, a read voltage may be applied to an access line (e.g., a selected access line) connected to a memory cell (e.g., a target memory cell) selected for a read operation, and a pass voltage may be applied to an access line (e.g., a non-selected access line) connected to each of the remaining memory cells of the NAND string 206. For example, if memory cell 208 1 Selected for a read operation, then it may receive a read voltage at its control gate, where the read voltage is configured to activate the memory cell 208 if its data state corresponds to a threshold voltage that is lower than or equal to the read voltage 1 And in the data state and threshold voltage pair higher than the read voltageIf appropriate, the memory cell 208 1 Deactivation. Each remaining memory cell 208 (e.g., memory cell 208 0 208 2 To 208 N ) A pass voltage may be received at its control gate, where the pass voltage is configured to activate each of the remaining memory cells 208 regardless of its data state.
The state of the data line 204 may indicate the target memory cell 208 1 In the activated or deactivated state, as current between the data line 204 and the source 216 may be enabled or disabled, respectively. This property may then be sensed by sensing device 760 connected to data line 204 using a differential amplifier or the like, such as by measurement of the current or resulting voltage level or comparison of the current or resulting voltage level to some threshold, for example. The output of the sensing device 760 may be used to set one or more registers of the page buffer 352. For example, the first register 762 may be a memory device having an indication of the target memory cell 208 1 A single-word (e.g., unit) register of a first value (e.g., a first logic level) that is deactivated, for example, in response to: indicating the sensing of the inhibited sensing device 760 of the current between the data line 204 and the source 216. The register 762 may further have an instruction to target memory unit 208 1 A second value (e.g., a second logic level different from the first logic level) that is activated, for example, in response to: indicating the sensing of the current enabled sensing device 760 between the data line 204 and the source 216. The page buffer 352 may further include a second register 764, which may be a multi-digital (e.g., multi-bit) register. In response to sensing of sensing device 760 indicating that current between data line 204 and source 216 is enabled, page buffer 352 may be configured (e.g., in response to toggling the value of first register 762 to its second value) to latch a representation of the count of output 644 from counter 642 into register 764. In this way, the register 764 may contain the target memory cell 208 1 For example, a representation of a voltage level that changes the state of the data line 204.
As the size of memory cells decreases, their associated data storage structures generally become smaller. In addition, as more levels of data states are stored to the memory cells, the distinction between data states may become more difficult. Furthermore, the threshold voltage of the memory cell may shift due to read disturb and/or other phenomena, such as rapid charge loss (QCL). In a read disturbance, the threshold voltage of a memory cell may be shifted in response to a voltage applied to the memory cell to facilitate access to a target memory cell selected for reading (e.g., increasing the threshold voltage of the memory cell). QCL is the capture of electrons near the gate dielectric interface to the channel region of the memory cell and can result in an intermediate Vt shift after a programming pulse. When a memory cell passes a verify operation, the programmed threshold voltage may appear to be higher due to trapped charge in the gate dielectric. When a memory cell is read after a program operation has been completed, the memory cell may have a Vt that is lower than the Vt obtained during a program verify operation due to charge in the gate dielectric leaking to the channel region. Various embodiments provide apparatus and methods that may help alleviate these problems.
FIG. 8 depicts a timing diagram of a method of operating a memory according to an embodiment. For example, the timing diagram of FIG. 8 may represent a read operation of a memory. The trace 840 may represent a voltage level applied to an access line connected to a memory cell selected for a read operation (e.g., a target memory cell). The following discussion will proceed with at least reference to FIG. 2A and will speculate that the memory cells selected for the read operation are NAND string 206 0 Is a memory cell 208 of (1) x So that trace 840 may represent an application to access line 202 x Is set in the above-described voltage level. Access line 202 x May be referred to as a selected access line because it contains the target memory cell, while the remaining access lines 202 may be referred to as unselected access lines. NAND string 206 0 A string of selected series connected memory cells may be referred to as containing the target memory cell. Trace 842 may represent a signal applied to a non-selected access line 202 (e.g., access line 202) 0 To 202 x-1 202, respectively x+1 To 202 N ) Is set in the above-described voltage level. Trace 844 may represent the voltage applied to select line 214And the voltage level applied to select line 215.
At time t0, a precharge phase may begin. The precharge phase of the read operation brings the unselected access lines 202 to a voltage level, e.g., pass voltage, sufficient to activate their respective connected memory cells regardless of their data states. As shown in the example of fig. 8, the voltage level of all access lines 202 of a block of memory cells containing a target memory cell (e.g., one or more target memory cells) is initially brought up to a voltage level 852. The voltage level 852 may be sufficient to activate each memory cell connected to one of the access lines 202 regardless of its data state. As one example, the voltage level 852 may be approximately 8V. Putting all access lines 202 together in this manner may help to increase the speed at which the steady state of any access line 202 is reached, the desired voltage level of the access line 202 being voltage level 852. Select line 214 and select line 215 may be brought up to a voltage level 854 sufficient to activate their respective select gates.
When the access line 202 (e.g., traces 840 and 842) increases to the voltage level 852, the data line 204 (e.g., data line 204) may be performed according to an embodiment and as described in more detail with reference to the figures 0 To 204 M Some subset or all of) the initial sensing of the sensor. By connecting one or more of the NAND strings 206 (e.g., NAND string 206) 0 To 206 M ) Programmed to contain a predetermined data pattern, the read voltage and pass voltage for performing a read operation on a block of memory cells containing the target memory cell may be determined.
For a predetermined data pattern, consider an example of programming memory cell 208 to one of sixteen data states (e.g., data states L0-L15). One or more NAND strings 206 0 To 206 M May be programmed such that each of the memory cells 208 of the NAND string 206 has an L0 data state. One or more NAND strings 206 0 To 206 M May be programmed such that each of the memory cells 208 of a NAND string 206 has an L1 data state, or at least one of the memory cells 208 of the NAND string 206 has an L1 data state, and any remaining memory cells 208 of the NAND string 206 have a number below L1A data state according to the state, for example, a data state corresponding to a threshold voltage range lower than that of the L1 data state. One or more NAND strings 206 0 To 206 M Each of the memory cells 208 of a NAND string 206 may be programmed such that it has an L2 data state, or at least one of the memory cells 208 of the NAND string 206 has an L2 data state, and any remaining memory cells 208 of the NAND string 206 have a data state that is lower than the L2 data state, e.g., a data state corresponding to a threshold voltage range that is lower than the threshold voltage range of the L2 data state. This may be repeated such that at least one NAND string 206 is programmed in this manner for each of the possible data states (e.g., all data states to which memory is configured for programming any memory cell of a block of memory cells). NAND strings programmed in this manner may be referred to as canary NAND strings or canary series connected strings of memory cells in that they can provide information about any shifts in the threshold voltage distribution of memory cells storing user data and/or overhead data.
For some embodiments, a NAND string 206 can be programmed such that one or more of its memory cells 208 are programmed to the corresponding data state of the NAND string 206, and any remaining memory cells 208 of the NAND string 206 can have an erased data state, e.g., an L0 data state. For example, a block of memory cells is typically programmed in a particular order of its page of memory cells. In the event that less than all of its pages of memory cells are programmed, the remaining pages of memory cells can remain in the erased data state. The data pattern of memory cells 208 programmed to a NAND string 206 will be referred to as a data pattern representing a particular data state, where at least one of the memory cells 208 of the NAND string 206 has a particular data state and any remaining memory cells 208 of the NAND string 206 have a data state that is less than or equal to the particular data state.
For some embodiments, a number of NAND strings 206 (e.g., eight NAND strings 206) corresponding to bytes of a page buffer are programmed such that each memory cell 208 of the NAND strings 206 is programmed to have a corresponding data state, e.g., eight NAND strings 206 are programmed such that each of their memory cells 208 has an L0 data state, eight NAND strings 206 are programmed such that each of their memory cells 208 has an L1 data state, eight NAND strings 206 are programmed such that each of their memory cells 208 has an L2 data state, eight NAND strings 206 are programmed such that each of their memory cells 208 has an L3 data state, and so on.
In response to the rising voltage level applied to each of the access lines 202 between times t0 and t1, the NAND string 206 can begin to enable current flow between the data line 204 and the source 216. Since each NAND string 206 containing one of the predetermined data patterns begins to pass current, a determination may be made as to the particular voltage level causing conduction of the entire NAND string 206 when its respective sensing device indicates activation of each of its memory cells 208. For a given data state of memory cell 208, the voltage level at which conduction occurs may provide information about the expected read voltage to be used when sensing that data state during a read operation. In a similar manner, the voltage level at which conduction occurs for each data line 204 associated with a read operation may provide information about the expected pass voltage that will be used to read the memory cells 208 of the memory cell block during the read operation. As an example, the incremental voltage levels applied to the access lines 202 (e.g., traces 840 and 842) may continue until conduction is sensed in each data line 204 associated with a read operation, and the voltage level 852 may be equal to or higher than the voltage level when such conduction is sensed.
At or around time t1, the selected access line 202 may be selected x Discharge to voltage level 848. The voltage level 848 may represent a read voltage intended to distinguish between possible data states of the target memory cell. For example, if voltage level 848 is being applied to access line 202 x And thus to the control gate of the target memory cell, it may be considered to have a data state corresponding to a threshold voltage range that is less than or equal to voltage level 848. If voltage level 848 is being applied to access line 202 x Is to store the target at the same timeThe memory cell is deactivated, then it may be considered to have a data state corresponding to a threshold voltage range above voltage level 848. The sensing operation may be performed while the voltage level 848 is applied, as is well understood in the art. As one example, the voltage level 848 may correspond to a voltage level applied to the access line 202 at a time at which it is determined that one or more NAND strings 206 having memory cells 208 (e.g., each of their memory cells) programmed to a particular data state (e.g., an L0 data state or a lowest data state) are all activated.
When the voltage level 848 is applied to the selected access line 202 at time t2 x When a voltage level 852 is applied to the unselected access lines 202 0 To 202 x-1 202, respectively x+1 To 202 N . The voltage level 852 is sufficient to activate memory cells connected to these non-selected access lines regardless of their data states. In addition, when the voltage level 848 is applied to the selected access line 202 at time t2 x When applied, the voltage level 854 may be applied to the select line 214 and to the select line 215. The voltage level 854 is sufficient to activate select gates connected to the select lines. In this way, if the target memory cell is activated, current can be established through the NAND string 206, thus permitting sensing of its data state. As one example, the voltage level 854 may be approximately 5V.
At time t3, the voltage level of the other traces 842 and 844 may be maintained while being applied to the selected access line 202 x Is increased to voltage level 850. The voltage level 850 may represent different read voltages intended to distinguish between different possible data states of a target memory cell. The sensing operation may be performed while the voltage level 850 is applied, as is well understood in the art. As one example, the voltage level 850 may correspond to a voltage level applied to the access line 202 at a time when it is determined that one or more NAND strings 206 having memory cells 208 (e.g., each or some subset of their memory cells) programmed to a next higher data state (e.g., an L1 data state) are all activated. Although only two read voltages are depicted in fig. 8, other numbers of read voltages may be used. Generally come from In other words, Y read voltages can be used to distinguish each of the Y+1 possible data states. At time t4, all lines may be discharged to a voltage level 846, which may be a reference potential (e.g., ground or 0V). For each read voltage of a read operation, the period between times t2 and t4 may correspond to a sense phase of the read operation when the data state of one or more target memory cells is sensed.
FIG. 9 is a conceptual depiction of threshold voltage distributions of multiple memory cells according to an embodiment. Fig. 9 will be used to provide additional detail regarding the process between times t0 and t1 in fig. 8. Consider an example in which at least one canary NAND string 206 is programmed with memory cells 208 having respective data states for each of the possible data states. Threshold voltage range 930 0 、930 1 、930 2 、930 3 、930 4 、930 5 、930 6 、930 7 、930 8 、930 9 、930 10 、930 11 、930 12 、930 13 、930 14 930, respectively 15 May each represent a threshold voltage distribution of memory cells of one or more NAND strings respectively programmed to corresponding respective data states (e.g., L0, L1, L2, L3, L4, L5, L6, L7, L8, L9, L10, L11, L12, L13, L14, and L15).
When the voltage level applied to access line 202 (e.g., traces 840 and 842) increases to voltage level 852 between times t0 and t1 of FIG. 8, canary NAND string 206 corresponding to data state L0 may reach voltage level 932 at the voltage level 0 When all enabled for current between the data line 204 and the source 216, the canary NAND string 206 corresponding to data state L1 may reach voltage level 932 at a voltage level 1 When all enabled for current between the data line 204 and the source 216, the canary NAND string 206 corresponding to data state L2 may reach voltage level 932 at a voltage level 2 All enabled for current between the data line 204 and the source 216, and so on, wherein each of the data states L0-L15 corresponds to a respective voltage level 932 0 To 932 to 15 . Voltage level 932 0 To 932 to 14 The read voltages, which can then be used to distinguish each of the respective data states to complete the read operation. Note that although voltage level 932 15 Useful information may be provided, such as it may be used to determine a desired pass voltage (e.g., voltage level 852) or to provide an indication of similarity between the performance of the memory cells of the canary NAND string and the remaining NAND strings, but it will generally not be necessary to determine each of the data states, and may be below voltage level 852.
While having only one canary NAND string 206 having memory cells 208 (e.g., each or some subset of their memory cells 208) programmed to each respective data state may provide information sufficient to determine the expected read voltage for that data state, improvements may be facilitated by utilizing more than one canary NAND string 206 for each of the data states.
10A-10B are schematic block diagrams of decoding circuitry for determining read voltages when using more than one canary NAND string 206 for corresponding data states, according to an embodiment. The decoding circuit 1000A of FIG. 10A includes a logic circuit 1060 Z Such as NAND gates. Logic circuit 1060 Z There may be multiple inputs, each input with a respective register 762 (e.g., register 762) of a page buffer (e.g., page buffer 352 of FIG. 3) Z0 To 762 of ZR One of which) communicates (e.g., is connected to receive) the value. The value of Z may be any integer value from 0 to Y, where Y+1 represents the number of predetermined target data states of memory cells selectively connected to the register 762 (e.g., any memory cells selectively connected to the data line 204, the data line 204 selectively connected to the register 762). There may be a decoding circuit 1000A for each data state Z from 0 to Y. For example, data state 0 may correspond to data state L0, data state 1 may correspond to data state L1, and so on. The value of R may be any integer value greater than or equal to 1, where R+1 represents the number of NAND strings 206 corresponding to data state Z, e.g., each NAND string programs at least one memory cell 208 to data state Z and programs each remaining memory cell 208 to a data state lower than data state Z. For example, where eight canary NAND strings 206 are used for data state Z, R may be equal to 7.
Logic circuit 1060 Z AND register 762 Z0 To 762 of ZR The NAND string 206 and data line 204 corresponding to either one of remain inhibited from conducting, have a first logic level (e.g., logic high), and may be in communication with all of the registers 762 Z0 To 762 of ZR The corresponding NAND string 206 and data line 204, when enabled to conduct, have a second logic level (e.g., a logic low level) different from the first logic level. Register 1064 Z AND logic circuit 1060 Z Is in communication with (e.g., connected to receive) the value and is in communication with (e.g., connected to receive) a representation of the count of the output 644 from the counter 642. Register 1064 Z May be part of the register set 128 of fig. 1. Register 1064 Z May be further configured to be responsive to logic circuit 1060 Z To latch a representation of the count of output 644 from counter 642 into register 1064 Z Is a kind of medium. For example, when logic 1060 Z Register 1064 toggles from its first logic level to its second logic level Z A representation of the count may be latched.
Decoding circuit 1000B of FIG. 10B provides logic circuit 1060 Z Schematic of one embodiment of (a). Logic circuit 1060 of decoding circuit 1000B Z A transistor (e.g., a p-type field effect transistor or pFET) 1068 may be included having a first source/drain (e.g., drain) connected to a first voltage node 1066. The first voltage node 1066 may be configured to receive a supply voltage, e.g., vcc. pFET 1068 may further enable AND register 1064 Z A second source/drain (e.g., source) in communication, e.g., connected to logic circuit 1060 Z Is provided. Logic circuit 1060 Z Multiple inputs thereof may each be connected to a respective transistor (e.g., an n-type field effect transistor or nFET) 1072 (e.g., nFET 1072 0 To 1072 R ) Is provided. nFET 1072 0 To 1072 R A second source/drain connectable in series with pFET 1068 and a second voltage node 1074. The second voltage node 1074 may be configured to receive a reference potential, such as ground or 0V.
Fig. 11 is a schematic block diagram of a register set 128 according to an embodiment. Register set 128 may have a number of registers 1064 (e.g., registers 1064 0 To 1064 Y ). Each register 1064 of register set 128 may correspond to a respective data state of the y+1 predetermined target data states, and may each be configured to latch a representation of the voltage level of each canary NAND string indicative of current of its corresponding respective data state. Register 1064 0 An indication of the read voltage that may be used to differentiate between data states L0 and L1 (or higher) may be stored, register 1064 1 An indication of the read voltage that can be used to differentiate between data states L1 and L2 (or higher) can be stored, register 1064 2 An indication of the read voltage that can be used to differentiate between data states L2 and L3 (or higher) can be stored, register 1064 3 An indication of the read voltage that can be used to distinguish between data states L3 and L4 (or higher) can be stored, and so on. For some embodiments, register 1064 may be eliminated Y 。
Register set 128 may further include registers 1066. Register 1066 may be configured to latch a representation of the voltage level of each NAND string indicative of the current of the read operation, e.g., each NAND string connected to a data line connected to a sensing device participating in the read operation. Decoding when each NAND string of a read operation indicates current may be performed in a similar manner as described with respect to canary NAND strings. For example, a logic circuit (e.g., logic circuit 1060) may be configured to have a plurality of inputs, each input in communication with (e.g., connected to receive) a value of a respective register 762 involved in a read operation, e.g., register 762 corresponds to canary NAND string 206 and register 762 corresponds to NAND string 206 containing a target memory cell for the read operation. Alternatively, the logic circuit may have inputs for less than all registers 762 that are involved in the read operation, e.g., it may have inputs only for those registers 762 that correspond to NAND strings 206 that contain the target memory cells for the read operation. The logic circuit may have a first logic level (e.g., a logic high level) when the NAND strings 206 and data lines 204 corresponding to any of its input registers 762 remain inhibited from conducting, and may have a second logic level (e.g., a logic low level) different from the first logic level when the NAND strings 206 and data lines 204 corresponding to all of their input registers 762 are enabled to conduct. Register 1066 may be in communication with (e.g., connected to receive) a value of an output of the logic circuit and with (e.g., connected to receive) a representation of a count of output 644 from counter 642. The register 1066 may be further configured to latch a representation of the count of the output 644 from the counter 642 into the register 1066 in response to a logic level of the output of its logic circuit. Register 1066 may store an indication of the pass voltage that may be used to activate each memory cell regardless of its data state.
Fig. 12 is a block diagram of data lines of a memory cell array according to an embodiment. Various embodiments may store a predetermined data pattern to memory cells associated with a portion of a data line connected to a page buffer. The predetermined data patterns may represent each of the data states that may be assigned to the memory cells. These memory cells may be expected to experience the same or similar threshold voltage shift levels as memory cells associated with the remainder of the data lines connected to the page buffer. For one embodiment, the memory cell array may include a first portion 1290 of data lines selectively connected to memory cells configured to store a predetermined data pattern 0 Which may be referred to as a canary data line, e.g., canary bit line 1204 0 To 1204 C . The array of memory cells may further include a second portion 1290 of data lines selectively connected to memory cells configured to store user data and/or overhead data (e.g., ECC data and/or metadata) 1 Which may be referred to as a primary data line, e.g., primary bit line 2204 0 To 2204 P 。
As one example, a first portion 1290 of a data line 0 256 canary data lines 1204 may be included, for example, where C equals 255. For every other period during a read operation One embodiment where the data lines are connected to a sensing device, 128 canary data lines 1204 may be sensed, for example, while increasing the voltage level applied to the access lines during a precharge phase of a read operation. For embodiments in which each data line is connected to a sensing device during a read operation, C may be equal to 127 to utilize 128 canary data lines 1204 during a read operation. For an example of sixteen possible data states, eight of these canary data lines 1204 may be selectively connected to NAND strings in corresponding memory cells of one or more blocks of memory cells that store a data pattern representing an L0 data state, eight canary data lines may be selectively connected to NAND strings in corresponding memory cells of one or more blocks of memory cells that store a data pattern representing an L1 data state, and so on. The use of the canary data line 1204 in this manner may help determine the appropriate read voltage and pass voltage for determining the data state of the memory cells of the logical page of memory cells selected for a read operation.
While fig. 12 depicts canary data lines 1204 and main data lines 2204 for user data and/or overhead data as being in respective consecutive groupings, other arrangements may also be used. For example, canary data line 1204 may be interleaved with main data line 2204. Similarly, multiple canary data lines 1204 corresponding to one data state may be in consecutive packets, or they may be interleaved among canary data lines 1204 corresponding to other data states. The predetermined data pattern of the canary data lines 1204 may be programmed to the corresponding memory cells of each block of memory cells of its memory plane.
Fig. 13 is a flow chart of a method of operating a memory according to an embodiment. For example, the method of FIG. 13 may be part of a read operation.
At 1301, a state of each of a plurality of data lines is sensed while increasing a voltage level applied to each of a plurality of access lines commonly connected to a plurality of series connected memory cell strings. This may include increasing the voltage level applied to all access lines commonly connected to the plurality of series connected strings of memory cells, e.g., such that the control gates of each of these series connected strings of memory cells receive an increasing voltage level. For example, incremental voltage levels such as described with reference to fig. 5-6 may be applied to each of the access lines.
The plurality of data lines may be each data line selectively connected to a block (or blocks) of memory cells of a memory plane. Alternatively, the plurality of data lines may be less than all data lines selectively connected to the memory cell block. For example, where a read operation only seeks to sense a data state of memory cells connected to every other data line selectively connected to a block of memory cells, the plurality of data lines may be every other (e.g., even or odd) data line selectively connected to the block of memory cells. Likewise, the plurality of series connected memory cell strings may be each series connected memory cell string of the selected memory cell block, or less than all series connected memory cell strings of the selected memory cell block, e.g., every other (e.g., even or odd) series connected memory cell string of the selected memory cell block.
Each series-connected string of memory cells of the plurality of series-connected strings of memory cells may correspond to a respective data line of the plurality of data lines, for example, in a one-to-one relationship. When sensing the state of each data line of the plurality of data lines, a select gate (e.g., drain select gate and/or source select gate) corresponding to each series connected memory cell string of the plurality of series connected memory cell strings may be activated.
At 1303, a particular voltage level that has changed the state of each data line of the first subset of the plurality of data lines is determined. For example, the initial state of the data line may be floating, e.g., isolated from the source by its deactivated memory cells corresponding to the series-connected string of memory cells, and it may be pre-charged to a particular voltage level, e.g., vcc. When the incremental voltage level applied to the plurality of access lines reaches a voltage level sufficient to activate each memory cell of the corresponding series connected string of memory cells, the state of the data line may change to conductive, e.g., to connect to the source through its corresponding series connected string of memory cells. The first subset of the plurality of data lines may contain one or more data lines of the plurality of data lines.
At 1305, the voltage level applied to a particular access line of the plurality of access lines is reduced, for example, after determining the particular voltage level. For some embodiments, reducing the voltage level applied to a particular access line may occur after determining the voltage level that has changed the state of each data line of the plurality of data lines. This may occur after activating each memory cell of each series connected string of memory cells of the plurality of series connected strings of memory cells.
For other embodiments, reducing the voltage level applied to a particular access line may further occur after determining the voltage level that has changed the state of each data line of a different subset of the plurality of data lines that contains the first subset of the plurality of data lines. For example, a first subset of the plurality of data lines may correspond to series-connected strings of memory cells, each series-connected string of memory cells programmed to contain a data pattern representing a particular data state of a plurality of data states (e.g., a plurality of predetermined target data states). In this example, a different subset of the plurality of data lines may further include data lines of the plurality of data lines corresponding to series-connected strings of memory cells, each series-connected string of memory cells programmed to contain a data pattern representing other (e.g., higher) data states of the plurality of data states.
The particular access line may be an access line selected for a read operation (e.g., a control gate connected to a target memory cell whose data state is to be sensed during the read operation). For some embodiments, the voltage level applied to a particular access line may be reduced to a particular voltage level. For other embodiments, the voltage level applied to a particular access line may be reduced to a voltage level that is lower than a bit voltage level. The voltage level applied to a particular access line may be reduced without reducing the voltage level applied to each remaining access line of the plurality of access lines (e.g., while maintaining or increasing the voltage level).
At 1307, the state of each data line of the second subset of the plurality of data lines is sensed while a particular voltage level is applied to a particular access line. Sensing the state of each data line of the second subset of the plurality of data lines may include determining whether each data line of the second subset of the plurality of data lines is connected to or isolated from the source through its corresponding series-connected string of memory cells, e.g., depending on the state of the memory cells of the corresponding series-connected string of memory cells connected to the particular access line, in response to a particular voltage level being applied to its control gate.
Sensing the state of each data line of the second subset of the plurality of data lines may occur without decreasing the voltage level applied to each access line of the plurality of access lines other than the particular access line (e.g., while maintaining or increasing the voltage level). Similarly, upon sensing the state of each data line of the second subset of the plurality of data lines, a select gate (e.g., drain select gate and/or source select gate) corresponding to each series connected string of memory cells corresponding to the second subset of the plurality of data lines may be activated. The second subset of the plurality of data lines may be mutually exclusive from the first subset of the plurality of data lines. The second subset of the plurality of data lines may contain one or more data lines of the plurality of data lines other than the first subset of the plurality of data lines. Alternatively, the second subset of the plurality of data lines may contain each data line of the plurality of data lines other than the first subset of the plurality of data lines.
Alternatively, the second subset of the plurality of data lines may contain each of the plurality of data lines other than the subset of the plurality of data lines that includes a data line corresponding to a series connected string of memory cells, each series connected string of memory cells programmed to contain a data pattern representing a respective data state of the plurality of data states and representing each data state of the plurality of data states.
Fig. 14 is a flow chart of a method of operating a memory according to another embodiment. For example, the method of FIG. 14 may be part of a read operation.
At 1411, for each of a plurality of data states, a state of each canary data line of a respective subset of a plurality of canary data lines of the data states is sensed while increasing a voltage level applied to each of a plurality of access lines commonly connected to a plurality of series-connected strings of memory cells. This may include increasing the voltage level applied to all access lines commonly connected to the plurality of series connected strings of memory cells, e.g., such that the control gates of each of these series connected strings of memory cells receive an increasing voltage level. A first subset of the plurality of series connected strings of memory cells may be selectively connected to the plurality of canary data lines.
Each respective subset of the plurality of canary data lines may contain one or more canary data lines of the plurality of canary data lines. Each respective subset of the plurality of canary data lines may contain the same or different number of canary data lines than other respective subsets of the plurality of canary data lines. Each respective subset of the plurality of canary data lines may correspond to a series connected string of memory cells, each series connected string of memory cells programmed to contain a data pattern representing its respective data state (e.g., a plurality of predetermined target data states) of the plurality of data states. The plurality of data states may include each data state to which the memory is configured to program any memory cell of the plurality of series connected strings of memory cells. For example, if the memory is configured to program a memory cell to one of sixteen different data states (e.g., L0-L15), or if the memory is configured to read a memory cell to distinguish sixteen different data states, the plurality of data states may include all sixteen data states. Alternatively, the plurality of data states may include less than all sixteen data states, e.g., the plurality of data states at 1411 may not include the highest data state (e.g., L15) of the plurality of data states.
The plurality of canary data lines may be selectively connected to a portion of a memory cell block (or a plurality of memory cell blocks) of a memory plane. The plurality of canary data lines may form a continuous grouping of canary data lines. Further, respective subsets of the plurality of canary data lines of a particular one of the plurality of data states may be consecutive groupings of canary data lines, or they may be interleaved with other data lines, e.g., other canary data lines of one or more different subsets of the plurality of canary data lines, data lines selectively connected to series-connected strings of memory cells of the plurality of series-connected strings of memory cells not sensed during a read operation, or other data lines other than the plurality of canary data lines sensed during a read operation.
Each series-connected memory cell string of the first subset of the plurality of series-connected memory cell strings may correspond, for example, in a one-to-one relationship to a respective canary data line of the plurality of canary data lines. Upon sensing a state of each of the plurality of canary data lines, a select gate (e.g., drain select gate and/or source select gate) corresponding to each series connected memory cell string of the first subset of the plurality of series connected memory cell strings may be activated.
At 1413, for each data state of the plurality of data states, a respective voltage level of the data state that has changed the state of each canary data line of a respective subset of the plurality of canary data lines is determined. For example, the initial state of a data line (e.g., canary or otherwise) may be floating, e.g., isolated from the source by its corresponding deactivated memory cells of a series-connected string of memory cells. When the incremental voltage level applied to the plurality of access lines reaches a voltage level sufficient to activate each memory cell of the corresponding series connected string of memory cells, the state of the data line may change to conductive, e.g., to connect to the source through its corresponding series connected string of memory cells.
At 1415, the voltage level applied to a particular access line of the plurality of access lines is reduced, for example, after each of the respective voltage levels is determined at 1413. For some embodiments, reducing the voltage level applied to a particular access line may occur after determining the voltage level that has changed the state of each of the plurality of canary data lines and each of the plurality of primary data lines. This may occur when each memory cell of each series connected string of memory cells of the plurality of series connected strings of memory cells is activated, and may indicate a value of a pass voltage for a read operation.
The particular access line may be an access line selected for a read operation (e.g., a control gate connected to one or more target memory cells whose data states are to be sensed during the read operation). For some embodiments, the voltage level applied to a particular access line may be reduced to the corresponding voltage level of the lowest data state of the plurality of data states. For other embodiments, the voltage level applied to a particular access line may be reduced to a voltage level lower than the corresponding voltage level of the lowest data state of the plurality of data states. The voltage level applied to a particular access line may be reduced without reducing the voltage level applied to each remaining access line of the plurality of access lines (e.g., while maintaining or increasing the voltage level).
At 1417, a state of each of the plurality of primary data lines is sensed while a respective voltage level of a particular data state of the plurality of data states is applied to the particular access line. Sensing the state of each of the plurality of primary data lines may include determining whether each of the plurality of primary data lines is connected to or isolated from the source through its corresponding series-connected string of memory cells, e.g., depending on the state of the memory cells connected to the corresponding series-connected string of memory cells of the particular access line, in response to the respective voltage level being applied to its control gate.
Sensing the state of each of the plurality of primary data lines may occur without decreasing the voltage level applied to each of the plurality of access lines other than the particular access line (e.g., while maintaining or increasing the voltage level). Similarly, upon sensing the state of each of the plurality of primary data lines, a select gate (e.g., drain select gate and/or source select gate) corresponding to each series connected string of memory cells corresponding to the plurality of primary data lines may be activated. The plurality of primary data lines may be mutually exclusive from the plurality of canary data lines. The plurality of primary data lines may contain each data line other than the plurality of canary data lines sensed during a read operation. Note that when sensing the state of each of the plurality of main data lines, the state of each of the plurality of canary data lines may be sensed. However, the state of the canary data line at 1417 may be irrelevant.
Sensing the state of each of the plurality of primary data lines while applying a respective voltage level of a particular data state to a particular access line may indicate the data state of one or more of the memory cells connected to the particular access line. For example, where the state of a primary data line indicates activation of its corresponding memory cell, the data state of that memory cell may be indicated as having a threshold voltage range that is lower than or equal to the respective voltage level. Similarly, where the state of a primary data line indicates deactivation of its corresponding memory cell, the data state of that memory cell may be indicated as having a threshold voltage range above the respective voltage level. In the case where the state of the primary data line indicates activation of its corresponding memory cell when the respective voltage level of a particular data state (e.g., L1) is applied to a particular access line and indicates deactivation of its corresponding memory cell when the respective voltage level of the next lower data state (e.g., L0) is applied to a particular access line, the data state of that memory cell may be indicated as the particular data state.
At 1419, a state of each of the plurality of primary data lines is sensed with a respective voltage level of a different one of the plurality of data states applied to a particular access line. The process of 1419 may be repeated for each remaining data state of the plurality of data states. This iterative process may begin at 1417 with the respective voltage level of the lowest data state of the plurality of data states and continue with each successively higher data state of the plurality of data states. For memory cells connected to a particular access line that are not activated in response to any respective voltage level for each of the plurality of data states, the memory cells may be considered to have a higher data state than any of the plurality of data states. For example, in a memory configured to program memory cells of the plurality of strings of serially connected memory cells into sixteen data states L0-L15, and where the plurality of data states includes data states L0-L14, memory cells that are not activated in response to any respective voltage level of each of the plurality of data states may be considered to have an L15 data state.
Note that the method of fig. 14 may be repeated for a subsequent read operation, for example, using a different access line of the plurality of access lines as a particular access line, but without determining a respective voltage level for a data state of the plurality of data states. For example, for a first read operation performed on a block of memory cells, the determined respective voltage levels for the various data states may be considered the same for a subsequent (e.g., immediately subsequent) read operation on that same block of memory cells, such that the value may not need to be re-determined. For embodiments in which the voltage level of the pass voltage is also determined, this may also be considered the same for subsequent read operations. While a subsequent read operation may increase the voltage level applied to each access line of the plurality of access lines at 1411 and decrease the voltage level applied to a particular access line at 1415, the respective voltage levels applied in 1417-1419 may not need to be determined while the same canary data line may be involved.
FIG. 15 is a flow chart of a method of operating a memory according to additional embodiments. For example, the method of FIG. 15 may be part of a read operation. The method of fig. 15 may be performed (e.g., concurrently performed) in conjunction with the method of fig. 13 or 14. As used herein, a first action and a second action occur simultaneously when the first action occurs in synchronization with the second action for at least a portion of the duration of the second action. For example, the increasing of the voltage level applied to each of the plurality of access lines at 1521 of fig. 15 may occur in synchronization with the increasing of the voltage level applied to each of the plurality of access lines at 1301 of fig. 13 or 1411 of fig. 14, for at least a portion of the duration of the voltage level applied to each of the plurality of access lines at 1521 of fig. 15.
At 1521, a state of each of a plurality of data lines is sensed with increasing a voltage level applied to each of a plurality of access lines commonly connected to a plurality of series connected strings of memory cells. This may include increasing the voltage level applied to all access lines commonly connected to the plurality of series connected strings of memory cells, e.g., such that the control gates of each of these series connected strings of memory cells receive an increasing voltage level.
The plurality of data lines at 1521 may be the same plurality of data lines that may be used with the method of fig. 13. Alternatively, the plurality of data lines at 1521 may include the plurality of canary data lines and the plurality of primary data lines as used with the method of fig. 14. Each series-connected string of memory cells of the plurality of series-connected strings of memory cells may correspond to a respective data line of the plurality of data lines, for example, in a one-to-one relationship. Upon sensing the state of each data line of the plurality of data lines, a select gate (e.g., drain select gate and/or source select gate) corresponding to each series connected memory cell string of the plurality of series connected memory cell strings may be activated.
At 1523, a particular voltage level that has changed the state of each of the plurality of data lines is determined. For example, the initial state of the data line may be floating, e.g., isolated from the source by its deactivated memory cells corresponding to the series-connected string of memory cells. When the incremental voltage level applied to the plurality of access lines reaches a voltage level sufficient to activate each memory cell of the corresponding series connected string of memory cells, the state of the data line may change to conductive, e.g., to connect to the source through its corresponding series connected string of memory cells. This particular voltage may be indicative of a pass voltage for a read operation sufficient to activate each memory cell of the plurality of strings of series-connected memory cells regardless of its data state.
Fig. 16 is a flow chart of a method of operating a memory according to yet additional embodiments. For example, the method of FIG. 16 may be part of a programming operation (e.g., a write operation). The method of fig. 16 may be performed as a precursor to performing the methods of fig. 13-15.
At 1631, data to be programmed to a first subset of the plurality of memory cells is received. The data has, for each memory cell of the first subset of the plurality of memory cells, a corresponding data state of a plurality of data states (e.g., a plurality of predetermined target data states). Data may be received by a memory (e.g., memory 100) from a controller (e.g., processor 130) external to the memory. The plurality of memory cells may be logical pages of a block of memory cells. Alternatively, the plurality of memory cells may be a block of memory cells. The data may be associated with one or more write commands received by the memory.
At 1633, for each memory cell of the first subset of the plurality of memory cells, its corresponding data state is programmed to the memory cell. Programming of the corresponding data states of the memory cells of the first subset of the plurality of memory cells may be performed concurrently.
At 1635, for each data state of the plurality of data states, the data state is programmed to each memory cell of a respective subset of the plurality of memory cells without reference to any of the received data. A respective subset of the plurality of memory cells of any one of the plurality of data states may contain one or more memory cells. The respective subset of the plurality of memory cells of any one of the plurality of data states may be mutually exclusive with the respective subset of the plurality of memory cells of any other of the plurality of data states and may be mutually exclusive with the first subset of the plurality of memory cells. Programming in this manner may be used to program respective data patterns representing respective ones of the plurality of data states along with user data.
Fig. 17 is a flow chart of a method of operating a memory according to yet additional embodiments. For example, the method of FIG. 17 may be part of a read operation.
At 1741, a plurality of read voltages for a read operation are determined during a precharge phase of the read operation. The plurality of read voltages may correspond to each data state to which the memory is configured to program any memory cells to be sensed during a read operation. For example, if the memory is configured to program a memory cell to one of sixteen different data states (e.g., L0-L15), the plurality of read voltages may include sixteen read voltages. Alternatively, the plurality of read voltages may correspond to less than all sixteen data states, e.g., the plurality of read voltages at 1741 may not include a read voltage corresponding to the highest data state (e.g., L15) to which the memory is configured to program one of the memory cells. The precharge phase of the read operation may include increasing the voltage level applied to the access lines involved in the read operation and sensing when the memory cells programmed to the various strings of serially connected memory cells containing the data pattern representing the respective data state are activated as previously described.
At 1743, a pass voltage for the read operation is determined during a precharge phase of the read operation. The pass voltage may be the voltage level that activates all memory cells involved in the read operation as previously described. The pass voltage may be determined simultaneously with and subsequent to determining the read voltage.
At 1745, a pass voltage is applied to each unselected access line of the plurality of access lines. At 1747, for each read voltage of the plurality of read voltages, a data state of a memory cell (e.g., a target memory cell) of a plurality of memory cells selected for a read operation is sensed while the read voltage is applied to a selected access line of the plurality of access lines. The plurality of read voltages may be applied in an ascending order (e.g., from a lowest read voltage of the plurality of read voltages to a highest read voltage of the plurality of read voltages). The sensed data state of the memory cell may be indicated as a data state corresponding to a voltage level of a particular read voltage activating the memory cell. For memory cells selected for a read operation that are not activated in response to any of the plurality of read voltages, the memory cells may be considered to have a higher data state than any data state corresponding to the read voltage of the plurality of read voltages.
Note that the process of 1745 and 1747 may be repeated for subsequent read operations, e.g., using different selected access lines. For example, for a first read operation performed on a block of memory cells, the determined pass voltage and the determined plurality of read voltages may be considered the same for a subsequent (e.g., immediately subsequent) read operation on the same block of memory cells, such that the value may not need to be re-determined.
Summary
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement that is calculated to achieve the same purpose may be substituted for the specific embodiments shown. Many variations of the embodiments will be apparent to those skilled in the art. Accordingly, this disclosure is intended to cover any adaptations or variations of the embodiments.
Claims (25)
1. A method of operating a memory, comprising:
sensing a state of each of the plurality of data lines while increasing a voltage level applied to each of a plurality of access lines commonly connected to the plurality of series-connected memory cell strings;
determining a first voltage level that has changed the state of each data line of a first subset of the plurality of data lines;
Reducing a voltage level applied to an access line selected for a read operation among the plurality of access lines; and
The state of each data line of the second subset of the plurality of data lines is sensed while the first voltage level is applied to the access line selected for the read operation.
2. The method of claim 1, wherein reducing the voltage level applied to the access line selected for the read operation comprises reducing the voltage level to a voltage level that is lower than or equal to the first voltage level.
3. The method of claim 1, wherein each data line of the plurality of data lines corresponds to a respective series connected string of memory cells of the plurality of series connected strings of memory cells, and wherein each series connected string of memory cells corresponding to a data line of the first subset of the plurality of data lines contains a predetermined data pattern that represents a respective data state of a plurality of data states.
4. The method of claim 1, wherein sensing the state of any one of the plurality of data lines comprises sensing a change in a property of the data line selected from the group consisting of a current of the data line and a voltage level of the data line.
5. The method of claim 4, wherein sensing the change in the property comprises comparing the property to a threshold.
6. The method of claim 1, wherein sensing the state of any one of the plurality of data lines comprises sensing whether the data line is isolated from a source or connected to a source.
7. A method of operating a memory, comprising:
for each data state of a plurality of data states, sensing a state of each canary data line of a respective subset of a plurality of canary data lines of the data state while increasing a voltage level applied to each access line of a plurality of access lines commonly connected to a plurality of series connected strings of memory cells, wherein the plurality of canary data lines are selectively connected to a first plurality of memory cells of the plurality of series connected strings of memory cells, and wherein the first plurality of memory cells are configured to store a predetermined data pattern;
for each data state of the plurality of data states, determining a respective voltage level of the data state that has changed the state of each canary data line of a respective subset of the plurality of canary data lines;
Reducing a voltage level applied to an access line selected for a read operation among the plurality of access lines; and
The method includes sensing a state of each of a plurality of primary data lines while applying the respective voltage level of a first data state of the plurality of data states to the access line selected for the read operation, wherein the plurality of primary data lines are selectively connected to a second plurality of memory cells of the plurality of strings of serially connected memory cells, and wherein the second plurality of memory cells are configured to store user data and/or overhead data.
8. The method as recited in claim 7, further comprising:
the state of each of the plurality of primary data lines is sensed while the respective voltage level of a different one of the plurality of data states is applied to the access line selected for the read operation.
9. The method as recited in claim 7, further comprising:
for each remaining data state of the plurality of data states, the state of each primary data line of the plurality of primary data lines is sensed while the respective voltage level of the remaining data state is applied to the access line selected for the read operation.
10. The method as recited in claim 7, further comprising:
for additional data states above the plurality of data states, sensing a state of each canary data line of a respective subset of the plurality of canary data lines of the additional data states while increasing the voltage level applied to each access line of the plurality of access lines; and
For the additional data state, a respective voltage level of the additional data state that has changed the state of each canary data line of a respective subset of the plurality of canary data lines is determined.
11. The method as recited in claim 7, further comprising:
a pass voltage level is determined that has changed the state of each of the plurality of canary data lines and the state of each of the plurality of primary data lines.
12. The method of claim 11, further comprising applying the pass voltage level to each access line of the plurality of access lines other than the access line selected for the read operation while applying the respective voltage level of the first data state to the access line selected for the read operation.
13. The method as recited in claim 7, further comprising:
for each data state of the plurality of data states other than the first data state, sensing the state of each of the plurality of primary data lines while applying the respective voltage level of the data state of the plurality of data states to the access line selected for the read operation;
decreasing the voltage level applied to each access line of the plurality of access lines, then increasing the voltage level applied to each access line of the plurality of access lines;
lowering the voltage level applied to an access line of the plurality of access lines selected for a subsequent read operation; and
For each data state of the plurality of data states, the state of each primary data line of the plurality of primary data lines is sensed while the respective voltage level of the data state of the plurality of data states is applied to the access line selected for the subsequent read operation.
14. A method of operating a memory, comprising:
sensing a state of each of a plurality of data lines while increasing a voltage level applied to each of a plurality of access lines commonly connected to a plurality of series connected memory cell strings, wherein each series connected memory cell string corresponds to a respective data line of the plurality of data lines;
Determining a first voltage level that has changed the state of each data line of a first subset of the plurality of data lines, wherein each corresponding series connected string of memory cells of each data line of the first subset of the plurality of data lines is programmed to contain a first data pattern representing a first data state of a plurality of data states;
reducing the voltage level applied to an access line selected for a read operation of the plurality of access lines without reducing the voltage level applied to each remaining access line of the plurality of access lines;
sensing a state of each data line of a second subset of the plurality of data lines while applying the first voltage level to the access line selected for the read operation; and
For each data line of the second subset of the plurality of data lines, if the data line first changes state in response to applying the first voltage level to the access line selected for the read operation after decreasing the voltage level applied to the access line selected for the read operation, the memory cells of the corresponding series-connected string of memory cells of the data line are considered to be programmed to the first data state.
15. The method as recited in claim 14, further comprising:
determining a second voltage level that has changed the state of each data line of a second subset of the plurality of data lines, wherein each corresponding series connected string of memory cells of each data line of the second subset of the plurality of data lines is programmed to contain a second data pattern representing a second data state of the plurality of data states, wherein the second data state is a higher data state of the plurality of data states next to the first data state;
sensing the state of each data line of the second subset of the plurality of data lines while applying the second voltage level to the access line selected for the read operation; and
For each data line of the second subset of the plurality of data lines, if the data line first changes state in response to applying the second voltage level to the access line selected for the read operation after decreasing the voltage level applied to the access line selected for the read operation, the memory cells of the corresponding series-connected string of memory cells of the data line are considered to be programmed to the second data state.
16. The method as recited in claim 14, further comprising:
for each data state of the plurality of data states other than the first data state, determining a respective voltage level that has changed the state of each data line of a respective subset of the plurality of data lines, wherein each corresponding series connected string of memory cells for each data line of the respective subset of the plurality of data lines of the data state is programmed to contain a respective data pattern representing the data state;
for each data state of the plurality of data states other than the first data state, sensing the state of each data line of the second subset of the plurality of data lines while applying the respective voltage level for the data state to the access line selected for the read operation; and
For each data state of the plurality of data states other than the first data state, and for each data line of the second subset of the plurality of data lines, if the data line first changes state in response to the respective voltage level of the data state being applied to the access line selected for the read operation after decreasing the voltage level applied to the access line selected for the read operation, the memory cells of the corresponding series-connected string of memory cells of the data line are considered programmed to the data state.
17. The method of claim 14, wherein a series connected string of memory cells programmed to contain the data pattern representing the first data state comprises a series connected string of memory cells as follows: the memory cells of the string of series connected memory cells are programmed to contain the first data state and each remaining memory cell of the string of series connected memory cells is programmed to contain a data state of the plurality of data states that is equal to or lower than the first data state.
18. The method of claim 14, wherein a series connected string of memory cells programmed to contain the data pattern representing the first data state comprises a series connected string of memory cells as follows: at least one memory cell of the series connected string of memory cells is programmed to contain the first data state and each remaining memory cell of the series connected string of memory cells is programmed to contain a lowest data state of the plurality of data states.
19. The method of claim 14, wherein a series connected string of memory cells programmed to contain the data pattern representing the first data state comprises a series connected string of memory cells as follows: each memory cell of the series connected string of memory cells is programmed to contain the first data state.
20. A method of operating a memory, comprising:
for each data state of a plurality of data states, sensing a state of each canary data line of a respective subset of a plurality of canary data lines of the data state while increasing a voltage level applied to each access line of a plurality of access lines commonly connected to a plurality of series connected strings of memory cells, wherein the plurality of canary data lines are selectively connected to a first plurality of memory cells of the plurality of series connected strings of memory cells, and wherein the first plurality of memory cells are configured to store a predetermined data pattern;
sensing a state of each of a plurality of primary data lines while increasing the voltage level applied to each of the plurality of access lines, wherein the plurality of primary data lines are selectively connected to a plurality of memory cells in the plurality of strings of serially connected memory cells, and wherein the plurality of memory cells are configured to store user data and/or overhead data;
for each data state of the plurality of data states, determining a respective voltage level of the data state that has changed the state of each canary data line of a respective subset of the plurality of canary data lines;
Determining a pass voltage level that has changed the state of each of the plurality of canary data lines and each of the plurality of primary data lines;
reducing a voltage level applied to an access line selected for a read operation of the plurality of access lines while applying the pass voltage level to each remaining access line of the plurality of access lines;
for each data state of the plurality of data states, sensing a state of each primary data line of the plurality of primary data lines while applying the respective voltage level of the data state to the access line selected for the read operation; and
For each memory cell of the plurality of strings of serially connected memory cells connected to the access line selected for the read operation:
if a corresponding one of the plurality of primary data lines for the memory cell first changes state in response to the respective voltage level applying a first one of the plurality of data states after reducing the voltage level applied to the access line selected for the read operation, determining that a data state programmed into the memory cell is the first data state; and
If the corresponding primary data line for the memory cell does not change state in response to the respective voltage level applying any of the plurality of data states after reducing the voltage level applied to the access line selected for the read operation, then the data state programmed into the memory cell is determined to be a higher data state than any of the plurality of data states.
21. The method of claim 20, wherein sensing the state of any primary data line comprises sensing a property of the primary data line selected from the group consisting of a current of the primary data line and a voltage level of the primary data line.
22. The method of claim 20, wherein applying the respective voltage level for each data state of the plurality of data states to the access line selected for the read operation comprises applying these respective voltage levels in an order of increasing voltage levels.
23. The method of claim 20, wherein sensing the state of each canary data line of the respective subset of the plurality of canary data lines of a data state of the plurality of data states comprises sensing a canary data line interleaved with a canary data line of the respective subset of the plurality of canary data lines of a different data state of the plurality of data states.
24. The method of claim 20, wherein sensing the state of each canary data line of the respective subset of the plurality of canary data lines of a data state of the plurality of data states comprises sensing a canary data line interleaved with a primary data line of the plurality of primary data lines.
25. A memory, comprising:
a memory cell array; and
A controller for access of the array of memory cells, wherein the controller is configured to cause the memory to perform the method of any one of claims 1-24.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/152,897 US10714196B2 (en) | 2018-10-05 | 2018-10-05 | Methods for determining data states of memory cells |
US16/152,897 | 2018-10-05 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111009278A CN111009278A (en) | 2020-04-14 |
CN111009278B true CN111009278B (en) | 2023-11-07 |
Family
ID=70051825
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910920281.5A Active CN111009278B (en) | 2018-10-05 | 2019-09-26 | Apparatus and method for determining data state of memory cell |
Country Status (2)
Country | Link |
---|---|
US (4) | US10714196B2 (en) |
CN (1) | CN111009278B (en) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10777286B2 (en) * | 2018-12-28 | 2020-09-15 | Micron Technology, Inc. | Apparatus and methods for determining data states of memory cells |
US11049582B1 (en) * | 2020-05-07 | 2021-06-29 | Micron Technology, Inc. | Detection of an incorrectly located read voltage |
US11238953B2 (en) | 2020-05-07 | 2022-02-01 | Micron Technology, Inc. | Determine bit error count based on signal and noise characteristics centered at an optimized read voltage |
US11177013B1 (en) | 2020-05-07 | 2021-11-16 | Micron Technology, Inc. | Determine signal and noise characteristics centered at an optimized read voltage |
US11024401B1 (en) | 2020-05-07 | 2021-06-01 | Micron Technology, Inc. | Compute an optimized read voltage |
US11654578B2 (en) * | 2020-09-17 | 2023-05-23 | Kawasaki Jukogyo Kabushiki Kaisha | Robot system and offset acquisition method |
US11468942B2 (en) * | 2021-03-02 | 2022-10-11 | Hewlett Packard Enterprise Development Lp | System and method for detecting memory cell disturbance by monitoring canary cells |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101025496A (en) * | 2006-02-17 | 2007-08-29 | 三星电子株式会社 | Touch sensitive display device |
CN102792382A (en) * | 2010-03-09 | 2012-11-21 | 美光科技公司 | Sensing operations in a memory device |
CN104395966A (en) * | 2012-06-01 | 2015-03-04 | 美光科技公司 | Memory cell sensing |
CN107767905A (en) * | 2016-08-19 | 2018-03-06 | 美光科技公司 | Segmented memory system and operation |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100673170B1 (en) * | 2005-03-10 | 2007-01-22 | 주식회사 하이닉스반도체 | Flash memory device with improved erase function and method for controlling erase operation of the same |
US8203876B2 (en) * | 2009-12-01 | 2012-06-19 | Micron Technology, Inc. | Reducing effects of erase disturb in a memory device |
KR102349729B1 (en) * | 2015-10-23 | 2022-01-12 | 삼성전자주식회사 | Nonvolatile memory device, storage device having the same, operating method thereof |
KR102469680B1 (en) * | 2016-05-04 | 2022-11-22 | 에스케이하이닉스 주식회사 | Semiconductor memory device |
US9779819B1 (en) * | 2016-06-24 | 2017-10-03 | Micron Technology, Inc. | Connecting memory cells to a data line sequentially while applying a program voltage to the memory cells |
JP2018116755A (en) * | 2017-01-19 | 2018-07-26 | 東芝メモリ株式会社 | Semiconductor memory |
US10020041B1 (en) * | 2017-05-23 | 2018-07-10 | Everspin Technologies, Inc. | Self-referenced sense amplifier with precharge |
CN109243505B (en) * | 2017-07-10 | 2021-06-08 | 华邦电子股份有限公司 | Current sensing circuit and sensing method of memory |
US10062441B1 (en) | 2017-08-31 | 2018-08-28 | Micron Technology, Inc. | Determining data states of memory cells |
US10629271B2 (en) * | 2017-12-05 | 2020-04-21 | Intel Corporation | Method and system for reducing program disturb degradation in flash memory |
US10535412B2 (en) * | 2018-02-09 | 2020-01-14 | Sandisk Technologies Llc | Single pulse verification of memory cells |
US10861537B1 (en) * | 2019-10-30 | 2020-12-08 | Sandisk Technologies Llc | Countermeasures for first read issue |
-
2018
- 2018-10-05 US US16/152,897 patent/US10714196B2/en active Active
-
2019
- 2019-09-26 CN CN201910920281.5A patent/CN111009278B/en active Active
-
2020
- 2020-06-23 US US16/908,832 patent/US10854303B2/en active Active
- 2020-11-11 US US17/095,291 patent/US11056201B2/en active Active
-
2021
- 2021-06-10 US US17/344,141 patent/US11508447B2/en active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101025496A (en) * | 2006-02-17 | 2007-08-29 | 三星电子株式会社 | Touch sensitive display device |
CN102792382A (en) * | 2010-03-09 | 2012-11-21 | 美光科技公司 | Sensing operations in a memory device |
CN104395966A (en) * | 2012-06-01 | 2015-03-04 | 美光科技公司 | Memory cell sensing |
CN107767905A (en) * | 2016-08-19 | 2018-03-06 | 美光科技公司 | Segmented memory system and operation |
Also Published As
Publication number | Publication date |
---|---|
US20210304829A1 (en) | 2021-09-30 |
US20200111534A1 (en) | 2020-04-09 |
US11508447B2 (en) | 2022-11-22 |
US10714196B2 (en) | 2020-07-14 |
US20200321065A1 (en) | 2020-10-08 |
CN111009278A (en) | 2020-04-14 |
US11056201B2 (en) | 2021-07-06 |
US10854303B2 (en) | 2020-12-01 |
US20210065825A1 (en) | 2021-03-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111052245B (en) | Determining data states of memory cells | |
CN111009278B (en) | Apparatus and method for determining data state of memory cell | |
CN111179982B (en) | Apparatus and method for discharging control gate after performing access operation on memory cell | |
US11309039B2 (en) | Apparatus for determining a pass voltage of a read operation | |
US11776633B2 (en) | Apparatus and methods for determining data states of memory cells | |
CN112908393A (en) | Apparatus and method for an inoculation operation concurrent with a data line set operation | |
CN112447246B (en) | Apparatus and method for mitigating program disturb | |
US11610637B2 (en) | Apparatus for determining an expected data age of memory cells | |
CN113470717B (en) | Apparatus for memory cell programming and method for memory cell programming | |
US11670346B2 (en) | Memory cell programming including applying programming pulses of different pulse widths to different access lines | |
US11823752B2 (en) | Memory devices for program verify operations |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |