Cache oblivious algorithm for butterfly code

US10164655B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10164655-B2
Application numberUS-201514865411-A
CountryUS
Kind codeB2
Filing dateSep 25, 2015
Priority dateSep 25, 2015
Publication dateDec 25, 2018
Grant dateDec 25, 2018

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.

Techniques for generating parities and repairing data erasures using a cache oblivious encoding algorithm are disclosed. The system includes an encoding module which receives a request to recreate data for a subset of a plurality of content stores from a storage manager. The encoding module generates a new first parity and a new second parity using the remaining content in the plurality of content stores. The encoding module generates a first portion of the requested data using the new first parity and a first parity for the plurality of content stores and a second portion of the requested data using the new second parity and a second parity for the plurality of content stores. The encoding module may recreate the data for the plurality of content stores using the first portion of the requested data and the second portion of the requested data.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer-implemented method comprising: retrieving a first subset of content from memory; generating a first combination of data elements from the first subset of content using a combinatorial circuit coupled with a cache memory; updating a first parity for the content with the first combination of data elements from the first subset of content; storing the first combination of data elements in the cache memory; generating an orthogonal permutation based on the first subset of content by: retrieving the first combination of data elements from the cache memory; and processing the first combination of data elements with a first correcting factor using the combinatorial circuit; updating a second parity for the content using the orthogonal permutation; retrieving a second subset of content from memory; generating a second combination of data elements from the second subset of content using the combinatorial circuit; updating the first parity for the content with the second combination of data elements from the second subset of content; storing the second combination of data elements in the cache memory; generating an inverse orthogonal permutation based on the second subset of content by: retrieving the second combination of data elements from the cache memory; and processing the second combination of data elements with a second correcting factor using the combinatorial circuit; and updating the second parity for the content using the inverse orthogonal permutation. 2. The computer-implemented method of claim 1 , wherein the first correcting factor and the second correcting factor are based on the first parity. 3. The computer-implemented method of claim 1 further comprising: determining that a code word is complete, wherein the content from memory includes the code word; writing the first parity to a first content store; and writing the second parity to a second content store. 4. The computer-implemented method of claim 1 further comprising receiving a request to recreate data for a content store of a plurality of content stores, wherein the plurality of content stores include the content from memory that is represented in the first parity and the second parity. 5. The computer-implemented method of claim 4 further comprising: in response to receiving the request to recreate data for the content store, comparing a new first parity for a subset of remaining content in the plurality of content stores and a new second parity for the subset of remaining content in the plurality of content stores with the first parity and the second parity, respectively; and recreating the data for the content store based on the comparison. 6. The computer-implemented method of claim 5 , wherein the comparison is an “exclusive or” (XOR) operation on the new first parity and the first parity and an XOR operation on the new second parity and the second parity. 7. The computer-implemented method of claim 1 further comprising generating the inverse orthogonal permutation in a recursive pattern, wherein the recursive pattern is based on a size of the content. 8. A system comprising: one or more processors; and a memory storing instructions that, when executed, cause the one or more processors to: retrieve a first subset of content; generate a first combination of data elements from the first subset of content using a combinatorial circuit coupled with a cache memory; update a first parity for the content with the first combination of data elements from the first subset of content; store the first combination of data elements in the cache memory; generate an orthogonal permutation based on the first subset of content by: retrieving the first combination of data elements from the cache memory; and processing the first combination of data elements with a first correcting factor using the combinatorial circuit update a second parity for the content using the orthogonal permutation; retrieve a second subset of content; generate a second combination of data elements from the second subset of content using the combinatorial circuit; update the first parity for the content with the second combination of data elements from the second subset of content; store the second combination of data elements in the cache memory; generate an inverse orthogonal permutation based on the second subset of content by: retrieving the second combination of data elements from the cache memory; and processing the second combination of data elements with a second correcting factor using the combinatorial circuit; and update the second parity for the content using the inverse orthogonal permutation. 9. A computer program product comprising a non-transitory computer useable medium including a computer readable program, wherein the computer readable program when executed on a computer causes the computer to: retrieve a first subset of content from memory; generate a first combination of data elements from the first subset of content using a combinatorial circuit coupled with a cache memory; update a first parity for the content with the first combination of data elements from the first subset of content; store the first combination of data elements in the cache memory; generate an orthogonal permutation based on the first subset of content by: retrieving the first combination of data elements from the cache memory; and processing the first combination of data elements with a first correcting factor using the combinatorial circuit; update a second parity for the content using the orthogonal permutation; retrieve a second subset of content from memory; generate a second combination of data elements from the second subset of content using the combinatorial circuit; update the first parity for the content with the second combination of data elements from the second subset of content; store the second combination of data elements in the cache memory; generate an inverse orthogonal permutation based on the second subset of content by: retrieving the second combination of data elements from the cache memory; and processing the second combination of data elements with a second correcting factor using the combinatorial circuit; and update the second parity for the content using the inverse orthogonal permutation.

Assignees

Inventors

Classifications

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

  • H03M13/11Primary

    using multiple parity bits · CPC title

  • Linear codes · CPC title

  • Theoretical methods to calculate these checking codes · CPC title

  • using codes or arrangements adapted for a specific type of error (G06F11/1048 takes precedence) · 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 US10164655B2 cover?
Techniques for generating parities and repairing data erasures using a cache oblivious encoding algorithm are disclosed. The system includes an encoding module which receives a request to recreate data for a subset of a plurality of content stores from a storage manager. The encoding module generates a new first parity and a new second parity using the remaining content in the plurality of cont…
Who is the assignee on this patent?
HGST Netherlands BV, Western Digital Tech Inc
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 Dec 25 2018 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 1 related publication on this page (citations in our corpus or others sharing the same primary CPC).