9697000

Energy-Focused Compiler-Assisted Branch Prediction

PublishedJuly 4, 2017
Assigneenot available in USPTO data we have
Technical Abstract

Patent Claims
20 claims

Legal claims defining the scope of protection, as filed with the USPTO.

1

1. A memory device having instructions stored thereon that, in response to execution by a processor, cause the processor to perform operations to: access control information of an instruction sequence at runtime, the control information added in the instruction sequence prior to runtime to prevent coded information corresponding to a control-flow changing instruction from being decoded in a pipeline of the processor at runtime; and use the control information to predict an outcome of the control-flow changing instruction, the outcome comprising a target of the control-flow changing instruction that includes a path following the control-flow changing instruction, and to fetch an instruction corresponding to the path.

2

2. The memory device of claim 1 , wherein the control information comprises part of a payload of a coprocessor instruction.

3

3. The memory device of claim 1 , wherein the control information comprises code to select a dynamic branch prediction mechanism.

4

4. The memory device of claim 1 , wherein the control information is configured to stall fetching until a second control-flow changing instruction is executed that is not predictable statically or dynamically.

5

5. The memory device of claim 1 , wherein the control information comprises static information that suggests at least one of plural dynamic prediction mechanisms.

6

6. The memory device of claim 1 , wherein the control information specifies a condition under which a control-flow change at an end of the instruction sequence should occur.

7

7. The memory device of claim 1 , wherein the control information comprises part of an instruction configured to affect at least one of processor efficiency or processor energy consumption.

8

8. A system for use with a processor, the system comprising: microarchitecture capable of accessing control information of an instruction sequence at runtime, the control information added in the instruction sequence prior to runtime to prevent coded information corresponding to a control-flow changing instruction from being decoded in a pipeline of the processor at runtime; and the microarchitecture capable of using the control information to predict an outcome of the control-flow changing instruction, the outcome comprising a target of the control-flow changing instruction that includes a path following the control-flow changing instruction, and to fetch an instruction corresponding to the path.

9

9. The system of claim 8 , wherein the control information comprises part of a payload of a coprocessor instruction.

10

10. The system of claim 8 , wherein the control information comprises code to select a dynamic branch prediction mechanism.

11

11. The system of claim 8 , wherein the control information is configured to stall fetching until a second control-flow changing instruction is executed that is not predictable statically or dynamically.

12

12. The system of claim 8 , wherein the control information comprises static information that suggests at least one of plural dynamic prediction mechanisms.

13

13. The system of claim 8 , wherein the control information specifies a condition under which a control-flow change at an end of the instruction sequence is to occur.

14

14. The system of claim 8 , wherein the control information comprises part of an instruction configured to affect at least one of processor efficiency or processor energy consumption.

15

15. A method for use with a processor, the method comprising: with respect to an instruction sequence including a control-flow changing instruction to affect a control-flow of the instruction sequence to which control information has been added, removing the control-flow changing instruction from the instruction sequence; wherein the control information is to be utilized at runtime to predict an outcome of the control-flow changing instruction, the outcome comprising a target of the control-flow changing instruction that includes a path following the control-flow changing instruction, and to fetch an instruction corresponding to the path.

16

16. The method of claim 15 , wherein the control information comprises part of an instruction configured to affect at least one of processor efficiency or processor energy consumption.

17

17. The method of claim 15 , wherein the control information comprises part of a payload of a coprocessor instruction.

18

18. The method of claim 15 , wherein the control information includes static instructions, and wherein the processor is configured to remove the static instructions in a prefetch buffer at runtime to prevent the static instructions from entering a pipeline of the processor.

19

19. The method of claim 15 , wherein the control information comprises code to select a dynamic branch prediction mechanism at runtime.

20

20. The method of claim 15 , wherein the control information comprises static information that suggests at least one of plural dynamic prediction mechanisms.

Patent Metadata

Filing Date

Unknown

Publication Date

July 4, 2017

Inventors

Saurabh Chheda
Kristopher Carver
Raksit Ashok

Want to explore more patents?

Browse 5M+ US patents with plain-English claim translations and AI-generated analysis.

Citation & reuse

Analysis on this page is generated by Patentable — an AI-powered patent intelligence platform. AI-generated summaries, explanations, and analysis may be reused with attribution and a visible link back to the canonical URL below. Patent abstracts and claims are USPTO public domain.

Cite as: Patentable. “ENERGY-FOCUSED COMPILER-ASSISTED BRANCH PREDICTION” (9697000). https://patentable.app/patents/9697000

© 2026 Patentable. All rights reserved.

Patentable is a research and drafting-assistant tool, not a law firm, and does not provide legal advice. Documents we generate are drafts for review by a licensed patent attorney.