gem5 v23.0.0.1
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
tournament.hh
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011, 2014 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Copyright (c) 2004-2006 The Regents of The University of Michigan
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 */
40
41#ifndef __CPU_PRED_TOURNAMENT_PRED_HH__
42#define __CPU_PRED_TOURNAMENT_PRED_HH__
43
44#include <vector>
45
46#include "base/sat_counter.hh"
47#include "base/types.hh"
49#include "params/TournamentBP.hh"
50
51namespace gem5
52{
53
54namespace branch_prediction
55{
56
65class TournamentBP : public BPredUnit
66{
67 public:
71 TournamentBP(const TournamentBPParams &params);
72
81 bool lookup(ThreadID tid, Addr branch_addr, void * &bp_history);
82
89 void uncondBranch(ThreadID tid, Addr pc, void * &bp_history);
97 void btbUpdate(ThreadID tid, Addr branch_addr, void * &bp_history);
110 void update(ThreadID tid, Addr branch_addr, bool taken, void *bp_history,
111 bool squashed, const StaticInstPtr & inst, Addr corrTarget);
112
118 void squash(ThreadID tid, void *bp_history);
119
120 private:
126 inline bool getPrediction(uint8_t &count);
127
132 inline unsigned calcLocHistIdx(Addr &branch_addr);
133
135 inline void updateGlobalHistTaken(ThreadID tid);
136
138 inline void updateGlobalHistNotTaken(ThreadID tid);
139
145 inline void updateLocalHistTaken(unsigned local_history_idx);
146
152 inline void updateLocalHistNotTaken(unsigned local_history_idx);
153
161 {
162#ifdef GEM5_DEBUG
163 BPHistory()
164 { newCount++; }
165 ~BPHistory()
166 { newCount--; }
167
168 static int newCount;
169#endif
172 unsigned localHistory;
176 };
177
179 static const int invalidPredictorIndex = -1;
182
185
187 unsigned localCtrBits;
188
191
194
197
200
203
206
209
214
218
222
226
230
233
236
239
246};
247
248} // namespace branch_prediction
249} // namespace gem5
250
251#endif // __CPU_PRED_TOURNAMENT_PRED_HH__
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
Basically a wrapper class to hold both the branch predictor and the BTB.
Definition bpred_unit.hh:69
Implements a tournament branch predictor, hopefully identical to the one used in the 21264.
Definition tournament.hh:66
void uncondBranch(ThreadID tid, Addr pc, void *&bp_history)
Records that there was an unconditional branch, and modifies the bp history to point to an object tha...
unsigned globalHistoryMask
Mask to apply to globalHistory to access global history table.
std::vector< SatCounter8 > choiceCtrs
Array of counters that make up the choice predictor.
unsigned globalHistoryBits
Number of bits for the global history.
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 updateGlobalHistTaken(ThreadID tid)
Updates global history as taken.
unsigned globalPredictorSize
Number of entries in the global predictor.
std::vector< SatCounter8 > localCtrs
Local counters.
unsigned localPredictorMask
Mask to truncate values stored in the local history table.
void squash(ThreadID tid, void *bp_history)
Restores the global branch history on a squash.
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.
unsigned historyRegisterMask
Mask to control how much history is stored.
bool getPrediction(uint8_t &count)
Returns if the branch should be taken or not, given a counter value.
void updateLocalHistNotTaken(unsigned local_history_idx)
Updates local histories as not taken.
static const int invalidPredictorIndex
Flag for invalid predictor index.
unsigned localHistoryBits
Number of bits for each entry of the local history table.
std::vector< unsigned > localHistoryTable
Array of local history table entries.
unsigned localCtrBits
Number of bits of the local predictor's counters.
unsigned localThreshold
Thresholds for the counter value; above the threshold is taken, equal to or below the threshold is no...
unsigned choiceHistoryMask
Mask to apply to globalHistory to access choice history table.
std::vector< SatCounter8 > globalCtrs
Array of counters that make up the global predictor.
unsigned localPredictorSize
Number of counters in the local predictor.
unsigned calcLocHistIdx(Addr &branch_addr)
Returns the local history index, given a branch address.
void updateGlobalHistNotTaken(ThreadID tid)
Updates global history as not taken.
std::vector< unsigned > globalHistory
Global history register.
unsigned globalCtrBits
Number of bits of the global predictor's counters.
unsigned choiceCtrBits
Number of bits in the choice predictor's counters.
void updateLocalHistTaken(unsigned local_history_idx)
Updates local histories as taken.
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.
unsigned localHistoryTableSize
Number of entries in the local history table.
unsigned choicePredictorSize
Number of entries in the choice predictor.
STL vector class.
Definition stl.hh:37
const Params & params() const
Bitfield< 4 > pc
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
int16_t ThreadID
Thread index/ID type.
Definition types.hh:235
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Definition types.hh:147
The branch history information that is created upon predicting a branch.

Generated on Mon Jul 10 2023 15:32:01 for gem5 by doxygen 1.9.7