Computer system
US-2015304423-A1 · Oct 22, 2015 · US
US9684575B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-9684575-B2 |
| Application number | US-201514747368-A |
| Country | US |
| Kind code | B2 |
| Filing date | Jun 23, 2015 |
| Priority date | Jun 23, 2014 |
| Publication date | Jun 20, 2017 |
| Grant date | Jun 20, 2017 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
Systems, methods, apparatuses, and software for data storage systems are provided herein. In one example, a data storage system is provided that includes storage drives each comprising a Peripheral Component Interconnect Express (PCIe) interface, and configured to store data and retrieve the data stored on associated storage media responsive to data transactions. The data storage system also includes processing modules each comprising one or more processors, where a first processor is configured to receive data transactions and transfer the data transactions for delivery to associated ones of the storage drives. A monitoring system is configured to identify when the first processor fails, and responsively instruct a second processor to handle further data transactions directed to storage drives associated with the first processor.
Opening claim text (preview).
What is claimed is: 1. A data storage system, comprising: a plurality of storage drives each comprising a Peripheral Component Interconnect Express (PCIe) interface, and configured to store data and retrieve the data stored on associated storage media responsive to storage operations; a plurality of processing modules each comprising one or more processors, where a first processor is configured to receive at least a portion of the storage operations and transfer the portion of the storage operations for delivery to associated ones of the plurality of storage drives over a PCIe interface; a control processor configured to initialize the plurality of storage drives for use on the PCIe interfaces by the processors on the processing modules, assign each of the plurality of storage drives an associated unique identifier using at least a sideband communication link distinct from the PCIe interfaces, wherein the sideband communication link communicatively couples the control processor and the ones of the plurality of storage drives, and report the associated unique identifiers to the processing modules over at least an associated interface; and a monitoring system configured to identify when the first processor fails, and responsively instruct a second processor to handle further storage operations directed to storage drives associated with the first processor. 2. The data storage system of claim 1 , wherein the first processor and the second processor are both included in a first processing module. 3. The data storage system of claim 1 , wherein the first processor is included in a first processing module and the second processor is included in a second processing module. 4. The data storage system of claim 1 , comprising: the control processor further configured to subdivide the plurality of storage drives among individual processors of the processing modules so that each of the individual processors manages ones of the storage operations directed to an associated subset of the plurality of storage drives. 5. The data storage system of claim 1 , comprising: the control processor further configured to subdivide a shared PCIe address space to subdivide the plurality of storage drives among individual processors of the processing modules, wherein each subdivision of the shared PCIe address space corresponds to an associated subset of the plurality of storage drives. 6. The data storage system of claim 5 , wherein the first processor is configured to handle the portion of the storage operations for a first subset of the plurality of storage drives that corresponds to a first subdivision of the shared PCIe address space; and comprising: the monitoring system configured to instruct the second processor to handle the further storage operations directed to the storage drives associated with the first processor by at least indicating to the second processor that the second processor is to handle the further storage operations for the first subset of the plurality of storage drives that corresponds to the first subdivision of the shared PCIe address space. 7. The data storage system of claim 1 , comprising: the second processor configured to maintain a failover table comprising indications of portions of a shared PCIe address space among the processing modules, wherein a first portion corresponds to a subset of the plurality of storage drives managed by the first processor and a second portion corresponds to a subset of the plurality of storage drives managed by the second processor; responsive to identifying when the first processor fails, the second processor configured to manage the first portion the shared PCIe address space instead of the first processor. 8. The data storage system of claim 1 , wherein the second processor comprises the monitoring system, and comprising: the second processor configured to periodically poll the first processor to identify when the first processor fails. 9. A method of operating a data storage system, the method comprising: in a plurality of storage drives, storing data and retrieving the data stored on associated storage media responsive to storage operations received over a Peripheral Component Interconnect Express (PCIe) interface; in a first processor among a plurality of processing modules each comprising one or more processors, receiving at least a portion of the storage operations and transferring the portion of the storage operations for delivery to associated ones of the plurality of storage drives over a PCIe interface; initializing the plurality of storage drives for use on the PCIe interfaces by the processors on the processing modules; assigning each of the plurality of storage drives an associated unique identifier using at least a sideband communication link distinct from the PCIe interfaces, the sideband communication link communicatively coupling a control processor and the ones of the plurality of storage drives; reporting the associated unique identifiers to the processing modules over at least an Ethernet interface; and responsive to identifying when the first processor fails instructing a second processor to handle further storage operations directed to storage drives associated with the first processor. 10. The method of claim 9 , wherein the first processor and the second processor are both included in a first processing module. 11. The method of claim 9 , wherein the first processor is included in a first processing module and the second processor is included in a second processing module. 12. The method of claim 9 , further comprising: subdividing the plurality of storage drives among individual processors of the processing modules so that each of the individual processors manages ones of the storage operations directed to an associated subset of the plurality of storage drives. 13. The method of claim 9 , further comprising: establishing a shared PCIe address space to subdivide the plurality of storage drives among individual processors of the processing modules, wherein each subdivision of the shared PCIe address space corresponds to an associated subset of the plurality of storage drives. 14. The method of claim 13 , wherein the first processor is configured to handle the portion of the storage operations for a first subset of the plurality of storage drives that corresponds to a first subdivision of the shared PCIe address space; and further comprising: instructing the second processor to handle the further storage operations directed to the storage drives associated with the first processor by at least indicating to the second processor that the second processor is to handle the further storage operations for the first subset of the plurality of storage drives that corresponds to the first subdivision of the shared PCIe address space. 15. The method of claim 9 , further comprising: in the second processor, maintaining a failover table comprising indications of portions of a shared PCIe address space among the processing modules, wherein a first portion corresponds to a subset of the plurality of storage drives managed by the first processor and a second portion corresponds to a subset of the plurality of storage drives managed by the second processor; in the second processor, responsive to identifying when the first processor fails, managing the first portion the shared PCIe address space instead of the first processor. 16. The method of claim 9 , wherein the second processor comprises the monitoring system, and further comprising: in the second processor periodically polling the first processor to identify when the first
with a single idle spare processing component · CPC title
where the redundant components share persistent storage (G06F11/2043 takes precedence) · CPC title
Electrical coupling · CPC title
being a memory bus · CPC title
Active fault masking without idle spares · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.