VREAD BIAS ALLOCATION ON WORD LINES FOR READ DISTURB REDUCTION IN 3D NON-VOLATILE MEMORY
Techniques are provided for sensing memory cells in a 3D stacked non-volatile memory device in a way which reduces read disturb, by using read pass voltages which are adjusted based on variations in a memory hole diameter. The memory cells are in NAND strings which extend in the memory holes. A larger read pass voltage is used for memory cells which are adjacent to wider portions of the memory holes, and a smaller read pass voltage is used for memory cells which are adjacent to narrower portions of the memory holes. This approach reduces the worst-case read disturb. Further, an overall resistance in the NAND string channel may be substantially unchanged so that a reference current used during sensing may be unchanged. The read pass voltage may be set based on a program voltage trim value, which is indicative of programming speed and memory hole diameter.
Latest SanDisk Technologies Inc. Patents:
- Exception handling using security subsystem in storage device
- File system integration into data mining model
- Data storage device and method for using zones of memory in a read scrub operation
- Storage of control data information
- Data storage device with balanced background operations and method therefor
The present technology relates to techniques for sensing memory cells in a 3D non-volatile memory device.
Recently, ultra high density storage devices have been proposed using a 3D stacked memory structure sometimes referred to as a Bit Cost Scalable (BiCS) architecture. For example, a 3D NAND stacked memory device can be formed from an array of alternating conductive and dielectric layers. A memory hole is drilled in the layers to define many memory layers simultaneously. A NAND string is then formed by filling the memory hole with appropriate materials. A straight NAND string extends in one memory hole, while a pipe- or U-shaped NAND string (P-BiCS) includes a pair of vertical columns of memory cells which extend in two memory holes and which are joined by a bottom back gate. Control gates of the memory cells are provided by the conductive layers. However, various challenges are presented in operating such memory devices.
Like-numbered elements refer to common components in the different figures.
FIG. 2B1 depicts the block 200
FIG. 2B2 depicts the block 200
FIG. 2B3 depicts a cross-sectional width of a memory hole which flares out to a widest region near the top and is then tapered toward the bottom.
FIG. 2B4 depicts a variation in memory hole diameter in a stack of word line layers (WLLs), corresponding to FIG. 2B3.
FIG. 2B5 depicts the example NAND string NS0 of FIG. 2B2, where memory cells are arranged in groups having a similar memory hole diameter based on FIG. 2B3.
FIG. 2B6 depicts the example NAND strings NS0, NS0-1, NS0-2, . . . , NS0-14 of FIG. 2B2.
FIG. 4B1 depicts the block BLK0 of
FIG. 4B2 depicts the block BLK0 of
Techniques are provided for sensing memory cells in a 3D stacked non-volatile memory device in a way which reduces read disturb, by using read pass voltages (Vrp) which are adjusted based on variations in a memory hole diameter.
In such a memory device, memory cells are formed along memory holes which extend through alternating conductive and dielectric layers in a stack. The memory cells are typically arranged in NAND strings. However, memory hole etching is challenging due to the very high aspect ratio. For example, a depth-to-diameter ratio of about 25-30 is common. The memory hole diameter (Dmh) can vary along the length of the hole. Typically, the diameter becomes progressively smaller from the top to the bottom of the memory hole, closer to the bottom of the stack. In some cases, a slight narrowing occurs at the top of the hole near the select gate so that the diameter becomes slight wider before becoming progressively smaller from the top to the bottom of the memory hole.
Due to the non-uniformity in the diameter of the memory hole, the programming and erase speed of the memory cells can vary based on their position along the memory hole. With a smaller diameter portion of a memory hole, the electric field across the tunnel oxide is stronger, so that the programming and erase speed is higher. Another result is that read disturb is more severe, reducing the reliability of the memory device. During a sensing operation (e.g., a read or verify operation), a moderately high read pass voltage is applied to unselected memory cells via unselected word line layers (WLLs) to provide the memory cells in a conductive state. Vrp has to be sufficiently higher than the upper tail of the threshold voltage (Vth) distribution of the highest data state to ensure that the unselected memory cells are provided in a conductive state. With the unselected memory cells in a non-conductive state, they do not interfere with the sensing of the selected memory cells.
However, the electric field created by Vrp acts as a weak programming voltage. The memory cells in the erased state are most affected by the electric field because they have the lowest Vth. As a result, the upper tail of the erased state Vth distribution of the unselected memory cells can increase and thereby decrease a read pass window. This problem becomes worse over time as more electrons are trapped in the charge trapping layer due to program-erase cycles.
Techniques provided herein address the above-mentioned issues. In one approach, during a sensing operation involving a selected WLL, Vrp is set higher for unselected WLLs which are adjacent to relatively wider portions of the memory holes. For conciseness, WLLs which are adjacent to relatively wider portions of the memory holes are referred to as large Dmh WLLs and their memory cells are referred to as large Dmh memory cells. Word line layers which are adjacent to relatively narrower portions of the memory holes are referred to as small Dmh WLLs and their memory cells are referred to as small Dmh memory cells.
This higher Vrp can result in additional read disturb for these WLLs. However, this additional read disturb is tolerable because the worst case read disturb is normally seen on the small Dmh WLLs. Moreover, Vrp is set lower on the small Dmh WLLs. This reduces read disturb for these WLLs. As a result, the amount of read disturb can be roughly equalized among the different WLLs. Further, by offsetting the decrease in Vrp on some WLLs with an increase on other WLLs, the current in the NAND strings during sensing can be maintained in an expected range so that sensing accuracy is not impaired. Sensing typically involves evaluating whether a selected memory cell is in a conductive or non-conductive state by determining whether the current in a NAND string is above or below, respectively, a reference current.
In another aspect, the programming speed of the different WLLs is determined as a proxy for the diameter of the portions of the memory holes adjacent to the different WLLs. The programming speed is greater when the memory hole diameter is smaller. In one approach, an initial programming voltage, or a trim value which is a function of an initial program voltage, is determined for different WLLs and stored in the memory device for later use during sensing. The trim value can be used to optimize programming on the WLLs, such as by ensuring that the different WLLs complete a programming pass after a roughly equal number of program loops. This results in a narrower Vth distribution.
Further, the trim value can be used to set a read pass voltage for unselected WLLs during a sensing operation. Since the trim value is already present for use in programming, it can be used for sensing with minimal additional cost. In another approach, Vrp is determined and stored in the memory device for use during sensing. To simplify the implementation, groups of WLLs which have a similar range of memory hole diameters can be assigned a same read pass voltage. A group can include adjacent and/or non-adjacent word lines.
Advantages of the above-mentioned techniques include reducing the worst case read disturb which occurs at narrower portions of the memory hole, at the bottom WLLs in a stack, without requiring modification of the reference current used during sensing.
The following discussion provides details of the construction of a memory device and of related programming and sensing techniques which address the above-mentioned issues.
In one possible approach, the length of the plane, in the x-direction, represents a direction in which signal paths to word lines extend in the one or more upper metal layers (a word line or SGD line direction), and the width of the plane, in the y-direction, represents a direction in which signal paths to bit lines extend in the one or more upper metal layers (a bit line direction). The z-direction represents a height of the memory device.
The control circuitry 110 cooperates with the read/write circuits 128 to perform memory operations on the memory array 126, and includes a state machine 112, an on-chip address decoder 114, and a power control module 116. The state machine 112 provides chip-level control of memory operations. The on-chip address decoder 114 provides an address interface between that used by the host or a memory controller to the hardware address used by the decoders 124 and 132. The power control module 116 controls the power and voltages supplied to the word lines and bit lines during memory operations. It can includes drivers for WLLs and WLL portions, drain- and source-side select gate drivers (referring, e.g., to drain- and source-sides or ends of a string of memory cells such as a NAND string, for instance) and source lines. The sense blocks 130 can include bit line drivers, in one approach.
A storage location 113 for (WLL, Vrp) entries may also be provided, where each entry identifies one or more WLLs and an associated read pass voltage (Vrp) to use during sensing. The storage location may be a table of entries, for instance. A storage location 115 for (WLL, Vpgm_trim) entries may also be provided, where each entry identifies one or more WLLs and an associated trim voltage to use during programming. For example, an initial program voltage may be set based on a sum of a fixed reference voltage and Vpgm_trim, as Vpgm_initial=Vpgm_ref+Vpgm_trim, as discussed, e.g., in connection with
In some implementations, some of the components can be combined. In various designs, one or more of the components (alone or in combination), other than memory array 126, can be thought of as at least one control circuit. For example, a control circuit may include any one of, or a combination of, control circuitry 110, state machine 112, decoders 114/132, power control module 116, sense blocks 130, read/write circuits 128, and controller 122, and so forth.
In another approach, a non-volatile memory system uses dual row/column decoders and read/write circuits. Access to the memory array 126 by the various peripheral circuits is implemented in a symmetric fashion, on opposite sides of the array, so that the densities of access lines and circuitry on each side are reduced by half. Thus, the row decoder is split into two row decoders and the column decoder into two column decoders. Similarly, the read/write circuits are split into read/write circuits connecting to bit lines from the bottom and read/write circuits connecting to bit lines from the top of the memory array 126. In this way, the density of the read/write modules is reduced by one half.
Other types of non-volatile memory in addition to NAND flash memory can also be used.
For each block, the WLL is divided into two WLL portions 202 and 204. Each block includes a slit pattern. A slit is a void which extends vertically in the stack, typically from an etch stop layer at the bottom to at least a top layer of the stack. The slit can be filled with insulation to insulate words line layer portions from one another. A slit 206 is a single continuous slit which extends in a zig-zag pattern in the block so that the block is divided into two portions, 202 and 204, which are insulated from one another. This approach can provide greater flexibility in controlling the memory cells since the WLL portions can be driven independently.
Each block includes rows of columnar, e.g., vertical, memory holes or pillars, represented by circles. Each row represents a vertical group of columns in the figure. The memory holes extend vertically in the stack and include memory cells such as in a vertical NAND string. Example columns of memory cells along a line 220 include C0 to C11. The figure represents a simplification, as many more rows of memory holes will typically be used, extending to the right and left in the figure. Also, the figures are not necessarily to scale. The columns of memory cells can be arranged in subsets such as sub-blocks.
Subsets of memory cells can be of different types, such as WL subsets, SGD line subsets and BL subsets.
A portion 209 of the block is depicted in further detail in connection with
FIG. 2B1 depicts the block 200
When U-shaped NAND strings are used, each SGD line subset can include two adjacent rows of columns of memory cells. In a subset, the adjacent rows are separated by the slit. The columns of memory cells on one side of the slit are drain-side columns (e.g., C0, C3, C4 and C7 in
Word line drivers can independently provide signals such as voltage waveforms to the WLL portions 202 and 204.
The drawings are not to scale and do not show all memory columns. For example, a more realistic block might have 12 memory columns in the y direction as shown, but a very large number such as 32 k memory columns in the x direction, for a total of 384 k memory columns in a block. With U-shaped NAND strings, 192 k NAND strings are provided in this example. With straight NAND strings, 384 k NAND strings are provided in this example. Assuming there are twenty-four memory cells per column, there are 384 k×24=9,216 k memory cells in the set.
A set of NAND strings 210 of the block 200 is described further below in connection with FIG. 2B6. This represents a set of NAND strings which have SGD transistors controlled by a common SGD line. In one approach, this also represents a unit of memory cells which are programmed. Additional sets of NAND strings 211-215 are also depicted.
FIG. 2B2 depicts the block 200
FIG. 2B3 depicts a cross-sectional width of a memory hole which flares out to a widest region near the top and is then tapered toward the bottom. As mentioned at the outset, the memory hole diameter (Dmh) can vary along a length of a memory hole as represented by a central axis CA. The memory hole diameters can vary in different ways depending on the process used to create them. In this example, the memory hole flares out to a widest region near the top and is then tapered toward the bottom. An assumption is that the memory hole diameters vary in a similar way for a set of memory holes in a block so that the diameter is similar within a WLL, but different in different WLLs. The memory hole diameter is a function of the z coordinate (elevation or height) in the stack. In another possible configuration, the memory hole is uniformly tapered from top to bottom.
FIG. 2B4 depicts a variation in memory hole diameter (Dmh) in a stack of WLLs, corresponding to FIG. 2B3. Generally, Dmh varies in a stack of WLLs, in the vertical direction. The horizontal axis represents a distance in a stack ranging from a bottom word line to a top word line. As mentioned, the diameter tends to decrease toward the bottom of the stack. Dmh ranges from a minimum diameter, Dmh_to a maximum diameter, Dmh_max. Dmh is expected to vary consistently among different memory holes in the memory device.
As explained further below in connection with
FIG. 2B5 depicts the example NAND string NS0 of FIG. 2B2, where memory cells are arranged in groups having a similar memory hole diameter based on FIG. 2B3. The example NAND string has a drain side 260 which extends between a bit line (BL) and a back gate (BG), and a source side 261 which extends between a source line (SL) and the BG. The drain side includes a SGD transistor and memory cells represented by control gates CGD0-CGD23. The source side includes a SGS transistor and memory cells represented by control gates CGS0-CGS23. Optionally, one or more dummy transistors on each side can be provided.
In this example, the memory cells are assigned to groups G0, G1, G2 (comprising subgroups G2a and G2b) and G3. Each group encompasses portions of the memory hole having a similar diameter. Moreover, groups G0, G1 and G3 include adjacent memory cells, while G2 includes non-adjacent memory cells (in subgroups G2a and G2b) and adjacent memory cells within each subgroup. In this case, programming and/or sensing operations can be customized for each group. The memory cells and WLLs within a group can be treated the same during programming and sensing since they will likely have similar characteristics, e.g., in terms of programming speed and susceptibility to read disturb. In one approach, a common Vpgm_trim can be used to program all WLLs within a group, and different groups of WLLs can have different values of Vpgm_trim. Similarly, a common Vrp can be used for all unselected WLLs within a group, and different groups of WLLs can have different values of Vrp.
See also
For example, in the set of NAND strings 210, G0 includes the memory cells in WLL0-WLL6, G1 includes the memory cells in WLL7-WLL12, G2 includes the memory cells in WLL13-WLL18, WLL22 and WLDD23, and G3 includes the memory cells in WLL19-WLL21.
FIG. 2B6 depicts the example NAND strings NS0, NS0-1, NS0-2, . . . , NS0-14 of FIG. 2B2 of the set of NAND strings 210. A set of memory cells SetD-23 encompasses all of the memory cells on the drain sides of the set of NAND strings at WLL23, including MCD23-0, MCD23-1, MCD23-2, . . . , MCD23-14. These memory cells are adjacent to portions of respective memory holes MH0, MH0-1, MH0-2, . . . , MH0-14, which have a relatively wide diameter and can therefore by treated similarly in programming and sensing operations. Another example set of memory cells SetD-0 encompasses all of the memory cells on the drain sides of the NAND strings at WLL0, including MCD0-0, MCD0-1, MCD0-2 . . . , MCD0-14. These memory cells are adjacent to portions of respective memory holes which have a relatively narrow diameter and can therefore by treated similarly in programming and sensing operations. Additional sets of memory cells can be defined in a set of NAND string at each of the WLLs.
Portions of the memory holes are depicted as having varying diameters consistent with the groups of FIG. 2B5. For example, MH0 includes portions 286, 270, 274, 278 and 282, MH0-1 includes portions 287, 271, 275, 279 and 283, MH0-2 includes portions 288, 272, 276, 280 and 284, and MH0-14 includes portions 289, 273, 277, 281 and 285. G0 includes portions 282-285, G1 includes portions 278-281, G2 includes portions 274-277 and 286-289 and G3 includes portions 274-277. As a simplification, the memory hole diameters (Dmh) are shown as decreasing in uniform steps. In practice, the memory hole diameters tend to vary gradually as such as shown in FIG. 2B3.
MH0 from FIG. 2B6, corresponding to C0, is depicted for reference. The memory hole is considered to be present in the final memory device even though the memory hole is filled in. As a simplification of the narrow-wide-narrow profile of FIG. 2B6, the memory hole is shown as becoming progressively and gradually narrower from the top 237 to the bottom 238 of the stack. The memory holes are columnar and extend at least from a top word line layer (WLL23) of the plurality of WLLs to a bottom word line layer (WLL0) of the plurality of WLLs.
The source line SL0 is connected to the source ends 240 and 242 of two adjacent memory strings NS0 and NS1. SL0 is also connected to other sets of memory strings which are behind NS0 and NS1 in the x direction. Recall that additional U-shaped NAND strings in the stack 230 (e.g., NS0-1, NS0-2, . . . , NS0-14 from FIG. 2B6) extend behind the U-shaped NAND strings depicted in the cross-section, e.g., along the x-axis, in a SGD line direction. The U-shaped NAND strings NS0 to NS3 are each in a different SGD line subset, but are in a common BL subset.
The slit 206 from
A region 236 of the stack is shown in greater detail in
Word line layers WLL0-WLL23 and dielectric layers D0-D24 extend alternatingly in the stack. The SG layer is between D24 and D2. Each WLL has a drain-side portion and a source-side portion. For example, WL23S-SB is a source-side sub-block of WLL23, and WL23D-SB is a drain-side sub-block of WLL23, consistent with FIG. 2B1. In each WLL, the diagonal line patterned region represents the source-side sub-block, and the unpatterned region represents the drain-side sub-block.
When a memory cell is programmed, electrons are stored in a portion of the CTL which is associated with the memory cell. For example, electrons are represented by “-” symbols in the CTL 297 for the MC. These electrons are drawn into the CTL from the channel, and through the TNL. The Vth of a memory cell is increased in proportion to the amount of stored charge. As mentioned, electrons can become trapped in the CTL as additional program-erase cycles are experienced. This makes it easier for read disturb to Occur.
Each of the memory holes is filled with a plurality of annular layers comprising a block oxide layer, a charge trapping layer, a tunneling layer and a channel layer. A core region of each of the memory holes is filled with a body material, and the plurality of annular layers are between the core region and the WLLs in each of the memory holes. Further, the diameter of the memory hole (Dmh) varies along a memory hole based on a variation in the diameter of the core region (Dcore) based on the assumption that Wono+ch is fixed, where Dcore+Wono+ch=Dmh.
NAND strings NS0, NS1, NS2 and NS3 are in communication with a bit line BL0 (a first bit line) in BL-SB0 (a first bit line sub-block), and NAND strings NS0A, NS1A, NS2A and NS3A are in communication with a bit line BL1 (a second bit line) in BL-SB1 (a second bit line sub-block). In this example, each NAND string has a drain-side column with four memory cells and a SGD transistor, and a source-side column with four memory cells and a SGS transistor. The filled in circles indicate control gates of the select transistor and the memory cells on the drain side of a NAND string. The open circles indicate control gates of the select transistor and the memory cells on the source side of a NAND string.
For example, NS0 has a drain side column COD comprising memory cells M00, M01, M02 and M03 and an SGD transistor SGD0, and a source side column C0S comprising memory cells M10, M11, M12 and M13 and an SGS transistor SGS0. NS1 has a drain side column CM comprising memory cells M30, M31, M32 and M33 and an SGD transistor SGD1, and a source side column C1S comprising memory cells M20, M21, M22 and M23 and an SGS transistor SGS1. NS2 has a drain side column C2D comprising memory cells M40, M41, M42 and M43 and an SGD transistor SGD2, and a source side column C2S comprising memory cells M50, M51, M52 and M53 and an SGS transistor SGS2. NS3 has a drain side column C3D comprising memory cells M70, M71, M72 and M73 and an SGD transistor SGD3, and a source side column C3S comprising memory cells M60, M61, M62 and M63 and an SGS transistor SGS3.
Similarly, NS0A has a drain side column CODA comprising memory cells M00A, M01A, M02A and M03A and an SGD transistor SGD0A, and a source side column C0SA comprising memory cells M10A, M11A, M12A and M13A and an SGS transistor SGS0A. NS1A has a drain side column C1DA comprising memory cells M30A, M31A, M32A and M33A and an SGD transistor SGD1A, and a source side column C1 SA comprising memory cells M20A, M21A, M22A and M23A and an SGS transistor SGS1A. NS2A has a drain side column C2DA comprising memory cells M40A, M41A, M42A and M43A and an SGD transistor SGD2A, and a source side column C2SA comprising memory cells M50A, M51A, M52A and M53A and an SGS transistor SGS2A. NS3A has a drain side column C3D comprising memory cells M70A, M71A, M72A and M73A and an SGD transistor SGD3A, and a source side column C3SA comprising memory cells M60A, M61A, M62A and M63A and an SGS transistor SGS3A.
Each NAND string has a back gate (BG0 for NS0, BG1 for NS1, BG2 for NS2, BG3 for NS3, BG0A for NS0A, BG1A for NS1A, BG2A for NS2A, BG3A for NS3A). The control gates of all of the back gates in the circuit may be connected to one another.
In one approach, the source side of each SGS transistor is connected to a common source line of the circuit.
At each level of the circuit, the control gates of the drain-side memory cells are connected to one another by a common WLL. For example, M03, M03A, M33, M33A, M43, M43A, M73 and M73A have control gates connected by a word line layer WL3D, consistent with
M02, M02A, M32, M32A, M42, M42A, M72 and M72A have control gates connected by a word line layer WL2D. M12, M12A, M22, M22A, M52, M52A, M62 and M62A have control gates connected by a word line layer WL2S.
M01, M01A, M31, M31A, M41, M41A, M71 and M71A have control gates connected by a word line layer WL1D. M11, M11A, M21, M21A, M51, M51A, M61 and M61A have control gates connected by a word line layer WL1S.
M00, M00A, M30, M30A, M40, M40A, M70 and M70A have control gates connected by a word line layer WL0D. M10, M10A, M20, M20A, M50, M50A, M60 and M60A have control gates connected by a word line layer WL0S.
Additionally, control gates of the SGD transistors are connected to one another in respective NAND string sub-blocks. For example, in NS-SB0, control gates of SGD0, . . . , SGD0A are connected by path 390. In NS-SB1, control gates of SGD1, . . . , SGD1A are connected by path 391. In NS-SB3, control gates of SGD2, . . . , SGD2A are connected by path 392. In NS-SB3, control gates of SGD3, . . . , SGD3A are connected by path 393.
The control gates of the SGS transistors are connected to one another in the x-direction. For example, control gates of SGS0, . . . , SGS0A are connected, control gates of SGS1, . . . , SGS1A are connected, control gates of SGS2, . . . , SGS2A are connected, and control gates of SGS3, . . . , SGS3A are connected.
During a wafer die sort process described further below, at the top word line layer (WL3), in NS-SB0, an initial set of memory cells which is programmed can include memory cells M03, . . . , M03A and M13, . . . , M13A. This initial set of memory cells can be programmed to determine a value of Vpgm_trim or Vpgm_initial. In one approach, this Vpgm_trim or Vpgm_initial is also used for programming remaining sets of memory cells on WL3. This is reasonable since, as mentioned, memory cells on a common WLL having a similar memory hole diameter, or a group of WLLs having a similar memory hole diameter, are expected to have a similar programming speed. Subsequently, each lower WLL, or a representative WLL from each group, is programmed to determine an optimal Vpgm_trim or Vpgm_initial. An optimal Vrp can then be determined for each WLL or group of WLLs from Vpgm_trim or Vpgm_initial.
In another approach, each memory cell at the top WLL is programmed to determine an optimal Vpgm_trim for the top WLL.
In this configuration, a NAND string has only one column, and the source-side select gate is on the bottom of the column instead of on the top, as in a U-shaped NAND string. Moreover, a given level of a block has one WLL which is connected to each of the memory cells of the layer. For example, FIG. 4B1 depicts the block BLK0 of
FIG. 4B2 depicts the block BLK0 of
A second step 502 involves performing a sensing operation for a set of memory cells of a selected WLL while applying Vrp on remaining, unselected WLLs which is a function of their programming speeds. See
For option A, step 522 involves reading the storage location 115 to obtain Vpgm_trim for unselected word line layers (WLLs in which memory cells are not sensed). Step 524 determines Vrp for the unselected WLLs based on Vpgm_trim using, e.g., the graph of
Alternatively, step 522 obtains Vpgm_initial. In this case, the data which indicates the respective programming speeds of memory cells of the unselected WLLs comprises data which indicates initial programming voltages for the unselected WLLs, and the initial programming voltages are relatively higher when the respective programming speeds are relatively lower. Step 524 is an example of the read pass voltages being based on the data which indicates the respective programming speeds of memory cells of the unselected WLLs, and the read pass voltages being relatively lower when the respective programming speeds are relatively lower.
For either option, step 526 applies a sense voltage to a set of memory cells in the NAND strings in the selected WLL (e.g., one WLL), while applying different read pass voltages (Vrp) to the unselected WLLs. As mentioned, the Vrp values are optimized to minimize the worst case read disturb. For example, the sense voltage can be a read voltage such as VrA, VrB or VrC (
Step 528 sense the conductivity of the NAND strings. With the sense voltage applied to the control gates of the selected memory cells, a NAND string should have a relatively high conductivity (current), e.g., above a reference current, when a selected memory cell of the NAND string is in a conductive state (e.g., when the control gate voltage exceeds the Vth of the memory cell). Conversely, a NAND string should have a relatively low conductivity (current) e.g., below the reference current, when a selected memory cell of the NAND string is in a non-conductive state (e.g., when the control gate voltage does not exceed the Vth of the memory cell). The unselected memory cells in a NAND string should be in a conductive state when Vrp is applied to their control gates.
As mentioned, the use of a higher Vrp for larger Dmh WLLs offsets the use of a lower Vrp for smaller Dmh WLLs, so that a reference current used by a sense amplifier can be the same regardless of the WLL of a selected memory cell which is being sensed. Specifically, each memory cell in a NAND string is associated with a portion of the NAND string channel. The resistance of each portion is inversely proportional to the value of Vrp of the associate memory cell, so that if Vrp is higher the resistance is lower, and if Vrp is lower the resistance is higher Further, the overall resistance of the NAND string is based on a sum of the resistances of each portion. In the techniques described herein, where Vrp is different for different memory cells in a NAND string, the channel portions with the higher resistance are offset by the channel portions with the lower resistance, so that the overall channel resistance can be the same, compared to a case where a fixed Vrp is used. With the voltage (V) applied by the sense amplifier and the overall NAND string channel resistance (R) being the same as the case where a fixed Vrp is used, the channel current (I) is also substantially the same (since I=V/R). As a result, Vrp can advantageously be adjusted to reduce the worst case read disturb without changing the reference current used for sensing.
At decision step 530, if there is a next sense operation, step 526 is repeated. If decision step 530 is false, the sensing process is done at step 532
Step 540 includes selecting a word line layer (WLL) to program. Step 542 sets Vpgm_trim to an initial level. Also, Vpgm_initial is set to Vpgm_ref+Vpgm_trim. Step 544 programs the memory cells of the selected WLL by applying a series of program pulses to the selected word line layer. Starting at Vpgm_initial, Vpgm is stepped up in each program loop. See also
Optionally, groups of WLLs can be defined. In one approach, Vpgm_trim can be determined for each WLL. Word line layers having a common Vpgm_trim or range of Vpgm_trim can be grouped. For a group, one of the Vpgm_trim values can be selected as being representative of the group. For example, referring to FIG. 2B5, it may be determined that WLL0-WLL6 have Vpgm_trim values from 1-2 V. An average or median value such as 1.5 V may then be used as a Vpgm_trim value for the group. In another option, Vpgm_trim can be adjusted to account for future cycling effects in the memory device. For example, Vpgm_trim can be designed for a cycled memory device instead of a fresh memory device. One approach is to reduce Vpgm_trim further to offset an increase in programming speed with cycling (e.g., program-erase cycles). In another option, Vpgm_initial is determined from Vpgm_trim and stored for future use.
If decision step 546 is false, step 548 adjusts Vpgm_trim. Generally, if Vpgm_trim is too high, the programming will be completed in fewer than the specified number of loops. In this case, Vpgm_trim is decreased. If Vpgm_trim is too low, the programming will be completed in more than the specified number of loops, and Vpgm_trim is increased in step 548. After adjusting Vpgm_trim, step 544 is repeated.
This process is an example of determining a programming speed of memory cells of a selected WLL among a plurality of WLLs which are arranged alternatingly with dielectric layers in a stack, wherein the memory cells are arranged in respective memory holes which extend through the stack, and the respective memory holes have respective widths which vary along the memory holes; determining a read pass voltage for use in a sensing operation for the selected WLL based on the programming speed; and storing data in a storage location of the 3d non-volatile memory device identifying the read pass voltage.
Step 552 can be used as an alternative or addition to step 550. Step 552 determines Vrp from Vpgm_trim, such as by using the plot of
Decision step 554 determines if there is a next WLL to program. If decision step 554 is true, step 540 is repeated. If decision step 554 is false, the process is done at step 556.
During a program pulse, a bit line voltage (Vbl) is set to a level such as 0 V on selected NAND strings, or to an inhibit level such as 2-3 V on unselected NAND strings. Example programming techniques which can be used in step 544 follow. For one pass programming, the #loops in decision step 546 is for the one pass. For two or more pass programming, the #loops in decision step 546 can be for a selected pass.
Example Vth distributions for the memory cell array are provided for a case where each memory cell stores two bits of data. Each graph depicts Vth on the horizontal axis and a number or population of memory cells in a Vth distribution on the vertical axis. One bit represents the LP data and the other bit represents the UP data. A bit combination can be denoted by the UP bit followed by the LP bit, e.g., 11 denotes UP=1 and LP=1, 01 denotes UP=0 and LP=1, 00 denotes UP=0 and LP=0 and 10 denotes UP=1 and LP=0. A first Vth distribution 600 is provided for erased (Er) state memory cells. Three Vth distributions 604, 606 and 608 represent target data states A, B and C, respectively, which are reached by memory cells when their Vth exceeds the nominal (higher) verify level VvA, VvB or VvC, respectively. In this case, each memory cell can store two bits of data in one of four possible Vth ranges, referred to as states Er (or E), A, B and C. A program option which uses a slow programming mode may be referred to as a “quick pass write” (QPW) technique. QPW can be used independently in one or more passes of a multiple pass programming technique. Although, generally, it is sufficient to use QPW in the final programming pass when accuracy is most important. QPW mode and slow programming mode are used interchangeably herein.
When QPW is used, lower verify levels (VvAL, VvBL or VvCL) are defined such that the memory cells enter a slow programming mode or zone (e.g., by raising the associated bit line voltages applied during program) when their Vth is between the lower verify level and the higher verify level of a respective target data state. The lower verify levels are offset below the respective higher verify levels, in one implementation. Specifically, when a verify test determines that the Vth of a memory cell exceeds the lower verify level associated with the target data state of the memory cell, a slow programming mode begins for the memory cell. Subsequently, when a verify test determines that the Vth of a memory cell exceeds the higher verify level associated with the target data state of the memory cell, the memory cell is inhibited from further programming. In some cases, QPW is used on fewer than all target data states.
The specific relationship between the data programmed into a memory cell and the Vth level of the memory cell depends upon the data encoding scheme adopted for the memory cells. In one embodiment, data values are assigned to the Vth ranges using a Gray code assignment so that if the Vth of a floating gate erroneously shifts to its neighboring physical state, only one bit will be affected. One example assigns “11,” “01,” “00” and “10” to the E, A, B- and C-states. Read reference voltages which are between the distributions are used for reading data from the memory cells. By testing whether the Vth of a given memory cell is above or below one or more of the read reference voltages, the system can determine the data state which is represented by a memory cell.
Programming can be similarly extended to three or more bits per memory cell.
In one approach, the program pulses are stepped up in successive iterations by a step size, dVpgm. Moreover, each program pulse may include a first portion which has a pass voltage (Vpass) level, e.g., 6-8 V, followed by a second, peak amplitude portion at a program level, e.g., 12-25 V. For example, this programming pass includes program pulses 901-905 and associated sets of verify pulses 911-915, respectively. As discussed, the initial program pulse has a magnitude of Vpgm_initial=Vpgm_ref+Vpgm_trim. In this example, the verify pulses have a magnitude of VvA, VvB and VvC, corresponding to the programming process of
Before the memory cells have been read, there will be no read disturb, so that the erased state distribution 901 will remain below Vv_Er. Assume the distributions are for memory cells in one WLL. When memory cells in another WLL are sensed, Vrp_fixed is applied to the one WLL and the remaining WLLs. Vrp_fixed is sufficiently higher than Vut3 to cause all of the memory cells of the one word line layer to be in a conductive state. That is, Vrp_fixed meets a certain control gate over-drive requirement on all the unselected WLLs to guarantee that the memory cell current is above a certain level. This gate over-drive requirement, together with the highest state verify level, determines the minimum Vrp we can use without compromising the cell current.
The read levels are VrA, VrB and VrC. The verify voltages for the A, B and C states are VvA, VvB and VvC, respectively.
Vut2 can be significantly higher than Vut1 (e.g., 1 V or more) due to variations between the narrowest and widest portions of the memory hole, so that the memory cells at the narrowest portions of the memory hole can represent a worst case read disturb. Thus, if the same Vrp is applied on all WLLs, the memory cells on the WLLs with the smallest memory hole diameter will be a bottleneck limiting the overall read disturb reliability.
A read window (Vrdw) can be defined as a difference between the upper tail of the erased state and the verify level of the highest state. For the distribution 902, the read window is VvC-Vut1. For the distribution 903, the read window is VvC-Vut2.
The increase in the upper tail (or the decrease in the read window) can lead to E to A-state read failures. For example, a portion of the Vth distribution 903 which exceeds VrA represents memory cells which will be read incorrectly as being in the A-state instead of the E-state.
In these examples, the unselected WLLs comprise memory cells which are programmed to a highest programmed data state (e.g., C state) of a plurality of data states (e.g., A, B and C states) using a common program-verify voltage (e.g., VvC). Further, a difference between the common program-verify voltage and the read pass voltages is relatively larger for the WLLs of the unselected large Dmh WLLs. For instance, the difference is Vrp_max−VvC for the unselected large Dmh WLLs, and Vrp_min−VvC for the unselected small Dmh WLLs, where (Vrp_max−VvC)>(Vrp_min−VvC).
A proposal is to use a Vrp which is lower than a nominal Vrp on small Dmh WLLs. To compensate for a reduction in cell current for these layers, a higher Vrp is applied on the large Dmh WLLs. With the lower Vrp on the small Dmh WLLs, the worst case read disturb can be improved. With a higher Vrp on the larger Dmh WLLs, the read disturb will become worse, but this is tolerable because it will be no worse than for the small Dmh WLLs, with the proper selection of Vrp.
In contrast, plot 1007 represents the case where Vrp increases as Dmh increases. Vrp varies between Vrp_min and Vrp_max. In this case, the erase state upper tail (plot 1001) is approximately constant as Dmh increases. As a result, with Vvc fixed (plot 1005), the read window Vrdw (plot 1002) is approximately constant as Dmh increases. Vrp can be varied based on control settings as mentioned. As an example, Vrp_fixed can be 7.5 V, Vr_min can be 7 V and Vrp_max can be 8 V. VvC can be 5 V.
The techniques provided herein select Vrp to reduce the worst case read disturb, make read disturb approximately uniform for different WLLs, and provide an overall improvement in the read disturb characteristics of a memory device.
This is an example of the read pass voltages being relatively lower when the respective programming speeds are relatively higher. Also, the trim values are relatively higher when the respective programming speeds are relatively lower.
Accordingly, it can be seen that, in one embodiment, a method for sensing in a 3d non-volatile memory device comprises: selecting a set of memory cells in a selected word line layer (e.g., one word line layer) of a plurality of word line layers to sense data, the plurality of word line layers are arranged alternatingly with dielectric layers in a stack, and memory cells in the set of memory cells in the selected word line layer are arranged in respective memory holes which extend through the stack, the respective memory holes having respective widths which vary along the memory holes; and in response to the selecting, sensing the set of memory cells in the selected word line layer, the sensing comprises applying a sense voltage to the selected word line layer while applying read pass voltages (Vrp) to unselected word line layers (e.g., remaining word line layers) of the plurality of word line layers, wherein the read pass voltages are relatively lower for word line layers of the unselected word line layers which are adjacent to relatively narrower portions of the memory holes.
In another embodiment, a 3d non-volatile memory device comprises: a plurality of word line layers arranged alternatingly with dielectric layers in a stack; a plurality of memory cells arranged in NAND strings and in communication with the plurality of word line layers, the NAND strings are arranged in respective memory holes which extend through the stack, the respective memory holes having respective widths which vary along the memory holes; and a control circuit. The control circuit, to sense data from a set of memory cells in selected word line layer of the plurality of word line layers: applies a sense voltage to the selected word line layer while applying read pass voltages (Vrp) to unselected word line layers of the plurality of word line layers, wherein the read pass voltages are relatively lower for word line layers of the unselected word line layers which are adjacent to relatively narrower portions of the memory holes.
In another embodiment, a method for configuring a 3d non-volatile memory device comprises: determining a programming speed of memory cells of a selected word line layer (e.g., one word line layer) among a plurality of word line layers which are arranged alternatingly with dielectric layers in a stack, wherein the memory cells are arranged in respective memory holes which extend through the stack, and the respective memory holes have respective widths which vary along the memory holes; determining a read pass voltage for use in a sensing operation for the selected word line layer based on the programming speed; and storing data in a storage location of the 3d non-volatile memory device identifying the read pass voltage.
The method further includes determining a programming speed of memory cells of another word line layer (e.g., any other word line layer) among the plurality of word line layers; determining a read pass voltage for use in a sensing operation for the another word line layer based on the programming speed of the memory cells of the another word line layer; and storing data in a storage location of the 3d non-volatile memory device identifying the read pass voltage for use in the sensing operation for the another word line layer.
The foregoing detailed description of the invention has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. The described embodiments were chosen in order to best explain the principles of the invention and its practical application, to thereby enable others skilled in the art to best utilize the invention in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the claims appended hereto.
Claims
1. A method for sensing in a 3d non-volatile memory device, comprising:
- selecting a set of memory cells in a selected word line layer of a plurality of word line layers to sense data, the plurality of word line layers are arranged alternatingly with dielectric layers in a stack, and memory cells in the set of memory cells in the selected word line layer are arranged in respective memory holes which extend through the stack, the respective memory holes having respective widths which vary along the memory holes; and
- in response to the selecting, sensing the set of memory cells in the selected word line layer, the sensing comprises applying a sense voltage to the selected word line layer while applying read pass voltages (Vrp) to unselected word line layers of the plurality of word line layers, wherein the read pass voltages are relatively lower for word line layers of the unselected word line layers which are adjacent to relatively narrower portions of the memory holes.
2. The method of claim 1, further comprising:
- obtaining data which indicates respective programming speeds of memory cells of the unselected word line layers, wherein the read pass voltages are based on the data which indicates the respective programming speeds of memory cells of the unselected word line layers, and the read pass voltages are relatively lower when the respective programming speeds are relatively higher.
3. The method of claim 2, wherein:
- the data which indicates the respective programming speeds of memory cells of the unselected word line layers comprises data which indicates trim values of initial programming voltages for the unselected word line layers; and
- the trim values are relatively higher when the respective programming speeds are relatively lower.
4. The method of claim 2, wherein:
- the data which indicates the respective programming speeds of memory cells of the unselected word line layers comprises data which indicates initial programming voltages for the unselected word line layers; and
- the initial programming voltages are relatively higher when the respective programming speeds are relatively lower.
5. The method of claim 2, wherein:
- the data which indicates the respective programming speeds of memory cells of the unselected word line layers is read from a storage location in the 3d non-volatile memory device.
6. The method of claim 2, wherein:
- the data which indicates the respective programming speeds of memory cells of the unselected word line layers is determined in a wafer die sort process involving the 3d non-volatile memory device.
7. The method of claim 1, wherein:
- the unselected word line layers comprise memory cells which are programmed to a highest programmed data state of a plurality of data states using a common program-verify voltage; and
- a difference between the common program-verify voltage and the read pass voltages is relatively larger for the word line layers of the unselected word line layers which are adjacent to relatively wider portions of the memory holes.
8. The method of claim 1, wherein:
- the unselected word line layers of the plurality of word line layers comprise groups of adjacent word line layers; and
- the read pass voltages are common within each group of word line layers.
9. The method of claim 1, wherein:
- the sensing is performed in a read operation.
10. A 3d non-volatile memory device, comprising:
- a plurality of word line layers arranged alternatingly with dielectric layers in a stack;
- a plurality of memory cells arranged in NAND strings and in communication with the plurality of word line layers, the NAND strings are arranged in respective memory holes which extend through the stack, the respective memory holes having respective widths which vary along the memory holes; and
- a control circuit, the control circuit, to sense data from a set of memory cells in selected word line layer of the plurality of word line layers: applies a sense voltage to the selected word line layer while applying read pass voltages (Vrp) to unselected word line layers of the plurality of word line layers, wherein the read pass voltages are relatively lower for word line layers of the unselected word line layers which are adjacent to relatively narrower portions of the memory holes.
11. The 3d non-volatile memory device of claim 10, wherein:
- the respective widths are progressively smaller closer to a bottom of the stack.
12. The 3d non-volatile memory device of claim 10, wherein:
- the memory holes are columnar and extend at least from a top word line layer of the plurality of word line layers to a bottom word line layer of the plurality of word line layers.
13. The 3d non-volatile memory device of claim 10, further comprising:
- obtaining data which indicates respective programming speeds of memory cells of the unselected word line layers, wherein the read pass voltages are based on the data which indicates the respective programming speeds of memory cells of the unselected word line layers, and the read pass voltages are relatively lower when the respective programming speeds are relatively higher.
14. The 3d non-volatile memory device of claim 13, wherein:
- the data which indicates the respective programming speeds of memory cells of the unselected word line layers comprises data which indicates trim values of initial programming voltages for the unselected word line layers; and
- the trim values are relatively higher when the respective programming speeds are relatively lower.
15. The 3d non-volatile memory device of claim 10, wherein:
- the unselected word line layers comprise memory cells which are programmed to a highest programmed data state of a plurality of data states using a common program-verify voltage; and
- a difference between the common program-verify voltage and the read pass voltages is relatively larger for the word line layers of the unselected word line layers which are adjacent to relatively wider portions of the memory holes.
16. A method for configuring a 3d non-volatile memory device, comprising:
- determining a programming speed of memory cells of a selected word line layer among a plurality of word line layers which are arranged alternatingly with dielectric layers in a stack, wherein the memory cells are arranged in respective memory holes which extend through the stack, and the respective memory holes have respective widths which vary along the memory holes;
- determining a read pass voltage for use in a sensing operation for the selected word line layer based on the programming speed; and
- storing data in a storage location of the 3d non-volatile memory device identifying the read pass voltage.
17. The method of claim 16, wherein:
- the determining the programming speed of the memory cells of the selected word line layer is performed in a wafer die sort process.
18. The method of claim 16, wherein:
- the storage location comprise a ROM fuse.
19. The method of claim 16, further comprising:
- determining a programming speed of memory cells of another word line layer among the plurality of word line layers;
- determining a read pass voltage for use in a sensing operation for the another word line layer based on the programming speed of the memory cells of the another word line layer; and
- storing data in a storage location of the 3d non-volatile memory device identifying the read pass voltage for use in the sensing operation for the another word line layer.
20. The method of claim 16, wherein:
- the data which indicates the programming speed of the memory cells of the selected word line layer comprises data which indicates a trim value of an initial programming voltage for the selected word line layer.
Type: Application
Filed: Sep 12, 2013
Publication Date: Mar 12, 2015
Applicant: SanDisk Technologies Inc. (Plano, TX)
Inventors: Yingda Dong (San Jose, CA), Chenfeng Zhang (San Jose, CA), Wendy Ou (San Jose, CA), Seung Yu (San Ramon, CA), Masaaki Higashitani (Cupertino, CA)
Application Number: 14/025,160
International Classification: G11C 16/26 (20060101);