Stream level uninterrupted restore operation using an interrupt service routine approach

US2020409800A1 · US · A1

Patent metadata
FieldValue
Publication numberUS-2020409800-A1
Application numberUS-201916454666-A
CountryUS
Kind codeA1
Filing dateJun 27, 2019
Priority dateJun 27, 2019
Publication dateDec 31, 2020
Grant date

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.

Embodiments are described for performing an uninterrupted restore in a storage system in view of one or more abort events. A restore agent receives writes one or more data blocks to a conditional construction container. A parent interrupt service routine (ISR) polls for abort events. In response to an abort event, an intermediate interrupt is generated that spawns a child processes for each process of the restore. The intermediate ISR logs each child ISR, the process it is responsible for, and the intermediate interrupt, for later restoration of the restore state. After a recovery of the above event, then each child ISR can be called to restore its state. After restoring the state, the restore agent resumes the restore from where the abort event was detected. The child ISRs are re-entrant. If another abort event is detected, the restore state can again be saved and later resumed from that state.

First claim

Opening claim text (preview).

What is claimed is: 1 . A method of performing uninterrupted restores in view of one or more unexpected abort events, the method comprising: in response to a restore agent receiving one or more data packets to be restored from a backup data storage to a target storage, invoking a parent interrupted service routine (ISR) that polls for an unexpected abort event; writing the received data packets to a conditional construction container (CCC) communicatively coupled to the target storage; in response to receiving the unexpected abort event, ( 500 ) saving a state of a plurality of restore processes; restoring the saved state at a future time, and completing the restore of data from the backup data storage to the target storage. 2 . The method of claim 1 , further comprising: masking the parent ISR; and stopping the writes of received data packets to the CCC. 3 . The method of claim 1 , wherein saving state of the plurality of restore processes comprises: generating a re-entrant child ISR for each restore process in the plurality of restore processes; and calling each child ISR to hold the current state of the restore process associated with the child ISR. 4 . The method of claim 3 , further comprising: calling an intermediate ISR that, for each child ISR, logs the current state of the restore process in the plurality of restore process, in association with the intermediate interrupt. 5 . The method of claim 4 , further comprising: querying the intermediate ISR to fetch details of the current state of the plurality of restore processes; calling each child ISR to enforce the fetched current state of a restore process in the plurality of restore processes associated with the child ISR; 6 . The method of claim 5 , further comprising: notifying the restore agent that the child ISRs have each enforced the current state of the restore process associated with the child ISRs; and instructing the restore agent to resume receiving data packets and writing data packets to the CCC. 7 . The method of claim 4 , further comprising: receiving a second unexpected abort event; and calling each re-entrant child ISR a second time to save a state for each restore process of a second plurality of restore processes. 8 . A non-transitory computer-readable medium programmed with executable instructions that, when executed by a processing system having at least one hardware processor, perform operations of performing an uninterrupted restore in view of one or more unexpected abort events, the operations comprising: in response to a restore agent receiving one or more data packets to be restored from a backup data storage to a target storage, invoking a parent interrupted service routine (ISR) that polls for an unexpected abort event; writing the received data packets to a conditional construction container (CCC) communicatively coupled to the target storage; in response to receiving the unexpected abort event, ( 500 ) saving a state of a plurality of restore processes; restoring the saved state at a future time, and completing the restore of data from the backup data storage to the target storage. 9 . The medium of claim 8 , the operations further comprising: masking the parent ISR; and stopping the writes of received data packets to the CCC. 10 . The medium of claim 8 , wherein saving state of the plurality of restore processes comprises: generating a re-entrant child ISR for each restore process in the plurality of restore processes; and calling each child ISR to hold the current state of the restore process associated with the child ISR. 11 . The medium of claim 10 , the operations further comprising: calling an intermediate ISR that, for each child ISR, logs the current state of the restore process in the plurality of restore process, in association with the intermediate interrupt. 12 . The medium of claim 11 , the operations further comprising: querying the intermediate ISR to fetch details of the current state of the plurality of restore processes; calling each child ISR to enforce the fetched current state of a restore process in the plurality of restore processes associated with the child ISR; 13 . The medium of claim 12 , the operations further comprising: notifying the restore agent that the child ISRs have each enforced the current state of the restore process associated with the child ISRs; and instructing the restore agent to resume receiving data packets and writing data packets to the CCC. 14 . The medium of claim 11 , the operations further comprising: receiving a second unexpected abort event; and calling each re-entrant child ISR a second time to save a state for each restore process of a second plurality of restore processes. 15 . A system comprising: a processing system having at least one hardware processor, the processing system coupled to a memory programmed with executable instructions that, when executed by the processing system, perform operations of performing an uninterrupted restore operation, the operations comprising: in response to a restore agent receiving one or more data packets to be restored from a backup data storage to a target storage, invoking a parent interrupted service routine (ISR) that polls for an unexpected abort event; writing the received data packets to a conditional construction container (CCC) communicatively coupled to the target storage; in response to receiving the unexpected abort event, ( 500 ) saving a state of a plurality of restore processes; restoring the saved state at a future time, and completing the restore of data from the backup data storage to the target storage. 16 . The system of claim 15 , the operations further comprising: masking the parent ISR; and stopping the writes of received data packets to the CCC. 17 . The system of claim 15 , wherein saving state of the plurality of restore processes comprises: generating a re-entrant child ISR for each restore process in the plurality of restore processes; and calling each child ISR to hold the current state of the restore process associated with the child ISR. 18 . The system of claim 17 , the operations further comprising: calling an intermediate ISR that, for each child ISR, logs the current state of the restore process in the plurality of restore process, in association with the intermediate interrupt. 19 . The system of claim 18 , the operations further comprising: querying the intermediate ISR to fetch details of the current state of the plurality of restore processes; calling each child ISR to enforce the fetched current state of a restore process in the plurality of restore processes associated with the child ISR; 20 . The system of claim 19 , the operations further comprising: notifying the restore agent that the child ISRs have each enforced the current state of the restore process associated with the child ISRs; and instructing the restore agent to resume receiving data packets and writing data packets to the CCC. 21 . The system of claim 18 , further comprising: receiving a second unexpected abort event; and calling each re-entrant child ISR a second time to save a state for each restore process of a second plurality of restore processes.

Assignees

Inventors

Classifications

  • by interrupt, e.g. masked · CPC title

  • Saving or restoring of program or task context · CPC title

  • in a storage system, e.g. in a DASD or network based storage system (drivers for digital recording or reproducing units G06F3/06; circuits for error detection or correction within digital recording or reproducing units G11B20/18; for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS], H04L67/1097) · CPC title

  • Restarting or rejuvenating · CPC title

  • G06F13/24Primary

    using interrupt (G06F13/32 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 US2020409800A1 cover?
Embodiments are described for performing an uninterrupted restore in a storage system in view of one or more abort events. A restore agent receives writes one or more data blocks to a conditional construction container. A parent interrupt service routine (ISR) polls for abort events. In response to an abort event, an intermediate interrupt is generated that spawns a child processes for each pro…
Who is the assignee on this patent?
Emc Ip Holding Co Llc
What technology area does this patent fall under?
Primary CPC classification G06F13/24. Mapped technology areas include Physics.
When was this patent published?
Publication date Thu Dec 31 2020 00:00:00 GMT+0000 (Coordinated Universal Time) (A1). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).