Low-density parity-check (LDPC) codes are a type of error correcting code. LDPC codes are becoming increasingly popular in storage media, for example to encode data that is written to storage media, such as hard disk drives or Flash drives. It would be desirable to develop techniques (e.g., testing techniques) relating to LDPC for storage applications.
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.
In one example application, storage media is tested before being distributed and/or integrated into a larger system. For example, manufacturing testing is used in some applications to ensure manufacturing defects, such as “stuck-at” faults, are below a guaranteed or desired level. Or, for storage media capable of storing multiple (e.g., voltage) levels, manufacturing testing can be used to ensure all of the levels are capable of being written and read back.
Manufacturing tester 100 writes (e.g., known) data to storage media 102 and reads it back. An error rate is determined, for example, by comparing known, written data with the read data (e.g., after any read processing); and if the error rate is satisfactorily low, the storage media 102 passes the test. For example, there is a passing error rate, and the storage media being tested must have an error rate lower than that. If the error rate is too high, storage media 102 fails.
In the embodiments described herein, the data written from manufacturing tester 100 to storage media 102 is encoded using a low-density parity-check (LDPC) code. In some embodiments, the LDPC code used during manufacturing testing is the same LDPC code as that used during a normal or operational mode. During decode of LDPC encoded data, one or more iterations are performed or otherwise used. As the number of iterations increases, the error rate tends to decrease. However, processing resources and test time increase correspondingly as the error rate decreases.
In various embodiments, manufacturing tester 100 is configured in a variety of ways. In some embodiments, manufacturing tester 100 includes components specifically configured and/or built only to perform a particular task, such as an application-specific integrated circuit (ASIC). In some embodiments, manufacturing tester 100 includes general purpose components (temporarily) configured to perform a specific task, such as a field-programmable gate array (FPGA) or (more generally) a processor and a memory coupled with the processor, where the memory is configured to provide the processor with instructions which when executed cause the processor to perform certain steps.
At 200, an LDPC code is received. In some embodiments, the LDPC code is the same as that used during an operational or normal mode. For example, if the storage media is to be used in a digital music player, the LDPC code used at step 200 is the same as that used when music is being written to or read from the digital music player. For the received LDPC code, an error rate function that is a function of a number of iterations is generated at 202. An example of an error rate function is described in further detail below.
A number of test iterations and a passing error rate are determined using the error rate function at 204. For example, the error rate function may be in the form f(iterations). In some embodiments, one of the iterations and the corresponding error rate of the error rate function f(iterations) are selected to be the number of test iterations and the passing error rate, respectively. In some embodiments, some margin is included in the passing error rate. In some embodiments, determining at step 204 is based on a desired amount of test time per storage device and/or a desired number of sectors to be tested per storage device. For example, writing to and reading from the desired number of sectors will consume a certain amount of time; from this the number of iterations that keeps the amount of test time under the desired test time can be calculated.
At 206, one or more storage media are tested using the LDPC code, the number of test iterations, and the passing error rate. An embodiment is described in further detail below.
At 208, it is determined whether to change the manufacturing test. If so, an LDPC code is received at 200. In some embodiments, the LDPC code received is different from another LDPC code received at a previous iteration of step 200. In some embodiments, it is the same LDPC code.
Referring back to
At 400, one or more storage media used in generating an error rate function are obtained. For example, if HDD storage is being tested, one or more HDD devices are obtained from which the error rate function is generated. A (next) storage media is obtained at 401. At 402, known data is encoded using the LDPC code, and the encoded data is written to the storage media. In one example, a random message is generated, encoded, and written; the random message is saved for later so it can be compared to what is read back and decoded. In some embodiments, predefined patterns or messages are used.
At 404, the encoded data is read back from the storage media, and the read data is decoded. In some embodiments, decoding is performed once up to a maximum number of iterations (e.g., in
At 406, it is checked at what iteration the data is successfully decoded. This can be done in various ways, such as using the status of the decoder itself, using error detection code, or comparing the final data with known data, etc. In embodiments where known data is used, the decoded data is compared against the known data. For example, if there is a mismatch, an error is declared. The results are recorded at 408. In various embodiments various pieces of information are obtained and may vary based on the technique used to calculate an error rate function. In various embodiments, a number of errors, an amount of total storage media accessed during the test, error rates, and/or iterations are recorded. Some example units of the first two items include bytes, sectors, etc.
It is determined at 410 if there is more storage media. If so, the next storage media is obtained at 401. Otherwise the error rate function is generated using the recorded results at 412. In some embodiments, for each storage media, an individual error rate function is generated (e.g., similar to that shown in
At 500, an amount of test time is determined. In one example, the time consumed is determined by the manufacturer based (e.g., solely) on cost. For example, for each unit to be shipped, they need to go through certain tests. In some embodiments, any time allocated for margining is decided by a manufacturer based on their experience.
At 502, it is determined how many sectors can be written and read using the amount of test time. For example, in order to observe a certain number of errors for a given error rate, we know how many sectors we need to process=number of observation/error rate. For example, it may be desired to measure 1e-5, and 100 errors are considered enough errors. In this example, the number of sectors read/written is 100/1e-5=1e7 sectors. To read that many sectors, HDD throughput decides the final time. For example, for a 5400 RPM HDD (each revolution takes ˜11 ms), each revolution has 1000 sectors and so to read 1e7 sectors, 1e7/1000*11 ms=110 seconds is needed.
At 504 a lower error rate that can be measured reliably is determined. In some embodiments, it is the lowest error rate that can be measure reliably. At 506, the number of iterations that corresponds to the lower error rate is selected based on the error rate function. For example, using the error rate function shown in
In one example, the following calculations (or more generally, determinations) are performed in the following order: 2 minutes is allocated→1e7 sectors can be read and 100 errors is considered sufficient→1e-5 is the error rate of practical error rate for measurement→based on the error function, a number of iterations NN that corresponds to the 1e-5 error rate is selected→if a new drive can pass 1e-5 with NN iterations, then it passes manufacturing test.
At 600, a (next) storage media to be tested is obtained. For example, if hard disk drives are being tested, a hard disk drive is obtained. At 602, known data is encoded using an LDPC code, and the encoded data is written to the storage media. For example, the LDPC code may be that obtained at step 200 in
At 604, encoded data is read back from the storage media. For example, in
It is determined at 608 whether an obtained error rate is less than or equal to a passing error rate. If so, the storage media is marked as having passed the manufacturing test at 610. Otherwise, the storage media is marked as having failed the manufacturing test at 612. For example, if the error rate obtained at step 606 is less than 10−2 (for the example scenario of
After marking as appropriate at 610 or 612, it is determined at 614 if there is more storage media to test. If so, a next storage media is obtained at 600.
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/387,720 (Attorney Docket No. LINKP033), entitled MANUFACTURING TESTING FOR LDPC CODES filed May 5, 2009 which is incorporated herein by reference for all purposes, which claims priority to U.S. Provisional Application No. 61/196,458 (Attorney Docket No. LINKP033+), entitled MARGINING FOR LDPC CODES filed Oct. 17, 2008 which is incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
61196458 | Oct 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12387720 | May 2009 | US |
Child | 13571228 | US |