Go to the documentation of this file.
43 #ifndef __CPU_PRED_TAGE_SC_L_HH__
44 #define __CPU_PRED_TAGE_SC_L_HH__
48 #include "params/TAGE_SC_L.hh"
49 #include "params/TAGE_SC_L_LoopPredictor.hh"
50 #include "params/TAGE_SC_L_TAGE.hh"
55 namespace branch_prediction
110 Addr target)
override;
115 int F(
int phist,
int size,
int bank)
const override;
120 Addr target)
override;
123 ThreadHistory & tHist,
int brtype,
bool taken,
126 void adjustAlloc(
bool & alloc,
bool taken,
bool pred_taken)
override;
163 ThreadID tid,
Addr branch_pc,
bool cond_branch,
void* &
b)
override;
167 Addr corrTarget)
override;
197 #endif // __CPU_PRED_TAGE_SC_L_HH__
int calcDep(TAGEBase::BranchInfo *bi)
void calculateParameters() override
Calculates the history lengths and some other paramters in derived classes.
StatisticalCorrector::BranchInfo * scBranchInfo
const unsigned firstLongTagTable
virtual bool calcConf(int index) const override
void updatePathAndGlobalHistory(ThreadHistory &tHist, int brtype, bool taken, Addr branch_pc, Addr target)
bool getBimodePred(Addr branch_pc, TAGEBase::BranchInfo *tage_bi) const override
Get a branch prediction from the bimodal predictor.
const unsigned longTagsTageFactor
void adjustAlloc(bool &alloc, bool taken, bool pred_taken) override
Extra calculation to tell whether TAGE allocaitons may happen or not on an update For this base TAGE ...
virtual void handleTAGEUpdate(Addr branch_pc, bool taken, TAGEBase::BranchInfo *bi) override=0
Handles the update of the TAGE entries.
TAGE_SC_L_TAGE(const TAGE_SC_L_TAGEParams &p)
void buildTageTables() override
Instantiates the TAGE table entries.
TAGE_SC_L_LoopPredictor(const TAGE_SC_L_LoopPredictorParams &p)
const unsigned shortTagsSize
virtual bool optionalAgeInc() const override
const unsigned shortTagsTageFactor
const Params & params() const
void squash(ThreadID tid, bool taken, TAGEBase::BranchInfo *bi, Addr target) override
Restores speculatively updated path and direction histories.
virtual TAGEBase::BranchInfo * makeBranchInfo() override
virtual uint16_t gtag(ThreadID tid, Addr pc, int bank) const override=0
Computes the partial tag of a tagged table.
TageSCLBranchInfo(TAGEBase &tage, StatisticalCorrector &sc, LoopPredictor &lp)
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.
StatisticalCorrector * statisticalCorrector
BranchInfo(TAGEBase &tage)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
int gindex(ThreadID tid, Addr pc, int bank) const override
Computes the index used to access a partially tagged table.
virtual int gindex_ext(int index, int bank) const =0
void extraAltCalc(TAGEBase::BranchInfo *bi) override
Extra steps for calculating altTaken For this base TAGE class it does nothing.
const unsigned logTagTableSize
int bindex(Addr pc_in) const override
Computes the index used to access the bimodal table.
void updateHistories(ThreadID tid, Addr branch_pc, bool taken, TAGEBase::BranchInfo *b, bool speculative, const StaticInstPtr &inst, Addr target) override
(Speculatively) updates global histories (path and direction).
const bool truncatePathHist
void handleUReset() override
Handles the U bits reset.
int F(int phist, int size, int bank) const override
Utility function to shuffle the path history depending on which tagged table we are accessing.
const unsigned longTagsSize
@ LAST_LTAGE_PROVIDER_TYPE
TAGE_SC_L(const TAGE_SC_LParams ¶ms)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual void handleAllocAndUReset(bool alloc, bool taken, TAGEBase::BranchInfo *bi, int nrand) override=0
Handles Allocation and U bits reset on an update.
unsigned getUseAltIdx(TAGEBase::BranchInfo *bi, Addr branch_pc) override
Calculation of the index for useAltPredForNewlyAllocated On this base TAGE implementation it is alway...
void calculateIndicesAndTags(ThreadID tid, Addr branch_pc, TAGEBase::BranchInfo *bi) override
On a prediction, calculates the TAGE indices and tags for all the different history lengths.
bool predict(ThreadID tid, Addr branch_pc, bool cond_branch, void *&b) override
Get a branch prediction from LTAGE.
virtual ~TageSCLBranchInfo()
int16_t ThreadID
Thread index/ID type.
Generated on Tue Dec 21 2021 11:34:27 for gem5 by doxygen 1.8.17