Absolute address bits kept in branch history table

Electrical computers and digital processing systems: memory – Address formation – Address mapping

Reexamination Certificate

Rate now

  [ 0.00 ] – not rated yet Voters 0   Comments 0

Details

C712S233000, C712S240000

Reexamination Certificate

active

06745313

ABSTRACT:

BACKGROUND
There are a variety of ways to organize and access data in cache memories. In some processors, the cache data is organized by absolute address rather than by virtual address. The absolute address is the address at which the data is located in main storage, and the virtual address is the address at which the data is located relative to the calling program. However, when data is to be fetched from the cache, the only address initially available is the virtual address. Because of the size of the cache and because some bits of the address may be changed during translation from the virtual address to the absolute address, some bits of the translated absolute address that are needed to uniquely define the location of the desired data in the cache are not available in the virtual address. The correct absolute address bits are held in the translation look-aside buffer (or “TLB”). Since accessing the translation look-aside buffer is done at the same time as the reading of the cache directory and data, the absolute address bits needed from the translation look-aside buffer to find the data in the cache are not available in time for the initial cache access.
This problem has existed on some processors for many years. The problem has been handled by reading from every location in the cache that the desired data could have been, and then sorting out the particular piece of desired data after all of the address information became available. This took a lot of comparison circuits and had a potential impact on the cycle time of the processor. The IBM® Alliance® processors introduced a structure called an absolute address history table (or “AAHT”) to predict the values of the absolute address bits that were needed. Unfortunately, the prior solutions did not adequately predict absolute address bits for accessing an instruction cache in the case of branch instructions.
SUMMARY
This disclosure presents a method for selecting data in a computer system having a cache memory and a branch history table where the method includes predicting an address corresponding to the data, selecting data at the predicted address in the cache memory, translating an address corresponding to the data, comparing the translated address with the predicted address, and if they are different; re-selecting data at the translated address in the cache memory and appending the translated address to the branch history table.


REFERENCES:
patent: 3781808 (1973-12-01), Ahearn et al.
patent: 4797817 (1989-01-01), Nguyen et al.
patent: 5067078 (1991-11-01), Talgam et al.
patent: 5148538 (1992-09-01), Celtruda et al.
patent: 5317704 (1994-05-01), Izawa et al.
patent: 5625808 (1997-04-01), Webb et al.
patent: 5768575 (1998-06-01), McFarland et al.
patent: 5893930 (1999-04-01), Song
patent: 6026488 (2000-02-01), Liptay et al.
patent: 6138223 (2000-10-01), Check et al.

LandOfFree

Say what you really think

Search LandOfFree.com for the USA inventors and patents. Rate them and share your experience with other people.

Rating

Absolute address bits kept in branch history table does not yet have a rating. At this time, there are no reviews or comments for this patent.

If you have personal experience with Absolute address bits kept in branch history table, we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and Absolute address bits kept in branch history table will most certainly appreciate the feedback.

Rate now

     

Profile ID: LFUS-PAI-O-3307610

  Search
All data on this website is collected from public sources. Our data reflects the most accurate information available at the time of publication.