The present invention relates generally to an electronic system and more particularly to a system with storage drive life estimation mechanism.
All electronic systems require some form of memory or storage. Data storage, often called storage or memory, refers to computer components and recording media that retain digital data. Data storage is a core function and fundamental component of consumer and industrial electronics, especially devices such as computers, televisions, cellular phones, mobile devices, and digital video cameras.
Recently, forms of long-term storage other than electromechanical hard disks have become feasible for use in computers. One of these is flash Electrically Erasable Programmable Read-Only Memory (EEPROM). Flash EEPROM memory includes a plurality of floating-gate field effect transistors arranged as memory cells. NAND flash is one form of non-volatile memory used in solid state storage devices. The memory cells are arranged in typical row and column fashion with circuitry for accessing individual cells. The memory transistors of those cells can store an analog value that can be interpreted to hold two logical states for Single Level Cell (SLC) or more than two logical states as for Multi Level Cells (MLC).
A flash memory cell, like a typical EEPROM cell but in contrast to Dynamic random-access memory (DRAM) memory, retains information when power is removed. Flash EEPROM memory has a number of characteristics, which adapt it to use as long-term memory. It is light in weight, occupies very little space, and consumes less power than electromechanical disk drives. Construction of a storage system with this type of memory allows for much higher bandwidth and higher input output operations per second than a typical electromechanical disk drive. More importantly, it is especially rugged and can operate at a much higher temperature range. It will withstand, without adverse effects, repeated drops, each of which would destroy a typical electromechanical hard disk drive. A problem exhibited by flash memory and storage devices that consist of flash memory is that it tends to have a limited life in use.
Thus, a need still remains for better storage life estimation to account for the failure and durability of electronic systems. In view of the increasing demand for storage management of electronic systems, it is increasingly critical that answers be found to these problems. In view of the ever-increasing commercial competitive pressures, along with growing consumer expectations and the diminishing opportunities for meaningful product differentiation in the marketplace, it is critical that answers be found for these problems. Additionally, the need to reduce costs, improve efficiencies and performance, and meet competitive pressures adds an even greater urgency to the critical necessity for finding answers to these problems.
Solutions to these problems have been long sought but prior developments have not taught or suggested any solutions and, thus, solutions to these problems have long eluded those skilled in the art.
The various implementations described herein include systems, methods and/or devices used to enable storage drive life estimation. Some implementations include systems, methods and/or devices to determine, in accordance with two or more age criteria of a storage device, a drive age of the storage device.
More specifically, some embodiments include a method of operation of an electronic system. In some embodiments, the method includes (1) determining two or more age criteria of a storage drive, and (2) determining a drive age of the storage drive in accordance with the two or more age criteria of the storage drive.
In some embodiments, the two or more age criteria include at least one criterion selected from the group consisting of a total number of accumulated program/erase (PE) cycles, a total number of grown defects, a defect rate, and a retry rate.
In some embodiments, the two or more age criteria are scaled by respective configurable factors to adjust relative importance of each respective age criterion on the drive age of the storage drive.
In some embodiments, determining a drive age of the storage drive in accordance with the two or more age criteria of the storage drive includes (1) determining a first scaled age criterion by multiplying a first configurable factor by a first age criterion of the two or more age criteria, (2) determining a first drive age indicator by multiplying the drive age by a first maximum age criterion for the storage drive, wherein the first maximum age criterion is a maximum value of the first age criterion, (3) determining whether the first scaled age criterion is greater than or equal to the first drive age indicator, (4) in accordance with a determination that the first scaled age criterion is greater than or equal to the first drive age indicator, incrementing the drive age, and (5) in accordance with a determination that the first scaled age criterion is not greater than or equal to the first drive age indicator, performing one or more operations including (a) determining a second scaled age criterion by multiplying a second configurable factor by a second age criterion of the two or more age criteria, (b) determining a second drive age indicator by multiplying the drive age by a second maximum age criterion for the storage drive, wherein the second maximum age criterion is a maximum value of the second age criterion, (c) determining whether the second scaled age criterion is greater than or equal to the second drive age indicator, and (d) in accordance with a determination that the second scaled age criterion is greater than or equal to the second drive age indicator, incrementing the drive age.
In some embodiments, the drive age is monotonically non-decreasing.
In some embodiments, the drive age is an integer.
In some embodiments, the storage drive comprises one or more flash memory devices.
In another aspect, any of the methods described above are performed by an electronic system, the electronic system including (1) one or more processors, and (2) memory storing one or more programs to be executed by the one or more processors, the one or more programs comprising instructions for performing or controlling performance of any of the methods described herein.
In yet another aspect, some embodiments include a non-transitory computer readable storage medium, storing one or more programs configured for execution by one or more processors of an electronic system, the one or more programs including instructions for performing or controlling performance of any of the methods described herein.
The following embodiments are described in sufficient detail to enable those skilled in the art to make and use the invention. It is to be understood that other embodiments would be evident based on the present disclosure, and that system, process, or mechanical changes may be made without departing from the scope of the present invention.
In the following description, numerous specific details are given to provide a thorough understanding of the invention. However, it will be apparent that the invention may be practiced without these specific details. In order to avoid obscuring the present invention, some well-known circuits, system configurations, and process steps are not disclosed in detail.
The drawings showing embodiments of the system are semi-diagrammatic and not to scale and, particularly, some of the dimensions are for the clarity of presentation and are shown exaggerated in the drawing FIGs. Similarly, although the views in the drawings for ease of description generally show similar orientations, this depiction in the FIGs. is arbitrary for the most part. Generally, the invention can be operated in any orientation.
Where multiple embodiments are disclosed and described having some features in common, for clarity and ease of illustration, description, and comprehension thereof, similar and like features one to another will ordinarily be described with similar reference numerals. The embodiments have been numbered first embodiment, second embodiment, etc. as a matter of descriptive convenience and are not intended to have any other significance or provide limitations for the present invention.
The term “module” referred to herein can include hardware, software running on or coupled to hardware, or a combination thereof in the present invention in accordance with the context in which the term is used. For example, the software can be machine code, firmware, embedded code, and application software. Also for example, the hardware can be circuitry, processor, computer, integrated circuit, integrated circuit cores, a microelectromechanical system (MEMS), passive devices, environmental sensors including but not limited to temperature sensors, or a combination thereof.
Solid State drives (SSDs) have a finite useful life presenting challenges to long term use and data storage. To plan for eventual replacement, a system and method for determining an estimate of drive life is needed. Estimations of storage drive life are also needed for warranty and resale purposes.
It is therefore desirable to have a system and method of estimating the percentage of a storage drive's expected life that has already been used. Furthermore, it is desirable that this estimate correlate well to the actual percentage of the drive's useful life while being relatively easy to compute. Finally, it is desirable that the measure reflect how a drive wears out, so that it is monotonically non-decreasing, and so that no possible values are skipped. In this way, the measure would never appear to run backwards or have large discontinuities, which would be confusing or misleading.
Referring now to
The memory controller 104 provides data control and management of the memory array 106. The memory controller 104 interfaces with the host system 108 and controls the memory array 106 to transfer data between the host system 108 and the memory array 106.
The memory array 106 includes an array of memory devices 110 including flash memory devices or non-volatile memory devices. The memory array 106 can include pages of data or information. The host system 108 can request the memory controller 104 for reading, writing, and deleting data from or to the logical address space of the storage device that includes the memory array 106.
The memory devices 110 can include chip selects 112, which are defined as control inputs, for enabling the memory devices 110. Each of the chip selects 112 can be used to control the operation of one of the memory devices 110. When the chip selects 112 are enabled, the memory devices 110 are in active state for operation including reading, writing, or recycling. This is also true for sub addresses LUNs (logical units) within a device controlled by one chip select.
Referring now to
The control unit 202 can be implemented in a number of different manners. For example, the control unit 202 can be a processor, an embedded processor, a microprocessor, a hardware control logic, a hardware finite state machine (FSM), a digital signal processor (DSP), or a combination thereof.
The control interface 210 can be used for communication between the control unit 202 and other functional units in the memory controller 104. The control interface 210 can also be used for communication that is external to the memory controller 104.
The control interface 210 can receive information from the other functional units or from external sources, or can transmit information to the other functional units or to external destinations. The external sources and the external destinations refer to sources and destinations external to the memory controller 104.
The control interface 210 can be implemented in different ways and can include different implementations depending on which functional units or external units are being interfaced with the control interface 210. For example, the control interface 210 can be implemented with dedicated hardware such as an application-specific integrated circuit (ASIC), configurable hardware such as an FPGA (Field Programmable Gate Array), discrete electronic hardware, or a combination thereof.
The storage unit 204 can include hardware, control firmware, and the software 212. The storage unit 204 can contain a volatile memory, a non-volatile memory, an internal memory, an external memory, or a combination thereof. For example, the storage unit 204 can be a non-volatile storage such as non-volatile random access memory (NVRAM), Flash memory, disk storage, or a volatile storage such as static random access memory (SRAM).
The storage unit 204 can include a storage interface 214. The storage interface 214 can also be used for communication that is external to the memory controller 104. The storage interface 214 can receive information from the other functional units or from external sources, or can transmit information to the other functional units or to external destinations. The external sources and the external destinations refer to sources and destinations external to the memory controller 104.
The storage interface 214 can include different implementations depending on which functional units or external units are being interfaced with the storage unit 204. The storage interface 214 can be implemented with technologies and techniques similar to the implementation of the control interface 210.
The memory interface unit 206 can enable external communication to and from the memory controller 104. For example, the memory interface unit 206 can permit the memory controller 104 to communicate with the memory array 106 of
The memory interface unit 206 can include a memory interface 216. The memory interface 216 can be used for communication between the memory interface unit 206 and other functional units in the memory controller 104. The memory interface 216 can receive information from the other functional units or can transmit information to the other functional units.
The memory interface 216 can include different implementations depending on which functional units are being interfaced with the memory interface unit 206. The memory interface 216 can be implemented with technologies and techniques similar to the implementation of the control interface 210.
The host interface unit 208 allows the host system 108 of
The control unit 202 can operate the host interface unit 208 to send control or status information generated by the memory controller 104 to the host system 108. The control unit 202 can also execute the software 212 for the other functions of the memory controller 104. The control unit 202 can further execute the software 212 for interaction with the memory array 106 via the memory interface unit 206.
The functional units in the memory controller 104 can work individually and independently of the other functional units. For illustrative purposes, the memory controller 104 is described by operation of the memory controller 104 with the host system 108 and the memory array 106. It is understood that the memory controller 104, the host system 108, and the memory array 106 can operate any of the modules and functions of the memory controller 104.
Referring now to
The drive age is a percentage of a storage drive's expected life that has already been used. For example, the drive age can be indicated as an integer between a range of 0 to 100 inclusively. In another example, the drive age is indicated as an integer between a range of 0 to 10,000, or more generally 0 to a maximum age. The drive age indicates a “threshold” of the storage drive's life such that the percentage of the maximum age indicated by the drive age corresponds to a percentage of the storage drive's life that has been depleted.
The drive age can include the maximum estimate of several age criteria of the storage drive, such as an estimate based on the accumulated program/erase cycles. The age criterion may have a larger range such as if a program/erase scale factor is 110, that criterion will be in the range of 0 to 110 (or more generally 0 to 1.1 times the maximum age) but the drive age is restricted to 0-100 (or more generally 0 to the maximum age).
The program/erase cycle is a base level operation of how data is replaced within an erase block. Memory types, such as NAND, have a limited number of useful program/erase cycles or PE cycles.
The drive age can also include an estimate of drive life based on the age criterion of the number of grown defects in the storage drive. A grown defect is defined as an erase block that fails after fewer program/erase cycles than expected.
For example, the electric system can track a drive's expected life in terms of both the drive's ability to retain data reliably and the drive's ability to service host operations at an acceptable performance level given the required background task and retries that result from accessing worn flash.
Performance will start to drop off due to advanced error and recovery and flash configuration before the drive would be at risk of data loss. Estimating when performance is too impacted is important to ensuring the continued use and reliability of the storage drive. This storage drive performance behavior as a function of drive wear is illustrated by the chart seen in
For example, the observed performance of the storage drive can decrease as the storage drive continues to wear. When the observed performance falls below the minimum acceptable performance threshold, the drive age can be at 100 percent of life used.
Based on the storage drive behavior, the method of estimating the percentage of a drive's expected life can rely on the gradual wear that occurs with each program/erase cycle and grown defects, which are defined as the occasional early failure of an erase block.
Other types of age criteria, such as related drive criteria or metrics can be used including rate of change in the number of grown defects and the number of read retries of the storage drive. The drive age can be estimated by calculating the largest of these drive criteria or metrics.
For example, it has been found that the drive age can be calculated as an estimate based on the accumulated program/erase cycles using Equation (1) herein called the gradual wear equation:
The PE scale factor or program erase cycle scale factor is defined as a relative weighting given to the gradual wear drive age estimate. The total PE measured is defined as the total number of program/erase cycles that have occurred on each erase block on the entire storage drive during the time of the calculation.
The erase block lifetime PE is defined as the estimated number of program/erase cycles that an erase block can endure. The total erase blocks are defined as the total number of erase blocks in the storage drive.
Further, it has been found that the drive age can be calculated as an estimate based on the number of grown defects using Equation (2) herein called the grown defect equation:
The defect scale factor is defined as the relative weight given to the grown defect estimate or grown defect age criterion. The number of grown defects is defined as the number of grown defects that have occurred on the drive at the current time of calculation.
The maximum allowed number of grown defects is the maximum number of grown defects that are allowed on the storage drive during its lifetime. The maximum allowed number of grown defects can be a predetermined value.
It has been found that drive age is jointly based upon the ways that flash memory wears out, including program/erase cycles and grown defects. In this way, each drive will have a current age based on whichever age criterion is more predominant at the time.
Referring now to
For example, the defect rate can be used to provide another estimate of drive age based on the defect rate at any given time. This storage drive behavior as a function of drive age is illustrated by the chart seen in
In the figure, curve A illustrates a storage drive where the number of defects increases with age. More significantly, the slope of curve A, as indicated by the dotted line, indicates the defect rate. It can be seen that this is increasing with time.
Curve B is indicative of another storage drive that is aging more rapidly. At the place where the two curves diverge, which is the pivot point, the slope of curve B is steeper than curve A. This shows that the defect rate is higher for curve B than curve A. This increase in the defect rate can be used to indicate that drive B has a higher drive age than drive A.
It has been found that drive age can be used to monitor the health of a single drive as well as be used to compare the drive life of multiple drives. For example, the drive age of a storage drive and another storage drive can be determined for comparing the life span of each drive to each other. The drive age provides a uniform and consistent metric in comparing the drive life or age of multiple drives as well as indicating the current health of a single drive. The drive age provides drive swapping and drive age leveling configuration applications to preserve the drive life of storage devices.
Referring now to
For example, it has been found that drive age can be estimated using Equation (3) herein called the defect rate equation:
The defect rate scale factor is defined as a relative weight given to the defect rate drive age estimate or the change in defect rate age criterion. For example, the defect rate scale factor can be 100 and be scaled to a specific percentage. The defect rate scale factor, as well as the other scale factors for the other age criteria can be set to a higher or lower value to cause the scale factor to have a higher impact on the drive age or age estimate. The measured defect rate is defined as the number of new (grown) defects per unit time.
The max end of life defect rate is defined as the maximum defect rate the storage drive can reach and still meet predetermined performance requirements. For example, a drive's end-of-life performance might be specified to be one percent of the erase blocks of the storage drive per day.
Further, it has been found that the calculation of the drive age as an estimate based on the read retry rate or retry rate criterion can be determined using Equation (4) herein called the retry rate equation:
A read retry is defined as reading data bytes again from the memory due to issues encountered when reading the data for the first time.
The measured retry rate (retries per read operations) is defined as the number of read failures due to error-correcting code (ECC) limit exceeded per read operations submitted.
The retry rate scale factor is defined as a relative weight given to the retry rate drive age estimate or the retry rate age criterion. For example, the retry rate scale factor can be 100 and be scaled to a specific higher or lower percentage to cause the retry rate to have a higher or lower impact on the drive age.
The max end of life retry rate is defined as the maximum retry rate the storage drive can reach and still meet performance requirements. For example, a storage drive's end-of-life performance might be specified to stay within five percent of the begin-of-life performance specification.
Further, it has been found that depending on the time overhead caused by retries, it is possible to calculate the maximum number of retries per read operation that the drive can operate at and stay within the pre-determined specification requirements. For example, some storage drives can tolerate at most one retry per one thousand read operations before performance is significantly impacted.
It has been found that the scale factors of the age criteria, including the PE scale factor, the defect scale factor, the defect rate scale factor, and the retry rate scale factor, can be adjusted to cause the scale factor to have a higher impact on the drive age. For example, the scale factor can be used to include a margin of error for the drive age compared to the actual failure stage of the storage drive. Further for example, the drive age can be estimated to be 100 by the use of the scale factor before the actual failure stage of the storage device. The margin of error provided by the scale factor ensures that the storage device can continue to perform reliably and predictably before the actual failure of the drive.
For example, the PE scale factor can be 100 and the defect scale factor can be 110. In this way, the drive age will reach 100 while more grown defects are still allowed. This margin is provided so that the storage drive can still be used for a short time after reaching the drive age of 100, ensuring storage drive reliability, avoiding loss of data, and providing replacement time for the drive.
Referring now to
A page is defined as the smallest group of data bytes that can be read from, or written to, in an erase block. An erase block is a group of pages, which contain the smallest number of pages that can be erased at one time.
Referring now to
The drive age is the maximum of the various underlying drive age criteria of the storage drive, such as the drive age based on the total PE measured, or the drive age based on the number of grown defects. Each of these age criteria has its own scale factor. The scale factor might allow that particular criterion to be outside of the range [0,100] but the final drive age is limited to [0, 100].
It has been found that the drive age can be an inherent integer, with the corresponding advantages in calculation and storage over a floating-point representation or a fixed-point representation containing a fractional part.
The control flow can begin at “start” and continue to a first drive age plus one step. The first drive age plus one step or function provides a bias at the beginning of the drive age calculations. It has been found that by providing a bias at the beginning of the calculations (where drive age is incremented by 1 before calculating the underlying age criteria), and then removing it later (where the drive age is decremented by 1 after calculating the underlying age criteria), the calculations of the underlying age criteria are simplified.
For example, it is desirable that the drive age remain at 0 until 1% of the drive's life is used, and only then increase to 1. If the drive age were not implemented as in integer calculation, it should have a floor function at the end of the calculation to cause this behavior. A way to perform that is to bias the calculations up and then remove the bias at the end of the calculations.
Further, it has been found that by biasing the drive age once at the beginning of the calculations, and removing the bias at the end of all the calculations, the step of having to perform this operation on each of the individual calculations is avoided. In addition, biasing the drive age involves simply incrementing and later decrementing by 1. However, the bias needed in the age criteria calculations would be more complicated than this base example.
The control flow can proceed to an equation one step or function. The memory controller can execute or calculate Equation (1) from
(PE factor*total PE measured)≧(drive age*erase block lifetime PE*total erase blocks) (1)
It has been found that by rearranging the calculations of the age criterion to those currently shown in the modified Equation (1) provide the benefit of no division operations being required. Division operations, which would be used in the most obvious implementations, are slow and cumbersome on most hardware. Equation (2), Equation (3), and Equation (4) can be rearranged in the same way to remove division operations, which increases the processing speed of the calculations by the memory controller.
If Equation (1) is found to be true, the control flow can proceed to a second age plus one step. After the drive age has been incremented by one by the second age plus one step, the control flow can proceed to a drive age minus one step. If Equation (1) is found to be false, the control flow can proceed to Equation (2).
The memory controller can execute or calculate Equation (2) to determine the drive age based on the number of grown defects. Equation (2) can be modified to avoid division operations as follows:
(defect scale factor*number of grown defects)≧(drive age*maximum allowed number of grown defects) (2)
If Equation (2) is found to be true, the control flow can proceed to a third drive age plus one step. After the drive age has been incremented by one, the control flow can proceed to a drive age minus one step. If Equation (2) is found to be false, the control flow can proceed to Equation (3).
The memory controller can execute or calculate Equation (3) to determine the drive age based on the change in defect rate. Equation (3) can be modified to avoid division operations as follows:
(defect rate scale factor*Measured defect rate)≧(drive age*max end of life defect rate) (3)
If Equation (3) is found to be true, the control flow can proceed to a fourth drive age plus one step. After the drive age has been incremented by one, the control flow can proceed to a drive age minus one step. If Equation (3) is found to be false, the control flow can proceed to Equation (4).
The memory controller can execute or calculate Equation (4) to determine the drive age based on the retry rate. Equation (4) can be modified to avoid division operations as follows:
(retry rate scale factor*Measured Retry Rate)≧drive age*Max end of life retry rate) (4)
If Equation (4) is found to be true, the control flow can proceed to a fifth drive age plus one step. After the drive age has been incremented by one, the control flow can proceed to a drive age minus one step. If Equation (4) is found to be false, the control flow can proceed to the drive age minus one step.
The control flow can proceed to the drive age minus one step from Equation (4), from the second drive age plus one step, the third drive age plus one step, the fourth drive age plus one step, or the fifth drive age plus one step. The bias of plus one that was included at the beginning of the control flow is removed during the drive age minus one step.
The control flow can proceed to a max drive age step after the drive age minus one step. The memory controller compares the drive age to the maximum drive age. The maximum drive age can be a predetermined value. For example, the maximum drive age can equal 100 or 99.
If the drive age is greater than the maximum drive age, then the storage drive has reached the maximum drive age. In this situation, the drive age is set to equal the maximum drive age. Based on this situation, a notification or warning to the user can be generated of the imminent failure of the storage drive and the control flow can conclude at “done”. If the drive age is less than the maximum drive age, the control flow can conclude at “done”.
It has been found that by calculating the age criteria sequentially, and skipping over the remaining age criteria if the drive age is incremented, calculations can be saved, and the storage drive age will not have any “missing codes” (the drive age will take on every value in [0, 100].
For example, Equation (1) to Equation (4) is sequentially calculated if the previous equation is found to be false. Subsequent equations are skipped if the current equation is found to be true. It has been discovered that the sequential calculation of the equations will also automatically select, over time, the maximum of all of the criteria, which will be reported as the drive age. The relative scale factors used in each criterion allows some criteria to have greater significance in the result.
It has been also found that calculating the drive age as an integer percentage provides the drive age as a monotonically non-decreasing value; this is a desirable property for the drive age for life of a single drive, and for comparing multiple storage drives to each other. Drive age results as integer percentages are consistent and predictable, which increases the reliability and predictability of the drive life of the storage drive.
It has also been found that by iteratively updating the drive age instead of calculating it directly on each update, the electronic system saves computational operations and yields the drive age guaranteed to be monotonically non-decreasing because of the single integer unit increments.
Referring now to
In the control flow, as an example, each module is indicated by an order and successively higher modules follow one another. Control flow can pass from one module to the next sequential module unless explicitly otherwise indicated. The memory controller of
The detect module can recall or access the current drive age at the time of the calculation for the estimate. The bias module increases the drive age by one to assign a bias.
The equation module can execute Equation (1), Equation (2), Equation (3), and Equation (4) to determine the drive age. The equations can be modified to remove division operations. It has been found that by rearranging the calculations of the underlying age criteria to those listed under the section for
For example, division operations, which would be used in the most obvious implementations, are slow and cumbersome on most hardware. Equation (1), Equation (2), Equation (3), and Equation (4) can be rearranged in the same way to remove division operations, which increases the processing speed of the calculations.
The equation module can include sub modules for executing the calculations for each of the equations based on age criteria. For example, an “equation one” sub-module can execute the calculations for Equation (1) and the electric system can include other sub-modules for Equation (2), Equation (3), and Equation (4).
The compare module can compare the metrics produced by each equation to determine the largest of the drive age estimates. The largest of the estimates from Equation (1), Equation (2), Equation (3), and Equation (4) will be used as the drive age.
The increment module can increase the drive age by one if any of the equations from the equation module are found to be true. The increment module can be coupled to the equation module and the remove module.
The remove module removes the bias that was added to the drive age by the bias module. The remove module can perform the drive age minus one step of
The max drive module determines if the drive age is greater or equal to the max drive age or maximum drive age. The max drive module can detect if the drive age has reached the max drive age. The max drive age can be a pre-determined percentage such as 100 or 99 percent. The max drive module can include a set module for setting the drive age to equal the max drive age.
The notification module can generate a notification or warning that the drive age of the storage drive has reached the max drive age. This allows users warning to back up information and timely replace the storage drive.
The control flow of the memory controller describes the module functions or order as an example. The modules can be partitioned differently. For example, the modules described in
The modules of
Referring now to
Thus, it has been discovered that the electronic system of the present invention furnishes important and heretofore unknown and unavailable solutions, capabilities, and functional aspects for an electronic system with read disturb management mechanism. The resulting method, process, apparatus, device, product, and/or system is straightforward, cost-effective, uncomplicated, highly versatile, accurate, sensitive, and effective, and can be implemented by adapting known components for ready, efficient, and economical manufacturing, application, and utilization.
Another important aspect of the present invention is that it valuably supports and services the historical trend of reducing costs, simplifying systems, and increasing performance. These and other valuable aspects of the present invention consequently further the state of the technology to at least the next level.
It will be understood that, although the terms “first,” “second,” etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first age criterion could be termed a second age criterion, and, similarly, a second age criterion could be termed a first age criterion, without changing the meaning of the description, so long as all occurrences of the “first age criterion” are renamed consistently and all occurrences of the “second age criterion” are renamed consistently. The first age criterion and the second age criterion are both age criteria, but they are not the same age criterion.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the claims. As used in the description of the embodiments and the appended claims, the singular forms “a,” “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
As used herein, the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in accordance with a determination” or “in response to detecting,” that a stated condition precedent is true, depending on the context. Similarly, the phrase “if it is determined [that a stated condition precedent is true]” or “if [a stated condition precedent is true]” or “when [a stated condition precedent is true]” may be construed to mean “upon determining” or “in response to determining” or “in accordance with a determination” or “upon detecting” or “in response to detecting” that the stated condition precedent is true, depending on the context.
The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the claims to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain principles of operation and practical applications, to thereby enable others skilled in the art.
This application claims priority to U.S. Provisional Patent Application Ser. No. 61/863,411, filed Aug. 7, 2013, entitled “Electronic System with Storage Drive Life Estimation Mechanism and Method of Operation Thereof,” which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4048481 | Bailey, Jr. et al. | Sep 1977 | A |
4839587 | Flatley et al. | Jun 1989 | A |
5034744 | Obinata | Jul 1991 | A |
5210854 | Beaverton et al. | May 1993 | A |
5311395 | McGaha et al. | May 1994 | A |
5450354 | Sawada et al. | Sep 1995 | A |
5479638 | Assar et al. | Dec 1995 | A |
5784174 | Fujino et al. | Jul 1998 | A |
5790828 | Jost | Aug 1998 | A |
5930504 | Gabel | Jul 1999 | A |
5949785 | Beasley | Sep 1999 | A |
5963983 | Sakakura et al. | Oct 1999 | A |
6034897 | Estakhri et al. | Mar 2000 | A |
6069827 | Sinclair | May 2000 | A |
6091652 | Haehn et al. | Jul 2000 | A |
6275436 | Tobita et al. | Aug 2001 | B1 |
6345367 | Sinclair | Feb 2002 | B1 |
6356447 | Scafidi | Mar 2002 | B2 |
6381176 | Kim et al. | Apr 2002 | B1 |
6381670 | Lee et al. | Apr 2002 | B1 |
6412080 | Fleming et al. | Jun 2002 | B1 |
6529997 | Debiez et al. | Mar 2003 | B1 |
6552581 | Gabara | Apr 2003 | B1 |
6587915 | Kim | Jul 2003 | B1 |
6618249 | Fairchild | Sep 2003 | B2 |
6661503 | Yamaguchi et al. | Dec 2003 | B1 |
6728913 | Parker | Apr 2004 | B1 |
6763424 | Conley | Jul 2004 | B2 |
6775792 | Ulrich et al. | Aug 2004 | B2 |
6778387 | Fairchild | Aug 2004 | B2 |
6850443 | Lofgren et al. | Feb 2005 | B2 |
6854070 | Johnson et al. | Feb 2005 | B2 |
6871304 | Hadjihassan et al. | Mar 2005 | B2 |
6903972 | Lasser et al. | Jun 2005 | B2 |
6906961 | Eggleston et al. | Jun 2005 | B2 |
6975028 | Wayburn et al. | Dec 2005 | B1 |
7082495 | DeWhitt et al. | Jul 2006 | B2 |
7107389 | Inagaki et al. | Sep 2006 | B2 |
7139864 | Bennett et al. | Nov 2006 | B2 |
7233497 | Simon et al. | Jun 2007 | B2 |
7243186 | Liang et al. | Jul 2007 | B2 |
7298888 | Hamar | Nov 2007 | B2 |
7330927 | Reeve et al. | Feb 2008 | B1 |
7333364 | Yu et al. | Feb 2008 | B2 |
7350101 | Nguyen et al. | Mar 2008 | B1 |
7355896 | Li et al. | Apr 2008 | B2 |
7434122 | Jo | Oct 2008 | B2 |
7441067 | Gorobets et al. | Oct 2008 | B2 |
7516267 | Coulson et al. | Apr 2009 | B2 |
7558109 | Brandman et al. | Jul 2009 | B2 |
7613871 | Tanaka et al. | Nov 2009 | B2 |
7620710 | Kottomtharayil et al. | Nov 2009 | B2 |
7620769 | Lee et al. | Nov 2009 | B2 |
7639532 | Roohparvar et al. | Dec 2009 | B2 |
7661054 | Huffman et al. | Feb 2010 | B2 |
7679948 | Park et al. | Mar 2010 | B2 |
7693422 | Alicherry et al. | Apr 2010 | B2 |
7738502 | Chang et al. | Jun 2010 | B2 |
7743216 | Lubbers et al. | Jun 2010 | B2 |
7818525 | Frost et al. | Oct 2010 | B1 |
7827348 | Lee et al. | Nov 2010 | B2 |
7830164 | Earle et al. | Nov 2010 | B2 |
7853749 | Kolokowsky | Dec 2010 | B2 |
7979614 | Yang | Jul 2011 | B1 |
8000161 | Stan et al. | Aug 2011 | B2 |
8001135 | Perlmutter et al. | Aug 2011 | B2 |
8010738 | Chilton et al. | Aug 2011 | B1 |
8028123 | Kilzer et al. | Sep 2011 | B2 |
8046645 | Hsu et al. | Oct 2011 | B2 |
8051241 | Feldman et al. | Nov 2011 | B2 |
8072805 | Chou et al. | Dec 2011 | B2 |
8095724 | Ji et al. | Jan 2012 | B2 |
8095765 | Asnaashari et al. | Jan 2012 | B2 |
8117396 | Fair et al. | Feb 2012 | B1 |
8127202 | Cornwell et al. | Feb 2012 | B2 |
8145984 | Sommer et al. | Mar 2012 | B2 |
8154921 | Mokhlesi et al. | Apr 2012 | B2 |
8169825 | Shalvi et al. | May 2012 | B1 |
8205028 | Sakarda | Jun 2012 | B1 |
8209677 | Shintani et al. | Jun 2012 | B2 |
8219724 | Caruso et al. | Jul 2012 | B1 |
8219776 | Forhan et al. | Jul 2012 | B2 |
8228701 | Sokolov et al. | Jul 2012 | B2 |
8245101 | Olbrich et al. | Aug 2012 | B2 |
8250621 | Cha | Aug 2012 | B2 |
8254172 | Kan | Aug 2012 | B1 |
8259506 | Sommer et al. | Sep 2012 | B1 |
8289801 | Smith et al. | Oct 2012 | B2 |
8296534 | Gupta et al. | Oct 2012 | B1 |
8332578 | Frickey, III et al. | Dec 2012 | B2 |
8363413 | Paquette et al. | Jan 2013 | B2 |
8369141 | Sommer et al. | Feb 2013 | B2 |
8386700 | Olbrich et al. | Feb 2013 | B2 |
8386860 | Tseng et al. | Feb 2013 | B2 |
8397101 | Goss et al. | Mar 2013 | B2 |
8407409 | Kawaguchi | Mar 2013 | B2 |
8464106 | Filor et al. | Jun 2013 | B2 |
8503238 | Wu et al. | Aug 2013 | B1 |
8521981 | Strauss et al. | Aug 2013 | B2 |
8560770 | Haines et al. | Oct 2013 | B2 |
8601203 | Holbrook et al. | Dec 2013 | B2 |
8612669 | Syu et al. | Dec 2013 | B1 |
8612804 | Kang et al. | Dec 2013 | B1 |
8661184 | Wood et al. | Feb 2014 | B2 |
8694811 | Raju et al. | Apr 2014 | B2 |
8725931 | Kang | May 2014 | B1 |
8750052 | Aoki et al. | Jun 2014 | B2 |
8793556 | Northcott et al. | Jul 2014 | B1 |
8799747 | Goss et al. | Aug 2014 | B2 |
8832506 | Griffin et al. | Sep 2014 | B2 |
8862818 | Ozdemir | Oct 2014 | B1 |
8880838 | Kaiser et al. | Nov 2014 | B2 |
8984216 | Fillingim | Mar 2015 | B2 |
9043668 | Goss et al. | May 2015 | B2 |
9063844 | Higgins et al. | Jun 2015 | B2 |
9069468 | Mehra et al. | Jun 2015 | B2 |
9116401 | Kim et al. | Aug 2015 | B2 |
20020056025 | Qiu et al. | May 2002 | A1 |
20020156891 | Ulrich et al. | Oct 2002 | A1 |
20020159285 | Morley et al. | Oct 2002 | A1 |
20030033308 | Patel et al. | Feb 2003 | A1 |
20030046603 | Harari et al. | Mar 2003 | A1 |
20030074592 | Hasegawa | Apr 2003 | A1 |
20030163633 | Aasheim et al. | Aug 2003 | A1 |
20040080985 | Chang et al. | Apr 2004 | A1 |
20040088511 | Bacon et al. | May 2004 | A1 |
20040252670 | Rong et al. | Dec 2004 | A1 |
20050021904 | Iaculo et al. | Jan 2005 | A1 |
20050038792 | Johnson | Feb 2005 | A1 |
20050073884 | Gonzalez et al. | Apr 2005 | A1 |
20050076102 | Chen et al. | Apr 2005 | A1 |
20050144516 | Gonzalez et al. | Jun 2005 | A1 |
20060015683 | Ashmore et al. | Jan 2006 | A1 |
20060020745 | Conley et al. | Jan 2006 | A1 |
20060022054 | Elhamias et al. | Feb 2006 | A1 |
20060080505 | Arai et al. | Apr 2006 | A1 |
20060136682 | Haridas et al. | Jun 2006 | A1 |
20060143365 | Kikuchi | Jun 2006 | A1 |
20060143475 | Herbert et al. | Jun 2006 | A1 |
20060253641 | Gatzemeier et al. | Nov 2006 | A1 |
20060256624 | Eggleston et al. | Nov 2006 | A1 |
20060282644 | Wong | Dec 2006 | A1 |
20060294574 | Cha | Dec 2006 | A1 |
20070050536 | Kolokowsky | Mar 2007 | A1 |
20070061511 | Faber | Mar 2007 | A1 |
20070067598 | Fujimoto | Mar 2007 | A1 |
20070079152 | Winick et al. | Apr 2007 | A1 |
20070083779 | Misaka et al. | Apr 2007 | A1 |
20070226592 | Radke | Sep 2007 | A1 |
20070234004 | Oshima et al. | Oct 2007 | A1 |
20070260811 | Merry, Jr. et al. | Nov 2007 | A1 |
20070263444 | Gorobets et al. | Nov 2007 | A1 |
20070276973 | Tan et al. | Nov 2007 | A1 |
20080028246 | Witham | Jan 2008 | A1 |
20080046630 | Lasser | Feb 2008 | A1 |
20080052446 | Lasser et al. | Feb 2008 | A1 |
20080082736 | Chow et al. | Apr 2008 | A1 |
20080126720 | Danilak | May 2008 | A1 |
20080183918 | Dhokia et al. | Jul 2008 | A1 |
20080189588 | Tanaka et al. | Aug 2008 | A1 |
20080263289 | Hosoya et al. | Oct 2008 | A1 |
20080313505 | Lee et al. | Dec 2008 | A1 |
20090006900 | Lastras-Montano et al. | Jan 2009 | A1 |
20090019321 | Radke | Jan 2009 | A1 |
20090070651 | Diggs et al. | Mar 2009 | A1 |
20090083587 | Ng et al. | Mar 2009 | A1 |
20090089485 | Yeh | Apr 2009 | A1 |
20090091990 | Park et al. | Apr 2009 | A1 |
20090109786 | Ye et al. | Apr 2009 | A1 |
20090125670 | Keays | May 2009 | A1 |
20090132756 | Hsieh | May 2009 | A1 |
20090138654 | Sutardja | May 2009 | A1 |
20090146721 | Kurooka et al. | Jun 2009 | A1 |
20090157948 | Trichina et al. | Jun 2009 | A1 |
20090164702 | Kern | Jun 2009 | A1 |
20090164710 | Choi et al. | Jun 2009 | A1 |
20090172248 | You | Jul 2009 | A1 |
20090172262 | Olbrich et al. | Jul 2009 | A1 |
20090179707 | Higashino | Jul 2009 | A1 |
20090183183 | Muppirala et al. | Jul 2009 | A1 |
20090228634 | Nakamura et al. | Sep 2009 | A1 |
20090228761 | Perlmutter et al. | Sep 2009 | A1 |
20090259819 | Chen et al. | Oct 2009 | A1 |
20090259896 | Hsu et al. | Oct 2009 | A1 |
20090271562 | Sinclair | Oct 2009 | A1 |
20090287975 | Kim et al. | Nov 2009 | A1 |
20090300238 | Panabaker et al. | Dec 2009 | A1 |
20090323419 | Lee et al. | Dec 2009 | A1 |
20090327581 | Coulson | Dec 2009 | A1 |
20090327591 | Moshayedi | Dec 2009 | A1 |
20100017650 | Chin et al. | Jan 2010 | A1 |
20100023674 | Aviles | Jan 2010 | A1 |
20100050053 | Wilson et al. | Feb 2010 | A1 |
20100082890 | Heo et al. | Apr 2010 | A1 |
20100122019 | Flynn et al. | May 2010 | A1 |
20100128537 | Suhail et al. | May 2010 | A1 |
20100138592 | Cheon | Jun 2010 | A1 |
20100165689 | Rotbard et al. | Jul 2010 | A1 |
20100169541 | Freikorn | Jul 2010 | A1 |
20100172179 | Gorobets et al. | Jul 2010 | A1 |
20100174845 | Gorobets et al. | Jul 2010 | A1 |
20100217898 | Priborsky et al. | Aug 2010 | A1 |
20100217915 | O'Connor et al. | Aug 2010 | A1 |
20100223531 | Fukutomi et al. | Sep 2010 | A1 |
20100228928 | Asnaashari et al. | Sep 2010 | A1 |
20100262792 | Hetzler et al. | Oct 2010 | A1 |
20100262795 | Hetzler et al. | Oct 2010 | A1 |
20100262875 | Hetzler et al. | Oct 2010 | A1 |
20100287328 | Feldman et al. | Nov 2010 | A1 |
20100293367 | Berke et al. | Nov 2010 | A1 |
20100312954 | Jeon et al. | Dec 2010 | A1 |
20100318719 | Keays et al. | Dec 2010 | A1 |
20100325340 | Feldman et al. | Dec 2010 | A1 |
20100332726 | Wang | Dec 2010 | A1 |
20110002224 | Tamura | Jan 2011 | A1 |
20110016239 | Stenfort | Jan 2011 | A1 |
20110055455 | Post et al. | Mar 2011 | A1 |
20110055468 | Gonzalez et al. | Mar 2011 | A1 |
20110066788 | Eleftheriou et al. | Mar 2011 | A1 |
20110072423 | Fukata | Mar 2011 | A1 |
20110078393 | Lin | Mar 2011 | A1 |
20110099342 | Ozdemir | Apr 2011 | A1 |
20110107144 | Ohara | May 2011 | A1 |
20110131365 | Zhang et al. | Jun 2011 | A1 |
20110131447 | Prakash et al. | Jun 2011 | A1 |
20110132000 | Deane et al. | Jun 2011 | A1 |
20110138100 | Sinclair | Jun 2011 | A1 |
20110145473 | Maheshwari | Jun 2011 | A1 |
20110161775 | Weingarten | Jun 2011 | A1 |
20110190963 | Glassl et al. | Aug 2011 | A1 |
20110191522 | Condict et al. | Aug 2011 | A1 |
20110191649 | Lim et al. | Aug 2011 | A1 |
20110209032 | Choi et al. | Aug 2011 | A1 |
20110238892 | Tsai et al. | Sep 2011 | A1 |
20110239088 | Post | Sep 2011 | A1 |
20110258496 | Tseng et al. | Oct 2011 | A1 |
20110314219 | Ulrich et al. | Dec 2011 | A1 |
20110320687 | Belluomini et al. | Dec 2011 | A1 |
20120008401 | Katz et al. | Jan 2012 | A1 |
20120011336 | Saika | Jan 2012 | A1 |
20120023144 | Rub | Jan 2012 | A1 |
20120047318 | Yoon et al. | Feb 2012 | A1 |
20120047320 | Yoo et al. | Feb 2012 | A1 |
20120047409 | Post et al. | Feb 2012 | A1 |
20120066450 | Yochai et al. | Mar 2012 | A1 |
20120079348 | Naeimi | Mar 2012 | A1 |
20120079355 | Patapoutian et al. | Mar 2012 | A1 |
20120096217 | Son et al. | Apr 2012 | A1 |
20120124046 | Provenzano | May 2012 | A1 |
20120124273 | Goss et al. | May 2012 | A1 |
20120151260 | Zimmermann et al. | Jun 2012 | A1 |
20120170365 | Kang et al. | Jul 2012 | A1 |
20120185706 | Sistla et al. | Jul 2012 | A1 |
20120213004 | Yun et al. | Aug 2012 | A1 |
20120216085 | Weingarten et al. | Aug 2012 | A1 |
20120236656 | Cometti | Sep 2012 | A1 |
20120239858 | Melik-Martirosian | Sep 2012 | A1 |
20120254686 | Esumi et al. | Oct 2012 | A1 |
20120266011 | Storer et al. | Oct 2012 | A1 |
20120266048 | Chung et al. | Oct 2012 | A1 |
20120278530 | Ebsen | Nov 2012 | A1 |
20120278531 | Horn | Nov 2012 | A1 |
20120284587 | Yu et al. | Nov 2012 | A1 |
20120297113 | Belluomini et al. | Nov 2012 | A1 |
20120311402 | Tseng et al. | Dec 2012 | A1 |
20120317334 | Suzuki et al. | Dec 2012 | A1 |
20120324191 | Strange et al. | Dec 2012 | A1 |
20120331207 | Lassa et al. | Dec 2012 | A1 |
20130007380 | Seekins et al. | Jan 2013 | A1 |
20130007543 | Goss et al. | Jan 2013 | A1 |
20130054881 | Ellis et al. | Feb 2013 | A1 |
20130060994 | Higgins et al. | Mar 2013 | A1 |
20130061019 | Fitzpatrick et al. | Mar 2013 | A1 |
20130073788 | Post et al. | Mar 2013 | A1 |
20130073797 | Chowdhury | Mar 2013 | A1 |
20130074093 | Gounares et al. | Mar 2013 | A1 |
20130080691 | Weingarten et al. | Mar 2013 | A1 |
20130094289 | Sridharan et al. | Apr 2013 | A1 |
20130100600 | Yin et al. | Apr 2013 | A1 |
20130104005 | Weingarten et al. | Apr 2013 | A1 |
20130124792 | Melik-Martirosian et al. | May 2013 | A1 |
20130151753 | Jeon et al. | Jun 2013 | A1 |
20130198436 | Bandic et al. | Aug 2013 | A1 |
20130205102 | Jones et al. | Aug 2013 | A1 |
20130232290 | Ish et al. | Sep 2013 | A1 |
20130238833 | Vogan et al. | Sep 2013 | A1 |
20130265825 | Lassa | Oct 2013 | A1 |
20130304998 | Palmer | Nov 2013 | A1 |
20130326116 | Goss et al. | Dec 2013 | A1 |
20130332791 | Chu | Dec 2013 | A1 |
20140036589 | Parthasarathy et al. | Feb 2014 | A1 |
20140059359 | Bahirat | Feb 2014 | A1 |
20140108891 | Strasser et al. | Apr 2014 | A1 |
20140129874 | Zaltsman et al. | May 2014 | A1 |
20140158525 | Greene | Jun 2014 | A1 |
20140181370 | Cohen et al. | Jun 2014 | A1 |
20140208174 | Ellis et al. | Jul 2014 | A1 |
20140258769 | Baryudin et al. | Sep 2014 | A1 |
20140372777 | Reller et al. | Dec 2014 | A1 |
Number | Date | Country |
---|---|---|
1 956 489 | Aug 2008 | EP |
1 990 921 | Nov 2008 | EP |
2 498 259 | Sep 2012 | EP |
2012129859 | Jul 2012 | JP |
WO 2009042298 | Apr 2009 | WO |
WO 2011156466 | Dec 2011 | WO |
Entry |
---|
Narayanan et al., “Migrating Server Storage to SSDs: Analysis of Tradeoffs,” Computer , Systems, Apr. 2009, 12 pages. |
Shiraz et al., “Block Aging Prevention Technique (BAP) for Flash Based Solid State Disks,” 7th International Conference on Emerging Technologies (ICET), Sep. 5, 2011, 6 pages. |
Tai et al., “Prolongation of Lifetime and the Evaluation Method of Dependable SSD,” 25 International Symposium on Defect and Fault Tolerance in VLSI Systems, 2010, NJ, USA, 8 pages. |
Tseng et al., “Understanding the Impact of Power Loss on Flash Memory,” DAC'11, Jun. 5-10, 2011, San Diego, California, 6 pages. |
Yimo et al., “WeLe-RAID: A SSD-Based RAID for System Endurance and Performance,” Jan. 2011, Network and Parallel Computing, Springer, 14 pages. |
International Search Report and Written Opinion dated Feb. 18, 2015, received in International Patent Application No. PCT/US2014/065401, which corresponds to U.S. Appl. No. 14/082,031, 9 pages (Higgins). |
International Search Report dated Apr. 15, 2014, received in International Patent Application No. PCT/US2013/078340, which corresponds to U.S. Appl. No. 13/746,642, 11 pages (Ellis). |
International Search Report and Written Opinion dated Jan. 9, 2015, received in International Patent Application No. PCT/US2014/049731, which corresponds to U.S. Appl. No. 14/334,324, 9 pages (Fitzpatrick). |
Cooke, “Introduction to Flash Memory (T1 A),” Flash Memory Summit, Aug. 22, 2008, Micron Technology, Inc., 102 pages. |
Gal et al., “Algotithms and Data Structures for Flash Memories,” ACM Computing Surveys, Jun. 2005, vol. 37, No. 2, 30 pages. |
IBM Corporation, “Systems Management, Work Management,” Version 5, Release 4, 9th Edition, Feb. 2006, pp. 1-21. |
O'Brien, “SMART Storage Systems Optimus SAS Enterprise SSD Review,” SMART Storage Systems, Oct. 9, 2012, 44 pages. |
Spanjer, “Flash Management—Why and How?” Smart Modular Technologies, Nov. 2009, http://www.scantec.de/fileadmin/pdf/Smart—Modular/Flash-Management.pdf, 14 pages. |
Texas Instruments, “Power Management IC for Digital Set Top Boxes,” SLVSA10A, Sep. 2009, pp. 1-22. |
International Search Report and Written Opinion dated Dec. 20, 2013, received in PCT/US2013/045282, which corresponds to U.S. Appl. No. 13/493,949, 7 pages (Ellis). |
International Search Report and Written Opinion dated Jun. 12, 2014, received in PCT/US2014/018972, which corresponds to U.S. Appl. No. 13/779,352, 12 pages (Schmier). |
International Search Report and Written Opinion dated May 14, 2014, received in International Patent Application No. PCT/US2014/017168, which corresponds to U.S. Appl. No. 14/076,115, 6 pages (Fitzpatrick). |
International Search Report and Written Opinion dated May 14, 2014, received in International Patent Application No. PCT/US2014/017169, which corresponds to U.S. Appl. No. 14/076,148, 6 pages (Fitzpatrick). |
Ulinktech, “ATA Command Table (in Alphabetic Order),” Feb. 6, 2011, https://web.archive.org/web/20110206060820/http://www.ulinktech.com/downloads/AT, 6 pages. |
International Search Report and Written Opinion dated Aug. 22, 2014, received in International Patent Application No. PCT/US2014/032978, which corresponds to U.S. Appl. No. 14/081,992, 10 pages (Ellis). |
International Search Report dated Mar. 25, 2014, received in International Patent Application No. PCT/US2013/072400, which corresponds to U.S. Appl. No. 13/690,337, 3 pages (Ellis). |
Invitation to Pay Additional Fees dated Jul. 25, 2014, received in International Patent Application No. PCT/US2014/021290, which corresponds to U.S. Appl. No. 13/791,797, 8 paaes (Dean). |
International Search Report and Written Opinion dated Jul. 31, 2014, received in International Patent Application No. PCT/US2014/031465, which corresponds to U.S. Appl. No. 13/851,928, 13 pages (Ellis). |
International Search Report and Written Opinion dated Jul. 31, 2014, received in International Patent Application No. PCT/US2014/033876, which corresponds to U.S. Appl. No. 13/861,326, 9 pages (Fitzpatrick). |
International Search Report and Written Opinion dated Nov. 7, 2014, received in International Patent Application No. PCT/US2014/049732, which corresponds to U.S. Appl. No. 14/334,350, 13 pages (Fitzpatrick). |
International Search Report and Written Opinion dated Oct. 7, 2014, received in International Patent Application No. PCT/US2014/049734, which corresponds to U.S. Appl. No. 14/332,259, 8 pages (Higgins). |
International Search Report and Written Opinion dated Oct. 23, 2014, received in International Patent Application No. PCT/US2014/049736, which corresponds to U.S. Appl. No. 14/446,249, 8 pages (Fitzpatrick). |
International Search Report and Written Opinion dated Nov. 5, 2014, received in International Patent Application No. PCT/US2014/049282, which corresponds to U.S. Appl. No. 13/957,407,12 pages (Fitzpatrick). |
Online Merriam Webster Dictionary, definition of “Distinct” from Jun. 12, 2011, https://web.archive.org/web/20110612181129/http://www2.merriam-webster.com/cgi-bin/mwdictadu?book=Dictionary&va=distinct. |
Number | Date | Country | |
---|---|---|---|
20150046635 A1 | Feb 2015 | US |
Number | Date | Country | |
---|---|---|---|
61863411 | Aug 2013 | US |