Offload processing using storage device slots

US10795612B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10795612-B2
Application numberUS-201816050868-A
CountryUS
Kind codeB2
Filing dateJul 31, 2018
Priority dateJul 31, 2018
Publication dateOct 6, 2020
Grant dateOct 6, 2020

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.

Offload processing may be provided that is not dedicated to a primary processor or a subset of primary processors. A system may have one or more offload processors, for example, GPUs, coupled to data storage slots of the system, which can be shared by multiple primary processors of the system. The offload processor(s) may be housed within a device configured to be coupled to a storage slot, for example, as if the device were a storage drive. The one or more offload processors may be housed within a device that includes an interface in conformance with a version of an NVMe specification and may have a form factor in accordance with the U.2 specification. Offload processing devices may be communicatively coupled to one or more primary processors by switching fabric disposed between the one or more primary processors and the storage slot to which the offload processing device is connected.

First claim

Opening claim text (preview).

What is claimed is: 1. A system comprising: one or more primary processors; one or more storage slots arranged to receive storage drives; a switch fabric communicatively coupling the one or more storage slots to the one or more primary processors to perform I/O operations between the one or more primary processors and one or more storage drives installed in the one or more storage slots; a processing device including one or more offload processors, the processing device disposed within the one or more storage slots, and the one or more offload processors communicatively coupled to the one or more primary processors; and a memory comprising code stored thereon that, when executed, performs a method comprising: a first primary processor of the one or more primary processors sending first data and one or more first instructions over the switch fabric to a first offload processor of the one or more offload processors, the first offload processor executing the one or more first instructions on the first data, a second primary processor of the one or more primary processors sending second data and one or more second instructions over the switch fabric to a first offload processor of the one or more offload processors, and the first offload processor executing the one or more second instructions on the second data, wherein at least one of the one or more offload processors includes a graphical processing unit. 2. The system of claim 1 , wherein the one or more primary processors includes a plurality of primary processors communicatively coupled to the one or more offload processors. 3. The system of claim 1 , wherein the processing device has a form factor in conformance with a U.2 specification. 4. The system of claim 1 , wherein the processing device has an interface that interfaces the one or more offload processors with the switch fabric in accordance with an NVMe specification. 5. The system of claim 1 , wherein the one or more first instructions define an application, and wherein the first offload processor executes the application to produce results without assistance from the first processor and communicates the results to the first processor. 6. The system of claim 1 , wherein during execution of the one or more first instructions, the first primary processor fails, and wherein the first offload processor continues executing the one or more first instructions during the failure of the first primary processor. 7. The system of claim 1 , wherein the system is a data storage system including one or more directors that include the one or more primary processors and one or more back-end adapters communicatively coupling the one or more directors to the one or more offload processors across the switch fabric. 8. For a system comprising a plurality of primary processors, an offload processor physically coupled to the system by a non-volatile storage slot of the system, and a switch fabric communicatively coupling the non-volatile storage slot to each of the plurality of primary processors, a method comprising: a first processor of the plurality of primary processors sending first data and one or more first instructions over the switch fabric to the offload processor; the offload processor executing the one or more first instructions on the first data; a second processor of the plurality of primary processors sending second data and one or more second instructions over the switch fabric to the offload processor; and the offload processor executing the one or more second instructions on the second data, wherein the offload processor includes a graphical processing unit. 9. The method of claim 8 , wherein the one or more first instructions define an application, and wherein the first offload processor executes the application to produce results without assistance from the first primary processor and communicates the results to the first primary processor. 10. The method of claim 8 , wherein during execution of the one or more first instructions, the first processor fails, and wherein the offload processor continues executing the one or more first instructions during the failure of the first processor. 11. A device for performing offload processing comprising: one or more graphical processing units; a connection interface that couples the device to a switching fabric; a form factor that couples the device to a storage slot of another device; and an offload processor that: receives first data and one or more first instructions over the switch fabric from a first primary processor of the one or more primary processors, executes the one or more first instructions on the first data, receives second data and one or more second instructions over the switch fabric from a second primary processor of the one or more primary processors, and executing the one or more second instructions on the second data. 12. The device of claim 11 , wherein the connection interface couples the device to a switching device as if the device were a storage drive. 13. The device of claim 12 , wherein the connection interface couples the device to a switching fabric in conformance with an NVMe specification. 14. The device of claim 11 , wherein the form factor couples the device to a storage slot of another device as if the device were a storage drive. 15. The device of claim 14 , wherein the form factor couples the device to a storage slot of another device in conformance with a U.2 specification.

Assignees

Inventors

Classifications

  • G06F3/0683Primary

    Plurality of storage devices · CPC title

  • Load balancing · CPC title

  • by changing the path, e.g. traffic rerouting, path reconfiguration · CPC title

  • G06F3/0659Primary

    Command handling arrangements, e.g. command buffers, queues, command scheduling · CPC title

  • Improving I/O performance · 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 US10795612B2 cover?
Offload processing may be provided that is not dedicated to a primary processor or a subset of primary processors. A system may have one or more offload processors, for example, GPUs, coupled to data storage slots of the system, which can be shared by multiple primary processors of the system. The offload processor(s) may be housed within a device configured to be coupled to a storage slot, for…
Who is the assignee on this patent?
Emc Ip Holding Co Llc
What technology area does this patent fall under?
Primary CPC classification G06F3/0683. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Oct 06 2020 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 2 related publications on this page (citations in our corpus or others sharing the same primary CPC).