Go to the documentation of this file.
29 #ifndef __CPU_PRED_BTB_HH__
30 #define __CPU_PRED_BTB_HH__
35 #include "config/the_isa.hh"
40 namespace branch_prediction
135 #endif // __CPU_PRED_BTB_HH__
const PCStateBase * lookup(Addr instPC, ThreadID tid)
Looks up an address in the BTB.
bool valid
Whether or not the entry is valid.
ThreadID tid
The entry's thread id.
unsigned tagBits
The number of tag bits per entry.
unsigned tagMask
The tag mask.
unsigned instShiftAmt
Number of bits to shift PC when calculating index.
DefaultBTB(unsigned numEntries, unsigned tagBits, unsigned instShiftAmt, unsigned numThreads)
Creates a BTB with the given number of entries, number of bits per tag, and instruction offset amount...
unsigned log2NumThreads
Log2 NumThreads used for hashing threadid.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Addr getTag(Addr instPC)
Returns the tag bits of a given address.
unsigned getIndex(Addr instPC, ThreadID tid)
Returns the index into the BTB, based on the branch's PC.
std::unique_ptr< PCStateBase > target
The entry's target.
unsigned numEntries
The number of entries in the BTB.
std::vector< BTBEntry > btb
The actual BTB.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
unsigned tagShiftAmt
Number of bits to shift PC when calculating tag.
bool valid(Addr instPC, ThreadID tid)
Checks if a branch is in the BTB.
void update(Addr inst_pc, const PCStateBase &target_pc, ThreadID tid)
Updates the BTB with the target of a branch.
int16_t ThreadID
Thread index/ID type.
unsigned idxMask
The index mask.
Generated on Thu Jun 16 2022 10:41:47 for gem5 by doxygen 1.8.17