STORAGE PROCESSOR MANAGING SOLID STATE DISK ARRAY
A method of writing to one or more solid state disks (SSDs) employed by a storage processor includes receiving a command, creating sub-commands from the command based on a granularity, and assigning the sub-commands to the SSDs independently of the command thereby causing striping across the SSDs.
Latest Avalanche Technology, Inc. Patents:
- Multilayered seed for perpendicular magnetic structure including an oxide layer
- Magnetic memory element including perpendicular enhancement layers and dual oxide cap layers
- Magnetic memory read circuit and calibration method therefor
- Cross-point MRAM including self-compliance selector
- Multilayered seed for perpendicular magnetic structure including an oxide layer
This application is a continuation-in-part of U.S. patent application Ser. No. 14/040,280, filed on Sep. 27, 2013, by Mehdi Asnaashari, and entitled “STORAGE PROCESSOR MANAGING SOLID STATE DISK ARRAY” and a continuation-in-part of U.S. patent application Ser. No. 14/050,274, filed on Oct. 9, 2013, by Mehdi et al., and entitled “STORAGE PROCESSOR MANAGING NVME LOGICALLY ADDRESSED SOLID STATE DISK ARRAY”, the disclosures of both of which are incorporated herein by reference as though set forth in full.
BACKGROUND OF THE INVENTION1. Field of the Invention
This invention relates generally to solid state disks and particularly to addressing schemes used by solid state disks.
2. Description of the Prior Art
The popularity of solid state drives (SSDs) and exponential growth of network content has led to emergence of all-flash storage systems, SSD arrays, or storage appliances. These systems or appliances are either directly attached to a server via the Peripheral Component Interconnect Express (PCIe) or Serial Attached SCSI (SAS) or network-attached via a high-speed, high bandwidth network such as a 10 Giga bit Ethernet (10 GbE). These storage units may include an array of one or more SSDs to meet requisite capacity and performance demands.
This popularity has also led to the creation of a Non-Volatile Memory (NVM) Express (NVMe), revision 1.1, Specification, dated Oct. 11, 2012 for Peripheral Component Interconnect Express (PCIe) SSDs.
One of the existing problems facing the foregoing arrangements is a bottle neck created between the host and the storage units in that hosts may not utilize the array of SSDs evenly therefore depriving optimum performance by the SSDs. For general consumer applications, such as hand-held devices, this arrangement works well. However, in more sophisticated applications, such as Redundant Array of Independent Disks (RAID), employing numerous SSDs, the performance of the system is hindered.
Another problem with current techniques is wear leveling. As readily known to those skilled in the art, SSD is addressed by a host using logical block addresses (LBAs) and physical block addresses (PBAs). The LBAs are ultimately correlated with PBAs, the latter of which identifies a physical location within a SSD. To this end, if a series of locations identified by LBAs belonging to a particular set of SSDs in the array are written and re-written and the remaining LBA-identified locations in the rest of SSD in the array are not as frequently written, the SSDs that are written and re-written experience more wear than those that are not written or less frequently written.
Another problem with designing of a storage appliance is the complexity and cost associated with designing the proprietary array of SSDs for use in the storage appliance.
Thus, there is a need for a low-cost high-performance storage appliance with improved performance and wear leveling without spending tremendous effort developing the array of SSDs.
SUMMARY OF THE INVENTIONBriefly, a method includes writing to one or more solid state disks (SSDs) employed by a storage processor. The method includes receiving a command, creating sub-commands from the command based on a granularity, assigning the sub-commands to the SSDs independently of the command thereby causing striping across the SSDs, and creating NVMe command structures for the sub-commands.
These and other objects and advantages of the invention will no doubt become apparent to those skilled in the art after having read the following detailed description of the various embodiments illustrated in the several figures of the drawing.
In the following description of the embodiments, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration of the specific embodiments in which the invention may be practiced. It is to be understood that other embodiments may be utilized because structural changes may be made without departing from the scope of the invention. It should be noted that the figures discussed herein are not drawn to scale and thicknesses of lines are not indicative of actual sizes.
Referring now to
The host 12 is shown coupled to the NIC 18 through the interface 34 and/or coupled to the PCIe switch 16 through the interface 32. The PCIe switch 16 is shown coupled to the bank of NVMe PCIe SSDs 26. The PCIe switch 16 is shown coupled to the bank of NVMe PCIe SSDs 26 which are shown to include ‘n’ number of NVMe PCIe SSDs or NVMe PCIe SSD 28 through NVMe PCIe SSDn 30 with the understanding that the bank of SSDs 26 may have additional SSDs than that which is shown in the embodiment of
In an embodiment of the invention, the memory 20 is volatile, such as dynamic random access memory (DRAM). In other embodiments, part or all of the memory 20 is non-volatile, such as flash, magnetic random access memory (MRAM), spin transfer torque magnetic random access memory (STTMRAM), resistive random access memory (RRAM), or phase change memory (PCM). In still other embodiments, the memory 20 is made of both volatile and non-volatile memory. It is desirable to save the table 22 in non-volatile memory so as to maintain the information that is saved therein even when power is not applied to the memory 20. As will be evident shortly, maintaining the information in memory at all times is of particular importance because the information maintained in the table 22 and queues 24 and 36 is needed for proper operation of the storage system subsequent to a power interruption.
During operation, the host 12 issues a read or a write command along with data in the case of the latter. Information from the host is normally transferred between the host 12 and the storage processor 10 through the interfaces 32 and/or 34. For example, information is transferred through the interface 34, between the processor 10 and the NIC 18. Information between the host 12 and the PCIe switch 16 is transferred using the interface 34 and under the direction of the of the CPU subsystem 14.
In the case where data is to be stored, i.e. a write operation is consummated; the storage processor 10 receives the write command and accompanying data for storage from the host and through the PCIe switch 16. The received data is ultimately saved in the memory 20. The host write command typically includes the starting LBA and the number of LBAs (sector count) that the host intents to write to. The starting LBA in combination with sector count is referred to herein as “host LBAs” or “host provided LBAs”. Advantageously, the storage processor 10 or the CPU subsystem 14 maps the host provided LBAs to the bank of NVMe PCIe SSDs 26 in such a way that all SSDs are near evenly utilized.
Prior to the foregoing mapping by the CPU subsystem 14, the host write command is divided into or broken up into one or multiple write commands based on the number LBAs that the host intents to write to and a granularity at which the logical to SSD logical table is maintained. Data striping is the technique of segmenting logically sequential data across different SSDs. The combination of the host-provided starting LBA and the sector count; host LBA, associated with a command is divided into one or more LBAs based on the striping granularity and each divided LBA is associated with a sub-command. For example, a host write command with a starting LBA of 24 and a sector count of 16 is divided into two write sub-commands; one with a starting LBA of 24 and a sector count of 8 and another with a starting LBA of 32 with a sector count of 8. Hence the sector count of 8 is the granularity at which the L2sL table is maintained. In this example, the starting LBA is also a multiple of 8, which is the granularity of the L2sL entries. In this manner, mapping is done using the divided or parsed LBAs.
In the case where the host provides a starting address and/or a sector count and the starting LBA is not a multiple of the striping granularity, some of the write sub-commands do not have a starting LBA address and/or a sector count of the striping granularity. Those sub-commands have to be treated in a different manner. For example, a host write command with a starting LBA of 26 and with a sector count of 18 is divided into three sub-commands; the first sub-command has a starting LBA of 26 and a sector count of 6, a second sub-command and with a starting LBA of 32 and with a sector count of 8, and a third sub-command and with a starting address of 40 and a sector count of 4. In this example, the starting LBA address and the sector count of the first write sub-command and the third write sub-command are less than the striping granularity and are accordingly treated in a different manner, as further described later.
Upon receiving a write command from the host, the command and the data associated with the command are saved is in the memory 20. The storage processor 10 breaks out the received command into multiple sub-commands based on a granularity that is typically the same as, although need not be, the same as the granularity of the L2sL table 22. The storage processor 10 or CPU subsystem 14 re-distribute the host logical block addresses (LBAs) across the bank of NVMe PCIe SSDs 26 in a manner so as to nearly guarantee even utilization of the bank of SSDs 26. A command from the host 12, once received, is generally identified by LBAs, however, these LBAs cannot be used to directly access the data in the SSDs. Instead, SSD LBAs (SLBAs) are used when accessing the bank of SSDs 26.
To prevent uneven use of one or more SSDs, host write commands are each divided into multiple sub-commands and mapped to an unassigned SLBA from each SSD therefore causing distribution of the sub-commands across the NVMe PCIe SSDs. Mapping of the LBAs to SLBAs is maintained in the L2sL table 22. Distributing the random LBAs corresponding to a host write command across multiple SSDs decouples the host LBAs from their final destination SLBAs in SSDs. Mapping of the host LBAs to unassigned SLBAs is done in a manner so as to nearly guarantee even utilization of the bank of SSDs 26. The assignment of the unassigned SLBAs to LBAs following host write commands starts where the previous assignment ended. The L2sL table 22 maintains the relationship between the host LBAs and the SSD LBAs. More specifically, the table 22 includes logical-to-SSD logical addresses (L2sL), as will be discussed in further detail below. Accordingly, the host is ignorant of the LBA assignments of SSDs and sub-commands are assigned to different SSDs independently of the host.
Ideally, the granularity of the SLBAs matches the granularity of the table 22.
NVMe is a standard with a specification for accessing PCIe SSDs. NVMe is an optimized, high performance, scalable host controller interface with a streamlined register interface and command set designed for enterprise and client systems that use PCI Express SSDs. NVMe reduces latency and provides faster performance. Previously, SSDs were made using the PCIe bus, but using non-standard proprietary interfaces. By standardizing the interface of the SSDs, hosts or operating systems need only one standard driver to work with all SSDs adhering to the same specification. This also means that each SSD manufacturer doesn't have to allocate resources to design specific interface drivers. With the standardization of the NVMe, the PCIe SSDs are becoming readily available from many SSD manufacturers such as Micron Technology, Inc. of San Jose, Calif., Samsung, Inc. of Korea and Intel Inc. of Santa Clara, Calif. Storage systems, or appliance manufacturers, can take advantage of this by employing NVMe PCIe SSDs in their system or appliance. By using a NVMe PCIe SSD, the storage system or appliance manufacturer need not have to allocate resources to design its own SSD cards for use in its appliance and can rather use off-the-shelf SSD drives that are designed for high throughput and low latency. Using off-the-shelf NVMe PCIe SSDs also lowers the cost of manufacturing the system or appliance since multiple vendors are competing to offer similar products.
In accordance with the various embodiments and methods of the invention, the storage appliance takes advantage of SSDs readily available in the marketplace, hence saving the engineering effort currently employed in optimizing utilization of the SSDs.
In one embodiment of the invention, the storage processor 10 serves as a NVMe host for the SSDs 26. The storage processor 10 receives a command form the host 12, divides the command into sub-commands based on the number of SSDs 26 and the striping granularity, and creates the NVMe command structures for each sub-commands in the submission queues of the corresponding SSDs.
In another embodiment of the invention, the storage processor 10 receives a command and associated data form the host 12, divides the command into sub-commands, associating each sub-command with a portion of the data (“sub-data”) that belongs to the sub-command based on the number of SSDs 26 and the granularity. Data received from the host and prior to being divided into sub-commands is stored in the memory 20. Storage processor 10 creates the NVMe command structures for each sub-command in the submission queues of the corresponding SSDs with each structure pointing to a sub-data.
In yet another embodiment of the invention, the data is stored in a non-volatile memory portion of the memory 20 and the storage processor 10 informs the host of completion of the write command as soon as the host data is stored in the non-volatile memory.
In some embodiments, host LBAs from multiple commands are aggregated and divided into one or more sub-commands based on a striping granularity. In some embodiments, the multiple commands may have some common LBAs or consecutive LBAs. Practically, the host LBA of each command rather than the command itself is used to create sub-commands. Example of the host LBA is the combination of the starting LBA and the sector count. The host LBA of each command is aggregated, divided into one or more LBAs based on the granularity, and each divided LBA is associated to a sub-command. In an exemplary embodiment, the host LBA of a command is saved in the memory 20.
The queue 202, 204, and 206 are each a circular buffer and include a head pointer and a tail pointer. For instance, queue 202 has a head pointer 240 pointing to SSD LBA 208 and a tail pointer 242 pointing to the SSD LBA 220. The head pointer points to the value that should be used by the CPU subsystem 14 to assign to the next host LBA for that particular SSD and the tail pointer points to the last valid value in the queue. In the case where, for example, the head pointer points to the same location as the tail pointer, there are no valid SLBAs left in the queue.
In some embodiments of the invention, the host LBAs of a command are divided and dynamically assigned to SLBAs of the bank of NVMe PCIe SSDs rather than permanently or statically assigned, as done by prior art techniques.
Initially, all the SLBA entries in the queue are available for assignment with the head pointer pointing to the top of the circular queue (or “circular buffer”) and the tail pointer pointing to the end of the circular buffer. For example, the top of the circular buffer 202 is the head pointer 240 pointing to the location 208 and the tail pointer 242 points to the end or bottom of the circular buffer 202, at the location 220. As the CPU subsystem 14 assigns SSD LBAs to the host LBAs, the head pointer of a SSD queue moves down to the next unassigned SSD LBA. And as an already assigned SSD LBA becomes invalid (or un-assigned), it is added to the same SSD queue pointed to by the tail pointer plus one. Each of the queues of
In one embodiment of the invention, the head pointer entries across the bank of SSDs 26 create a stripe of unassigned SLBAs 230 as shown in
The foregoing host LBA manipulation has a number of benefits, one of which is wear leveling by having the random LBAs from the host mapped to SLBAs that are evenly spread across the bank of SSDs 26. Another benefit is increased performance. Regarding the latter, because the host LBAs are evenly spread across all SSDs, they are evenly employed therefore alleviating scenarios where a small set of SSDs rather than all SSDs within the bank are employed, such as in the case of the host commands targeting a small set of SSDs. By employing all SSDs evenly, bottlenecks are avoided and performance is increased.
For a better understanding of the tables of
Each of the queues 302-308 holds unassigned SLBAs for a particular SSD among the bank of PCIe SSD 26 (of
In one embodiment of the invention, the CPU subsystem 14 of
The storage processor 10 or CPU subsystem 14 maintain the L2sL table 22 (in
In the example of
Queues 302, 304, 306 and 308 include the SSD LBAs that have not yet been assigned to the host LBAs. Entries X1 310, Y1 312, Z1 314, and U1 340 in queue 302 are the LBAs in SSD1 that have not yet been assigned. Similarly, SLBAs entries A2 320, B2 318, C2 316, and D2 342, in queue 304, are the LBAs in SSD2; SLBAs entries G3 326, H3 324, I3 322 and J3 344 in queue 306 are the LBAs in SSD3; SLBAs entries M4 330, N4 331, O4 328; and P4 346 in queue 308 are the LBAs in SSD4 that have not yet been assigned to any host LBAs.
The head of the queues 302, 304, 306, and 308 in SSD1, SSD2, SSD3, and SSD4, respectively, make up stripe 350. The CPU subsystem 14 uses the SLBAs entries X1 310, A2 320, G3 326, and M4 330 to assign host LBAs. Once all the entries in stripe 350 are exhausted (or have been assigned), a new stripe 352 is formed with SLBAs entries Y1 312, B2 318, H3 324, and N4 331.
In accordance with an embodiment and method of the invention, the storage processor 10 or CPU subsystem 14 assigns SLBAs from each SSD to random host LBAs in a round robin manner to ensure that all four SSDs are used substantially evenly thereby preventing wear of one or more SSDs. This is due in large part to no one SSD being used substantially more than other SSDs. The SLBAs are assigned across the bank of SSDs to host LBAs (also referred to as “striping”) rather than pre-assignment of host LBAs to a bank of SSDs as done in prior art techniques. Stated differently, SLBAs are striped across all four SSDs before another striping is performed. In addition to addressing wear leveling, embodiments and methods of the invention cause an increase in the performance of the storage processor 10 by allowing parallel or simultaneous access of the SSDs.
The queues 302-308 are generally saved in the memory 20, shown in
It is understood that other schemes besides the queuing scheme shown and discussed herein may be employed to maintain the unassigned SLBAs for the bank of SSD 26.
The host commands “m”, “n”, “o”, and “p”, each have associated host LBAs. Write commands are initially striped or divided into one or a number of sub-commands at a granularity of the L2sL table, i.e. entries in the tables of
In this example, a sequential type of algorithm is employed with the SLBAs being sequentially assigned to the host LBAs. However, CPU subsystem 14 or storage processor 10 may choose to employ another algorithm to assign the SLBAs to host LBAs. Also in this example, stripes are shown formed from head pointers of unassigned SLBAs queues and nicely aligned in rows to make the illustration simple. The CPU subsystem 14 or storage processor 10 may choose other algorithms for creating a stripe.
The table 406 is essentially a logical to logical mapping, which maps host LBAs across a bank of SSDs. It maps the host LBAs to SLBAs. For example, the host LBA 8-LBA 15 of write command m in the table 402 is mapped to SLBA X1 424 and the LBA 16-LBA 23 of the same command is mapped to the SLBA A2 426.
Accordingly, unlike host LBAs, the SLBAs are sequentially and evenly assigned to the bank of SSDs thereby ensuring against uneven use of the SSDs.
Because each command can be divided into multiple parts, i.e. sub-commands, the table 406 is used to indicate the location of each part of the command within one or more SSDs. For example, the SLBA X1 address locations are within the SSD1 and the SLBA A2 address locations are within the SSD2. The SLBA G3, M4 and Y1 span across multiple SSDs, i.e. SSD3, SSD4, and SSD1, respectively. The X1 and A2 span across the SSD1 and SSD2.
Referring still to
Referring still to
In an embodiment of the invention, the tables 700 resides in the memory 20, as shown in
In the event the received LBAs that are associated with a host command do not align with the granularity of the L2sL tables, the storage processor 10 may perform one of a few options. One option is to wait until it receives the remainder of the LBAs to complete the granularity and then assign the complete host LBAs to a SLBA and dispatch the command. Another option is the storage processor 10 to issue a read command to a SSD that contains the host data associated with the host LBAs to complete the granularity and then assign the LBAs to a new unassigned SLBA and dispatch the command. Yet another option is to have the storage processor 10 issue a partial write command to the same SLBA and SSD corresponding to the received host LBA and have the SSD merge the partial SLBA data with the remainder of the data.
In an embodiment of the invention, the storage processor 10 attempts to minimize the scattering of the sub-data. Though scattering the data provides flexibility for the storage processor 10 to manage its memory 20, it disadvantageously creates additional processing time for the NVMe PCIe SSDs 26 to gather the list. The storage processor 10 should manage the memory allocation/de-allocation at the granularity of the sub-data to avoid creating SGL and to optimize performance of the bank of NVMe PCIe SSDs. Furthermore, eliminating or minimizing the SGL also reduces the number of memory reads the SSDs have to perform to the memory 20 for reading the list hence reducing the accesses to the memory 20.
In one embodiment of the invention and in accordance with the NVMe standard, the storage processor 10 may create multiple submission and completion queues for each of the SSDs in the bank of NVMe PCIe SSDs 26. For example, it may maintain a separate submission queue for write and read commands.
In yet another embodiment of the invention, a round robin arbitration or weighted round robin with urgent priority class arbitration may be employed by the storage processor 10 for the NVMe PCIe SSDs to process commands from each submission queue in accordance with NVMe standards.
In one embodiment of the invention, the striping granularity matches the intended workload in which the storage system 8 is being utilized. Storage appliances are being deployed in different applications requiring high performance; applications such as but not limited to mail servers, databases and indexing. These applications have different workload and input/output (I/O) requirements. Smaller striping granularity may fit one workload better than the others. The host may instruct the storage processor 10 to set the striping granularity accordingly.
In the event the data associated with the striping granularity does not match the flash memory page size, the storage processor 10 stores as many NVMe command structures in the submission queue of a SSD as is needed to fill the entire flash page before storing commands in the submission queue of the next SSD.
To optimize the overall performance of the individual SSDs in the bank of NVMe PCIe SSDs 26, the storage processor 10 stores as many sub-commands in each of the SSD submission queues as it takes to fill the entire flash page. Once enough sub-commands are queued for one SSD to fill its entire flash page, the storage processor dispatches the sub-commands to the SSD in accordance with the NVMe Standard and queues the subsequent sub-commands for the next SSD in the bank of NVMe PCIe SSDs 26.
In some embodiments of the invention, the storage processor 10 or CPU subsystem 14 may queue enough commands for each flash memory, such as the memory 20, to perform a program page multi-plane operation to further improve the performance of the SSDs and the storage system 8. In other embodiments of the invention, storage processor 10 queues and dispatches the SSD sub-commands based on and regardless of the flash page size and allows the individual SSDs to perform the optimization.
In the foregoing example, 4 sub-commands are queued per SDD because the flash page size is 4 times greater than the L2sL entries. Since the four sub-commands are being queued for the same SSD, the four unassigned SLBA being assigned to the LBA is drawn from the same unassigned SLBA queue, which corresponds to the SSD.
Referring now to the example on
In another embodiment of the invention, the unassigned queues and L2sL table as well as the submission and completion queues are maintained in the non-volatile portion of the memory 20. These queues and table retain their values in the event of power failure. In another embodiment, the queues and/or table are maintained in a DRAM and periodically stored in the bank of SSDs 26.
In yet another embodiment of the invention, the host data associated with a host write command is stored or cached in the non-volatile memory portion of the memory 20; that is some of the non-volatile memory portion of the memory 20 is used as a write cache. In such case, completion of the write command can be sent to the host once the data is in the memory 20, prior to dispatching the data to the bank of NVMe PCIe SSDs. This is due to the data being in a persistent memory hence the write latency being substantially reduced therefore allowing the host to de-allocate resources that were dedicated to the write command. Storage processor 10, at its convenience, moves the data from the memory 20 to the bank of NVMe PCIe SSDs. In the meanwhile, if the host wishes to access the data that is in the write cache but not yet moved to bank of NVMe PCIe SSDs 26, the storage processor 10 knows to access this data only from the write cache. Thus, host data coherency is maintained.
In other embodiments of the invention, the storage processor 10 keeps track of a number of sub-commands corresponding to a host write command and only de-allocates the portion of the memory 20 that has been allocated to the write command, and other resources associated with the write command, once all the sub-commands are successfully written to the bank of NVMe PCIe SSDs 26.
In another embodiment of the invention, the storage processor 10 keeps track of the number of sub-commands corresponding to a host read command and only transfers the data to the host once all the data associated with the sub-commands are successfully read and transferred to a portion of the memory 20.
In some embodiment of the invention, the storage processor 10 maintains an entry in a status queue corresponding to each entry of the SSD command queue to keep track of sub-command completion. It is understood that a command can be made of a single sub-command.
Next, at 1428, a determination is made as whether or not the LBAs from the host have been previously mapped or assigned to SLBAs and if so, the process continues to step 1432 and if not, the process continues to step 1430. At step 1432, the previously-assigned SLBAs are reclaimed and added to the tail pointer of the corresponding pool of unassigned SLBA queues and the process continues to the step 1430. At step 1430, the L2sL table entries pointed to by the LBAs are updated with new SLBA values from step 1426. Lastly, at step 1434, the storage processor 10 creates NVMe command structures for each sub-command in the submission queues of the corresponding SSDs. At 1436, the writing process ends.
In one embodiment of the invention, the granularity of the SLBAs maintained in the SSD unassigned queues and the L2sL table are the same. In another embodiment, the granularity of the SLBAs and the L2sL table matches the granularity at which the SSDs maintain theirs logical to physical tables.
Although the invention has been described in terms of specific embodiments, it is anticipated that alterations and modifications thereof will no doubt become apparent to those skilled in the art. It is therefore intended that the following claims be interpreted as covering all such alterations and modification as fall within the true spirit and scope of the invention.
Claims
1-30. (canceled)
31. A method of writing to two or more solid state disks (SSDs) employed by a storage processor, the method comprising:
- receiving one or more commands from a host, the one or more commands having host logical block addresses (LBAs), a portion of the one or more commands defining a sub-command, the portion of the one or more commands excluding the host LBAs;
- assigning a queue to a distinct SSD, each queue having entries and each entry holding an unassigned SSD LBA (SLBAs), one entry of each of the queues forming a stripe;
- assigning a sub-command of a command to an unassigned SLBA of a stripe;
- continuing assigning remaining sub-commands of the command to unassigned SLBAs of the stripe until the stripe includes only assigned sub-commands before starting another stripe; and
- creating a Non-Volatile Memory Express (NVMe) command structure for each sub-command.
32. The method of writing, as recited in claim 31, further including maintaining a list of unassigned SLBAs.
33. The method of writing, as recited in claim 32, wherein the host LBAs are each divided into one or more LBAs based on a granularity and assigning each of the divided LBAs to an unassigned SLAB.
34. The method of writing, as recited in claim 33, wherein the NVMe command structure includes one of the SLBAs.
35. The method of writing, as recited in claim 34, further including maintaining the assignment of the host LBAs and SLBAs.
36. (canceled)
37. The method of writing, as recited in claim 1, wherein the queues are circular buffers, with each circular buffer having a head pointer and a tail pointer.
38. The method of writing, as recited in claim 37, further including pointing to unassigned SLBAs of each of the queues by their corresponding head pointer.
39. The method of writing, as recited in claim 31, further including receiving data associated with the one or more commands from the host and further dividing the data into one or more sub-data based on a granularity, with each divided sub-data being associated with a sub-command.
40. The method of writing, as recited in claim 39, further including the NVMe command structure pointing to a sub-data of a sub-command.
41. The method of writing, as recited in claim 40, wherein the storage processor includes memory and the memory includes non-volatile memory and further maintaining the L2sL table in the non-volatile memory.
42. A method of writing to two or more solid state disks (SSDs) employed by a storage processor, the method comprising:
- receiving one or more commands from a host, the one or more commands having host logical block addresses (LBAs);
- assigning a queue to a distinct SSD, each queue having entries and each entry holding an unassigned SSD LBA (SLBAs), one entry of each of the queues forming a stripe;
- assigning a distinct unassigned SLBA to each of a plurality of sub-commands, the plurality of sub-commands being associated with a command and based on a granularity, each of the unassigned SLBAs belonging to a different SSD of a stripe thereby causing striping across all of the SSDs of the stripe before causing striping across a next stripe, the SLBAs assigned to sub-commands having no relationship to the host LBAs;
- wherein a SLBA assigned to a sub-command is different from a previously-assigned SLBA of the same sub-command; and
- creating a Non-Volatile Memory Express (NVMe) command structure for each sub-command.
43. The method of writing, as recited in claim 42, further including maintaining a list of unassigned SLBAs.
44. The method of writing, as recited in claim 43, wherein the host LBAs are each divided into one or more LBAs based on the granularity and assigning each of the divided LBAs to an unassigned SLBA.
45. The method of writing, as recited in claim 44, wherein the NVMe command structure includes the SLBA assigned to a corresponding sub-command.
46. The method of writing, as recited in claim 45, further including maintaining the assignment of the unassigned SLBA to the divided LBAs in a logical to SSD logical (L2sL) table.
47. (canceled)
48. The method of writing, as recited in claim 42, wherein the queues are circular buffers, with each circular buffer having a head pointer and a tail pointer.
49. The method of writing, as recited in claim 48, wherein performing the striping across the two or more SSDs by using an unassigned SLBA from each of the queues pointed to by the queue's corresponding head pointer.
50. The method of writing, as recited in claim 42, further including receiving data associated with a command of the one or more commands from the host and further dividing the data into one or more sub-data based on the granularity, with each divided sub-data being associated with a sub-command.
51. The method of writing, as recited in claim 50, wherein the NVMe command structure pointing to a sub-data associated with one of the sub-commands of the command.
52. The method of writing, as recited in claim 42, wherein the storage processor includes memory and the memory includes non-volatile memory and maintaining the L2sL table in the non-volatile memory.
53. A method of writing to two or more solid state disks (SSDs) employed by a storage processor, the method comprising:
- receiving one or more commands from a host, the one or more commands having host logical block addresses (LBAs);
- forming sub-commands from a command from the host, a set of first sub-commands being based on host LBAs and a granularity, the set of first sub-commands defining the number of sub-commands of a set of second sub-commands;
- assigning SLBAs to each of the set of second sub-commands, each of the assigned SLBAs belonging to a distinct SSD of a stripe causing striping of the set of second sub-commands across all of the SSDs of the stripe before starting striping across a next stripe;
- upon forming a set of sub-commands that is the same as the set of first sub-commands, assigning a different SLBA to a set of second sub-commands that corresponds to the set of sub-commands; and
- creating a Non-Volatile Memory Express (NVMe) command structure for each sub-command.
54. The method of writing, as recited in claim 53, further including maintaining a list of unassigned SLBAs groups that are not assigned to any of the two or more SSDs.
55. The method of writing, as recited in claim 54, wherein the host LBAs are each divided into one or more LBAs based on the granularity and assigning each of the divided LBAs to an unassigned SLBA.
56. The method of writing, as recited in claim 55, wherein the NVMe command structure including the SLBA assigned to the sub-command.
57. The method of writing, as recited in claim 56, further including maintaining the assignment of the unassigned SLBAs and the divided LBAs in a logical to SSD logical (L2sL) table.
58. A method of writing to two or more solid state disks (SSDs) employed by a storage processor, the method comprising: wherein a SLBA assigned to a sub-command has no relationship to the host LBA; and
- receiving one or more commands from a host, the one or more commands having host logical block addresses (LBAs), the host LBAs defining sub-commands, the sub-commands being based on a granularity;
- assigning a queue to a distinct SSD, each queue having entries and each entry holding an unassigned SSD LBA (SLBAs), one entry of each of the queues forming a stripe;
- assigning each of the sub-commands to a SLBA from a different one of the queues of a stripe and causing striping across all of the SSDs of the stripe before causing striping across a next stripe,
- creating a Non-Volatile Memory Express (NVMe) command structure for each sub-command.
59. The method of writing, as recited in claim 58, further including maintaining a list of unassigned SLBA and further dividing the host LBAs into one or more LBAs based on the granularity and assigning each of the divided LBAs to a unassigned SLBA.
60. The method of writing, as recited in claim 58, wherein the NVMe command structure including the SLBA assigned to the sub-command.
Type: Application
Filed: Nov 6, 2013
Publication Date: Apr 2, 2015
Applicant: Avalanche Technology, Inc. (Fremont, CA)
Inventors: Mehdi Asnaashari (Danville, CA), Siamack Nemazie (Los Altos Hills, CA)
Application Number: 14/073,669
International Classification: G06F 12/02 (20060101);