Managed instruction cache prefetching

US9811341B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9811341-B2
Application numberUS-201113995649-A
CountryUS
Kind codeB2
Filing dateDec 29, 2011
Priority dateDec 29, 2011
Publication dateNov 7, 2017
Grant dateNov 7, 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.

Disclosed is an apparatus and method to manage instruction cache prefetching from an instruction cache. A processor may comprise: a prefetch engine; a branch prediction engine to predict the outcome of a branch; and dynamic optimizer. The dynamic optimizer may be used to control: identifying common instruction cache misses and inserting a prefetch instruction from the prefetch engine to the instruction cache.

First claim

Opening claim text (preview).

What is claimed is: 1. A method to manage instruction cache prefetching from an instruction cache comprising: storing information about instruction cache misses, wherein the information includes an instruction cache line address, branch target characteristics including a type of branch indicator, the confidence of the prediction, and a branch address; identifying common instruction cache misses; predicting the outcome of a branch and providing a confidence of the prediction; for an indirect branch, inserting, regardless of the confidence, a prefetch instruction from a prefetch engine to the instruction cache; and for a direct branch, inserting the prefetch instruction from the prefetch engine to the instruction cache is based upon whether the taken branch had a strong prediction or a weak prediction and the prefetch instruction is executed or not executed dependent upon the confidence of the prediction. 2. A processor to manage instruction cache prefetching from an instruction cache comprising: a prefetch engine; a branch prediction engine to predict the outcome of a branch and provide a confidence of the prediction; and a dynamic optimizer to control: storing information about cache misses, wherein the information includes an instruction cache line address, branch target characteristics including a type of branch indicator, the confidence of the prediction, and a branch address; identifying common instruction cache misses; for an indirect branch, to insert, regardless of the confidence, a prefetch instruction from the prefetch engine to the instruction cache; and for a direct branch, to insert a prefetch instruction from the prefetch engine to the instruction cache is based upon whether the taken branch had a strong prediction or a weak prediction and the prefetch instruction is executed or not executed dependent upon the confidence of the prediction. 3. A computer system comprising: a memory control hub coupled to a memory; and a processor to manage instruction cache prefetching comprising: a prefetch engine; a branch prediction engine to predict the outcome of a branch and provide a confidence of the prediction; and a dynamic optimizer to control: storing information about cache misses, wherein the information includes an instruction cache line address, branch target characteristics characteristics including a type of branch indicator, the confidence of the prediction, and a branch address; identifying common instruction cache misses; for an indirect branch, inserting, regardless of the confidence, a prefetch instruction from the prefetch engine to the instruction cache; and for a direct branch, inserting the prefetch instruction from the prefetch engine to the instruction cache is based upon whether the taken branch had a strong prediction or a weak prediction and the prefetch instruction is executed or not executed dependent upon the confidence of the prediction. 4. A computer program product comprising: a non-transitory computer-readable medium comprising code for: storing information about instruction cache misses, wherein the information includes an instruction cache line address, branch target characteristics including a type of branch indicator, the confidence of the prediction, and a branch address; identifying common instruction cache misses; predicting the outcome of a branch and providing a confidence of the prediction; and for an indirect branch, inserting, regardless of the confidence, a prefetch instruction from a prefetch engine to the instruction cache; and for a direct branch, inserting the prefetch instruction from the prefetch engine to the instruction cache is based upon whether the taken branch had a strong prediction or a weak prediction and the prefetch instruction is executed or not executed dependent upon the confidence of the prediction. 5. The computer program product of claim 4 , further comprising code for creating a table to store profiled information including at least an address of an instruction missed in the instruction cache.

Assignees

Inventors

Classifications

  • Instruction prefetching · CPC title

  • with prefetch · CPC title

  • Prefetch instructions; cache control instructions · CPC title

  • G06F9/3804Primary

    for branches, e.g. hedging, branch folding · CPC title

  • Runtime instruction translation, e.g. macros · 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 US9811341B2 cover?
Disclosed is an apparatus and method to manage instruction cache prefetching from an instruction cache. A processor may comprise: a prefetch engine; a branch prediction engine to predict the outcome of a branch; and dynamic optimizer. The dynamic optimizer may be used to control: identifying common instruction cache misses and inserting a prefetch instruction from the prefetch engine to the ins…
Who is the assignee on this patent?
Stavrou Kyriakos A, Gibert Codina Enric, Codina Josep M, and 17 more
What technology area does this patent fall under?
Primary CPC classification G06F9/30047. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Nov 07 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 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).