Go to the documentation of this file.
34 #include "debug/Fetch.hh"
39 namespace branch_prediction
44 localPredictorSize(params.localPredictorSize),
45 localCtrBits(params.localCtrBits),
46 localPredictorSets(localPredictorSize / localCtrBits),
47 localCtrs(localPredictorSets,
SatCounter8(localCtrBits)),
48 indexMask(localPredictorSets - 1)
51 fatal(
"Invalid local predictor size!\n");
55 fatal(
"Invalid number of local predictor sets! Check localCtrBits.\n");
60 DPRINTF(Fetch,
"local predictor size: %i\n",
65 DPRINTF(Fetch,
"instruction shift amount: %i\n",
83 DPRINTF(Fetch,
"Looking up index %#x\n",
86 uint8_t counter_val =
localCtrs[local_predictor_idx];
88 DPRINTF(Fetch,
"prediction is %i.\n",
100 assert(bp_history == NULL);
101 unsigned local_predictor_idx;
112 DPRINTF(Fetch,
"Looking up index %#x\n", local_predictor_idx);
115 DPRINTF(Fetch,
"Branch updated as taken.\n");
118 DPRINTF(Fetch,
"Branch updated as not taken.\n");
#define fatal(...)
This implements a cprintf based fatal() function.
std::vector< SatCounter8 > localCtrs
Array of counters that make up the local predictor.
LocalBP(const LocalBPParams ¶ms)
Default branch predictor constructor.
static constexpr bool isPowerOf2(const T &n)
const unsigned localPredictorSize
Size of the local predictor.
const unsigned indexMask
Mask to get index bits.
void update(ThreadID tid, Addr branch_addr, bool taken, void *bp_history, bool squashed, const StaticInstPtr &inst, Addr corrTarget)
Updates the branch predictor with the actual result of a branch.
const unsigned localCtrBits
Number of bits of the local predictor's counters.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
unsigned getLocalIndex(Addr &PC)
Calculates the local index based on the PC.
const unsigned instShiftAmt
Number of bits to shift instructions by for predictor addresses.
const unsigned localPredictorSets
Number of sets.
bool lookup(ThreadID tid, Addr branch_addr, void *&bp_history)
Looks up the given address in the branch predictor and returns a true/false value as to whether it is...
void btbUpdate(ThreadID tid, Addr branch_addr, void *&bp_history)
Updates the branch predictor to Not Taken if a BTB entry is invalid or not found.
Basically a wrapper class to hold both the branch predictor and the BTB.
virtual void uncondBranch(ThreadID tid, Addr pc, void *&bp_history)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
bool getPrediction(uint8_t &count)
Returns the taken/not taken prediction given the value of the counter.
int16_t ThreadID
Thread index/ID type.
Generated on Tue Sep 7 2021 14:53:44 for gem5 by doxygen 1.8.17