The present disclosure relates generally to information handling systems, and more particularly to performing deferred parity data update operations in an information handling system with the assistance of RAID storage devices.
As the value and use of information continues to increase, individuals and businesses seek additional ways to process and store information. One option available to users is information handling systems. An information handling system generally processes, compiles, stores, and/or communicates information or data for business, personal, or other purposes thereby allowing users to take advantage of the value of the information. Because technology and information handling needs and requirements vary between different users or applications, information handling systems may also vary regarding what information is handled, how the information is handled, how much information is processed, stored, or communicated, and how quickly and efficiently the information may be processed, stored, or communicated. The variations in information handling systems allow for information handling systems to be general or configured for a specific user or specific use such as financial transaction processing, airline reservations, enterprise data storage, or global communications. In addition, information handling systems may include a variety of hardware and software components that may be configured to process, store, and communicate information and may include one or more computer systems, data storage systems, and networking systems.
Information handling systems sometime utilize storage systems such as those provided by a Redundant Array of Independent Disks (RAID) storage system that includes a plurality of RAID storage devices. As will be appreciated by one of skill in the art, RAID storage systems are provided by a data storage virtualization technology that combines the physical RAID storage devices into one or more logical storage units for the purposes of data redundancy, performance improvements, and/or other benefits known in the art. For example, data in a RAID storage system may be distributed across the RAID storage devices using several different techniques that are referred to as “RAID levels” that provide different levels of redundancy and performance (e.g., RAID 0, RAID 1, RAID 5, RAID 6, and so on), with each RAID level providing a different balance among goals that include reliability, availability, performance, and capacity. However, the introduction of new storage technologies for use in RAID storage systems has been found to raise some issues.
For example, Non-Volatile Memory express (NVMe) storage devices (e.g., NVMe Solid State Drive (SSD) drives) utilize an open logical device interface specification for accessing its non-volatile storage media (e.g., provided by NAND flash memory devices) via a Peripheral Component Interconnect express (PCIe) bus to provide low latency, internal parallelism, and/or other benefits known in the art. However, NVMe storage devices present a challenge when utilized with RAID storage systems because the aggregate performance of the NVMe storage devices is typically much greater than the performance capabilities of the RAID storage controller provided for the RAID storage system (and that performance is even projected to be much greater than the performance capabilities of next-generation RAID storage controllers), which results in those RAID storage controllers being unable to manage more than a few NVMe storage devices (e.g., conventional RAID storage controllers are currently capable of managing approximately four NVMe storage devices). As such, the use of NVMe storage devices in RAID storage subsystems present RAID storage system scaling issues, as the RAID storage controllers cannot scale with more than a few NVMe storage devices.
Accordingly, it would be desirable to provide a RAID storage system that addresses the issues discussed above.
According to one embodiment, an Information Handling System (IHS) includes a Redundant Array of Independent Disk (RAID) primary data storage device that includes a first storage subsystem storing first primary data, a first buffer subsystem, and a second buffer subsystem, wherein the RAID primary data storage device is configured, in response to a first command received from a RAID storage controller device, to: write, to the first buffer subsystem via a first Direct Memory Access (DMA) operation from a host system, second primary data; perform an XOR operation on the first primary data in the first storage subsystem and the second primary data in the first buffer subsystem to produce first interim parity data; write, to the second buffer subsystem, the first interim parity data; send a first completion message to the RAID storage controller device that causes the RAID storage controller to provide a journal entry in the host system that indicates an inconsistent parity stripe, wherein the RAID primary data storage device is configured, in response to a second command received from the RAID storage controller device, to: write, to the first buffer subsystem via a second DMA operation from the host system, third primary data; perform an XOR operation on the second primary data in the first storage subsystem, the third primary data in the first buffer subsystem, and the first interim parity data in the second buffer subsystem to produce second interim parity data; write, to the second buffer subsystem, the second interim parity data; a RAID parity data storage device that includes a second storage subsystem storing first parity data and a third buffer subsystem, wherein the RAID parity data storage device is configured, in response to a third command received from the RAID storage controller device, to: write, to the third buffer subsystem via a third DMA operation from the second buffer subsystem, the second interim parity data; perform an XOR operation on the first parity data in the second storage subsystem and the second interim parity data in the third buffer subsystem to produce second parity data; overwrite, in the second storage subsystem, the first parity data with the second parity data; and send a second completion message to the RAID storage controller device that causes the RAID storage controller to remove the journal entry in the host system that indicates the inconsistent parity stripe.
For purposes of this disclosure, an information handling system may include any instrumentality or aggregate of instrumentalities operable to compute, calculate, determine, classify, process, transmit, receive, retrieve, originate, switch, store, display, communicate, manifest, detect, record, reproduce, handle, or utilize any form of information, intelligence, or data for business, scientific, control, or other purposes. For example, an information handling system may be a personal computer (e.g., desktop or laptop), tablet computer, mobile device (e.g., personal digital assistant (PDA) or smart phone), server (e.g., blade server or rack server), a network storage device, or any other suitable device and may vary in size, shape, performance, functionality, and price. The information handling system may include random access memory (RAM), one or more processing resources such as a central processing unit (CPU) or hardware or software control logic, ROM, and/or other types of nonvolatile memory. Additional components of the information handling system may include one or more disk drives, one or more network ports for communicating with external devices as well as various input and output (I/O) devices, such as a keyboard, a mouse, touchscreen and/or a video display. The information handling system may also include one or more buses operable to transmit communications between the various hardware components.
In one embodiment, IHS 100,
Referring now to
In the illustrated embodiment, the RAID storage system 200 also includes a RAID storage controller device 204 that is coupled to the host system 202 and that may be provided by the IHS 100 discussed above with reference to
However, while a few RAID storage devices in a particular configuration are illustrated, one of skill in the art in possession of the present disclosure will recognize that many more storage devices may (and typically will) be coupled to the RAID storage controller device 204 and the host system 202 (e.g., in a datacenter) and may be provided in other RAID configurations while remaining within the scope of the present disclosure. In the embodiments discussed below, the RAID storage devices 206a-206d are described as being provided by Non-Volatile Memory express (NVMe) Solid State Drive (SSD) drives, but one of skill in the art in possession of the present disclosure will recognize that other types of storage devices with similar functionality as the NVMe SSD drives (e.g., NVMe PCIe add-in cards, NVMe M.2 cards, etc.) may be implemented according to the teachings of the present disclosure and thus will fall within its scope as well. While a specific RAID storage system 200 has been illustrated and described, one of skill in the art in possession of the present disclosure will recognize that the RAID storage system of the present disclosure may include a variety of components and component configurations while remaining within the scope of the present disclosure as well.
Referring now to
The chassis 302 may also house a storage subsystem 306 that is coupled to the RAID storage engine 304 (e.g., via a coupling between the storage subsystem 306 and the processing system). Continuing with the example provided above in which the RAID storage device 300 is an NVMe SSD storage device, the storage subsystem 306 may be provided by a flash memory array such as, for example, a plurality of NAND flash memory devices. However, one of skill in the art in possession of the present disclosure will recognize that the storage subsystem 306 may be provided using other storage technologies while remaining within the scope of the present disclosure as well. The chassis 302 may also house a buffer system 308 that includes a first buffer subsystem 308a that is coupled to the RAID storage engine 304 (e.g., via a coupling between the first buffer subsystem 308a and the processing system), and a second buffer subsystem 308b that is coupled to the RAID storage engine 304 (e.g., via a coupling between the second buffer subsystem 308b and the processing system). For example, the buffer system 308 may be provided by one or more buffer memory devices that include a first set of memory address ranges that provide the first buffer subsystem 308a, and a second set of memory address ranges that provide the second buffer subsystem 308b. Continuing with the example provided above in which the RAID storage device 300 is an NVMe SSD storage device, the first buffer subsystem 308a may be provided by a portion of the buffer system 308 that is often referred to as the “device buffer”. However, one of skill in the art in possession of the present disclosure will recognize that the first buffer subsystem 308a may be provided using other buffer technologies while remaining within the scope of the present disclosure as well.
Similarly, continuing with the example provided above in which the RAID storage device 300 is an NVMe SSD storage device, the second buffer subsystem 308b may be provided by a portion of the buffer system 308 that is often referred to as the “Controller Memory Buffer (CMB)”, “scratchpad buffer”, or “cache buffer”. In an embodiment, the second buffer subsystem 308b/CMB may be provided by a subset of the buffer system 308 that is distinguished from the first buffer subsystem 308a/device buffer. For example, the second set of memory address ranges in the buffer memory device(s) that provide the second buffer subsystem 308b/CMB may be mapped to the PCIe memory space of the host system 202, which one of skill in the art in possession of the present disclosure will recognize makes the second buffer subsystem 308b/CMB visible to the host system 202 while the rest of the buffer system 308 (e.g., the first buffer subsystem 308a/device buffer) is not (i.e., due to the first set of memory address ranges in the buffer memory device(s) that provide the first buffer subsystem 308a/device buffer not being mapping to the PCIe memory space of the host system 202.) As will be appreciated by one of skill in the art in possession of the present disclosure, mapping the second buffer subsystem 308b/CMB to the PCIe memory space of the host system 202 allows for the second buffer subsystem 308b/CMB to be the target of the Direct Memory Access (DMA) data operation discussed below. However, one of skill in the art in possession of the present disclosure will recognize that the second buffer subsystem 308b may be provided using other buffer technologies while remaining within the scope of the present disclosure as well. The chassis 302 may also house a storage system (not illustrated, but which may be provided by the storage device 108 discussed above with reference to
The chassis 302 may also house a communication system 310 that is coupled to the RAID storage engine 304 (e.g., via a coupling between the communication system 310 and the processing system), the first buffer subsystem 308a, and the second buffer subsystem 308b, and that may be provided by any of a variety of storage device communication technologies and/or any other communication components that would be apparent to one of skill in the art in possession of the present disclosure. Continuing with the example provided above in which the RAID storage device 300 is an NVMe SSD storage device, the communication system 310 may include any NVMe SSD storage device communication components that enable the Direct Memory Access (DMA) operations described below, the submission and completion queues discussed below, as well as any other components that provide NVMe SDD storage device communication functionality that would be apparent to one of skill in the art in possession of the present disclosure. While a specific RAID storage device 300 has been illustrated, one of skill in the art in possession of the present disclosure will recognize that RAID storage devices (or other devices operating according to the teachings of the present disclosure in a manner similar to that described below for the RAID storage device 300) may include a variety of components and/or component configurations for providing conventional RAID storage device functionality, as well as the functionality discussed below, while remaining within the scope of the present disclosure as well.
Referring now to
Subsequently, as long as a parity update requirement is not met, the RAID primary data storage device may receive subsequent commands from the RAID storage controller device and, in response to each of those subsequent commands, may retrieve new primary data from the host system via a DMA operation, perform an XOR operation on the current primary data in its first storage subsystem, the current interim parity data in its first buffer subsystem, and the new primary data to produce updated interim parity data, write the updated interim parity data to its first buffer subsystem, overwrite the current primary data with the new primary data in its first storage subsystem (with the new primary data becoming current primary data), and send a completion message to the RAID storage controller device. In many cases, the overwriting of the current primary data with the new primary data in its first storage subsystem is to the same storage location in the first storage subsystem such that the RAID storage controller device need not provide or update any journal entry in the host system that indicates an inconsistent parity stripe. However, if the writing or updating of the new primary data in its first storage subsystem is to any different memory location, the RAID storage controller device may provide or update journal entry(ies) in the host system that indicate an inconsistent parity stripe.
Once the parity update requirement is met, the RAID parity data storage device may receive a second command from the RAID storage controller device and, in response, may retrieve the current interim parity data via a DMA operation from the first buffer subsystem in the RAID primary data storage device, perform an XOR operation on current parity data in its second storage subsystem and the current interim parity data to produce updated parity data, overwrite the current parity data with the updated parity data in the second storage subsystem, and send a completion message to the RAID storage controller device. In response to receiving the completion message, the RAID storage controller device may remove the journal entry in the host system that indicates the inconsistent parity stripe. As such, deferred parity update operations are offloaded from the RAID storage controller device, thus increasing the ability of the RAID storage controller device to scale with high performance RAID storage devices.
With reference to
As will also be appreciated by one of skill in the art in possession of the present disclosure, the primary/parity data storage configuration illustrated in
The method 400 begins at block 402 where a RAID primary data storage device receives a command from a RAID storage controller device. In an embodiment, at block 402, the RAID storage controller device 204 may generate and transmit a command to a RAID primary data storage device. With reference to
In some embodiments, the command 604 may be a multi-operation command like those described in U.S. patent application Ser. No. 16/585,296, filed on Sep. 27, 2019. For example, the command 604 may be an NVMe WRITE WITH XOR multi-operation command that is configured to cause the RAID primary data storage device 206b to perform the multiple operations described below. However, while described as providing a multi-operation command at block 402, one of skill in the art in possession of the present disclosure will recognize that the multiple operations performed by the RAID primary data storage device 206b discussed below may be performed in response to respective commands transmitted by the RAID storage controller device 204 while remaining within the scope of the present disclosure as well. In a specific example, the transmission of the command 604 may include the RAID storage controller device 204 providing the command 604 in a submission queue that is included in the communication system 310 in the RAID primary data storage device 206b/300, and then ringing a doorbell for the RAID primary data storage device 206b/300. However, one of skill in the art in possession of the present disclosure will recognize that the command 604 may be provided to the RAID primary data storage device 206b in a variety of manners that will fall within the scope of the present disclosure as well.
As such, in some examples the RAID storage engine 304 in the RAID primary data storage device 206b/300 may respond to the ringing of its doorbell by accessing the command 604 in the submission queue in its communication system 310. In embodiments in which the command 604 is a multi-operation command, the RAID storage engine 304 in the RAID primary data storage device 206b/300 may identify the multiple operations instructed by that command 604 (as described in U.S. patent application Ser. No. 16/585,296, filed on Sep. 27, 2019.) However, while a single RAID primary data storage device is illustrated and described below as receiving the command 604 that causes it to update its primary data 500b, one of skill in the art in possession of the present disclosure will recognize how multiple RAID primary storage devices may receive similar commands at block 402 while remaining within the scope of the present disclosure as well.
The method 400 then proceeds to block 404 where the RAID primary data storage device retrieves primary data from a host system. With reference to
The method 400 then proceeds to block 406 where the RAID primary data storage device performs XOR operations on primary data to produce interim parity data, and writes the interim parity data to its buffer subsystem. With reference to
With reference to
With reference to
The method 400 may then proceed to optional block 408 where the RAID storage controller device may provide a journal entry in the host system to indicate an inconsistent parity stripe. For example, with reference to
However, as discussed below, the determination and storage of the interim parity data 612 allows for the updating of the parity data 502 stored in the storage subsystem 306 in the RAID parity data storage device 206d to be deferred, and the journal data 702 provided in the storage subsystem 202a of the host system 202 allows for data recovery from a failure (e.g., a power loss to the RAID storage system 200) that occurs prior to the updating of the parity data 502 stored in the storage subsystem 306 in the RAID parity data storage device 206d. As would be appreciated by one of skill in the art in possession of the present disclosure, the journal data 702 provides “insurance” for deferring the update of the parity data 502 by recording the data stripes that have been modified without an associated parity data update so that in the case of a power loss or other RAID storage system failure, the parity data can be recalculated. As will be appreciated by one of skill in the art in possession of the present disclosure, the journal may document whether the stripe is inconsistent (and in some cases to more granular level than the stripe), as well as the most recent written data which is not yet represented as consistent parity in the parity stripe (unless the risk that no drive loss will happen during the deferred parity update time is deemed acceptable by an administrator.)
The deferred parity data updates of the present disclosure may be particularly beneficial in situations where an application (e.g., running on the host system 202) repeatedly writes and/or updates data in the same storage location (e.g., the same location in the storage subsystem 306 in the RAID primary data storage device 206b, i.e., the same NAND flash memory device location(s)). For example, as will be appreciated by one of skill in the art in possession of the present disclosure, the journal data 702 may indicate an inconsistent parity stripe for a particular storage location and, as such, once the journal data 702 is provided in the storage subsystem 202a in the host system 202, subsequent changes to the primary data at that same storage location in the storage subsystem 306 in the RAID primary data storage device 206b do not require changes, updates, and/or modifications to that journal data 702/journal entry. Thus, optional block 408 may not be performed in situations in which the primary data updates that occur on subsequent iterations of the method 400 are provided in the same storage locations. However, as discussed below, optional block 408 may be performed any time a new storage location is used to write/update primary data stored in the RAID primary data storage device(s).
Following the writing of the journal data 702 to the storage subsystem 202a in the host system 202, the RAID storage controller device 204 may generate and transmit a completion message 704 to the host system 202. As will be appreciated by one of skill in the art in possession of the present disclosure, the completion message 704 may indicate to the host system 202 that the write command 602 to write the primary data 600 to the RAID primary data storage devices 206a-206c has been performed, and in some situations may indicate that the primary data 600 has been backed up (e.g., by indicating that the parity data 502 has been updated (even though it actually has not), by indicating that the interim parity data 612 and the journal data 702 have been generated and stored, etc.) As such, following operation block 408, the host system 202 may assume that the write operation associated with the write command 602 is completed, and may operate to generate and request storage of additional primary data I the RAID primary data storage devices 206a-206c, discussed in further detail below.
The method 400 then proceeds to decision block 410 where it is determined whether a parity update requirement has been met. In an embodiment, the RAID storage controller device 204 may operate at decision block 410 to determine whether a requirement for updating the parity data 502 in the storage subsystem 306 of the RAID parity data storage device 206d has been met. As will be appreciated by one of skill in the art in possession of the present disclosure, the deferral of parity updates is accompanied by some risk of primary data loss, and that risk grows the longer the update of the parity data is deferred. As such, a RAID storage system administrator may define any of a variety of parity update requirements that may be met to trigger an update of parity data. In some embodiments, the parity update requirement may be associated with a time period after which the parity data 502 must be updated. For example, the RAID storage controller device 204 may begin a timer after sending the command 604 that causes the RAID primary data storage device 206b to generate and store the interim parity data 612, and the parity update requirement may be met when that timer indicates that the defined time period has passed. In other embodiments, the parity update requirement may be associated with a number of times interim parity data is updated in the RAID primary data storage device 206b, after which the parity data 502 must be updated. For example, the RAID storage controller device 204 may track the generation and storage of interim parity data by the RAID primary data storage device 206b, and the parity update requirement may be met when that interim parity data has been updated the defined number of times. However, while a few examples have been described, one of skill in the art in possession of the present disclosure will recognize that any of a variety of parity update requirements, or combinations of parity update requirements, may be utilized at decision block 410 while remaining within the scope of the present disclosure as well.
If, at decision block 410, the RAID storage controller device 204 determines that the parity update requirement has not been met, the method 400 returns to block 402 to repeat substantially as described above. For the purposes of the example provided below, that second iteration of blocks 402-410 of the method 400 is described below, but one of skill in the art in possession of the present disclosure will recognize that any number of iterations of blocks 402-410 of the method 400 may be performed before the parity update requirement is met.
As illustrated in
In some embodiments, the command 804 may be a multi-operation command like those described in U.S. patent application Ser. No. 16/585,296, filed on Sep. 27, 2019. For example, the command 804 may be an NVMe WRITE WITH XOR multi-operation command that is configured to cause the RAID primary data storage device 206b to perform the multiple operations described below. However, while described as providing a multi-operation command at the second iteration of block 402, one of skill in the art in possession of the present disclosure will recognize that the multiple operations performed by the RAID primary data storage device 206b discussed below may be performed in response to respective commands transmitted by the RAID storage controller device 204 while remaining within the scope of the present disclosure as well. In a specific example, the transmission of the command 804 may include the RAID storage controller device 204 providing the command 804 in a submission queue that is included in the communication system 310 in the RAID primary data storage device 206b/300, and then ringing a doorbell for the RAID primary data storage device 206b/300. However, one of skill in the art in possession of the present disclosure will recognize that the command 804 may be provided to the RAID primary data storage device 206b in a variety of manners that will fall within the scope of the present disclosure as well.
As such, in some examples the RAID storage engine 304 in the RAID primary data storage device 206b/300 may respond to the ringing of its doorbell by accessing the command 804 in the submission queue in its communication system 310. In embodiments in which the command 804 is a multi-operation command, the RAID storage engine 304 in the RAID primary data storage device 206b/300 may identify the multiple operations instructed by that command 804 (as described in U.S. patent application Ser. No. 16/585,296, filed on Sep. 27, 2019.) However, while a single RAID primary data storage device is illustrated and described below as receiving the command 804 that causes it to update its primary data 600, one of skill in the art in possession of the present disclosure will recognize how multiple RAID primary storage devices may receive similar commands at the second iteration of block 402 while remaining within the scope of the present disclosure as well.
The method 400 then proceeds to the second iteration of block 404 where the RAID primary data storage device retrieves primary data from a host system. With reference to
The method 400 then proceeds to the second iteration of block 406 where the RAID primary data storage device performs XOR operations on primary data and current interim parity data to produce new interim parity data, and writes the new interim parity data to its buffer subsystem. With reference to
As will be appreciated by one of skill in the art in possession of the present disclosure, the calculation of updated interim parity requires the current primary data (e.g., the primary data 600 in this example), the new primary data (e.g., the primary data 800 in this example), and the current interim parity data (e.g., the interim parity data 612 in this example). As such, a third iteration of the method 400 would utilize the primary data 800 (e.g., which overwrites the primary data 600 as discussed below), the interim parity data 812, and the new primary data retrieved from the host system 202 in that third iteration of the method 400. As such, in some embodiments, following the determination and storage of the new interim parity data in subsequent iterations of the method 400 (e.g., the interim parity data 812 in this example), the current interim parity data (e.g., the interim parity data 612 in this example) may be discarded from the second buffer subsystem in the RAID primary data storage device.
With reference to
With reference to
The method 400 may then proceed to the second iteration of optional block 408 where the RAID storage controller device may provide a journal entry in the host system to indicate an inconsistent parity stripe. Similarly as discussed above, the updating of the primary data on the RAID primary data storage device 206b (e.g., overwriting the primary data 600 with the primary data 800 in the storage subsystem 306 on the RAID primary data storage device 206b as discussed above) without the updating of the parity data 502 on the storage subsystem 306 in the RAID parity data storage device 206d continues to result in an “inconsistent parity stripe” for the data stripe that includes primary data 500a, 800, and up to 500c, as the parity data 502 was generated from the primary data 500a, 500b, and up to 500c, and cannot be used to rebuild any of that primary data 500a, 800, and up to 500c in the event it becomes unavailable.
However, as discussed below, the determination and storage of the interim parity data 812 allows for the updating of the parity data 502 stored in the storage subsystem 306 in the RAID parity data storage device 206d to be deferred, and the journal data 702 provided in the storage subsystem 202a of the host system 202 allows for data recovery from a failure (e.g., a power loss for the RAID storage system 200) that occurs prior to the updating of the parity data 502 stored in the storage subsystem 306 in the RAID parity data storage device 206d.
As discussed above, the deferred parity data updates of the present disclosure may be particularly beneficial in situations where an application (e.g., running on the host system 202) repeatedly writes and/or updates data in the same storage location (e.g., the same location in the storage subsystem 306 in the RAID primary data storage device 206b, i.e., the same NAND flash memory device location(s)), and the example illustrated for the second iteration of the method 400 in
If, at decision block 410, it is determined that the parity update requirement has been met, the method 400 then proceeds to block 412 where the RAID parity data storage device receives a command from the RAID storage controller device. In an embodiment, at block 412, the RAID storage controller device 204 may generate and transmit a command to a RAID parity data storage device. For example, and as discussed above, the RAID storage controller device 204 may determine that the parity update requirement has been met as discussed above and, in response, at block 412 the RAID storage controller device 204 may generate a command 900 and transmit the command 900 to the RAID parity data storage device 206d.
Similarly as discussed above, the command 900 may be a multi-operation command like those described in U.S. patent application Ser. No. 16/585,296, filed on Sep. 27, 2019. For example, the command 900 may be a three-input NVMe WRITE WITH XOR multi-operation command that is configured to cause the RAID parity data storage device 206d to perform the multiple operations described below. However, while described as providing a multi-operation command at block 412, one of skill in the art in possession of the present disclosure will recognize that the multiple operations performed by the RAID parity data storage device 206d discussed below may be performed in response to respective commands transmitted by the RAID storage controller device 204 while remaining within the scope of the present disclosure as well. In a specific example, the transmission of the command 900 may include the RAID storage controller device 204 providing the command 900 in a submission queue that is included in the communication system 310 in the RAID parity data storage device 206d/300, and then ringing a doorbell for the RAID parity data storage device 206d/300. However, one of skill in the art in possession of the present disclosure will recognize that the command 900 may be provided to the RAID parity data storage device 206d in a variety of manners that will fall within the scope of the present disclosure as well.
As such, in some examples the RAID storage engine 304 in the RAID parity data storage device 206d/300 may respond to the ringing of its doorbell by accessing the command 900 in the submission queue in its communication system 310. In embodiments in which the command 900 is a multi-operation command, the RAID storage engine 304 in the RAID parity data storage device 206d/300 may identify the multiple operations instructed by that command 900 (as described in U.S. patent application Ser. No. 16/585,296, filed on Sep. 27, 2019.)
The method 400 then proceeds to block 414 where the RAID parity data storage device writes interim parity data from the RAID primary data storage device to its buffer subsystem. With reference to
The method 400 then proceeds to block 416 where the RAID parity data storage device performs an XOR operation on current parity data and interim parity data to produce updated parity data, and overwrites the current parity data with the updated parity data. With reference to
With reference to
The method 400 then proceeds to block 418 were the RAID storage controller device removes the journal entry in the host system that indicates the inconsistent parity stripe. With reference to
Thus, systems and methods have been described that provide for the performance of deferred parity data update operations to backup data in a RAID storage system with the assistance of the RAID storage devices that store that data. For example, a RAID primary data storage device may perform an XOR operation on current primary data in its first storage subsystem and new primary data to produce interim parity data, write the interim parity data to its first buffer subsystem, and send a completion message to the RAID storage controller device. In response to receiving the completion message, the RAID storage controller device may provide a journal entry in the host system that indicates an inconsistent parity stripe, while the RAID primary data storage device overwrites the current primary data with the new primary data in its first storage subsystem such that the new primary data becomes current primary data, with the interim parity data becoming current interim parity data.
Subsequently, as long as a parity update requirement is not met, the RAID primary data storage device may retrieve new primary data from the host system via a DMA operation, perform an XOR operation on the current primary data in its first storage subsystem, the current interim parity data in its first buffer subsystem, and the new primary data to produce updated interim parity data, write the updated interim parity data to its first buffer subsystem, overwrite the current primary data with the new primary data in its first storage subsystem (with the new primary data becoming current primary data), and send a completion message to the RAID storage controller device. In many cases, the overwriting of the current primary data with the new primary data in its first storage subsystem is to the same memory location such that the RAID storage controller device need not provide or update any journal entry in the host system that indicates an inconsistent parity stripe. However, if the writing of the new primary data in its first storage subsystem is to any different memory location, the RAID storage controller device may provide or update journal entry(ies) in the host system that indicate an inconsistent parity stripe.
Once the parity update requirement is met, the RAID parity data storage device may then retrieve the current interim parity data via a DMA operation from the first buffer subsystem in the RAID primary data storage device, perform an XOR operation on current parity data in its second storage subsystem and the current interim parity data to produce updated parity data, overwrite the current parity data with the updated parity data in the second storage subsystem, and send a completion message to the RAID storage controller device. In response to receiving the completion message, the RAID storage controller device may remove the journal entry in the host system that indicates the inconsistent parity stripe. As such, deferred parity update operations are offloaded from the RAID storage controller device, thus increasing the ability of the RAID storage controller device to scale with high performance RAID storage devices.
Although illustrative embodiments have been shown and described, a wide range of modification, change and substitution is contemplated in the foregoing disclosure and in some instances, some features of the embodiments may be employed without a corresponding use of other features. Accordingly, it is appropriate that the appended claims be construed broadly and in a manner consistent with the scope of the embodiments disclosed herein.
Number | Name | Date | Kind |
---|---|---|---|
5720025 | Wilkes et al. | Feb 1998 | A |
5774641 | Islam | Jun 1998 | A |
6526477 | Yuan | Feb 2003 | B1 |
9384093 | Aiello | Jul 2016 | B1 |
20090144497 | Withers | Jun 2009 | A1 |
20100106906 | Galloway | Apr 2010 | A1 |
20100312961 | Koul | Dec 2010 | A1 |
20110264857 | Delaney | Oct 2011 | A1 |
20140189212 | Slaight | Jul 2014 | A1 |
20150286438 | Simionescu | Oct 2015 | A1 |
20160246678 | Galbraith | Aug 2016 | A1 |
20170168896 | Karrotu | Jun 2017 | A1 |
20180203765 | Critchley | Jul 2018 | A1 |
Number | Date | Country | |
---|---|---|---|
20210096950 A1 | Apr 2021 | US |