Program temperature dependent read
Methods and non-volatile storage systems are provided for using compensation that depends on the temperature at which the memory cells were programmed. Note that the read level compensation may have a component that is not dependent on the memory cells' Tco. That is, the component is not necessarily based on the temperature dependence of the Vth of the memory cells. The compensation may have a component that is dependent on the difference in width of individual Vth distributions of the different states across different temperatures of program verify. This compensation may be used for both verify and read, although a different amount of compensation may be used during read than during verify.
Latest SanDisk Technologies Inc. Patents:
The present disclosure relates to technology for non-volatile memory.
Semiconductor memory has become increasingly popular for use in various electronic devices. For example, non-volatile semiconductor memory is used in cellular telephones, digital cameras, personal digital assistants, mobile computing devices, non-mobile computing devices and other devices. Electrically Erasable Programmable Read Only Memory (EEPROM) and flash memory are among the most popular non-volatile semiconductor memories. With flash memory, also a type of EEPROM, the contents of the whole memory array, or of a portion of the memory, can be erased in one step, in contrast to the traditional, full-featured EEPROM. The array of storage elements may be divided into a large number of blocks of storage elements.
Both the traditional EEPROM and the flash memory utilize a floating gate that is positioned above and insulated from a channel region in a semiconductor substrate. The floating gate is positioned between the source and drain regions. A control gate is provided over and insulated from the floating gate. The threshold voltage (Vth) of the transistor thus formed is controlled by the amount of charge that is retained on the floating gate. That is, the minimum amount of voltage that must be applied to the control gate before the transistor is turned on to permit conduction between its source and drain is controlled by the level of charge on the floating gate. Thus, a storage element may be read by applying a reference voltage to its control gate and sensing the magnitude of the current that flows between its drain and source.
A storage element may be programmed by applying suitable programming voltages to its control gate. Typically, a program voltage Vpgm applied to the control gate during a program operation is applied as a series of pulses that increase in magnitude over time.
Typically, the Vth of the memory cell varies with temperature. If the same memory cell is read at different temperatures, its Vth typically shifts lower as the temperature increases. The Vth shift per temperature unit is defined as the Temperature Coefficient (or simply Tco) for that memory cell. For some devices, Tco is a negative quantity since the Vth reduces as the temperature increases.
This shift is depicted in
One possible way to compensate for this Vth temperature dependence is to determine read levels according to an equation such as Equation 1.
R(atT)=R0+Tco*T Eq. 1
In Equation 1, R is the read level for a given state, R0 is a base read reference voltage for that state, T is the temperature during read, and Tco is the temperature coefficient which may be optimized by matching it with the memory cell Tco. Note that Tco may be a function of the state being read. As one example, a result of applying Equation 1 may be to determine level VrB for the low-temperature read and VrB′ for the high-temperature read (see
Further complicating the situation is that the memory cells could be programmed at different temperatures. For example, memory cells in one block (or some other unit) in the memory could be programmed at a high temperature and another block at a low temperature. In one scenario, the different blocks may be read back at the same read temperature. For example, there may be a high-temperature program paired with a high-temperature read, as well as a low-temperature program paired with a high-temperature read. In another scenario, the different blocks may read back at different read temperatures. For example, there may be a high-temperature program paired with a high-temperature read, as well as a low-temperature program paired with a low-temperature read.
If the same program verify levels are used at different temperatures, it would lead to different Vth distribution positions for the blocks programmed at different temperatures due to the Tco of the memory cells. This is true even if both blocks are read at the same temperature. This is also true even if temperature compensation is used during read for the case that reading is performed at different temperatures. Thus, simply having a Tco on read levels is not sufficient to take care of different programming temperatures.
To resolve the problem of different programming temperatures, the same Tco may also be applied to all the verify levels (not depicted in
Note that to achieve the above, the value for Tco used on read/verify levels needs to be optimized such that it matches with the memory cell Tco (the rate at which typical cell's Vth moves with temperature). Also there may be state dependency in the memory cell Tco, which means different Tco values may be used to determine read and verify reference levels for different states.
Methods and non-volatile storage systems are provided for programming and reading non-volatile storage. In one embodiment, memory cells are read using read levels (or read level compensation) that depend on the temperature at which the memory cells were programmed and verified. Note that in one embodiment the read level compensation has a component that is not dependent on the memory cells' Tco. That is, the component is not based on the temperature dependence of the Vth of the memory cells. In one embodiment, the sensing compensation has a component that is dependent on the temperature dependence of width of individual Vth distributions of the different states. This compensation may be used for both verify and read, although a different amount of compensation may be used during read than during verify.
Note that a Tco-scheme discussed in the background assumes that the Vth distribution widths of programmed states are independent of the temperature at which the data is programmed. Under this assumption, the Vth distributions at read align well for the cases when data is programmed at different temperatures and read back at same read temperature. However, in practice the Vth distribution widths may be temperature dependent.
One consequence of the temperature dependent Vth distribution widths is that optimum read levels at any given read temperature may depend on the program temperature. Thus, by saving the program temperature and using it to determine read levels, read errors may be reduced.
If the individual Vth distribution widths are temperature dependent, then the gaps between the individual Vth distribution for adjacent states may also vary with temperature. As one example, if the Vth distribution widths are wider with lower temperature, then the gaps between states may be larger with increasing temperature. In one embodiment, these gaps are reduced by providing temperature dependent verify reference levels. The total amount of gaps between all states may be referred to herein as a “threshold voltage distribution window.” Thus, without compensation, this window may be larger for higher program temperatures. In one embodiment, programming at a low temperature is a worst case scenario because the window is smallest for the lowest operating temperature. The window at higher temperatures may not need to be this large to accurately read the memory cells. Therefore, the window may be reduced such that it is about the same size across a wide range of temperatures (although uniformity is not required). Stated another way, the window may be reduced for other than the worst case scenario, where the reduction depends on how much read margin (e.g., how much window) is desired. As will be discussed more fully below, shrinking the window at higher (and other) program temperatures may be used to help reduce total read errors.
Example Memory System and Operation
One example of a memory system suitable for implementing embodiments uses a NAND flash memory architecture, which includes connecting multiple transistors in series between two select gates. The transistors connected in series and the select gates are referred to as a NAND string.
For example, NAND string 320 includes select gates 322 and 327, and storage elements 323-326, NAND string 340 includes select gates 342 and 347, and storage elements 343-346, NAND string 360 includes select gates 362 and 367, and storage elements 363-366. Each NAND string is connected to the source line by its select gates (e.g., select gates 327, 347 or 367). A selection line SGS is used to control the source side select gates. The various NAND strings 320, 340 and 360 are connected to respective bit lines 321, 341 and 361, by select transistors in the select gates 322, 342, 362, and so forth. These select transistors are controlled by a drain select line SGD. In other embodiments, the select lines do not necessarily need to be in common among the NAND strings; that is, different select lines can be provided for different NAND strings. WL3 is connected to the control gates for storage elements 323, 343 and 363. WL2 is connected to the control gates for storage elements 324, 344 and 364. WL1 is connected to the control gates for storage elements 325, 345 and 365. WL0 is connected to the control gates for storage elements 326, 346 and 366. As can be seen, each bit line and the respective NAND string comprise the columns of the array or set of storage elements. The word lines (WL3, WL2, WL1 and WL0) comprise the rows of the array or set. Each word line connects the control gates of each storage element in the row. Or, the control gates may be provided by the word lines themselves. For example, WL2 provides the control gates for storage elements 324, 344 and 364. In practice, there can be thousands of storage elements on a word line.
In some embodiments, the voltage applied to the bit line is greater than the voltage applied to source when reading a memory cell on the NAND string. In some embodiments, the voltage applied to the bit line is less than the voltage applied to source when reading a memory cell on the NAND string. For consistency of discussion, the source line will always be referred to as a source line regardless of whether the voltage applied to it is less than or greater than the voltage applied to the bit line.
Each storage element can store data. For example, when storing one bit of digital data, the range of possible threshold voltages (VTH) of the storage element is divided into two ranges which are assigned logical data “1” and “0.” In one example of a NAND type flash memory, the VTH is negative after the storage element is erased, and defined as logic “1.” The VTH after a program operation is positive and defined as logic “0.” When the VTH is negative and a read is attempted at a suitable read level, the storage element will turn on to indicate logic “1” is being stored. When the VTH is positive and a read operation is attempted, the storage element will not turn on, which indicates that logic “0” is stored. A storage element can also store multiple levels of information, for example, multiple bits of digital data. In this case, the range of VTH value is divided into the number of levels of data. For example, if four levels of information are stored, there will be four VTH ranges assigned to the data values “11”, “10”, “01”, and “00.” In one example of a NAND type memory, the VTH after an erase operation is negative and defined as “11”. Positive VTH values are used for the states of “10”, “01”, and “00.” The specific relationship between the data programmed into the storage element and the threshold voltage ranges of the storage element depends upon the data encoding scheme adopted for the storage elements.
When programming a flash storage element, a program voltage is applied to the control gate of the storage element, and the bit line associated with the storage element is grounded. Electrons from the channel are injected into the floating gate. When electrons accumulate in the floating gate, the floating gate becomes negatively charged and the VTH of the storage element is raised. To apply the program voltage to the control gate of the storage element being programmed, that program voltage is applied on the appropriate word line. As discussed above, one storage element in each of the NAND strings share the same word line. For example, when programming storage element 324 of
Control circuitry 220 cooperates with the read/write circuits 230A and 230B to perform memory operations on the memory array 200. The control circuitry 220 includes a state machine 222, an on-chip address decoder 224, a power control module 226, a temperature sensor 228, and temperature dependent circuit 229. The state machine 222 provides chip-level control of memory operations. The on-chip address decoder 224 provides an address interface to convert between the address that is used by the host or a memory controller to the hardware address used by the decoders 240A, 240B, 242A, and 242B. The power control module 226 controls the power and voltages supplied to the word lines and bit lines during memory operations. In one embodiment, power control module 226 includes one or more charge pumps that can create voltages larger than the supply voltage.
The temperature sensor 228 is able to sense and provide an indication of the present temperature. The temperature dependent circuit 229 is able to provide a signal that depends on the temperature. As one example, it might provide a reference voltage whose magnitude depends on temperature. Various techniques are known for providing temperature-compensated signals. One or more of these techniques can be used in the temperature-dependent circuit 229. Most of these techniques do not rely on obtaining an actual temperature measurement, although this approach is also possible. For example, U.S. Pat. No. 6,801,454, titled “Voltage Generation Circuitry Having Temperature Compensation,” incorporated herein by reference, describes a voltage generation circuit which outputs read voltages to a non-volatile memory based on a temperature coefficient. The circuit uses a band gap current which includes a temperature-independent portion and a temperature-dependent portion which increases as temperature increases. Other techniques may be used. In one embodiment, the temperature-dependent circuit 229 outputs a signal that depends at least in part on temperature information that is provided to the temperature-dependent circuit 229. For example, temperature information may be stored during program verify, then used as input to the temperature-dependent circuit 229 during read. Thus, the temperature-dependent circuit 229 may provide a signal that depends, at least in part, on a temperature at a previous time. The signal may also depend, at least in part, on the present temperature.
In one embodiment, one or any combination of control circuitry 220, power control circuit 226, decoder circuit 224, state machine circuit 222, decoder circuit 242A, decoder circuit 242B, decoder circuit 240A, decoder circuit 240B, read/write circuits 230A, read/write circuits 230B, and/or controller 244 can be referred to as one or more managing circuits.
In another embodiment, the bit lines are divided into odd bit lines and even bit lines. In an odd/even bit line architecture, memory cells along a common word line and connected to the odd bit lines are programmed at one time, while memory cells along a common word line and connected to even bit lines are programmed at another time.
Sense module 480 comprises sense circuitry 470 that determines whether a conduction current in a connected bit line is above or below a predetermined threshold level. In some embodiments, sense module 480 includes a circuit commonly referred to as a sense amplifier. Sense module 480 also includes a bit line latch 482 that is used to set a voltage condition on the connected bit line. For example, a predetermined state latched in bit line latch 482 will result in the connected bit line being pulled to a state designating program inhibit (e.g., Vdd).
Common portion 490 comprises a processor 492, a set of data latches 494 and an I/O Interface 496 coupled between the set of data latches 494 and data bus 471. Processor 492 performs computations. For example, one of its functions is to determine the data stored in the sensed memory cell and store the determined data in the set of data latches. The set of data latches 494 is used to store data bits determined by processor 492 during a read operation. It is also used to store data bits imported from the data bus 471 during a program operation. The imported data bits represent write data meant to be programmed into the memory. I/O interface 496 provides an interface between data latches 494 and the data bus 471.
During read or sensing, the operation of the system is under the control of state machine 222 that controls the supply of different control gate voltages to the addressed cell. As it steps through the various predefined control gate voltages corresponding to the various memory states supported by the memory, the sense module 480 may trip at one of these voltages and an output will be provided from sense module 480 to processor 492 via bus 472. At that point, processor 492 determines the resultant memory state by consideration of the tripping event(s) of the sense module and the information about the applied control gate voltage from the state machine via input lines 493. It then computes a binary encoding for the memory state and stores the resultant data bits into data latches 494. In another embodiment of the core portion, bit line latch 482 serves double duty, both as a latch for latching the output of the sense module 480 and also as a bit line latch as described above.
It is anticipated that some implementations will include multiple processors 492. In one embodiment, each processor 492 will include an output line (not depicted in
During program or verify, the data to be programmed is stored in the set of data latches 494 from the data bus 471. The program operation, under the control of the state machine, comprises a series of programming voltage pulses (with increasing magnitudes) applied to the control gates of the addressed memory cells. Each programming pulse may be followed by a verify process to determine if the memory cell has been programmed to the desired state. Processor 492 monitors the verified memory state relative to the desired memory state. When the two are in agreement, processor 492 may set the bit line latch 482 so as to cause the bit line to be pulled to a state designating program inhibit. This inhibits the cell coupled to the bit line from further programming even if it is subjected to programming pulses on its control gate. In other embodiments the processor initially loads the bit line latch 482 and the sense circuitry sets it to an inhibit value during the verify process.
Data latch stack 494 contains a stack of data latches corresponding to the sense module. In one embodiment, there are 3-5 (or another number) data latches per sense module 480. In one embodiment, the latches are each one bit. In some implementations (but not required), the data latches are implemented as a shift register so that the parallel data stored therein is converted to serial data for data bus 471, and vice versa. In one embodiment, all the data latches corresponding to the read/write block of M memory cells can be linked together to form a block shift register so that a block of data can be input or output by serial transfer. In particular, the bank of read/write modules is adapted so that each of its set of data latches will shift data in to or out of the data bus in sequence as if they are part of a shift register for the entire read/write block.
Additional information about the read operations and sense amplifiers can be found in (1) U.S. Pat. No. 7,196,931, “Non-Volatile Memory And Method With Reduced Source Line Bias Errors,”; (2) U.S. Pat. No. 7,023,736, “Non-Volatile Memory And Method with Improved Sensing,”; (3) U.S. Pat. No. 7,046,568; (4) U.S. Pat. No. 7,196,928, “Compensating for Coupling During Read Operations of Non-Volatile Memory,” and (5) U.S. Pat. No. 7,327,619, “Reference Sense Amplifier For Non-Volatile Memory”. All five of the immediately above-listed patent documents are incorporated herein by reference in their entirety.
At the end of a successful programming process (with verification), the threshold voltages of the memory cells should be within one or more distributions of threshold voltages for programmed memory cells or within a distribution of threshold voltages for erased memory cells, as appropriate.
In some embodiments, there may be some overlap between threshold voltage distributions.
Although the programming examples depict eight data states and three pages of data, the concepts taught can be applied to other implementations with more or fewer than eight states and more or fewer than three pages. Moreover, in the example programming techniques discussed, the Vth of a storage element is raised gradually as it is programmed to a target data state. However, programming techniques can be used in which the Vth of a storage element is lowered gradually as it is programmed to a target data state. Programming techniques which measure storage element current can be used as well. The concepts herein can be adapted to the different programming techniques.
Also note that contrary to the equal spacing/width of the depicted threshold voltage distributions, various distributions may have different widths/spacings in order to accommodate varying amounts of susceptibility to data retention loss.
In some embodiments, a “verify low” and a “verify high” reference voltage is used.
Read reference voltages, VrA, VrB and VrC, are also provided for reading data from storage elements. By testing whether the threshold voltage of a given storage element is above or below VrA, VrB and VrC, the system can determine the state, e.g., programming condition, the storage element is in.
Further, verify reference voltages, VvA, VvB, and VvC are provided. When programming storage elements to the A-state, B-state or C-state, the system will test whether those storage elements have a threshold voltage greater than or equal to VvA, VvB or VvC, respectively. In one embodiment, “verify low” reference voltages, VvaL, VvbL, and VvcL are provided. Similar “verify low” reference voltages could also be used in embodiments with a different number of states.
In full sequence programming, storage elements can be programmed from the Erased-state directly to any of the programmed states A, B or C. For example, a population of storage elements to be programmed may first be erased so that all storage elements in the population are in the Erased-state. A series of program pulses such as depicted in
One example of a slow programming mode uses low (offset) and high (target) verify levels for one or more data states. For example, VvaL and VvA are offset and target verify levels, respectively, for the A-state, and VvbL and VvB are offset and target verify levels, respectively, for the B-state. During programming, when the threshold voltage of a storage element which is being programmed to the A-state as a target state (e.g., an A-state storage element) exceeds VvaL, its programming speed is slowed, such as by raising the bit line voltage to a level, e.g., 0.6-0.8 V, which is between a nominal program or non-inhibit level, e.g., 0 V and a full inhibit level, e.g., 2-3 V. This provides greater accuracy by avoiding large step increases in threshold voltage. When the threshold voltage reaches VvA, the storage element is locked out from further programming. Similarly, when the threshold voltage of a B-state storage element exceeds VvbL, its programming speed is slowed, and when the threshold voltage reaches VvB, the storage element is locked out from further programming. In one approach, a slow programming mode is not used for the highest state since some overshoot is typically acceptable. Instead, the slow programming mode can be used for the programmed states, above the erased state, and below the highest state.
Moreover, in the example programming techniques discussed, the threshold voltage of a storage element is raised as it is programmed to a target data state. However, programming techniques can be used in which the threshold voltage of a storage element is lowered as it is programmed to a target data state. Programming techniques which measure storage element current can be used as well. The concepts herein can be adapted to different programming techniques.
In one embodiment, the verify levels that are used are compensated based on temperature. One factor in the compensation may be the Tco, or temperature dependence of the memory cells Vt. However, the compensation may also be based on one or more factors that are independent of Tco. That is, the compensation is not simply used to adjust for the temperature dependence of the memory cell's Vt. In one embodiment, the Tco-independent component of the compensation depends on temperature dependence of the individual threshold distributions of the memory cells. In one embodiment, the compensation has a component that compresses the Vth distribution window of the memory cells as a function of temperature. For example, there may be more compression of the Vth distribution window with higher temperature. As noted above, the Vth distribution window may be defined as the total amount of gaps between the individual Vth distributions for all adjacent states.
In step 804, an indication of the temperature at which program verify was performed is stored. There are many ways to store this indication of temperature. In one embodiment, some indication is stored in spare memory cells on the word line being programmed. Details of determining the temperature are discussed in connection with
In step 806, the group of non-volatile storage elements are read using compensation that depends on the temperature during the program verify. In one embodiment, this read compensation compensates for temperature dependence of Vth distribution widths that occurred during program verify. Thus, using read levels that depend on program verify temperature may provide more accurate read levels, which may minimize the overall read errors. In one embodiment, the read compensation compensates for shifts in verify levels that result from using compensation during program verify that depends on the temperature dependence of Vth distributions.
In one embodiment, the compensation is to adjust the read levels. For example, referring to
Note that the compensation of step 806 is different from performing a read using compensation that depends only on the temperature during read. As noted, such compensation may compensate only for the temperature dependence (Tco) of the memory cell's Vt. However, note that the read levels in step 806 may be determined, in part, based on the present temperature in order to compensate for the memory cells' Tco.
Note that any amount of time may pass between the program verify and the read. The temperature during read may be the same as, higher than, or lower than the temperature during program verify.
In step 810, the program voltage (Vpgm) is set to an initial value. Also, in step 810, a program counter (PC) is initialized to zero. In step 811, temperature information is determined. In one embodiment, the system will take a reading of the current temperature. In one embodiment, there is a temperature sensor 228 in communication with controller 244, state machine 222, or other circuits. In another embodiment, temperature sensor 228, on the memory chip, is used to provide temperature data to state machine 222, controller 244, or another circuit. In another embodiment, controller 244 includes an onboard temperature sensor. In another embodiment, the host will provide temperature data to controller 244. No specific means for obtaining the current temperature is required.
In one embodiment, a temperature dependent circuit 229 is used to produce a signal that depends, at least in part on the present temperature. As one example, circuit 229 could produce a reference current or voltage whose magnitude depends on that current temperature.
In step 815, the temperature information is stored. This temperature information may be used during later reads to determine suitable read levels. The temperature information is provided from temperature sensor 228 in one embodiment. As one example, the temperature information may be a digital value that represents degrees (in any suitable scale). If temperature dependent circuit 229 was used to provide a reference current or voltage, then the temperature information may be based on this reference current or voltage. As one example, the temperature information may be a digital value that represents the magnitude of the reference current or voltage.
In step 817, suitable verify levels are determined. In one embodiment, suitable verify levels (e.g., VvA, VvB, VvC) are determined based on the present temperature. In one embodiment, suitable verify low levels (e.g., VvaL, VvbL, VvcL) are determined based on temperature. Note that compensating for temperature variations may have a component that depends on the memory cell's Tco and a component that is independent of the memory cell's Tco. In one embodiment, the component that is independent of the memory cell's Tco is used to compensate for temperature dependence of the individual threshold distribution widths for each state. Further details of the component that is independent of the memory cell's Tco are discussed below.
In one embodiment, determining the suitable verify levels includes accessing a lookup table. This lookup table may be based on Equation 2 below, but is not so limited. Note the determining suitable verify levels does not necessarily mean that an actual voltage level to apply to the selected word line needs to be determined. For example, a circuit such as temperature dependent circuit 229 may be used to generate a reference current or voltage whose magnitude depends on present temperature, and other inputs. One of those inputs could be a compensation factor (e.g., Tcoprogi in Equation 2 below). Thus, the suitable verify level may be based on the output reference current or voltage of temperature dependent circuit 229.
In step 820, a program pulse is applied. In step 822, a verification process is performed. As noted, the verify levels may be based on the present temperature.
In one embodiment, the verification is a concurrent coarse/fine verify. Referring to
In step 824, it is determined whether all of the memory cells have verified that their threshold voltages are at the final target voltage for that memory cell. If so, the programming process is completed successfully (status=pass) in step 826. If all of the memory cells are not verified to have reached their final target levels, then it is determined whether the program counter (PC) is less than a maximum value such as 20. If the program counter (PC) is not less than max (step 828), then the program process has failed (step 830). If the program counter (PC) is less than a maximum value (e.g., 20), then the program counter (PC) is incremented by one and the program voltage is stepped up to the next pulse in step 832. Subsequent to step 832, the process loops back to step 820 and the next program pulse is applied to the memory cells.
As noted, a conventional Tco-scheme discussed in the background assumes that the Vth distribution widths of programmed states are independent of the temperature at which the data is programmed. Then, the Vth distributions will align well when data programmed at different temperatures is read back at same temperature. However, in practice, the Vth distribution widths may be temperature dependent.
A possible cause of the Vth distribution widths being different is wider Vth lower-tails at lower temperature programming. A possible reason for this is that the trap time constant may be longer at lower temperature. Thus, if an electron gets trapped during the programming pulse (before the verify) at low temperature, then there is a greater chance that such an electron remains trapped during verify as well (compared to a high-temperature program). After programming and verifying is complete, the electron may eventually de-trap, leading to a Vth downshift resulting in a wider Vth distribution, especially on the lower-tail. This phenomenon of change in cell's Vth before and after verify, may also referred to as read/verify noise. In summary, the read/verify noise may be larger at low temperature leading to a wider lower-tail. The read/verify noise may tend to affect A-state cells the most, since A-verify is generally the first verify operation after the program pulse. However, B-state and C-state cells may also be affected by read/verify noise, although to a smaller degree. Thus, the difference in Vth distribution lower tails may tend to be largest for the A-state and gradually reduce for higher states such as the B-state and C-state.
The wider Vth distribution for lower temperatures are depicted in
Also note that there may be a greater gap between the upper tail of the A-state and the lower tail of the B-state for the high-temperature case than the others.
Thus, the gap between 0V and the A-state may be wider for the conventional high-temperature case than the conventional low-temperature case. Also, the gap between individual Vth distributions for the high-temperature case may be wider than the conventional low-temperature case for other states. Thus, the sum of these gaps may be greater for the conventional high-temperature case than for the conventional low-temperature case. The medium temperature gaps may be somewhere between the other two. Herein, the sum of the gaps may be referred to as the Vth distribution window.
Another aspect to note about the gaps in
Another way to think about the Vth distribution window is by referring to the Vth distribution widths. Referring to
Another aspect to note is that conventionally the Erase-to-A (or Er-A) failures may be quite high at higher programming temperatures. An Er-A failure refers to the situation in which a memory cell was intended to be in the erased state, but is read as being in the A-state.
A possible reason for the additional Er-A failures at higher programming temperatures is due to greater leakage of the boosting potential at higher temperatures. Note that the channel potential may be boosted during programming for the inhibited channels, to reduce or prevent program disturb (e.g., unintended programming). However, there may be some current that leaks between the boosted channel and the substrate, thereby reducing the boosting potential. This leakage may be greater at higher temperatures. Note that the number of Er-A failures may depend on a variety of factors.
Thus, the Er-A failures may be much greater for the high-temperature case. Also note that, as previously discussed, the conventional high-temperature programming case may allow for the total gap window to be compressed. Therefore, this compression may be taken advantage of to reduce Er-A failures.
Note that the upper tail of the A-state distribution may also have been shifted down more for higher temperatures, as a result of shifting the lower tail of the A-state down. However, the lower tail for the B-state may be shifted more than the upper tail for the A-state (referring to the high-temperature case). What this means is that the separation between the upper tail of the A-state and the lower tail of the B-state is reduced for the high-temperature case. This may be achieved by suitable selection of verify reference voltages. In other words, VvB may be shifted down more than VvA for the high temperature case than for the low-temperature case. In one embodiment, a different amount of compensation (based on temperature) is used for determining VvA than for VvB.
Note that an alternative to shifting the A-state down for higher temperatures may be to shift up the A-state distribution more for lower temperatures. Again, the gaps in
In one embodiment, the shifts to VvA and VvB are such that the gap between the Vth distributions for the A-state and B-state is about the same regardless of temperature. In contrast, using conventional compensation that only compensates for Tco, this gap size may depend on temperature. Note that it is not required in all embodiments to have the gap size uniform across the entire operating temperature range. However, as will be discussed more fully below, reducing the extra gap for higher (and possible moderate) temperatures can help to reduce failures, such as Er-A failures for higher (and possible moderate) temperatures.
Also note that while the foregoing discussion pertains to the gap between the A-state and B-state, gaps between other states may be adjusted based on the verify temperature. For example, the gap between the B-state and C-state might be wider at higher temperature if only compensation for Tco was used. In one embodiment, this gap is reduced for higher temperatures. In one embodiment, this gap is made to be approximately uniform across all operating temperatures. However, a uniform gap size is not required. As done for A-state and B-state, this may be achieved by determining a suitable reference voltage for verifying the C-state, wherein the reference voltage depends on the temperature of program. Also, as in the case for A-state and B-state, VvC may be shifted down more than VvB for the high temperature case than for the low-temperature case.
Referring back to
One aspect of the shift to the verify reference levels (which may be based on the program temperature dependence of Vth distribution widths) is that the Vth distributions for different program temperatures do not necessarily overlap. For example, the Vth distributions programmed at low temperature do not necessarily overlap with the Vth distributions programmed at high-temperature. In one embodiment, read levels should be in about the middle of the gap between two adjacent states. Referring to
In this example, the range of the gap (as measured from Vth of the upper tail to the Vth of the lower tail of adjacent states) may have been affected by the compensation used during verify. As discussed, the verify levels may be shifted based on the temperature dependence of the Vth distribution widths. Therefore, determining suitable read levels may compensate for the shift to the verify levels.
The following example will be used to illustrate the foregoing. Assume that the memory cells were programmed at a low-temperature (e.g., −30 C) and a high-temperature (e.g., 85 C). During read, the optimum read levels depend on the program verify temperature in one embodiment. For example, the optimum read level for VrB may be 150 mV less for memory cells programed at the high-temperature than for low-temperature programming. Note that this may assume reading back at the same temperature for each case. Also, this is just one example; the voltages could be greater or less. As one example, the optimum read level for VrC may be 165 mV less for memory cells programed at the high-temperature than for low-temperature. However, this is also just one example. Assuming, 150 mV less for VrB, the optimum read level for VrC could be more or less than 150 mV.
Further details of one embodiment of temperature compensation in which read level compensation depends on verify temperature will now be discussed. In one embodiment, Equation 2 is used to determine a suitable verify reference level, and Equation 3 is used to determine a suitable read reference level.
BV(atT):BV0+(Tco_prog1+Tco)*Tprog Eq. 2
BR(atT):BR0+Tco_prog2*Tprog+Tco*Tread Eq. 3
In Equation 2, BV0 is a base (or default) verify level for the B state. In Equation 3, BR0 is a base (or default) read level for the B state. Tprog is the temperature during program verify, and Tread is the temperature during read. Tco may be used to compensate for the temperature dependence of the memory cell's Vt. Tco_prog1 and Tco_prog2 may be independent of Tco. In other words, they may be independent of the temperature dependence of the memory cell's Vt. They may be a function of the program temperature dependence of Vth distribution widths. In other words, Tcoprogi and Tco_prog2 may compensate for the differences in Vth distribution widths at different program temperatures.
Note that a similar equation could be used to determine reference values for the A-state, C-state, and other states (if more states are used). In one embodiment, the value for Tco_prog1 depends on the state. In one embodiment, the value for Tco_prog2 depends on the state. In one embodiment, the values for both Tco_prog1 and Tco_prog2 depend on the state. In one embodiment, using different values for Tco_prog1 (for different states) may be used to control the gap between adjacent states.
In one embodiment, Tco_prog1 and Tco_prog2 are both negative values. Note that Tco may also be negative in value. Tco_prog1 and Tco_prog2 can be imagined as correction terms to correct the differences that are seen in programming behavior at different temperature. In one embodiment, for a specific state (such as B-state) the absolute magnitude of Tco_prog2<Tco_prog1, which means the shift on verify levels at higher temperature is larger than the shift on read levels for the same state.
This process may be used to read memory cells on a selected word line. In step 1202, the selected word line is read using a reference voltage that is suitable to read binary data. The data from the memory cells that store the temperature information is noted. In one embodiment, the temperature information is sent to control circuitry 220 such as the state machine 222. Thus, the temperature information could be stored in a temporary register in the state machine 222. In one embodiment, the temperature information is sent to the controller 244. The temperature information could be sent to other logic.
In one embodiment, several copies of the temperature information are read from the selected word line. These copies may be compared to determine whether they match. In one embodiment, as long as two of three copies match, the matching information is used. If all three copies are different, the temperature information could be ignored. In this case, compensation based on program verify temperature may be skipped. More or fewer than three copies could be used.
Any number of bits may be used to store the temperature information, depending on the desired granularity and temperature range. As one example, −30 C to 85 C could be used as the operating range, which means a 115 C temp range. To save temperature with 5 C resolution would need 5 bits. To save 2.5 C resolution would need 6 bits. As noted, two or three copies of these bits could to be programmed on the WL.
Also, note that the temperature information is not required to be a value that directly represents a temperature. For example, the temperature information might be a value that represents a reference current or reference voltage that was generated by, for example, temperature dependent circuit 229.
In step 1204, compensation based, at least in part, on the temperature at program verify is determined for reading at least one state. Note that “reading a state” as used herein refers to reading to determine whether memory cells have a Vth that is higher or lower than a reference voltage level associated with a state. As one example, a read reference level is determined based, at least in part, on the temperature at program verify. In one embodiment, Equation 3 is used. In one embodiment, the value for Tco_prog2 depends on the state. The read reference level may be determined either on chip (e.g., in control circuitry 220) or off chip (e.g., in controller 244). Note that step 1204 is not limited to determining read voltage levels to be applied to the selected word line. For example, step 1204 may determine how to modify a reference current that is used to sense memory cells. As another example, step 1204 may determine how to modify an integration time that is used to charge a sense capacitor used to sense memory cells.
In step 1206, reading is performing based on the temperature compensation. In one embodiment, the read reference voltage is applied to the selected word line is changed to provide the compensation. However, other techniques may be used to provide the temperature compensation. In one embodiment, the memory cells are read by comparing their conduction current to a sensing current. In one embodiment, the sensing current depends on the temperature during the verifying to provide the compensation. In one embodiment, the memory cells are read by sensing for a period of time. For example, a sense capacitor may be discharged (or charged) for some defined period of time. In one embodiment, the sensing time depends on the temperature during the verifying to provide the compensation. Step 1206 could include any combination of these techniques, or others.
In step 1222, temperature compensation is determined for reading other states. For example, read reference levels are determined for VrB, VrC, VrD, etc. Step 1222 may be similar to step 1204 from
In step 1302, a hot count is accessed. A hot count is the number of erase/write cycles for a block of memory cells, in one embodiment. The controller 244 may keep the hot count. In one embodiment, the hot count may be stored in extra memory cells in the block. In one embodiment, a different measure of erase/write cycles for a block may be used, such as the number of erase loops required to erase the block, or the average number of program loops required to program the WLs in the block. Such measures may also offer a good estimation of the number of erase/write cycles that the block has gone through.
In step 1304, a look up table for determining temperature compensation is accessed. In one embodiment, this table is based on Equation 3. However, another Equation could be used. As noted, different compensation may be used for different states. Thus, the lookup table may have separate entries for each state. In one embodiment, the controller 244 stores the table. However, the table could be stored elsewhere.
In step 1306, compensation that depends on the program verify temperature is determined. In this case, it is based on the hot count. As noted, a different measure of erase/write cycles for a block may be used, such as the number of erase loops required to erase the block, or the average number of program loops required to program the WLs in the block. This concludes discussion of
It may be that the entire block is programmed completely at once. In fact, it could be that typically the entire block is programmed completely at once. Thus, the temperature of program may be the same for each WL in the block. In this case, the temperature information might be saved on a single WL (or if desired multiple WLs). Regardless, when reading that block the temperature information only needs to be read once. The temperature information could be stored in a temperature register in the state machine 222, or elsewhere. Thus, if the read includes reading multiple WLs in the same block, time can be saved. Also note that any calculations or lookup table processing only needs to performed once per block. Similar methodology may be used for sets of blocks that are programmed at once.
One embodiment includes a method of operating non-volatile storage while providing for compensation that depends on the temperature at which the program verify was performed. The method includes verifying one or more program operations of a group of non-volatile storage elements in the non-volatile storage; storing an indication of temperature at which the verifying was performed; and later reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed.
One embodiment includes a non-volatile storage device comprising a plurality of non-volatile storage elements, a plurality of word lines, and one or more management circuits in communication with the plurality of non-volatile storage elements and the plurality of word lines. A first of the word lines is associated with a group of the plurality of non-volatile storage elements. The one or more management circuits verify one or more program operations of the group of non-volatile storage elements. The one or more management circuits store an indication of temperature at which the verify was performed. The one or more management circuits read the group of non-volatile storage elements using compensation that depends on the temperature at which the verify was performed.
One embodiment includes a method of operating non-volatile storage while providing temperature compensation during read that depends on the verify temperature. A group of non-volatile storage elements are programmed. The programming include performing one or more verify operations using compensation that is based on the equation: Tco_prog1*Tprog+Tco*Tprog, where Tprog is the temperature during program verify, Tco compensates for Vth temperature dependence of the group of non-volatile storage elements and Tco_prog1 compresses the width of a Vth distribution window of the programmed group of non-volatile storage elements with increasing temperature. An indication of the temperature at which the verifying was performed is stored. Later, the group of non-volatile storage elements are read using compensation that is based on the equation: Tco_prog2*Tprog+Tco*Tread, where Tread is the temperature during read and Tco_prog2 adjusts the read levels to compensate for an effect caused by Tco_prog1 during program verify.
One embodiment includes a non-volatile storage device comprising a plurality of non-volatile storage elements, a plurality of word lines, and one or more management circuits in communication with the plurality of non-volatile storage elements and the plurality of word lines. A first of the word lines is associated with a group of the plurality of non-volatile storage elements. The one or more management circuits program the group of non-volatile storage elements. The one or more management circuits perform one or more verify operations during the programming using verify reference voltages that are based on the equation: Tco_prog1*Tprog+Tco*Tprog, where Tprog is the temperature during program verify, Tco compensates for Vth temperature dependence of the group of non-volatile storage elements and Tcoprog1 reduces gaps between states of the programmed group of non-volatile storage elements with increasing temperature. The one or more management circuits store an indication of temperature at which the verifying was performed. The one or more management circuits read the group of non-volatile storage elements using compensation that is based on the equation: Tco_prog2*Tprog+Tco*Tread, where Tread is the temperature during read and Tco_prog2 adjusts read reference voltages to compensate for an effect to the width of the threshold voltage distribution window caused by Tcoprog1 during program verify.
One embodiment includes a method of operating non-volatile storage, comprising: programming a group of non-volatile storage elements to a plurality of data states at a first temperature, the programming includes verifying the plurality of data states using a first set of verify levels; and programming the group of non-volatile storage elements to the plurality of data states at a second temperature, the programming includes verifying the plurality of data states using a second set of verify levels, the first set and the second set of verify levels compensate for temperature dependence of individual threshold distribution widths of the plurality of data states.
The foregoing detailed description has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit embodiments 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 principles and practical applications, to thereby enable others skilled in the art to best utilize various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope be defined by the claims appended hereto.
Claims
1. A method of operating non-volatile storage, comprising:
- verifying one or more program operations of a group of non-volatile storage elements in the non-volatile storage;
- storing an indication of temperature at which the verifying was performed; and
- reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed, including applying compensation that is independent of temperature dependence of the non-volatile storage elements threshold voltages.
2. A method of operating non-volatile storage, comprising:
- verifying one or more program operations of a group of non-volatile storage elements in the non-volatile storage, including applying different amounts of compensation to verify respective different states of a plurality of states to which the group of non-volatile storage elements are programmed, the different amounts of compensation shift a first verify level for a higher state more than a second verify level for a lower state, with increasing verify temperature;
- storing an indication of temperature at which the verifying was performed; and
- reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed.
3. The method of claim 2, wherein the different amounts of compensation depend at least in part on temperature dependence of threshold voltage distribution widths of the respective different states.
4. The method of claim 2, wherein the reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed includes:
- applying different amounts of compensation for reading different states of the plurality of states, the different amounts of compensation shift down a first read level for the higher state more than a second read level for the lower state, with increasing temperature at which the verifying was performed.
5. A method of operating non-volatile storage, comprising:
- verifying one or more program operations of a group of non-volatile storage elements in the non-volatile storage, including—applying one or more first compensations for temperature dependence of the group of non-volatile storage elements threshold voltage and one or more second compensations that are independent of temperature dependence of the group of non-volatile storage elements threshold voltage;
- storing an indication of temperature at which the verifying was performed; and
- reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed.
6. The method of claim 5, wherein there are gaps between threshold voltage distributions that represent adjacent states of a plurality of states to which the group is programmed, the one or more second compensations decrease at least one of the gaps with increasing temperature.
7. The method of claim 5, wherein the reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed includes:
- applying one or more third compensations that adjust read levels to compensate for shifts caused by the second one or more compensations.
8. The method of claim 1, wherein the reading the group of non-volatile storage elements using compensation that depends on the temperature at which the verifying was performed includes one or more of:
- reading with a sensing current that depends on the temperature during the verifying;
- reading with a sensing time that depends on the temperature during the verifying; or
- applying a voltage to a selected word line that depends on the temperature during the verifying.
9. A non-volatile storage device comprising:
- a plurality of non-volatile storage elements;
- a plurality of word lines, a first of the word lines is associated with a group of the plurality of non-volatile storage elements;
- one or more management circuits in communication with the plurality of non-volatile storage elements and the plurality of word lines, the one or more management circuits verify one or more program operations of the group of non-volatile storage elements, the one or more management circuits store an indication of temperature at which the verify was performed, the one or more management circuits read the group of non-volatile storage elements using compensation that depends on the temperature at which the verify was performed, wherein the compensation that depends on the temperature at which the verify was performed compensates for temperature dependence of threshold voltage distribution widths of the non-volatile storage elements threshold voltages.
10. A non-volatile storage device comprising:
- a plurality of non-volatile storage elements;
- a plurality of word lines, a first of the word lines is associated with a group of the plurality of non-volatile storage elements;
- one or more management circuits in communication with the plurality of non-volatile storage elements and the plurality of word lines, the one or more management circuits verify one or more program operations of the group of non-volatile storage elements, the one or more management circuits apply different amounts of compensation to verify respective different states of a plurality of states to which the group of non-volatile storage elements are programmed, the different amounts of compensation shift a first verify level for a higher state more than a second verify level for a lower state, with increasing verify temperature, the one or more management circuits store an indication of temperature at which the verify was performed, the one or more management circuits read the group of non-volatile storage elements using compensation that depends on the temperature at which the verify was performed.
11. The non-volatile storage device of claim 10, wherein the different amounts of compensation depend on threshold voltage distribution widths of the respective different states.
12. The non-volatile storage device of claim 10, wherein there are gaps between threshold voltage distributions that represent adjacent states of a plurality of states to which the group is programmed, the different amounts of compensation decrease at least one of the gaps with increasing temperature.
13. A method of operating non-volatile storage, comprising:
- programming a group of non-volatile storage elements, the programming including performing one or more verify operations using compensation that is based on the equation: Tco_prog1*Tprog+Tco*Tprog,
- where Tprog is the temperature during program verify, Tco compensates for Vth temperature dependence of the group of non-volatile storage elements and Tco_prog1 compresses a width of a Vth distribution window of the programmed group of non-volatile storage elements with increasing temperature;
- storing an indication of temperature at which the verifying was performed; and
- reading the group of non-volatile storage elements using compensation that is based on the equation: Tco_prog2*Tprog+Tco*Tread,
- where Tread is the temperature during read and Tco_prog2 adjusts read levels to compensate for an effect caused by Tco_prog1 during program verify.
14. The method of claim 13, wherein the storing an indication of temperature at which the verifying was performed includes:
- writing the indication to a word line that includes the group of non-volatile storage elements.
15. The method of claim 13, further comprising:
- reading the indication from a selected word line when reading the group of non-volatile storage elements at a first reference level without applying compensation based on the temperature at which the verifying was performed.
16. The method of claim 13, wherein values for Tco_prog1 and Tco_prog2 are based on an erase/program cycle count for a block containing the group of non-volatile storage elements.
17. The method of claim 13, wherein the storing an indication of temperature at which the verifying was performed includes storing the indication in spare non-volatile storage elements associated with a first word line in a block, the indication of the temperature is used when reading other word lines in the block that were verified at about the same temperature.
18. A non-volatile storage device comprising:
- a plurality of non-volatile storage elements;
- a plurality of word lines, a first of the word lines is associated with a group of the plurality of non-volatile storage elements;
- one or more management circuits in communication with the plurality of non-volatile storage elements and the plurality of word lines, the one or more management circuits program the group of non-volatile storage elements, the one or more management circuits perform one or more verify operations during the programming using verify reference voltages that are based on the equation: Tco_prog1*Tprog+Tco*Tprog, where Tprog is the temperature during program verify, Tco compensates for Vth temperature dependence of the group of non-volatile storage elements and Tco_prog1 reduces gaps between states of the programmed group of non-volatile storage elements with increasing temperature, the one or more management circuits store an indication of temperature at which the verifying was performed, the one or more management circuits read the group of non-volatile storage elements using compensation that is based on the equation: Tco_prog2*Tprog+Tco*Tread, where Tread is the temperature during read and Tco_prog2 adjusts read reference voltages to compensate for an effect to the width of the threshold voltage distribution window caused by Tco_prog1 during program verify.
19. A method of operating non-volatile storage, comprising:
- programming a group of non-volatile storage elements to a plurality of data states at a first temperature, the programming includes verifying the plurality of data states using a first set of verify levels; and
- programming the group of non-volatile storage elements to the plurality of data states at a second temperature, the programming includes verifying the plurality of data states using a second set of verify levels, the first set and the second set of verify levels compensate for temperature dependence of individual threshold distribution widths of the plurality of data states.
20. The method of claim 19, further comprising:
- reading the group of non-volatile storage elements using compensation that depends on the temperature at which the group of non-volatile storage elements were programmed.
21. The method of claim 19, wherein the first set of verify levels has a first difference between verify levels for two adjacent states, the second set of verify levels has a second difference between verify levels for the two adjacent states that is less than the first difference, the second temperature is higher than the first temperature.
22. The method of claim 21, further comprising:
- applying compensation for temperature dependence of threshold voltages of the group of non-volatile storage elements when verifying and reading the two adjacent states.
23. The method of claim 1, wherein:
- the group of non-volatile storage elements are arranged in a three-dimensional memory structure.
24. The method of claim 2, wherein:
- the non-volatile storage comprises a three-dimensional memory array, the three-dimensional memory array comprises the group of non-volatile storage elements.
25. The method of claim 5, wherein:
- the group of non-volatile storage elements are part of a three-dimensional memory array.
26. The non-volatile storage device of claim 9, wherein:
- the plurality of non-volatile storage elements are arranged in a three-dimensional memory structure.
27. The non-volatile storage device of claim 10, wherein:
- the non-volatile storage device comprises a three-dimensional memory array, the three-dimensional memory array comprises the plurality of non-volatile storage elements.
28. The method of claim 13, wherein:
- the group of non-volatile storage elements are part of a three-dimensional memory array.
29. The non-volatile storage device of claim 18, wherein:
- the non-volatile storage device comprises a three-dimensional memory array, the three-dimensional memory array comprises the plurality of non-volatile storage elements.
30. The method of claim 19, wherein:
- the non-volatile storage comprises a three-dimensional memory array, the three-dimensional memory array comprises the group of non-volatile storage elements.
6560152 | May 6, 2003 | Cernea |
6801454 | October 5, 2004 | Wang et al. |
7057958 | June 6, 2006 | So et al. |
7257028 | August 14, 2007 | Lee et al. |
7345913 | March 18, 2008 | Isobe |
7460407 | December 2, 2008 | Mokhlesi et al. |
7755946 | July 13, 2010 | Dunga et al. |
7957215 | June 7, 2011 | Tanzawa |
8611157 | December 17, 2013 | Dutta |
20020109539 | August 15, 2002 | Takeuchi et al. |
20030189856 | October 9, 2003 | Cho et al. |
20050213387 | September 29, 2005 | Kubo et al. |
20070291566 | December 20, 2007 | Mokhlesi et al. |
20080158992 | July 3, 2008 | Sekar et al. |
20080247253 | October 9, 2008 | Nguyen et al. |
20090097319 | April 16, 2009 | Sekar et al. |
20090290428 | November 26, 2009 | Noh |
20090310408 | December 17, 2009 | Lee et al. |
20100073069 | March 25, 2010 | Wang et al. |
20100110815 | May 6, 2010 | Lee et al. |
20100329026 | December 30, 2010 | Nakamura et al. |
20110205823 | August 25, 2011 | Hemink et al. |
20120033503 | February 9, 2012 | Kim et al. |
20120099388 | April 26, 2012 | Lee |
20120163092 | June 28, 2012 | Jung et al. |
20120300550 | November 29, 2012 | Hemink et al. |
Type: Grant
Filed: May 21, 2014
Date of Patent: Sep 29, 2015
Assignee: SanDisk Technologies Inc. (Plano, TX)
Inventor: Deepanshu Dutta (San Jose, CA)
Primary Examiner: Ovidio Escalante
Application Number: 14/284,193
International Classification: G11C 11/34 (20060101); G11C 16/26 (20060101); G11C 7/04 (20060101); G11C 11/56 (20060101); G11C 16/34 (20060101);