45#include "debug/BTB.hh"
52 btb(
"simpleBTB",
p.numEntries,
p.associativity,
53 p.btbReplPolicy,
p.btbIndexingPolicy,
56 DPRINTF(BTB,
"BTB: Creating BTB object.\n");
59 fatal(
"BTB entries is not a power of 2!");
72 return btb.findEntry({instPC, tid});
80 return entry !=
nullptr;
94 return entry->
target.get();
122 btb.insertEntry({instPC, tid}, victim);
123 victim->
update(target, inst);
void update() const
Align cycle and tick to the next clock edge if not already done.
StaticInstPtr inst
Pointer to the static branch inst at this address.
std::unique_ptr< PCStateBase > target
The entry's target.
void update(const PCStateBase &_target, StaticInstPtr _inst)
Update the target and instruction in the BTB entry.
gem5::branch_prediction::BranchTargetBuffer::BranchTargetBufferStats stats
enums::BranchType BranchType
bool valid(ThreadID tid, Addr instPC) override
Checks if a branch address is in the BTB.
const PCStateBase * lookup(ThreadID tid, Addr instPC, BranchType type=BranchType::NoBranch) override
Looks up an address in the BTB to get the target of the branch.
void memInvalidate() override
Invalidate the contents of memory buffers.
BTBEntry * findEntry(Addr instPC, ThreadID tid)
Internal call to find an address in the BTB.
const StaticInstPtr getInst(ThreadID tid, Addr instPC) override
Looks up an address in the BTB and return the instruction information if existant.
SimpleBTB(const SimpleBTBParams ¶ms)
AssociativeCache< BTBEntry > btb
The actual BTB.
static constexpr bool isPowerOf2(const T &n)
#define fatal(...)
This implements a cprintf based fatal() function.
int16_t ThreadID
Thread index/ID type.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
static constexpr auto genTagExtractor(BTBIndexingPolicy *ip)
This helper generates a tag extractor function object which will be typically used by Replaceable ent...
statistics::Vector misses
statistics::Vector lookups
statistics::Vector updates