JPS62159233A - 命令先取り装置 - Google Patents

命令先取り装置

Info

Publication number
JPS62159233A
JPS62159233A JP32686A JP32686A JPS62159233A JP S62159233 A JPS62159233 A JP S62159233A JP 32686 A JP32686 A JP 32686A JP 32686 A JP32686 A JP 32686A JP S62159233 A JPS62159233 A JP S62159233A
Authority
JP
Japan
Prior art keywords
instruction
branch
address
stage
circuit
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
JP32686A
Other languages
English (en)
Inventor
Toshiteru Shibuya
渋谷 俊輝
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
NEC Corp
Original Assignee
NEC Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by NEC Corp filed Critical NEC Corp
Priority to JP32686A priority Critical patent/JPS62159233A/ja
Priority to US07/000,427 priority patent/US4853840A/en
Priority to DE3752100T priority patent/DE3752100T2/de
Priority to EP87100055A priority patent/EP0229619B1/en
Publication of JPS62159233A publication Critical patent/JPS62159233A/ja
Pending legal-status Critical Current

Links

Landscapes

  • Advance Control (AREA)

Abstract

(57)【要約】本公報は電子出願前の出願データであるた
め要約のデータは記録されません。

Description

【発明の詳細な説明】 〔産業上の利用分野〕 本発明は、情報処理袋πの命令ソーケンスのステップに
含まれる分岐条件判定ステップ実行処理に先立って判定
結果を予測しつつ次の命令の先取りを行なう命令先取り
装置に関する。
〔従来の技術〕
従来、分岐ヒストリテーブルを用いて分岐予測を行なう
命令先取り装置としては、例えば特開昭59−9155
0−M公報に見られる装置が存在する。この従来装置は
分岐命令のアドレスを指定する情報とその分岐命令の分
岐先アドレスを含む分岐情報とを対にして分岐ヒストリ
テーブルに登録しておき、命令先取り動作としてキャッ
シュメモリから命令を取出す時に、先取りする命令のア
ドレスが分岐命令のアドレスとして分岐ヒストリテーブ
ルに登録されているか否かを調べ、登録されていれば対
応する分岐先アドレスを用いて次の命令先取り動作を行
なうよう制御するもので、分岐ヒストリテーブルに登録
された情報が誤っていた場合には、その命令の分岐条件
の判定を行った後に分岐ヒストリテーブルの対応する情
報を更新し、その後に後続の命令の先取りをやり直すよ
う構成されている。
〔発明が解決しようとする問題点] 前記の従来技術においては、頻繁に発生するキャッシュ
メモリの書換え等によって分岐ヒストリテーブルの内容
が古くなって、誤った分岐情報によって先取りが行なわ
れてしまった場合、後続の正しい命令が取出されるのは
、誤った分岐情報を持っていた命令の分岐条件判定ステ
ップが終了した後のこととなり、分岐命令の高速処理を
めざす分岐ヒストリテーブル技術が逆に他の命令の処理
速度の低下を招いてしまうという欠点がある。
本発明はこのような従来の欠点を解消したもので、その
目的は、一連の命令実行処理過程を複数のステージに分
け?31数の命令を同時に連続して実行するパイプライ
ン方式で制御される情報処理システムにおいて、誤った
分岐情報によって先取りが行なわれた場合、速やかに正
しい命令の先取りを開始し得るようにすることにある。
〔問題点を解決するための手段〕
本発明は上記目的を達成するために、一連の命令実行処
理過程を複数のステージに分け、複数の命令を同時に連
続して実行するパイプライン方式で制御される情報処理
システムにおける命令先取り装置において、 分岐命令のアドレスを指定する情報と該分岐命令の分岐
先アドレスを含む分岐情報とを対にして複数対記憶する
分岐ヒストリテーブル手段と、命令先取り動作を行なう
際に該命令先取り動作において先取りされる命令のアド
レスを指定する情報が前記分岐ヒストリテーブル手段に
登録されているか否かを調べる第1の点検手段と、前記
複数のステージにおいて前記先取りされた命令に対応す
る前記分岐情報が正しいか否かを調べる第2の点検手段
と、 上記複数の異なるステージの一部または全部の各々に対
して、当該ステージ以前のステージにおいて前記第2の
点検手段によって生成された点検結果を保持するととも
に、当該ステージの前記第2の点検手段の点検動作を制
御するフリップフロップ群と、 前記第1の点検手段による登録の判明に応答して前記分
岐ヒストリテーブル手段から対応する分岐情報を読出し
該分岐情報に従って命令先取り動作を継続せしめるよう
制御し、且つ、前記第1および第2の点検手段の結果に
応答して誤った命令先取り動作が行なわれた時には前記
先取りされた命令の後続の誤った命令先取り動作を是正
せしめるよう制御する命令先取り制御手段とを備える。
〔作用〕
誤った分岐情報に基づく誤った命令先取り動作が行なわ
れると、これが第2の点検手段で検出され、第1.第2
の点検手段の結果に応答して、命令先取り制御手段は、
先取りされた命令の後続の誤った命令先取り動作を是正
する。
〔実施例〕
次に本発明について図面を参照して詳細に説明する。
第1図を参照すると本発明の一実施例は、命令アドレス
生成回路(IA)401.命令アドレス変換回路(IT
)402、命令解読回路(ID)403、オペランドア
ドレス生成回路(OA)404、オペランドアドレス変
換回路(OT) 405 、オペランド記憶回路を有す
るオペランド読出し回路(OC)406、命令実行回路
(EX) 407 、命令記憶回路(IC)408、命
令ハ、ファ409、分岐ヒストリテーブル(BHT) 
410 、命令アドレスレジスタ411、命令アドレス
加算回B412 、分岐情報バッファ413、命令整列
回路414、分岐情報切換回路415、分岐情報レジス
タ416,417,418,419,420、選択回路
421,422 、命令先取り制御回路423 、OA
Xステージ予測確認回路424、OTステージ予測VI
i認回路425、QCステージ予測確認回路426、E
Xステージ予測確認回路427、命令アドレスリカバレ
ジスタ428、アドレス生成回路430,431,43
2゜比較回路433、レジスタ434,435 、フリ
ップフロップ436,437,438,439,440
,441から構成されている。
なお、命令先取り制御回路423が命令先取り制御手段
を構成し、分岐ヒス) IJ子テーブル10が分岐ヒス
トリテーブル手段及び第1の点検手段*1を構成し、O
AXステージ予測確認回路424 OTステージ予測確
認回路425. OCステージ予測確認回路426およ
びEXステージ予測61認回路427が第2の点検手段
*2を構成し、フリップフロップ436〜440がフリ
ップフロップ群*3を構成する。
命令記憶回路408およびオペランド続出し回路406
内のオペランド記憶回路は共に主記憶装置そのものであ
ってもよく、さらに命令記憶回路408が主記憶装置の
命令部の一部の写しである命令キャッシュメモリ、前記
オペランド記憶回路が主記憶装置のオペランド部の一部
の写しであるオペランドキャッシュメモリとして構成し
ても良い。
本発明は前述の命令の処理単位に対応した装置構成を必
ずしも有する必要はなく、例えば命令アドレス生成回路
401 とオペランドアドレス生成回路404.命令ア
ドレス変換回路402とオペランドアドレス変換回路4
05.命令記憶回路40Bとオペランド続出し回路40
6内の記憶回路が共用されたコンピュータシステムにお
いても通用され得る。
第1図において、分岐ヒストリテーブル(BHT) 4
10は分岐命令のアドレスを指定する情報と該分岐命令
の実行の予測としての分岐成否フラグ(V)と分岐先ア
ドレスとを第3図に示すように対にして記憶している。
命令記憶回路408に対する命令アドレスレジスタ(J
AR)411 は、命令読出しのリクエストアドレスを
保持して命令の読出し動作を実行する。
さらに命令アドレスレジスタ(IAR)411は分岐ヒ
ストリテーブル(BHT)410および命令アドレス加
算回路412に信号vA101を介して接続されている
。レジスタ411の内容は分岐ヒストリテーブル(BH
T)410を索引し、読出されるべき命令のアドレスが
それに登録されているか否かを示す信号を信号線106
に出力する。登録されていれば対応する分岐先アドレス
が信号線105に読出される。登録されていなければ命
令アドレス加算回路412により後続の命令語の命令先
取りのためのアドレスが生成される。
命令アドレス加算回路412は1回のリクエストで読出
される命令語を8Byteと仮定したとき単に”IAR
+8”を出力107に生成する回路である。命令バッフ
ァ409は、命令記憶回路408から読出された8By
teの先取り命令語を蓄積し命令処理部への命令の供給
における待ち行列(Queue)を形成する。命令整列
回路414は、命令バッファ409が空のとき信号線1
02を介して命令記憶回路408から読み出される。8
Byteの命令語に対応して、また命令バッファ4θ9
が空でないとき信号線103を介して前記命令バッファ
に貯えられる8Byteの命令語に対応してそれぞれ命
令を抽出して信号線104を介して命令解読回路403
に命令を供給する回路である。
命令解読回路403は信号線104を介して命令語が与
えられると、その命令語長を信号’h9= 112を介
して分岐情報レジスタ417へ報告するとともに、その
命令が分岐命令(無条件分岐命令1条件分岐命令など分
岐動作を行ない得る命令)であるか否かを信号線113
を介してOAXステージ予測確認回路424輯告し、さ
らに、その命令が無条件分岐命令であるか否かと、計数
分岐命令(B ranch oncount命令:以降
BCT命令と呼ぶ)であるか否かを信号線114を介し
てレジスタ435ヘセントする機能を有する。
分岐情報バッファ413は、命令バッファ409に格納
される命令語に対して用意されておりその命令語中に分
岐成功と予測された分岐命令が存在すれば、第7図に示
す該分岐命令の分岐情報を格納する回路であり、分岐命
令のアドレスは信号線101を介して、また分岐情報と
しての分岐先アドレスおよび■ビットは分岐ヒストリテ
ーブル(BHT)410から信号線105を介してそれ
ぞれセットされ、分岐成功と予測さた分岐命令が存在し
なければ、Vビットは0に、命令アドレスは信号線10
1を介してそれぞれセットされる。
分岐情報切換回路415は、命令バッファ409が空の
とき信号線101および105を介して与えられる前記
分岐情報を、そうでないときは分岐情報バッファ413
を介して与えられる前記分岐情報をそれぞれ出力する。
レジスタ416 、417および418はそれぞれ分岐
命令の各処理ステージに対応し、第8図に示す分岐情報
を保持する。分岐情報レジスタ419 、420はその
分岐先アドレス部を該分岐命令の実行によって生成され
る実際の分岐先アドレスに置き換えて保持するレジスタ
である。
アドレス生成回路430,431.432は、それぞれ
分岐情報レジスタ417,418,420に保持される
分岐命令のアドレスと、該分岐命令自身の命令語長とを
加算して分岐N0GO側の命令の命令アドレスを生成す
る。
オペランドアドレス生成回路404は、命令の指定する
オペランドアドレスを生成するとともに、命令がBCT
命令である場合、そのBCT命令によって指定された汎
用レジスタの保持する計数動作を行なうための値を信号
線120を介乙て比較回路433へ出力する機能を有す
る。
OAステージ予測確認回路424は、命令解読回路40
3で解読した命令が分岐命令でないのに、対応する分岐
情報が分岐ヒストリテーブルから読出されたか否かを検
出する回路であり、信号線113を介して命令の解読結
果を、信号線115を介して分岐情報レジスタ416の
保持するVピントをそれぞれ受取り、分岐命令でないの
にVビットが1である時にはOAステージ予測失敗信号
を信号線121を介して命令先取り制御回路423とフ
リ、ブフロフプ436へ出力する。
比較回路433は、信号線120を介して与えられる計
数値と値“1°を比較し、計数値が1であれば計数値1
信号を信号線123を介してOTステージ予測確認回路
425へ出力する。
OTステージ予測確認回路425は、OAステージ予測
確認回路424の出力するOAステージ予測失敗信号を
保持するフリップフロップ436の出力。
命令が無条件分岐命令であるかBCT命令であるかを保
持するレジスタ435の出力、比較回路433の出力す
る計数値l信号、および分岐情報レジスタ41gの保持
するVビットより、無条件分岐命令なのに対応する分岐
情報の■ビットが0である時、およびBCT命令で且つ
計数値l信号が出力されない即ち分岐を行なう時なのに
対応する分岐情報の■ビットがOである時には、信号線
129を介して命令先取り制御回路423へOTステー
ジ予測失敗信号を、信号線+30を介してフリップフロ
ップ437へ○TステージBHT更新指示信号を、信号
線131を介してフリップフロップ438と選択回路4
21へOTステージGO先取り指示信号をそれぞれ出力
し、BCT命令で且つ計数値l信号が出力された、即ち
、分岐を行なわない時なのに対応する分岐情報の■ビッ
トが1である時には、信号線129と信号線130へそ
れぞれOTステージ予測失敢信号とOTステージBIT
更新指示信号を出力する。
選択回路421は、○Tステージ予測確認回路425の
出力するOTステージGO先取り指示信号が1である時
は命令アドレス変換回路402の出力する分岐先アドレ
スを、0である時はアドレス生成回路431の出力する
分岐N0GO側のアドレスを選を尺する。
OCステージ予測確認回路426は、OTステージBI
T更新指示信号を保持するフリップフロップ437の出
力、OTステージGo先取り指示信号を保持するフリッ
プフロップ438の出力、命令アドレス変換回路402
の出力する分岐先アドレス。
及び分岐情報レジスタ418の保持する予測された分岐
先アドレスと■ビットより、■ビットが1で分岐Goと
予測され、実際の分岐先アドレスと予測された分岐先ア
ドレスが異なっていて更にOTステージ以前で予測の失
敗が検出されていない時には、信号線140を介してO
Cステージ予測失敗信号を命令先取り制御回路423へ
、信号線156を介してフリップフロップ439へOC
ステージBHT更新指示信号を、信号線141を介して
フリップフロップ440へOCステージGO先取り指示
信号をそれぞれ出力する。
EXステージ予測確認回路427は、OCステージBH
T更新指示信号を保持するフリップフロップ439の出
力、oCステージGO先取り指示信号を保持するフリッ
プフロップ440の出力1分岐情報レジスタ419の保
持するVビット、及び命令実行回路407の出力する分
岐成否信号より、実際の分岐成否と■ビットが異なり、
且つ、OCステージ以前の予測失敗の検出にともなう先
取りのやり直しが行なわれていない時には、信号線14
7を介して命令先取り制御回路423へEXステージ予
測失敗信号を、また、信号線14Bを介して同しく命令
先取り制御回路423とフリップフロップ441へEX
ステージBIT更新指示信号を出力する。
選択回路422は分岐成否信号線149の状態に応答し
て該信号線の状態が分岐Goを示すとき、信号線152
を介して与えられる分岐情報レジスタ420の保持する
分岐先アドレスを選択し、分岐N0GOを示す時には信
号線153を介して与えられるアドレス生成回路432
の出力を選択し、その出力を信号線155を介してレジ
スタ434と命令アドレスリカバレジスタ428へ供給
する。
レジスタ434は、分岐予測が失敗した時に、分岐ヒス
トリテーブル(BIT)410を更新するためのもので
あり、命令アドレスリカバレジスタ428は命令アドレ
スレジスタ (JAR)411に分岐ヒストリテーブル
410の内容を更新するためのライトアドレスがセット
された後に命令先取りのための新たなアドレスを供給す
るためのものである。
命令先取り制御回路423は、信号線121,129,
140゜147を介してそれぞれ与えられるOA、OT
、0C,EX各ステージの予測失敗信号、及び信号線1
4Bを介して与えられるEXステージBHT更新指示信
号に基づいて、命令アドレスレジスタ (■AR)41
1の入力と、命令アドレスリカバレジスタ426の入力
とを制御する回路である。
第16図を参照すると、第1図に示す本発明の実施例に
おける命令の処理は、次の8つの処理単位に分けられる
flllAステージ:実行すべき命令アドレス(論理ア
ドレス)が生成される。
(211Tステージ;生成された命令アドレスのアドレ
ス変換が行なわれる。
+311cステージ:変換された命令の実アドレスで記
憶装置から命令が読出さ れる。
+411Dステージ:続出された命令が解読される。
+510Aステージ:解読された命令のオペランドアド
レス(論理アドレス)が 生成される。
(610Tステージ:生成されたオペランドアドレスの
アドレス変換が行なわれ る。
(7) OCステージ:変換されたオペランドの実アド
レスで記憶装置からオペラ ンドが続出される。
f81EXステージ:命令が実行される。
上述のITステージ及びOTステージのアドレス変換に
おいてアドレス変換バッファを設は必要な変換テーブル
が該アドレス変換バッファに存在すれば上記アドレス変
換処理は関連に実行し得る。
また、上述のICステージおよびOCステージの命令お
よびオペランドの読出し動作において主記憶装置のデー
タの一部の写しを保持するキャッシュメモリを設は必要
な命令およびオペランドが該キャッシュメモリに存在す
ればICステージおよびOCステージの処理は高速に行
ない得る。
上述のIT、OTおよびIC,QCの各ステージの真速
処理が可能なとき、複数の命令の処理の流れを無駄なく
実行する8段のパイプライン制御が可能である。
次に分岐ヒストリテーブル(B HT) 410 、 
OA、OT、○C,EX各ステージの予測確認回路42
4 、425.426.427および命令先取り制御回
路423のブロック図とタイムチャートを参照しながら
本実施例の動作を詳細に説明する。
第2図を参照すると分岐ヒストリテーブル(BHT)4
10は、ディレクトリ記憶部501、データ記憶部50
2、テスト回路503,504,505,506 、プ
ライオリティ回路507、レベル選択回路508、およ
びオア回路509を備えている。記憶部501および5
02は、1回のリクエストに対して命令記憶回路408
から読出される命令語の単位をブロックの単位とし、セ
ント数m、レベル数nの記憶部である。
第3図を参照すると、記憶部501には分岐命令の命令
アドレスの一部とその内容が有効か否かを示すVビット
が格納され、記憶部502には分岐先アドレスの実アド
レスが格納されている。前記Vビットは対応する分岐ヒ
ストリテーブル(BHT)410のワードの有効性を示
すと同時に該分岐命令の実行の予測としての分岐成否フ
ラグの機能を有する。
この分岐ヒストリテーブル(BHT)410への索引は
以下のようなセットアソシアティブ法によって行なわれ
る。
第2図に示されるテスト回路503,504,505及
び506はテーブル410の各レベルに対応して命令ア
ドレスレジスタ(TAR)411に保持されるリクエス
トアドレスが各レベルのBHT−AAi  (iはレベ
ルに対応するサフィクスを示す)に登録されているか否
かを示す信号を信号Litl130.1131゜113
2、1133に出力する。第4図を参照すると、テスト
回路503.504 、505および506のそれぞれ
は、−数回路701および大小比較回路702から構成
されている。
前記−数回路701では、命令アドレスレジスタ(IA
R)411に保持されるリクエストアドレスの一部IA
R(: 4−17)をセントアドレスとして読出された
記憶部501の各レベルの内容と前記レジスタ411の
内容IARC: 4−17)とが比較され、等しいアド
レスが存在するか否かを検出する。−数回路701の出
力により命令アドレスレジスフ(IAR)411に保持
されるリクエストアドレスで読出されるべき命令語の8
Byteブロツク中にすでに分岐ヒストリテーブル(B
HT)410に登録された分岐命令が存在するか否かが
判明する。しかしリクエストアドレスとそれが読出すべ
き分岐命令との対応をとるには上記−敗検出のみでは不
十分である。第5図を参照すると、1回のリクエストで
読出される8Byteの命令語のブロック中に2Byt
e命令BCO,A、BCI。
BO2の4個の命令が存在する。命令BCO,BCl、
BO2が共に分岐成功と予測された分岐命令であるとき
には、各々の分岐命令は共にそのアドレスの一部が記憶
部(BHT−AA)501に登録される。このとき他の
分岐命令から命令へに分岐して命令Aのアドレス<A>
が前記命令語のブロックを読出すためのリクエストアド
レスとして命令アドレスレジスタ(IAR)411に保
持されるときには、分岐ヒストリテーブル(ThHT)
41Qから3ノコ出されるべき分岐命令の情報は命令の
実行の経路から分岐命令BCIの情報でなければならな
い。
従って前記レジスタ(IAR)411に保持されるリク
エストアドレスと前記記憶部(BHT−AA i ) 
501に保持される分岐命令のアドレスとの関係が上記
の一致条件とともに次式の関係が成立するとき、対応す
るレベルのBHT−HITi信号が生成される。なお、
この信号は線130〜133を介してオア回路509に
与えられ、Xi B HT −HITi信号のオア信号
がfilOGを介して出力され分岐予測信号(BHT−
HIT信号)となる。
BIIT −111Ti  =  [IAR(:4  
17)  =  BIIT   AAi(=4−17)
 1 0 (IAR(:29,30)  ≦ BIT−Aへ1
(:29,30) 1 n BHT−AAi(V) 再び第4図を参照すると、前記大小比較回路702は、
この条件を実現する回路である。
さらに前記信号BHT−HITiの条件が2(置板上の
レベルにおいて成立したとき記憶部501の対応するレ
ベル(BIT−AA +)に保持される分岐命令のアド
レスの8Byteブロツク内アドレスBHT−AA i
  (:29.30)の値の最も小さいレベルが選択さ
れる必要がある。再び第5図を参照すると、命令BCI
およびBO2の分岐命令関係情報が格納される分岐ヒス
トリテーブル410のレベルで前記信号BHT−HIT
i条件が共に成立する。このとき命令の実行の経路から
命令BC1に対するレベルが選択される必要がある。
前記プライオリティ回路507は、前記信号BHT  
HITiの2個以上の成立に対するものであり、この出
力により記憶部BHT−DA502のセントアドレス]
ΔR(: 18−28)で示されるエントリの分岐先ア
ドレスがレベル選択回路508を介して読出される。
第6図を参照すると、前記プライオリティ回路507は
アンド回路601〜604およびオア回路605〜60
8から構成されている。アンド回路601〜604はf
i+1個並列個並置されている。前記第2図におけるレ
ベル選択回路508のn個のレベルの選択信号は第6図
における信号■。、V、、V2.V。
により以下のように与えられる。
voのとき        VoLo、VoL+、”’
、 VoLlIV、−V、ノとき     V、L、、
VIL、、・、 V、Lfiv、 ・v、 ・V、0)
とき    VzLo、 VIL、、 −、V2Lll
Vo ’ L ・Vz ’ Vxのとき V3Lo、 
(hLl、 ”・、 V3[、。
以上のようにして第2図におけるレベル選択回路508
から続出された分岐情報は第1図の命令記憶回路408
から続出される命令と対応づけることが可能である。
第9図には、命令記憶回路408における命令と分岐ヒ
ストリテーブル(BHT)410における分岐情報の上
記対応関係が示されている。命令の実行順序が命令AO
,分岐命令BCO,Bl、BCl、B2.B3.BO2
,C1,C2・・・と予測された場合である。なお、<
A>はA命令のアドレスを、BCjは分岐命令をそれぞ
れ示す。
第10図を参照すると、第9図に示した分岐ヒストリテ
ーブル(BHT)410による命令先取り動作は次のよ
うにされる。リクエストアドレスの命令アドレスレジス
タ411のセソ1〜に応答して命令記憶回路408から
命令語が読出され、これと同時にテーブル(BHT)4
10が索引される。信号線106を介してBHT−HI
T信号が出力されると記憶部BHT−DA502の分岐
先アドレスくB1〉がアドレスレジスタ411にセット
され、次の命令先取りが行なわれる。前記信号線106
を介してBHT−HIT信号が出力されないときには命
令アドレス加算回路412に命令への8バイト境界アド
レス(A)が与えられ、「8」加算されたアドレスが出
力され、次の命令先取りが逐次行なわれる。
以上の命令の先取りに従えば命令記憶回路408から読
出される命令語は、テーブル(BHT)410の内容に
よる予測に従って順次読出され、命令バッファ409に
は予測された命令の実行順に格納することが可能である
このときたとえ信号BHT−HITが出力されても分岐
予測方向と反対側の命令先取り動作を一部付なわせしめ
た後に分岐予測方向の命令先取り動作を行なってもよい
以上のようにして命令先取りされた命令が分岐命令で第
1図の命令整列回路414により命令解読回路403に
導かれたとき同時に該分岐命令に対応する分岐情報が最
初の分岐情報レジスタ416  (QRO)にセントさ
れる。
以降前記分岐命令の処理の進行に伴い、前記分岐情報が
順次筒2.第3.第4.第5の分岐情報レジスタ (Q
R1) 417. (QR2) 418. (QR3)
419、 (QR4) 420へと転送される。そして
OA。
OT、QC,EX各ステージの予測確認回路424゜4
25、426.427によって該分岐命令の実際の実行
処理結果と対応する前記分岐情報とが各ステージ毎にチ
ェックされる。
第11図を参照すると、前記OAステージ予測確認回路
424は、フリフプフロップ1101.1102. ノ
ット回路1103.およびアンド回路1104から構成
されている。フリツプフロツプ1101.1102には
それぞれ信号線113を介して命令解読回路403の出
力する分岐命令を示す信号と、信号線115を介して分
岐情報レジスタ(QRO)416の保持するVビソトと
がセットされる。ノット回路1103とアンド回路11
04とによって、フリップフロップ1101の出力が“
0”で且つフリ、プフロノプ1102の出力が“1”で
ある時、即ち命令を解読した結果、分岐命令ではない命
令なのに対応する分岐情報が存在し、その分岐情報に従
って命令先取りが行なわれた時には、信号線121にO
Aステージ予測失敗信号を出力する。
第12図を参照すると、前記OTステージ予測確認回路
425は、フリップフロップ1201.1202.12
03゜1204と真偽回路1206.1207と、アン
ド回路1208゜1209、1210.およびオア回路
1211,1212.1213とから構成されている。
フリップフロップ1201.1202には、レジスタ4
35の保持する無条件ブランチ命令を示すビットと、B
CT命令を示すビットが信号線122を介してそれぞれ
セットされ、フリップフロップ1203には信号線12
3を介して比較回路433の出力する計数値1信号がセ
ットされ、フリップフロップ1204には分岐情報レジ
スタ(QRI)の保持するvビットが信号線126を介
してセットされ、オア回路1213には信号線144を
介してOAステージ予σす確認回路424が出力し且つ
フリップフロップ436に保持されたOAステージ予測
失敗信号の出力が与えられる。真偽回路1206.12
07.アンド回路120B、 1209.1210によ
ってフリップフロップ1201.1204の出力がそれ
ぞれ“1”、“0″すなわち無条件ブランチ命令である
のに対応する分岐情報が存在しなくて分岐GO側への命
令先取りが行なわれなかったときには、アンド回路12
08の出力が1”になり、フリップフロップ1202,
1203゜1204の出力がそれぞれ“l”、“0″1
 “0″である時すなわちBCT命令であってそのBC
T命令で指定された汎用レジスタの保持する計数値が“
1”ではなくて分岐を行なうBCT命令であるのに対応
する分岐命令が存在しなくて分岐Go側への先取り動作
が行なわれなかった時にはアンド回路1209の出力が
“11になり、フリップフロップ1202.1203.
1204の出力が全て1″の時すなわちBCT命令であ
ってそのBCT命令で指定された汎用レジスタの保持す
る計数値が“1”であって、分岐を行なわないBCT命
令であるのに対応する分岐情報が存在して分岐Go側へ
命令先取り動作が行なわれた時にはアンド回路121O
の出力が”1’にfする。更に、オア回路1211.1
212.1213によって無条件分岐命令あるいは分岐
を行なうBCT命令なのに分岐GO側への命令先取りが
行なわれなかった時には、OTステージGo先取り指示
信号が信号線131に、OTステージ予測失敗信号が信
号線129に、OTステージBHT更新指示信号が信号
線130にそれぞれ出力される。又、分岐を行なわない
BCT命令なのに分岐Go側への命令先取りが行なわれ
た時には、OTステージ予測失敗信号とOTステージB
HT更新指示信号とが出力される。なお、OTステージ
BIT更新指示信号は、OAステージで予測の失敗が検
出され、OAステージ予測確認回路424より、OAス
テージ予/Itす失敗信号がフリップフロップ436に
セットされ、その出力が信号綿144を介して与えられ
た時にも出力される。
第13図を参照すると前記OCステージ予測確認回路4
26は、レジスタ1301 、1302.フリップフロ
ップ1303.不一致を検出する比較回路1306.真
偽回路1307.アンド回路1308およびオア回路1
309.1310より構成されている。レジスタ130
1には、命令アドレス変換回路402より信号線133
を介して与えられる分岐命令の命令語より実際に求めら
れた分岐先アドレスがセットされ、同じくレジスタ13
02には、分岐情報レジスタ (QR2)418より信
号線137を介して与えられる予測された分岐先アドレ
スがセットされる。フリップフロップ1303には同じ
く分岐情報レジスタ (QR2) 418の保持する■
ビットがセットされ、真偽回路1307とオア回路13
10には、OTステージ予測確認回路425が出力した
OTステージBHT更新指示信号と、OTステージGO
先取り指示信号を受けたフリップフロップ437.43
8の出力が、それぞれ信号線157と158を介して与
えられる。比較回路1306と真偽回路1307および
アンド回路1308によって、比較回路1306、フリ
ップフロップ1303の出力、信号線157がそれぞれ
“1”、11″、“0”、即ち、分岐ヒストリテーブル
に対応する分岐情報が存在し、その分岐情報に従って後
続の命令先取りが行なわれたその命令について、OA、
OTステージの予測確認回路で予測の失敗が検出されて
いなくて、なお且つ、予測された分岐先アドレスが実際
の分岐先アドレスと異なっていた時には、アンド回路1
308の出力が“l”になりOCステージ予測失敗−信
号が信号線140に出力される。同時にオア回路130
9、1310によってOCステージBHT更新指示信号
とOCステージGo先取り指示信号がそれぞれ信号線1
56と141上に出力される。又、OCステージBIT
更新指示信号とOCステージGO更新指示信号は、それ
ぞれOTステージ予測確認回路425より出力されるO
TステージBHT更新指示信号とOTステージGo先取
り指示信号とを受けたフリップフロップ437,438
の出力が“1”となった時にも出力される。
第14図を参照すると、前記EXステージ予測確認回路
427は、フリップフロップ1401.真偽回路140
2、1403.1404.論理積の否定を求めるナンド
回路1405.1406.アンド回路1407.140
B、及びオア回路1409から構成されている。真偽回
路I402には、信号線149を介して命令実行回路4
07の出力する分岐成否信号が与えられ、フリップフロ
ップ1401には、分岐情報レジスタ(QR3) 41
9の保持する■ビットがセントされ、ナンド回路140
5.1406およびオア回路1409につながる信号線
159には、OCステージBHT更新指示信号を受けた
フリップフロップ439の出力が与えられ、真偽回路1
404には、OCステージGo先取り指示信号を受けた
フリップフロップ440の出力が信号線160を介して
与えられる。前記の真偽回路1402.1403.14
04.ナンド回路1405.1406.アンド回路14
07.1408によって、信号線149の分岐成否信号
、フリップフロップ1401の出力1信号線159.信
号線160がそれぞれ“1”、“0゛、“1″、“11
.即ち、予測に従って後続の命令の先取りを分岐N0G
O側へ行なったその命令は、実際には分岐Goであり、
分岐成否信号が出力され、更にOCステージまでにその
命令についての予測の失敗が検出されておらず或いは検
出されていてもGO側への先取り指示が出力されていな
いときのみ、アンド回路1407の出力が“l”になり
、同様に信号線149.フリップフロップ1401の出
力、信号m159.160がそれぞれ“0”、“l”、
“1”、“0”、すなわち、分岐Goと予測され、分岐
GO側へ後続の命令先取りを行なった命令が実際には分
岐N0GOであり、分岐成否信号が出力されなくて且つ
OCステージまでにその命令についての予測の失敗が検
出されていないか或いは検出されていても同時にGo側
への先取り指示が出ている場合のみ、アンド回路140
8の出力が”l”になる。更にオア回路1409によっ
て、oCステージまでに予測の失敗が検出されているか
或いは分岐GOと予測された命令が実際には分岐N0G
Oであり且つOCステージまでに分岐N0GO側への先
取り指示が出力されていない時、および分岐N0GOと
予測された命令が実際には分岐GOであり且つOCステ
ージまでに分岐Go側への先取り指示が出力されていな
い時に、EXステージBIT更新指示信号が信号線14
8に出力される。
第15図を参照すると、前記命令先取り制御回路423
は、フリノブフロツブ1501.真偽回路1502゜1
503、1504.1505.1506.150?、ア
ンド回路1508.1509゜1510、1511.1
512.1513.1514.1515.1516.1
517.1518とから構成されている。この命令先取
り制御回路423は、OA、OT、QC,EX(7)各
ス−5−−’; ノ予/111確認回路より出力される
予測失敗信号と、EXステージ予測確認回路427の出
力するEXステージBHT更新指示信号、並びに分岐ヒ
ストリテーブル410の出力するBHT−HIT信号に
括づいて、命令アドレスレジスフ411の前段にあるセ
レクタおよび命令アドレスリカバレジスタ428の前段
にあるセレクタの選択指示信号を出力する。
命令先取り制御回路423の入力信号が全て“0”の時
には、命令アドレスレジスタ411の人力セレクタは信
号線107上の命令アドレス加算回路412の出力する
+8された命令アドレスを選択するよう制御され、次の
マシンサイクルには、命令アドレスレジスタ411 に
は選択された命令アドレス+8がセットされる。信号線
148.147を介してEXステージ予測確認回路42
7よりEXステージB)(T更新指示(3号とEXステ
ージ予測失敗信号とが与えられると、命令アドレスリカ
バレジスタ428には命令実行回路407の出力する分
岐成否信号によって制御される選択回路422の出力、
即ち実際の分岐判定を行なった結果分岐GOであれば分
岐情報レジスタ(QR4)の保持する実際に命令語の指
示により求められた分岐先アドレスが、又、命令実行回
路407の分岐判定の結果分岐N0GOであれば、アド
レス生成回路433の出力する分岐N0GO側のアドレ
スが、いずれの場合も信号線155を介してセットされ
、同時に命令アドレスレジスタ411には分岐情報レジ
スタ (QR4)の保持する分岐命令自身のアドレスが
信号線151を介してセットされる。更にその1マシン
サイクル後には、命令先取り制御回路423は、入力信
号が全て“0”であれば、EXステージBHT更新指示
信号を1マシンサイクル保持するフリツブフロップ15
01の出力によって、命令アドレスレジスタ411には
、lマシンサイクル前に命令アドレスリカバレジスタ4
28にセットされた実際の分岐判定結果による次に実行
すべき命令のアドレスが信号線162を介してセントさ
れるよう制御する。
信号線147のEXステージ予測失敗信号が“0”の時
、信号綿140を介して○Cステージ予測確認回路42
6よりOCステージ予測失敗信号が与えられると、命令
先取り制御回路423は、命令アドレスレジスタ411
に、分岐情報レジスタ (QR3)419の保持するO
Cステージにある命令の命令語より求めた分岐GO側の
アドレスを信号線143を介してセットするよう制御す
る。この時、同時にEXステージBHT更新指示信号も
与えられれば、分岐情報レジスタ(QR3) 419の
保持するOCステージにある命令の分岐先アドレスは命
令アドレスリカバレジスタ42Bにセットされ、かわり
に命令アドレスレジスタ411には分岐情報レジスタ(
QR4)420の保持するEXステージにある命令の命
令アドレスがセントされ、その1マシンサイクル後には
、命令先取り制御回路423の全ての入力が“O”であ
れば命令アドレスリカバレジスタ428に1マシンサイ
クル前にセントされた、■マシンサイクル前にはOCス
テージにあった命令の実際の分岐GO側のアドレスが命
令アドレスレジスタ411にセットされるよう制御する
信号′1LfA147.140 ノEX、 QC両ステ
ージの予測失敗信号がともに“0”の時、信号線129
を介してOTステージ予測確認回路425よりOTステ
ージ予7!11失敗信号が与えられると、命令先取り制
御回路423は、選択回路421の出力すなわちOTX
ステージある命令が無条件分岐命令か、実際には分岐を
行なうBCT命令であって対応する分岐情ンαが分岐ヒ
ストリテーブルに存在しなくて分岐N0GO側に先取り
が行なわれた時には、命令アドレス変換回路402の出
力する分岐GO側のアドレスが、又実際には分岐を行な
わないBCT命令であって対応する分岐llff報が分
岐ヒストリテーブルより読出されて分岐GO側へ後続の
命令先取りが行なわれた時にはアドレス生成回路431
の出力する分岐N0GO側のアドレスが、いずれもOT
ステージ予測確認回路425が信号線131を介して出
力するOTステージGO先取り指示信号の制御によって
選択回路421で選択されたその結果を信号線139を
介して命令アドレスレジスタ411にセントするよう制
御する。この時、同時にEXステージB I T更新指
示信号も与えられれば、選択回路421の出力は、命令
アドレスリカバレジスタ428にセットされ、かわりに
命令アドレスレジスタ411には分岐情報レジスタ(Q
 R4,) 420の保持するEXステージにある命令
の命令アドレスが信号線151を介してセットされ、そ
の1マシンサイクル後には、命令先取り制御回路423
の全ての入力が“01であれば、命令アドレスリカバレ
ジスタ428に1マシンサイクル前にセットされた、1
マシンサイクル前にはOTXステージあった無条件分岐
命令かBCT命令の後続の命令の先取りやり直しのため
のアドレスが信号線IG2を介して命令アドレスレジス
タ411にセントされるよう制御する。
信号線147,140.129 ノEX、 QC,0T
(7)各ステージの予測失敗信号が“O”の時、信号線
121を介してOAXステージ予測確認回路424りO
Aステージ予測失敗信号が与えられると、命令先取り制
御回路423は、アドレス生成回路430が出力する○
Aステージにある命令の分岐N0Go側の命令アドレス
を信号線128を介して命令アドレスレジスタ411に
セットするよう制御する。この時同時に、EXステージ
BHT更新指示信号が与えられれば、アドレス生成回路
430の出力は命令アドレスリカバレジスタ428にセ
ットされ、命令アドレスレジスタ411には、かわりに
分岐情報レジスタ(QR4)420の保持するEXステ
ージにある命令の命令アドレスが信号線151を介して
セットされ、そのlマシンサイクル後には、命令先取り
制御回路423の全ての入力が0′であれば、1マシン
サイクル前に命令アドレスリカバレジスタにセットされ
たアドレスが信号線162を介して命令アドレスレジス
タ411 にセットされるよう制御する。
信号線147.140.129.121のEX、QC,
OT。
OAの各ステージの予測失敗信号が全て“O”の時、信
号線106を介して分岐ヒストリテーブル410よりB
HT−HIT信号が与えられると、命令先取り制御回路
423は、分岐ヒストリテーブル410の出力するIC
ステージにある命令の予測された分岐アドレスを信号線
105を介して命令アドレスレジスタ411にセットす
るよう制御する。この時、同時にEXステージBHT更
新指示信号も与えられると、信号線105の分岐ヒスト
リテーブル410より読出された分岐先アドレスは、命
令アドレスリカバレジスタ428にセットされ、命令ア
ドレスレジスタ411には、かわりにEXステージにあ
る命令の命令アドレスが分岐情報レジスタ (QR4)
420より信号線151を介してセットされ、その1マ
シンサイクル後には、命令先取り制御回路423の全て
の入力が“0”であればlマシンサイクル前にセントさ
れた命令アドレスリカバレジスタ428の内容が命令ア
ドレスレジスタ411にセットされるよう制御する。
信号線147,140,129,121 ノEX、 Q
C,OT。
OA各ステージの予測失敗信号および信号線106のB
HT−HIT信号が全て“0″の時に信号線148を介
してEXステージ予測確認回路427よりEXステージ
BHT更新指示信号が与えられると、命令先取り制御回
路423は、命令アドレスリカバレジスタ428に信号
線107を介して命令アドレス加算回路412の出力を
セットし、命令アドレスレジスタ411にはEXステー
ジにある命令の命令アドレスを分岐情報レジスタ(QR
4)420より信号線151を介してセントし、その1
マシンサイクル後には、命令先取り制御回路423の全
ての入力が“0”であれば、lマシンサイクル前に命令
アドレスリカバレジスタ428にセットされたアドレス
を命令アドレスレジスタ411にセットするよう制御す
る。
次に第1図およびタイムチャートを参照しながら本実施
例の動作を詳細に説明する。
第17図は、分岐命令ではない命令A1のアドレスを分
岐命令のアドレスとして指定する誤った分岐情報が分岐
ヒストリテーブル410に存在し、命令先取り制御回路
423が誤った分岐情報に従って命令A1の後続の命令
として命令CIを取出して実行している動作を示すタイ
ムチャートである。
第1図および第17図を参照すると、マシンサイクルO
の時刻において、分岐命令ではない命令A1のアドレス
<Al>が命令アドレスレジスタ411にセットされ、
命令A1のICステージが実行される。アドレス〈A1
〉は信号線101を介して命令記憶回路408へ与えら
れ命令語の取出しが行なわれるとともに、分岐ヒストリ
テーブル410にも与えられ、アドレス〈A1〉を分岐
命令のアドレスとして指定する分岐情報の取出しが行な
われる。
その結果、誤った分岐情報が取出され、BHT−HIT
信号が信号線106上に出力される。このため、命令先
取り制御回路423は、命令アドレスレジスタ411の
入力セレクタに分岐情報より得られた分岐先アドレス〈
C1〉が出力されている信号線105を選択するよう指
示する。
次のマシンサイクル1の時刻においては、誤った分岐情
報による分岐先アドレスくC1〉が命令アドレスレジス
タ411にセットされて、命令C1のICステージが実
行されるとともに、命令A1のIDステージが実行され
る。命令解読回路403は、命令A1が分岐命令ではな
いことから、命令解読結果が分岐命令であることを示す
信号113には“0”を出力して命令Atが分岐命令で
ないことをOAステージ予測確認回路424へ通知する
とともに、命令AIの命令語長を分岐情報レジスタ(Q
R1) 417への信号線112に出力する。同時に、
分岐情報レジスタ(QRO)416に保持された命令A
Iのアドレス〈A1〉とVビット分岐先アドレス〈C1
〉のうちvビットが信号線115に出力される。
マシンサイクル2の時刻においては、命令CIのIDス
テージと命令C1の後続の命令C2のICステージが実
行されると共に、命令AIのOAステージが実行される
。同時にOAステージ予測確認回路424は、前のマシ
ンサイクルで信号線113および115を介して与えら
れた情報より、今OAステージにある命令A1が分岐命
令でないにもかかわらず分岐情報が存在し、分岐GO側
へ後続の命令の先取りを行なったことを示すOAXステ
ージ予測失敗信号信号線121へ出力する。同時にアド
レス生成回路430は、分岐情報レジスタ(QR2)4
18の保持する命令A1のアドレス〈A1〉と命令A1
の命令語長を加算し、命令A1のN0GO側の後続の命
令のアドレスくA2〉を生成し、信号線128上に出力
する。命令先取り制御回路423は、OAステージ予測
確認回路424の出力する信号線121のOAXステー
ジ予測失敗信号より、命令アドレスレジスタ411の入
力セレクタに、信号線128上のOAステージからの命
令Alの分岐N0GO側のアドレス〈A2〉を選択する
よう指示する。又、OAXステージ予測失敗信号出力さ
れたことにより、OAステージより前のステージにある
予測側に後続する命令CI、C2の動作はすべてキャン
セルされる。
マシンサイクル3においては、命令A1のOTステージ
が実行され、同時に命令アドレスレジスタ411には命
令A1の後続の命令のアドレスくA2〉がセットされ、
命令A2のICステージも実行される。フリップフロッ
プ436は、前のマシンサイクルで出力されたOAXス
テージ予測失敗信号受けて“1”にセットされ、今OT
ステージにある命令A1の分岐情報が誤っており、正し
く更新しなければならないことを示す。
次のマシンサイクル4において、命令A1はOCステー
ジを実行し、命令A2のIDステージ。
命令A2の後続の命令A3のICステージが実行される
。フリップフロップ437には、フリップフロップ43
6を受けて11”がセットされ、フリップフロップ43
8は“0”を保持し、合わせて現在OCステージにある
命令AIの分岐情報が誤っており、正しく更新する必要
のあることを並びに命令AIについての予測に従った後
続の命令先取りはキャンセルされて既にN0GO側への
命令先取り動作の実行が改めて行なわれたことを示す。
マシンサイクル5においては、命令A1のEXステージ
、が実行される。命令実行回路407は命令Alが分岐
命令ではないことから信号線149の分岐成否信号に分
岐N0GOを示す“0”を出力する。このため、選択回
路422は、分岐情報レジスタ(QR4)の保持する命
令AIのアドレスくA1〉と命令Alの命令語長をアド
レス生成回路432で加算した結果得られるアドレスく
A2〉を選択し信号線155上に出力する。また、信号
線151には、命令AIのアドレスくA1〉が出力され
る。
一方フリップフロフブ439,440は、フリップフロ
ップ437,438の内容をoCステージ予測確認回路
426を通して受け、それぞれ11.“0″にセントさ
れる。EXステージ予測確認回路427は、信号線14
9の分岐成否信号と、前のマシンサイクルで信号線14
6を介して与えられた分岐情報レジスタ(QR3)41
9の保持していた命令AIの分岐情報のVビット、およ
びフリップフロップ439゜440とから、信号線14
8上のEXステージBHT更新指示信号として“l”を
出力し、信号線147のEXステージ予測失敗信号には
“0゛を出力することによって、命令A1についての分
岐情報が存在し、その情報に従って分岐Go側へ後続の
命令先取りを行なったにもかかわらず、命令Atは実際
には分岐動作を行なわないこと、しかしながら後続の誤
った分岐先取り動作はキャンセルされて既に分岐N0G
O側への命令取出し動作が行なわれているため、EXス
テージでは命令先取りのやり直しを指示する必要のない
ことを示すとともに、命令A1についての分岐情報の更
新が必要なことを示す。これを受けて、命令先取り制御
回路423ば、命令アドレスレジスタ411の入力セレ
クタに対し信号線151上の命令A1のアドレスくAl
〉を選択するよう指示し、命令アドレスリカバレジスタ
428の入力セレクタに対しては、信号線107上のア
ドレス<A2>+24を選択するよう指示スル。もしこ
の時、命令アドレスレジスタ411の保持するアドレス
<A2>+16に対応する分岐情報が分岐ヒストリテー
ブルに存在し、BHT−HIT信号が信号線106を介
して与えられれば、命令先取り制御回路423は、命令
アドレスリカバレジスタ428の入力セレクタに対して
は、信号線105上に出力される1分岐ヒストリテーブ
ル410より取出された分岐情報の示す分岐先アドレス
を、またOAステージにある命令A2についてOAステ
ージ予測確認回路424より信号線121を介してOA
ステージ予測失敗信号が与えられれば信号線128上の
アドレスを選択するよう指示する。
次のマシンサイクル6において、命令AIは、分岐ヒス
トリテーブル410内の命令AIについての分岐情報の
更新を行なうHUXステージ実行する。先ず、フリップ
フロップ441は前のマシンサイクルで信号線148上
に出力されたEXステージBHT更新指示信号を受けて
“1”にセットされ、信号線154を介してその出力は
分岐ヒストリテーブル410へ送られる。又、レジスタ
434には、同じく前のマシンサイクルで信号線155
上に出力されていた命令アドレス〈A2〉がセントされ
、命令アドレスレジスタ[1には、同じく前のマシンサ
イクルで信号線151上に出力されていた命令アドレス
くA1〉が、また命令アドレスリカバレジスタ428に
は前のマシンサイクルで信号&?t107上に出力され
ていたアドレス<A2>+24がそれぞれセットされる
。これに応答して分岐ヒストリテーブル410内の命令
AIについての分岐情報の更新が行なわれ、A1につい
ての分岐情報のvビットがリセットされ、これ以降命令
AIは分岐命令としては扱われなくなる。一方この時、
命令先取り制御回路423は、命令アドレスレジスタ4
11の入力セレクタに対して、信号線162上に出力さ
れている命令アドレスリカバレジスタ428の保持する
アドレス<A2>+24を選択するよう指示する。
もしこの時、OTステージにある命令A2について、O
Tステージ予測確認回路425より信号線129を介し
てOTステージ予測失敗信号が与えられれば、命令先取
り制御回路423は、命令アドレスレジスフ411の入
力セレクタに対し信号線139上のアドレスを選択する
ように、又OAステージにある命令A3についてOAス
テージ予測確認回路424より信号線121を介してO
Aステージ予測失敗信号が与えられれば、信号線128
上のアドレスを選択するように指示する。
マシンサイクル7以降は、命令アドレスレジスタ411
にセットされたアドレス<A2>+24に従って命令先
取り動作が続けられる。
第18図は、分岐ヒストリテーブル410にVビットが
“1”である対応する分岐情報が存在しなかったBCT
命令あるいは無条件分岐命令である命令B1の実行のよ
うすを示すタイムチャートであり、B1がBCT命令の
場合、命令B1で指定した計数値は“1″ではなくて、
−1する計数動作を行なっても計数結果は“0”とはな
らす゛、実際には分岐を行なうBCT命令の場合を示し
ている。
MI[fflおよび第18図を参照するとマシンサイク
ルOの時刻において、BCT命令あるいは無条件分岐命
令である命令B1のアドレス〈B1〉が命令アドレスレ
ジスタ411にセットされ、命令BlのICステージが
実行される。アドレス〈B1〉は信号101を介して命
令記憶回路408へ与えられ命令語の取出しが行なわれ
るとともに、分岐ヒストリテーブル410に与えられ、
命令Blに対応する分岐情報の取出しが行なわれ、同時
に、命令アドレス加算回路412へも与えられ、アドレ
スくB1〉+8が生成される。分岐ヒストリテーブル4
10には命令B1に対応する分岐情報が存在しないため
、信号線106のBHT−HIT信号として0”を出力
する。これに応答して命令先取り制御回路423は、命
令アドレスレジスタ411の入力セレクタに対し、信号
線107に出力されるアドレスくB1〉+8を選択する
よう指示する。
次のマシンサイクル1の時刻においては、命令アドレス
レジスタ411にはアドレス<B 1 >+3がセント
され、命令Blの分岐NOC;O側の後続の命令A1の
ICステージが実行される。同時に、分岐情報レジスタ
(QRO)416には、命令Blのアドレス〈B1〉と
Vビットとして“0”がセットされ、命令B1のIDス
テージが実行される。
命令解読回路403は命令B1がBCT命令であること
を、あるいは無条件分岐命令であることを信号線114
に出力する。
マシンサイクル2の時刻においては、命令B1のOAス
テージと、命令A1のIDステージ及び命令A1の後続
の命令A2のICステージが実行される。レジスタ43
5は、前のマシンサイクルの信号線114の出力を受け
て、命令B1がBCT命令であることを或いは無条件分
岐命令であることを信号線122上に示す。分岐情報レ
ジスタ(QRl)417には分岐情報レジスタ (QR
O)が前のマシンサイクルで保持していたアドレス〈B
1〉と0”であるVビットがセントされ、■ビットはさ
らに信号線126に出力される。命令アドレス生成回路
401は、命令B1の分岐先アドレスを生成し、命令B
1がBCT命令である時にはオペランドアドレス生成回
路404より命令Blで指定された計数値を保持する汎
用レジスタの値が信号線120を介して比較回路433
へ与えられる。比較回路433は与えられた計数値が“
1”でないことを検出して信号線123上の計数値1信
号として“0“を出力する。
マシンサイクル3においては、命令BlのOTステージ
が実行され、命令B1の分岐先アドレスが命令アドレス
変換回路402によって実アドレス<C1>に変換され
るとともに、命令B1の分岐N0GO側の後続の命令A
l、A2.A3のOA。
ID、ICステージが実行される。OTステージ予測確
認回路425は、前のマシンサイクルで信号線122.
123.126を介して与えられた情報から、現在OT
ステージにある命令が、分岐GoであるBCT命令であ
ること或いは無条件分岐命令であることにもかかわらず
対応する分岐情報が分岐ヒストリテーブル410にヒツ
トせず、分岐N0GO側へ後続の命令の先取りが続けら
れたこと、このため、命令B1の分岐GO側へ命令の先
取りを改めて実行する必要のあること、並びに命令B1
についての分岐情報を正しく更新する必要のあることを
示すために、信号線129にOTステージ予測失敗信号
を、信号線130にOTステージBIT更新指示信号を
、また信号線131にOTステージG。
先取り指示信号をそれぞれ出力する。このOTステージ
GO先取り指示信号に応答して選択回路421は、信号
線133に出力される命令Blの分岐先アドレスを選択
し、信号線139上に出力する。命令先取り制御回路4
23は、OTステージ予測確認回路425の出力する信
号線129のOTステージ予測失敗信号により、命令ア
ドレスレジスタ411の入力セレクタに対して信号線1
39上の命令B1の分岐先アドレス〈C1〉を選択する
よう指示する。
またOTステージ予測失敗信号が出力されたことにより
、OTステージより前のステージにある分岐N0GO側
に後続する命令A1.A2.A3の動作は全てキャンセ
ルされる。
マシンサイクル4においては、命令B1のoCサイクル
が実行され、同時に命令アドレスレジスタ411には命
令Blの分岐先アドレス〈C1〉がセント、アドレス<
C1>にある命令C1のICステージも実行される。フ
リップフロップ437,438 。
は、前のマシンサイクルで出力されたOTステージBH
T更新指示信号とOTステージGo先取り指示信号とを
受けてどちらも“l”にセットされる。
次のマシンサイクル5においては、命令B1のEXステ
ージが実行される。命令実行回路407は、命令B1が
BCT命令であれば指定された計数動作を行ない、その
結果が“O″ではないことがら信号線149の分岐成否
信号に分岐GOを示す“1“を、命令B1が無条件分岐
命令であるときは信号線149の分岐成否信号としてや
はり“loを出力する。これに応答して選択回路422
は、分岐情報レジスタ (QR4)420の保持する命
令B1の分岐先アドレス〈C1〉を選択し信号線155
上に出力する。同時に信号線151上には、同じく分岐
情報レジスタ (QR4)420の保持する命令B1の
アドレスくB1〉が出力される。一方フリップフロップ
439.440は、フリップフロップ437,438の
内容をOCステージ予測確認回路426を通して受け、
どちらも“1″にセットされる。EXステージ予測確認
回路427は、信号線149の分岐成否信号と、前のマ
シンサイクルで信号線146を介して与えられた分岐情
報レジスタ (QR3)419の保持していた命令B1
の分岐情報の“0”である■ビット、およびフリップフ
ロップ439,440とから信号線148上のEXステ
ージBHT更新指示信号として“loを出力し、信号線
147のEXステージ予測失敗信号には“0”を出力す
ることによって、命令B1についての分岐情報が存在せ
ず分岐N0GO側へ後続の命令の先取りを行なったにも
かかわらず、命令Blは分岐を行なうこと、しかしなが
ら後続の分岐N0GO側の命令はキャンセルされて既に
分岐Go側の命令取出しが行なわれているためEXステ
ージでは命令先取りのやり直しを指示する必要のないこ
とを示すとともに、命令B1についての分岐情報の更新
が必要なことを示す。これに応答して命令先取り制御回
路423は、命令アドレスレジスタ411の入力セレク
タに対して信号線151上の命令B1のアドレスくB1
〉を選択するよう指示し、命令アドレスリカバレジスタ
428の入力セレクタに対しては信号線107上のアド
レス<C1>+16を選択するよう指示する。
もしこの時、命令アドレスレジスタ411の保持するア
ドレス<CI>+8に対して分岐ヒストリテーブル41
0よりBHT−HIT信号が信号線106を介して与え
られれば、命令先取り制御回路423は、命令アドレス
リカバレジスタ428の入力セレクタに対しては信号線
105上の分岐ヒストリテーブル410より取出された
分岐アドレスを選択するよう指示する。
次のマシンサイクル6において、命令B1は分岐ヒスト
リテーブル410の更新を行なうHUXステージ実行す
る。レジスタ434には信号線155上の命令B1の分
岐先アドレスくC1〉がセットされ、命令アドレスレジ
スタ411には信号線151上の命令B1のアドレス〈
B1〉が、命令アドレスリカバレジスタ428には<C
I>+16がそれぞれセットされる。一方、フリップフ
ロップ441 は前のマシンサイクルで信号線148上
に出力されたEXステージBHT更新指示信号を受けて
“1”にセントされ、その出力は信号線154を介して
分岐ヒストリテーブル410に与えられる。これに応答
して分岐ヒストリテーブル410には、分岐先アドレス
としくC1〉をもつアドレス<31>の分岐情報が格納
され、これ以後、命令B1は分岐先アドレスとして<C
1>が予測されるようになる。
一方この時命令先取り制御回路423は、命令アドレス
レジスタ411の入力セレクタに対して信号線162上
に出力されている命令アドレスリカバレジスタ428の
保持するアドレス<CL>+16を選択するよう指示す
る。もしこの時、OAXステージある命令C1について
OAステージ予測確認回路424より信号線121を介
してOAステージ予測失敗信号が与えられれば、命令先
取り制御回路423は命令アドレスレジスタ411の入
力セレクタに対し信号線128上のアドレスを選択する
よう指示する。
マシンサイクル7以降は命令アドレスレジスタ411に
セットされたアドレス<CI>+16に従って命令先取
り動作が続けられる。
第19図は、分岐ヒストリテーブルに対応する分岐情報
が存在するBCT命令BCTIの実行のようすを示すタ
イムチャートであり、命令BCTIで指定した計数値は
“l”であって、−1する計数動作の結果は“0”とな
って実際には分岐を行なわないBCT命令の場合を示し
ている。
第1図および第19図を参照すると、マシンサイクル0
の時刻において、命令BCTIのアドレス<BCTI>
が命令アドレスレジスフ411にセ。
トされ、命令13CT1のICステージが実行される。
アドレス<BCTl>は信号線101を介して命令記憶
回路408へ与えられ、命令語の取出しが行なわれると
ともに分岐ヒストリテーブル410に与えられ、命令B
CTIについての分岐情報の取出しが行なわれる。分岐
ヒストリテーブル410より取出された分岐情報は信号
線105上に出力される。同時にBHT−HIT信号が
信号線106上に出力される。これに応答して命令先取
り制御回路423は、命令アドレスレジスフ411の入
力セレクタに対し、信号線105に出力された命令BC
TIの分岐先アドレス<CI>を選択するよう指示する
次のマシンサイクルlの時刻においては、命令BCTI
の分岐先アドレス<CI>が命令アドレスレジスタ41
1にセットされて、命令C1のICステージが実行され
るとともに、命令BCTIのIDステージが実行される
。命令解読回路403は命令BCTIがBCT命令であ
ることを信号線114に出力すると同時に、信号線11
2上に命令BCTlの命令語長を出力する。
マシンサイクル2においては、命令3CT1のOAステ
ージと命令C1のIDステージおよび命令CIの後続の
命令C2のICステージが実行される。レジスタ435
は、前のマシンサイクルの信号線114の出力を受けて
、命令BCTIがBCT命令であることを信号線122
上に示す。分岐情報レジスタ(QRI)417には、前
のマシンサイクルで分岐情報レジスタ (QRO)が保
持していた命令BCTIの分岐情報と命令BCTIの命
令語長がセットされ、信号線126にはVビットが出力
される。命令アドレス生成回路401は命令BCTlの
分岐先アドレスを生成し、オペランドアドレス生成回路
404は命令BCTIで指定された計数値を保持する汎
用レジスタの値を信号線120を介して比較回路433
に出力する。比較回路433は与えられた計数値が“1
“であることを検出して信号線123に計数値l信号を
出力する。
マシンサイクル3においては、命令BCTIの0Tステ
ージが実行され、命令BCTIの分岐先アドレスが命令
アドレス変換回路402で実アドレスに変換されるとと
もに、命令C1,C2およびC2の後続の命令C3のO
A、ID、ICステージがそれぞれ実行される。OTス
テージ予測確認回路425は、前のマシンサイクルで信
号線122.123゜126を介して与えられた情報か
ら、OTステージにある命令BCTIが分岐N0GOの
BCT命令であることにもかかわらず命令BCTIの分
岐情報が分岐ヒストリテーブル410にヒツトして分岐
GO側へ後続の先取りが行なわれたこと、このため命令
BCTlの分@N OG O側への後続の命令先取りを
改めて実行する必要のあること、並びに命令BCTIに
ついての分岐情報を正しく更新する必要のあることを示
すために、信号線129にOTステージ予測失敗信号を
出力し、信号線130にはOTステージBIT更新指示
信号を出力し、信号線131のOTステージGO先取り
指示信号には“0”を出力する。これに応答して選択回
路421は、アドレス生成回路431が信号線138に
出力する命令BCTIの分岐N0GO側の次の命令のア
ドレスくA1〉を選択して信号線139上に出力し、命
令先取り制御回路423は、命令アドレスレジスタ41
1の入力セレクタに対して信号線139上のアドレスく
A1〉を選択するよう指示する。又、OTステージ予測
失敗信号が出力されたことにより、OTステージより前
にある分岐GO側に後続する命令C1,C2,C3の動
作は全てキャンセルされる。
マシンサイクル4においては、命令BCTIのOCサイ
クルが実行され、同時に命令アドレスレジスタ411に
は、命令BCTIの分岐N0GO側に後続する命令AI
のアドレスくA1〉がセットされ、命令A】のICステ
ージが実行される。フリップフロップ437,438は
、前のマシンサイクルで出力されたOTステージBHT
更新指示信号とOTステージGo先取り指示信号とを受
けてそれぞれ1”、10″にセットされる。OCステー
ジ予測確認回路426は、前のマシンサイクルで分岐情
報レジスタ (QR2)418が保持していた命令BC
TIの予測された分岐先アドレスくC1〉とVビットを
信号線137を介して、又命令BCTlの命令語の指定
により求められた実際の分岐先アドレスを信号vA13
3を介して命令アドレス変換回路402からそれぞれ受
は取り、予測された分岐先アドレスくC1〉が正しいか
どうかの検出を行なう。しかしながらフリップフロ7プ
437が“1″にセントされているため、たとえ分岐先
アドレス<CI>が正しくなくともOCステージ予測失
敗信号が信号線140に出力されることはなく、OTス
テージで命令BCTIの分岐N0GO側へ先取りをやり
直した動作をキャンセルして分岐Go側への先取りが改
めて始まることはない。
次のマシンサイクル5において、命令BCTIのEXス
テージが実行される。命令実行回路407は命令BCT
Iで指定された計数動作を行ない、その結果が“0“に
なることから、信号線149の分岐成否信号に分岐N0
GOを示す“0”を出力する。これに応答して選択回路
422は、アドレス生成回路432の出力する命令BC
TIの分岐N。
GO側に後続する命令A1のアドレスくA1〉を選択し
て信号線155に出力する。同時に信号線151には分
岐情報レジスタ (QR4)420の保持する命令BC
TIのアドレス<3CT1>が出力される。一方フリッ
プフロップ439,440は、フリップフロップ437
,438の内容をOCステージ予測確認回路426を通
して受けそれぞれ“1″、“0”にセットされる。EX
ステージ予測確認回路427は、信号線149の分岐成
否信号と、前のマシンサイクルで信号線146を介して
与えられた分岐情報レジスタ (QR3)419の保持
していた命令BCTIの分岐情報の■ビット、およびフ
リップフロップ439、440とから、信号線148の
EXステージBHT更新指示信号として“1”を出力し
、信号線147のEXステージ予測失敗信号として“0
”を出力することによって、命令BCTIの分岐情報に
従って分岐Goへ後続の命令先取りを行なったにもかか
わらず、命令BCTIは実際には分岐N0GOであるこ
と、しかしながら後続の誤った命令先取り動作はキャン
セルされて既に分岐N0GO側への命令取出し動作が行
なわれているためEXステージでは命令先取りのやり1
 を指示する必要のないことを示すと共に、命令BCT
Iの分岐情報の更新が必要なことを示す。これを受けて
命令先取り制御回路423は、命令アドレスレジスタ4
11の入力セレクタに対し信号綿151上の命令BCT
1のアドレス<BCTI>を選択するよう指示し、命令
アドレスリカバレジスフ428の入力セレクタに対して
は信号19101上のアドレス<Al>+16を選択す
るよう指示する。もしこの時、命令アドレスレジスタ4
11の保持するアドレス<AI>+8に対応する分岐情
帳が分岐ヒストリテーブル410に存在してB I T
 −HI T信号が信号線106を介して与えられれば
、命令先取り制御回路423は、命令アドレスリカバレ
ジスタ428の入力セレクタに対しては信号線105上
の分岐ヒストリテーブル410より取出された分岐情報
の示す分岐先アドレスを選択するよう指示する。
次のマシンサイクル6において、命令BCTIは分岐ヒ
ストリテーブル410内の命令BCTIについての分岐
情報の更新を行なうHUステージを実行する。命令アド
レスレジスタ411には命令アドレス<3CT1>がセ
ットされ、フリップフロップ441は前のマシンサイク
ルで信号線148に出力されたEXステージBHT更新
指示信号を受けて“l“にセントされ、その出力は信号
線154を介して分岐ヒストリテーブル410に与えら
れる。
これに応答して分岐ヒストリテーブル410内の命令B
CTIの分岐情報の■ビットがリセットされる。一方こ
の時、命令先取り制御回路423は命令アドレスレジス
タ411の入力セレクタに対して信号線162上に出力
されている命令アドレスリカバレジスタ428の保持す
るアドレス<AI>+16を選択するよう指示し、もし
この時、OAXステージある命令AIについて、〇へス
テージ予測5(1>2回路424より信号線121を介
してOAステージ予測失敗信号が与えられれば、信号線
12B上のアドレスを選択するように指示する。
マシンサイクル7以降は、命令アドレスレジスタ411
にセントされたアドレスに従って命令先取り動作が続け
られる。
第20図は、分岐ヒストリテーブルに対応する分岐情報
が存在し、分岐Go側へ後続の命令先取り動作が行なわ
れた無条件分岐命令、あるいは実際に分岐Goとなる条
件分岐命令B1の実行のようすを示すタイムチャートで
あり、命令B1に対する分岐情報の示す分岐先アドレス
が実際に命令Blの指定する分岐先アドレスとは異なっ
ていた場合を示している。
第1図及び第20図を参照するとマシンサイクル0の時
刻において、無条件分岐命令あるいは条件分岐命令であ
る命令B1のアドレスくB1〉が命令アドレスレジスタ
411 にセントされて命令B1のICステージが実行
される。アドレス〈B1〉は信号線101を介して命令
記憶回路408に与えられ命令語の取出しが行なわれる
とともに、分岐ヒストリテーブル410にも与えられ、
命令Blに対する分岐情報の取出しが行なわれる。その
結果分岐ヒストリテーブル410は命令B1に対する分
岐情報を取出し、信号線105に分岐先アドレスくCI
〉を出力するとともに、信号線106にはBHT−HI
T信号を出力する。これに応答して命令先取り制御回路
423は、命令アドレスレジスタ411の入力セレクタ
に対して、予測された分岐先アドレス<CI>が出力さ
れている信号線105を選択するよう指示する。
次のマシンサイクルlにおいては、予測された分岐先ア
ドレス〈C1〉が命令アドレスレジスタ411にセント
され、命令C1のICステージが実行されるとともに命
令B1のIDステージが実行される。
マシンサイクル2において、命令C1のIDステージと
命令C1の後続の命令C2のICステージが実行される
とともに、命令B1のOAステージが実行され、命令B
lの分岐先アドレスが命令アドレス生成回路401によ
って計算され信号線119上にその論理アドレスが出力
される。
マシンサイクル3においては命令B1の○Tステージが
実行され、命令Blの分岐先アドレスが命令アドレス変
換回路402で実アドレス<DI>に変換され、信号W
1133上に出力されるとともに、命令CI、C2,C
3のOA、  r D、  r Cスf −ジがそれぞ
れ実行される。分岐情報レジスタ(QR2)41Bには
、命令B1の分岐情報がセットされ、予測された分岐ア
ドレス<CI>とVビットが信号線137上に出力され
る。
マシンサイクル4において、命令Bl、ci。
C2,C3,C4のOC,OT、OA、ID、ICの各
ステージがそれぞれ実行される。ocステージ予測確認
回路426は、前のマシンサイクルで信号線137を介
して与えられた命令81の予測された分岐先アドレスく
C1〉とVビットおよび信号線133を介して与えられ
た命令Blの命令語によって指定された実際の分岐先ア
ドレス<DI>とを照合し、予測された分岐先アドレス
<C1>が誤っていることを検出し、信号線140にo
cステージ予測失敗信号を出力するとともに、信号線1
56にOCステージBHT更新指示信号を、信号VA1
41には○CステージGo先取り指示信号をそれぞれ出
力する。分岐情報レジスタ (Q R3)419は簡の
マシンサイクルで信号線133上に出力された命令B1
の実際の分岐先アドレス〈Dl〉がセントされ、信号線
143上にアドレス<Di>を出力する。命令先取り制
御回路423は、信号線140のOCステージ予測失敗
信号に応答して、命令アドレスレジスタ411の入力セ
レクタに対して信号&?t143上のアドレス〈Dl〉
を選択するよう指示する。又、OCステージ予測失敗信
号が出力されたことにより、命令B1の分岐↑;Uta
の示す誤った分岐先アドレスくC1〉に従って先取りさ
れた命令CI、C2,C3,C4の動作は全てキャンセ
ルされる。
マシンサイクル5においては、命令アドレスレジスタ4
11には命令B1の実際の分岐先アドレスであるアドレ
ス<DI>がセットされて命令D1のICステージが実
行されるとともに、命令B1のEXステージが実行され
る。命令実行回路407は命令B1が条件分岐命令であ
れば、命令B1の命令語により指定された分岐条件を判
定して、その結果信号線149の分岐成否信号に分岐G
Oを示す“1”を出力し、命令B1が無条件分岐命令で
あればやはり信号線149の分岐成否信号に“1”を出
力する。これに応答して選択回路422は、分岐情報レ
ジスタ (QR4)420の保持する実際の分岐先アド
レス〈Dl〉を選択して信号線155上に出力する。又
、信号線151には命令B1のアドレスくB1〉が出力
される。フリップフロップ439゜440は、前のマシ
ンサイクルで出力されたOCステージB I T更新指
示信号と、OCステージG。
先取り指示信号を受けてどらちも“l”にセントされる
。EXステージ予測確認回路427は、命令B1に対す
る分岐情報に従って誤った後続の命令の取出しが行なわ
れたが既にキャンセルされて正しい分岐GO側のアドレ
スに従った命令先取りが行なわれており、EXステージ
から命令先取りのやり直しを指示する必要のないこと、
ただし分岐ヒストリテーブル410の命令B1について
の分岐情幸uは修正する必要のあることを示すために、
信号線147のEXステージ予測失敗信号には′0″を
、信号線148のEXステージBHT更新指示信号には
“1”を出力する。これに応答して命令先取り制御回路
423は、命令アドレスレジスフ411の入力セレクタ
に対し信号線151上の命令B1のアドレスくB1〉を
選択するように、また命令アドレスリカバレジスタ42
8の入力セレクタに対し信号線107上のアドレス<D
I>+8を選択するようそれぞれ指示する。もしこの時
、命令アドレスレジスタ411の保持するアドレスくD
l〉に対応する分岐情報が分岐ヒストリテーブル410
に存在してBHT−HIT信号が信号線106に出力さ
れれば、命令アドレスリカバレジスタ428の入力セレ
クタに対しては、信号線105上の分岐ヒストリテーブ
ル410より取出された分岐情報の示す分岐先アドレス
を選択するよう指示する。
次のマシンサイクル6において、命令B1のHUステー
ジが実行され、命令B1に対する分岐情報の更新が行な
われる。命令アドレスレジスタ411には命令B1のア
ドレスくB1〉がセットされ、レジスタ434には命令
Blの正しい分岐先アドレスくDl〉がセントされ、フ
リップフロップ441は前のマシンサイクルで出力され
たEXステージBHT更新指示信号を受け“1”がセッ
トされ、その出力が信号線154を介して分岐ヒストリ
テーブル410に与えられる。これに応答して分岐ヒス
トリテーブル410内の命令B1に対する分岐情報が分
岐先アドレスとして<DI>を示すように更新される。
一方この時、命令先取り制御回路423は、命令アドレ
スレジスタ411の入力セレクタに対し、命令アドレス
リカバレジスタ428の出力ヲ選択するよう指示する。
マシンサイクル7において、命令アドレスリカバレジス
タ428に退避していた命令アドレスが命令アドレスレ
ジスタ411にセットされて、以降そのアドレスに従っ
て命令先取り動作が続けられる。
第21図は、分岐ヒストリテーブル410に対応する分
岐情報が存在し分岐GO側へ後続の命令先取り動作が行
なわれた条件分岐命令BCIの実行のようすを示すタイ
ムチャートであり、命令BCIに対する分岐情報の示す
分岐先アドレスは、実際に命令BCIの指定する分岐先
アドレスとは異なっており、さらに条件分岐命令BCI
はその分岐条件を判定した結果分岐N0GOであった場
合を示している。
第1図および第21図を参照すると、マシンサイクル0
において、条件分岐命令BCIのアドレス<BCI>が
命令アドレスレジスタ411にセットされ、命令BCI
のICステージが実行される。
同時に命令BCIの分岐情報が分岐ヒストIJテーブル
410より取出され、予測された分岐先アドレスとして
〈C1〉が信号線105上に出力され、BHT−H!T
信号が信号線106上に出力される。
これに応答して命令先取り制御回路423は、命令アド
レスレジスフ411の入力セレクタに対して、信号線1
05上のアドレス〈C1〉を選択するよう指示する。
次のマシンサイクル1において、命令BCIの予測され
た分岐先アドレス<C1>が命令アドレスレジスタ41
1にセントされ、命令C1のICステージが実行される
とともに、命令BCIのTDステージが実行される。
マシンサイクル2において、命令CIのIDステージと
、命令C1の後続の命令C2のICステージが実行され
ると共に、命令BCIのOAステージが実行され、命令
BCIの分岐先アドレスが命令アドレス生成回路401
によって計算され、信号線119上にその論理アドレス
が出力される。
マシンサイクル3においては、命令BCIのOTステー
ジが実行され、命令BCIの分岐先アドレスが命令アド
レス変換回路402によって実アドレス<DI>に変換
され信号vA133上に出力される。同時に命令CL 
 C2,C3のOA、  rD。
Icステージもそれぞれ実行される。分岐情報レジスタ
 (Qr? 2) 41Bには命令BC1の分岐情報が
セットされ予測された分岐先アドレスくC1〉と■ビッ
トが信号線137上に出力される。
マシンサイクル4においては、命令BCI、CI、C2
,C3,C4のQC,OT、 OA、  10゜ICの
各ステージがそれぞれ実行される。OCステージ予測確
認回路426は、前のマシンサイクルで信号線137を
介して与えられた命令BCIの予測された分岐先アドレ
ス<C1>と■ビット、および信号線133を介して与
えられた命令BCIの命令語によって指定された実際の
分岐先アドレスくDl〉とを照合して、予測された分岐
先アドレス<C1>が誤っていることを検出し、信号線
140にOCステージ予測失敗信号を出力するとともに
、信号線156にOCステージBHT更更新来示信号、
信号線141にはOCステージGO先取り指示信号をそ
れぞれ出力する。分岐情報レジスタ (QR3)419
は、前のマシンサイクルで信号線133に出力されてい
た実際の分岐先アドレスくDl〉がセントされ、信号線
143上にそのアドレス〈Dl〉を出力する。命令先取
り制御回路423は信号線140のOCステージ予測失
敗信号に応答して、命令アドレスレジスタ411の人力
セレクタに対して、信号線143上のアドレスくDl〉
を選択するよう指示する。又、○Cステージ予測失敗信
号が出力されたことにより命令BCIの分岐情報の示す
誤った分岐先アドレスくC1〉に従って先取りされた命
令CI、C2,C3,C4の動作は全てキャンセルされ
る。
マシンサイクル5においては、命令アドレスレジスタ4
11には、命令BCIの命令語より求められた分岐先ア
ドレスくDl〉がセットされ、命令DIのICステージ
が実行されるとともに、命令BCIのEXステージが実
行される。命令実行回路407は、条件分岐命令BCI
の命令語により指定された分岐条件を判定して、その結
果信号線149の分岐成否信号に分岐N0GOを示す“
0°を出力する。これに応答して選択回路422は、ア
ドレス生成回路432の出力する命令BCIの命令アド
レス<BCI>と命令BCIの命令語長とを加算したア
ドレス<At>を選択し、信号線155上に出力する。
また、信号線151上には、命令BCIのアドレス<B
CI>が出力される。フリップフロップ439,440
は、前のマシンサイクルで出力されたOCステージBH
T更新指示信号と、○CステージGo先取り指示信号と
を受けて、どちらも1”にセットされる。EXステージ
予測確認回路427は、前のマシンサイクルで信号線1
46を介して分岐情報レジスタ(QR3)419の保持
する命令BCIのvビットと、信号線149の分岐成否
信号およびフリップフロップ439,440の出力を受
けて、信号線147のEXステージ予測失敗信号と信号
線148のEXステージBHT更新指示信号とに“l”
を出力し、命令BCIの分岐情報は誤っており、既に分
岐Go側へ後続する命令の先取りのやり直しが指示され
たが、実際には命令B(,1は分岐N0GOであり、分
岐ヒストリテーブル410のBCIに関する分岐情報を
正しく更新するとともに分岐N0GO側に後続する命令
の先取りのやり直しを行なう必要のあることを示す。こ
れに応答して命令先取り制御回路423は、命令アドレ
スレジスタ411の入力セレクタに対して信号線151
上のアドレス<BCI>を選択するように、また命令ア
ドレスリカハレジスク428の人ツノセレクタに対して
は信号線155上のアドレス〈A1〉を選択するように
それぞれ指示する。
次のマシンサイクル6において、命令BCIのHUステ
ージが実行され命令BCIに対する分岐情報の更新が行
なわれる。命令アドレスレジスタ411には命令BCI
のアドレス<BCI>がセットされ、命令アドレスリカ
バレジスタ428とレジスタ434には命令B(、lの
分岐N OG O側のアドレス〈A1〉がセットされる
。又、フリップフロップ441には前のマシンサイクル
で出力されたEXステージBIT更新指示信号によって
“l”がセットされ、その出力が信号線154を介して
分岐ヒストリテーブル410に与えられる。これに応答
して分岐ヒストリテーブル410内の命令BC1に対す
る分岐情報の■ビットがリセットされる。一方この時、
命令先取り制御回路423は、命令アドレスレジスフ4
11の入力セレクタに対して、命令BCIの分岐N0G
O側のアドレスくA1〉を保持する命令アドレスリカバ
レジスフ428の出力を選択するように指示する。
マシンサイクル7においては、命令アドレスレジスタ4
11にアドレス<Al>がセ・ツトされ、命令BCIの
後続の命令Atの取出しが行なわれる。
そして以降、命令アドレスレジスタ411にセットされ
たアドレスに従って命令先取り動作が続けられる。
〔発明の効果〕
次に本発明の効果について、第17図乃至第21図を参
照しながら説明する。
第17図は、分岐命令でない命令AIに対応する分岐情
報が分岐ヒストリテーブルより取出されてその分岐情報
の示す分岐先アドレスに従って後続の命令C1の先取り
が行なわれた場合を示している。マシンサイクル2の命
令A1のOAXステージおいて、命令Alが分岐命令で
ないにもかかわらず誤った分岐情報が存在したため、後
続の命令先取りのやり直しを行なう必要のあることが検
出され、次のマシンサイクル3のOTステージでは誤っ
た7& 続の命令の動作は全てキャンセルされ、正しい
後続の命令A2の命令取出しを行なうIcステージが実
行されている。一方、命令Atについての分岐情報が誤
っていること並びに分岐N0GO側の後続の命令先取り
のやり直しが行なわれたことが、命令A1の実行にとも
なって各ステージのフリップフロップに持回られる。こ
のため、マシンサイクル5の命令A1のEXステージで
は、再び、命令Alの実行結果より分岐GOの指示が出
されないにもかかわらず、分岐情報が存在していて分岐
Go側へ後続の命令先取りが行なわれたことが検出され
るが、先取りのやり直しの情報を持回るフリップフロッ
プによってEXステージからは改めて命令先取りのやり
直しをする必要のないことが判断され、分岐ヒストリテ
ーブル上の誤った分岐情報の更新の指示だけが行なわれ
る。若しこのEXステージで命令先取りのやり直しが再
び指示された場合、既に先取りされている正しい7& 
hlの命令A2はOAXステージで実行されているとい
うのにキャンセルされてしまい、改めてICステージか
ら実行されることになる。
第18図を参照すると、無条件分岐命令あるいは実際に
は分岐GoとなるBCT命令である命令B1についての
分岐情報が分岐ヒストリテーブルにヒツトしなくて分岐
N0GO側へ後続の命令先取りが行なわれた場合を示し
ているが、命令B1の0′rステージが行なわれるマシ
ンサイクル3において、命令B1が無条件分岐命令であ
ること、或いは実際に分岐GoとなるBCT命令である
ことが検出され、次のマシンサイクル4において正しい
後続の分岐先の命令CIの取出しが行なわれるICステ
ージが実行されている。命令B1についての分岐情報が
ヒツトしなかったこと、つまり分岐ヒストリテーブルが
更新されるべきであるということと、既に分岐Go側へ
の後続の命令の先取りが行なわれたことは、各ステージ
に置かれたフリップフロップで命令Blの実行とともに
持回られる。このため、命令B1のEXステージでは、
命令Blの実行結果が分岐GOであるのに分岐情報がヒ
ツトしなかったことから再び命令B1の後続の命令先取
りが誤っていたことが検出されるが、フリップフロップ
の情報によってEXステージからは改めて命令の先取り
のやり直しの指示が出されることはなく、分岐情報の更
新のみが指示される。
第19図を参照すると、実際には分岐N0GOとなるB
CT命令BCTIが誤った分岐情報によって分岐GO側
へ後続の命令先取りが行なわれた場合を示しているが、
第18図と同様、マシンサイクル3の命令BCTIのO
Tステージで、命令BCT1は分岐N0GOとなること
、にもかかわらず分岐GO側へ先取りが行なわれたこと
が検出され、マシンサイクル4において正しい後続の命
令A1の取出しを行なうICステージが実行されている
分岐N0GO側への先取りのやり直しが行なわれたこと
と、分岐ヒストリテーブルの更新が必要なことは、各ス
テージのフリップフロップに持回られ、命令BCTIの
EXステージでは、命令の先取りやり直しの必要のない
ことが判断され、分岐情報の更新のみ指示される。
第20図を参照すると、無条件分岐命令あるいは実際に
分岐GOとなる条件分岐命令である命令B1の分岐情報
が分岐ヒストリテーブルにヒツトして、分岐情報の示す
分岐先アドレスに従って分岐先の命令C1が先取りされ
たにもかかわらず、分岐情報の示す分岐先アドレスが誤
っていた場合を示しており、マシンサイクル4の命令B
1のOCステージで、先取りされた分岐先アドレスが誤
っていることが検出され、次のマシンサイクル5におい
て正しい分岐先の命令DIの取出しを行なうIcステー
ジが実行されている。同時に、命令B1についての分岐
情報の誤っていることと、正しい分岐GO側の命令の先
取りのやり直しが指示されたことは、フリッププロップ
で持回られる。命令B1のEXステージで命令Blにつ
いての分岐情報の更新が指示され、マシンサイクル6で
命令B1のHUXステージ実行され、分岐情報の更新が
行なわれている。
第21図を参照すると、実際には分岐N OG Oとな
る条件分岐命令BCIの分岐情報がヒントして、分岐情
報の示す分岐先アドレスに従って命令C1が先取りされ
たものの、分岐情報の示す分岐先アドレスは命令語の示
す分岐先アドレスとは異なっていた場合を示している。
マシンサイクル4の命令BCIのoCステージにおいて
、先取りされた分岐先アドレスが誤っていたことが検出
され、誤って先取りされた命令CI、C2,C3,C4
の動作がキャンセルされるとともに命令BCIの命令語
によって指定された分岐先アドレスによって命令DIの
取出しが指示される。次のマシンサイクル5において、
命令D1のICステージが実行されるとともに、命令B
CIの分岐GO側への命令先取りのやり直しが行なわれ
たことと、分岐情報の更新がa・要なことが持回りのフ
リップフロップにセットされる。同時に命令BC1のE
Xステージが実行され、命令BCIの命令語で指定され
た分岐条件が判定されて、その結果、分岐N0GOであ
ることが明らかになる。EXステージでは、フリップフ
ロップの情報から分岐Go側への命令先取りのやり直し
が行なわれたことを知り、改めて分岐N0GO側への命
令の先取りのやり直しを指示するとともに、命令BCI
の誤った分岐情報の更新を指示している。このため、次
のマシンサイクル6では、分岐GO側へ先取りが指示さ
れてICステージを実行した命令DIはキャンセルされ
、同時に命令BCIの分岐情報が更新され、更に次のマ
シンサイクル7において、正しい分岐N0GO側の命令
A1の取出しが実行される。
以上説明したように、本発明によれば、分岐情報の誤り
が検出されると、即座に正しい命令の先取りが開始され
るよう制御されるとともに、一度、先取りがやり直され
た場合は不必要な先取りのやり直しを再び指示すること
のないよう制御され、分岐情報が誤っていた場合、本発
明を適用しない従来技術に比べ格段に性能の向上が図れ
るという効果がある。
【図面の簡単な説明】
第1図は本発明の一実施例のブロック図、第2図は第1
図の分岐ヒストリテーブル410の実施例のブロック図
、 第3図は第2図の記憶部501および502の記憶形式
を示す図、 第4図は第2図のテスト回路503〜506の実施例の
ブロック図、 第5図は第1図の命令記憶回路408における命令語の
配列の一例を示す図、 第6図は第2図のプライオリティ回路507の実施例の
ブロック図、 第7図は第1図における分岐情報バッファ413および
分岐情報レジスタ416の格納形式を示す図、第8図は
第1図における分岐情報レジスタ417〜420の格納
形式を示す図、 第9図は第1図の命令記憶回路408における命令語と
分岐ヒストリテーブル410における分岐情報との対応
関係を説明するための図、 第10図は第9図の分岐ヒストリテーブル410による
命令先取り動作を説明するための図、第11図は第1図
のOAステージ予測確認回路424の実施例のブロック
図、 第12図は第1図のOTステージ予測確認回路425の
実施例のブロック図、 第13図は第1図のOCステージ予測確認回路426の
実施例のブロック図、 第14図は第1図のEXステージ予測確認回路427の
実施例のブロック図、 第15図は第1図の命令先取り制御回路423の実施例
のブロック図、 第16図は命令の処理の流れの概要を示す図、第17図
は分岐命令でない命令に対応する分岐情報が分岐ヒスト
リテーブルに登録されていてその誤った分岐情報に従っ
て命令先取りが行なわれた場合の動作を説明するための
タイムチャート、第18図は無条件分岐命令あるいは実
際には分岐を行なうBCT命令の実行において対応する
分岐情報が分岐ヒストリテーブルに登録されていない場
合の動作を説明するためのタイムチャート、第19図は
実際には分岐を行なわないBCT命令に対応する分岐情
報が分岐ヒストリテーブルに登録されていて、その分岐
情報に従って命令先取りが行なわれた場合の動作を説明
するためのタイムチャート、 第20図は無条件分岐命令あるいは実際に分岐を行なう
条件分岐命令に対応する分岐情報が分岐ヒストリテーブ
ルに登録されていて、その分岐情報に従って命令先取り
を行なったところ、その分岐情報の示す分岐先アドレス
が誤っていた場合の動作を説明するためのタイムチャー
トおよび、第21図は実際には分岐を行なわない条件分
岐命令に対応する分岐情報が分岐ヒストリテーブルに登
録されていて、その分岐情報に従って命令先取りを行な
ったところ分岐情報の示す分岐情報の示す分岐先アドレ
スが誤っていた場合の動作を説明するためのタイムチャ
ートである。 第1図〜第21図において、 401・・・命令アドレス生成回路 402・・・命令アドレス変換回路 403・・・命令解読回路 404・・・オペランドアドレス生成回路405・・・
オペランドアドレス変換回路406・・・オペランド続
出し回路 407・・・命令実行回路、408・・・命令記憶回路
409・・・命令バッファ 410・・・分岐ヒストリテーブル(BHT)411・
・・命令アドレスレジスタ 412・・・命令アドレス加算回路 413・・・分岐情報バッファ、414・・・命令整列
回路415・・・分岐情報切換回路 416・・・分岐情報レジスタ (QRO)417・・
・分岐情報レジスタ (QRI)418・・・分岐情報
レジスタ (QR2)419・・・分岐情報レジスタ(
QR3)420・・・分岐情報レジスタ (QR4)4
21.422・・・選択回路、423・・・命令先取り
制御回路424・・・OAステージ予測確認回路425
・・・OTステージ予測確認回路426・・・OCステ
ージ予Ill確認回路427・・・EXステージ予測確
認回路428・・・命令アドレスリカバレジスタ430
、431 、432・・・アドレス生成回路433・・
・比較回路、434,435・・・レジスタ436.4
37,438,439,440,441 ・・・フリッ
プフロップ501.502・・・記憶部 503.504,505,506・・・テスト回路50
7・・・プライオリティ回路、508・・・選択回路5
09・・・オア回路、601,602,603,604
・・・アンド回路605、606.607.608・・
・オア回路、701・・・一致回路702・・・大小比
較回路、703・・・アンド回路1101.1102・
・・フリップフロップ1103・・・ノット回路、11
04・・・アンド回路1201、1202.1203.
1204・・・フリップフロップ1206、1207・
・・真偽回路 1208、1209.1210・・・アンド回路121
1.1212.1213・・・オア回路1301、13
02・・・レジスタ、1303・・・フリップフロップ
1306・・・比較回路、1307・・・真偽回路13
08・・・アンド回路、1309.1310・・・オア
回路1401・・・フリップフロップ 1402、1403.1404・・・真偽回路1405
、1406・・・ナンド回路 1407、1408・・・アンド回路、1409・・・
オア回路1501・・・フリップフロップ 1502、1503.1504.1505.1506.
1507・・・真偽回路1508.1509.L5LO
,L5LL、15L2,1513.15L4,1515
.15に6゜1517、1518・・・アンド回路。 記憶部の記Im形式を示す図 第3図 BHT−1−11Ti テスト回路の実施例のブロック図 第4図 命令記憶回路における命令語の配列例を示す面部5図 プライオソティ回路の実施例のブロック図第6図 第7図 分岐情報レジスタ417〜420の格納形式を示す図第
8図 命令記憶1回路におけ4命令話と分岐ヒストリテーブル
にお1fる分岐情報との対応関係の説明図第9図 OAステージ予測確認回路の実施例のブロック図第11
図 OTステージ予測確認回路の実施例のブロック図0cス
テ一ジ予測確認回路の実施例のブロック図第13図

Claims (1)

  1. 【特許請求の範囲】 一連の命令実行処理過程を複数のステージに分け、複数
    の命令を同時に連続して実行するパイプライン方式で制
    御される情報処理システムにおける命令先取り装置にお
    いて、 分岐命令のアドレスを指定する情報と該分岐命令の分岐
    先アドレスを含む分岐情報とを対にして複数対記憶する
    分岐ヒストリテーブル手段と、命令先取り動作を行なう
    際に該命令先取り動作において先取りされる命令のアド
    レスを指定する情報が前記分岐ヒストリテーブル手段に
    登録されているか否かを調べる第1の点検手段と、 前記複数のステージにおいて前記先取りされた命令に対
    応する前記分岐情報が正しいか否かを調べる第2の点検
    手段と、 上記複数の異なるステージの一部または全部の各々に対
    して、当該ステージ以前のステージにおいて前記第2の
    点検手段によって生成された点検結果を保持するととも
    に、当該ステージの前記第2の点検手段の点検動作を制
    御するフリップフロップ群と、 前記第1の点検手段による登録の判明に応答して前記分
    岐ヒストリテーブル手段から対応する分岐情報を読出し
    該分岐情報に従って命令先取り動作を継続せしめるよう
    制御し、且つ、前記第1および第2の点検手段の結果に
    応答して誤った命令先取り動作が行なわれた時には前記
    先取りされた命令の後続の誤った命令先取り動作を是正
    せしめるよう制御する命令先取り制御手段とを具備した
    ことを特徴とする命令先取り装置。
JP32686A 1986-01-07 1986-01-07 命令先取り装置 Pending JPS62159233A (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP32686A JPS62159233A (ja) 1986-01-07 1986-01-07 命令先取り装置
US07/000,427 US4853840A (en) 1986-01-07 1987-01-05 Instruction prefetching device including a circuit for checking prediction of a branch instruction before the instruction is executed
DE3752100T DE3752100T2 (de) 1986-01-07 1987-01-05 Befehlsvorabrufgerät mit einer Schaltung zum Prüfen der Vorhersage eines Verzweigungsbefehls vor seiner Ausführung
EP87100055A EP0229619B1 (en) 1986-01-07 1987-01-05 Instruction prefetching device comprising a circuit for checking prediction for a branch instruction before the instruction is executed

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP32686A JPS62159233A (ja) 1986-01-07 1986-01-07 命令先取り装置

Publications (1)

Publication Number Publication Date
JPS62159233A true JPS62159233A (ja) 1987-07-15

Family

ID=11470781

Family Applications (1)

Application Number Title Priority Date Filing Date
JP32686A Pending JPS62159233A (ja) 1986-01-07 1986-01-07 命令先取り装置

Country Status (1)

Country Link
JP (1) JPS62159233A (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH08249181A (ja) * 1994-02-04 1996-09-27 Internatl Business Mach Corp <Ibm> ブランチ予測式データ処理装置および動作方法

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH08249181A (ja) * 1994-02-04 1996-09-27 Internatl Business Mach Corp <Ibm> ブランチ予測式データ処理装置および動作方法

Similar Documents

Publication Publication Date Title
US10795675B2 (en) Determine whether to fuse move prefix instruction and immediately following instruction independently of detecting identical destination registers
JPH0283735A (ja) 命令先取り装置
EP0352935B1 (en) Pipelined processor
JPH0429093B2 (ja)
EP0094535B1 (en) Pipe-line data processing system
KR930003124B1 (ko) 파이프라인방식의 분기명령제어장치
JP2643087B2 (ja) プログラム処理方法及びコンピュータ・システム
JPS62159233A (ja) 命令先取り装置
JPS62159230A (ja) 命令先取り装置
JPS5991551A (ja) 分岐先アドレス予測を行なう命令先取り装置
JPS62159231A (ja) 命令先取り装置
JPS62159229A (ja) 命令先取り装置
JPH046983B2 (ja)
JPS62159232A (ja) 命令先取り装置
JP2626675B2 (ja) データ誘起状態信号発生装置及び方法
JPS62159228A (ja) 命令先取り装置
JP2616542B2 (ja) 疑似障害発生システム
JPS60175148A (ja) 命令先取り装置
EP0211487A1 (en) Conditional operations in computers
JPH0248733A (ja) 情報処理装置
CA1223079A (en) Data processor having selective breakpoint capability with minimal overhead
JPS5991552A (ja) セツトアソシアテイブ型分岐ヒストリテ−ブルを有する命令先取り装置
JPH0311430A (ja) フエッチアクセス時の異常処理方法
JPH05210500A (ja) データ処理装置
JPS63214856A (ja) デ−タ処理装置のデ−タ保護制御方式