Control plane method and apparatus for providing erasure code protection across multiple storage devices

US11042442B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11042442-B2
Application numberUS-201916289257-A
CountryUS
Kind codeB2
Filing dateFeb 28, 2019
Priority dateJan 20, 2017
Publication dateJun 22, 2021
Grant dateJun 22, 2021

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.

A system and method for providing erasure code protection across multiple storage devices. A data switch in a storage system connects a plurality of storage devices to a remote host. Each storage device is also connected to a controller, e.g., a baseboard management controller. During normal operation, read and write commands from the remote host are sent to respective storage devices through the data switch. When a write command is executed, the storage device executing the command sends a copy of the data to the controller, which generates and stores erasure codes, e.g., on a storage device that is dedicated to the storage of erasure codes, and invisible to the remote host. When a device fails or is removed, the controller reconfigures the data switch to redirect all traffic addressed to the failed or absent storage device to the controller, and the controller responds to host commands in its stead.

First claim

Opening claim text (preview).

What is claimed is: 1. A system comprising: a plurality of storage devices, comprising first storage devices and second storage devices different from the first storage devices, and configured to store erasure codes sufficient to recover data stored on the first storage devices from data on the second storage devices; a switch, configured during a first mode of operation to route storage commands received through a storage interface associated with the plurality of storage devices to respective storage devices from the plurality of storage devices, based at least in part on addresses associated with the storage commands; and a controller, the controller being configured to, in response to satisfying a first condition, perform operations comprising: reconfiguring the switch to route storage commands of a first type to the controller; and sending, in response to receiving the storage commands of the first type, a command response, through at least one of the switch or the storage interface. 2. The system of claim 1 , wherein: the first condition is satisfied based, at least in part on, a storage device of the first storage devices failing or being absent, and storage commands of the first type are storage commands associated with an address of the storage device that has failed or become absent. 3. The system of claim 2 , wherein: storage commands of a second type are storage commands associated with addresses of storage devices other than the storage device that has failed or become absent; and during the first mode of operation, and after reconfiguring of the switch by the controller in response to satisfying the first condition, the switch is configured to send a command response, generated in response to a storage command of the second type by a storage device other than the storage device that has failed or become absent, through the storage interface. 4. The system of claim 1 , wherein: one of the first storage devices is configured, during the first mode of operation, upon receipt of a write command including a data block, to store the data block and to send a copy of the data block to the controller; and the controller is configured, upon receipt of a copy of a data block from a first storage device of the plurality of storage devices, to generate erasure codes sufficient to recover the data block, and to store the erasure codes on one or more of the second storage devices. 5. The system of claim 1 , wherein one of the first storage devices is configured, during the first mode of operation, upon receipt of a write command including a data block: to store the data block; to generate erasure codes sufficient to recover the data block; and to store the erasure codes on one or more of the second storage devices. 6. The system of claim 1 , wherein: one of the second storage devices is configured to store erasure codes; and the switch is configured, during the first mode of operation, to route a storage command received through the storage interface to a respective storage device of a subset of the plurality of storage devices, according to a respective address in the storage command, the one of the second storage devices not being a member of the subset. 7. The system of claim 1 , wherein the controller is configured, in the event of failure or absence of any one of the plurality of storage devices, in response to a received read command requesting a data block: to read erasure codes from the present and correctly operating storage devices of the plurality of storage devices; to recover the data block; and to send the recovered data block through the switch and through the storage interface as part of a command response. 8. The system of claim 1 , wherein: one of the storage devices comprises a connector having a presence pin, the presence pin being connected to a respective sensing pin of the controller; and the controller is configured to detect removal of the storage device by a change in a voltage or current at the respective sensing pin. 9. The system of claim 1 , wherein the switch is an Ethernet switch. 10. The system of claim 1 , further comprising a PCIe switch, wherein one of the plurality of storage devices is connected to the controller through the PCIe switch. 11. The system of claim 1 , wherein: the switch has a PCIe control port, connected to a port of the controller, and the switch is configured to receive configuration commands from the controller through the PCIe control port; and the controller is a baseboard management controller. 12. A method of operating a storage system comprising a plurality of storage devices, a switch, and a controller, the method comprising: during a first mode of operation, routing storage commands received through a storage interface associated with the plurality of storage devices to respective storage devices from the plurality of storage devices, based at least in part on addresses associated with the storage commands; and in response to satisfying a first condition, performing operations comprising: reconfiguring the switch to route storage commands of a first type to the controller; and sending, in response to receiving the storage commands of the first type, a command response, through at least one of the switch and the storage interface. 13. The method of claim 12 , wherein: the first condition is satisfied based, at least in part on a storage device of the plurality of storage devices failing or being absent, and storage commands of the first type are storage commands associated with an address of the storage device that has failed or become absent. 14. The method of claim 13 , wherein: storage commands of a second type are storage commands associated with addresses of storage devices other than the storage device that has failed or become absent; and during the first mode of operation, and after reconfiguring of the switch by the controller in response to satisfying the first condition, the switch is configured to send a command response, generated in response to a storage command of the second type by a storage device other than the storage device that has failed or become absent, through the storage interface. 15. The method of claim 12 , further comprising, during the first mode of operation, upon receipt, by a storage device of the plurality of storage devices, of a write command including a data block: storing, by the storage device, the data block; and sending, by the storage device, a copy of the data block to the controller. 16. The method of claim 15 , further comprising, upon receipt, by the controller, of a copy of a data block from a first storage device of the plurality of storage devices: generating, by the controller, erasure codes sufficient to recover the data block; and storing, by the controller, the erasure codes on one or more storage devices other than the first storage device, from among the plurality of storage devices. 17. The method of claim 12 , further comprising, during the first mode of operation, upon receipt by a first storage device, of the plurality of storage devices, of a write command including a data block: storing, by the first storage device, the data block; generating, by the first storage device, erasure codes sufficient to recover the data block; and storing, by the first storage device, the erasure codes on one or more storage devices other than the first storage device, from among the plurality of storage devices. 18. The method of claim 12 , wherein: a first storage device of the plurality o

Assignees

Inventors

Classifications

  • PCI express · CPC title

  • Parity data used in redundant arrays of independent storages, e.g. in RAID systems · CPC title

  • Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS] · CPC title

  • by changing the state or mode of one or more devices · CPC title

  • G06F3/062Primary

    Securing storage systems · 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 US11042442B2 cover?
A system and method for providing erasure code protection across multiple storage devices. A data switch in a storage system connects a plurality of storage devices to a remote host. Each storage device is also connected to a controller, e.g., a baseboard management controller. During normal operation, read and write commands from the remote host are sent to respective storage devices through t…
Who is the assignee on this patent?
Samsung Electronics Co Ltd
What technology area does this patent fall under?
Primary CPC classification G06F11/1076. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jun 22 2021 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 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).