Failover handling in modular switched fabric for data storage systems

US9684575B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9684575-B2
Application numberUS-201514747368-A
CountryUS
Kind codeB2
Filing dateJun 23, 2015
Priority dateJun 23, 2014
Publication dateJun 20, 2017
Grant dateJun 20, 2017

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

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.

First claim

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

Assignees

Inventors

Classifications

  • 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

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9684575B2 cover?
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 in…
Who is the assignee on this patent?
Liqid Inc
What technology area does this patent fall under?
Primary CPC classification G06F11/2053. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jun 20 2017 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 3 related publications on this page (citations in our corpus or others sharing the same primary CPC).