Servicing a globally broadcast interrupt signal in a multi-threaded computer
US-9223729-B2 · Dec 29, 2015 · US
US2020409800A1 · US · A1
| Field | Value |
|---|---|
| Publication number | US-2020409800-A1 |
| Application number | US-201916454666-A |
| Country | US |
| Kind code | A1 |
| Filing date | Jun 27, 2019 |
| Priority date | Jun 27, 2019 |
| Publication date | Dec 31, 2020 |
| Grant date | — |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
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.
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.
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
using interrupt (G06F13/32 takes precedence) · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.