×

Two-level branch prediction cache

  • US 5,163,140 A
  • Filed: 03/02/1992
  • Issued: 11/10/1992
  • Est. Priority Date: 02/26/1990
  • Status: Expired due to Term
First Claim
Patent Images

1. In a computer system having decode logic responsive to fetched instructions and an instruction cache from which instructions, including branch instructions, are fetched for execution, the improvement comprising:

  • means for generating an input PC representative of the address of an encountered instruction;

    a first level branch prediction cache (BPC), separate from the instruction cache, having a first number N1 of lines for storing prediction information on up to N1 previously encountered branch instructions, each line capable of storing an entry providing prediction information at a first level of detail including the address of the branch instruction for which prediction information is stored, a target address for the branch instruction, target instruction bytes corresponding to the instruction stream starting at the target address, and branch history information representing the direction taken during at least one previous execution of the branch instruction;

    means, associated with said first level BPC, for comparing said input PC with the address of the branch instruction in each of the first level BPC entries, and, in the event of a match between the input PC and the address of the branch instruction in the first level BPC entry, for enabling a first level BPC entry to be output and target instruction bytes in the first level BPC entry to be communicated to the decode logic;

    a second level BPC, separate from the instruction cache, having a second number N2 of lines, larger than said first number of lines, for storing prediction information on up to N2 previously encountered branch instructions, each line capable of storing an entry providing prediction information at a second level of detail, lower than said first level of detail, including a portion of a target instruction address and branch history information representing the direction taken during at least one previous execution of the branch instruction for which prediction information is stored, said second level BPC being indexed by only a portion of the input PC; and

    means, associated with said second level BPC, for enabling a second level BPC entry to be output for use in the event that no match exists in said first level BPC.

View all claims
  • 3 Assignments
Timeline View
Assignment View
    ×
    ×