1. Technical Field
This disclosure relates to non-volatile storage systems, including but not limited to flash drives. More particularly, the disclosure relates to systems and methods for an enhanced controller architecture in solid state drives.
2. Description of the Related Art
Various types of controller architecture exist for controlling flash media. The Open NAND Flash Interface (ONFI) is a standard interface that specifies some common sets of commands that flash memory manufacturers should support. ONFI supports some low level rudimentary I/O operations that can include, for example, page write/read and block erase. However, effective flash media management often involves a number of high level and potentially process-intensive functions such as logical-to-physical mapping, garbage collection, and wear leveling. These functions are beyond the scope of ONFI and thus an effective controller architecture needs to address these needs while providing a high level of data throughput performance to the host.
Systems and methods that embody the various features of the invention will now be described with reference to the following drawings, in which:
While certain embodiments of the inventions are described, these embodiments are presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms. Furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions.
I. Controller/Bridge Designs
II. System Overview
Unlike the designs described above, the controller in this architecture is provided a rich set of physical level of controls over individual elements of the NVM (e.g., page level control) over a sophisticated and fast interface such as PCIe. It is observed that in many controller-bridge type designs that the bridge is typically implemented on a processor with reduced performance due to power concerns, while the controller typically is in an environment that faces less power concerns. If the processor intensive functionalities are shifted to the higher performing controller, then overall latency can be reduced. Thus, in some embodiments, the controller is typically implemented in a higher powered processor that can support the advanced NVM management functions. The bridge, on the other hand, is implemented in some embodiments in a lower powered processor to minimize energy usage of the overall NVM storage module/unit. As a result, the bridge may perform basic signal processing and channel management of the NVM, as well as some basic error correction functions and XOR parity accumulation. In some embodiments, the controller performs logical-to-physical address mapping, garbage collection, wear leveling, parity management (via control of the parity accumulator in the bridge), RAID striping, etc. This division of labor still provides the controller direct, physical (e.g., page-level) control of the NVM, resulting in the controller managing the NVM at both the page and block level over a fast, high level interface such as PCIe. The controller in one embodiment also manages other integrated services such as the XOR parity accumulator in the bridge.
In one embodiment, another advantage of the architecture's division of the management tasks relates to NVM industry trends. Physical management of the NVM is becoming increasingly important as the most common type of NVM, e.g., MLC (Multi-Level Cell) NAND, continues to evolve to provide higher capacity at the cost of reduced endurance. For example, today's MLC products with a 5,000 P/E-cycle endurance are being replaced with next-generation MLC products with a 1,500-2,000 P/E-cycle endurance. Commonly, the bridge designer is in the best position to understand the physical properties of the NVM and how best to extend its life by implementing various endurance enhancement/management functionalities. Because of this rapidly changing technological landscape, and because each individual NVM manufacturer may require different such endurance enhancement/management functionalities, these functionalities may constantly require fine-tuning to suit the diverse and ever-change varieties of NVM products. Thus, the architecture of some embodiments provides another advantage in its labor division by isolating these functions in the bridge and allowing the controller designer to focus on the high level data management functions. In other words, since the controller and the bridge have different design constraints and priorities, under the architecture each may be updated according to different schedules and manners without a complete redesign of the whole.
With the reduced latency provided by the design, the bridge may be paired with less expensive media. For example, the bridge may be paired with MLC NAND rather SLC (Single-Level Cell) NAND while still meeting performance metrics demanded by customers. In addition, in some embodiments the above described controller-bridge design can be adapted for use in a hybrid drive comprising flash memory and hard disk components. In those embodiments the controller, in addition to managing data accesses to the NVM through the bridge, would also manage data accesses to one or more hard drives. Additional features of this design will be further illustrated below with various drawings and descriptions of the embodiments of the invention.
II.A. Controller-Bridge Implementation
In one embodiment, the non-volatile storage system 120 includes a controller 130 and a NVM storage module 150. The controller 130 in one embodiment communicates with a bridge device 152 within the NVM storage module 150 via a high level interface such as PCIe (through bus logic/interface 140). PCIe is used in one embodiment as it defines a rich packet based routing and Quality of Service (QoS) infrastructure and provides a high speed interface. The controller may include a processor 136 to control data functions, and the core may be coupled with static memory 132 and dynamic memory 134. The controller 130 may also include a data path 138 for processing/transferring data related to data access commands from the host system 110. In one embodiment, the controller 130 is implemented on a SoC (System on Chip), though those skilled in the art will recognize that other hardware/firmware implementations are possible.
In one embodiment, the use of PCIe means that the address range assigned to a device function is used for packet routing both on the fabric and within the device. In one embodiment, the PCIe transaction layer delivers packets to an internal register interface that is read by firmware. Advanced devices often direct incoming packets to internal RAM or hardware acceleration modules.
The bridge device 152 in one embodiment comprises bus logic/interface 154 for communicating with the bus logic/interface 140 (on the controller 130) over the high level interface bus. On the other end of the bridge, the bridge device 152 includes a low level interface 158 such as ONFI for communicating with the NVM storage 160 (e.g., NAND), which may include a number of storage devices such as flash dies 162, 164, 166, and 168. Although ONFI is depicted in this embodiment, other suitable flash memory interfaces may be used. In another embodiment, the bridge may use a different interface such as Toggle or a proprietary interface to communicate with the NVM storage 160, or send direct commands to the storage.
II.B. Division of Labor
The advantages of dividing the NVM management functions were outlined above in Section II. In particular, the architecture reduces latency and addresses the various design constraints while allowing the controller and bridge designers to optimize their respective portions of the architecture. In one embodiment, the controller is responsible for block level management, parity stripe layout, garbage collection, wear leveling, handling read disturb and error recovery. The bridge device, in one embodiment, manages the raw NVM flash interface. It may also provide one or more of: command queuing, error correction, XOR parity accumulator, data protection, and enhances block endurance. The interface between the bridge and the controller in one embodiment is a lightweight PCIe-based data and management interface. The controller uses the interface control command to configure the bridge and data commands to access the NVM media.
It is also noted that the controller uses physical page addressing instead of a logical one that is common in existing controller-bridge designs. The bridge can identify the relationship between pages, blocks, planes, and dies. This gives the controller the greatest flexibility for creating RAID stripe layout, performing data moves, and handling bad blocks. These details are abstracted from the bridge. When using direct addressing, the controller simply provides a set of direct page addresses in the command header to the bridge. In one embodiment, the pages are not necessarily sequential or even in the same block. In most cases, the controller will access pages spread across multiple planes and multiple dies in order to maximize concurrent hardware access.
II.C. Hybrid Application
Some embodiments of the controller-bridge architecture can be adapted for other uses. For example,
The hybrid application illustrates an additional advantage of the controller architecture. A hybrid drive typically includes an SSD that has its own internal controller that has a mapping table to address the NVM within the SSD. While the HDD portion of the hybrid is typically addressed directly, the hybrid controller uses a special mapping table to determine whether data is in the SSD or the HDD. The use of this special mapping table along with the internal SSD mapping table introduces duplicate overhead in cases where data is accessed in the SSD portion of the hybrid, since there are two mapping tables and there is significant cost associated with maintaining each table.
In contrast, because the controller 130 in the present architecture manages the NVM at both the block and page levels and the magnetic media, it can provide uniformed address management across the flash and magnetic media in a single location. Hence there is no need to have the two tables noted above. This has the advantages of reducing duplicative table lookups and all the associated costs/complexities related to maintaining separate mapping tables. Direct page addressing is used in the unified mapping scheme.
In addition, in a hybrid application, the NVM could still provide effective performance enhancement even when it has a large amount of bad blocks (e.g., 50%). In one hybrid embodiment, the controller also has efficient address gap handling capability (on gaps caused by the bad blocks). In an alternative hybrid embodiment, the unified addressing scheme does not necessarily require a bridge to work with the controller. The controller can potentially use a raw NVM interface (e.g., ONFI) to access the NVM.
III. Data Command Processing
III.A. Command and Admin Queues—Bridge
In one embodiment, the controller sends data access commands to a command queue 262 in the bridge device. This is performed by the controller sending data command messages to the bridge (by writing to the command queue BAR (base address register)). In one embodiment, the command queue has room for sixteen messages, though the number of messages can vary in other embodiments. The command queue can be implemented in a number of ways. One option is full hardware automation where the controller simply writes to a fixed offset. Alternately it can be implemented in memory using a ring buffer or an array based linked list. In one embodiment, the implementation must allow for efficient insertion and notification with minimal bus traffic. In one embodiment, the controller knows the current queue depth based on the number of status responses the bridge has sent back (e.g., a message to the controller's completion queue indicating completion of a command). Note that the data commands are much smaller than the actual data. A given record slot in the queue is considered available once the bridge sends back a completion status or an error report.
In the embodiment shown in
III.B. Status Queues—Controller
On the controller side 210 are a set of data ports 214 at data addresses 212 and a number of status queues. In one embodiment, the status queues include an error queue 218, an information queue 222, and a command completion queue 226. These queues are responsible for receiving messages from the bridge regarding command processing, as well as current status of the bridge and the NVM. Additional details relating to the operation on these queues will be further described below in Sections V and VI.
III.C. Communications Between the Controller and the Bridge
Communications between the controller and the bridge are effected in one embodiment through a PCIe protocol stack 230 which includes a number of layers on both sides, including a transactional layer (232, 242), a data link layer (234, 240), and physical layer (236, 238). While PCIe is used in this disclosure to illustrate the operation of the controller and the bridge, other similar standards can be used as well.
The PCIe transaction layer assigns transmit credits based on how much room is left in its Virtual Channel (VC) buffer space. According to the PCIe specification, devices must implement VCO, though some devices implement additional VC to ensure high priority messages have dedicated resources. Packets are directed to the appropriated VC based on their Traffic Class (TC). The TC is also used to determine priority when packets are flowing over the PCIe fabric. Higher TC packets are generally given priority by the root complex, switches and end-devices.
In one embodiment, the controller is designed to operate using only VCO. In one embodiment, though the bridge may implement additional VC, it must be configurable so that it can operate in single VC mode. The messages communicated between the controller and the bridge will be better understood in view of the following brief description of the data processing flow. To service a read command from the host, the controller may first send a command message to the bridge's command queue. Once the bridge processes the command message, it will read the requested data from the NVM and send the read data back to a corresponding data port on the controller side. This action triggers the data path on the controller, which leads to the data being sent back to the host. Conversely, to service a write command from the host, the controller may first send a command message to the bridge's command queue. Once the bridge processes the command message, it will read from a corresponding data port on the controller side. This action triggers the data path on the controller, which leads to the write data being sent from a buffer in the controller to the bridge for writing to the NVM.
The controller in one embodiment communicates with the bridge using three message types of increasing priority: data to be written to the NVM for write commands (0), messages for the bridge's command queue (1), and messages for the bridge's admin queue (2). Those skilled in the art will recognize that different priorities may be assigned to these messages, and the messages could be combined into fewer types or divided into more types depending on the implementation. In one embodiment, under normal conditions, the controller sends a steady stream of data packets to the bridge.
In one embodiment, the bridge interacts with the controller using its own set of prioritized message types (listed here in increasing priority): data read from the NVM for read commands (0), messages for the controller's completion/info queues (1), and messages for the controller's error queue (2). Those skilled in the art will recognize that different priorities may be assigned to these messages, and the messages could be combined into fewer types or divided into more types depending on the implementation. As will be further described below, to facilitate fast processing of data access commands, a read or write by the bridge to a data port in the controller automatically triggers the data path in the controller. In one embodiment, it is not uncommon for the bridge to process several commands in parallel. In one embodiment, the bridge uses the completion queue 226 to notify the controller when commands have completed successfully. In additional, non-critical messages are sent to the info queue 222 while detailed error reports are sent to the error queue 218. In other embodiments, these queues may be combined into fewer queues (with different message types being distinguished by special flags or implied address values) or separated into more queues (e.g., different error queues for different types of error or different info queues for different types of information returned from the bridge).
In other embodiments where a different interface than PCIe is used, the PCIe protocol stack may be replaced with the appropriate stacks/layers of that interface. Those skilled in the art will recognized that other equivalent standardized interfaces (e.g., eMMC) may be adapted to replace PCIe. In other embodiments, a custom/proprietary interface may be used to handle communications between the controller and the bridge.
IV. Implied Command Tag ID and Triggering the Data Path
As shown in block 308, for a read command, the bridge obtains data from the NVM and writes to a corresponding data port 214 and for a write command, the bridge reads data from a corresponding data port 214 and writes to the NVM. In other embodiments, other less efficient variations are possible. For example, the controller may read and write the transactions, and the bridge may simply notify that attention is needed via an interrupt, etc.
In one embodiment, each command in the bridge command queue 262 has a tag. When the bridge is ready to start working on a command that involves a data transfer, it accesses the data port 214 that matched the command tag. In one embodiment, the data path in the controller has sixteen ports defined by two values in the bridge CSR: base address and port size. These two values are sufficient to derive the location of all sixteen ports. In other embodiments, a different number of ports and/or a different address derivation scheme may be used.
For example, when the bridge accesses a particular data port address in the controller (e.g., No. 0 of 15) defined by the associated PCIe address range, the controller will understand that this is for the command associated with that tag. Thus, there is no need for the bridge to separately send a command tag, which reduces overhead as each additional communication between the bridge and the controller adds to the overall latency. To accomplish this, in one embodiment the controller automatically decodes the address (split the upper bits), and loads the registers to trigger/prime the host data path for processing (initiating the automation). However, those skilled in the art will recognize implementations other than the above described implied tag implementation could be used. For example, the bridge could send an explicit command tag message to the controller to indicate the command the bridge is currently working on and which data port it intends to use. The priming of the data path would then be dependent on that explicit command tag message. In other embodiments, the command tags as described above need not be used. Generally, any command configuration data that enables the bridge and/or the controller to keep track of the data port and command correlation can be used.
Returning to
In another embodiment, instead of the implied command tag/data path trigger mechanism describe above, the controller-bridge could communicate in a controller-push model in which the controller sends data along with the commands to the bridge. The bridge would thus need a large volatile memory buffer capacity to hold the user data from the controller for the various commands in the bridge's command queue. This implementation could reduce latency but potentially increase the cost of bridge implementation as a large memory buffer will need to be added to the bridge. This also leads to increased power consumption by the bridge.
V. Advanced Queuing Management
In one embodiment, the bridge supports a number of queues. The bridge in one embodiment has at least one command queue 262 and one control/admin queue 258, as shown in
In one embodiment, the command queue supports sophisticated queuing and out-of-order execution, while the admin queue is ordered. The various queues on both the controller and bridge sides can have a mixture of commands outstanding, and can be asynchronous. The mixture of commands is particularly notable in the bridge command queue as compared to the ONFI specifications. ONFI provides some basic queuing capability through its “read multiple” and “write multiple” commands. However, there can be no mixing of different types of commands. Moreover, commands are batch processed, which means that the commands must clear the queue completely before more commands can be accepted.
In contrast, the advanced queuing capability of the bridge can (1) accept mixed command types, (2) support out of order execution, and (3) allow the controller to send additional commands without having the queue(s) be cleared first. The bridge can also accept special commands from the controller to specify that a certain command be executed with high priority. The bridge manages several channels so it has the flexibility to re-order the commands it receives.
V.A. Command Ordering
The command queue may be implemented in one embodiment as a single queue handling commands with various types of priority indicated by queuing flags (e.g., “priority,” “ordered,” “unordered,” and “background”), or as several separate queues based on the queuing flags. Data commands may be unordered by default, and subject to ordering by the bridge in order to take advantage of hardware optimizations and media utilization. In one embodiment, “priority” and “ordered” flags are used by the controller to indicate deviation from that default.
If the commands A-D are write commands, the bridge may maximize concurrency by executing commands A, C, and D in parallel (A and B can't be executed in parallel). If the bridge has sufficient buffer space, it could also pull down the data from the controller for command B and work on the portion going to die 2. On the other hand, if the commands A-D are read commands, the bridge may maximize concurrency by executing commands A, C, and D in parallel. Though it can read the data on die 2 for command B, the bridge may be required to send the data to the controller in the order specified by the command header.
V.B. Background Priority
A unique feature in the queuing model is the implementation of a background priority in one embodiment. The background priority lets the bridge decide when to execute the command. In one embodiment, commands with the “background” flag are unordered and given the lowest priority. They may also be exempt from the command promotion timer requirement, which is a time value dictating a deadline by which a certain command should be executed. In one embodiment, although the order of command execution is left up to the bridge, a command cannot sit in the queue indefinitely. When the bridge is choosing between unordered commands on the pending list, it will give preference to commands that have expired promotion timers. The timeout value is set by the controller in the bridge control CSR field in one embodiment.
The bridge may work on these “background” commands when it has available resources. For example, background priority can be used for data retention and health scan tasks. As another example, the controller may send down a block erase command with the background flag set. The bridge will perform the erase operation when the target die is not needed for other commands in the queue. In one embodiment, the “ordered,” “priority,” and “background” flags are mutually exclusive. This background command feature is currently absent in in-band I/O interfaces (e.g., UFS, eMMC, SAS or SATA), as they do not support background long running tasks.
VI. Completion, Info, and Error Queues
As previously shown in
In one embodiment, the controller sets the base address and size for each queue in the CSR. In one embodiment, there is no need to communicate the number of queue entries as both sides have sufficient information to derive this value. In one embodiment, the bridge needs to generate an error if the controller attempts to configure a queue with less than one entry.
In one embodiment, the bridge is configured to be required to write to the next valid slot and keep track of how many entries it has written. The address for each slot is derived from the start address and the maximum message size. Every queue entry is required in one embodiment to start on a valid boundary. In one embodiment, the messages are padded to the full record size as the act of writing the last double word (DW) is often used to trigger hardware automation.
The bridge may write multiple entries to one queue in a single operation. One embodiment implements a doorbell-mode, in which the controller does not act on the new entries until the bridge writes to the associated doorbell register with the count of records it has added. In an automation-mode, the controller generates its own signaling when one or more entries are added to the queue. The queue mode (automation or doorbell) may be configured in the CSR.
The controller side queues are sized to match the maximum number of potential entries in one embodiment. In general terms, these values are proportional to the bridge's command queue depth. Given that each command has a tag, the controller may not reuse a tag until it has received status and cleaned up the queue space.
VI.A. Completion Queue
Given that not all commands result in bus transfers, the controller expects to be notified when data and admin commands have completed successfully. Trying to embed the status in regular data path messages creates alignment issues and other edge cases. Instead, in one embodiment the bridge simply writes a completion notice to the completion queue on the controller side. Although other implementations are possible, in one embodiment it is sufficient to send a 32-bit Double Word (DW) where each bit is set to one to represent a command that has completed successfully. For example, where there are 16 slots each in the admin and command queues, the upper 16 bits of the DW can map to admin tags while the lower 16 bits can map to command tags. Though the bridge could send status promptly, system efficiency improves when multiple completion tags are combined. Given that each of these bridge queues is 16 deep in this example embodiment, the completion queue is guaranteed to be 32 entries deep. However, in other embodiments different queue depths for the two queues are possible, and the completion queue mechanism is adjusted accordingly.
VI.B. Info Queue
In one embodiment, the bridge can send general system/status information messages to the controller by writing to the info queue 222 (i.e., writing to the info queue address range 220). Health reports of the NVM, for example, are sent to this queue, and other messages are possible. In one embodiment, this queue is 16 entries deep. In one embodiment, the controller may not issue active or concurrent health scans if there are outstanding read commands. Active and concurrent health scans of the NVM are performed by the bridge at the direction of the controller. Active scans of the NVM are performed without returning of data while concurrent scans are performed concurrently with normal data access operations.
VI.C. Error Queue
In one embodiment, the bridge sends error messages to the controller error queue 218 by writing to the error queue address range 216. In one embodiment, this queue is 16 entries deep.
VII. XOR Parity Accumulator Management
In one embodiment, the bridge includes a XOR parity accumulator that is managed by the controller, which makes the data path simpler in the controller. The controller manages the XOR parity accumulator through XOR parity accumulator commands. In one embodiment, the controller issues common control operation instructions/commands (e.g., embedded within read and write commands) such as: (1) clear before accumulate (operation: read, write), (2) accumulate parity in a buffer (operation: read, write), (3) write a parity buffer to a page in NAND (operation: write). In one embodiment, the instructions/commands are communicated in three bits in the data access command fields. To keep command size down, dedicated commands may be used for less common XOR parity accumulator operations such as: load a parity buffer from a page in NAND, read a parity buffer over the bus, load a parity buffer over the bus, and reset all the parity buffers.
VIII. Other Features
In one embodiment, the bridge supports several power management commands. Returning to
The bridge may on its own implement an energy-credit based throttled policy according to an available number of credits presently available for command execution. In the alternative, the controller may implement the energy-credit based policy and the bridge is configured to support power commands issued by the controller based on that policy. One example policy allows the controller and/or the bridge to set a maximum number of concurrent operations and/or a time delay between operations such that the average power consumed stays under a threshold. Various types of energy-credit based policy are further described in co-pending application Ser. No. 13/216,177, entitled “Non-volatile Storage Subsystem With Energy-Based Performance Throttling,” filed on Aug. 23, 2011, the disclosure of which is hereby incorporated by reference. In another embodiment, the bridge is configured to report power consumption for various operations and allow the controller to set explicit limits through an exposed interface.
In another embodiment, unlike common bridge implementations, the bridge exposes the NAND level information that is typically available over an ONFI interface but hidden in other bridge-controller architectures, as many controllers in those architectures do not manage at the physical page level. Below are some example values that the controller can access:
In some embodiments, because the controller is in a unique position to manage the NVM at both the block and page levels, the exposure of these values are helpful in assisting the controller in its management of the NVM.
In one embodiment, the bridge also supports at least some configuration details listed below. At least some of these relate to the features described above:
In one embodiment, the bridge can support an SLC mode. That is, the controller can specify that certain portions of the MLC NAND operate as SLC. While this is an available option in ONFI, many common bridge implementations do not support this capability.
IX. Inline Parameter Service
A common practice for optimizing NAND endurance is to maintain parametric data such as optimal read threshold settings per page or per block and then use that data when reading or programming specific pages. Two possible options exist for storage of such data. First, this data could be stored in a volatile memory (e.g., DRAM) associated with the controller when high performance is desired. Second, the data could be stored in the NVM and accessed ahead of each NVM operation when the performance requirement is not critical, or when including enough volatile memory on the controller is not practical. The second option places a burden on performance and memory resources.
IX.A. Overview
As between the controller and the bridge device, the bridge device is closely coupled with the NVM and thus is in the best position to determine the optimal parameters to access the NVM based on current condition/historical usage. Thus, one embodiment includes an Inline Parameter Service (IPS) that allows the bridge device 152 to store parameters on a memory associated with the controller 130, with the parameters being automatically appended by the controller 130 to each command as described above. In one embodiment, the controller does not need to be aware of how the parameter data is used; it could simply read the applicable table entry based on the NVM addresses and commands being sent. In addition, the specific table format can vary depending on the various embodiments. In one embodiment the format includes a header that allows the controller to determine how table entries are associated with specific NVM commands. As shown in
IX.B. Boot-up Process; Table Updates
In one embodiment, the controller 130 reads the initial table data during the boot sequence using an IPS Read command sent to the bridge device 152. The bridge device 152 can make small updates to the table 400 by sending IPS Update messages to the controller 130. For example, when a block reaches a certain P/E cycle threshold, the bridge device can send an updated parameter associated with that block to the table. The bridge device can also send an IPS Refresh signal which will prompt the controller 130 to send another IPS Read command to the bridge. Alternatively, updates can be handled via the info queue, or by other methods such as through an interrupt. The table 400 in one embodiment is periodically flushed (copied) to the NVM. For example, it may be flushed to a reserved system area within an SLC-mode area of the NVM since SLC memory is considered more reliable. The reserved system area may include other system data that is read by the controller during power on to load into DRAM/SRAM.
In one embodiment, the parameters 404 are associated with individual addresses 402. For example, each page address may have an entry, and may be associated with several bytes of data (e.g., 4 bytes per entry) of a parameter. In another embodiment, a page address can be associated with multiple parameters. For example, a first parameter value may be associated with read operations for that address (e.g., reference voltage threshold adjustment) and a second parameter value may be associated with write operations for that address.
IX.C. Automatic Append of Parameters
The table 400 may also be used for other purposes. For example, the bridge device may elect to store debugging information, trace log information, metrics/counters. In addition, the bridge device may store media health scan logging information. The table 400 thus provides another way for the bridge device to report NVM-specific information to the controller.
X. Alternative Embodiments; Conclusion
As used in this application, “non-volatile memory” typically refers to solid-state memory such as NAND flash. However, the systems and methods of this disclosure may also be useful in more conventional hard drives and hybrid drives including both solid-state and hard drive components. As such, while certain internal operations are referred to which typically are associated with solid-state drives, such as “wear leveling” and “garbage collection,” analogous operations for hard drives can also take advantage of some embodiments of this disclosure. Solid-state memory may comprise a wide variety of technologies, such as flash integrated circuits, Chalcogenide RAM (C-RAM), Phase Change Memory (PC-RAM or PRAM), Programmable Metallization Cell RAM (PMC-RAM or PMCm), Ovonic Unified Memory (OUM), Resistance RAM (RRAM), NAND memory, NOR memory, EEPROM, Ferroelectric Memory (FeRAM), or other discrete NVM (non-volatile memory) chips. The solid-state storage devices (e.g., dies) may be physically divided into planes, blocks, pages, and sectors, as is known in the art. Other forms of storage (e.g., battery backed-up volatile DRAM or SRAM devices, magnetic disk drives, etc.) may additionally or alternatively be used.
While certain embodiments of the inventions have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms. Furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions. For example, the various components illustrated in
| Number | Name | Date | Kind |
|---|---|---|---|
| 6148354 | Ban et al. | Nov 2000 | A |
| 6182248 | Armstrong et al. | Jan 2001 | B1 |
| 6304984 | Neal et al. | Oct 2001 | B1 |
| 6519718 | Graham et al. | Feb 2003 | B1 |
| 6735661 | Gelke et al. | May 2004 | B2 |
| 6785767 | Coulson | Aug 2004 | B2 |
| 6856556 | Hajeck | Feb 2005 | B1 |
| 6988175 | Lasser | Jan 2006 | B2 |
| 7103684 | Chen et al. | Sep 2006 | B2 |
| 7126857 | Hajeck | Oct 2006 | B2 |
| 7127549 | Sinclair | Oct 2006 | B2 |
| 7136973 | Sinclair | Nov 2006 | B2 |
| 7430136 | Merry, Jr. et al. | Sep 2008 | B2 |
| 7447807 | Merry et al. | Nov 2008 | B1 |
| 7460394 | Happ et al. | Dec 2008 | B2 |
| 7502256 | Merry, Jr. et al. | Mar 2009 | B2 |
| 7509441 | Merry et al. | Mar 2009 | B1 |
| 7594135 | Gonzalez et al. | Sep 2009 | B2 |
| 7596643 | Merry, Jr. et al. | Sep 2009 | B2 |
| 7623401 | Philipp et al. | Nov 2009 | B2 |
| 7631245 | Lasser | Dec 2009 | B2 |
| 7653778 | Merry, Jr. et al. | Jan 2010 | B2 |
| 7685337 | Merry, Jr. et al. | Mar 2010 | B2 |
| 7685338 | Merry, Jr. et al. | Mar 2010 | B2 |
| 7685374 | Diggs et al. | Mar 2010 | B2 |
| 7716411 | Panabaker et al. | May 2010 | B2 |
| 7733712 | Walston et al. | Jun 2010 | B1 |
| 7765373 | Merry et al. | Jul 2010 | B1 |
| 7861038 | Fontenot et al. | Dec 2010 | B2 |
| 7861122 | Cornwell et al. | Dec 2010 | B2 |
| 7898855 | Merry, Jr. et al. | Mar 2011 | B2 |
| 7912991 | Merry et al. | Mar 2011 | B1 |
| 7936603 | Merry, Jr. et al. | May 2011 | B2 |
| 7957173 | Kim | Jun 2011 | B2 |
| 7962777 | Gonzalez et al. | Jun 2011 | B2 |
| 7962792 | Diggs et al. | Jun 2011 | B2 |
| 7970978 | Luo et al. | Jun 2011 | B2 |
| 8065304 | Ross | Nov 2011 | B2 |
| 8078918 | Diggs et al. | Dec 2011 | B2 |
| 8090899 | Syu | Jan 2012 | B1 |
| 8095851 | Diggs et al. | Jan 2012 | B2 |
| 8108692 | Merry et al. | Jan 2012 | B1 |
| 8120969 | Montierth et al. | Feb 2012 | B1 |
| 8122185 | Merry, Jr. et al. | Feb 2012 | B2 |
| 8127048 | Merry et al. | Feb 2012 | B1 |
| 8135903 | Kan | Mar 2012 | B1 |
| 8151020 | Merry, Jr. et al. | Apr 2012 | B2 |
| 8161227 | Diggs et al. | Apr 2012 | B1 |
| 8166245 | Diggs et al. | Apr 2012 | B2 |
| 8243525 | Kan | Aug 2012 | B1 |
| 8254172 | Kan | Aug 2012 | B1 |
| 8261012 | Kan | Sep 2012 | B2 |
| 8291295 | Harari et al. | Oct 2012 | B2 |
| 8296625 | Diggs et al. | Oct 2012 | B2 |
| 8312207 | Merry, Jr. et al. | Nov 2012 | B2 |
| 8315092 | Strasser et al. | Nov 2012 | B2 |
| 8316176 | Phan et al. | Nov 2012 | B1 |
| 8341339 | Boyle et al. | Dec 2012 | B1 |
| 8341374 | Kwon et al. | Dec 2012 | B2 |
| 8375151 | Kan | Feb 2013 | B1 |
| 8392635 | Booth et al. | Mar 2013 | B2 |
| 8397107 | Syu et al. | Mar 2013 | B1 |
| 8407449 | Colon et al. | Mar 2013 | B1 |
| 8423722 | Deforest et al. | Apr 2013 | B1 |
| 8433858 | Diggs et al. | Apr 2013 | B1 |
| 8443167 | Fallone et al. | May 2013 | B1 |
| 8443263 | Selinger et al. | May 2013 | B2 |
| 8447920 | Syu | May 2013 | B1 |
| 8458435 | Rainey, III et al. | Jun 2013 | B1 |
| 8478930 | Syu | Jul 2013 | B1 |
| 8489854 | Colon et al. | Jul 2013 | B1 |
| 8503237 | Horn | Aug 2013 | B1 |
| 8521972 | Boyle et al. | Aug 2013 | B1 |
| 8549236 | Diggs et al. | Oct 2013 | B2 |
| 8583835 | Kan | Nov 2013 | B1 |
| 8601311 | Horn | Dec 2013 | B2 |
| 8601313 | Horn | Dec 2013 | B1 |
| 8612669 | Syu et al. | Dec 2013 | B1 |
| 8612804 | Kang et al. | Dec 2013 | B1 |
| 8615681 | Horn | Dec 2013 | B2 |
| 8638602 | Horn | Jan 2014 | B1 |
| 8639872 | Boyle et al. | Jan 2014 | B1 |
| 8683113 | Abasto et al. | Mar 2014 | B2 |
| 8700834 | Horn et al. | Apr 2014 | B2 |
| 8700950 | Syu | Apr 2014 | B1 |
| 8700951 | Call et al. | Apr 2014 | B1 |
| 8706985 | Boyle et al. | Apr 2014 | B1 |
| 8707104 | Jean | Apr 2014 | B1 |
| 8713066 | Lo et al. | Apr 2014 | B1 |
| 8713357 | Jean et al. | Apr 2014 | B1 |
| 8719531 | Strange et al. | May 2014 | B2 |
| 8724422 | Agness et al. | May 2014 | B1 |
| 8725931 | Kang | May 2014 | B1 |
| 8745277 | Kan | Jun 2014 | B2 |
| 8751728 | Syu et al. | Jun 2014 | B1 |
| 8769190 | Syu et al. | Jul 2014 | B1 |
| 8769232 | Suryabudi et al. | Jul 2014 | B2 |
| 8775720 | Meyer et al. | Jul 2014 | B1 |
| 8782327 | Kang et al. | Jul 2014 | B1 |
| 8788778 | Boyle | Jul 2014 | B1 |
| 8788779 | Horn | Jul 2014 | B1 |
| 8788880 | Gosla et al. | Jul 2014 | B1 |
| 8793429 | Call et al. | Jul 2014 | B1 |
| 20020053010 | Piccirillo et al. | May 2002 | A1 |
| 20030165076 | Gorobets et al. | Sep 2003 | A1 |
| 20030172261 | Lee et al. | Sep 2003 | A1 |
| 20050160217 | Gonzalez et al. | Jul 2005 | A1 |
| 20050223373 | Gage et al. | Oct 2005 | A1 |
| 20050251617 | Sinclair et al. | Nov 2005 | A1 |
| 20060248387 | Nicholson et al. | Nov 2006 | A1 |
| 20070038901 | Shiota et al. | Feb 2007 | A1 |
| 20070180328 | Cornwell et al. | Aug 2007 | A1 |
| 20070190328 | Cowburn et al. | Aug 2007 | A1 |
| 20070220202 | Sutardja et al. | Sep 2007 | A1 |
| 20070245092 | Yeh | Oct 2007 | A1 |
| 20070288683 | Panabaker et al. | Dec 2007 | A1 |
| 20070288692 | Bruce et al. | Dec 2007 | A1 |
| 20080040531 | Anderson | Feb 2008 | A1 |
| 20080192928 | Yu et al. | Aug 2008 | A1 |
| 20080215808 | Ashmore et al. | Sep 2008 | A1 |
| 20080250270 | Bennett | Oct 2008 | A1 |
| 20090013233 | Radke | Jan 2009 | A1 |
| 20090024793 | Fontenot et al. | Jan 2009 | A1 |
| 20090037652 | Yu et al. | Feb 2009 | A1 |
| 20090063730 | Gower et al. | Mar 2009 | A1 |
| 20090150605 | Flynn et al. | Jun 2009 | A1 |
| 20090158124 | Kawai et al. | Jun 2009 | A1 |
| 20090172257 | Prins et al. | Jul 2009 | A1 |
| 20090240873 | Yu et al. | Sep 2009 | A1 |
| 20090282305 | Chen et al. | Nov 2009 | A1 |
| 20090313411 | Stenfort | Dec 2009 | A1 |
| 20100023800 | Harari et al. | Jan 2010 | A1 |
| 20100037012 | Yano et al. | Feb 2010 | A1 |
| 20100088459 | Arya et al. | Apr 2010 | A1 |
| 20100100675 | Furuhjelm | Apr 2010 | A1 |
| 20100122022 | Luo et al. | May 2010 | A1 |
| 20100174849 | Walston et al. | Jul 2010 | A1 |
| 20100174851 | Leibowitz et al. | Jul 2010 | A1 |
| 20100180182 | Trantham | Jul 2010 | A1 |
| 20100205517 | Lee et al. | Aug 2010 | A1 |
| 20100217924 | Panabaker et al. | Aug 2010 | A1 |
| 20100250793 | Syu | Sep 2010 | A1 |
| 20100268874 | Pyeon | Oct 2010 | A1 |
| 20100281342 | Chang et al. | Nov 2010 | A1 |
| 20100325352 | Schuette et al. | Dec 2010 | A1 |
| 20100327923 | Pyeon et al. | Dec 2010 | A1 |
| 20110010491 | Anderson | Jan 2011 | A1 |
| 20110035540 | Fitzgerald et al. | Feb 2011 | A1 |
| 20110040924 | Selinger | Feb 2011 | A1 |
| 20110041039 | Harari et al. | Feb 2011 | A1 |
| 20110082985 | Haines et al. | Apr 2011 | A1 |
| 20110099323 | Syu | Apr 2011 | A1 |
| 20110107076 | Kim et al. | May 2011 | A1 |
| 20110119442 | Haines et al. | May 2011 | A1 |
| 20110138112 | Chiang et al. | Jun 2011 | A1 |
| 20110145489 | Yu et al. | Jun 2011 | A1 |
| 20110238885 | Kitahara et al. | Sep 2011 | A1 |
| 20110283049 | Kang et al. | Nov 2011 | A1 |
| 20110283135 | Burger et al. | Nov 2011 | A1 |
| 20110289267 | Flynn et al. | Nov 2011 | A1 |
| 20110320915 | Khan | Dec 2011 | A1 |
| 20120008414 | Katz et al. | Jan 2012 | A1 |
| 20120102263 | Aswadhati | Apr 2012 | A1 |
| 20120131268 | Anderson | May 2012 | A1 |
| 20120203951 | Wood et al. | Aug 2012 | A1 |
| 20120221922 | Bennett | Aug 2012 | A1 |
| 20120233380 | Butterfield | Sep 2012 | A1 |
| 20120260020 | Suryabudi et al. | Oct 2012 | A1 |
| 20120265926 | Tal et al. | Oct 2012 | A1 |
| 20120278531 | Horn | Nov 2012 | A1 |
| 20120284460 | Guda | Nov 2012 | A1 |
| 20120324191 | Strange et al. | Dec 2012 | A1 |
| 20130060981 | Horn et al. | Mar 2013 | A1 |
| 20130073785 | Emma et al. | Mar 2013 | A1 |
| 20130132638 | Horn et al. | May 2013 | A1 |
| 20130145106 | Kan | Jun 2013 | A1 |
| 20130290793 | Booth et al. | Oct 2013 | A1 |
| 20140059405 | Syu et al. | Feb 2014 | A1 |
| 20140101369 | Tomlin et al. | Apr 2014 | A1 |
| 20140115427 | Lu | Apr 2014 | A1 |
| 20140133220 | Danilak et al. | May 2014 | A1 |
| 20140136753 | Tomlin et al. | May 2014 | A1 |
| 20140149826 | Lu et al. | May 2014 | A1 |
| 20140157078 | Danilak et al. | Jun 2014 | A1 |
| 20140181432 | Horn | Jun 2014 | A1 |
| 20140223255 | Lu et al. | Aug 2014 | A1 |
| Number | Date | Country |
|---|---|---|
| WO2011019596 | Feb 2011 | WO |
| Entry |
|---|
| Office Action dated Oct. 23, 2013 from U.S. Appl. 13/297,163 No., 34 pages. |
| Sebastien A. Jean, et al., U.S. Appl. No. 13/297,163, filed Nov. 15, 2011, 40 pgs. |
| Sebastien A. Jean, U.S. Appl. No. 13/297,082, filed Nov. 15, 2011, 28 pgs. |