Replacing an accelerator firmware image without operating system reboot

US9710254B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9710254-B2
Application numberUS-201514925768-A
CountryUS
Kind codeB2
Filing dateOct 28, 2015
Priority dateOct 28, 2015
Publication dateJul 18, 2017
Grant dateJul 18, 2017

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.

The present disclosure relates to updating a firmware image on a coherent hardware accelerator concurrently with executing operations on the coherent hardware accelerator. According to one embodiment, while executing accelerator-enabled operations on the coherent hardware accelerator, a system stores a firmware update package in a local memory on the coherent hardware accelerator. Once the firmware update package is stored in local memory on the coherent hardware accelerator, the system restarting the coherent hardware accelerator by pausing the execution of at least a first operation initiated on the coherent hardware accelerator and applying the firmware update package to the firmware image on the coherent hardware accelerator. Once the firmware update package is applied to the coherent hardware accelerator, the system resumes the operation on the coherent hardware accelerator.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer program product comprising: a computer-readable storage medium having computer-readable program code embodied therewith, the computer-readable program code configured to perform a function to update a firmware image on a coherent hardware accelerator concurrently with executing operations on the coherent hardware accelerator, the function comprising: while executing a set of operations on the coherent hardware accelerator, storing a firmware update package in a local memory on the coherent hardware accelerator; restarting the coherent hardware accelerator by: pausing the execution of at least a first operation initiated on the coherent hardware accelerator; and applying the firmware update package to the firmware image on the coherent hardware accelerator; and while resuming the paused operation on the coherent hardware accelerator, querying a configuration of the updated coherent hardware accelerator and making the configuration available to an operating system for discovery and use in one or more subsequent operations. 2. The computer program product of claim 1 , wherein pausing the first operation executing on the coherent hardware accelerator comprises saving at least one of: one or more interrupt source numbers identifying the paused operation; a range of memory mapped input/output (I/O) (MMIO) addresses associated with the paused operation; a program counter associated with an instruction most recently executed by the paused operation; or a most recently executed I/O command associated with the paused operation. 3. The computer program product of claim 2 , wherein resuming the paused operations comprises restoring at least one of the one or more interrupt source numbers, the range of MMIO addresses associated with the paused operation, the program counter associated with an instruction most recently executed by the operation, or the most recently executed I/O command associated with the operation. 4. The computer program product of claim 1 , wherein the function further comprises: after pausing the first operation executing on the coherent hardware accelerator, resuming the paused operation using a software algorithm executing on a processor other than the hardware accelerator. 5. The computer program product of claim 1 , wherein the set of operations executing on the coherent hardware accelerator is paused in response to at least one of: detecting a timeout condition when the set of operations attempts to transmit a command to the coherent hardware accelerator; or detecting a reserved value when the set of operations queries the coherent hardware accelerator for a state of the coherent hardware accelerator. 6. The computer program product of claim 1 , wherein the first operation is included in the set, wherein the set of operations comprises a set of accelerator-enabled operations, wherein pausing the first operation executing on the coherent hardware accelerator comprises saving at least one of: one or more interrupt source numbers identifying the paused operation; a range of memory mapped input/output (I/O) (MMIO) addresses associated with the paused operation; a program counter associated with an instruction most recently executed by the paused operation; or a most recently executed I/O command associated with the paused operation. 7. The computer program product of claim 6 , wherein pausing the first operation executing on the coherent hardware accelerator comprises saving, in respective instances, each of: the one or more interrupt source numbers identifying the paused operation; the range of memory mapped input/output (I/O) (MMIO) addresses associated with the paused operation; the program counter associated with the instruction most recently executed by the paused operation; and the most recently executed I/O command associated with the paused operation. 8. The computer program product of claim 7 , wherein resuming the paused operation comprises restoring: at least one of the one or more interrupt source numbers, the range of MMIO addresses associated with the paused operation, the program counter associated with an instruction most recently executed by the operation, or the most recently executed I/O command associated with the operation. 9. The computer program product of claim 8 , wherein resuming the paused operation comprises restoring: at least one of the one or more interrupt source numbers, the range of MMIO addresses associated with the paused operation, the program counter associated with an instruction most recently executed by the operation, and the most recently executed I/O command associated with the operation. 10. The computer program product of claim 9 , wherein the function further comprises: after pausing the operation executing on the coherent hardware accelerator, resuming the paused operation using a software algorithm executing on a processor other than the hardware accelerator. 11. The computer program product of claim 10 , wherein the set of operations executing on the coherent hardware accelerator is paused in response to at least one of: detecting a timeout condition when the set of operations attempts to transmit a command to the coherent hardware accelerator; or detecting a reserved value when the set of operations queries the coherent hardware accelerator for a state of the coherent hardware accelerator. 12. The computer program product of claim 11 , wherein the set of operations executing on the coherent hardware accelerator is paused in response to, in respective instances, each of: detecting the timeout condition when the set of operations attempts to transmit the command to the coherent hardware accelerator; and detecting the reserved value when the set of operations queries the coherent hardware accelerator for the state of the coherent hardware accelerator. 13. The computer program product of claim 12 , wherein the software algorithm executes on one or more computer processors executing the computer-readable program code, wherein the set of operations includes the one or more subsequent operations. 14. The computer program product of claim 1 , wherein the set of operations comprises a set of accelerator-enabled operations. 15. A system comprising: a processor; and a memory storing one or more instructions which, when executed by the processor, performs a function to update a firmware image on a coherent hardware accelerator concurrently with executing operations on the coherent hardware accelerator, the function comprising: while executing a set of operations on the coherent hardware accelerator, storing a firmware update package in a local memory on the coherent hardware accelerator; restarting the coherent hardware accelerator by: pausing the execution of at least a first operation initiated on the coherent hardware accelerator; and applying the firmware update package to the firmware image on the coherent hardware accelerator; and while resuming the paused operation on the coherent hardware accelerator, querying a configuration of the updated coherent hardware accelerator and making the configuration available to an operating system for discovery and use in one or more subsequent operations. 16. The system of claim 15 , wherein pausing the first operation executing on the coherent hardware accelerator comprises saving at least one of: one or more interrupt source numbers identifying the paused operation; a range of memory mapped input/output (I/O) (MMIO) addresses associated with the paused operation; a program counter associated with an instruction most rec

Assignees

Inventors

Classifications

  • using techniques specially adapted for alterable solid state memories, e.g. for EEPROM or flash memories · CPC title

  • Address translation · CPC title

  • on a serial bus, e.g. I2C bus, SPI bus (on daisy chain buses G06F13/4247) · CPC title

  • Virtual address space management · CPC title

  • G06F8/65Primary

    Updates (security arrangements therefor G06F21/57) · 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 US9710254B2 cover?
The present disclosure relates to updating a firmware image on a coherent hardware accelerator concurrently with executing operations on the coherent hardware accelerator. According to one embodiment, while executing accelerator-enabled operations on the coherent hardware accelerator, a system stores a firmware update package in a local memory on the coherent hardware accelerator. Once the firm…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F8/65. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jul 18 2017 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 4 related publications on this page (citations in our corpus or others sharing the same primary CPC).