The present invention relates generally to a data storage system and more particularly to data management with modular erase in a data storage system.
Various forms of long-term storage in computer systems include, other than electromechanical hard disks, non-volatile storage rooted in semiconductor or other memory technology. NOT-AND (NAND) flash memory is one form of non-volatile memory used in solid-state storage devices. In a common configuration of flash memory, the memory cells are arranged in typical row and column fashion with circuitry for accessing individual cells. The data store elements (e.g. transistors) of those cells are configured to hold two logical states in the case of Single Level Cell (SLC) or more than two logical states in the case of Multi Level Cell (MLC).
The flash memory is block-based storage and can require a block to be erased before being rewritten. Other commands cannot be performed while the erase operation is being performed. This can lead to longer command latency for the other commands while they wait for the erase operation to complete. In addition, because the duration of the erase operations can increase as the flash memory ages, the command latency can increase over time.
Thus, a need still remains for better data storage devices that can optimize command latency. 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 important to find answers 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.
Prior developments have long sought but not found optimal solutions to these problems. Hence, there remains a need that has long eluded those skilled in the art.
The present disclosure covers a system and method of data management with modular erase in a data storage system including partitioning the erase operation into one or more partial erase operations, executing intervening commands between partial erase operations, modifying the operational values of the partial erase operations, and implementing a dwell time delay for partial erase.
Certain embodiments have other steps or elements in addition to or in place of those mentioned above. The steps or elements will become apparent to those skilled in the art from a reading of the following detailed description when taken with reference to the accompanying drawings. The embodiments described herein are illustrative and should not limit the scope of the claimed invention as recited in the claims.
The following embodiments are described in sufficient detail to enable those skilled in the art to make and use the claimed 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 claimed 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 simplify the disclosure, 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 figures.
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.
Referring now to
The controller 102 is a processing unit for managing the storage and retrieval of data in the memory array 106. The controller 102 can be an embedded processor, control logic, or a combination thereof. The controller 102 can transfer stored data from the memory array 106 to a host device 140.
The memory array 106 is a non-volatile memory unit for storing data. The memory array 106 can include NAND flash memory arrays, NOR flash memory arrays, other non-volatile memory arrays, or a combination thereof.
The memory array 106 can be formed with memory dice 132. The memory dice 132 are semiconductor devices for storing information. The memory dice are the minimum unit that can independently execute commands and report status. For example, the memory dice 132 can be flash memory devices, NAND flash memory chips, NOR flash memory devices, or a combination thereof.
The memory bus 104 is a communication channel. The memory bus 104 conveys data and control information between the controller 102 and the memory array 106.
The memory dice 132 can include a cell array 134. The cell array 134 is a set of non-volatile flash memory cells for storing data. For example, the cell array 134 can include a single-level cell flash memory, a multi-level cell flash memory, a mixed functionality cell, or a combination thereof.
The cell array 134 can include memory cells 136. The memory cells 136 are electronic structures for storing information. For example, the memory cells 136 can be floating gate flash memory devices.
The memory array 106 can include an array logic unit 130 coupled to the cell array 134. The array logic unit 130 is circuitry to provide addressing, data transfer and sensing, and other support to control the memory array 106 for saving and retrieving information from the cell array 134.
The controller 102 can include a memory interface 116 coupled to the memory array 106. The memory interface 116 can include circuitry for communicating with the memory array 106 over the memory bus 104.
The controller 102 can include a control unit 110 coupled to the memory interface 116 and a host interface 114. A read only memory 118 can be coupled to the control unit 110. A random access memory 120 can be coupled to the control unit 110 and to the read only memory 118. The random access memory 120 can be utilized as a buffer memory for temporary storage of data being written to or read from the memory array 106.
The random access memory 120 can include a controller database 124. The controller database 124 is a data storage and retrieval system. The controller database 124 can be used to store read threshold information.
The read only memory 118 can include a software 122 for operating the control unit 110. The software 122 is executable code for implementing the intelligence of the data storage system 100.
The controller 102 can include an error correction code unit 112 coupled to the control unit 110. The error correction code unit 112 is a processing module for calculating an error correction code value that can be used to detect errors, correct errors, or a combination thereof in data stored or transmitted from the memory array 106.
The error correction code unit 112 can calculate one or more error correction code values using different methods such as a Reed-Solomon code, a Hamming code, a Bose-Chauduri-Hocquenghem (BCH) code, or a combination thereof. Although the error correction code unit 112 is a dedicated element for calculating error correction codes, it is understood that error correction codes can also be calculated in other ways, such as using the control unit 110 to calculate error correction codes.
The controller 102 can include the host interface 114 coupled to the host device 140 via a digital connection 138. The host device 140 is a computing device that can use the data storage system 100 for storing data. For example, the host device 140 can be a laptop computer, a desktop computer, a server, a smart phone, or a combination thereof.
The host interface 114 can communicate commands and data between the host device 140 and the controller 102 with the digital connection 138. For example, the host interface 114 can detect a connection to the host device 140 and generate command based on the connection to the host device 140.
The data storage system 100 can be connected to the host device 140 with the digital connection 138. The digital connection 138 is a communication link for transferring digital information between the data storage system 100 and the host device 140.
The digital connection 138 can be formed in a variety of ways. For example, the digital connection 138 can be a universal serial bus (USB) connection for transferring information. In another example, the digital connection 138 can be a wireless communication mechanism, such as Wireless Fidelity (Wi-Fi), infrared communication mechanism, optical communication system, near field communication system, or a combination thereof.
Referring now to
The data storage system 100 can have a variety of storage capacities determined by the number of the memory dice 132 used to form the data storage system 100. For example, the data storage system 100 can include 2 gigabytes (GB) of flash memory, 8 GB, 16 GB, or other memory sizes.
The data storage system 100 can include a number of the memory blocks 204. The memory blocks 204 are portions of the memory array 106 of
The memory blocks 204 can be on different logical units 222. The logical units 222 are a group of the memory blocks on the memory dice 132 which are single threaded and allow only one operation at a time. The logical units 222 can be a complete one of the memory dice 132, logical memory partitions, or a combination thereof. A die is a physical memory element composed of a number of the memory blocks that are accessed via one single CE (chip enable). The logical units 222 (LUN) is a group of logical erase blocks on a die which are single threaded and only one operation is allowed at a time.
The memory blocks 204 can include erase blocks 206. The erase blocks 206 are the smallest unit of memory that can be erased as a single entity at one time.
There are a number of different configurations for the data storage system 100 that use block based non-volatile random access memory (NVRAM) or NAND flash memory. The erase command can cause latencies will increase as the age of the memory increases.
During the normal operation of the data storage system 100, blocks of memory are required to be erased for a number of reasons. One of the memory blocks 204, such as the erase blocks 206, must be erased to re-write one of the memory blocks 204. While the erase command is executing no other operations, other than status reads, can be executed on the logical units 222 where the erase blocks 206 reside.
The data in the logical units 222 of the erase blocks 206 being erased is not available for use by other commands until the erase command has completed. Thus, a host read operation received at the start of the erase command can have a latency of the read operation plus the executing erase operation. Latency can be defined as the amount of time it takes the storage device to respond to a host request. Read latency is the amount of time it takes between receiving the host read request and when the read data starts flowing back to the host.
Each of the erase blocks 206 can have a program erase cycle count 218. When one of the erase blocks 206 is erased, then the program erase cycle count 218 can be incremented. The program erase cycle count 218 can be one factor used to determine the age or level of wear of one of the memory blocks 204. The program erase cycle count 218 is a measure of the level of usage within one of the erase blocks 206. The flash memory devices, such as NAND flash, have a limited number of useful program erase cycles. The program erase cycle count 218 can be a base level determination of how data is replaced within the erase blocks 206. NAND flash memory and other memory types have a limited number of useful program erase cycles.
During the normal operation of the data storage system 100, one of the erase blocks 206 can be erased for a variety of reasons. For example, in NAND flash memory, the erase blocks 206 must be erased before being re-written with a given set of data for the memory blocks 204.
The memory blocks 204 can be divided into the memory pages 202. The memory pages 202 are the smallest group of data bytes that can be read or written in the data storage system 100. The memory pages 202 are the smallest addressable unit of memory that can be programmed. For example, each of the memory blocks 204 can have 64 of the memory pages 202.
The memory pages 202 include a data area 208 and a spare area 210. The data area 208 is a group of memory cells used to store user data. The data area 208 can be various sizes. For example, the data area 208 of one of the memory pages 202 can be 2,048 bytes.
The spare area 210 is a group of memory cells to store metadata about the data area 208. For example, the spare area 210 can include error correction code information, status information, or a combination thereof. The spare area 210 can have a variety of sizes. For example, the spare area 210 can be 128 bytes. The memory pages 202 can have a size of 4,224 bytes for the data area 208 and the spare area 210.
The memory array 106 of
Reading one of the memory pages 202 can result in reading errors where one or more of the bits in the memory pages 202 are incorrect. The number of individual bit errors in a stream of data is described as a bit error rate 216. The bit error rate 216 (BER) is defined as numbers of incorrect bits in a data stream stored in the data storage system 100. The incorrect bits can be detected within a code word protected by an error-correcting code (ECC).
The code word refers to a group of data bytes covered by a single instance of multiple ECC parity words. The error-correcting code refers to parity or redundant data generated over a set of host or user data grouped into the code word. The bit error rate 216 is the number of incorrect bits in a data stream stored in the flash memory.
The data storage system 100 can include a memory age 220 associated with different memory elements. The memory age 220 is a value indicating the level of usage of a memory element. The memory age 220 can indicate how long a storage system or a memory component has existed or has been in operation. For example, the memory age 220 can be based on a number of erase cycles, how long it has been since the last time an erase block was written, an average BER an erase block is yielding, a temperature at which a device has been run, or a combination thereof.
The memory age 220 can be calculated based on age metrics 221. The age metrics 221 are values for indicating the level of wear of the erase blocks 206. The age metrics 221 can also include the bit error rate 216, the temperature, calendar age, usage cycles, or a combination thereof. In another example, the age metrics 221 can be influenced by the program erase cycle count 218.
There are numerous methods for measuring the memory age 220. For example, the memory age 220 can be on the value of one of the age metrics 221 such as the bit error rate 216, temperature, program time, optimal read threshold, erase time, or a combination thereof. The memory age 220 is an estimate of the amount of wear on the flash memory element.
The memory age 220 can represent a variety of memory elements. For example, the memory age 220 can include the age of one of the memory dice 132, one of the memory blocks 204, one of the memory pages 202, one of the erase blocks 206, one of the memory cells, or a combination thereof.
Referring now to
The memory blocks 204 are units of memory. The memory blocks 204 with content that is no longer required can be designed as the erase blocks 206 and allocated to the erase block pool 304. The erase block pool 304 is the set of erase blocks 206 that can be recycled and erased before being rewritten. The target block 302 is one of the memory blocks 204 where a read or write operation can be performed.
The defect pool 308 is a list of defect blocks 306 that are designated defective and not reused. One of the erase blocks 206 can be assigned to the defect pool 308 and designated one of the defect blocks 306 if the erase operation fails and one of the erase blocks 206 cannot be erased. The defect block 306 can have an erase failed status 310 to indicate that the erase operation has failed.
Referring now to
The data storage system 100 can be coupled to the host device 140 with the digital connection 138. The host device 140 can include a host command queue 402 for holding data operation commands 424 for the data storage system 100. The data operation commands 424 are instructions for manipulating data. The data operation commands 424 can include read, write, erase, status, set parameter, or a combination thereof.
The host command queue 402 can include an ordered set of commands for manipulating data in the data storage system 100 such as read, write, erase, status, or a combination thereof. The data operation commands 424 in the host command queue 402 can be transferred to the controller 102 for execution.
The data storage system 100 can include the controller 102 coupled to the memory array 10 with the memory bus 104. The controller 102 can include a controller command queue 404.
The controller command queue 404 is a structure for holding the data operation commands 424. The controller command queue 404 can include the data operation commands 424 from the host command queue 402 and local commands generated within the controller 102. The controller command queue 404 can include an ordered set of commands for manipulating data in the memory array 106. For example, the controller command queue 404 can include commands such as read, write, erase, status, or a combination thereof.
The controller command queue 404 can include a variety of the data operation commands 424. For example, the controller command queue 404 can include one of the data operation commands 424 to erase one of the erase blocks 206. The controller command queue 404 can include one of the data operation commands 424 to read the target block 302.
In an illustrative example, the controller 102 can select a command, such as an erase command 406, from the controller command queue 404 and transfer the erase command 406 to the memory array 106 for execution. The erase command 406 is an operation to erase one or more of the erase blocks 206. The erase command 406 can include an operation matrix 408 having configuration information.
The erase command 406 can include a command status 430. The command status 430 is a value indicating the result of an operation. For example, the command status 430 can indicate the success or failure of the erase command 406.
The operation matrix 408 is a set of values for controlling how the erase command 406 is performed. The operation matrix 408 can include erase operation values 426 for controlling the electrical properties of the erase command 406.
For example, the operation matrix 408 can include values such as an erase mode 410, an erase pulse count 412, an erase voltage 414, an erase pulse width 416, a maximum execution time 418, a threshold voltage 420, and a dwell time 422. The operation matrix 408 can include values for a complete erase operation, individual values for one or more partial erase operations, or a combination thereof.
The erase mode 410 can indicate the type of erase operation to perform. For example, the erase mode 410 can specify that a complete erase operation be performed in a single step. In another example, the erase mode 410 can specify that the complete erase operation be performed with one or more partial erase operations. The partial erase can be an erase-component that does not fully erase the memory (i.e., partially erases the memory). A final erase can be an erase-component that fully erases the memory. The final erase is the last erase component of a multiple-erase-component operation. The erase pulse count 412 can indicate the number of erase pulses to be used to perform the erase command 406. Using a lower value of the erase pulse count 412 can result in a partial erasure of one of the erase blocks 206.
The erase voltage 414 can indicate the value of the voltage to be used to perform the erase command 406. Using a lower value of the erase voltage 414 can result in a partial erasure of one of the erase blocks 206.
The erase pulse width 416 is the length of time the erase voltage 414 is applied to one of the erase blocks 206 during an erase operation, including a partial erase operation. An erase pulse is the erase voltage 414 applied for a period of time defined by the erase pulse width 416. Using a shorter value of the erase pulse width 416 for a given value of the erase voltage 414 can result in a partial erasure of the erase blocks 206.
The maximum execution time 418 is the maximum amount of time for performing a complete erase operation. The maximum execution time 418 can include one or more cycles of the erase pulse width 416.
The threshold voltage 420 is the voltage level indicating that one of the erase blocks 206 has been erased. The threshold voltage 420 can indicate the voltage setting applied to internal NAND comparators which determine the digital values stored in the NAND cells. After the erase operation, the voltage level of the erase blocks 206 can be compared to the threshold voltage 420 and if the voltage level of the erase blocks 206 meets or exceeds the threshold voltage 420, then the erase blocks 206 have been completely erased.
The dwell time 422 is the amount of time between successive erase or partial erase operations. Increasing the dwell time 422 between erase operations can increase the endurance, or effective lifetime, of the erase blocks 206. The term endurance can be the number of operations a memory device including NAND flash device tolerates over a given period of operational life of a data storage system including a solid state disk drive (SSD).
Each time an erase operation is performed, the act of erasing can temporarily change the charge defects in the material of the memory cells 136 of
In another illustrative example, the erase command 406 can include the operation matrix 408 having individual values for each of four partial erase operations for one of the erase blocks 206. The operation matrix 408 can specify that the erase voltage 414 is initially set to a high value and decreased for each partial erase operation. The operation matrix 408 can specify that the erase pulse width 416 can remain constant for each partial erase operation.
The operation matrix 408 can specify the maximum execution time 418 indicating the maximum erase operation latency to determine when the erase operation should complete. The operation matrix 408 can specify the threshold voltage 420 used to determine if the erase operation has been successful. The operation matrix 408 can specify the dwell time 422 for scheduling the individual partial erase operations.
The operation matrix 408 can be used to perform an erase optimization 428. The erase optimization 428 is an operation to modify the behavior of the erase command 406. The erase optimization 428 can improve the performance of the erase command 406 by modifying the erase operation values 426 of the erase command 406. For example, the erase optimization 428 can change the erase voltage 414, the erase pulse width 416, and the dwell time 422 to improve the overall performance of the erase command 406.
It has been discovered that performing the erase command 406 with the operation matrix 408 increase flexibility and performance. By including variable operational parameters with each of the erase commands, the data storage system 100 of
It has been discovered that performing the erase command 406 with the operation matrix 408 specifying the dwell time 422 increases the endurance of the data storage system 100. Optimizing the dwell time 422 can reduce the physical impact of the erase operation on the erase blocks 206 and increase the endurance or effective lifetime of the erase blocks 206.
It has been found that performing the erase command 406 with the dwell time 422 provides a longer duration of the overall erase operation which improves endurance. Configuring the modular erase operation to allow for a longer erase time results in higher endurance without sacrificing latency.
Referring now to
The erase operation 502 can include receiving the erase command 406, performing the erase command 406 over an erase duration 504, and providing the command status 430 when completed. The erase duration 504 is the time between receiving and completing the erase command 406. A complete erase time 508 can include receiving the erase command 406, the erase duration 504, and providing the command status 430. For example, a conventional flash memory system can perform a complete erase operation in the range of 3-30 milliseconds (ms). In another example, a flash memory system configured for maximum endurance can perform a complete erase operation in the range of 10-30 ms. The time for a complete erase operation would preferably be under 10 ms.
The time required to erase one of the erase blocks 206 can lengthen with use and the memory age 220 of
Referring now to
The erase command 406 in a NAND flash memory can be broken up into segments by limiting the number of erase pulses in a given erase operation. By limiting the number of erase pulses, the erase operation may not complete with a single erase command but will not exceed a given amount of command processing time. The erase operation 602 is then composed of a number of the erase components 604.
The use of erase components allows the controlling firmware to interlace other operations to the die/LUN that is being erased with the component erase commands. The software can also perform “look ahead” operations the will stack a number of erase components together if there are no other host operations targeted for the device being erased.
The erase components 604 are a portion of the erase operation 602. Each of the erase components 604 can represent using the erase operation 602 configured with the operation matrix 408 of
The erase operation 602 can execute one or more of the erase components 604 until the erase operation 602 is complete. The erase operation 602 is complete when the command status 430 of
The erase operation 602 can include a reconfigure erase function 608 for applying the operation matrix 408 to the erase components 604. The reconfigure erase function 608 can be performed at different times. For example, the reconfigure erase function 608 can be performed once at drive initialization time during manufacture. In another example, the reconfigure erase function 608 can be performed at drive boot time for the data storage system 100 and not changed as the data storage system 100 operates.
The erase operation 602 can receive a partial erase command 610 with the operation matrix 408 and erase one of the erase blocks 206. The partial erase command 610 can be performed according the settings in the operation matrix 408.
The erase operation 602 can include the erase duration 612. During the erase duration 612, the partial erase command 610 can operate on the memory array 106 of
The erase operation 602 can provide the command status 430 when the erase components 604 have completed. The command status 430 indicates the status of the operation, such as the partial erase command 610. For example, the command status 430 can indicate that the partial erase command 610 resulted in an incomplete erase or a complete erase condition.
The data storage system 100 of
It has been discovered that executing the erase component 604 a number of times can reduce command latency. The erase blocks 206 can become erased as if a normal erase operation was executed by executing one or more of the erase components 604 which can provide a guaranteed value for the maximum execution time 418 of
Referring now to
The erase components 704 are a portion of the erase operation 702. Each of the erase components 704 can represent using the erase operation 702 configured with the operation matrix 408 of
The erase operation 702 can execute one or more of the erase components 704 until the erase operation 702 is complete. The erase operation 702 is complete when the command status 430 indicates a successful erasure. The command status 430 indicates the status at the end of the erase components 704.
The erase operation 702 can include the erase components 704 for performing a partial erase. Each of the erase components 704 can include the reconfigure erase function 708 for applying the operation matrix 408 to one of the erase components 704.
The reconfigure erase function 708 can be performed for each of the erase components 704 to provide fine grained control over the erase operation 702. The operation matrix 408 can include a set of parameters for each of the erase components 704.
The erase operation 702 can receive the partial erase command 702 with the operation matrix 408 and erase one of the erase blocks 206. The partial erase command 710 can be performed according the settings in the operation matrix 408.
The erase operation 702 can include the erase duration 712. During the erase duration 712, the partial erase command 702 can operate on the memory array 106 of
The erase operation 702 can provide the command status 430 when the erase component 704 has completed. The command status 430 indicates the status of the operation, such as the partial erase command 710. For example, the command status 430 can indicate that the partial erase command 710 resulted in an incomplete erase or a complete erase condition. In another example, the command status 430 can indicate that a partial erase operation is in progress, such as an incomplete erase status 720.
It has been discovered that dynamically reconfiguring each of the erase components 704 based on the status received at the completion of the erase components 704 can increase the flexibility of the erase operation 702. Increasing the erase voltage 414 of
Referring now to
The intervening commands 806, such as a read or write command, can be the data operation commands 424 of
An erase operation 804 can include a set of partial erase components 812 that result in a complete erase operation. The partial erase components 812 are erase components that do not fully erase the erase blocks 206 of
For example, the erase operation 804 can include two of the partial erase components 812 and a final erase component 810. The erase operation 804 can include the final erase component 810. The final erase component 810 is the last erase component of a multiple erase-component operation. The command status 430 of
The erase blocks 206 of
The interleaved erase process 802 can include an interleaved erase operation 808 having a set of partial erase operations with one or more of the intervening commands 806 interleaved within the partial erase operations. Interleaving the intervening commands 806 between the partial erase operations can avoid high latencies for host commands. The high latencies can be the result of waiting for the entire erase operation to complete.
The interleaved erase operation 808 can include a dwell delay 814 after one of the partial erase operations. The dwell delay 814 is a pause before executing another of the partial erase operations for an amount of time indicated by the dwell time 422 of
Separating the interleaved erase operation 808 into one or more of the partial erase operations can support having a dwell time delay between the partial erase operations. Separating the partial erase operations from one another for the dwell time 422 can result in lower wear on the data storage system 100 of
It has been discovered that executing intervening commands 806 between the erase components 704 of
Referring now to
The erase process 902 can include a configuration module 904, an partial erase module 906, a check status module 908, an intervening command module 912, an optimization module 914, and an update module 924. The optimization module 914 can include an erase parameter module 916, a total time module 918, a dwell time module 920, and a memory age module 922.
The term “module” referred to herein can include software, 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 sensor, or a combination thereof.
The configuration module 904 can configure the erase process 902 by receiving the operation matrix 408 of
For example, the configuration module 904 can use the erase mode 410 to determine the type of erase to be performed. If the erase mode 410 indicates a complete erase operation, then the erase process 902 can be performed as a single complete erase operation. If the erase mode 410 indicates a partial erase operation, then the erase process 902 can be performed as a series of partial erase components to support the execution of intervening commands 806.
In another example, the configuration module 904 can set the operational values for the erase pulse count 412, the erase voltage 414, and the erase pulse width 416. The operational values can determine the degree of change in the charge performed on the memory cells 136 of
In yet another example, the configuration module 904 can determine the amount of the dwell time 422 between the current one of the erase components 704 and the next one of the erase components 704. The delay of the dwell time 422 can lower the wear on the memory cells 136 and increase the functional lifetime of the data storage system 100 of
In a further example, the configuration module 904 can adjust the behavior of the erase command 406 of
The configuration module 904 can set one or more of the operational values for the erase process 902. When the configuration module 904 is completed, the control flow can pass to the partial erase module 906.
The partial erase module 906 can perform the partial erase operation on the selected ones of the erase blocks 206 using the operational values from the operation matrix 408. The partial erase module 906 can form part of one of the erase components.
When the partial erase module 906 is actively performing the partial erase operation by applying the erase voltage 414 to the erase blocks 206, no other operation can take place on the logical units 222 of
The partial erase module 906 can set the command status 430 to indicate the status of the erase command 406. The command status 430 can indicate that the erase blocks 206 are completely erased and ready for use or that the partial erase is still in progress and another of the erase components 704 is still required to complete the erase command 406.
The partial erase module 906 can implement the dwell delay 814 of
The check status module 908 can determine if the erase command 406 has completely erased the selected ones of the erase blocks 206 by checking the command status 430. If the command status 430 indicates that the erase blocks 206 have been completely erased, then the check status module 908 can calculate and update the memory age 220 for the erase blocks 206 and then the erase command 406 can terminate.
If the command status 430 matches the erase failed status 310 of
The intervening command module 912 can identify and execute one or more of the intervening commands 806 in the intervals between the erase components 704. Executing the intervening commands 806 without waiting for the complete erase operation can reduce a command latency 930 for the intervening commands 806. The command latency 930 is the amount of time required for a command to execute.
The intervening command module 912 can identify one of the intervening commands 806 by searching a command queue to identify any of the data operation commands 424 of
The commands in the command queue, such as a read command or a write command, can operate on the target block 302 of
If the logical units 222 of the target block 302 is different from that of the erase blocks 206, then the command can be designated the intervening commands 806 and the intervening command module 912 can execute one of the intervening commands 806 on the target block 302.
When the intervening commands 806 have completed, the intervening command module 912 can evaluate whether another command can be executed before performing another partial erase. For example, the intervening command module 912 can calculate whether another of the intervening commands 806 can be performed within the time interval of the dwell time 422. In another example, the intervening command module 912 can calculate whether another of the intervening commands 806 can be performed without exceeding the maximum execution time 418 of
The intervening command module 912 can execute the intervening commands 806 until the available commands are exhausted or until the available time has ended. The intervening command module 912 can perform more than one of the intervening commands 806 from the command queue sequentially to improve performance, including different types of the intervening commands 806. The intervening command module 912 can perform one or more different ones of the intervening commands 806 between one of the erase operations and another of the erase operations. After the final one of the intervening commands 806 has been completed, the intervening command module 912 can pass the control flow to the optimization module 914.
The optimization module 914 can calculate the operational values for one of the erase components 704. The optimization module 914 can include the erase parameter module 916, the total time module 918, the dwell time module 920, and the memory age module 922. The optimization module 914 can perform the erase optimization 428 of
The optimization module 914 can manage the implementation of a total execution time 932 for the erase operation by modifying the operational values for the erase components 704. The optimization module 914 can make sure the total execution time 932 for the erase operation is less than or equal to the maximum execution time 418.
The optimization module 914 can pass control to one or more of the modules depending on the internal configuration of the optimization module 914. For example, the optimization module 914 can execute the other modules based on the erase mode 410. In another example, the optimization module 914 can select other modules for execution based on a pre-defined configuration. After the optimization module 914 has completed, the control flow can pass to the update module 924.
The erase parameter module 916 can calculate the erase operation values for the next partial erase operation. The erase operation values can include the erase pulse count 412, the erase voltage 414, the erase voltage 414, and the erase pulse width 416.
The erase operation values can vary in different ways. For example, the erase parameter module 916 can schedule a sequence of increasing values for the erase pulse count 412, the erase voltage 414, and the erase pulse width 416. The values can increase individually or together with each other.
In another example, the erase parameter module 916 can schedule a sequence of decreasing values for the erase pulse count 412, the erase voltage 414, and the erase pulse width 416. The values can decrease individually or together with each other.
The total time module 918 can determine whether another of the intervening commands 806 can be performed within the maximum execution time 418. The total time module 918 can insure that the erase process 902 completes within the interval defined by the maximum execution time 418.
The dwell time module 920 can determine the value of the dwell time 422. The dwell time 422 is the amount of time the data storage system 100 can wait after performing the partial erase operation to reduce wear on the memory cells 136.
The erase operation values can vary in different ways. The dwell time 422 can be a fixed value, a calculated value based on the memory age 220 of
For example, the dwell time module 920 can schedule a sequence of increasing values for the dwell time 422 for each of the erase components 704. In another example, the dwell time module 920 can schedule a sequence of decreasing values for the dwell time 422 for each of the erase components 704.
The memory age module 922 can calculate the erase operation values for the next partial erase operation based on the memory age 220 of each of the erase blocks 206. The erase operation values can include the erase pulse count 412, the erase voltage 414, the erase voltage 414, and the erase pulse width 416.
The erase pulse count 412 can be calculated based on the memory age 220 of the erase blocks 206. As the memory age 220 of the erase blocks 206 increases, the erase blocks 206 can require a higher value for the erase pulse count 412 to achieve the same level of erasure or partial erasure.
The erase voltage 414 can be calculated based on the memory age 220 of the erase blocks 206. As the memory age 220 of the erase blocks 206 increases, the erase blocks 206 can require higher values for the erase voltage 414 to achieve the same level of erasure or partial erasure.
The erase pulse width 416 can be calculated in a variety of ways. For example, the erase pulse width 416 can be calculated based on the memory age 220 of the erase blocks 206. As the memory age 220 of the erase blocks 206 increases, the erase blocks 206 can require longer values for the erase pulse width 416 to achieve the same level of erasure or partial erasure.
The update module 924 can configure the erase process 902 by receiving the operation values calculated in the optimization module 914 and configuring the next partial erase operation based on the erase operation values 426. After completion, the update module 924 can pass the control flow back to the partial erase module 906.
The modules of the erase process 902 can be implemented in software, hardware, or a combination thereof. For example, the erase process 902 can be performed by executing the software 122 of
The erase process 902 can be performed in hardware as dedicated hardware units and then providing a command interface to access the erase components. The erase process 902 can be implemented as a custom command or by modifying the erase command 406 of the data storage system 100.
The physical transformation resulting from the erase process 902 results in the change of charge levels in the memory cells 136 of the data storage system 100. As charge level changes in the physical world, such as the erase process 902 proceeding with the cycle of partial erase operations and executing the intervening commands 806, the incremental change in the charge level in the memory cells 136 creates additional information about the charge level that is used for continued operation of the data storage system 100 and to determine further changes in the charge level to complete the erase process 902.
The controller 102 can use the software 122 executing on the control unit 110 to implement the erase process 902. For example, the software 122 can include the configuration module 904, the partial erase module 906, the check status module 908, the intervening command module 912, the optimization module 914, and the update module 924. The software 122 can include the erase parameter module 916, the total time module 918, the dwell time module 920, and the memory age module 922.
The controller 102 can implement the erase process 902 using the control unit 110 and the software 122 to control the error correction code unit 112 of
The control unit 110 can execute the software 122 for the configuration module 904 to configure the memory array 106. The control unit 110 can execute the software 122 for the partial erase module 906 to partially erase the memory array 106. The control unit 110 can execute the software 122 for the check status module 908 to determine the status of the erase operation.
The control unit 110 can execute the software 122 for the intervening command module 912 to perform the intervening command 806. The control unit 110 can execute the software 122 for the optimization module 914 to calculate the erase operation values 426. The control unit 110 can execute the software 122 for the update module 924 to update the operation matrix 408.
The data storage system 100 describes the module functions or order as an example. The modules can be partitioned differently. For example, the partial erase module 906 and the check status module 908 can be combined. Each of the modules can operate individually and independently of the other modules.
Furthermore, data generated in one module can be used by another module without being directly coupled to each other. For example, the optimization module 914 can receive the command status 430 from the check status module 908.
It has been discovered that performing the erase operation 804 with the intervening commands 806 can reduce host access latency for the block-based NAND flash memory. By enabling the intervening commands 806 to complete before the complete erasure of the erase blocks 206 can allow more commands to execute in less time providing low latency for the intervening commands 806 even as the erase time increases as the memory age 220 of the erase blocks 206 increase.
It has been discovered that performing the erase operation 804 with the intervening commands 806 can reduce complexity and simplify memory operations. Because the erase operations and the intervening commands 806 can be performed without memory conflict, the erase operation does not need to be interrupted and restarted at a later time.
It has been discovered that performing the erase operation 804 with the intervening commands 806 can provide consistent performance over time as the memory age 220 of the erase blocks 206 increases. By interleaving the intervening commands 806, the command latency can be decoupled from the actual erase time and provide more consistent operation.
It has been discovered that varying the erase voltage 414 and the erase pulse width 416 between the erase components 704 can increase flexibility. Changing the erase voltage 414 and the erase pulse width 416 between the erase components 704 allows the data storage system 100 to dynamically adapt to the amount of charge in memory cells 132 to perform a complete erase.
It has been discovered that varying the erase voltage 414 and the erase pulse width 416 between the erase components 704 based on the memory age 220 of the erase blocks 206 can increase flexibility. Adjusting the erase voltage 414 and the erase pulse width 416 based on the memory age 220 of the erase blocks 206 allows the data storage system 100 to dynamically adapt to the amount of charge in memory cells 132 to perform a complete erase.
It has been discovered that providing a delay for the dwell time 422 between the erase components 704 can enhance endurance and increase operational lifetime. Allowing the memory cells 136 to recover between the erase components 704 by pausing for the dwell time 422 reduces wear on the physical structure of the NAND flash memory and induces less wear. Endurance is enhanced by performing gentler erase operations over a longer time period. To compensation for erase operations that exceed the maximum read latency, the erase operation can be partitioned into multiple partial erase operations to allow performing the intervening commands 806 between the partial erase operations.
It has been discovered that varying the dwell time 422 between the erase components 704 based on the memory age 220 of the erase blocks 206 can increase operational lifetime. Allowing the erase blocks 206 to recover between the erase components 704 by dynamically increasing the dwell time 422 for erase blocks 206 having a higher value of the memory age 220 reduces wear on the physical structure of the NAND flash memory and induces less wear.
Referring now to
Thus, it has been discovered that the data storage system of the present invention furnishes important and heretofore unknown and unavailable solutions, capabilities, and functional aspects for a data storage system with modular erase. 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.
While the invention has been described in conjunction with a specific best mode, it is to be understood that many alternatives, modifications, and variations will be apparent to those skilled in the art in light of the aforegoing description. Accordingly, it is intended to embrace all such alternatives, modifications, and variations that fall within the scope of the included claims. All matters hithertofore set forth herein or shown in the accompanying drawings are to be interpreted in an illustrative and non-limiting sense.
The claimed invention provides a method of data management with modular erase in a data storage system with a memory array having an erase block and a target block with the target block in a logical unit separate from the erase block including: performing an erase operation on the erase block, the erase operation having an operation matrix configured for partial erasing of the erase block; updating a command status for the erase block; enabling an intervening command on the target block based on the command status indicating an incomplete erase status with the intervening command updating the command status; performing an erase optimization based on the command status; performing an additional erase operation based on the erase optimization; and updating the command status to an erase complete status based on the additional erase operation.
The claimed invention provides a data storage system including: a configuration module for configuring a memory array having an erase block and a target block, the target block in a logical unit separate from the erase block; a partial erase module coupled to the configuration module for performing an erase operation on the erase block, the erase operation having an operation matrix configured for partial erasing of the erase block, the erase operation updating a command status for the erase block, and for performing an additional erase operation based on an erase optimization; an intervening command module coupled to the partial erase module for performing an intervening command on the target block based on the command status indicating an incomplete erase status with the intervening command updating the command status; an optimization module coupled to the intervening command module for performing an erase optimization based on the command status; and an update module coupled to the optimization module for updating the command status to an erase complete status based on the additional erase operation.
The claimed invention provides a data storage system including: a controller coupled to a memory array having an erase block and a target block, the target block in a logical unit separate from the erase block; a control unit coupled to the memory array for performing an erase operation on the erase block, the erase operation having an operation matrix configured for partial erasing of the erase block, the erase operation updating a command status for the erase block, and for performing an additional erase operation based on an erase optimization; a memory interface coupled to the control unit for performing an intervening command on the target block based on the command status indicating an incomplete erase status with the intervening command updating the command status; an array logic coupled to the memory interface for performing an erase optimization based on the command status; and a database coupled to the control unit for updating the command status to an erase complete status based on the additional erase operation.
Number | Name | Date | Kind |
---|---|---|---|
4048481 | Bailey, Jr. et al. | Sep 1977 | A |
4839587 | Flatley et al. | Jun 1989 | A |
4916652 | Schwarz et al. | Apr 1990 | 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 |
5519847 | Fandrich et al. | May 1996 | A |
5530705 | Malone | Jun 1996 | A |
5537555 | Landry | Jul 1996 | A |
5551003 | Mattson et al. | Aug 1996 | A |
5657332 | Auclair et al. | Aug 1997 | A |
5666114 | Brodie et al. | Sep 1997 | A |
5708849 | Coke et al. | Jan 1998 | A |
5784174 | Fujino et al. | Jul 1998 | A |
5790828 | Jost | Aug 1998 | A |
5805501 | Shiau et al. | Sep 1998 | A |
5930504 | Gabel | Jul 1999 | A |
5943692 | Marberg et al. | Aug 1999 | A |
5949785 | Beasley | Sep 1999 | A |
5963983 | Sakakura et al. | Oct 1999 | A |
5982664 | Watanabe | Nov 1999 | A |
6000006 | Bruce et al. | Dec 1999 | A |
6016560 | Wada et al. | Jan 2000 | A |
6018304 | Bessios | Jan 2000 | A |
6034897 | Estakhri et al. | Mar 2000 | A |
6069827 | Sinclair | May 2000 | A |
6070074 | Perahia et al. | May 2000 | A |
6091652 | Haehn et al. | Jul 2000 | A |
6138261 | Wilcoxson et al. | Oct 2000 | A |
6182264 | Ott | Jan 2001 | B1 |
6192092 | Dizon et al. | Feb 2001 | B1 |
6195290 | Dallabora et al. | Feb 2001 | B1 |
6275436 | Tobita et al. | Aug 2001 | B1 |
6295592 | Jeddeloh et al. | Sep 2001 | B1 |
6311263 | Barlow et al. | Oct 2001 | B1 |
6345367 | Sinclair | Feb 2002 | B1 |
6356447 | Scafidi | Mar 2002 | B2 |
6381670 | Lee et al. | Apr 2002 | B1 |
6412080 | Fleming et al. | Jun 2002 | B1 |
6442076 | Roohparvar | Aug 2002 | B1 |
6449625 | Wang | Sep 2002 | B1 |
6484224 | Robins et al. | Nov 2002 | B1 |
6515909 | Wooldridge | Feb 2003 | B1 |
6516437 | Van Stralen et al. | Feb 2003 | 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 |
6665214 | Cheah et al. | Dec 2003 | B1 |
6678788 | O'Connell | Jan 2004 | B1 |
6728913 | Parker | Apr 2004 | B1 |
6757768 | Potter et al. | Jun 2004 | B1 |
6763424 | Conley | Jul 2004 | B2 |
6775792 | Ulrich et al. | Aug 2004 | B2 |
6778387 | Fairchild | Aug 2004 | B2 |
6810440 | Micalizzi, Jr. et al. | Oct 2004 | B2 |
6836808 | Bunce et al. | Dec 2004 | B2 |
6836815 | Purcell et al. | Dec 2004 | B1 |
6842436 | Moeller | Jan 2005 | B2 |
6850443 | Lofgren et al. | Feb 2005 | B2 |
6854070 | Johnson et al. | Feb 2005 | B2 |
6871257 | Conley et al. | Mar 2005 | B2 |
6871304 | Hadjihassan et al. | Mar 2005 | B2 |
6895464 | Chow et al. | May 2005 | B2 |
6903972 | Lasser et al. | Jun 2005 | B2 |
6906961 | Eggleston et al. | Jun 2005 | B2 |
6975028 | Wayburn et al. | Dec 2005 | B1 |
6978343 | Ichiriu | Dec 2005 | B1 |
6980985 | Amer-Yahia et al. | Dec 2005 | B1 |
6981205 | Fukushima et al. | Dec 2005 | B2 |
6988171 | Beardsley et al. | Jan 2006 | B2 |
7020017 | Chen et al. | Mar 2006 | B2 |
7032123 | Kane et al. | Apr 2006 | B2 |
7043505 | Teague et al. | May 2006 | B1 |
7082495 | DeWhitt et al. | Jul 2006 | B2 |
7100002 | Shrader et al. | Aug 2006 | B2 |
7107389 | Inagaki et al. | Sep 2006 | B2 |
7111293 | Hersh et al. | Sep 2006 | B1 |
7139864 | Bennett et al. | Nov 2006 | B2 |
7162678 | Saliba | Jan 2007 | B2 |
7173852 | Gorobets et al. | Feb 2007 | B2 |
7184446 | Rashid et al. | Feb 2007 | B2 |
7233497 | Simon et al. | Jun 2007 | B2 |
7243186 | Liang et al. | Jul 2007 | B2 |
7298888 | Hamar | Nov 2007 | B2 |
7328377 | Lewis et al. | Feb 2008 | B1 |
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 |
7516292 | Kimura et al. | Apr 2009 | B2 |
7523157 | Aguilar, Jr. et al. | Apr 2009 | B2 |
7527466 | Simmons | May 2009 | B2 |
7529466 | Takahashi | May 2009 | B2 |
7571277 | Mizushima | Aug 2009 | B2 |
7574554 | Tanaka et al. | Aug 2009 | B2 |
7596643 | Merry et al. | Sep 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 |
7681106 | Jarrar et al. | Mar 2010 | B2 |
7685494 | Varnica et al. | Mar 2010 | B1 |
7693422 | Alicherry et al. | Apr 2010 | B2 |
7707481 | Kirschner et al. | Apr 2010 | B2 |
7738502 | Chang et al. | Jun 2010 | B2 |
7743216 | Lubbers et al. | Jun 2010 | B2 |
7761655 | Mizushima et al. | Jul 2010 | B2 |
7774390 | Shin | Aug 2010 | B2 |
7818525 | Frost et al. | Oct 2010 | B1 |
7827348 | Lee et al. | Nov 2010 | B2 |
7830164 | Earle et al. | Nov 2010 | B2 |
7840762 | Oh et al. | Nov 2010 | B2 |
7870326 | Shin et al. | Jan 2011 | B2 |
7890818 | Kong et al. | Feb 2011 | B2 |
7913022 | Baxter | Mar 2011 | B1 |
7925960 | Ho et al. | Apr 2011 | B2 |
7934052 | Prins et al. | Apr 2011 | B2 |
7954041 | Hong et al. | May 2011 | B2 |
7971112 | Murata | Jun 2011 | B2 |
7974368 | Shieh et al. | Jul 2011 | B2 |
7978516 | Olbrich | Jul 2011 | B2 |
7979614 | Yang | Jul 2011 | B1 |
7996642 | Smith | Aug 2011 | B1 |
8000135 | Perlmutter et al. | Aug 2011 | B1 |
8006161 | Lestable et al. | Aug 2011 | B2 |
8010738 | Chilton et al. | Aug 2011 | B1 |
8028123 | Kilzer et al. | Sep 2011 | B2 |
8032724 | Smith | Oct 2011 | B1 |
8036044 | Dong et al. | Oct 2011 | B2 |
8046645 | Hsu et al. | Oct 2011 | B2 |
8051241 | Feldman et al. | Nov 2011 | B2 |
8069390 | Lin | 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 |
8190967 | Hong et al. | May 2012 | B2 |
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 |
8254181 | Hwang et al. | Aug 2012 | B2 |
8259506 | Sommer et al. | Sep 2012 | B1 |
8289801 | Smith et al. | Oct 2012 | B2 |
8296534 | Gupta et al. | Oct 2012 | B1 |
8312349 | Reche et al. | Nov 2012 | B2 |
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 |
8391068 | Shelton et al. | Mar 2013 | B2 |
8407409 | Kawaguchi | Mar 2013 | B2 |
8412985 | Bowers et al. | Apr 2013 | B1 |
8464106 | Filor et al. | Jun 2013 | B2 |
8503238 | Wu et al. | Aug 2013 | B1 |
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 |
8832506 | Griffin et al. | Sep 2014 | B2 |
8984216 | Fillingim | Mar 2015 | B2 |
20020024846 | Kawahara et al. | Feb 2002 | A1 |
20020056025 | Qiu et al. | May 2002 | A1 |
20020083299 | Van Huben et al. | Jun 2002 | A1 |
20020152305 | Jackson et al. | Oct 2002 | A1 |
20020156891 | Ulrich et al. | Oct 2002 | A1 |
20020159285 | Morley et al. | Oct 2002 | A1 |
20020162075 | Talagala et al. | Oct 2002 | A1 |
20020165896 | Kim | Nov 2002 | A1 |
20030033308 | Patel et al. | Feb 2003 | A1 |
20030041299 | Kanazawa et al. | Feb 2003 | A1 |
20030043829 | Rashid et al. | Mar 2003 | A1 |
20030046603 | Harari et al. | Mar 2003 | A1 |
20030074592 | Hasegawa | Apr 2003 | A1 |
20030088805 | Majni et al. | May 2003 | A1 |
20030093628 | Matter et al. | May 2003 | A1 |
20030163633 | Aasheim et al. | Aug 2003 | A1 |
20030188045 | Jacobson | Oct 2003 | A1 |
20030189856 | Cho et al. | Oct 2003 | A1 |
20030198100 | Matsushita et al. | Oct 2003 | A1 |
20030212719 | Yasuda et al. | Nov 2003 | A1 |
20040024957 | Lin et al. | Feb 2004 | A1 |
20040024963 | Talagala et al. | Feb 2004 | A1 |
20040073829 | Olarig | Apr 2004 | A1 |
20040080985 | Chang et al. | Apr 2004 | A1 |
20040088511 | Bacon et al. | May 2004 | A1 |
20040153902 | Machado et al. | Aug 2004 | A1 |
20040181734 | Saliba | Sep 2004 | A1 |
20040199714 | Estakhri et al. | Oct 2004 | A1 |
20040237018 | Riley | Nov 2004 | A1 |
20040252670 | Rong et al. | Dec 2004 | A1 |
20050021904 | Iaculo et al. | Jan 2005 | A1 |
20050038792 | Johnson | Feb 2005 | A1 |
20050060456 | Shrader et al. | Mar 2005 | A1 |
20050060501 | Shrader | Mar 2005 | A1 |
20050073884 | Gonzalez et al. | Apr 2005 | A1 |
20050076102 | Chen et al. | Apr 2005 | A1 |
20050114587 | Chou et al. | May 2005 | A1 |
20050144516 | Gonzalez et al. | Jun 2005 | A1 |
20050172065 | Keays | Aug 2005 | A1 |
20050172207 | Radke et al. | Aug 2005 | A1 |
20050193161 | Lee et al. | Sep 2005 | A1 |
20050201148 | Chen et al. | Sep 2005 | A1 |
20050231765 | So et al. | Oct 2005 | A1 |
20050257120 | Gorobets et al. | Nov 2005 | A1 |
20050273560 | Hulbert et al. | Dec 2005 | A1 |
20050289314 | Adusumilli et al. | Dec 2005 | A1 |
20060015683 | Ashmore et al. | Jan 2006 | A1 |
20060020745 | Conley et al. | Jan 2006 | A1 |
20060022054 | Elhamias et al. | Feb 2006 | A1 |
20060039196 | Gorobets et al. | Feb 2006 | A1 |
20060053246 | Lee | Mar 2006 | A1 |
20060080505 | Arai et al. | Apr 2006 | A1 |
20060085671 | Majni et al. | Apr 2006 | A1 |
20060136570 | Pandya | Jun 2006 | A1 |
20060136682 | Haridas et al. | Jun 2006 | A1 |
20060143365 | Kikuchi | Jun 2006 | A1 |
20060143475 | Herbert et al. | Jun 2006 | A1 |
20060156177 | Kottapalli et al. | Jul 2006 | A1 |
20060195650 | Su et al. | Aug 2006 | A1 |
20060253641 | Gatzemeier et al. | Nov 2006 | A1 |
20060256624 | Eggleston et al. | Nov 2006 | A1 |
20060259528 | Dussud et al. | Nov 2006 | A1 |
20060282644 | Wong | Dec 2006 | A1 |
20060294574 | Cha | Dec 2006 | A1 |
20070011413 | Nonaka et al. | Jan 2007 | A1 |
20070050536 | Kolokowsky | Mar 2007 | A1 |
20070058446 | Hwang et al. | Mar 2007 | A1 |
20070061511 | Faber | Mar 2007 | A1 |
20070061597 | Holtzman et al. | Mar 2007 | A1 |
20070067598 | Fujimoto | Mar 2007 | A1 |
20070076479 | Kim et al. | Apr 2007 | A1 |
20070079152 | Winick et al. | Apr 2007 | A1 |
20070081408 | Kwon et al. | Apr 2007 | A1 |
20070083697 | Birrell et al. | Apr 2007 | A1 |
20070083779 | Misaka et al. | Apr 2007 | A1 |
20070113019 | Beukema | May 2007 | A1 |
20070133312 | Roohparvar | Jun 2007 | A1 |
20070147113 | Mokhlesi et al. | Jun 2007 | A1 |
20070150790 | Gross et al. | Jun 2007 | A1 |
20070157064 | Falik et al. | Jul 2007 | A1 |
20070174579 | Shin | Jul 2007 | A1 |
20070180188 | Fujbayashi et al. | Aug 2007 | A1 |
20070208901 | Purcell et al. | Sep 2007 | A1 |
20070226592 | Radke | Sep 2007 | A1 |
20070234004 | Oshima et al. | Oct 2007 | A1 |
20070234143 | Kim | Oct 2007 | A1 |
20070245061 | Harriman | Oct 2007 | A1 |
20070260811 | Merry et al. | Nov 2007 | A1 |
20070263444 | Gorobets et al. | Nov 2007 | A1 |
20070276973 | Tan et al. | Nov 2007 | A1 |
20070277036 | Chamberlain et al. | Nov 2007 | A1 |
20070291556 | Kamei | Dec 2007 | A1 |
20070294496 | Goss et al. | Dec 2007 | A1 |
20070300130 | Gorobets | Dec 2007 | A1 |
20080019182 | Yanagidaira et al. | Jan 2008 | A1 |
20080022163 | Tanaka et al. | Jan 2008 | A1 |
20080028246 | Witham | Jan 2008 | A1 |
20080046630 | Lasser | Feb 2008 | A1 |
20080052446 | Lasser et al. | Feb 2008 | A1 |
20080077841 | Gonzalez et al. | Mar 2008 | A1 |
20080077937 | Shin et al. | Mar 2008 | A1 |
20080082736 | Chow et al. | Apr 2008 | A1 |
20080086677 | Yang et al. | Apr 2008 | A1 |
20080126720 | Danilak | May 2008 | A1 |
20080144371 | Yeh et al. | Jun 2008 | A1 |
20080147964 | Chow et al. | Jun 2008 | A1 |
20080147998 | Jeong | Jun 2008 | A1 |
20080148124 | Zhang et al. | Jun 2008 | A1 |
20080163030 | Lee | Jul 2008 | A1 |
20080168191 | Biran et al. | Jul 2008 | A1 |
20080168319 | Lee et al. | Jul 2008 | A1 |
20080170460 | Oh et al. | Jul 2008 | A1 |
20080183918 | Dhokia et al. | Jul 2008 | A1 |
20080189588 | Tanaka et al. | Aug 2008 | A1 |
20080229000 | Kim | Sep 2008 | A1 |
20080229003 | Mizushima et al. | Sep 2008 | A1 |
20080229176 | Arnez et al. | Sep 2008 | A1 |
20080263289 | Hosoya et al. | Oct 2008 | A1 |
20080270680 | Chang | Oct 2008 | A1 |
20080282128 | Lee et al. | Nov 2008 | A1 |
20080285351 | Shlick et al. | Nov 2008 | A1 |
20080313505 | Lee et al. | Dec 2008 | A1 |
20090003058 | Kang | Jan 2009 | A1 |
20090006900 | Lastras-Montano et al. | Jan 2009 | A1 |
20090019321 | Radke | Jan 2009 | A1 |
20090037652 | Yu et al. | Feb 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 |
20090138654 | Sutardja | May 2009 | A1 |
20090144598 | Yoon et al. | Jun 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 |
20090168525 | Olbrich et al. | Jul 2009 | A1 |
20090172258 | Olbrich et al. | Jul 2009 | A1 |
20090172259 | Prins et al. | Jul 2009 | A1 |
20090172260 | Olbrich et al. | Jul 2009 | A1 |
20090172261 | Prins et al. | Jul 2009 | A1 |
20090172262 | Olbrich et al. | Jul 2009 | A1 |
20090172308 | Prins et al. | Jul 2009 | A1 |
20090172335 | Kulkarni et al. | Jul 2009 | A1 |
20090172499 | Olbrich et al. | Jul 2009 | A1 |
20090179707 | Higashino | Jul 2009 | A1 |
20090193058 | Reid | Jul 2009 | A1 |
20090207660 | Hwang et al. | Aug 2009 | A1 |
20090222708 | Yamaga | Sep 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 |
20090296466 | Kim et al. | Dec 2009 | A1 |
20090296486 | Kim et al. | Dec 2009 | A1 |
20090300238 | Panabaker et al. | Dec 2009 | A1 |
20090319864 | Shrader | 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 |
20100061151 | Miwa et al. | Mar 2010 | A1 |
20100103737 | Park | Apr 2010 | A1 |
20100122019 | Flynn et al. | May 2010 | A1 |
20100128537 | Suhail et al. | May 2010 | A1 |
20100138592 | Cheon | Jun 2010 | A1 |
20100161936 | Royer et al. | 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 |
20100199125 | Reche | Aug 2010 | A1 |
20100202196 | Lee et al. | Aug 2010 | A1 |
20100208521 | Kim et al. | Aug 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 |
20100262889 | Bains | Oct 2010 | A1 |
20100281207 | Miller et al. | Nov 2010 | A1 |
20100281342 | Chang et al. | Nov 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 |
20100332726 | Wang | Dec 2010 | A1 |
20110002224 | Tamura | Jan 2011 | A1 |
20110016239 | Stenfort | Jan 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 |
20110083060 | Sakurada et al. | Apr 2011 | A1 |
20110099342 | Ozdemir | Apr 2011 | A1 |
20110107144 | Ohara | May 2011 | A1 |
20110113281 | Zhang et al. | May 2011 | A1 |
20110131365 | Zhang et al. | Jun 2011 | A1 |
20110131444 | Buch 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 |
20110173378 | Filor et al. | Jul 2011 | A1 |
20110190963 | Glassl et al. | Aug 2011 | A1 |
20110191522 | Condict et al. | Aug 2011 | A1 |
20110191649 | Lim et al. | Aug 2011 | A1 |
20110205823 | Hemink et al. | Aug 2011 | A1 |
20110209032 | Choi et al. | Aug 2011 | A1 |
20110213920 | Frost et al. | Sep 2011 | A1 |
20110228601 | Olbrich et al. | Sep 2011 | A1 |
20110231600 | Tanaka et al. | Sep 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 |
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 |
20120096217 | Son et al. | Apr 2012 | A1 |
20120110250 | Sabbag et al. | May 2012 | A1 |
20120124046 | Provenzano | May 2012 | A1 |
20120124273 | Goss et al. | May 2012 | A1 |
20120151253 | Horn | Jun 2012 | A1 |
20120151260 | Zimmermann et al. | Jun 2012 | A1 |
20120170365 | Kang et al. | Jul 2012 | A1 |
20120185706 | Sistla et al. | Jul 2012 | A1 |
20120195126 | Roohparvar | Aug 2012 | A1 |
20120213004 | Yun et al. | Aug 2012 | A1 |
20120216085 | Weingarten et al. | Aug 2012 | A1 |
20120233384 | Charles et al. | Sep 2012 | A1 |
20120236656 | Cometti | Sep 2012 | A1 |
20120239858 | Melik-Martirosian | Sep 2012 | A1 |
20120239976 | Cometti et al. | 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 |
20130073788 | Post 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 |
20130124792 | Melik-Martirosian et al. | May 2013 | A1 |
20130151753 | Jeon et al. | Jun 2013 | A1 |
20130198436 | Bandic et al. | Aug 2013 | A1 |
20130238833 | Vogan et al. | Sep 2013 | A1 |
20130265825 | Lassa | Oct 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 |
20140208174 | Ellis et al. | Jul 2014 | A1 |
20140372777 | Reller et al. | Dec 2014 | A1 |
Number | Date | Country |
---|---|---|
1465203 | Oct 2004 | EP |
1 956 489 | Aug 2008 | EP |
1 990 921 | Nov 2008 | EP |
2 498 259 | Sep 2012 | EP |
2002-532806 | Oct 2002 | JP |
2012129659 | Jul 2012 | JP |
WO 2007036834 | Apr 2007 | WO |
WO 2007080586 | Jul 2007 | WO |
WO 2008121553 | Oct 2008 | WO |
WO 2008121577 | Oct 2008 | WO |
WO 2009028281 | Mar 2009 | WO |
WO 2009032945 | Mar 2009 | WO |
WO 2009042298 | Apr 2009 | WO |
WO 2009058140 | May 2009 | WO |
WO 2009084724 | Jul 2009 | WO |
WO 2009134576 | Nov 2009 | WO |
WO 2011156466 | Dec 2011 | WO |
Entry |
---|
Cooke, “Introduction to Flash Memory (T1A),” 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 pages (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). |
Gal et al., “Algorithms and Data Structures for Flash Memories”, “ACM Computing Surveys”, Jun. 2005, pp. 138-163, vol. 37, No. 2, ACM Inc., NY, US. |
Cooke, “Introduction to Flash Memory (T1A)”, “Flash Memory Summit”, Aug. 22, 2008, pp. 1-102, Micron Technology, Inc., Santa Clara, US. |
Spanjer, “Flash Management—Why and How?”, “Smart Modular Technologies”, Nov. 2009, pp. 1-14, http://www.scantec.de/fileadmin/pdf/Smart—Modular/Flash-Management.pdf. |
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. 17, 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). |
Barr, Introduction to Watchdog Timers, Oct. 2001, 3 pgs. |
Canim, Buffered Bloom ilters on Solid State Storage, ADMS*10, Singapore, Sep. 13-17, 2010, 8 pgs. |
Kang, A Multi-Channel Architecture for High-Performance NAND Flash-Based Storage System, J. Syst. Archit., 53, Sep. 9, 2007, 15 pgs. |
Kim, A Space-Efficient Flash Translation Layer for CompactFlash Systems, May 2002, 10 pgs. |
Lu, A Forest-structured Bloom Filter with Flash Memory, MSST 2011, Denver, CO, May 23-27, 2011, article, 6 pgs. |
Lu, A Forest-structured Bloom Filter with Flash Memory, MSST 2011, Denver, CO, May 23-27, 2011, presentation slides, 25 pgs. |
McLean, Information Technology-AT Attachment with Packet Interface Extension, Aug. 19, 1998, 339 pgs. |
Park, A High Performance Controller for NAND Flash-Based Solid State Disk (NSSD), Feb. 12-16, 2006, 4 pgs. |
International Search Report and Written Opinion dated Mar. 7, 2014, received in International Patent Application No. PCT/US2013/074772, which corresponds to U.S. Appl. No. 13/831,218, 10 pages (George). |
International Search Report and Written Opinion dated Mar. 24, 2014, received in International Patent Application No. PCT/US2013/074777, which corresponds to U.S. Appl. No. 13/831,308, 10 pages (George). |
International Search Report and Written Opinion dated Mar. 7, 2014, received in International Patent Application No. PCT/US2013/074779, which corresponds to U.S. Appl. No. 13/831,374, 8 pages (George). |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88133, Mar. 19, 2009, 7 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88136, Mar. 19, 2009, 7 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88146, Feb. 26, 2009, 10 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88154, Feb. 27, 2009, 8 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88164, Feb. 13, 2009, 6 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88206, Feb. 18, 2009, 8 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88217, Feb. 19, 2009, 7 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88229, Feb. 13, 2009, 7 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88232, Feb. 19, 2009, 8 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US08/88236, Feb. 19, 2009, 7 pgs. |
Pliant Technology, International Search Report / Written Opinion, PCT/US2011/028637, Oct. 27, 2011, 11 pgs. |
Pliant Technology, Supplementary ESR, 08866997.3, Feb. 23, 2012, 6 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/042764, Aug. 31, 2012, 12 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/042771, Mar. 4, 2013, 14 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/042775, Sep. 26, 2012, 8 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/059447, Jun. 6, 2013, 12 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/059453, Jun. 6, 2013, 12 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/059459, Feb. 14, 2013, 9 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/065914, May 23, 2013, 7 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/065916, Apr. 5, 2013, 7 pgs. |
SanDisk Enterprise IP LLC, International Search Report / Written Opinion, PCT/US2012/065919, Jun. 17, 2013, 8 pgs. |
SanDisk Enterprise IP LLC, Notification of the Decision to Grant a Patent Right for Patent for Invention, CN 200880127623.8, Jul. 4, 2013, 1 pg. |
SanDisk Enterprise IP LLC, Office Action, CN 200880127623.8, Apr. 18, 2012, 12 pgs. |
SanDisk Enterprise IP LLC, Office Action, CN 200880127623.8, Dec. 31, 2012, 9 pgs. |
SanDisk Enterprise IP LLC, Office Action, JP 2010-540863, Jul. 24, 2012, 3 pgs. |
Watchdog Timer and Power Savin Modes, Microchip Technology Inc., 2005, 14 pgs. |
Zeidman, 1999 Verilog Designer's Library, 9 pgs. |
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). |
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,542, 11 pages (Ellis). |
Number | Date | Country | |
---|---|---|---|
20150143068 A1 | May 2015 | US |