Go to the documentation of this file.
33 #ifndef __CPU_PRED_BI_MODE_PRED_HH__
34 #define __CPU_PRED_BI_MODE_PRED_HH__
38 #include "params/BiModeBP.hh"
43 namespace branch_prediction
121 #endif // __CPU_PRED_BI_MODE_PRED_HH__
unsigned globalPredictorSize
unsigned globalHistoryBits
void uncondBranch(ThreadID tid, Addr pc, void *&bp_history)
unsigned choiceHistoryMask
Implements a bi-mode branch predictor.
unsigned globalHistoryReg
unsigned choicePredictorSize
std::vector< SatCounter8 > takenCounters
BiModeBP(const BiModeBPParams ¶ms)
unsigned historyRegisterMask
unsigned globalHistoryMask
const Params & params() const
void btbUpdate(ThreadID tid, Addr branch_addr, void *&bp_history)
If a branch is not taken, because the BTB address is invalid or missing, this function sets the appro...
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
std::vector< SatCounter8 > notTakenCounters
std::vector< unsigned > globalHistoryReg
void updateGlobalHistReg(ThreadID tid, bool taken)
bool lookup(ThreadID tid, Addr branch_addr, void *&bp_history)
Looks up a given PC in the BP to see if it is taken or not taken.
Basically a wrapper class to hold both the branch predictor and the BTB.
unsigned notTakenThreshold
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void update(ThreadID tid, Addr branch_addr, bool taken, void *bp_history, bool squashed, const StaticInstPtr &inst, Addr corrTarget)
Updates the BP with taken/not taken information.
void squash(ThreadID tid, void *bp_history)
int16_t ThreadID
Thread index/ID type.
std::vector< SatCounter8 > choiceCounters
Generated on Tue Sep 7 2021 14:53:44 for gem5 by doxygen 1.8.17