JPH0529941B2 - - Google Patents

Info

Publication number
JPH0529941B2
JPH0529941B2 JP2032614A JP3261490A JPH0529941B2 JP H0529941 B2 JPH0529941 B2 JP H0529941B2 JP 2032614 A JP2032614 A JP 2032614A JP 3261490 A JP3261490 A JP 3261490A JP H0529941 B2 JPH0529941 B2 JP H0529941B2
Authority
JP
Japan
Prior art keywords
address
bit
bits
register
validity
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.)
Expired - Lifetime
Application number
JP2032614A
Other languages
English (en)
Other versions
JPH02245949A (ja
Inventor
Jeemuzu Ozuraa Piiitaa
Tsu Tongu Furetsudo
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.)
International Business Machines Corp
Original Assignee
International Business Machines 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 International Business Machines Corp filed Critical International Business Machines Corp
Publication of JPH02245949A publication Critical patent/JPH02245949A/ja
Publication of JPH0529941B2 publication Critical patent/JPH0529941B2/ja
Granted legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/10Address translation
    • G06F12/1027Address translation using associative or pseudo-associative address translation means, e.g. translation look-aside buffer [TLB]

Description

【発明の詳細な説明】 A 産業上の利用分野 本発明は、デイジタル・プロセツサから出力さ
れた有効アドレスから生じる仮想アドレスをコン
ピユータ・メモリ内の実アドレスに変換するため
のシステム及び方法に関し、さらに具体的には、
この変換処理の速度を増大させる推定機構に関す
るものである。
B 従来の技術 データ処理中にルツクアサイド・テーブルを使
つて仮想アドレスを実アドレスに変換することは
周知であり、前に変換されたアドレスをテーブル
項目に記憶しておいて、同じ仮想アドレスが再び
要求されたとき直ちに得られるようにしている。
この技術は、一度処理されたアドレス要求が繰り
返される確率が高いことを利用したもので、要求
が発生するたびに主メモリに頼る必要をなくすこ
とにより、アドレス処理に必要な時間を短縮す
る。
区分変換ルツクアサイド・バツフア(TLB)
を使用する従来技術のシステムの1例は、米国特
許第4367297号明細書に記載されており、入力ア
ドレスと適切に一致したとき、TLBに記憶され
たアドレスが変換のため使用されて、もつと時間
のかかる通常の複数取り出しアドレス変換処理を
打ち切る。区分TLBの代わりに事前変換テーブ
ルを使つて変換処理の速度を増すことを特徴とす
る従来システムのもう1つの例は、米国特許第
4170039号明細書に開示されている。これらの例
及び関連技術の考察から明らかなように、変換処
理の高速化は当技術では避けられない問題であ
り、多くの異なる方法で処理されてきた。
C 発明が解決しようとする課題 本発明の目的は、高い確率で正しい推定をもた
らす、最も最近に使用された指示を与えるアルゴ
リズムを含む推定機構を使用することにより、簡
単で効率的な改善された方式で上記の問題に対す
る解決策を提供することである。
D 課題を解決するための手段 本発明は、プロセツサによつて発生された有効
(effective)アドレスをメモリ内の実アドレスに
変換する速度を向上させるための推定機構を提供
するシステム及び方法として実施され、1組のル
ツクアサイド・テーブル及び論理要素を、1組の
妥当性(validity)レジスタ及び1つのMRUレ
ジスタと共に使用して、2サイクル動作の第1サ
イクルの間に、実アドレスで出力するためテーブ
ルの1つから適当な実フレーム・インデツクスを
選択する。さらに具体的には、テーブル・セツト
中の各テーブルはアドレス項目のリストを含み、
アドレス項目はテーブルを横断するいくつかのセ
ツトとして配列され、各項目は仮想ページ・イン
デツクス(VPI)、セグメントID(SID)及び実フ
レーム・インデツクス(RFI)を含んでいる。各
妥当性レジスタは、セツト中の当該のテーブルの
各項目の妥当性をそれぞれ示す値を有するビツト
を含み、MRUレジスタは各アドレス項目セツト
に対応するビツトを含み、これらのビツトは、セ
ツトの最も最近使用された(MRU)項目を含む
各セツト内のテーブルをそれぞれ示す値を有す
る。妥当性レジスタ及びMRUレジスタ内のビツ
トは推定機構に入力され、推定機構は、第1サイ
クル中にRFIを実アドレスに出力する際に正しい
推定を行なう可能性を大幅に高める。
動作の際には、有効アドレス(EA)の一部分、
すなわち下位ビツトが第1サイクル中にテーブル
内にインデツクスされて、アドレス項目セツトに
関する一致に応答して、一致したセツト中の各項
目から実フレーム・インデツクスを読み出す。同
じ下位有効アドレス・ビツトを使つて、妥当性レ
ジスタ及びMRUレジスタが検査され、一致した
アドレス項目セツトに対応するそれらのレジスタ
内のビツトの値が決定される。次に、1)「推定」
RFIを含む選択されたアドレス項目に関する当該
の妥当性レジスタ内の有効ビツトの決定と、2)
「推定」RFIが含まれる一致したセツト中のテー
ブルを示すMRUレジスタ内のMRU指示ビツト
値とに応答して、「推定」実フレーム・インデツ
クスが、一致したアドレス項目セツト中のRFIの
うちから選択されて、実アドレスに組み込むべく
出力される。次に、第2サイクルで有効アドレス
の上位ビツトを使つて、有効アドレスの上位ビツ
トをSIDレジスタにインデツクスし、それらを、
第1サイクルで適当な実フレーム・インデツクス
(「推定」RFI)を含むものとして選択されたテー
ブル項目セツトと比較することにより、第1サイ
クルの推定を検査する。1)第1サイクル中に出
力される「推定」RFIを含むテーブル項目と、
2)第2サイクルの上位ビツト比較との比較で、
選択された実フレーム・インデツクスが不適当で
あつたことを論理機構が示す場合は、第2サイク
ルの後に、その「推定」RFIを含む実アドレスの
出力を無効にする信号が送られる。妥当性レジス
タ及びMRUレジスタの検査を行なうための大多
数の推定が正しくなるので、仮想アドレス変換の
性能が大幅に向上する。
E 実施例 本発明を実施する際の機能要素間でのデータの
流れを示す図を第1図に示す。好ましい構成、及
び本発明を実現するのに重要な関連する仮想変換
の諸機能について詳細に説明する。しかし、本発
明は、異なる構成を有する他の一般的変換方式に
も適用できることを理解されたい。
簡単に言うと、このシステムを通常構成する要
素には以下のものがある。
・ それぞれ下記のアドレス項目セツトを有す
る、テーブル10セツト、たとえば、TLB0,
TLB1を含む2方向連想式16合同式クラスの
変換ルツクアサイド・バツフア(TLB)。
− 仮想ページ・インデツクス(VPI):12ビ
ツト −セグメントID(SID):15ビツト − 実フレーム・インデツクス(RFI):15ビ
ツト ・ それぞれ15ビツトを含む、SID項目を有する
16個のセグメント・レジスタ20。
・ それぞれ16ビツトを含む、各テーブルTLB
0、TLB1用の妥当性レジスタ30,31。
・ 16ビツトを含むMRUレジスタ40。
・ 「推定」RFIを選択するための制御論理機構
50,51。
・ 選択された「推定」RFIを検査するための制
御論理機構60a,60b,61a,61b,
70a,70b,71a,71b、80,9
0。
データの流れに含まれる主な信号は以下の通り
である。
・ EA(有効アドレス):16個の上位ビツト
(HEA)及び16個の下位ビツト(LEA)を含
む。上位ビツトと下位ビツトのそれぞれ最初の
4ビツト(HEA−h,LEA−h)はインデク
シングに使用され、一方、HEAビツトの最後
の12個(HEA−)は推定検査に使用され、
LEAビツトの最後の12個(LEA−)は実ア
ドレス(RA)出力の下位ビツトとして付加さ
れる。
・ VA(仮想アドレス):セグメント・レジスタ
の15個のSIDビツト、HEA−の12ビツト、
LEA−hの4ビツト及びLEA−lの12ビツト
を含む。
・ RA(実アドレス):テーブルの1つから選択
されたRFIを示す15個の上位ビツト、及び12個
の下位ビツトを含む。
・ GUESS0:RFI0を送出するための多重化
を制御するために使用される。
・ GUESS1:RFI1を送出するための多重化
を制御するために使用される。
・ TLB0HIT:TLB0から導かれる比較指示 ・ TLB1HIT:TLB1から導かれる比較指示 ・ TLB−MISS:TLB項目で一致が見つから
なかつたことを示す。
・ WRONG GUESS:推定アドレスが、比較
されたアドレスと同じでないことを示す。
さらに具体的には、本発明の変換・推定動作を
実施するための好ましいシステムを第1図に詳細
に示し、かつ第1図を参照して説明する。このシ
ステムはまず、ルツクアサイド・テーブル・セツ
ト10を含む変換ルツクアサイド・バツフア
TLBを備えている。説明の便宜上、それぞれ16
個の合同式クラスをもつ2方向連想式の2つのそ
のようなテーブルTLB0及びTLB1を図に示す
が、関連する構成要素に適当な変更を加えること
により、このセツトにもつと多くのテーブルを容
易に追加できることが、以下の説明から理解され
るはずである。各テーブル、すなわちTLB0及
びTLB1は、アドレス項目(16個とするのが好
都合)のリストを含み、隣接する項目11は、並
列に動作して各テーブルを横断してセツトを形成
する。各アドレス項目11は、12ビツトの仮想ペ
ージ・インデツクス(VPI),15ビツトのセグメ
ントID(SID)、及び15ビツトの実フレーム・イン
デツクス(RFI)を含む。当業者なら理解できる
ように、この構成はIBM370等のコンピユータ・
アーキテクチヤに合致するように選択するのが好
都合であり、また当業者は適当なテーブルを作成
する方法を熟知しているはずなので、ここではそ
れについては説明しない。
変換ルツクアサイド・バツフアTLBに加えて、
システムはそれぞれ15ビツトの1群のセグメン
ト・レジスタ20(TLBテーブル・リストのア
ドレス項目の数に一致するよう、16個とするのが
好都合)、それぞれ16ビツトの2つの妥当性レジ
スタ30と31、及び16ビツトのMRUレジスタ
40を含む。セグメント・レジスタ20は、以下
にさらに詳しく説明するように、ルツクアサイ
ド・テーブルTLB0及びTLB1内の項目11中の
SIDと比較すべきSID項目21を含む。妥当性レジ
スタ30及び31は、それぞれTLB0及びTLB
1内のアドレス項目11の妥当性を示すビツトを含
み、MRUレジスタ40は、テーブル内の並列ア
ドレス項目の各セツトごとに、このセツトの最も
最近に使用された項目を含む、このセツト中の特
定のテーブル10を示す値をもつビツトを含む。
レジスタ30,31及び40はそれぞれ、テーブ
ル10の項目と関係する項目を含む関連する選択
マクロ30a,31a及び40aを有する。
さらに、推定機構及び、以下に説明するよう
に、最終的に装置102からシステムに出力され
る実アドレスに組み込まれるRFIを発生させるた
めの比較機構60a,60b,61a,61b,
ANDゲート70aと70b,71aと71b,
50と51及び80、及びORゲート90を含む
論理要素の組合せが、多重化出力装置101と共
に設けられている。
以下のようにして推定機構は動作し、実アドレ
ス(RA)が最終的にシステムによつて出力され
る。まず第1に、変換される有効アドレス(EA)
の32ビツトが、連続する2サイクルでデイジタ
ル・プロセツサPからシステム制御装置SCUに
送られる。すなわち、各サイクルでビツトの半
分、すなわち16ビツトが送られる。本発明によれ
ば、有効アドレスの下位半分LEA(ビツト16:
31)が最初に送られ、次のサイクルで上位半分
HEA(ビツト0:15)が送られる。EAの下位半
分の最初の4ビツトLEA−h(16−19)はTLB内
にインデツクスするために使用される。テーブル
にリストされた一組のアドレス項目11との一致が
見られた場合は、適当な並列項目(この例では2
個)から実フレーム・インデツクス(RFI)が
TLB0及びTLB1から読み取られ、多重化出力
装置101に直接送られる。装置101によつて
出力されたRFIは、下位ビツトLEA−1(20:31)
の残りのビツトと共に、第1サイクルの後に装置
102から送出される実アドレスRAに組み込ま
れる。しかし、1つのRFIのみが正しく、どちら
が使用すべき正しいRFIかを判定するために上位
ビツト(HEA)とTLB項目の間の比較が必要で
あり、かつその情報は次のサイクルまで入手でき
ないので、正しいアドレスを出力するには第2サ
イクルの完了まで待つ必要があるように思われ
る。本発明によれば、処理の速度を増すため、た
だちに判定または推定を行なつて第1サイクルの
後で実アドレスRAに出力される1つのRFIを選
択することができ、この選択を第2サイクルの後
で検査し、この選択が正しくない場合は、実アド
レスを無効にすることができる。相当な高速化を
実現するため、以下のアルゴリズムに基づいて、
第1図のシステムを使つて推定が行なわれる。
MRUビツト=0で、かつTLB0に対する有効
ビツト=1の場合は、 RFI0を使用する。
MRUビツト=1で、かつTLB1に対する有効
ビツト=1の場合は、 RFI1を使用する。
このアルゴリズムは、正しい推定率が95%より
もよいかなり高いことが判明したので、それを使
用すると、メモリに対するほぼすべての(実)ア
クセスで1サイクルが節約される。
本発明の推定機構は、このシステムで以下のよ
うにして実施される。第1図に見られるように、
EAの下位半分の最初の4ビツト(16:19)は、
TLB内にインデツクスされることに加えて、選
択マクロ30a,31a及び40aに対する当該
の入力としても使用される。これらの選択マクロ
は、妥当性レジスタ30及び31及びMRUレジ
スタ40に動作可能に接続されている。これらの
マクロは、テーブル10の項目に関係する項目を
含み、EAビツト(LEA−h)と妥当性レジス
タ・ビツト及びMRUレジスタ・ビツトとの比較
に応答して、適当な出力を供給する。マクロの単
一ビツト出力は、アルゴリズムに従つて、AND
ゲート50及び51に送られる。マクロ30a及
び31aはゲート50及び51にそれぞれの入力
を供給し、マクロ40aはその出力を各ゲートに
供給し、ゲート50への入力は反転される。
ANDゲート50及び51は、それぞれ推定出力
信号GUESS(0)及びGUESS(1)を発生し、そ
れが多重化出力装置101、及びそれぞれAND
ゲート71b及び70bに入力される。
ANDゲート50及び51の一方または他方が
出力GUESS信号を発生し、それが多重化出力装
置101に入力されることを理解されたい。上記
アルゴリズムに従つて、MRU出力が1で、か
つ、TLB1に対する妥当性レジスタ31及びマ
クロ31aの出力が1の場合、ゲート51は、適
当な出力装置102でLEA−1ビツトと共に実
アドレス出力RAに組み込まれるRFI(1)信号を出
力させる信号を、多重化出力装置101に供給す
る。逆に、MRU出力が0で、かつTLB0に対す
る妥当性レジスタ30及びマクロ30aの出力が
1の場合は、ゲート50は、装置102でLEA
−1と共に実アドレス出力RAに組み込まれる
RFI(0)信号を出力させる出力を多重化装置1
01に供給する。したがつて、プロセツサPから
の最初の入力サイクルに続いて、一致が見つかつ
たTLBテーブルからの項目セツトからの様々な
RFIのうち最良の推定となるRFI部分を含む、実
アドレス(RA)が出力される。この推定が正し
いか否かが、第2サイクル中に受け取つた情報に
応答して検査される。
第2サイクルでは、EAの上位ビツトの最初の
4ビツト(HEA−h)がセグメント・レジスタ
20内にインデツクスするために使用され、一致
があつたときは、適当な15ビツトが発生されて、
テーブルTLB0及びTLB1からのSID出力と比
較すべくSID比較機構60b及び61bに出力さ
れる。これらのSID出力は第1サイクルの間に、
LEA−hビツトとその中の項目との一致によつ
て発生されたものである。残り12個の上位ビツト
(HEA−)は、一致したSID出力と同じ項目セ
ツト中のテーブルからのVPI出力と比較すべく、
VPI比較機構60a及び61aに直接入力され
る。比較機構60a及び60bはANDゲート7
0aに入力を供給し、比較機構61a及び61b
はANDゲート71aに入力を供給する。比較機
構60a及び60bからの出力がともに正である
場合は、ANDゲート70aはTLB0HIT信号を
ANDゲート70bに出力し、比較機構61a及
び61bからの出力がともに正である場合は、
ANDゲート71aはTLB1HIT信号をANDゲ
ート71bに出力する。ANDゲート70aと7
1aのどちらの出力にも正の信号が現れない場合
は、ANDゲート80は、第1サイクル中にイン
デクシング・ビツトLEA−hがテーブル項目中
で一致を見つけられなかつたことを示す信号
(TLB−MISS)を出力する。したがつて、変換
のためアドレス要求を主メモリに送られねばなら
ない。
ANDゲート70a及び71bの出力は、それ
ぞれANDゲート51及び50からのGUESS信号
と共にANDゲート70b及び71bに入力され
る。TLB0HITを示すゲート70aからの正の
信号がゲート70bに入力され、同時に正の信号
GUESS(1)が入力される場合は、ゲート70b
はORゲート90への出力を発生し、次いでOR
ゲート90は第1サイクルでの推定が誤つている
ことを示す。その結果発生するWRONG
GUESS信号は、前の推定アドレスが比較された
アドレスと同じでないことを示し、次にこの信号
を使つて正しくないRFIを含む装置102からの
RA出力が無効にされる。同様に、TLB1HITを
示すゲート71aからの正の信号がゲート71b
に入力され、同時に正の信号GUESS(0)が入力
される場合は、ゲート71bは、ORゲート90
への出力を発生し、ORゲート90はやはり、第
1サイクルでの推定が誤つていることを示す。そ
の結果発生するWRONGGUESS信号は、前の推
定アドレスが比較されたアドレスと同じでないこ
とを示し、次にこの信号を使つて、正しくない
RFIを含む装置102からのRA出力が無効にさ
れる。無効動作を行なうには、「破棄」信号を送
つて前の要求を取り消すこと、及び正しいものを
再び送ること、または要求に応じて誤つたアドレ
スからのデータを無効にすることが必要なことが
ある。
この方式がすべての場合に働くことを保証する
には、以下の規則を守ることが好ましい。
・ アルゴリズムが命令取出し、分岐、ロード及
び入出力読取りにのみ適用され、記憶動作には
適用されない。
・ 誤つた推定の場合は、前の要求を取り消すた
めの「破棄」信号が送出され、正しい推定が再
び送出される。
・ 記憶保護検査等の例外検査が検出された場合
は、推定は行なわれない。
「推定」事象のプロトコル・タイミング図を第
2図に示す。
・ABUS:アドレス・バスであり、最初に下位
有効アドレス・ビツトを送り、次のサイク
ルで上位有効アドレス・ビツトを送る。
・GUESS:推定有限状態機械を始動するための
信号。
・PENDING:プロセツサが有効アドレスの取
消しまたは変更を行なわないことを確認す
るための信号。
・REQUEST:メモリにデータを求める要求を
送る。
・ACK:要求を受け取つたという記憶制御装置
からの肯定応答。
・OP−DONE:要求が処理されたという肯定応
答。
推定有限状態機械(FSM)は、このプロトコ
ルを処理できるように実施される。このFSMは
仮想制御装置に併合されている。話を簡単にする
ため、第3図には、この状態機械を以下の3状態
でのみ示す。
・TIDS:変換遊休状態 ・TGUS:変換推定状態。GUESS信号によつて
開始され、記憶制御装置からの肯定応答を
待つている間、または複数推定の間そのま
まである。
・TGCS:変換推定訂正状態。最後の誤つた推定
が訂正されるまでそのままである。
さらに、性能上の理由から、プロセツサは通
常、第1サイクルで変換されるアドレスを送り、
1サイクル後に要求を確認する。これは主として
プロセツサが内部パイプライン・ルツクアヘツド
構造になつているためである。したがつて、連続
する複数の推定を処理するための論理機構が、第
3図に示した有限状態機械に組み込まれている。
以上、本発明を、有効アドレスが時間多重化さ
れるシステムでの適用例について説明してきた
が、この方式は、セグメント・レジスタを有する
すべての仮想システムに適用することができる。
というのは、この方式は、セグメントが読み取ら
れ、次いで比較される間に、記憶制御装置に対す
る要求が開始できるからである。バスを時間多重
化すると、有用性がさらに高まる。
したがつて、本発明は、プロセツサによつて発
生される有効アドレスをメモリの実アドレスに変
換する速度を向上させるための推定機構を含むシ
ステムを提供するものであり、このシステムで
は、1組の妥当性レジスタ及びMRUレジスタを
使つて、1組のルツクアサイド・テーブルのうち
の1つからの適当な実フレーム・インデツクス
(RFI)の選択時に推定が行なわれ、このRFIは
2サイクル動作の第1サイクルで、変換された実
アドレスに出力される。有効アドレスの下位ビツ
トの一部分は第1サイクルの間にテーブルをイン
デツクスするために送られ、上位ビツトは、第1
サイクルで適当なRFIを含むものとして選択され
たテーブル項目セツトと比較するために、第2サ
イクルで使用される。1)第1サイクルで出力さ
れた実フレーム・インデツクス(RFI)を含むテ
ーブル項目と、2)第2サイクルの上位ビツト比
較との比較に基づいて、選択されたRFIが不適当
であることを論理機構が示す場合は、第2サイク
ルの後に、そのRFIを含む実アドレス出力を無効
にする信号が送られる。
E 発明の効果 本発明によれば、プロセツサによつて発生され
た有効アドレスをメモリ内の実アドレスに変換す
る速度が向上する。
【図面の簡単な説明】
第1図は、本発明を実施するための好ましい構
成の機能要素間でのデータでの流れを示す概略図
である。第2図は、第1図のデータの流れに対す
るプロトコル・タイミング図である。第3図は、
本発明の動作を示す有限状態機械を示す図であ
る。 10……ルツクアサイド・テーブル、20……
セグメント・レジスタ、30,31……妥当性レ
ジスタ、60a,60b,61a,61b……比
較機構、101……多重化出力装置。

Claims (1)

  1. 【特許請求の範囲】 1 有効アドレスを示す複数ビツト信号を供給す
    るプロセツサ手段の出力に応答して、仮想アドレ
    スを実アドレスに変換するための装置であつて、 各テーブルが、テーブルを横断するセツトの形
    で配列されたアドレス項目のリストを有し、各項
    目が仮想ページ・インデツクス及び実フレーム・
    インデツクスを含んでなる、ルツクアサイド・テ
    ーブルのセツトと、 各妥当性レジスタが、上記テーブル・セツトの
    それぞれのテーブル中の各項目の妥当性をそれぞ
    れ示す値を有するビツトを含んでなる、妥当性レ
    ジスタのセツトと、 各アドレス項目セツトに対応するビツトを含
    み、上記ビツトが、各セツト中の最も最近に使用
    された項目を含むテーブルをそれぞれ示す値を有
    してなる、MRUレジスタと、 アドレス項目セツトに関する一致に応答して、
    一致したセツト内の各項目からの実フレーム・イ
    ンデツクスを読み出すため、上記有効アドレス・
    ビツトの一部分を上記テーブル内にインデツクス
    するための手段と、 上記有効アドレス・ビツトの上記部分を使つて
    上記妥当性レジスタ及び上記MRUレジスタを検
    査して、一致したアドレス項目セツトに対応する
    その中のビツトの値を決定するための手段と、 一致したアドレス項目セツトから読み出された
    ものから、実アドレスに組み込むべく出力される
    実フレーム・インデツクスを選択する信号を発生
    するための推定手段とを含み、 上記選択信号が、1)上記実フレーム・インデ
    ツクスを含む選択されたアドレス項目に関する当
    該の妥当性レジスタ内の有効ビツトの決定と、
    2)上記実フレーム・インデツクスが含まれる上
    記一致セツト中のテーブルを示す上記MRUレジ
    スタ内のMRU指示ビツト値とに応答することを
    特徴とする 装置。 2 ルツクアサイド・テーブル・セツトをバツフ
    ア内に有し、アドレス項目がテーブルを横断する
    セツトの形で配列され、かつ各項目が仮想ペー
    ジ・インデツクス及び実フレーム・インデツクス
    を含んでなるコンピユータで仮想アドレスを変換
    するための方法であつて、 それぞれが、上記バツフア内の当該のテーブル
    の各アドレス項目の妥当性をそれぞれ示す値を有
    するビツトを含む、妥当性レジスタのセツトを設
    けるステツプと、 上記テーブルを横断する各アドレス項目セツト
    ごとに、そのセツトの最も最近に使用された項目
    を含むセツト中のテーブルをそれぞれ示す値を有
    するビツトを含むMRUレジスタを設けるステツ
    プと、 有効アドレスを示す複数ビツト信号を供給する
    ステツプと、 上記有効アドレス・ビツトの一部分を上記テー
    ブル内にインデツクスし、アドレス項目セツトに
    関する一致に応答して、一致したセツト中の各項
    目に対する実フレーム・インデツクスを読み出す
    ステツプと、 上記有効アドレス・ビツトの上記1部分を使つ
    て上記妥当性レジスタ及び上記MRUレジスタを
    検査して、一致したアドレス項目セツトに対応す
    るその中のビツトの値を決定するステツプと、 実アドレスに含めるべく出力される一致セツト
    の実フレーム・インデツクスを選択するための推
    定信号を発生するステツプとを含み、 上記選択が、選択された実フレーム・インデツ
    クスを含むアドレス項目に対する妥当ビツトの決
    定と、上記アドレス項目が含まれるテーブルに対
    するMRU指示ビツトとに応答して行なわれるこ
    とを特徴とする 方法。
JP2032614A 1989-02-15 1990-02-15 アドレス変換装置及び方法 Granted JPH02245949A (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US07/311,666 US5099415A (en) 1989-02-15 1989-02-15 Guess mechanism for virtual address translation
US311666 1989-02-15

Publications (2)

Publication Number Publication Date
JPH02245949A JPH02245949A (ja) 1990-10-01
JPH0529941B2 true JPH0529941B2 (ja) 1993-05-06

Family

ID=23207923

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2032614A Granted JPH02245949A (ja) 1989-02-15 1990-02-15 アドレス変換装置及び方法

Country Status (4)

Country Link
US (1) US5099415A (ja)
EP (1) EP0382910B1 (ja)
JP (1) JPH02245949A (ja)
DE (1) DE68924414T2 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0649339U (ja) * 1992-05-13 1994-07-05 正民 丸山 ハサミのいらない便利な封筒

Families Citing this family (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH02205953A (ja) * 1989-02-03 1990-08-15 Nec Corp アドレス変換装置
US5341485A (en) * 1991-05-07 1994-08-23 International Business Machines Corporation Multiple virtual address translation per computer cycle
US5500948A (en) * 1991-10-29 1996-03-19 Intel Corporation Translating instruction pointer virtual addresses to physical addresses for accessing an instruction cache
US5485589A (en) * 1991-12-31 1996-01-16 Dell Usa, L.P. Predictive addressing architecture
US5392410A (en) * 1992-04-30 1995-02-21 International Business Machines Corporation History table for prediction of virtual address translation for cache access
US5392414A (en) * 1992-06-30 1995-02-21 Sun Microsystems, Inc. Rapid data retrieval from data storage structures using prior access predictive annotations
US5548739A (en) * 1993-11-04 1996-08-20 Sun Microsystems, Inc. Method and apparatus for rapidly retrieving data from a physically addressed data storage structure using address page crossing predictive annotations
JP3456768B2 (ja) * 1994-09-28 2003-10-14 株式会社東芝 アドレス変換装置
US5682495A (en) * 1994-12-09 1997-10-28 International Business Machines Corporation Fully associative address translation buffer having separate segment and page invalidation
JPH0981457A (ja) * 1995-09-18 1997-03-28 Nec Corp キャッシュ記憶制御装置
US5940877A (en) * 1997-06-12 1999-08-17 International Business Machines Corporation Cache address generation with and without carry-in
US6192459B1 (en) * 1998-03-23 2001-02-20 Intel Corporation Method and apparatus for retrieving data from a data storage device
US8862827B2 (en) * 2009-12-29 2014-10-14 International Business Machines Corporation Efficient multi-level software cache using SIMD vector permute functionality
US10318435B2 (en) * 2017-08-22 2019-06-11 International Business Machines Corporation Ensuring forward progress for nested translations in a memory management unit

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4050094A (en) * 1976-04-30 1977-09-20 International Business Machines Corporation Translator lookahead controls
US4128875A (en) * 1976-12-16 1978-12-05 Sperry Rand Corporation Optional virtual memory system
US4241401A (en) * 1977-12-19 1980-12-23 Sperry Corporation Virtual address translator utilizing interrupt level code
US4376297A (en) * 1978-04-10 1983-03-08 Signetics Corporation Virtual memory addressing device
US4170039A (en) * 1978-07-17 1979-10-02 International Business Machines Corporation Virtual address translation speed up technique
US4218743A (en) * 1978-07-17 1980-08-19 International Business Machines Corporation Address translation apparatus
US4481573A (en) * 1980-11-17 1984-11-06 Hitachi, Ltd. Shared virtual address translation unit for a multiprocessor system
US4410941A (en) * 1980-12-29 1983-10-18 Wang Laboratories, Inc. Computer having an indexed local ram to store previously translated virtual addresses
US4583162A (en) * 1983-01-13 1986-04-15 The Singer Company Look ahead memory interface
US4691277A (en) * 1984-10-24 1987-09-01 International Business Machines Corp. Small instruction cache using branch target table to effect instruction prefetch

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0649339U (ja) * 1992-05-13 1994-07-05 正民 丸山 ハサミのいらない便利な封筒

Also Published As

Publication number Publication date
DE68924414T2 (de) 1996-05-02
EP0382910A2 (en) 1990-08-22
DE68924414D1 (de) 1995-11-02
EP0382910A3 (en) 1991-08-07
US5099415A (en) 1992-03-24
JPH02245949A (ja) 1990-10-01
EP0382910B1 (en) 1995-09-27

Similar Documents

Publication Publication Date Title
US5265227A (en) Parallel protection checking in an address translation look-aside buffer
KR960001946B1 (ko) 우선 변환 참조버퍼
JP2618175B2 (ja) キャッシュ・アクセスのための仮想アドレス変換予測の履歴テーブル
CA1092719A (en) Synonym control means for multiple virtual storage systems
US4800489A (en) Paged memory management unit capable of selectively supporting multiple address spaces
JP3936378B2 (ja) アドレス変換装置
JP5373173B2 (ja) アドレス変換方法及び装置
JPH0529941B2 (ja)
JPH0564816B2 (ja)
JPH0137773B2 (ja)
US5226132A (en) Multiple virtual addressing using/comparing translation pairs of addresses comprising a space address and an origin address (sto) while using space registers as storage devices for a data processing system
US20050102473A1 (en) Cache control method and processor system
EP0173909B1 (en) Look-aside buffer least recently used marker controller
KR100321107B1 (ko) 데이타 프로세싱 시스템 내의 캐쉬 메모리를 억세싱하기 위한 방법 및 시스템
JP3190700B2 (ja) アドレス変換装置
KR910007029B1 (ko) 어드레스 변환장치
US6327646B1 (en) Translation look-aside buffer utilizing high-order bits for fast access
JPH055137B2 (ja)
JP3015528B2 (ja) アドレス変換バッファ機構
JPS623354A (ja) キヤツシユメモリ・アクセス方式
JP2507785B2 (ja) ペ―ジテ―ブルエントリ無効化装置
JP2797961B2 (ja) 検索システム
JPH06309196A (ja) トレース機能付情報処理装置
JPH03110648A (ja) データ処理システム
JP2837174B2 (ja) アドレス変換バッファ構成方式