Directed interrupt virtualization with interrupt table

US11593153B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-11593153-B2
Application numberUS-202117643910-A
CountryUS
Kind codeB2
Filing dateDec 13, 2021
Priority dateFeb 14, 2019
Publication dateFeb 28, 2023
Grant dateFeb 28, 2023

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.

An interrupt signal is provided to an operating system executed using one or more processors of a plurality of processors. A bus attachment device receives an interrupt signal with an interrupt target ID identifying a processor assigned for use as a target processor for handling the interrupt signal. The bus attachment device translates the received interrupt target ID to a processor ID using an interrupt table entry and forwards the interrupt signal to the target processor for handling. The processor ID is used to address the target processor directly.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer program product for providing an interrupt signal, the computer program product comprising: at least one computer readable storage medium readable by at least one processing circuit and storing instructions for performing a method comprising: receiving an interrupt signal with an interrupt target ID, the interrupt target ID identifying one processor of a plurality of processors of a computing environment assigned for usage as a target processor for handling the interrupt signal; translating the interrupt target ID to a processor ID; and forwarding the interrupt signal to the target processor to handle, the forwarding using the processor ID resulting from the translating to address the target processor directly. 2. The computer program product of claim 1 , wherein the interrupt signal being received is in a form of a message signaled interrupt comprising the interrupt target ID of the target processor. 3. The computer program product of claim 1 , wherein the method further comprises retrieving a copy of an interrupt table entry assigned to the interrupt target ID, the copy of the interrupt table entry comprising a first mapping of the interrupt target ID to a processor ID, and wherein the translating uses the copy of the interrupt table entry. 4. The computer program product of claim 1 , wherein the method further comprises: checking using a copy of a running indicator that the target processor is scheduled for usage by an operating system, the running indicator to indicate whether the target processor identified by the interrupt target ID is scheduled for usage by the operating system; and continuing, based on the target processor being scheduled, with the forwarding of the interrupt signal. 5. The computer program product of claim 4 , wherein the method further comprises forwarding the interrupt signal for handling to the plurality of processors using broadcasting, based on the target processor not being scheduled. 6. The computer program product of claim 1 , wherein the method further comprises: checking using an interrupt blocking indicator that the target processor is unblocked enabling receipt of interrupt signals, the interrupt blocking indicator to indicate whether the target processor identified by the interrupt target ID is currently blocked from receiving interrupt signals; and continuing, based on the target processor being unblocked, with the forwarding of the interrupt signal. 7. The computer program product of claim 6 , wherein the method further comprises forwarding the interrupt signal for handling to remaining processors of the plurality of processors using broadcasting. 8. The computer program product of claim 6 , wherein the method further comprises: checking that no interrupts addressed to the target processor are pending for handling by the target processor; and changing based on no interrupts addressed to the target processor being pending for handling by the target processor, the interrupt blocking indicator to indicate the target processor is unblocked. 9. The computer program product of claim 8 , wherein the method further comprises changing, based on the target processor being unblocked, the interrupt blocking indicator in a first copy of an interrupt table entry assigned to the interrupt target ID to indicate the processor ID is blocked, the changing being performed before the forwarding of the interrupt signal to the target processor for handling. 10. The computer program product of claim 9 , wherein the method further comprises: retrieving based on the changing of the interrupt blocking indicator, a second copy of the interrupt table entry assigned to the interrupt target ID; and checking the second copy of the interrupt table entry to exclude a predefined type of change of the second copy of the interrupt table entry relative to the first copy of the interrupt table entry, the forwarding of the interrupt signal to the target processor for handling being based on a successful exclusion of the predefined type of change. 11. The computer program product of claim 10 , wherein the predefined type of change is a change of a first mapping of the interrupt target ID relative to a second mapping of the interrupt target ID to another processor ID comprised by the second copy of the interrupt table entry, and based on the second mapping comprising a change relative to the first mapping, the interrupt signal being forwarded for handling to the plurality of processors using broadcasting. 12. The computer program product of claim 10 , wherein the predefined type of change is a change of a first copy of a running indicator indicating that the target processor identified by the interrupt target ID is scheduled for usage by an operating system relative to a second copy of the running indicator, and based on the second copy of the running indicator comprising a change relative to the first copy of the running indicator, the second copy of the running indicator indicating the target processor not being scheduled for usage by an operating system, the interrupt signal being forwarded for handling to the plurality of processors using broadcasting. 13. A computer system for providing an interrupt signal, the computer system comprising: a memory; and at least one processor in communication with the memory, wherein the computer system is configured to perform a method, said method comprising: receiving an interrupt signal with an interrupt target ID, the interrupt target ID identifying one processor of a plurality of processors of a computing environment assigned for usage as a target processor for handling the interrupt signal; translating the interrupt target ID to a processor ID; and forwarding the interrupt signal to the target processor to handle, the forwarding using the processor ID resulting from the translating to address the target processor directly. 14. The computer system of claim 13 , wherein the method further comprises retrieving a copy of an interrupt table entry assigned to the interrupt target ID, the copy of the interrupt table entry comprising a first mapping of the interrupt target ID to a processor ID, and wherein the translating uses the copy of the interrupt table entry. 15. The computer system of claim 13 , wherein the method further comprises: checking using a copy of a running indicator that the target processor is scheduled for usage by an operating system, the running indicator to indicate whether the target processor identified by the interrupt target ID is scheduled for usage by the operating system; and continuing, based on the target processor being scheduled, with the forwarding of the interrupt signal. 16. The computer system of claim 15 , wherein the method further comprises forwarding the interrupt signal for handling to the plurality of processors using broadcasting, based on the target processor not being scheduled. 17. The computer system of claim 13 , wherein the method further comprises: checking using an interrupt blocking indicator that the target processor is unblocked enabling receipt of interrupt signals, the interrupt blocking indicator to indicate whether the target processor identified by the interrupt target ID is currently blocked from receiving interrupt signals; and continuing, based on the target processor being unblocked, with the forwarding of the interrupt signal. 18. The computer system of claim 17 , wherein the method further comprises forwarding the interrupt signal for handling to remaining processors of the plurality of processors us

Assignees

Inventors

Classifications

  • Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues · CPC title

  • G06F9/4812Primary

    by interrupt, e.g. masked · CPC title

  • Hypervisors; Virtual machine monitors · CPC title

  • Guest-host, i.e. hypervisor is an application program itself, e.g. VirtualBox · CPC title

  • 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 US11593153B2 cover?
An interrupt signal is provided to an operating system executed using one or more processors of a plurality of processors. A bus attachment device receives an interrupt signal with an interrupt target ID identifying a processor assigned for use as a target processor for handling the interrupt signal. The bus attachment device translates the received interrupt target ID to a processor ID using a…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F9/4812. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Feb 28 2023 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 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).