Go to the documentation of this file.
   48 #ifndef __CPU_PRED_TAGE_BASE_HH__ 
   49 #define __CPU_PRED_TAGE_BASE_HH__ 
   56 #include "params/TAGEBase.hh" 
   62 namespace branch_prediction
 
   99         void init(
int original_length, 
int compressed_length)
 
  103             outpoint = original_length % compressed_length;
 
  212     virtual int F(
int phist, 
int size, 
int bank) 
const;
 
  231     static void ctrUpdate(T & ctr, 
bool taken, 
int nbits);
 
  268     void updateGHist(uint8_t * &h, 
bool dir, uint8_t * tab, 
int &PT);
 
  330         int nrand, 
Addr corrTarget, 
bool pred, 
bool preAdjustAlloc = 
false);
 
  380     virtual void adjustAlloc(
bool & alloc, 
bool taken, 
bool pred_taken);
 
  386         bool alloc, 
bool taken, BranchInfo* 
bi, 
int nrand);
 
  397         Addr branch_pc, 
bool taken, BranchInfo* 
bi);
 
  417     int8_t 
getCtr(
int hitBank, 
int hitBankIndex) 
const;
 
  517 #endif // __CPU_PRED_TAGE_BASE_HH__ 
  
This is a simple scalar statistic, like a counter.
size_t getSizeInBits() const
const bool speculativeHistUpdate
virtual void squash(ThreadID tid, bool taken, BranchInfo *bi, Addr target)
Restores speculatively updated path and direction histories.
virtual void buildTageTables()
Instantiates the TAGE table entries.
const int64_t initialTCounterValue
const unsigned tagTableUBits
std::vector< ThreadHistory > threadHistory
TAGEBaseStats(statistics::Group *parent, unsigned nHistoryTables)
FoldedHistory * computeIndices
bool isSpeculativeUpdateEnabled() const
virtual BranchInfo * makeBranchInfo()
virtual void handleAllocAndUReset(bool alloc, bool taken, BranchInfo *bi, int nrand)
Handles Allocation and U bits reset on an update.
unsigned getTageCtrBits() const
virtual bool getBimodePred(Addr pc, BranchInfo *bi) const
Get a branch prediction from the bimodal predictor.
void init(int original_length, int compressed_length)
virtual void calculateIndicesAndTags(ThreadID tid, Addr branch_pc, BranchInfo *bi)
On a prediction, calculates the TAGE indices and tags for all the different history lengths.
statistics::Scalar bimodalProviderWrong
virtual void updateStats(bool taken, BranchInfo *bi)
Update the stats.
statistics::Scalar altMatchProviderWrong
virtual bool isHighConfidence(BranchInfo *bi) const
virtual int F(int phist, int size, int bank) const
Utility function to shuffle the path history depending on which tagged table we are accessing.
statistics::Scalar longestMatchProviderWrong
A vector of scalar stats.
static void ctrUpdate(T &ctr, bool taken, int nbits)
Updates a direction counter based on the actual branch outcome.
std::vector< bool > noSkip
virtual uint16_t gtag(ThreadID tid, Addr pc, int bank) const
Computes the partial tag of a tagged table.
static void unsignedCtrUpdate(uint8_t &ctr, bool up, unsigned nbits)
Updates an unsigned counter based on up/down parameter.
const unsigned logRatioBiModalHystEntries
const unsigned tagTableCounterBits
statistics::Scalar bimodalAltMatchProviderCorrect
void baseUpdate(Addr pc, bool taken, BranchInfo *bi)
Updates the bimodal predictor.
int8_t getCtr(int hitBank, int hitBankIndex) const
statistics::Scalar longestMatchProviderWouldHaveHit
std::vector< unsigned > tagTableTagWidths
const StaticInstPtr nullStaticInstPtr
Statically allocated null StaticInstPtr.
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
std::vector< bool > btablePrediction
gem5::branch_prediction::TAGEBase::TAGEBaseStats stats
virtual unsigned getUseAltIdx(BranchInfo *bi, Addr branch_pc)
Calculation of the index for useAltPredForNewlyAllocated On this base TAGE implementation it is alway...
virtual void initFoldedHistories(ThreadHistory &history)
Initialization of the folded histories.
statistics::Vector longestMatchProvider
const unsigned pathHistBits
const unsigned nHistoryTables
statistics::Scalar longestMatchProviderCorrect
virtual void extraAltCalc(BranchInfo *bi)
Extra steps for calculating altTaken For this base TAGE class it does nothing.
FoldedHistory * computeTags[2]
statistics::Scalar bimodalAltMatchProviderWrong
int getPathHist(ThreadID tid) const
std::vector< bool > btableHysteresis
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).
Abstract superclass for simulation objects.
virtual int gindex(ThreadID tid, Addr pc, int bank) const
Computes the index used to access a partially tagged table.
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.
virtual void calculateParameters()
Calculates the history lengths and some other paramters in derived classes.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
statistics::Scalar altMatchProviderWouldHaveHit
BranchInfo(const TAGEBase &tage)
virtual int bindex(Addr pc_in) const
Computes the index used to access the bimodal table.
virtual void handleUReset()
Handles the U bits reset.
std::vector< int > logTagTableSizes
statistics::Scalar bimodalProviderCorrect
void btbUpdate(ThreadID tid, Addr branch_addr, BranchInfo *&bi)
void update(ThreadID tid, Addr branch_pc, bool taken, BranchInfo *bi)
Update TAGE.
statistics::Vector altMatchProvider
std::vector< int8_t > useAltPredForNewlyAllocated
const unsigned instShiftAmt
unsigned getGHR(ThreadID tid, BranchInfo *bi) const
TAGEBase(const TAGEBaseParams &p)
virtual void adjustAlloc(bool &alloc, bool taken, bool pred_taken)
Extra calculation to tell whether TAGE allocaitons may happen or not on an update For this base TAGE ...
void updateGHist(uint8_t *&h, bool dir, uint8_t *tab, int &PT)
(Speculatively) updates the global branch history.
@ LAST_TAGE_PROVIDER_TYPE
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const unsigned histBufferSize
statistics::Scalar altMatchProviderCorrect
virtual void resetUctr(uint8_t &u)
Algorithm for resetting a single U counter.
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.
virtual void handleTAGEUpdate(Addr branch_pc, bool taken, BranchInfo *bi)
Handles the update of the TAGE entries.
Generated on Thu Jul 28 2022 13:32:29 for gem5 by  doxygen 1.8.17