Some storage systems, such as Flash memory, permit one of multiple possible levels (e.g., voltage levels) to be stored in a unit of storage (e.g., a cell in a Flash memory system). This permits multiple bits to be stored per unit of storage. For example, if four possible (voltage) levels can be stored, then each unit has a 2-bit storage capacity. In general, if there are M levels per unit of storage this corresponds to log2(M) bits/unit of storage. For a variety of reasons, the level read back from storage media may not be the same level as what was originally written. In a Flash memory system, some examples include temperature variation (e.g., depending upon the ambient temperature, the level read back will vary), data retention issues (e.g., over time, leakage from a cell transistor's floating gate causes the stored and read back voltage to decrease), and transmission line effects (e.g., observed as a ramp in the read back voltage that gradually increases from one end of a transistor string (i.e., wordline) to the other end). Regardless of the underlying cause, storage systems attempt to compensate or otherwise adjust for this using channel estimation.
One channel estimation technique involves the usage of reference cells. Reference cells are cells used to stored overhead information (i.e., not user data) and in particular for channel estimation, the reference cells are used to store known values. The values are later read back and then the channel is estimated using the known, stored values and the level that was actually read back. There are two disadvantages associated with performing channel estimation in this manner. First, a maximum number of cells are typically allocated to be reference cells and these reference cells are also used to store code information so that the read back data can be decoded (e.g., using an error correction or error detection code). Channel estimation relies on a sufficiently large number of samples and thus the strength of a code suffers since there are a limited number of reference cells. Another disadvantage is that a reference cell can become damaged or defective (e.g., sometimes referred to as a slow or stuck cell). If this occurs and a statistically insufficient number of stored values are used for channel estimation (e.g., because of the requirements of the code and/or the limited number of reference cells), then channel estimation will suffer. It would be desirable to develop new channel estimation techniques which overcome some or all of these issues.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
Controller 104 includes write controller 106 and read controller 108, which send write data and receive read data from storage media 102. In the examples described herein, a unit of storage is capable of storing multiple levels. For example, in the case of NAND Flash storage media, a cell is capable of storing 2, 4, or 8 levels. (These are merely examples and some other storage systems are capable of storing a different number of levels.) In some embodiments, a level is a voltage level.
During a read back, distributions 202a-202d are the values observed. In some cases, the shift from distributions 200a-200d to 202a-202d occurs over a relatively long period of time, for example if a few years elapse between writing and reading. This change from distributions 200a-200d to 202a-202d (respectively) is modeled as and referred to as a channel effect. To properly process the read back signal, a read controller (e.g., read controller 108 in
At 300, a set of bins having bin ranges is received. In various embodiments, the bin ranges extend from the center (e.g., mean or median) of a distribution to the center of another distribution (e.g., from the center of distribution 202a to the center of distribution 202b). See, for example, the bin ranges shown in diagram 350 in
At 301, for each bin in the set, a corresponding portion of read values which fall into that particular bin is received. For example, in 350 in
At 302, a read value which is read from a multi-level storage device is received. One or more of the bin ranges is/are adjusted such that the received portions of read values remain substantially the same after adjustment and after assignment of the read value to one of the set of bins after adjustment at 304. That is, each bin has a corresponding fraction or portion of the read voltages and these fractions are maintained by adjusting the bin ranges. For example, one or more bin ranges in
In some embodiments, adjustment at 304 includes incrementing or decrementing a previous value (e.g., k*μ, where k is an integer and μ is a step size). In one example, the value of μ is determined by “sweeping” μ and finding the μ which provides the best bit error-rate. In one example, the optimal value of μ depends on how much the levels have moved between write and read (e.g., if the levels have only moved a small amount, there is no reason to use a large μ which permits the levels to move quickly, alternatively, if the levels have moved a significant amount or vary drastically from one end of a word-line to the other (sometimes referred to as ramp), then a larger μ might be preferred). In some embodiments, it is in the form of a gradient descent in that it uses a noisy value to move parameters which, hopefully, improve the system performance.
It is determined at 306 whether there is more data. For example, if cells in a wordline are being processed, it is determined whether there are remaining cells in the wordline. In some embodiments, cells in a page are read back and processed. If there is additional data, the process proceeds to the next cell at 308. Otherwise, the bin ranges of voltage levels are output at 310. For example, the bin ranges in
The techniques described in
One example, to illustrate the process described above in embodiments where the bin ranges correspond to centers, is:
Another example, to illustrate the process described above in embodiments where the bin ranges correspond to thresholds, is:
Although the process shown in this figure and some other figures are represented as iterative processes, the scope of the technique includes non-iterative processes as well. For example, all data may be input at the beginning of such a non-iterative process, the bin ranges are adjusted so that each range has an appropriate number of read-back values falling within that range, and the bin ranges are output.
For the blind channel estimation technique described herein, it is assumed the number of samples, data points, and/or iterations used is sufficiently large enough from a statistical point of view. In some embodiments, a check is performed at the start of the process described above to ensure the value of N (e.g., where i is 0, . . . , N−1) is sufficiently large enough. An appropriate or sufficient value of N will depend upon the number of possible (voltage) levels that can be stored in a unit of storage (e.g., 16 possible voltage levels will require more samples or data than a system that stores 4 possible voltage levels). In general, the number of (voltage) levels able to be stored by a unit of storage is called M (e.g., M=2, 4, 8, etc. for various systems).
Also, this blind channel estimation technique relies upon a relatively even distribution of read-back values amongst the M possible read-back voltage levels. For example, the technique may not necessarily perform optimally if all of the read-back values are one of the possible M voltage levels. In some embodiments, there is some pre-processing to ensure a relatively equal or even distribution of read-back voltage values. In one example, a scrambler (e.g., in a write controller prior to writing or in a read controller after reading back a stored value) is used to ensure data values are sufficiently distributed amongst the possible M levels. In another example, a checker or counter is used to forward read back values for processing if it is not one for which too many values have already been received, otherwise it is discarded.
At 400, a set of decision criteria is received, where based upon an input value and the set of decision criteria, a decision is made.
A read value is received which is read from a multi-level storage device at 402. At 404, a decision is made using the read value and set of decision criteria. For example, in diagram 450 of
At 406, one or more of the decision criteria in the set that correspond to the decision is/are adjusted based at least in part on the read value. For example, in diagram 450 in
It is determined at 408 whether there is more data. If so, the process proceeds to a next cell at 410. Otherwise, the set of decision criteria is output at 412. For example, after multiple iterations of adjustment, the decision criteria shown in diagram 450 or 480 in
The techniques described in
To illustrate the technique, in one example below, blind channel estimation is performed in a first pass of the cells, decision directed estimation is performed in a second pass of the cells, and the bin ranges correspond to centers:
z
i
=n if |xi−cin|≦|xi−cim|∀m≠n
for n=1 to M
In some embodiments, decision directed estimation is used in combination with a decoder that makes soft decisions (e.g., a low-density parity-check (LDPC) code or system is used) and such systems or codes require log-likelihood ratios (LLR's) as input to the (e.g., LDPC) decoder. To illustrate, a hard decision decoder (in the binary case) would output a 0 or 1 whereas a soft decision decoder would output a likelihood, for example 0.1 if the decoder is very certain the decision is a 0, a 0.5 if the decoder is equally unsure, or a 0.9 if the decoder was very certain the decision is a 1. In some embodiments, other soft decision codes besides LDPC codes are used. In some embodiments, the variance of the histogram associated with each bin (or level) is estimated or otherwise generated in order to provide these LLR values to a decoder. In one example:
z
i
=n if |xi−cin|≦|xi−cim|∀m≠n
for n=1 to M
∀n and output variances
In some embodiments, variances and centers are passed to a soft-decision decoder (e.g., a LDPC decoder) as LLRs and means, respectively. Variances and centers (i.e. means) of these distributions are utilized to construct LLRs. LLRs are one specific example. In some embodiments, the means and variances of these distributions are used to construct probabilities (i.e., the probability that each of the bits written to a given cell were written as 0's or written as 1's). LLRs are just a way to represent those probabilities, but need not be the form passed to the soft-decision decoder.
As described above, blind decision estimation and decision directed estimation can be performed alone, alone in combination with other techniques, or together. The following show some example combinations.
Using the bin ranges, the read data received from Flash media 102 is channel corrected by channel corrector 502. For example, over time Flash media can degrade and a read back value can be lower than expected or lower than levels stored when the device was new. In such cases where the levels decay or drop, channel corrector 502 increases the read back data to higher levels and the amount of the increase is specified by or otherwise controlled by the bin ranges output by blind channel estimator 500. In one example, originally a Flash cell stores the levels [1V 2V 3V 4V] and blind channel estimator 500 outputs [0.2V 1.2V 2.8V 4V]. In that example, the first level dropped (nominally) by 0.8V, the second level by 0.8V, the third level by 0.2V, and the fourth level by 0V (i.e., no performance degradation). In some embodiments, a read back value of 1.1V would be channel corrected to be 2V.
In various embodiments, the bin ranges output by blind channel estimator 500 correspond to a variety of cells. In some embodiments, a bin range is output for each cell or unit of storage. This may be undesirable in some applications, for example where the number of levels (M) is relatively small and/or it is undesirable to store a large amount of overhead information. In some embodiments, a bin range (sometimes referred to as a bin range vector) is output for cells in a page, for cells in a wordline, etc. This may be acceptable where cells in the same page or wordline degrade in a similar manner.
Decision directed channel estimator 600 performs decision directed channel estimation, for example using the process described in
In some embodiments, the decision criteria correspond to centers (e.g., diagram 450 in
As described in the previous example, decision criteria can be output for any number or group of cells or storage units.
In the example shown, blind channel estimation is used in a first pass. For example, read data from all cells in a page are passed to and processed by blind channel estimator 500. In this example, the same read data is passed to decision directed channel estimator and is processed in a second pass. The bin ranges passed from blind channel estimation as used as initial decision criteria by decision directed channel estimator 600. Decision directed channel estimator adjusts the decision criteria as needed and passes it to channel corrector 502.
Blind channel estimator 500 passes bin ranges to reference cell based channel estimator 800 which in turn passes bin ranges to decision directed channel estimation. Reference cell based channel estimator updates and/or modifies the received bin ranges as appropriate based on the reference cell data. The bin ranges output by blind channel estimator 500 and reference cell based channel estimator 800 do not necessarily have the same bin range values.
In some embodiments, blind channel estimator 500 and reference cell based channel estimator 800 adjust one or more of the bin ranges by incrementing or decrementing a previous bin range by k*μ where μ is a constant and k is a scaling factor (integer or otherwise). In some embodiments, since the values or levels written to reference cells are known (whereas it is not known what values or levels read back data “actually” are), a larger constant (e.g., μlarger) is used to increment/decrement a previous bin value during reference cell based estimation and a smaller constant (e.g., μsmaller) is used during blind channel estimation.
Decision directed channel estimator 600 outputs decision criteria and passes it to channel corrector 502. Channel corrector 502 outputs channel corrected read back data.
In the example shown, decision directed channel estimator 902 outputs both decision criteria and variance. Returning to the example of
Although not shown in this figure, a decision directed channel estimator that outputs decision criteria and variance can be used with a variety of other modules, such as other channel estimators, channel correctors, etc. For example, in some embodiments, a blind channel estimator is used in combination with the system shown in
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
This application is a continuation of co-pending U.S. patent application Ser. No. 12/384,894 (Attorney Docket No. LINKP027) entitled BLIND AND DECISION DIRECTED MULTI-LEVEL CHANNEL ESTIMATION filed Apr. 8, 2009 which claims priority to U.S. Provisional Patent Application No. 61/123,555 (Attorney Docket No. LINKP027+) entitled BLIND MULTI-LEVEL CHANNEL ESTIMATION filed Apr. 9, 2008 which is incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
61123555 | Apr 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12384894 | Apr 2009 | US |
Child | 13456065 | US |