Go to the documentation of this file.
   44 #include "debug/Fetch.hh" 
   45 #include "debug/Tage.hh" 
   50 namespace branch_prediction
 
   75     if (
bi->tageBranchInfo->condBranch) {
 
   76         DPRINTF(Tage, 
"Updating tables for branch:%lx; taken?:%d\n",
 
   80                                corrTarget, 
bi->tageBranchInfo->tagePred);
 
   93     DPRINTF(Tage, 
"Deleting branch info: %lx\n", 
bi->tageBranchInfo->branchPC);
 
  108     bool retval = 
predict(tid, branch_pc, 
true, bp_history);
 
  112     DPRINTF(Tage, 
"Lookup branch: %lx; predict:%d\n", branch_pc, retval);
 
  129     DPRINTF(Tage, 
"UnConditionalBranch: %lx\n", br_pc);
 
  130     predict(tid, br_pc, 
false, bp_history);
 
  
TAGE(const TAGEParams ¶ms)
virtual void squash(ThreadID tid, bool taken, BranchInfo *bi, Addr target)
Restores speculatively updated path and direction histories.
virtual void squash(ThreadID tid, void *bp_history) override
void btbUpdate(ThreadID tid, Addr branch_addr, void *&bp_history) override
If a branch is not taken, because the BTB address is invalid or missing, this function sets the appro...
virtual void updateStats(bool taken, BranchInfo *bi)
Update the stats.
void update(ThreadID tid, Addr branch_addr, bool taken, void *bp_history, bool squashed, const StaticInstPtr &inst, Addr corrTarget) override
Updates the BP with taken/not taken information.
std::enable_if_t< std::is_integral_v< T >, T > random()
Use the SFINAE idiom to choose an implementation based on whether the type is integral or floating po...
virtual bool predict(ThreadID tid, Addr branch_pc, bool cond_branch, void *&b)
void uncondBranch(ThreadID tid, Addr br_pc, void *&bp_history) override
virtual void updateHistories(ThreadID tid, Addr branch_pc, bool taken, BranchInfo *b, bool speculative, const StaticInstPtr &inst=nullStaticInstPtr, Addr target=MaxAddr)
(Speculatively) updates global histories (path and direction).
virtual void condBranchUpdate(ThreadID tid, Addr branch_pc, bool taken, BranchInfo *bi, int nrand, Addr corrTarget, bool pred, bool preAdjustAlloc=false)
Update TAGE for conditional branches.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void btbUpdate(ThreadID tid, Addr branch_addr, BranchInfo *&bi)
Basically a wrapper class to hold both the branch predictor and the BTB.
bool lookup(ThreadID tid, Addr branch_addr, void *&bp_history) override
Looks up a given PC in the BP to see if it is taken or not taken.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
int16_t ThreadID
Thread index/ID type.
bool tagePredict(ThreadID tid, Addr branch_pc, bool cond_branch, BranchInfo *bi)
TAGE prediction called from TAGE::predict.
Generated on Wed May 4 2022 12:13:54 for gem5 by  doxygen 1.8.17