Alternative implementations of two-level adaptive branch prediction by Tse-yu Yeh & Yale N. Patt
Alternative Implementations of Two-Level Adaptive Branch Prediction
Tse-Yu Yeh and Yale N. Patt
Department of Electrical Engineering and Computer Science
The University of Michigan
Ann Arbor, Michigan 48109-2122
Abstract
As the issue rate and depth of pipelining of high perfor-
mance Superscalar processors increase, the importance
of an excellent branch predictor becomes more vital to
delivering the potential performance of a wide-issue,
deep pipelined microarchitecture. We propose a new
dynamic branch predictor (Two-Level Adaptive Branch
Prediction) that achieves substantially higher accuracy
than any other scheme reported in the literature. The
mechanism uses two levels of branch history information
to make predictions, the history of the last k branches
encountered, and the branch behavior for the last s oc-
currences of the specific pattern of these k branches. We
have identified three variations of the Two-Level Adap-
tive Branch Prediction, depending on how finely we re-
solve the history information gathered. We compute the
hardware costs of implementing each of the three varia-
tions, and use these costs in evaluating their relative ef-
fectiveness. We measure the branch prediction accuracy
of the three variations of Two-Level Adaptive Branch
Prediction, along with several other popular proposed
dynamic and static prediction schemes, on the SPEC
benchmarks. We show that the average prediction ac-
curacy for Two-Level Adaptive Branch Prediction is 97
percent, while the other known schemes achieve at most
94.4 percent average prediction accuracy. We measure
the effectiveness of different prediction algorithms and
different amounts of history and pattern information.
We measure the costs of each variation to obtain the
same prediction accuracy.
1 Introduction
As the issue rate and depth of pipelining of high per-
formance Superscalar processors increase, the amount
of speculative work due to branch prediction becomes
much larger. Since all such work must be t brown away
if the prediction is incorrect, an excellent branch pre-
dictor is vital to delivering the potential performance of
a wide-issue, deep pipelined microarchitecture. Even a
Permlsslon to copy without fee all or part of this material is granted
provided that the copies are not made or dntrlbuted for dmect commercial
advantage, the ACM copyright notice and the title of the pubhcat[on and
Its date appear, and notice is given that copying IS by percussion of the
Association for Computmg Machinery. To copy otherwise, or to repubhsh,
requires a fee and/or specific perrnlsslon.
prediction miss rate of 5 percent results in a substantial
loss in performance due to the number of instructions
fetched each cycle and the number of cycles these in-
structions are in the pipeline before an incorrect branch
prediction becomes known.
The literature is full of suggested branch prediction
schemes [6, 13, 14, 17], Some are static in that they use
opcode information and profiling statistics to make pre-
dictions. Others are dynamic in that they use run-time
execution history to make predictions. Static schemes
can be as simple aa always predicting that the branch
will be taken, or can be based on the opcode, or on the
direction of the branch, as in “if the branch is backward,
predict taken, if forward, predict not taken” [17]. This
latter scheme is effective for loop intensive code, but
does not work well for programs where the branch be-
havior is irregular. Also, profiling [6, 13] can be used to
predict branches by measuring the tendency of a branch
on sample data sets and presetting a static prediction
bit in the opcode according to that tendency. Unfor-
tunately, branch behavior for the sample data may be
very different from the data that appears at run-time.
Dynamic branch prediction also can be as simple as in
keeping track only of the last execution of that branch
instruction and predicting the branch will behave the
same way, or it can be elaborate as in maintaining
very large amounts of history information. In all cases,
the fact that the dynamic prediction is being made on
the basis of run-time history information implies that
substantial additional hardware is required. J. Smith
[17] proposed utilizing a branch target buffer to store,
for each branch, a two-bit saturating up-down counter
which collects and subsequently bases its prediction on
branch history information about that branch. Lee and
A. Smith proposed [14] a Static Training method which
uses statistics gathered prior to execution time coupled
with the history pattern of the last k run-time execu-
tions of the branch to make the next prediction as to
which way that branch will go. The major disadvantage
of Static Training methods has been mentioned above
with respect to profiling; the pattern history statistics
gathered for the sample data set may not be applicable
to the data that appears at run-time.
In this paper we propose a new dynamic branch pre-
dictor that achieves substantially higher accuracy than
any other scheme reported in the literature. The mech-
anism uses two levels of branch history information to
make predictions. The first level is the history of the
@ 1992 ACM 0.89791 .509.7/92/0005/0124 $1.50 124last k branches encountered. (Variations ofour scheme
reflect whether this means the actual last k branches en-
countered, or the last k occurrences of the same branch
instruction.) The second level is the branch behavior
for the last s occurrences of the specific pattern of these
k branches. Prediction is based on the branch behavior
for the last s occurrences of the pattern in question.
For example, suppose, for k = 8, the last k branches
had the behavior 11100101 (where 1 represents that the
branch waa taken, O that the branch was not taken).
Suppose further that s = 6, and that in each of the last
six times the previous eight branches had the pattern
11100101, the branch alternated between taken and not
taken. Then the second level would contain the history
101010. Our branch predictor would predict “taken.”
The history information for level 1 and the pattern
information for level 2 are collected at run time, elimi-
nating the above mentioned disadvantages of the Static
Training method. We call our method Two-Level Adap-
tive Branch Prediction. We have identified three vari-
ations of Two-Level Adaptive Branch Prediction, de-
pending on how finely we resolve the history informa-
tion gathered. We compute the hardware costs of im-
plementing each of the three variations, and use these
costs in evaluating their relative effectiveness.
Using trace-driven simulation of nine of the ten SPEC
benchmarks 1, we measure the branch prediction ac-
curacy of the three variations of Two-Level Adaptive
Branch Prediction, along with several other popular
proposed dynamic and static prediction schemes. We
measure the effectiveness of different prediction algo-
rithms and different amounts of history and pattern
information. We measure the costs of each variation
to obtain the same prediction accuracy. Finally we
compare the Two-Level Adaptive branch predictors to
the several popular schemes available in the literature.
We show that the average prediction accuracy for Two-
Level Adaptive Branch Prediction is about 97 percent,
while the other schemes achieve at most 94.4 percent
average prediction accuracy.
This paper is organized in six sections. Section two
introduces our Two-Level Adaptive Branch Prediction
and its three variations. Section three describes the cor-
responding implementations and computes the associ-
ated hardware costs. Section four discusses the Simula-
tion model and traces used in this study. Section five
reports the simulation results and our analysis. Section
six contains some concluding remarks.
2 Definition of Two-Level Adaptive Branch
Predict ion
2.1 Overview
Two-Level Adaptive Branch Prediction uses two levels
of branch history information to make predictions. The
first level is the history of the last k branches encoun-
tered. (Variations of our scheme reflect whether this
1The N=a7 benbmk was not simulated because this bench-
mark consists of seven independent loops. It takes too long to
simulate the branch behavior of these seven kernels, so we omit-
ted these loops.
means the actual last k branches encountered. or the
last k occurrences of the same branch instruction.) The
second level is the branch behavior for the last s oc-
currences of the specific pattern of these k branches.
Prediction is based on the branch behavior for the IIast
s occurrences of the pattern in question.
To maintain the two levels of information, Two-Level
Adaptive Branch Prediction uses two major’data struc-
tures, the branch history register (HR) and the pattern
history table (PHT), see Figure 1. Instead of accumu-
lating statistics by profiling programs, the information
on which branch predictions are based is collected at
run-time by updating the contents of the history regis-
ters and the pattern history bits in the entries of the
pattern history table depending on the outcomes of the
branches. The history register is a k-bit shift register
which shifts in bits representing the branch results of
the most recent k branches.
PatternBiituryTehle (PET)
BrsnchHietory
Pattern
BranehEiitary Register (BHB) 00-.-00 ~
(Shiileft when update) 00.! .....01
Be4ik-k+l .... .....lb.a Bd 00.......10 — i%
7’ : ‘+ *
11 . ..’.. 1 0 Pram
l(s%)
Hietay Sdictirm
““’.~dex : Bi@) ofB
‘*\ :
11.......10
se +J=d(%&)
11....4..11 state
‘lhmition
lb: BrnuhPmlt ofB hgicford
Figure 1: Structure of Two-Level Adaptive Branch F’re-
diction.
If the branch was taken, then a “l” is recorded; if
not, a “O” is recorded. Since there are k bits in the
history register, at most 2k different patterns appear in
the history register. For each of these 2k patterns, there
is a corresponding entry in the pattern history table
which contains branch results for the last s times the
preceding k branches were represented by that specific
content of the history register.
When a conditional branch B is being predicted,
the content of its history register, HR, denoted as
R+kRc_k+l...... R=_I, is used to address the pattern
history table. The pattern history bits SC in the ad-
dressed entry PHTR=_kR=_k+l ......B=_. in the pattern ]his-
tory table are then used for predicting the branch. The
prediction of the branch is
2C = A(sc), (1)
where ~ is the prediction decision function.
After the conditional branch is resolved, the clut-
come R. is shifted left into the history register IfR
in the least significant bit position and is also used
to update the pattern history bits in the pattern lhis-
tory table entry PHTRc_k Rc_k+l ...... Rc_l. After being
125updated, the content of the history register beccmes
&k+l&k+2 . . . . .. R. and the state represented by the
pattern history bits becomes S.+l. The transition of the
pattern history bits in the pattern history table entry
is done by the state transition function 6 which takes
in the old pattern history bits and the outcome of the
branch as inputs to generate the new pattern history
bits. Therefore, the new pattern history bits S.+l be-
come
Sc+l = 6(Sc, RJ. (2)
A straightforward combinational logic circuit is used to
implement the function 6 to update the pattern history
bits in the entries of the pattern history table. The tran-
sition function b, predicting function J, pattern history
bits S and the outcome R of the branch comprise a
finite-state Moore machine, characterized by equations
1 and 2.
State diagrams of the finite-state Moore machines
used in this study for updating the pattern history in
the pattern history table entry and for predicting which
path the branch will take are shown in Figure 2. The
automaton Last- Time stores in the pattern history only
the outcome of the last execution of the branch when
the history pattern appeared. The next time the same
history pattern appears the prediction will be what hap-
pened last time. Only one bit is needed to store that
pattern history information. The automaton Al records
the results of the last two times the same history pat-
tern appeared. Only when there is no taken branch
recorded, the next execution of the branch when the
history register has the same history pattern will be
predicted as not taken; otherwise, the branch will be
predicted as taken. The automaton A2 is a saturating
up-down counter, similar to the automaton used in J.
Smith’s branch target buffer design for keeping branch
history [17].
Automaton Lae&Time (LT) AtinmtaI Al Atizmatnn M!
ma S=.”-.”e u.- cod..>
Automaton A3 Automaton A4
Fimre 2: State diamams of the finite-state Moore ma-
ch~nes used for mak~ng prediction and updating the pat-
tern history table entry.
In J. Smith’s design the 2-bit saturating up-down
counter keeps track of the branch history of a certain
branch. The counter is incremented when the branch
is taken and is decremented when the branch is not
taken. The branch path of the next execution of the
branch will be predicted as taken when the counter value
is greater than or equal to two; otherwise, the branch
will be predicted as not taken. In Two-Level Adap-
tive Branch Prediction, the 2-bit saturating up-down
counter keeps track of the history of a certain history
pattern. The counter is incremented when the result of
a branch, whose history register content is the same as
the pattern history table entry index, is taken; other-
wise, the counter is decremented. The next time the
branch has the same history register content which ac-
cesses the same pattern history table entry, the branch is
predicted taken if the counter value is greater or equal
to two; otherwise, the branch is predicted not taken.
Automata A3 and A4 are variations of A2.
Both Static Training [14] and Two-Level Adaptive
Branch Prediction are dynamic branch predictors, be-
cause their predictions are based on run-time informa-
tion, i.e. the dynamic branch history. The major dif-
ference between these two schemes is that the pattern
history information in the pattern history table changes
dynamically in Two-Level Adaptive Branch Prediction
but is preset in Static Training from profiling. In Static
Training, the input to the prediction decision function,
A, for a given branch history pattern is known before
execution. Therefore, the output of A is determined be-
fore execution for a given branch history pattern. That
is, the same branch predictions are made if the same
history pattern appears at different times during execu-
tion. Two-Level Adaptive Branch Prediction, on the
other hand, updates the pattern history information
kept in the pattern history table with the actual results
of branches. As a result, given the same branch his-
tory pattern, different pattern history information can
be found in the pattern history table; therefore, there
can be different inputs to the prediction decision func-
tion for Two-Level Adaptive Branch Prediction. Predic-
tions of Two-Level Adaptive Branch Prediction change
adaptively as the program executes.
Since the pattern history bits change in Two-Level
Adaptive Branch Prediction, the predictor can adjust to
the current branch execution behavior of the program to
make proper predict ions. Wit h these run-time up dat es,
Two-Level Adaptive Branch Prediction can be highly
accurate over many different programs and data sets.
Static Training, on the contrary, may not predict well
if changing data sets brings about different execution
behavior.
2.2 Alternative Implementations of Two-Level
Adaptive Branch Prediction
There are three alternative implementations of the Two-
Level Adaptive Branch Prediction, as shown in Figure
3. They are differentiated as follows:
Two-Level Adaptive Branch Prediction Using a
Global History Register and a Global Pattern
History Table (GAg)
In GAg, there is only a single global history regis-
ter (GHR) and a single global pattern history table
(GPHT) used by the Two-Level Adaptive Branch Pre-
126GAg
Glab.1
—
Slsby
‘IUI1.
UObd
(CWmTJ
%
k-h
bt-Y
L8#hr
Qnmu
PAg
Figure 3: Global view of three variations of Two-Level
Adaptive Branch Prediction.
diction. All branch predictions are based on the same
global history register and global pattern history table
which are updated after each branch is resolved. This
variation therefore is called Global Two-Level Adaptive
Branch Prediction using a global pattern history table
(GAg).
Since the outcomes of different branches update the
same history register and the same pattern history table,
the information of both branch history and pattern his-
tory is influenced by results of different branches. The
prediction for a conditional branch in this scheme is ac-
tually dependent on the outcomes of other branches.
Two-Level Adaptive Branch Prediction Using a
Per-address Branch History Table and a Global
Pattern History Table (PAg)
In order the reduce the interference in the first level
branch history information, one history register is as-
sociated with each distinct static conditional branch to
collect branch history information individually. The his-
tory registers are contained in a per-address branch his-
tory table (PBHT) in which each entry is accessible by
one specific static branch instruction and is accessed by
branch instruction addresses. Since the branch history
is kept for each distinct static conditional branch indi-
vidually and all history registers access the same global
pattern history table, this variation is called Per-address
Two-Level Adaptive Branch Prediction using a global
pattern history table (PAg).
The execution results of a static conditional branch
update the branch’s own history register and the global
pattern history table. The prediction for a conditional
branch is based on the branch’s own history and the
pattern history bits in the global pattern history table
entry indexed by the content of the branch’s history
register. Since all branches update the same pattern
history table, the pattern history interference still exists.
Two-Level Adaptive Branch Prediction Using
Per-address Branch History Table and Per-
address Pattern History Tables (PAp)
In order to completely remove the interference in both
levels, each static branch has its own pattern history ta-
ble a set of which is called a per-address pattern history
table (P PHT). Therefore, a per-address history register
and a per-address pattern history table are associated
with each static conditional branch. All history regis-
ters are grouped in a per-address branch history tab ie.
Since this variation of Two-Level Adaptive Branch Pre-
diction keeps separate history and pattern informatim
for each distinct static conditional branch, it is called
Per-address Two-Level Adaptive Branch Prediction uM-
ing Per-address pattern history tables (PAp).
3 Implementation Considerations
3.1 Pipeline Timing of Branch Prediction and
Information Update
Two-Level Adaptive Branch Prediction requires two se-
quential table accesses to make a prediction. It is dif-
ficult to squeeze the two accesses into one cycle. High
performance requires that prediction be made witbin
one cycle from the time the branch address is known.
To satisfy this requirement, the two sequential accesses
are performed in two different cycles as follows: When~ a
branch result becomes known, the branch’s history reg-
ister is updated. In the same cycle, the pattern history
table can be accessed for the next prediction with the
updated history register contents derived by appending
the result to the old history. The prediction fetched
from the pattern history table is then stored along with
the branch’s history in the branch history table. The
pattern history can also be updated at that time. The
next time that branch is encountered, the prediction is
available as soon as the branch history table is accessed.
Therefore, only one cycle latency is incurred from the
time the branch address is known to the time the pre-
diction is available.
Sometimes the previous branch results may not be
ready before the prediction of a subsequent branch takes
place. If the obsolete branch history is used for making
the prediction, the accuracy is degraded. In such a czme,
the predictions of the previous branches can be used to
update the branch history. Since the prediction accu-
racy of Twc-Level Adaptive Branch Prediction is very
high, prediction is enhanced by updating the branch his-
tory speculatively. The update timing for the pattern
history table, on the other hand, is not as critical as that
of the branch history; therefore, its update can be cle-
layed until the branch result is known. With speculative
updating, when a misprediction occurs, the branch his-
tory can either be reinitialized or repaired depending on
the hardware budget available to the branch predictor.
Also, if two instances of the same static branch occur
in consecutive cycles, the latency of prediction can be
reduced for the second branch by using the prediction
fetched from the pattern history table directly.
3.2 Target Address Caching
After the direction of a branch is predicted, there is
still the possibility of a pipeline bubble due to the time
it takes to generate the target address. To eliminate
127this bubble, we cache the target addresses of branches.
One extra field is required in each entry of the branch
history table fordoing this. When abranch is predicted
taken, the target address is used to fetch the following
instructions; otherwise, the fall-through address is used.
Caching the target addresses makes prediction in con-
secutive cycles possible without any delay. This also
requires the branch history table to be accessed by the
fetching address of the instruction block rather than by
the address of the branch in the instruction block being
fetched because the branch address is not known until
the instruction block is decoded. If the address hits in
the branch history table, the prediction of the branch
in the instruction block can be made before the instruc-
tions are decoded. If the address misses in the branch
history table, either there is no branch in the instruction
block fetched in that cycle or the branch history infor-
mation is not present in the branch history table. In this
case, the next sequential address is used to fetch new in-
st ruct ions. After the instructions are decoded, if t here is
a branch in the instruction block and if the instruction
block address missed in the branch history table, static
branch prediction is used to determine whether or not
the new instructions fetched from the next sequential
address should be squashed.
3.3
F’Ag
Per-address Branch History Table Imple-
ment at ion
and PAp branch predictors all use per-address
branch history tables in their structure. It is not fea-
sible to have a branch history table large enough to
hold all branches’ execution history in real implemen-
t ations. Therefore, a practical approach for the per-
address branch history table is proposed here.
The per-address branch history table can be imple-
mented as a set-associative or direct-mapped cache. A
fixed number of entries in the table are grouped together
as a set. Within a set, a Least-Recently-Used (LRU) al-
gorithm is used for replacement. The lower part of a
branch address is used to index into the table and the
higher part is stored as a tag in the entry associated
with that branch. When a conditional branch is to be
predicted, the branch’s entry in the branch history ta-
ble is located first. If the tag in the entry matches the
accessing address, the branch information in the entry
is used to predict the branch. If the tag does not match
the address, a new entry is allocated for the branch.
In this study, both the above practical approach and
an Ideal Branch History Table (IBHT), in which there
is a history register for each static conditional branch,
were simulated for Two-Level Adaptive Branch Predic-
tion. The branch history table was simulated with four
configurations: 4-way set-associative 512-entry, 4-way
set-associative 256-entry, direct-mapped 512-entry and
direct-mapped 256-entry caches. The IBHT simulation
data is provided to show the accuracy loss due to the
history interference in a practical branch history table
implement ations.
3.4 Hardware Cost Estimates
The chip area required for a run-time branch predic-
tion mechanism is not inconsequential. The following
hardware cost estimates are proposed to characterize
the relative costs of the three variations. The branch
history table and the pattern history table are the two
major parts. Detailed items include storage space for
keeping history information, prediction bits, tags, and
LRU bits and the accessing and updating logic of the
tables. The accessing and updating logic consists of
comparators, MUXes, LRU bits incrementors, and ad-
dress decoders for the branch history table, and address
decoders and pattern history bit update circuits for the
pattern history table. The storage space for caching tar-
get addresses is not included in the following equations
because it is not required for the branch predictor.
Assumptions of these estimates are:
There are a address bits, a subset of which is used
to index the branch history table and the rest are
stored as a tag in the indexed branch history table
entry.
In an entry of the branch history table, there are
fields for branch history, an address tag, a predic-
tion bit, and LRU bits.
The branch history table size is h.
The branch history table is 2~-way set-associative.
Each history register contains k bits.
Each pattern history table entry contains s bits.
Pattern history table set size is p. (In PAp, p is
equal to the size of the branch history table, h, while
in GAg and PAg, p is always equal to one.)
C., 6’d, C., Cm, Csh, Ci, and C. are the constant
base costs” for the storage, the decoder, the com-
parator, the multiplexer, the shifter, the incremen-
tor, and the finite-state machine.
Furthermore, i is equal to log2h and is a non-negative
integer. When there are k bits in a history register, a
pattern history table always has 2h entries.
The hardware cost of Two-Level Adaptive Branch
Prediction is as follows:
cost.5.cheme(BHz’( h,j, k),p x PHT(2k, s))
= CCJStBJI~(h, j, k) + ~ X f30StPWT(2k, S)
= {BHTstcwageasPcace + BHTACCe.mg.LOgtC +
BHT~P~ating-~ogtc} +P x {PHTstomgeJpace +
PHTAc.e.,in9_Logtc + PHTupdattng_z.og ic)
= {[~ x (~w?f.-t+,)-b,t + H&btt + Predictzorz-BitI_w
+LRU-Bits,Jzt)] +
[1 x Address-Decoder,~,t +2’ x
Comparators(.-i+ Jj_b,t + 1 X 2Jxl-Muxk-b,t] i-
[h X sh2f~eTkJit i- ’2’ X LRU.Incrementorsj_b, t]} +
p X {[2k X ~iStOT@itS.-b,t] +
[1 x /iddress-~ecoderkAit] + [State-updater.-b, t]}
128= {hx[(a–i+j) +k+l+j]xcs+
[hxc. +2’x(a– a+j)xcc+2’xkxcm]+
[h XkXC,g. +2’ XjXCi]} +~X{[2k X. XC.]+
[2’ x Cd]+ [s x 2s+’ x Ca]}, a +j > i. (3)
In GAg, only one history register and one global pat-
tern history table are used, so h and p are both equal to
one. No tag and no branch history table accessing logic
are necessary for the single history register. Besides,
pattern history state updating logic is small compared
to the other two terms in the pattern history table cost.
Therefore, cost estimation function for GAg can be sim-
plified from Function 3 to the following Function:
costGAg(BHT(l, , k), 1 x PHT(2~, s))
= COStBHT(l, , k) + 1 X COS~PHT(2k, S)
& {[k+l]xc, +k xc,,}+
{2’ x($ x C.+c,)} (4)
It is clear to see that the cost of GAg grows exponen-
tially with respect to the history register length.
In PAg, only one pattern history table is used, so p
is equal to one. Since j and s are usually small com-
pared to the other variables, by using Function 3, the
estimated cost for PAg using a branch history table is
as follows:
costp&(BHT(h, j, k), 1 x PHT(2’, s))
= COStBHT(h, j, k) + 1 X cOStPHT(2k, S)
H {hx[(a+2x j+k+l-i)x C.+ Cd+
~ x Csh]} +
{2k X( SXCS+C~)}, a+j~i. (5)
The cost of a PAg scheme grows exponentially with
respect to the history register length and linearly with
respect to the branch history table size.
In a PAp scheme using a branch history table as de-
fined above, h pattern history tables are used, so p is
equal to h. By using Function 3, the estimated cost for
PAp is as follows:
costp,4p(BHT(h, j, k), h x PHT(2k, s))
= 6’OS~BHT(h, j, k) + h X COS~PHT(2k, S)
E {hx[(a+2x j+k+l–i)xc, +cd+
k x Csh]} +
h x {2’ x (s x c, +Cd)}, a+j>i. (6)
When the history register is sufficiently large, the cost
of a PAp scheme grows exponentially with respect to the
history register length and linearly with respect to the
branch history table size. However, the branch history
table size becomes a more dominant factor than it is in
a PAg scheme.
4 Simulation Model
Trace-driven simulations were used in this study. A Mo-
torola 88100 instruction level simulator is used for gen-
erating instruction traces. The instruction and address
traces are fed into the branch prediction simulator which
decodes instructions, predicts branches, and verifies the
predictions with the branch results to collect statistics
for branch prediction accuracy.
4.1 Description of Traces
Nine benchmarks from the SPEC benchmark suite are
used in this branch prediction study. Five are float-
ing point benchmarks and four are integer benchmarks.
The floating point benchmarks include doduc, fpppp,
matrix300, spice2g6 and tomcatv and the integer ones
include eqntott, espresso, gee, and li. Nasa7 is not in-
cluded because it takes too long to capture the branch
behavior of all seven kernels.
Among the five floating point benchmarks, ~pppp,
matrix300 and tomcatv have repetitive loop execution;
thus, a very high prediction accuracy is attainable, in-
dependent of the predictors used. Doduc, spice2g6 and
the integer benchmarks are more interesting. They have
many conditional branches and irregular branch behav-
ior. Therefore, it is on the integer benchmarks where a
branch predictor’s mettle is tested.
Since this study of branch prediction focuses on the
prediction for conditional branches, all benchmarks
were simulated for twenty million conditional branch
instructions except gcc which finished before twenty
million conditional branch instructions are executed.
Fpppp, matrix300, and tomcatv were simulated for lC)O
million instruction because of their regular branch be-
havior through out the programs. The number of static
conditional branches in the instruction traces of the
benchmarks are listed in Table 1. History register hit
rate usually depends on the number of static branches
in the benchmarks. The testing and training data sets
for each benchmark used in this study are listed in Table
2.
II
Benchmark Number of Benchmark Number of “
Static Static n
II tomcatv 370 IJ
Table 1: Number of static conditional branches in each
benchmark.
Benchmark
Name
eqntott
espresso
gcc
Xhsp
doduc
fpppp
matrix300
spice2g6
tomcatv
Cps
cexp.i
tower of hanoi
tiny doducin
NA
NA
short greycode.in
NA
bca-
dbxout.i
eight queens
doducin
natoms
Built-in
greycode.in
Built-in
Table 2: Training and testing data sets of benchmarks.
129In the traces generated with the testing data sets,
about 24 percent of the dynamic instructions for the
integer benchmarks and about 5 percent of the dy-
namic instructions for the floating point benchmarks
are branch instructions. Figure 4 shows about 80 per-
cent of the dynamic branch instructions are conditional
branches; therefore, the prediction mechanism for con-
ditional branches is the most important among the pre-
diction mechanisms for different classes of branches.
-C B-h Idrwtion Distribution
1
~ 9s.. Frm .Suh hst
ElIm Smlwh h!
n Junv Fnc.ilw Iml
q Cadnc.ml Bmti 1.s1
Figure 4: Distribution of dynamic branch instructions.
4.2 Characterization of Branch Predictors
The three variations of Two-Level Adaptive Branch
Prediction were simulated with several configura-
tions. Other known dynamic and static branch
predictors were also simulated. The configura-
tions of the dynamic branch predictors are shown
in Table 3. In order to distinguish the different
schemes we analyzed, the following naming conven-
tion is used: Scheme( History( Size, Associativity,
Entry-Content), Pattern.TableSet-.Size x Pattern(
Size, Entry-Content), ConteztSwitch). If a predictor
does not have a certain feature in the naming conven-
tion, the corresponding field is left blank.
Scheme specifies the scheme, for example, (lAg,
PAg, PAp or Branch Target Buffer design (BTB)
[17]. In History( Size, Associativity, EntrgX’ontent),
History is the entity used to keep history information
of branches, for example, HR (A single history register),
IBHT, or BHT. Size specifies the number of entries in
that entity, Associativity is the associativity of the ta-
ble, and Entry_Content specifies the content in each
branch history table entry. When Associativity is set
to 1, the branch history table is direct-mapped. The
content of an entry in the branch history table can be
any automaton shown in Figure 2 or simply a history
register.
In Pattern-Table-Set-Size Pattern(
Size, Entry-Cent ent ), Pattern_Table?Set_ Size is the
number of pattern history tables used in the scheme,
Pattern is the implementation for keeping pattern his-
tory information, Size specifies the number of entries in
the implementation, and Entry_Content specifies the
content in each entry. The content of an entry in the
pattern history table can be any automaton shown in
Figure 2. For Branch Target Buffer designs, the Pattern
part is not included, because there is no pattern history
information kept in their designs. Context_Switch is
a flag for context switches. When Cent extS’wit ch is
specified aa c, context switches are simulated. If it is
not specified, no context switches are simulated.
Since there are more taken branches than not taken
branches according to our simulation results, a history
register in the branch history table is initialized to all 1‘s
when a miss on the branch history table occurs. After
the result of the branch which causes the branch history
table miss is known, the result bit is extended through-
out the history register. A context switch results in
flushing and reinitialization of the branch history table.
Mod.]
Name
GAg(HK(l, ,,.s,),
1 X PHT(2r ,A2),[c])
PAs(BHT (256,1, r-sr),
1 X PHT(2” ,A2),[c])
PA~(BHT(256,4, wr),
1 XPHT(2r ,A2),[c])
PAs(BHT(512,1, r-sr),
1 X PHT(2r ,A2), [c])
PAs(BHT( 512,4,,-s,),
1 X PHT(2r ,Al),[c])
PAg(BHT(512,4,Mr),
1 xPHT(2” ,A2),[c])
PAs(BHT(512,4,,. s.),
1x PHT(22r,A3),[c])
PA~(BHT(512>4,r-st),
1 XPH’1’(2r ,A4), [c])
pAg(BHT (512,4, r-Sr),
1 X PHT(2r ,LT),[c])
PAg(l BHT(inf, ,xsr),
J.i)
BTB(BHT(512,4,LT),
J.])
# of
Er,tr.
1
256
256
512
51’2
512
512
512
512
512
1
512
512
512
—
r co
As.
—
1
4
1
4
4
4
4
4
7
—
4
T
4
—
~
Ed,y
Comt
r-bit
S,
r-bit
**
r-bit
S,
r. bit
,,
r-bit
s,
r-bit
s,
r-bit
s,
r-bit
,,
r-bit
s,
r-bit
S,
r-bit
S*
r-bit
S,
73K
s
At III
A2
Aim
LT
PHT
set
Size
1
1
1
1
1
1
1
1
1
1
512
1
1
PHT
# of
!3ni,.
2T
2’
2r
2r
2,
2“
2.
2“
~.
2r
2“
2“
2P
.mfig.
Entry
Cent
At m
A2
A*JII
AZ
Atm
A2
At m
A2
Aim
Al
At m
A2
Aim
AS
Atm
A4
A* III
LT
Atm
A2
Atui
A2
PB
PB
Asc – Table Set-A ssociativxty, Atm – Automaton, BHT – Branch
H%story Table, BTB – Branch Target Buffer Des8gn, Config. –
Configuration, Entr. – Entr8es, GAg – Global Two-Level Adapttve
Branch Predactaon Ustng a Global Pattern H8story Table, GSg -
Global Stattc Tra$nmg Ustng a Preset Global Pattern H8story Ta.
ble, IBHT - Idea/ Branch Hwtory Tab/e, inf - Infin$te, LT - Last.
Tame, PAg - Per-address Two-Level Adapt%ue Branch Prediction
Us$ng a Global Pattern H%story Table, PAP – Per-address Two-
Level Adaptsve Branch Predation Us$ng Per-address Pattern Hzs-
tory Tables, PB - Preset Predzctzon Bzt, PSg - Per-address Stattc
Training Using a Preset Global Pattern History Table, PHT – Pat-
tern History Table, sr - Shaft Register.
Table 3: Configurations of simulated branch predictors.
The pattern history bits in the pattern history table
entries are also initialized at the beginning of execution.
Since taken branches are more likely for those pattern
history tables using automata Al, A2, A3, and A4, all
entries are initialized to state 3. For Last-Time, all en-
tries are initialized to state 1 such that the branches at
130the beginning of execution will be more likely to be pre-
dicted taken. It is not necessary to reinitialize pattern
history tables during execution.
In addition to the Two-Level Adaptive schemes, Lee
and A. Smith’s Static Training schemes, Branch Tar-
get Buffer designs, and some dynamic and static branch
prediction schemes were simulated for comparison pur-
poses. Lee and A. Smith’s Static Training scheme is sim-
ilar in structure to the Per-address Two-Level Adaptive
scheme with an IBHT but with the important difference
that the prediction for a given pattern is pre-determined
by profiling. In this study, Lee and A. Smith’s Static
Training is identified as PSg, meaning per-address Static
Training using a global preset pattern history table.
Similarly, the scheme which has a similar structure to
GAg but with the difference that the second-level pat-
tern history information is collected from profiling is
abbreviated PSg, meaning Global Static Training using
a preset global pattern history table. Per-address Static
Training using per-address pattern history tables (PSp)
is another application of Static Training to a different
structure; however, this scheme requires a lot of storage
to keep track of pattern behavior of all branches stati-
cally. Therefore, no PSp schemes were simulated in this
study. Lee and A. Smith’s Static Training schemes were
simulated with the same branch history table configu-
rations as used by the Two-Level Adaptive schemes for
a fair comparison. The cost to implement Static Train-
ing is not less expensive than the cost to implement the
Two-Level Adaptive Scheme because the branch history
table and the pattern history table required by both
schemes are similar. In Static Training, before program
execution starts, extra time is needed to load the preset
pattern prediction bits into the pattern history table.
Branch Target Buffer designs were simulated with
automata A2 and Last-Time. The static branch pre-
diction schemes simulated include the Always Taken,
Backward Taken and Forward Not Taken, and a pro-
filing scheme. Always Taken scheme predicts taken for
all branches. Backward Taken and Forward Not Taken
(BTFN) scheme predicts taken if a branch branches
backward and not taken if the branch branches for-
ward. The BTFN scheme is effective for loop-bound
programs, because it mispredicts only once in the exe-
cution of a loop. The profiling scheme counts the fre-
quency of taken and not-taken for each static branch
in the profiling execution. The predicted direction of
a branch is the one the branch takes most frequently.
The profiling information of a program executed with a
training data set is used for branch predictions for the
program executed with testing data sets, thus calculat-
ing the prediction accuracy.
5 Branch Prediction Simulation Results
Figures 5 through 11 show the prediction accuracy of
the branch predictors described in the previous session
on the nine SPEC benchmarks. “Tot GMean” is the ge-
ometric mean across all the benchmarks, “Int GMean”
is the geometric mean across all the integer benchmarks,
and “FP GMean” is the geometric mean across all the
floating point benchmarks. The vertical axis shows the
prediction accuracy scaled from 76 percent to 100 per-
cent.
5.1 Evaluation of the Parameters of the TWID-
Level Adaptive Branch Prediction Branch
Prediction
The three variations of Two-Level Adaptive Branch
Prediction were simulated with different history regjs-
ter lengths to assess the effectiveness of increasing the
recorded history length. The PAg and PAp schemes
were each simulated with an ideal branch history ta-
ble (IBHT) and with practical branch history tables to
show the effect of the branch history table hit ratio.
5.1.1 Effect of Pattern History Table Automa-
ton
Figure 5 shows the efficiency of using different finite-
state automata. Five automata Al, A2, A3, A4, and
Last- Time were simulated with a PAg branch predic-
tor, having 12-bit history registers in a four-way set-
associative 512-entry BHT. Al, A2, A3, and A4 all per-
form better than Last- Time. The four-state automata
Al, A2, A3, and A4 maintain more history information
than Last- Time which only records what happened the
last time; they are therefore more tolerant to the devi-
ations in the execution history. Among the four-state
automata, Al performs worse than the others. The per-
formance of A2, A3, and A4 are very close to each other;
however, A2 usually performs best. In order to show
the following figures clearly, each Two-Level Adaptive
Scheme is shown with automaton A2.
ho.laml AdsPU. kin. U- DifArd Mb Tmmi!4mAnkmmta
0 9s00 ~
c
;08000. --------------------------- ------ .--..,. -----------
a I I
t
c00400 ----------------------------------------------------------- Y
—
-——U— P~( BHT(512,4,12m’\
PliT(2.12,LllJ
- .+ -. P*( 8HT(512,4,12s’k
PHT(’2W2J1 )J
–– 4–- P~( BHT(512,4,12sJ
PnT(m2A2),)
‘e P~( S14T(512,4,12H’~
Plil(’?l Z.Ml)
— PM BliT(51Z4,12m’~
PHT(2w2#\}
—
Becchmalk
Fimre 5: Comparison of Two-Level Adaptive Branch
Pr~dictors usin~ different finite-state auto~lata.
5.1.2 Effect of History Register Length
Three variations using history registers of the
same length
Figure 6 shows the effects of history register length on
the prediction accuracy of Two-Level Adaptive schemes.
Every scheme in the graph waa simulated with the samle
history register length. Among the variations, PAp per-
forms the best, PAg the second, and GAg the worst.
131GAg is not effective with 6-bit history registers, because
every branch updates the same history register, causing
excessive interference. PAg performs better than GAg,
because it has a branch history table which reduces the
interference in branch history. PAp predicts the best,
because the interference in the pattern history is re-
moved.
~of-bpu”-.s sillabktoiymahhrdtb-kn aih
t Qooo
cmm
Y
O.moo
— PIG BHl(51a,4,aaL
ZifPHT(M,A2k) I
Figure 6: Comparison of the Two-Level Adaptive
schemes using history registers of the same length.
Effects of various history register lengths
To further investigate the effect of history register
length, Figure 7 shows the accuracy of GAg with var-
ious history register lengths. There is an increase of 9
percent in accuracy by lengthening the history register
from 6 bits to 18 bits. The effect of history register
length is obvious on GAg schemes. The history regis-
ter len~th has smaller effect on PAiz schemes and even
smaller effect on PAp schemes because of the less inter-
ference in the branch history and pattern history and
their effectiveness with short history registers.
A
~ O.azoo
c
“ O.aaoo
a
c0 Moo
!
O.aooo
....J3.... @# BHql,.Mw~
PHT(N4J2L] I
Ben&mark
Figure 7: Effect of various history register lengths on
GAg schemes.
5.1.3 Hardware Cost Efficiency of Three Vari-
at ions
In Figure 6, prediction accuracy for the schemes with
the same history register length were compared. How-
ever, the various Two-Level Adaptive schemes have dif-
ferent costs. PAp is the most expensive, PAg the second,
and GAg the least, as you would expect. When evaluat-
ing the three variations of Two-Level Adaptive Branch
Prediction, it is useful to know which variation is the
least expensive when they predict with approximately
the same accuracy.
Figure 8 illustrates three schemes which achieve about
97 percent prediction accuracy. One scheme is chosen
for each variation to show the variation’s configuration
requirements to obtain that prediction accuracy. To
achieve 97 percent prediction accuracy, GAg requires an
18-bit history register, PAg requires 12-bit history regis-
ters, and PAp requires 6-bit history registers. According
to our cost estimates, PAg is the cheapest among these
three. GAg’s pattern history table is expensive when a
long history register is used. PAp is expensive due to
the-required multiple pattern history tables.
/m
~+’+~......~%:x~-...- ............-
~ O,azoo -.----...-.......-.-.:. ---. --. --, ---------------------------
O.a+oo
0.7800
Banchmafk
----0---- t&+# BHq,m,w\
PHT(2vBA2L]
- .+ -- PM Bli-r[51~,a@,
2wPHl(afA2).)
.- -A.... PN[ BHT[51z4,1w
?HT(&12&),)
Figure 8: The Two-Level Adaptive schemes achieve
about 97 percent prediction accuracy.
5.1.4 Effect of Context Switch
Since Two-Level Adaptive Branch Prediction uses the
branch history table to keep track of branch history, the
table needs to be flushed during a context switch. Fig-
ure 9 shows the difference in the prediction accuracy
for three schemes simulated with and without context
switches. During the simulation, whenever a trap oc-
curs in the instruction trace or every 500,000 instruc-
tions if no trap occurs, a context switch is simulated.
After a context switch, the pattern history table is not
re-initialized, because the pattern history table of the
saved process is more likely to be similar to the current
process’s pattern history table than to a re-initialized
pattern history table. The value 500,000 is derived
by assuming that a 50 MHz clock is used and context
switches occur every 10 ms in a 1 IPC machine. The
average accuracy degradations for the three schemes are
132all less than 1 percent. The accuracy degradations for
gccwhen PAgand PAp are used aremuch greater than
those of the other programs because of the large num-
ber of traps in gee. However, the excessive number of
traps do not degrade the prediction accuracy of the GAg
scheme, because an initialized global history register can
be refilled quickly. The prediction accuracy of ~pppp
using GAg actually increases when context switches are
simulated. There are very few conditional branches in
.fPPPP and all the conditional branches have regular be-
havior; therefore, initializing the global history register
helps clear out the noise.
-of aati titi
1 0000
0.9600
~ 0 eon
c
c
: 8.=00
a
c
y O,Moo
0 Moo
07600
Tot Int eqntott WIOW gcc ZI,sp P &-ic fpppp matm SPIM t.mcaw
Q&ma&al o rMm 300 29s
Figure
racy.
5.1.5
Benchmark
9: Effect of context switch on prediction accu-
Effect of Branch History Table Imple-
ment at ion
Figure 10 illustrates the effects of the size and associa-
tivity of the branch history table in the presence of con-
text switches. Four practical branch history table imple-
mentations and an ideal branch history table were sim-
ulated. The four-way set-associative 512-entry branch
history table’s performance is very close to that of the
ideal branch history table, because most branches in the
programs can fit in the table. Prediction accuracy de-
creases as table miss rate increases, which is also seen
in the PAp schemes.
5.2 Comparison of Two-Level Adaptive Branch
Prediction and Other Prediction schemes
Figure 11 compares the branch prediction schemes. The
PAg scheme which achieves 97 percent prediction ac-
curacy is chosen for comparison with other well-known
schemes, because it costs the least among the three vari-
ations of Two-Level Adaptive Branch Prediction.
The 4-way set-associative 512-entry BHT is selected
to be used by all schemes which keep the first-level
branch history information, because it is simple enough
to be implemented. The Two-Level Adaptive scheme
and the Static Training scheme were chosen on the ba-
sis of similar costs.
The top curve is achieved by the Two-Level Adaptive
scheme whose prediction accuracy is about 97 percent.
? .0000
A
~ O.woa
c
: O.eaoo
a
; 0.0400
c--d-hwti-@-&dhp&
““”””””” ‘
----- . . . :.. r .> ,,
*’> .....Y . . . ..LL..LZ.I.:I: . ..&i . . . .. . .
‘“i$; ““i :~, . .. ........................
‘.[/
...!..,[...
,
t
Owoo . . . .. . . . . .. . . . . . . . . . . . .. . . . . .. . .. . . . . . . . . . . . . . . . . . . . . . . . . . . . .
— P*( lwT@f.,lzsrl,
PHT(212,KI,C)
‘.+ ‘. PA#( 8HT(61a4,12s.~
PHT[2-lW.C)
.+r.-.. P~[ BHT[2f6,4,w14~
PHT[2”12,A2),C)
---0-. P*( c!m(m,l,la.~
?HT(2W,A21,S)
-.-. *..-. P*( BHT(2W,,,,ZS.L
PHT(2”12,A2),C)
Figure 10: Effect of branch history table implementi>-
tion on PAg schemes.
Since the data for the Static Training schemes are nc)t
complete due to the unavailability of appropriate data
sets, the data points for eqntott, fpppp, matrix300 , and
tomcatv are not graphed. PSg is about 1 to 4 percent
lower than the top curve for the benchmarks that are
available and GSg is about 4 to 19 percent lower with av-
erage prediction accuracy of 94.4 percent and 89 percent
individually. Note that their accuracy depends greatly
on the similarities between the data sets used for train-
ing and testing. The prediction accuracy for the branch
target buffer using 2-bit saturating up-down counters
[17] is around 93 percent. The Profiling scheme achieves
about 91 percent prediction accuracy. The branch tar-
get buffer using Last- Time achieves about 89 percent
prediction accuracy. Most of the prediction accuracy
curves of BTFN and Always Taken are below the base
line (76 percent). BTFN’s average prediction accuracy
is about 68.5 percent and Always Taken’s is about 62.5
percent. In this figure, the Two-Level Adaptive scheme
is superior to the other schemes by at least 2.6 percent.
Cb#mnd- PNdidh *O
10000
0 Moo
A
~ 09200
c
; 06900
a
cOMOO Y
o woo
0,7800
— P*( WT[slmlhrk
PHT(2-12M}
. ...4...- q[ BH~l.ls@.
PHT(2”1 B,F9),)
--0-- P~[ W(61~4,12$,~
PHT(2,12, M),)
— 9m( BHT($I2,4,LT),)
--# — Brn( WT(N 2,4,A2)J
—— F.ro,dt,g
-. -*- BTm (m.w]
–.+-. MPlh(am$)
Figure 11: Comparison of branch prediction schemes.
1336 Concluding Remarks
In this paper we have proposed a new dynamic branch
predictor (Two-Level Adaptive Branch Prediction) that
achieves substantially higher accuracy than any other
scheme that we are aware of. We computed the hard-
ware costs of implementing three variations of this
scheme and determined that the most effective imple-
mentation of Two-Level Adaptive Branch Prediction
utilizes a per-address branch history table and a global
pattern history table.
We have measured the prediction accuracy of the
three variations of Two-Level Adaptive Branch Pre-
diction and several other popular proposed dynamic
and static prediction schemes using trace-driven sim-
ulation of nine of the ten SPEC benchmarks. We have
shown that the average prediction accuracy for Two-
Level Adaptive Branch Prediction is about 97 percent,
while the other known schemes achieve at most 94.4
percent average prediction accuracy.
We have measured the effects of varying the param-
eters of the Two-Level Adaptive predictors. We noted
the sensitivity to k, the length of the history register,
and s, the size of each entry in the pattern history ta-
ble. We reported on the effectiveness of the various
prediction algorithms that use the pattern history table
information. We showed the effects of cent ext swit th-
ing.
Finally, we should point out that we feel our 97 per-
cent prediction accuracy figures are not good enough
and that future research in branch prediction is still
needed. High performance computing engines in the
future will increase the issue rate and the depth of
the pipeline, which will combine to increase further the
amount of speculative work that will have to be thrown
out due to a branch prediction miss. Thus, the 3 per-
cent prediction miss rate needs improvement. We are
examining that 3 percent to try to characterize it and
hopefully reduce it.
Acknowledgments The authors wish to acknowl-
edge with gratitude the other members of the HPS re-
search group at Michigan for the stimulating environ-
ment they provide, and in particular, for their comments
and suggestions on this work. We are also grateful to
Motorola Corporation for technical and financial sup-
port, and to NCR Corporation for the gift of an NCR
Tower, Model No. 32, which was very useful in our
work.
References
[1]
[2]
[3]
T-Y Yeh and Y.N. Patt, “Two-Level Adaptive Branch
Prediction”, Technical Report CSE- TR-11 7-91, Com-
puter Science and Engineering Division, Department
of EECS1 The University of Michigan, (Nov. 1991).
T-Y Yeh and Y.N. Patt, “Two-Level Adaptive Branch
Prediction”, The 24th A CM/IEEE International Sym-
posium and Workshop on Microarchitecture , (Nov.
1991), pp. 51-61.
M. Butler, T-Y Yeh, Y.N. Patt, M. Alsup, H. Scales,
and M. Shebanow, “Instruction Level Parallelism is
[4]
[5]
[6]
[7]
[8]
[9]
[10]
[11]
[12]
[13]
[14]
[15]
[16]
[17]
[18]
Greater Than Two”, Proceedings o.f the 18th Inter-
national Symposium on Computer Architecture, (May.
1991), PP. 276-286.
D. R. Kaeli and P. G. Emma, “Branch History Table
Prediction of Moving Target Branches Due to Subrou-
tine Returns” , Proceedings of the 18th International
Symposium on Computer Architecture, (May 1991), pp.
34-42.
Motorola Inc., “M881OO User’s Manual”, Phoenix, Ari-
zona, (March 13, 1989).
W.W. Hwu, T. M. Conte, and P. P. Chang, “Comparing
Software and Hardware Schemes for Reducing the Cost
of Branchesn, Proceedings of the 16th International
Symposium on Computer Architecture, (May 1989).
N.P. Jouppi and D. Wall, “Available Instruction-Level
Parallelism for Superscalar and Superpipelined Ma-
chines.”, Proceedings of the Third International Con-
ference on Architectural Support for Programming Lan-
guages and operating Systems, (April 1989), pp. 272-
282.
D. J. Lilja, “Reducing the Branch Penalty in Pipelined
Processors “, IEEE Computer, (July 1988), pp.47-55.
W.W. Hwu and Y.N. Patt, “Checkpoint Repair for
Out-of-order Execution Machines”, IEEE Transactions
on Computers, (December 1987), pp.1496-1514.
P. G. Emma and E. S. Davidson, “Characterization of
Branch and Data Dependencies in Programs for Eval-
uating Pipeline Performance” , IEEE Transactions on
Computers, (July 1987), pp.859-876.
J. A. DeRosa and H. M. Levy, “An Evaluation of
Branch Architectures “, Proceedings of the Iith Inter-
national Symposium on Computer Architecture, (June
1987), pp.10-16.
D.R. Ditzel and H.R. McLellan, “Branch Folding in
the CRISP Microprocessor: Reducing Branch Delay to
Zero”, Proceedings of the Ilth International Symposium
on Computer Architecture, (June 1987), pp.2-9.
S. McFarling and J. Hennessy, “Reducing the Cost of
Branches”, Proceedings of the 13th International SYm-
posium on Computer Architecture, (1986), pp.396-403.
J. Lee and A. J. Smith, “Branch Prediction Strategies
and Branch Target Buffer Design”, IEEE Computer,
(January 1984), pp.6-22.
T.R. Gross and J. Hennessy, “Optimizing Delayed
Branches”, Proceedings of the 15th Annual Workshop
on Microprogramming, (Oct. 1982), pp.114-120.
D.A. Patterson and C.H. Sequin, “RISC-I: A Reduced
Instruction Set VLSI Computer”, Proceedings of the
8th International Symposium on Computer Architec-
ture, (May. 1981), pp.443-458.
J.E. Smith, “A Study of Branch Prediction Strate-
gies”, Proceedings of the 8th International Symposium
on Computer Architecture, (May. 1981), pp.135-148.
T. C. Chen, “Parallelism, Pipelining and Computer Ef-
ficiency”, Computer Design, Vol. 10, No. 1, (Jan. 1971),
pp.69-74.
134