Programmable event driven yield mechanism which may activate other threads

US10877910B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10877910-B2
Application numberUS-201715475680-A
CountryUS
Kind codeB2
Filing dateMar 31, 2017
Priority dateFeb 19, 2003
Publication dateDec 29, 2020
Grant dateDec 29, 2020

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.

Method, apparatus, and program means for a programmable event driven yield mechanism that may activate other threads. In one embodiment, an apparatus includes execution resources to execute a plurality of instructions and a monitor to detect a condition indicating a low level of progress. The monitor can disrupt processing of a program by transferring to a handler in response to detecting the condition indicating a low level of progress. In another embodiment, thread switch logic may be coupled to a plurality of event monitors which monitor events within the multithreading execution logic. The thread switch logic switches threads based at least partially on a programmable condition of one or more of the performance monitors.

First claim

Opening claim text (preview).

What is claimed is: 1. A processor comprising: execution resources to execute program instructions; a monitor to detect conditions associated with the execution resources, the monitor including multiple monitor counters, at least one of the monitor counters programmable by software to count occurrences of a microarchitectural event selected from multiple events, wherein the at least one monitor counter is programmed to monitor a cache miss event by setting a first set of one or more bits; wherein the monitor is to detect the cache miss event based on the at least one monitor counter reaching a count; and wherein, in response to the at least one monitor counter reaching the count and a second set of one or more bits indicating that what is monitored by the at least one monitor counter is unmasked, execution of the program instructions is to be redirected to an address stored in a first register. 2. The processor of claim 1 wherein the monitor is further configured to detect at least one low progress indicating condition other than the cache miss event. 3. The processor of claim 1 wherein a low progress indicating condition is indicated by a count of microarchitectural events. 4. The processor of claim 1 wherein the monitor comprises a processor performance monitor readable by a processor instruction. 5. The processor of claim 1 wherein redirection to the address is to be performed by an event handler routine stored in a computer readable medium. 6. The processor of claim 5 wherein the execution resources comprise multithreaded execution circuitry capable of executing a plurality of threads. 7. The processor of claim 1 wherein the monitor is context sensitive. 8. The processor of claim 1 wherein the software comprises a user program. 9. The processor of claim 1 wherein the monitor is programmable by a user program executed at a privilege level lower than a privilege level of an operating system and wherein the cache miss event is at least partially caused by the user program. 10. The processor of claim 9 wherein the privilege level comprises a ring three privilege level.

Assignees

Inventors

Classifications

  • to perform operations for flow control · CPC title

  • from multiple instruction streams, e.g. multistreaming · CPC title

  • Event-based monitoring · CPC title

  • Circuit details, i.e. tracer hardware · CPC title

  • by program, e.g. task dispatcher, supervisor, operating system · 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 US10877910B2 cover?
Method, apparatus, and program means for a programmable event driven yield mechanism that may activate other threads. In one embodiment, an apparatus includes execution resources to execute a plurality of instructions and a monitor to detect a condition indicating a low level of progress. The monitor can disrupt processing of a program by transferring to a handler in response to detecting the c…
Who is the assignee on this patent?
Intel Corp
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 Tue Dec 29 2020 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 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).