JPH11328017A - 偶数/奇数キャッシュ・ディレクトリ方法及び装置 - Google Patents

偶数/奇数キャッシュ・ディレクトリ方法及び装置

Info

Publication number
JPH11328017A
JPH11328017A JP11060382A JP6038299A JPH11328017A JP H11328017 A JPH11328017 A JP H11328017A JP 11060382 A JP11060382 A JP 11060382A JP 6038299 A JP6038299 A JP 6038299A JP H11328017 A JPH11328017 A JP H11328017A
Authority
JP
Japan
Prior art keywords
address
parity
cache directory
cache
index
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
JP11060382A
Other languages
English (en)
Inventor
Ravi Kumar Arimilli
ラビ・クマール・アリミリ
John Steven Dodson
ジョン・スティーブン・ドットソン
Jerry Don Lewis
ジェリー・ダン・ルイス
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 JPH11328017A publication Critical patent/JPH11328017A/ja
Pending 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
    • 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/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0893Caches characterised by their organisation or structure
    • G06F12/0895Caches characterised by their organisation or structure of parts of caches, e.g. directory or tag array

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Memory System Of A Hierarchy Structure (AREA)

Abstract

(57)【要約】 【課題】データ処理システムにおいてキャッシュのため
のデータ記憶サイズを減少させるキャッシュ・ディレク
トリ・アドレシング及びパリティ・チェック方式を提供
する。 【解決手段】アドレスのインデックス・フィールドが下
位のキャッシュ・ディレクトリ・アドレス・ラインに対
してマップする。残りのキャッシュ・ディレクトリ・ア
ドレス・ライン、すなわち、最高位のラインは、対応す
るキャッシュ・ディレクトリ・エントリに記憶されるべ
きキャッシュ・エントリ又はその対応するキャッシュ・
ディレクトリ・エントリから検索されるべきキャッシュ
・エントリに対するアドレス・タグのパリティによって
インデックスされる。従って、最上位のインデックス/
アドレス・ビット(msb)においてゼロを有するキャ
ッシュ・ディレクトリ・ロケーションに偶数パリティ・
アドレス・タグが記憶され、一方、最上位のインデック
ス/アドレス・ビットにおいて1を有するキャッシュ・
ディレクトリ・ロケーションに奇数パリティ・アドレス
・タグが記憶される。

Description

【発明の詳細な説明】
【0001】
【発明の属する技術分野】本発明は、概していえば、デ
ータ処理システムにおけるキャッシュに関するものであ
り、詳しくいえば、キャッシュのためのキャッシュ・デ
ィレクトリ・アドレシング及びパリティ・チェック方式
に関するものである。更に詳しくいえば、本発明は、デ
ータ処理システムにおいてキャッシュのためのデータ記
憶サイズを減少させるキャッシュ・ディレクトリ・アド
レシング及びパリティ・チェック方式に関するものであ
る。
【0002】
【従来の技術】現在のデータ処理システムは、一般に、
アクセス待ち時間を少なくすることに関連してシステム
・メモリからプロセッサへのデータをステージ化するた
めにキャッシュを使用している。そのようなキャッシュ
は、一般に、キャッシュ・ディレクトリにおいてパリテ
ィ・チェック機構を使用する。図3は、1MBを使用す
る32ビット・データ処理システムのためのキャッシュ
・ディレクトリ・アドレシング及びパリティ・チェック
方式を示す。1MBキャッシュ・ディレクトリ・アドレ
シング構成は64バイト・キャッシュ・ラインを使用す
る。キャッシュ・ラインは、コヒーレンシ(一貫性)状
態が規定するメモリのブロックであり、キャッシュ・ブ
ロックとも呼ばれる。キャッシュをアドレスする時、そ
のアドレスのビット26−31(6ビット)はキャッシ
ュ・ライン内アドレスを指定し、そのアドレスのビット
12−25(14ビット)はキャッシュ・ディレクトリ
及びキャッシュ・メモリにおけるキャッシュ・ラインに
対するインデックスとして利用され、そのアドレスのビ
ット0−11(12ビット)はキャッシュ・ライン・ア
ドレス・タグとして利用される。
【0003】キャッシュ・ライン内アドレス・フィール
ドは、特定のバイトがキャッシュ・ラインから選択され
ることを可能にする。インデックス・フィールドは、キ
ャッシュ・ディレクトリ及びキャッシュ・メモリにおけ
る行(又は、コングルーエンス・クラス)指定する。ア
ドレス・タグ・フィールドも特定のキャッシュ・ライン
を識別する。アドレス・タグは、そのアドレスと関連し
たデータを含むキャッシュ・ラインに対応したキャッシ
ュ・ディレクトリ・エントリに記憶される。アドレスの
アドレス・タグ・フィールドとキャッシュ・ディレクト
リ・エントリの内容との一致は、正しいキャッシュ・エ
ントリが選択されつつあることを確認するものである。
【0004】既知に方法では、キャッシュ・ディレクト
リ302におけるエントリ302aを選択するために、
アドレス・インデックス・フィールド(アドレス・ビッ
ト[12−25])がキャッシュ・ディレクトリ302
によって利用される。アドレス・インデックス・フィー
ルドは、キャッシュ・ディレクトリ302及びキャッシ
ュ・メモリ(図示されてない)のアドレス・ライン0−
13にマップする。選択されたキャッシュ・ディレクト
リ・エントリ302aは、12ビットのアドレス・タグ
302b及びパリティ・ビット302cを含んでいる。
キャッシュ・ディレクトリ・エントリ302aにおける
パリティ・ビット302cは、アドレス・タグ302b
のパリティを含んでいる。アドレス・タグ302bは、
与えられたアドレスのアドレス・タグ・フィールド(ア
ドレス・ビット[0−11])と比較するためにコンパ
レータ304に送られる。アドレス・タグ302b及び
パリティ・ビット302cは、アドレス・タグ302b
を検証するためにパリティ・チェック・ロジック306
に一緒に送られる。パリティ・チェック・ロジック30
6はアドレス・タグ302bのパリティを計算し、その
結果をパリティ・ビット302cと比較して、一致が検
出されるかどうかを表す信号308を発生する。
【0005】上記のタイプのキャッシュ・ディレクトリ
・アドレシング及びパリティ・チェック・システムを実
装するための方法に伴う1つの問題は、各キャッシュ・
エントリにおいてパリティ・ビットをアドレス・タグと
関連付けるために更なるキャッシュ・ディレクトリ空間
が必要であるということである。従って、キャッシュ・
ディレクトリにおけるパリティ・ビットの記憶を必要と
しないキャッシュ・ディレクトリ・アドレシング及びパ
リティ・チェック方式を提供することが望ましいであろ
う。それは、利用されるキャッシュ・ディレクトリ・ア
ドレシング及びパリティ・チェック方式が新規なパリテ
ィ生成及び(又は)チェック・ロジックを必要としない
場合には更に有利であろう。その機構がクリティカルな
キャッシュ・ディレクトリ・アクセス・パスにおける遅
れを改良することは更に有利なことであろう。
【0006】
【発明が解決しようとする課題】従って、本発明の目的
はデータ処理システムにおいて使用するための改良され
たキャッシュを提供することにある。
【0007】本発明のもう1つの目的は、キャッシュの
ための改良されたキャッシュ・ディレクトリ・アドレシ
ング及びパリティ・チェック方式を提供することにあ
る。
【0008】本発明の更にもう1つの目的は、データ処
理システムにおいてキャッシュのためのデータ記憶サイ
ズを減少させるキャッシュ・ディレクトリ・アドレシン
グ及びパリティ・チェック方式を提供することにある。
【0009】本発明の更にもう1つの目的は、クリティ
カルなキャッシュ・ディレクトリ・アクセス・パスにお
ける遅延を改良するキャッシュ・ディレクトリ・アドレ
シング及びパリティ・チェック方式を提供することにあ
る。
【00010】
【課題を解決するための手段】上記の目的は、次に述べ
るようにして達成される。アドレスのインデックス・フ
ィールドが下位のキャッシュ・ディレクトリ・アドレス
・ラインに対してマップする。残りのキャッシュ・ディ
レクトリ・アドレス・ライン、すなわち、最高位のライ
ンは、対応するキャッシュ・ディレクトリ・エントリに
記憶されるべきキャッシュ・エントリ又はその対応する
キャッシュ・ディレクトリ・エントリから検索されるべ
きキャッシュ・エントリに対するアドレス・タグのパリ
ティによってインデックスされる。従って、最上位のイ
ンデックス/アドレス・ビット(msb)においてゼロ
を有するキャッシュ・ディレクトリ・ロケーションに偶
数パリティ・アドレス・タグが記憶され、一方、最上位
のインデックス/アドレス・ビットにおいて1を有する
キャッシュ・ディレクトリ・ロケーションに奇数パリテ
ィ・アドレス・タグが記憶される。パリティが最上位ビ
ットではなく最下位ビットを供給するという構成である
時には、反対の配列(msbが1の時に偶数パリティ;
msbがゼロの時に奇数パリティ)も使用可能である。
これらのいずれの場合においても、キャッシュ・ディレ
クトリにおけるアドレス・タグのロケーションに基づい
て、偶数/奇数パリティが含まれる。
【0011】連想キャッシュでは、その機構は、偶数パ
リティ・アドレス・タグが一組のコングルーエンス・ク
ラス(行)又はキャッシュ・ディレクトリのコングルー
エンス・クラス・メンバ(列)に記憶され、奇数パリテ
ィが他の組に記憶されるように構成可能である。与えら
れたアドレスにおけるアドレス・タグ・フィールドのパ
リティは、キャッシュ・ヒットを表すアドレス・タグ及
びパリティの一致の場合、インデックスされたロケーシ
ョンに記憶されたアドレス・タグのパリティをテストす
るためにも利用される。説明された例では、開示された
暗黙パリティ機構は、各キャッシュ・ディレクトリ・エ
ントリに関連してパリティを記憶することを必要とする
構成に比べて、必要なキャッシュ・ディレクトリ・アレ
イ・スペースの約1/12(ほぼ、9%)を節約する。
更に、この機構は、クリティカルなキャッシュ・ディレ
クトリ・アクセス・パスにおける遅れを改良する。
【0012】本発明の上記及び更なる目的、特徴、及び
利点は、以下の詳細に記述された説明において明らかに
なるであろう。
【0013】
【発明の実施の形態】図面、特に、図1を参照すると、
本発明の望ましい実施例に従って、マルチプロセッサ・
データ処理システムが示される。データ処理システム1
00は、複数のプロセッサ102及び104を含む対称
マルチプロセッサ(SMP)システムである。それらの
プロセッサは、米国ニューヨーク州アーモンクにあるイ
ンターナショナル・ビジネス・マシーンズ・コーポレー
ション(IBM社)から入手可能なプロセッサのPow
erPC(IBM社の商標)ファミリの1つを含むこと
が望ましい。その例示的な実施例では2つのプロセッサ
しか示されていないけれども、本発明に従って、マルチ
プロセッサ・データ処理システムにおいて更なるプロセ
ッサが利用可能であることは当業者には明らかであろ
う。
【0014】各プロセッサ102及び104は、それぞ
れ、レベル1(L1)データ・キャッシュ106及び1
08、並びに、L1命令キャッシュ110及び112を
含んでいる。その例示的な実施例では命令キャッシュ及
びデータ・キャッシュが分離したものとして示されてい
るけれども、単一の一体化されたL1キャッシュが実装
可能であることは当業者には明らかであろう。データ・
アクセス待ち時間を最小にするために、レベル2(L
2)キャッシュ114及び116並びにレベル3(L
3)キャッシュ118及び119のような1つ又はそれ
以上の更なるレベルのキャッシュ・メモリをデータ処理
システム100において実装することも可能である。L
2及びL3のような低いキャッシュ・レベルはL1キャ
ッシュに対するデータをステージ化するために使用さ
れ、それらは、一般に、漸進的に大きい記憶容量を持つ
が、アクセス時間は長くなる。例えば、データ・キャッ
シュ106及び108並びに命令キャッシュ110及び
112は、それぞれ、32KBの記憶容量及び約1−2
プロセッサ・サイクルのアクセス待ち時間を持つもので
よい。L2キャッシュ114及び116は512KBの
記憶容量を有するが、5プロセッサ・サイクルのアクセ
ス待ち時間を持つことになろうし、一方、L3キャッシ
ュ118及び119は4MBの記憶容量を有するが、1
5プロセッサ・サイクルよりも大きいアクセス待ち時間
を持つことになろう。従って、L2キャッシュ114及
び116並びにL3キャッシュ118及び119はプロ
セッサ102及び104とシステム・メモリ120との
間の中間記憶装置として働く。システム・メモリ120
は、一般には、ずっと大きな記憶容量を揺するが、50
プロセッサ・サイクルよりも大きいアクセス待ち時間を
持つことになろう。
【0015】キャッシュ・ハイアラーキにおけるレベル
の数及びデータ処理システム100において使用される
キャッシュ・ハイアラーキ構成の両方とも変更可能であ
る。図示の例におけるL2キャッシュ114及び116
は、それぞれのプロセッサ102及び104とシステム
・メモリ120との間に(システム・バス122を介し
て)接続された専用のキャッシュである。L3キャッシ
ュ118及び119は、L2キャッシュ114及び11
6と論理的に垂直なルックアサイド・キャッシュとして
示される。その結果、データ又は命令はL2キャッシュ
114及び116の1つ並びにL3キャッシュ118及
び119の1つでルックアップされ得るが、それらのデ
ータ又は命令は、それぞれのL2キャッシュ114又は
116がミスヒットし、一方L3キャッシュ118又は
119がヒットする場合、L3キャッシュ118又は1
19から検索されるだけであろう。示されたレベル及び
構成に関する種々の変更を施し得ることは当業者には明
らかであろう。
【0016】L2キャッシュ114及び116並びにL
3キャッシュ118及び119は、システム・バス12
2を介してシステム・メモリ120に接続される。ディ
スプレイ(図示されてない)に対する接続を提供するグ
ラフィックス・アダプタのようなメモリ・マップド・デ
バイス124及び入出力(I/O)バス・ブリッジ12
6もシステム・バス122に接続可能である。I/Oバ
ス・ブリッジ126はシステム・バス122をI/Oバ
ス128接続する。I/Oバス128はI/Oデバイス
130及び不揮発性メモリ132に対する接続を提供し
得るものである。従って、システム・バス122、I/
Oブリッジ126、及びI/Oバス128は、付属のデ
バイスを結合する相互接続線を形成する。その相互接続
線に対する別の実施方法が従来技術において知られてい
【0017】I/Oデバイス130は、キーボード、マ
ウス又はトラック・ボールのようなグラフィカル・ポイ
ンティング・デバイス、ディスプレイ、及びプリンタを
含む一般的な周辺装置を含む。それらの周辺装置は通常
のアダプタを介してI/Oバス128にインターフェー
スされる。不揮発性メモリ132はハードディスク・ド
ライブを含み得るし、システム100のオペレーション
を制御するオペレーティング・システム及び他のソフト
ウエアを記憶する。それらのソフトウエアは、システム
100がパワー・オンされることに応答して揮発性のシ
ステム・メモリ120にロードされる。データ処理シス
テム100が、シリアル及びパラレル・ポート、ネット
ワーク又は付属のデバイスへの接続線、システム・メモ
リ120へのアクセスを調整するメモリ・コントローラ
等のような図1に示されてない多くの更なるコンポーネ
ントを含み得ることは当業者には明らかであろう。その
ような修正及び変更は本発明の精神及び技術的範囲にあ
る。
【0018】システム・バス122における代表的なコ
ミュニケーション・トランザクションは、そのトランザ
クションのソースを表すソース・タグ及びアドレス及び
(又は)データを含む。システム・バス122に接続さ
れた各デバイスはシステム・バス122におけるすべて
のコミュニケーション・トランザクションをスヌープ
し、必要な時には他の受信者に対して意図されたコミュ
ニケーション・トランザクションにおいて介入し、その
デバイスにおいて複写されているシステム・メモリのデ
ータに対する変更を、実行可能で且つ適正である時に複
製することが望ましい。
【0019】図2を参照すると、本発明の望ましい実施
例に従って、共通キャッシュ・ディレクトリ・アドレシ
ング及びパリティ・チェック方式のためのキャッシュ構
成に関する図が示される。図示のキャッシュ・ディレク
トリ構成は、L2キャッシュ114及び116並びにL
3キャッシュ118及び119を含む図1に示されたい
ずれのキャッシュに対しても利用可能である。説明され
るキャッシュ・ディレクトリ・アドレシング方式の例示
的な実施例は、L2キャッシュ114又は116或いは
L3キャッシュ118又は119として実装するに最も
適しているであろう。しかし、本発明のキャッシュ・デ
ィレクトリ・アドレシング及びパリティ・チェック方式
はデータ処理システムの記憶ハイアラーキのいずれのレ
ベルにおけるいずれのサイズのキャッシュに対しても実
装可能である。
【0020】図2は、64バイト・キャッシュ・ライン
を持った1MBキャッシュを使用する32ビット・デー
タ処理システムのためのキャッシュ・ディレクトリ・ア
ドレシング及びパリティ・チェック方式を示す。アドレ
スのビット26−31(6ビット)はキャッシュ・ライ
ン内アドレスを指定する。そのアドレスの小さいインデ
ックス・フィールド、すなわち、ビット13−25(1
2ビット)は、キャッシュディレクトリにおけるエント
リ及びキャッシュ・メモリ内のキャッシュ・ラインに対
するインデックスとして利用される。そのアドレスのビ
ット0−11(12ビット)はキャッシュ・ライン・ア
ドレス・タグとして利用される。
【0021】アドレス・インデックス・フィールド(ア
ドレス・ビット[13−25])は、キャッシュ・ディ
レクトリ202におけるエントリ202aを選択するた
めにキャッシュ・ディレクトリ202によって利用され
る。そのアドレス・インデックス・フィールドは、キャ
ッシュ・ディレクトリ202及びキャッシュ・メモリ
(図示されてない)のアドレス・ライン1−13にマッ
プする。従来技術の場合のように、選択されたキャッシ
ュ・ディレクトリ・エントリ202aは、与えられたア
ドレスのアドレス・タグ・フィールド(アドレス・ビッ
ト[0−11])と比較するためにコンパレータ204
に、及びパリティ・チェック・ロジック206に送られ
る12ビット・アドレス・タグを含む。そのパリティ・
チェック・ロジック206は、キャッシュ・ディレクト
リ・エントリ202aからのアドレス・タグのパリティ
が適正なパリティと一致するかどうかを表す信号208
を発生する。しかし、従来技術とは違って、パリティ・
ビットはキャッシュ・ディレクトリ・エントリ202b
と何の関連もない。そのかわり、パリティは、一致した
アドレス・タグを含むキャッシュ・ロケーションに対す
るキャッシュ・ディレクトリ・インデックスによって暗
黙指定(implied)される。
【0022】暗黙パリティ(implied pari
ty)を得るために、アドレス・タグ・フィールド(ア
ドレス・ビット[0−11])がパリティ・ジェネレー
タ210によって利用されアドレスタグのパリティを計
算する。その結果は、対応するタグを含むキャッシュ・
ディレクトリ・エントリ202aの残りのアドレス・ビ
ット(アドレス・ビットゼロ)として使用される。プラ
ス(偶数)/マイナス(奇数)パリティ方式がその結果
として生じる。すなわち、偶数パリティを持ったアドレ
ス・タグが正のアドレス(0X XXXX XXXX
XXXX)を有するキャッシュ・ディレクトリ・エント
リに記憶され、一方、奇数パリティ(1X XXXX
XXXX XXXX)を持ったアドレスが負のアドレス
を有するエントリに記憶される。従って、キャッシュ・
ディレクトリ及びキャッシュ・メモリが効果的に分離さ
れ、一方の半分が偶数パリティを持ったアドレス・タグ
を有し、もう一方の半分が奇数パリティを持ったアドレ
ス・タグを有する。
【0023】例示的な実施例では、最上位のキャッシュ
・ディレクトリ・アドレス・ビットが使用されるけれど
も、最下位のビットも利用可能である。その場合、キャ
ッシュ・ディレクトリにおける1つおきのラインが偶数
パリティを持ったアドレス・タグ(例えば、アドレスX
X XXXX XXXX XXX0を有するロケーショ
ン)を含み、残りの1つおきのラインが奇数パリティを
持ったアドレス・タグ(アドレスXX XXXX XX
XX XXX1を有するロケーションのような)を含む
であろう。
【0024】パリティ・ジェネレータ210によって計
算されたパリティはパリティ・チェック・ロジック20
6にも送られる。そのロジック206は、選択されたキ
ャッシュ・エントリ202aにおけるアドレス・タグの
パリティを計算して一致を検証する。パリティ・ジェネ
レータ210及びパリティ・チェック・ロジック206
は既知の技術に従って形成され得るものである。従っ
て、本発明のパリティ・チェック機構に対する特別なパ
リティ・ロジックは必要ない。パリティ・チェック・ロ
ジック206は、キャッシュ・ディレクトリ202の外
で利用されるものとして示されているけれども、別の方
法として、キャッシュ・ディレクトリ202において記
憶アレイと出力における選択ロジックとの間でも使用可
能である。
【0025】本発明は、非連想キャッシュに関連して説
明された。しかし、本発明のアドレシング及びパリティ
・チェック機構は同じ機構を持った連想キャッシュと共
に使用されてもよい。連想キャッシュの場合、本発明の
パリティ・ベースのアドレシング方式は、偶数パリティ
・アドレス・タグがコングルーエンス・クラスの1つの
セットに記憶され、一方、奇数パリティ・アドレス・タ
グがコングルーエンス・クラスの別のセットに記憶され
るよう、コングルーエンス・クラス(行)をディレクト
リ・インデックスの一部として選択するために利用可能
である。別の方法として、そのパリティ・ベースのアド
レシング方式は、偶数パリティ・アドレス・タグがコン
グルーエンス・クラス・メンバの1つにセットに記憶さ
れ、一方、奇数パリティ・アドレス・タグがコングルー
エンス・クラス・メンバのもう1つにセットに記憶され
るよう、コングルーエンス・クラス(列)のメンバをマ
ルチプレクサ入力として選択するために使用可能であ
る。
【0026】各アドレス・タグと関連したパリティ・ビ
ットを必要なくすることによって、本発明の暗黙パリテ
ィ機構はキャッシュ・ディレクトリのためのアレイ・ス
ペースにおける約1/12(約9%)の節約を達成す
る。従って、パリティ・ビットの記憶を必要とする設計
のキャッシュよりも大きいキャッシュが同じ領域におい
て使用可能であり、或いは、それと同等のサイズのキャ
ッシュがより小さい領域において実装可能である。更
に、キャッシュ・ディレクトリは、少なくとも部分的に
は、キャッシュに記憶されたアドレス・タグのパリティ
に基づいてインデックスされるので、特定のアドレス・
サイズに対して大きいキャッシュが実装可能である。
【0027】アドレス・ビット・ゼロが、その分野では
知られているような「レイト・セレクト」としてキャッ
シュ・ディレクトリ・アレイにおいて実装可能である。
これは、キャッシュ・ディレクトリ・アクセス(Add
[1−13])がパリティ生成ロジックに平行して生
じ、クリティカルなキャッシュ・ディレクトリ・アクセ
ス・パスに対する如何なる追加の遅延も除去することを
可能にする。更に、1エントリ当たりのビットの数の減
少(13から12への減少)及びキャッシュ・ディレク
トリ全体のサイズの減少によって、実際のキャッシュ・
ディレクトリ・アクセスが改良される。
【0028】本発明を望ましい実施例に関して詳細に示
し、説明したけれども、本発明の精神及び技術的範囲か
ら逸脱することなく、形式及び細部の種々の変更を行い
得ることは当業者には明らかであろう。
【0029】まとめとして、本発明の構成に関して以下
の事項を開示する。
【0030】(1)キャッシュ・ディレクトリをアドレ
スする方法にして、与えられたアドレスにおけるアドレ
ス・タグ・フィールドのパリティを計算するステップ
と、インデックスを計算するステップと、前記計算され
たインデックスを利用してキャッシュ・ディレクトリ・
エントリを選択するステップと、を含み、前記インデッ
クスは該インデックスの1つのビットにおいて前記計算
されたパリティを含み、前記インデックスの残りのビッ
トにおいて前記与えられたアドレスにおけるインデック
ス・フィールドを含む、方法。 (2)前記インデックスを計算するステップは前記計算
されたパリティを前記インデックスにおける最上位のビ
ットとして利用するステップを更に含む、上記(1)に
記載の方法。 (3)前記インデックスを計算するステップは前記計算
されたパリティを前記インデックスにおける最下位のビ
ットとして利用するステップを更に含む、上記(1)に
記載の方法。 (4)前記選択されたキャッシュ・ディレクトリ・エン
トリに記憶されたアドレス・タグのパリティを計算する
ステップと、前記選択されたキャッシュ・ディレクトリ
・エントリに記憶されたアドレス・タグのパリティを前
記与えられたアドレスにおけるアドレス・タグ・フィー
ルドのパリティに比較するステップと、を更に含む上記
(1)に記載の方法。 (5)前記選択されたキャッシュ・ディレクトリ・エン
トリに記憶されたアドレス・タグを前記与えられたアド
レスにおけるアドレス・タグ・フィールドに比較するス
テップ、を更に含む上記(4)に記載の方法。 (6)前記選択されたキャッシュ・ディレクトリ・エン
トリに記憶されたアドレス・タグが前記与えられたアド
レスにおけるアドレス・タグ・フィールドに一致したこ
と及び前記選択されたキャッシュ・ディレクトリ・エン
トリに記憶されたアドレス・タグのパリティが前記与え
られたアドレスにおけるアドレス・タグ・フィールドの
パリティに一致したことに応答してキャッシュ・ヒット
を表示するステップ、を更に含む上記(5)に記載の方
法。 (7)前記選択されたキャッシュ・ディレクトリ・エン
トリに記憶されたアドレス・タグが前記与えられたアド
レスにおけるアドレス・タグ・フィールドに一致しなか
ったことに応答してキャッシュ・ミスを表示するステッ
プ、を更に含む上記(5)に記載の方法。 (8)前記選択されたキャッシュ・ディレクトリ・エン
トリに記憶されたアドレス・タグのパリティが前記与え
られたアドレスにおけるアドレス・タグ・フィールドの
パリティに一致しなかったことに応答してキャッシュ・
ミスを表示するステップ、を更に含む上記(5)に記載
の方法。 (9)前記計算されたインデックスを利用してキャッシ
ュ・ディレクトリ・エントリを選択するステップは、前
記計算されたインデックスを利用して前記キャッシュ・
ディレクトリ・エントリを含むコングルーエンス・クラ
スを選択するステップを含む、上記(1)に記載の方
法。 (10)キャッシュ・ディレクトリ・アドレシング機構
にして、与えられたアドレスにおけるアドレス・タグ・
フィールドのパリティを計算するパリティ・ジェネレー
タと、インデックスを計算するキャッシュ・ディレクト
リと、を含み、前記インデックスは、前記インデックス
の1つのビットにおいて前記計算されたパリティを含
み、前記インデックスの残りのビットにおいて前記与え
られたアドレスにおけるインデックス・フィールドを含
み、前記キャッシュ・ディレクトリは前記計算されたイ
ンデックスを利用してキャッシュ・ディレクトリ・エン
トリを選択する、キャッシュ・ディレクトリ・アドレシ
ング機構。 (11)前記計算されたパリティは前記インデックスに
おける最上位のビットとして利用される、上記(10)
に記載の機構。 (12)前記計算されたパリティは前記インデックスに
おける最下位のビットとして利用される、上記(10)
に記載の機構。 (13)前記選択されたキャッシュ・ディレクトリ・エ
ントリに記憶されたアドレス・タグのパリティを計算
し、前記選択されたキャッシュ・ディレクトリ・エント
リに記憶されたアドレス・タグのパリティを前記与えら
れたアドレスにおけるアドレス・タグ・フィールドのパ
リティに比較するパリティ・チェック・ロジックを更に
含む上記(10)に記載の機構。 (14)前記選択されたキャッシュ・ディレクトリ・エ
ントリに記憶されたアドレス・タグを前記与えられたア
ドレスにおけるアドレス・タグ・フィールドに比較する
コンパレータを更に含む上記(13)に記載の機構。 (15)前記選択されたキャッシュ・ディレクトリ・エ
ントリに記憶されたアドレス・タグが前記与えられたア
ドレスにおけるアドレス・タグ・フィールドに一致した
こと及び前記選択されたキャッシュ・ディレクトリ・エ
ントリに記憶されたアドレス・タグのパリティが前記与
えられたアドレスにおけるアドレス・タグ・フィールド
のパリティに一致したことに応答してキャッシュ・ヒッ
トを信号するキャッシュ・コントローラを更に含む上記
(14)に記載の機構。 (16)前記選択されたキャッシュ・ディレクトリ・エ
ントリに記憶されたアドレス・タグが前記与えられたア
ドレスにおけるアドレス・タグ・フィールドに一致しな
かったことに応答してキャッシュ・ミスを信号するキャ
ッシュ・コントローラを更に含む上記(14)に記載の
機構。 (17)前記選択されたキャッシュ・ディレクトリ・エ
ントリに記憶されたアドレス・タグのパリティが前記与
えられたアドレスにおけるアドレス・タグ・フィールド
のパリティに一致しなかったことに応答してキャッシュ
・ミスを信号するキャッシュ・コントローラを更に含む
上記(14)に記載の機構。 (18)前記キャッシュ・ディレクトリは前記計算され
たインデックスを利用して前記キャッシュ・ディレクト
リ・エントリを含むコングルーエンス・クラスを選択す
る、上記(10)に記載の機構。 (19)キャッシュ・ディレクトリをアドレスする方法
にして、与えられたアドレスにおけるアドレス・タグ・
フィールドのパリティを計算するステップと、前記計算
されたパリティ及び前記与えられたアドレスにおけるイ
ンデックス・フィールドを利用してキャッシュ・ディレ
クトリ・エントリを前記キャッシュ・ディレクトリに対
するインデックスとして選択するステップと、を含む方
法。 (20)前記キャッシュ・ディレクトリ・エントリを前
記キャッシュ・ディレクトリに対するインデックスとし
て選択するステップは、前記計算されたパリティ及び前
記インデックス・フィールドの一部分を利用して前記キ
ャッシュ・ディレクトリ・エントリを含むコングルーエ
ンス・クラスを選択するステップを含む、上記(19)
に記載の方法。 (21)前記キャッシュ・ディレクトリ・エントリを前
記キャッシュ・ディレクトリに対するインデックスとし
て選択するステップは、前記インデックス・フィールド
の一部分を利用して前記キャッシュ・ディレクトリ・エ
ントリを含むコングルーエンス・クラスを選択するステ
ップと、前記計算されたパリティ及び前記インデックス
・フィールドの残りの部分を利用して前記選択されたコ
ングルーエンス・クラスにおけるコングルーエンス・ク
ラス・メンバを選択するステップと、を更に含む上記
(19)に記載の方法。 (22)前記選択されたキャッシュ・ディレクトリ・エ
ントリにおけるアドレス・タグを前記与えられたアドレ
スにおけるアドレス・タグ・フィールドに比較するステ
ップと、前記選択されたキャッシュ・ディレクトリ・エ
ントリにおけるアドレス・タグが前記与えられたアドレ
スにおけるアドレス・タグ・フィールドに一致したこと
に応答してキャッシュ・ヒットを信号するステップと、
前記選択されたキャッシュ・ディレクトリ・エントリに
おけるアドレス・タグが前記与えられたアドレスにおけ
るアドレス・タグ・フィールドに一致しなかったことに
応答してキャッシュ・ミスを信号するステップと、を更
に含む上記(19)に記載の方法。 (23)前記選択されたキャッシュ・ディレクトリ・エ
ントリにおけるアドレス・タグのパリティを計算するス
テップと、前記選択されたキャッシュ・ディレクトリ・
エントリにおけるアドレス・タグのパリティを前記与え
られたアドレスにおけるアドレス・タグ・フィールドの
パリティに比較するステップと、前記選択されたキャッ
シュ・ディレクトリ・エントリにおけるアドレス・タグ
のパリティが前記与えられたアドレスにおけるアドレス
・タグ・フィールドのパリティに一致したことに応答し
てキャッシュ・ヒットを信号するステップと、前記選択
されたキャッシュ・ディレクトリ・エントリにおけるア
ドレス・タグのパリティが前記与えられたアドレスにお
けるアドレス・タグ・フィールドのパリティに一致しな
かったことに応答してキャッシュ・ミスを信号するステ
ップと、を更に含む上記(19)に記載の方法。 (24)キャッシュ・ディレクトリの第1部分において
偶数パリティを有するすべてのアドレス・タグを記憶す
るステップと、キャッシュ・ディレクトリの前記第1部
分とは異なる第2部分において奇数パリティを有するす
べてのアドレス・タグを記憶するステップと、を更に含
む上記(19)に記載の方法。
【図面の簡単な説明】
【図1】本発明の望ましい実施例に従って、マルチプロ
セッサ・データ処理システムを示す。
【図2】本発明の望ましい実施例に従って、キャッシュ
・ディレクトリ・アドレシング及びパリティ・チェック
方式のためのキャッシュ構成を示す図である。
【図3】従来技術のキャッシュ・ディレクトリ・アドレ
シング及びパリティ・チェック方式を示す。
【符号の説明】
202 キャッシュ・ディレクトリ 204 コンパレータ 206 パリティ・チェック・ロジック 210 パリティ・ジェネレータ
───────────────────────────────────────────────────── フロントページの続き (72)発明者 ジョン・スティーブン・ドットソン アメリカ合衆国78660、テキサス州フルゲ ールヴィッレ、ベル・ロック・サークル 1205 (72)発明者 ジェリー・ダン・ルイス アメリカ合衆国78681、テキサス州ラウン ド・ロック、アロウヘッド・サークル 3409

Claims (24)

    【特許請求の範囲】
  1. 【請求項1】キャッシュ・ディレクトリをアドレスする
    方法にして、 与えられたアドレスにおけるアドレス・タグ・フィール
    ドのパリティを計算するステップと、 インデックスを計算するステップと、 前記計算されたインデックスを利用してキャッシュ・デ
    ィレクトリ・エントリを選択するステップと、 を含み、 前記インデックスは該インデックスの1つのビットにお
    いて前記計算されたパリティを含み、前記インデックス
    の残りのビットにおいて前記与えられたアドレスにおけ
    るインデックス・フィールドを含む、方法。
  2. 【請求項2】前記インデックスを計算するステップは前
    記計算されたパリティを前記インデックスにおける最上
    位のビットとして利用するステップを更に含む、請求項
    1に記載の方法。
  3. 【請求項3】前記インデックスを計算するステップは前
    記計算されたパリティを前記インデックスにおける最下
    位のビットとして利用するステップを更に含む、請求項
    1に記載の方法。
  4. 【請求項4】前記選択されたキャッシュ・ディレクトリ
    ・エントリに記憶されたアドレス・タグのパリティを計
    算するステップと、 前記選択されたキャッシュ・ディレクトリ・エントリに
    記憶されたアドレス・タグのパリティを前記与えられた
    アドレスにおけるアドレス・タグ・フィールドのパリテ
    ィに比較するステップと、 を更に含む請求項1に記載の方法。
  5. 【請求項5】前記選択されたキャッシュ・ディレクトリ
    ・エントリに記憶されたアドレス・タグを前記与えられ
    たアドレスにおけるアドレス・タグ・フィールドに比較
    するステップ、 を更に含む請求項4に記載の方法。
  6. 【請求項6】前記選択されたキャッシュ・ディレクトリ
    ・エントリに記憶されたアドレス・タグが前記与えられ
    たアドレスにおけるアドレス・タグ・フィールドに一致
    したこと及び前記選択されたキャッシュ・ディレクトリ
    ・エントリに記憶されたアドレス・タグのパリティが前
    記与えられたアドレスにおけるアドレス・タグ・フィー
    ルドのパリティに一致したことに応答してキャッシュ・
    ヒットを表示するステップ、 を更に含む請求項5に記載の方法。
  7. 【請求項7】前記選択されたキャッシュ・ディレクトリ
    ・エントリに記憶されたアドレス・タグが前記与えられ
    たアドレスにおけるアドレス・タグ・フィールドに一致
    しなかったことに応答してキャッシュ・ミスを表示する
    ステップ、 を更に含む請求項5に記載の方法。
  8. 【請求項8】前記選択されたキャッシュ・ディレクトリ
    ・エントリに記憶されたアドレス・タグのパリティが前
    記与えられたアドレスにおけるアドレス・タグ・フィー
    ルドのパリティに一致しなかったことに応答してキャッ
    シュ・ミスを表示するステップ、 を更に含む請求項5に記載の方法。
  9. 【請求項9】前記計算されたインデックスを利用してキ
    ャッシュ・ディレクトリ・エントリを選択するステップ
    は、前記計算されたインデックスを利用して前記キャッ
    シュ・ディレクトリ・エントリを含むコングルーエンス
    ・クラスを選択するステップを含む、請求項1に記載の
    方法。
  10. 【請求項10】キャッシュ・ディレクトリ・アドレシン
    グ機構にして、 与えられたアドレスにおけるアドレス・タグ・フィール
    ドのパリティを計算するパリティ・ジェネレータと、 インデックスを計算するキャッシュ・ディレクトリと、 を含み、 前記インデックスは、前記インデックスの1つのビット
    において前記計算されたパリティを含み、前記インデッ
    クスの残りのビットにおいて前記与えられたアドレスに
    おけるインデックス・フィールドを含み、 前記キャッシュ・ディレクトリは前記計算されたインデ
    ックスを利用してキャッシュ・ディレクトリ・エントリ
    を選択する、 キャッシュ・ディレクトリ・アドレシング機構。
  11. 【請求項11】前記計算されたパリティは前記インデッ
    クスにおける最上位のビットとして利用される、請求項
    10に記載の機構。
  12. 【請求項12】前記計算されたパリティは前記インデッ
    クスにおける最下位のビットとして利用される、請求項
    10に記載の機構。
  13. 【請求項13】前記選択されたキャッシュ・ディレクト
    リ・エントリに記憶されたアドレス・タグのパリティを
    計算し、前記選択されたキャッシュ・ディレクトリ・エ
    ントリに記憶されたアドレス・タグのパリティを前記与
    えられたアドレスにおけるアドレス・タグ・フィールド
    のパリティに比較するパリティ・チェック・ロジックを
    更に含む請求項10に記載の機構。
  14. 【請求項14】前記選択されたキャッシュ・ディレクト
    リ・エントリに記憶されたアドレス・タグを前記与えら
    れたアドレスにおけるアドレス・タグ・フィールドに比
    較するコンパレータを更に含む請求項13に記載の機
    構。
  15. 【請求項15】前記選択されたキャッシュ・ディレクト
    リ・エントリに記憶されたアドレス・タグが前記与えら
    れたアドレスにおけるアドレス・タグ・フィールドに一
    致したこと及び前記選択されたキャッシュ・ディレクト
    リ・エントリに記憶されたアドレス・タグのパリティが
    前記与えられたアドレスにおけるアドレス・タグ・フィ
    ールドのパリティに一致したことに応答してキャッシュ
    ・ヒットを信号するキャッシュ・コントローラを更に含
    む請求項14に記載の機構。
  16. 【請求項16】前記選択されたキャッシュ・ディレクト
    リ・エントリに記憶されたアドレス・タグが前記与えら
    れたアドレスにおけるアドレス・タグ・フィールドに一
    致しなかったことに応答してキャッシュ・ミスを信号す
    るキャッシュ・コントローラを更に含む請求項14に記
    載の機構。
  17. 【請求項17】前記選択されたキャッシュ・ディレクト
    リ・エントリに記憶されたアドレス・タグのパリティが
    前記与えられたアドレスにおけるアドレス・タグ・フィ
    ールドのパリティに一致しなかったことに応答してキャ
    ッシュ・ミスを信号するキャッシュ・コントローラを更
    に含む請求項14に記載の機構。
  18. 【請求項18】前記キャッシュ・ディレクトリは前記計
    算されたインデックスを利用して前記キャッシュ・ディ
    レクトリ・エントリを含むコングルーエンス・クラスを
    選択する、請求項10に記載の機構。
  19. 【請求項19】キャッシュ・ディレクトリをアドレスす
    る方法にして、 与えられたアドレスにおけるアドレス・タグ・フィール
    ドのパリティを計算するステップと、 前記計算されたパリティ及び前記与えられたアドレスに
    おけるインデックス・フィールドを利用してキャッシュ
    ・ディレクトリ・エントリを前記キャッシュ・ディレク
    トリに対するインデックスとして選択するステップと、 を含む方法。
  20. 【請求項20】前記キャッシュ・ディレクトリ・エント
    リを前記キャッシュ・ディレクトリに対するインデック
    スとして選択するステップは、前記計算されたパリティ
    及び前記インデックス・フィールドの一部分を利用して
    前記キャッシュ・ディレクトリ・エントリを含むコング
    ルーエンス・クラスを選択するステップを含む、請求項
    19に記載の方法。
  21. 【請求項21】前記キャッシュ・ディレクトリ・エント
    リを前記キャッシュ・ディレクトリに対するインデック
    スとして選択するステップは、 前記インデックス・フィールドの一部分を利用して前記
    キャッシュ・ディレクトリ・エントリを含むコングルー
    エンス・クラスを選択するステップと、 前記計算されたパリティ及び前記インデックス・フィー
    ルドの残りの部分を利用して前記選択されたコングルー
    エンス・クラスにおけるコングルーエンス・クラス・メ
    ンバを選択するステップと、 を更に含む請求項19に記載の方法。
  22. 【請求項22】前記選択されたキャッシュ・ディレクト
    リ・エントリにおけるアドレス・タグを前記与えられた
    アドレスにおけるアドレス・タグ・フィールドに比較す
    るステップと、 前記選択されたキャッシュ・ディレクトリ・エントリに
    おけるアドレス・タグが前記与えられたアドレスにおけ
    るアドレス・タグ・フィールドに一致したことに応答し
    てキャッシュ・ヒットを信号するステップと、 前記選択されたキャッシュ・ディレクトリ・エントリに
    おけるアドレス・タグが前記与えられたアドレスにおけ
    るアドレス・タグ・フィールドに一致しなかったことに
    応答してキャッシュ・ミスを信号するステップと、 を更に含む請求項19に記載の方法。
  23. 【請求項23】前記選択されたキャッシュ・ディレクト
    リ・エントリにおけるアドレス・タグのパリティを計算
    するステップと、 前記選択されたキャッシュ・ディレクトリ・エントリに
    おけるアドレス・タグのパリティを前記与えられたアド
    レスにおけるアドレス・タグ・フィールドのパリティに
    比較するステップと、 前記選択されたキャッシュ・ディレクトリ・エントリに
    おけるアドレス・タグのパリティが前記与えられたアド
    レスにおけるアドレス・タグ・フィールドのパリティに
    一致したことに応答してキャッシュ・ヒットを信号する
    ステップと、 前記選択されたキャッシュ・ディレクトリ・エントリに
    おけるアドレス・タグのパリティが前記与えられたアド
    レスにおけるアドレス・タグ・フィールドのパリティに
    一致しなかったことに応答してキャッシュ・ミスを信号
    するステップと、を更に含む請求項19に記載の方法。
  24. 【請求項24】キャッシュ・ディレクトリの第1部分に
    おいて偶数パリティを有するすべてのアドレス・タグを
    記憶するステップと、 キャッシュ・ディレクトリの前記第1部分とは異なる第
    2部分において奇数パリティを有するすべてのアドレス
    ・タグを記憶するステップと、 を更に含む請求項19に記載の方法。
JP11060382A 1998-03-23 1999-03-08 偶数/奇数キャッシュ・ディレクトリ方法及び装置 Pending JPH11328017A (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/046,009 US6212616B1 (en) 1998-03-23 1998-03-23 Even/odd cache directory mechanism
US09/046009 1998-03-23

Publications (1)

Publication Number Publication Date
JPH11328017A true JPH11328017A (ja) 1999-11-30

Family

ID=21941069

Family Applications (1)

Application Number Title Priority Date Filing Date
JP11060382A Pending JPH11328017A (ja) 1998-03-23 1999-03-08 偶数/奇数キャッシュ・ディレクトリ方法及び装置

Country Status (3)

Country Link
US (1) US6212616B1 (ja)
JP (1) JPH11328017A (ja)
KR (1) KR100320977B1 (ja)

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7065558B2 (en) * 2002-02-22 2006-06-20 Microsoft Corporation Opportunistic directory cache and method of serving target directory information in a network environment
US6920604B2 (en) * 2002-04-08 2005-07-19 Galazar Networks, Inc. Systems and methods for high speed serial encoding and decoding for data and control interfaces
US7167955B1 (en) 2003-12-23 2007-01-23 Unisys Corporation System and method for testing and initializing directory store memory
US8135910B2 (en) * 2005-02-11 2012-03-13 International Business Machines Corporation Bandwidth of a cache directory by slicing the cache directory into two smaller cache directories and replicating snooping logic for each sliced cache directory
JP2008090442A (ja) * 2006-09-29 2008-04-17 Fujitsu Ltd メモリ制御装置
FR2951310B1 (fr) * 2009-10-13 2011-11-18 St Microelectronics Rousset Dispositif de memoire a protocole serie et procede d'adressage correspondant
US20150100733A1 (en) * 2013-10-03 2015-04-09 Synopsys, Inc. Efficient Memory Organization
US9842060B1 (en) * 2016-07-13 2017-12-12 Seagate Technology Llc Cache over-provisioning in a data storage device
GB2560336B (en) * 2017-03-07 2020-05-06 Imagination Tech Ltd Address generators for verifying integrated circuit hardware designs for cache memory
KR102579319B1 (ko) 2023-04-19 2023-09-18 메티스엑스 주식회사 캐시 메모리 장치 및 이를 이용하는 캐시 스케줄링 구현 방법

Family Cites Families (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4055851A (en) * 1976-02-13 1977-10-25 Digital Equipment Corporation Memory module with means for generating a control signal that inhibits a subsequent overlapped memory cycle during a reading operation portion of a reading memory cycle
US4441155A (en) * 1981-11-23 1984-04-03 International Business Machines Corporation Page controlled cache directory addressing
US4785395A (en) * 1986-06-27 1988-11-15 Honeywell Bull Inc. Multiprocessor coherent cache system including two level shared cache with separately allocated processor storage locations and inter-level duplicate entry replacement
US4768148A (en) * 1986-06-27 1988-08-30 Honeywell Bull Inc. Read in process memory apparatus
JPH04205449A (ja) 1990-11-30 1992-07-27 Matsushita Electric Ind Co Ltd キャッシュ装置
US5479641A (en) * 1993-03-24 1995-12-26 Intel Corporation Method and apparatus for overlapped timing of cache operations including reading and writing with parity checking
US5761714A (en) * 1996-04-26 1998-06-02 International Business Machines Corporation Single-cycle multi-accessible interleaved cache

Also Published As

Publication number Publication date
KR19990077470A (ko) 1999-10-25
KR100320977B1 (ko) 2002-01-18
US6212616B1 (en) 2001-04-03

Similar Documents

Publication Publication Date Title
JP6505132B2 (ja) メモリ容量圧縮を利用するメモリコントローラならびに関連するプロセッサベースのシステムおよび方法
US5586294A (en) Method for increased performance from a memory stream buffer by eliminating read-modify-write streams from history buffer
US5510934A (en) Memory system including local and global caches for storing floating point and integer data
US6138209A (en) Data processing system and multi-way set associative cache utilizing class predict data structure and method thereof
JP3821644B2 (ja) 旧キャッシュラインを無効化および除去する装置
US5388247A (en) History buffer control to reduce unnecessary allocations in a memory stream buffer
US4724518A (en) Odd/even storage in cache memory
JP3620473B2 (ja) 共有キャッシュメモリのリプレイスメント制御方法及びその装置
KR100327935B1 (ko) 연관성을 이용한 가변 캐시 크기에 대한 고성능 캐시 디렉토리 어드레싱 스킴
JP3666689B2 (ja) 仮想アドレス変換方法
EP0706133A2 (en) Method and system for concurrent access in a data cache array utilizing multiple match line selection paths
US5668972A (en) Method and system for efficient miss sequence cache line allocation utilizing an allocation control cell state to enable a selected match line
JPH02189659A (ja) 仮想記憶動的アドレス変換システム
JP2003067357A (ja) 不均一メモリ・アクセス(numa)データ処理システムおよびその操作方法
US9720847B2 (en) Least recently used (LRU) cache replacement implementation using a FIFO storing indications of whether a way of the cache was most recently accessed
JPH06110781A (ja) キャッシュメモリ装置
US6157980A (en) Cache directory addressing scheme for variable cache sizes
US5724547A (en) LRU pointer updating in a controller for two-way set associative cache
US8621152B1 (en) Transparent level 2 cache that uses independent tag and valid random access memory arrays for cache access
JPH11328017A (ja) 偶数/奇数キャッシュ・ディレクトリ方法及び装置
JP3468268B2 (ja) インターリーブ式キャッシュ
US5890221A (en) Method and system for offset miss sequence handling in a data cache array having multiple content addressable field per cache line utilizing an MRU bit
JP2004199677A (ja) キャッシュを動作させるためのシステム及び方法
US6240487B1 (en) Integrated cache buffers
US6643742B1 (en) Method and system for efficient cache memory updating with a least recently used (LRU) protocol