Go to the documentation of this file.
33 #include "debug/Fetch.hh"
38 namespace branch_prediction
43 unsigned _instShiftAmt,
44 unsigned _num_threads)
45 : numEntries(_numEntries),
47 instShiftAmt(_instShiftAmt),
50 DPRINTF(Fetch,
"BTB: Creating BTB object.\n");
53 fatal(
"BTB entries is not a power of 2!");
97 unsigned btb_idx =
getIndex(instPC, tid);
104 && inst_tag ==
btb[btb_idx].tag
105 &&
btb[btb_idx].tid == tid) {
118 unsigned btb_idx =
getIndex(inst_pc, tid);
125 && inst_tag ==
btb[btb_idx].tag
126 &&
btb[btb_idx].tid == tid) {
127 return btb[btb_idx].target.get();
136 unsigned btb_idx =
getIndex(inst_pc, tid);
140 btb[btb_idx].tid = tid;
141 btb[btb_idx].valid =
true;
142 set(
btb[btb_idx].target, target);
#define fatal(...)
This implements a cprintf based fatal() function.
const PCStateBase * lookup(Addr instPC, ThreadID tid)
Looks up an address in the BTB.
static constexpr std::enable_if_t< std::is_integral_v< T >, int > floorLog2(T x)
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.
static constexpr bool isPowerOf2(const T &n)
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.
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