JP3640978B2 - ページテーブル中のハッシュアドレスタグを用いたメモリアドレス制御装置 - Google Patents
ページテーブル中のハッシュアドレスタグを用いたメモリアドレス制御装置 Download PDFInfo
- Publication number
- JP3640978B2 JP3640978B2 JP06849194A JP6849194A JP3640978B2 JP 3640978 B2 JP3640978 B2 JP 3640978B2 JP 06849194 A JP06849194 A JP 06849194A JP 6849194 A JP6849194 A JP 6849194A JP 3640978 B2 JP3640978 B2 JP 3640978B2
- Authority
- JP
- Japan
- Prior art keywords
- tag
- field
- index
- information
- simplified
- 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 - Fee Related
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/10—Address translation
- G06F12/1009—Address translation using page tables, e.g. page table structures
- G06F12/1018—Address translation using page tables, e.g. page table structures involving hashing techniques, e.g. inverted page tables
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)
Description
【産業上の利用分野】
本発明は、仮想メモリを組み込んだコンピュータ装置の設計に関し、特に、仮想アドレスから物理アドレスへの変換操作に変換ルックアサイドバッファ(TLB)を用いるコンピュータに関する。
【0002】
【従来の技術】
従来のコンピュータ装置は、仮想メモリと呼ばれる技術を用いている。この仮想メモリは、実在するメモリよりも多くのメモリをシミュレートして、そのサイズに関わらずコンピュータが幾つかのプログラムを同時に実行できるようにするものである。並行ユーザプログラムは、オペレーティングシステムにより割り当てられた仮想アドレスを介してメインメモリアドレスにアクセスする。メインメモリ即ち物理アドレスに対する仮想アドレスのマッピングは、仮想アドレス変換として周知のプロセスである。この仮想メモリ変換は、プロセッサがメインメモリ中の所望情報にアクセスできるように多数の技法で実施可能なものである。
【0003】
仮想アドレス空間および物理アドレス空間は、一般に、ページと呼ばれる等サイズのメモリブロックに分割され、ページテーブルにより、仮想アドレスと物理アドレスとの間の変換が行われる。ページテーブルは、多数の構造で編成することが可能である。「順マップ」テーブルは、変換を含むテーブル項目に対するポインタとして仮想ページ番号を用いて最も容易にアクセスされるものである。また「逆マップ」テーブルは、変換を含むテーブル項目に対するポインタとして物理ページ番号を用いて最も容易にアクセスされるものである。考え得る仮想ページ番号は、物理ページ番号よりも多く存在するので、順マップテーブルは、極めて大きくて疎となり得るが、仮想ページ番号が与えられれば、探索はかなり容易となる。逆マップテーブルは、物理メモリの各ページ毎に1つの項目を含んでいる。仮想ページに比べて物理ページの数が限られているので、逆マップテーブルは、一層効率の良い記憶構造となる傾向にあるが、仮想ページ番号だけしか与えられない場合にはアクセスが困難なものとなる。
【0004】
各ページテーブル項目には、一般に、仮想アドレスおよび/または物理アドレスと、ページに関する保護およびステータス情報が含まれる。ステータスには、一般に、ページが受けたアクセスのタイプに関するステータスが含まれる。例えば、汚損(dirty)ビットはページ中のデータが修正されたことを示している。ページテーブルは、通常は大きいものであるので、メインメモリに格納される。従って、通常の各メモリアクセスには、実際には2つのアクセス、即ち変換を得るためのアクセスと物理記憶位置にアクセスするためのアクセスとが必要となる。
【0005】
仮想アドレス変換をサポートする多くのコンピュータ装置は、変換ルックアサイドバッファ(TLB)を利用している。このTLBは、通常はプロセッサにまたはプロセッサに近接して設けられ、最近使用された仮想アドレスおよび物理アドレスの対を格納する小さくて高速の連想メモリである。TLBは、ページテーブル中に変換のサブセットを含み、はるかに迅速にアクセスが可能なものである。処理装置は、メインメモリからの情報を必要とする際にTLBに仮想アドレスを送る。TLBは、その仮想アドレスのページ番号を受け取って物理ページ番号を返す。その物理ページ番号が低位のアドレス情報と組み合わせられて、メインメモリ中の所望のバイトまたはワードへのアクセスが行われる。
【0006】
ほとんどの場合、TLBはページテーブル全体を格納することができないので、TLBを更新する手順を実施する必要がある。仮想ページにアクセスする際に、そのための変換がTLB中に存在しない場合には、ページテーブルにアクセスして、その仮想ページ番号から物理ページ番号への変換が決定され、その情報がTLBに入力される。ページテーブルへのアクセスは、TLBへのアクセスの20倍も時間を要するものであり、従って、プログラム実行速度は、変換がTLBにおいて利用されるよう維持することにより最適化される。
【0007】
今日、ほとんどのコンピュータ装置は、何らかの種類の大量記憶装置(一般にはディスク)を利用して、コンピュータ中の物理ランダムアクセスメモリ(RAM)を増補している。このメインメモリの増補により、メインメモリだけしか利用できない場合に比べて一層大きなプログラムを実行することが可能になる。更に、ディスクメモリは、RAMよりもかなり安価ではあるが、その数百倍も低速なものである。プログラムの長さに応じて、また他のプログラムとのメインメモリの競合に応じて、任意の時点で、プログラムの一部は、メインメモリ中に存在し、またディスクメモリ中に存在することが可能である。直ちにアクセスされる必要のあるプログラム部分がメインメモリに送り込まれる一方、現在利用しない部分はディスクメモリに残される。
【0008】
例えば、1つのプログラムが、2Mbyteの長さを有し、1Mbyteのメインメモリを備えたコンピュータで使用される場合、そのプログラムにより用いられる仮想アドレスは2Mbyteとなる。メインメモリは、1Mbyteの情報しか保持することができないので、残りの1Mbyteのプログラム情報は、ディスクメモリ装置中に格納されることになる。従って、利用可能な物理メモリをプログラムの半分が満たしている場合、仮想アドレスの半分はメインメモリ中のプログラム情報にマッピング可能なものとなり、残りの半分は前記プログラム情報にマッピング不可能なものとなる。メインメモリ中の情報に対するアクセスは通常通り行われる。即ち、まずTLBを参照して変換を備えているか否かを確認し、その変換を備えていない場合には、ページテーブル中の情報によりTLBを更新し、次いで再度TLBを参照して変換情報を得ることになる。
【0009】
メインメモリ中に存在しない情報へのアクセスが生じた場合、まずTLBを参照して(そこには存在しない)変換を探す。次いでページテーブルを参照して変換情報を入手し、TLBの更新を行う。しかし、ページテーブルは、メインメモリ中の情報に関する変換だけしか備えておらず、従って、必要な変換情報を備えていないことになる。この状態はページフォルトと呼ばれる。ページフォルトに応じて、参照された仮想ページに物理ページが割り当てられ、この情報がページディレクトリに挿入される。全ての物理ページが既に他の仮想ページに関連づけられている場合には、ページフォルトハンドラが、現在参照中の仮想アドレスページにどの物理ページを再割当てするかを選択する必要がある。こうした選択のために、先入れ先出しおよび最低使用頻度アルゴリズム等の多くのアルゴルズムが存在する。ページフォルトハンドラは、一般にソフトウェアで実施されるが、TLB更新プロセスは、当業界で周知のようにハードウェアまたはソフトウェアにより処理可能である。
【0010】
図1は上述のプロセスを示すものである。ステップ112において、仮想アドレスがTLBに提示される。その仮想アドレスについての変換がTLB中に存在する(TLBヒット)場合には、その変換で関連付けされた物理アドレスがTLBから取り出されて、物理メモリへのアクセスに利用される(ステップ114)。また、該当する仮想アドレスがTLB中に存在しない(TLBミス)場合には、その仮想アドレスについての変換をページディレクトリ/テーブル中でルックアップする(ステップ116)。その変換がページディレクトリ中に存在する場合には、その情報がTLBに挿入され(ステップ118)、仮想アドレスが再び提示される(ステップ112)。今度はTLBヒットが生じるので、その結果として得られる物理アドレスを用いて、物理メモリに対するアクセスが行われる。
【0011】
物理アドレスページが全く関連付けされていない仮想アドレスページ中に仮想アドレスが存在する場合には、そのページに関する項目はページディレクトリには存在せず、ページフォルトが発生することになる。この状況において、ソフトウェアページフォルトハンドラ(ステップ120)は、仮想ページに物理ページを割り当ててページテーブルを更新する。次いで、前記仮想アドレスがTLBに再度提示されるが、TLBはまだ変換を備えていないのでTLBミスとなり、TLBはページディレクトリにより更新されることになる。次いで前記仮想アドレスがTLBに再度提示されると、今度はTLBヒットが確認されるので、その結果として得られる物理アドレスを用いて物理メモリへのアクセスが行われる。
【0012】
図2は、仮想アドレスの提示に応じて変換ルックアサイドバッファ(TLB)中の項目にアクセスする単純化された方法を示すものである。例示を目的とするため、図示のTLBは1つの項目しか有していないが、TLBは更に多くの項目を有するのが普通である。仮想アドレスはレジスタ201にロードされる。この仮想アドレスは、2つの部分、即ち仮想ページ番号203および物理オフセット205から構成される。物理オフセット205は、通常は、1ページ中の特定バイトを指定するアドレスの下位12ビット(ビット11〜0)である。レジスタ中の残りのビットは、仮想ページ番号を示している。
【0013】
「ページオフセット」という用語は、当業界でよく用いられる用語であり、本発明の説明で用いる「物理オフセット」という用語と同義語である。物理ページ番号に変換を一意的に指定するのに別のビットを用いることが多い。こうしたビットには、例えば「アドレス空間識別子」ビットが含まれる。しかし、本発明の目的上、こうしたビットを全て、仮想ページ番号の一部とみなすこととする。
【0014】
図示の例の場合、仮想ページ番号203は、TLB比較器207に第1入力を供給する仮想タグとなる。TLB209は、2つのリンク部分、即ちTLBタグ211およびそれに関連付けされた物理ページ番号213を備えている。TLBタグ211はTLB比較器207に第2入力を供給し、TLB比較器207はTLBタグを仮想タグと比較する。それらのタグが一致する場合、比較器207はTLBヒットを示し、物理ページ番号213が物理オフセット205と組み合わされて、物理(実)メモリアドレスが提供される。また、それらのタグが一致しない場合には、TLBミスが生じたことになり、図1に関連して説明したTLBミスプロセスを用いてTLBの更新が行われる。
【0015】
図3は、仮想ページ番号が与えられた場合に物理ページ情報を取り出すプロセスを示すものであり、これは、TLBミスが生じた後にTLBを更新するために必要なものである。上述のように、仮想/物理マッピングは、ページテーブル中に維持される。所与の仮想アドレスを物理アドレスに変換する1つの方法として、仮想アドレスについて多対1機能(ハッシュ)を実施してページテーブルへの索引を形成する、という方法がある。これにより、リンクされた項目リストへのポインタが得られる。これら項目は一致するものを求めて探索される。一致を判定するために、仮想ページ番号がページテーブル中の項目(仮想タグ)と比較される。その両者が等しい場合には、そのページテーブル項目により物理アドレスへの変換が提供される。
【0016】
図示の例の場合、仮想ページ番号203についてハッシュ機能301が実行されて、索引が形成される。この索引はページテーブル303へのオフセットである。図示のように、索引は0であり、即ち、その索引はページテーブル中の最初の項目305を指している。ページテーブル中の各項目は複数部分から構成されるが、少なくとも仮想タグ307、物理ページ309、およびポインタ311を含んでいるのが普通である。仮想ページ番号203が仮想タグ307に等しい場合、物理ページ309により所望の物理(実)メモリページのアドレスが提供される。また、仮想ページ番号203が仮想タグ307と一致しない場合には、ポインタ311は、仮想/物理変換情報を格納しているメモリ中の項目チェーンを指す。2つ以上の仮想ページ番号を同じページテーブル項目にハッシュすることが可能なので、前記項目チェーンに含まれる追加情報が必要となる。
【0017】
図示のように、ポインタ311はチェーンセグメント313を指す。このチェーンセグメントにはページテーブルと同じタイプの情報が含まれる。前述のように、仮想ページ番号203が次の仮想タグ315と比較され、それらが一致するか否かが確認される。それらが一致する場合には、その仮想タグ315と関連付けされた物理ページ317により、所望の物理メモリページのアドレスが得られる。また、それらが一致しない場合には、次いでポインタ319を検査して、次のチェーンセグメントを(もし存在すれば)探し出す。図示のように、ポインタ319が別のチェーンセグメントを示さない場合には、ページフォルトが生じたことになる。次いで、図1に関連して説明したように、ページフォルトソフトウェアプログラムを利用してページテーブルの更新が行われる。
【0018】
上述の方法は、仮想タグがコンピュータの基本データパスサイズより小さい装置の場合、または、中央演算処理装置(CPU)が1つしか存在しない装置の場合にうまく機能する。しかし、仮想タグがデータパスサイズより大きい場合には、仮想タグおよび仮想ページ番号が同じであるか否かを検査するために2つの比較を行う必要がある。この追加する比較ステップによりコンピュータ装置の処理速度が低下する。更に、複数のCPUを利用した装置の場合には、或るCPUにより検査中である同じページテーブル項目を別のCPUが更新することが決してないように多大の注意を払わねばならない。さもなければ、第1のCPUがページテーブル項目を修正すると同時に、それと同じページテーブル項目について第2のCPUが第2の比較ステップを実施することが可能となってしまう。これは、許容できない結果であり、従って、競合が決して生じないようにするために別のハードウェアを追加する必要が生じることになる。
【0019】
【発明が解決しようとする課題】
ページテーブル中の項目の検査時に、多数の比較ステップを必要とすることなく、コンピュータ装置の基本データパスより大きな仮想タグに対処し得る方法および装置が、当業界で所望されている。
【0020】
【課題を解決するための手段】
本発明は、多数の比較操作を必要とすることなくコンピュータ装置の基本データパスより大きな仮想タグを利用する方法および装置を提供する。ページテーブル項目中にタグ全体を格納する代わりに、簡素化したタグ(以下、簡素化タグと称す)を格納することにより、多数の比較が回避される。この簡素化タグは、基本データパスサイズ以下の大きさを有し、従って、単一の比較操作しか必要としない。簡素化タグは、ビットの幾つかを除去して一層小さなタグを形成することにより、装置の仮想アドレスから形成される。ページテーブル項目の一意性を維持するために、仮想アドレスから除去されたビットを用いてページテーブルへの索引を形成する。
【0021】
第2の好適実施例では、簡素化タグの形成に用いられないビットが仮想アドレスからの他のビットと組み合わされてハッシュ索引が形成される。このハッシュ索引により、ページテーブル中の項目の均一な配分が提供される。
【0022】
第3の好適実施例では、仮想ページ番号ビットおよび索引ビットからハッシュタグが形成される。このハッシュタグは、コンピュータの基本データ幅以下の大きさを有し、簡素化タグの代わりにページテーブル中に格納される。ページテーブルへの索引は、ページテーブル項目の一意性を維持するように設計される。
【0023】
【実施例】
本発明の基本的な特徴は、仮想ページ番号203を2つの部分に分割することにある。即ち、その第1部分が簡素化タグとなり、第2部分が索引として用いられる。簡素化タグは、タグに用いられるビットを、基本コンピュータデータパス幅以下に制限することにより形成される。例えば、コンピュータ装置が32ビットのデータ幅を有する場合には、簡素化タグは32ビット以下のビットを含むことになる。次いで簡素化タグの形成に使用されないビットが使用されて残余索引が形成される。
【0024】
図4は、TLBミスの後に物理ページ情報を取り出すための本発明の好適実施例を示すものである。図示のように、仮想ページ番号203は、2つの部分、即ち、簡素化タグ401および残余索引403に分割される。簡素化タグ401は、コンピュータの基本データ幅以下のビットから構成される。簡素化タグの形成に使用されないビットにより残余索引403が形成される。従って、仮想ページ番号203の長さが36ビットの場合、コンピュータのデータ幅を32ビットと仮定すれば、簡素化タグ401は32ビットの長さを有し、残余索引403は4ビットの長さを有することになる。
【0025】
簡素化タグ401についてハッシュ機能405が実行されてタグ索引407が生成される。このタグ索引407が、例えば連結により、残余索引403と組み合わされて、ページテーブル索引409が形成される。図示のように、ページテーブル索引409は1であり、ページテーブル413の第2項目411を指している。ページテーブル中の各項目は、図3に関連して上述したように複数部分から構成される。簡素化タグ401が簡素化タグ415に等しい場合には、物理ページ417により所望の物理(実)メモリページのアドレスが与えられる。また、簡素化タグ401,415が一致しない場合には、上述のように、ポインタ419を調べてチェーン中の次のリンクを(もし存在すれば)見つけ出す。
【0026】
この方法および装置は、ページテーブルが最小数の索引を備えていることを必要とする。この例では、残余索引403のサイズが4ビットなので、ページテーブルは少なくとも16項目を備えていなければならない。しかし、ページテーブルは一般にはこれよりはるかに大きいサイズを有するので、前記制約によって問題が生じることはない。
【0027】
図5は、本発明の第2好適実施例を示すものである。前述のように、仮想ページ番号203は、簡素化タグ401および残余索引403へと分割される。簡素化タグ401はコンピュータの基本データ幅と同じ幅である。その簡素化タグ401の形成に利用されないビットによって残余索引403が形成される。図示の例の場合、残余索引403は4ビットの長さを有し、簡素化タグ401は32ビットの長さを有している。
【0028】
32ビットの簡素化タグ401がハッシュ機能405により処理されてタグ索引407が生成される。また、残余索引403と仮想タグ401からの「n」ビットとについて第2のハッシュ機能501が実行される。ここで、「n」は0から簡素化タグの最大ビット数までの値をとることができる。第2のハッシュ機能501の出力505が、例えば連結によりタグ索引407と組み合わせられてページテーブル索引507が形成される。
【0029】
第2のハッシュ機能501を使用することにより、残余索引403のビットだけしか使用しない場合に比べて、ページテーブル索引の一層均一な配分が可能になる。この配分により、ページテーブルにへの最初の索引でヒットすることが理想的である。しかし、ページテーブルサイズに関する制約により、テーブルへの探索長が1.1であるのがより一般的であり、これにより、妥当なページテーブルサイズが得られることになる。
【0030】
ページテーブル509の編成および機能は、基本的には図3および図4に関連して説明した通りである。しかし、ページテーブルのサイズは、第2のハッシュ機能の出力505のビット数により決定される。最小の場合、出力505は残余索引403におけるビット数から構成されることになる。残余索引の長さが4ビットで「n」=0である最小の場合には、ページテーブルは、16項目を備え、図4に関連して説明したように機能することになる。また「n」>0 の場合には、出力505が4ビットを超え、ページテーブルが2mの項目空間を有することになる。ここで、mは出力505のビット数である。「n」と「m」の間には必ずしも直接的な関係があるとは限らない。これは、第2のハッシュ機能が簡素化タグから任意数のビットを取り出して1つ以上の追加ビットを生成し、それを残余索引ビット403と組み合わせることができるからである。出力505のビット数が増すほど、ページテーブル中のページが一層均一に配分される。
【0031】
簡素化タグからの「n」ビットは、ソフトウェアによって構成可能なものであり、ビット数と使用される特定のビットとをソフトウェアで選択するようにすることができる。これにより、仮想アドレス203がデータパスサイズよりはるかに大きく、それ故、ページテーブルサイズに関する制約が問題となる場合に望ましい、コンピュータ装置の効果的な構成が可能となる。
【0032】
図6に本発明のもう1つの実施例を示す。ページテーブルのルックアッププロセスは、下記例外を除き、図4に関連して説明したものと基本的に同じである。
【0033】
ページテーブル413は、図4の簡素化タグの代わりに「ハッシュタグ」601,603を含んでいる。これらのハッシュタグは、索引ビット403および仮想ページ番号ビット401を選択して該ビットにハッシュ機能を実行し、コンピュータの基本データ幅を超えることのない結果を得ることにより形成される。次いでそのハッシュ結果が、前述の簡素化タグの代わりにページテーブル中(601,603)に格納される。
【0034】
動作時に、ページテーブル索引409が前述のように形成される。このページテーブル索引の形成と同時に、索引ビット403と仮想ページ番号ビット401とについてハッシュ機能607を実行することによりハッシュ結果605が形成される。このハッシュ機能は、ページテーブルに格納された全てのハッシュタグを生成するのに用いられたものと同じである。ページテーブル索引は、ページテーブル413中の項目411を指し、そのハッシュタグ603がハッシュ結果605と比較(609)される。ハッシュタグ603とハッシュ結果605とが一致する場合には、物理ページ417により所望の物理メモリページのアドレスが与えられる。またハッシュタグ603とハッシュ結果605とが一致しない場合には、ポインタ419を調べてチェーン中の次のリンクを(もし存在すれば)見つけ出すことになる。
【0035】
このページテーブルタグの生成方法および装置は、仮想ページ番号中の高位ビットがゼロになることをコンピュータのオペレーティングシステムが保証できる場合に、特に有効なものとなる。例えば、仮想アドレス空間全体が必要とはならない場合には、幾つかのビットを常にゼロにすることができる。この方法および装置はまた、索引IDXのサイズの縮小を可能とするものであり、これによりページテーブルの最小サイズが縮小されるので、ページテーブルの効率が改善される。
【0036】
図7は、本発明の範囲から逸脱することなく有効となる多くの考え得る代替的なページテーブル編成のうちの1つを示すものである。この例では、1ページテーブル中の1項目701が示されている。この項目は、3組(703,705,707)の簡素化タグ項目および物理ページ項目を備えている。このページテーブルに関する操作は、基本的には図4に関連して説明したものと同じである。但し、ポインタ715を調べて次のリンクを(もし存在すれば)見つけ出す前に、3つの簡素化タグ(709,711,713)を仮想ページ番号401と比較する、という点では異なっている。
【0037】
上述の好適実施例は全て、大きな仮想アドレスの利用を可能にすると共に、多数の比較ステップの必要性をなくす、という利点を備えている。従って、本発明を実施したコンピュータは、従来の設計に付随した性能上の不利および問題を伴うこと無く、大アドレス空間という利点を享受することになる。これは、共通の物理メモリに各々がアクセスする多数のCPUを用いた高性能コンピュータ装置にとっては特に重要な利点となる。
【0038】
当業者であれば、本発明の他の態様は、本開示の本発明の詳細説明または実施例を考察することにより明らかであろう。詳細な説明および実施例は、単なる例示とみなされることを意図したものであり、本発明の真の思想およびその範囲は特許請求の範囲に示されている。
【0039】
以下に本発明の実施態様を列挙する。
【0040】
1.変換ルックアサイドバッファ(TLB)およびページテーブルを有する種類の仮想メモリ/物理メモリ変換装置を組み込んだ、基本データ幅を有するコンピュータ装置であって、このコンピュータ装置が、
仮想タグを記憶する第1記憶手段であって、前記仮想タグのビット数が前記コンピュータの前記基本データ幅を超えている、前記第1記憶手段を備え、
前記仮想タグが簡素化タグセクションを有し、その簡素化タグセクションのビット数が前記コンピュータの前記基本データ幅以下であり、
前記仮想タグが、前記簡素化タグセクションから排除された前記仮想タグ中のビットを含む索引セクションを有し、更に、前記コンピュータ装置が、
前記簡素化タグセクション中のビットから出力ビットストリングを生成するハッシュ機能と、
前記出力ビットストリングのビットおよび前記索引セクションのビットを含むページテーブルオフセットと、
項目対を有するページテーブルであって、その各項目対が簡素化タグ項目を含み、その簡素化タグ項目が、簡素化タグとそれに関連する物理ページアドレスとからなる、前記ページテーブルとを備え、
TLBミスの後に、前記ページテーブルオフセットが、前記仮想タグの前記簡素化タグセクションと比較される前記ページテーブル中の前記簡素化タグ項目を指すようにしたことを特徴とする、前記コンピュータ装置。
【0041】
2.前記ページテーブルが2Iの前記簡素化タグ項目を含み、その「I」が前記索引セクションのビット数に等しいことを特徴とする、前項1記載のコンピュータ装置。
【0042】
3.一連の項目を指すポインタ項目を前記ページテーブルが更に含み、前記一連の項目が簡素化タグ項目を含むことを特徴とする、前項1記載のコンピュータ装置。
【0043】
4.変換ルックアサイドバッファ中の情報を更新するコンピュータ装置であって、このコンピュータ装置が、
簡素化タグフィールドと索引フィールドと物理オフセットフィールドとを含む仮想アドレスを記憶する第1記憶手段と、
簡素化タグフィールド中の情報にハッシュ処理を行ってタグ索引の出力を生成するハッシュ機能手段と、
前記タグ索引と前記索引フィールド中の情報とを含み、ページテーブル中の簡素化タグ項目を指す、ページテーブル索引と、
前記簡素化タグ項目中の情報を前記簡素化タグフィールド中の情報と比較し、前記簡素化タグ項目中の情報と前記簡素化タグフィールド中の情報とが一致する場合に、前記簡素化タグ項目に関連する物理ページ項目と、前記簡素化タグ項目に関連する仮想アドレスとがTLBに記憶されるようにする、比較器と
を備えることを特徴とする、前記コンピュータ装置。
【0044】
5.前記簡素化タグフィールドおよび前記簡素化タグ項目のサイズが、関連するコンピュータの基本データ幅以下であり、前記簡素化タグフィールドに前記索引フィールドを加えたものが前記の関連するコンピュータの基本データ幅を超えることを特徴とする、前項4記載のコンピュータ装置。
【0045】
6.前記ページテーブル索引が、前記タグ索引と第2のハッシュ機能からの出力とを含み、
前記第2のハッシュ機能への第1入力が、前記索引フィールド中の全情報を含み、前記第2のハッシュ機能への第2入力が、前記簡素化タグフィールドからの1ビットの情報を含む、
ということを特徴とする、前項4記載のプロセッサ装置。
【0046】
7.TLBミスを処理するためのコンピュータベースの装置であって、この装置が、
仮想アドレスを介してアクセスされるデータページを記憶する物理メモリ手段と、
前記仮想アドレスを前記物理メモリ手段中のデータの物理アドレスに変換するためのアドレス変換情報を記憶するTLBと、
そのTLBに接続され、前記仮想アドレス内の第1フィールド中の情報にハッシュ処理を行うよう構成された、TLBミス操作手段であって、前記第1フィールドが、関連するコンピュータの基本データ幅以下の大きさを有してタグ索引を形成し、そのタグ索引を前記仮想アドレス内の別の第2フィールド中の情報と組み合わせてページテーブルへのオフセットポインタを形成する、前記TLBミス操作手段とを備え、
更に、そのTLBミス操作手段が、前記オフセットポインタによって指されたページテーブル情報を、前記仮想アドレス内の前記第1フィールド中の情報と比較し、それら情報が一致した場合に、前記ページテーブルからの情報を前記TLBに記憶させるようにしたことを特徴とする、前記コンピュータベースの装置。
【0047】
8.前記TLBミス操作手段が更に、前記の別の第2フィールド中の情報に前記第1フィールドからの1ビットの情報を加えたものにハッシュ処理を行うことによりハッシュ索引出力を形成するように構成されており、そのハッシュ索引出力を前記タグ索引と組み合わせて前記オフセットポインタを形成するようにしたことを特徴とする、前項7記載のコンピュータベースの装置。
【0048】
9.前記ページテーブルが2Iの変換項目を含み、その「I」が前記ハッシュ索引出力のビット数に等しいことを特徴とする、前項8記載のコンピュータベース装置。
【0049】
10.変換ルックアサイドバッファ中の情報を更新するためのコンピュータ装置であって、このコンピュータ装置が、
簡素化タグフィールドと索引フィールドと物理オフセットフィールドとを含む仮想アドレスを記憶する第1記憶手段と、
簡素化タグフィールドにハッシュ処理を行ってタグ索引の出力を生成する第1ハッシュ機能手段と、
前記タグ索引と前記索引フィールドとを含み、ページテーブル中のハッシュタグ項目を指す、ページテーブル索引と、
前記仮想アドレスにハッシュ処理を行ってハッシュ結果を生成する第2ハッシュ機能手段と、
前記ハッシュタグ項目を前記ハッシュ結果と比較し、前記ハッシュタグ項目と前記ハッシュ結果とが一致する場合に、前記ハッシュタグ項目に関連する物理ページ項目がTLBに記憶されるようにする、比較器と
を備えることを特徴とする、前記コンピュータ装置。
【0050】
11.前記ページテーブルが2Iのハッシュタグ項目を含み、その「I」が前記索引セクションのビット数に等しいことを特徴とする、前項10記載のコンピュータ装置。
【0051】
12.前記ハッシュタグが、それが関連するコンピュータの基本データ幅に等しいことを特徴とする、前項10記載のコンピュータ装置。
【0052】
【発明の効果】
本発明は上述のように構成したので、ページテーブル中の項目の検査時に多数の比較ステップを要することなく、即ちコンピュータ装置の処理速度を低下させることなく、コンピュータ装置の基本データパスより大きな仮想タグに対処することが可能となる。
【図面の簡単な説明】
【図1】プログラムの実行中に提示される仮想アドレスに応答する従来の手順を示すフローチャートである。
【図2】変換ルックアサイドバッファ中の項目にアクセスするための従来の方法を示す機能ブロック図である。
【図3】TLBミスの後にTLBの更新を行うために物理ページ情報を取り出すための従来の方法を示す機能ブロック図である。
【図4】索引ビットをハッシュタグと組み合わせてページテーブルへのアクセスを提供する本発明の第1好適実施例を示す機能ブロック図である。
【図5】ハッシュ索引ビットをハッシュタグと組み合わせてページテーブルへのアクセスを提供する本発明の第2好適実施例を示す機能ブロック図である。
【図6】ハッシュタグがページテーブル中に格納される本発明の第3好適実施例を示す機能ブロック図である。
【図7】代替的なページテーブル形式を示す説明図である。
【符号の説明】
203 仮想ページ番号
401,415 簡素化タグ
403 残余索引
405 ハッシュ機能
407 タグ索引
409 ページテーブル索引
413 ページテーブル
417 物理ページ
419 ポインタ
Claims (12)
- 変換ルックアサイドバッファ(TLB)およびページテーブルを有する種類の、仮想メモリから物理メモリへの変換装置を組み込んだ、基本データ幅を有するコンピュータ装置であって、
仮想タグを記憶する第1の記憶手段であって、前記仮想タグのビット数が前記コンピュータの前記基本データ幅を超えており、かつ、前記仮想タグが簡素化タグセクションを有し、かつ、前記簡素化タグセクションのビット数が前記コンピュータの前記基本データ幅以下であり、かつ前記仮想タグが、前記簡素化タグセクションから排除された仮想タグのビットを含む索引セクションを有する、第1の記憶手段と、
前記簡素化タグセクションのビットから出力ビットストリングを生成するように動作するハッシュ機能と、
前記索引セクションのビットと組み合わされた前記出力ビットストリングを含むページテーブル索引と、
簡素化タグ項目を含むページテーブルであって、前記簡素化タグ項目が、簡素化タグとそれに関連する物理ページアドレスとからなり、かつ、TLBミスの後に、前記ページテーブル索引が指す前記簡素化タグ項目を有する前記簡素化タグと、前記仮想タグの前記簡素化タグセクションとが比較されるものである、ページテーブルとを含む、コンピュータ装置。 - 前記ページテーブルが少なくとも2Iの簡素化タグ項目を含み、その「I」が前記索引セクションのビット数に等しい、請求項1記載のコンピュータ装置。
- 一連の項目を指すポインタ項目を前記ページテーブルが更に含み、その一連の項目が簡素化タグ項目を含む、請求項1記載のコンピュータ装置。
- 変換ルックアサイドバッファ(TLB)中の情報を更新するためのコンピュータ装置であって、
簡素化タグフィールドと索引フィールドと物理オフセットフィールドとを含む仮想アドレスを記憶する第1の記憶手段と、
簡素化タグフィールド中の情報にハッシュ処理を行ってタグ索引の出力を生成するためのハッシュ機能手段と、
前記タグ索引と前記索引フィールド中の情報とを含み、ページテーブル中の簡素化タグ項目を指す、ページテーブル索引と、
前記簡素化タグ項目中の情報を前記簡素化タグフィールド中の情報と比較し、前記簡素化タグ項目中の情報と前記簡素化タグフィールド中の情報とが一致する場合に、前記簡素化タグ項目に関連する物理ページ項目と、前記簡素化タグ項目に関連する仮想アドレスとが前記TLBに記憶される、比較器とを含み、
前記簡素化タグフィールドおよび前記簡素化タグ項目のサイズが、関連するコンピュータの基本データ幅以下であり、前記簡素化タグフィールドに前記索引フィールドを加えたものが前記関連するコンピュータの基本データ幅を超える、コンピュータ装置。 - 変換ルックアサイドバッファ(TLB)中の情報を更新するためのコンピュータ装置であって、
簡素化タグフィールドと索引フィールドと物理オフセットフィールドとを含む仮想アドレスを記憶する第1の記憶手段と、
簡素化タグフィールド中の情報にハッシュ処理を行ってタグ索引の出力を生成するための第1のハッシュ機能手段と、
前記索引フィールドの全情報と前記簡素化タグフィールドからの情報にハッシュ処理を行って結果を出力するための第2のハッシュ機能手段と、
前記タグ索引と前記第2のハッシュ機能手段の出力とを含み、ページテーブル中の簡素化タグ項目を指す、ページテーブル索引と、
前記簡素化タグ項目中の情報を前記簡素化タグフィールド中の情報と比較し、前記簡素化タグ項目中の情報と前記簡素化タグフィールド中の情報とが一致する場合に、前記簡素化タグ項目に関連する物理ページ項目と、前記簡素化タグ項目に関連する仮想アドレスとが前記TLBに記憶される、比較器とを含み、
前記簡素化タグフィールドおよび前記簡素化タグ項目のサイズが、関連するコンピュータの基本データ幅以下であり、前記簡素化タグフィールドに前記索引フィールドを加えたものが前記関連するコンピュータの基本データ幅を超える、コンピュータ装置。 - TLBミスを処理するためのコンピュータベースの装置であって、
仮想アドレスを介してアクセスされるデータページを記憶するための物理メモリ手段と、
前記仮想アドレスを前記物理メモリ手段中のデータの物理アドレスに変換するためのアドレス変換情報を記憶するTLBと、
前記TLBに結合され、前記仮想アドレス内の第1フィールド中の情報にハッシュ処理を行うよう適合された、TLBミスハンドラであって、前記第1フィールドが、関連するコンピュータの基本データ幅以下の大きさを有しており、かつ、前記TLBミスハンドラは前記第1フィールドにハッシュ処理を行ってタグ索引を形成するものであり、かつ、前記TLBミスハンドラは前記タグ索引を前記仮想アドレス内の別個の第2フィールド中の情報と組み合わせてページテーブルへのオフセットポインタを形成するものであり、かつ、前記別個の第2フィールドは前記第1フィールドから排除された前記仮想アドレスの仮想ビットを含むものであり、かつ、前記TLBミスハンドラは前記オフセットポインタによって指されたページテーブル情報を、前記仮想アドレス内の前記第1フィールド中の情報と比較し、それら情報が一致した場合に、前記ページテーブルからの情報を前記TLBに記憶させるものである、TLBミスハンドラとを含む、コンピュータベースの装置。 - 前記ページテーブルが少なくとも2 I の変換項目を含み、その「 I 」が前記別個の第2フィールドのビット数に等しい、請求項6記載のコンピュータベース装置。
- TLBミスを処理するためのコンピュータベースの装置であって、
仮想アドレスを介してアクセスされるデータページを記憶するための物理メモリ手段と、
前記仮想アドレスを前記物理メモリ手段中のデータの物理アドレスに変換するためのアドレス変換情報を記憶するTLBと、
前記TLBに結合され、前記仮想アドレス内の第1フィールド中の情報にハッシュ処理を行うよう適合された、TLBミスハンドラであって、前記第1フィールドが、関連するコンピュータの基本データ幅以下の大きさを有しており、かつ、前記TLBミスハンドラは前記第1フィールドにハッシュ処理を行ってタグ索引を形成するものであり、かつ、前記TLBミスハンドラは前記仮想アドレス内の別個の第2フィールド中の情報に前記第1フィールドからの情報を加えたものにハッシュ処理を行ってハッシュ索引出力を形成するものであり、かつ、前記別個の第2フィールドは前記第1フィールドから排除された前記仮想アドレスの仮想ビットを含むものであり、かつ、前記TLBミスハンドラは前記タグ索引と前記ハッシュ索引出力とを組み合わせてページテーブルへのオフセットポインタを形成するものであり、かつ、前記TLBミスハンドラは前記オフセットポインタによって指されたページテーブル情報を、前記仮想アドレス内の前記第1フィールド中の情報と比較し、それら情報が一致した場合に、前記ページテーブルからの情報を前記TLBに記憶させるものである、TLBミスハンドラとを含む、コンピュータベースの装置。 - 前記ページテーブルが少なくとも2Iの変換項目を含み、その「I」が前記ハッシュ索引出力のビット数に等しい、請求項8記載のコンピュータベース装置。
- 変換ルックアサイドバッファ(TLB)中の情報を更新するためのコンピュータ装置であって、
簡素化タグフィールドと索引フィールドと物理オフセットフィールドとを含む仮想アドレスを記憶する第1の記憶手段と、
簡素化タグフィールドにハッシュ処理を行ってタグ索引の出力を生成するための第1のハッシュ機能手段と、
前記タグ索引と前記索引フィールドとを含み、ページテーブル中のハッシュタグ項目を指す、ページテーブル索引と、
前記仮想アドレスにハッシュ処理を行ってハッシュ結果を生成する第2のハッシュ機能手段と、
前記ハッシュタグ項目を前記ハッシュ結果と比較し、前記ハッシュタグ項目と前記ハッシュ結果とが一致する場合に、前記ハッシュタグ項目に関連する物理ページ項目が前記TLBに記憶される、比較器とを含む、コンピュータ装置。 - 前記ページテーブルが少なくとも2Iのハッシュタグ項目を含み、その「I」が前記索引フィールドのビット数に等しい、請求項10記載のコンピュータ装置。
- 前記ハッシュタグが、それが関連するコンピュータの基本データ幅に等しい、請求項10記載のコンピュータ装置。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US4485493A | 1993-04-08 | 1993-04-08 | |
US044854 | 1993-04-08 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH0749812A JPH0749812A (ja) | 1995-02-21 |
JP3640978B2 true JP3640978B2 (ja) | 2005-04-20 |
Family
ID=21934684
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP06849194A Expired - Fee Related JP3640978B2 (ja) | 1993-04-08 | 1994-04-06 | ページテーブル中のハッシュアドレスタグを用いたメモリアドレス制御装置 |
Country Status (4)
Country | Link |
---|---|
US (1) | US5724538A (ja) |
JP (1) | JP3640978B2 (ja) |
KR (1) | KR100297454B1 (ja) |
DE (1) | DE4410060B4 (ja) |
Families Citing this family (82)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5809563A (en) * | 1996-11-12 | 1998-09-15 | Institute For The Development Of Emerging Architectures, Llc | Method and apparatus utilizing a region based page table walk bit |
US5787431A (en) * | 1996-12-16 | 1998-07-28 | Borland International, Inc. | Database development system with methods for java-string reference lookups of column names |
US6073226A (en) * | 1997-03-19 | 2000-06-06 | Microsoft Corporation | System and method for minimizing page tables in virtual memory systems |
US6065010A (en) * | 1997-06-10 | 2000-05-16 | Daikin Us Corporation | Computer implemented method of generating virtual files for sharing information of physical information file |
WO1999030239A1 (fr) * | 1997-12-05 | 1999-06-17 | Tokyo Electron Limited | Memoire et procede d'acces |
US6633922B1 (en) * | 1997-12-15 | 2003-10-14 | International Business Machines Corporation | Object access mechanism that dynamically switches between multiple distributed access models |
US7953931B2 (en) * | 1999-08-04 | 2011-05-31 | Super Talent Electronics, Inc. | High endurance non-volatile memory devices |
US6393544B1 (en) * | 1999-10-31 | 2002-05-21 | Institute For The Development Of Emerging Architectures, L.L.C. | Method and apparatus for calculating a page table index from a virtual address |
US8019943B2 (en) * | 2000-01-06 | 2011-09-13 | Super Talent Electronics, Inc. | High endurance non-volatile memory devices |
US6480950B1 (en) * | 2000-01-24 | 2002-11-12 | Oracle International Corporation | Software paging system |
US6671645B2 (en) * | 2001-09-28 | 2003-12-30 | Ciena Corporation | Method for in-service RAM testing |
US6697276B1 (en) | 2002-02-01 | 2004-02-24 | Netlogic Microsystems, Inc. | Content addressable memory device |
US6934796B1 (en) * | 2002-02-01 | 2005-08-23 | Netlogic Microsystems, Inc. | Content addressable memory with hashing function |
US7382637B1 (en) | 2002-02-01 | 2008-06-03 | Netlogic Microsystems, Inc. | Block-writable content addressable memory device |
US20030225992A1 (en) * | 2002-05-29 | 2003-12-04 | Balakrishna Venkatrao | Method and system for compression of address tags in memory structures |
US7197620B1 (en) * | 2002-12-10 | 2007-03-27 | Unisys Corporation | Sparse matrix paging system |
US7343477B1 (en) * | 2003-12-29 | 2008-03-11 | Sun Microsystems, Inc. | Efficient read after write bypass |
US7555634B1 (en) | 2004-04-22 | 2009-06-30 | Sun Microsystems, Inc. | Multiple data hazards detection and resolution unit |
US7606994B1 (en) * | 2004-11-10 | 2009-10-20 | Sun Microsystems, Inc. | Cache memory system including a partially hashed index |
JP3894335B1 (ja) * | 2005-10-04 | 2007-03-22 | インターナショナル・ビジネス・マシーンズ・コーポレーション | データベースの整合性を判断する装置、およびその方法 |
US8464024B2 (en) * | 2007-04-27 | 2013-06-11 | Hewlett-Packard Development Company, L.P. | Virtual address hashing |
WO2009095902A2 (en) | 2008-01-31 | 2009-08-06 | Densbits Technologies Ltd. | Systems and methods for handling immediate data errors in flash memory |
US8694715B2 (en) | 2007-10-22 | 2014-04-08 | Densbits Technologies Ltd. | Methods for adaptively programming flash memory devices and flash memory systems incorporating same |
US8453022B2 (en) | 2007-12-05 | 2013-05-28 | Densbits Technologies Ltd. | Apparatus and methods for generating row-specific reading thresholds in flash memory |
US8359516B2 (en) | 2007-12-12 | 2013-01-22 | Densbits Technologies Ltd. | Systems and methods for error correction and decoding on multi-level physical media |
US8972472B2 (en) | 2008-03-25 | 2015-03-03 | Densbits Technologies Ltd. | Apparatus and methods for hardware-efficient unbiased rounding |
US8819385B2 (en) | 2009-04-06 | 2014-08-26 | Densbits Technologies Ltd. | Device and method for managing a flash memory |
US8458574B2 (en) * | 2009-04-06 | 2013-06-04 | Densbits Technologies Ltd. | Compact chien-search based decoding apparatus and method |
US9330767B1 (en) | 2009-08-26 | 2016-05-03 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Flash memory module and method for programming a page of flash memory cells |
US8995197B1 (en) | 2009-08-26 | 2015-03-31 | Densbits Technologies Ltd. | System and methods for dynamic erase and program control for flash memory device memories |
US8730729B2 (en) | 2009-10-15 | 2014-05-20 | Densbits Technologies Ltd. | Systems and methods for averaging error rates in non-volatile devices and storage systems |
US8724387B2 (en) | 2009-10-22 | 2014-05-13 | Densbits Technologies Ltd. | Method, system, and computer readable medium for reading and programming flash memory cells using multiple bias voltages |
US8429377B2 (en) * | 2010-01-08 | 2013-04-23 | International Business Machines Corporation | Optimizing TLB entries for mixed page size storage in contiguous memory |
US9037777B2 (en) * | 2009-12-22 | 2015-05-19 | Densbits Technologies Ltd. | Device, system, and method for reducing program/read disturb in flash arrays |
US8812513B2 (en) | 2009-12-25 | 2014-08-19 | International Business Machines Corporation | Hash pointer checking for hierarchical database logical relationship |
US8745317B2 (en) | 2010-04-07 | 2014-06-03 | Densbits Technologies Ltd. | System and method for storing information in a multi-level cell memory |
US8510639B2 (en) | 2010-07-01 | 2013-08-13 | Densbits Technologies Ltd. | System and method for multi-dimensional encoding and decoding |
US8964464B2 (en) | 2010-08-24 | 2015-02-24 | Densbits Technologies Ltd. | System and method for accelerated sampling |
US9063878B2 (en) | 2010-11-03 | 2015-06-23 | Densbits Technologies Ltd. | Method, system and computer readable medium for copy back |
US8850100B2 (en) | 2010-12-07 | 2014-09-30 | Densbits Technologies Ltd. | Interleaving codeword portions between multiple planes and/or dies of a flash memory device |
US8478740B2 (en) * | 2010-12-16 | 2013-07-02 | Microsoft Corporation | Deriving document similarity indices |
US8990665B1 (en) | 2011-04-06 | 2015-03-24 | Densbits Technologies Ltd. | System, method and computer program product for joint search of a read threshold and soft decoding |
US20120265962A1 (en) * | 2011-04-17 | 2012-10-18 | Anobit Technologies Ltd. | High-performance sas target |
US9110785B1 (en) | 2011-05-12 | 2015-08-18 | Densbits Technologies Ltd. | Ordered merge of data sectors that belong to memory space portions |
US9195592B1 (en) | 2011-05-12 | 2015-11-24 | Densbits Technologies Ltd. | Advanced management of a non-volatile memory |
US9372792B1 (en) | 2011-05-12 | 2016-06-21 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Advanced management of a non-volatile memory |
US9501392B1 (en) | 2011-05-12 | 2016-11-22 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Management of a non-volatile memory module |
US9396106B2 (en) | 2011-05-12 | 2016-07-19 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Advanced management of a non-volatile memory |
US8996790B1 (en) * | 2011-05-12 | 2015-03-31 | Densbits Technologies Ltd. | System and method for flash memory management |
WO2013085518A1 (en) * | 2011-12-08 | 2013-06-13 | Intel Corporation | A method, apparatus, and system for efficiently handling multiple virtual address mappings during transactional execution |
US8996788B2 (en) | 2012-02-09 | 2015-03-31 | Densbits Technologies Ltd. | Configurable flash interface |
US8947941B2 (en) | 2012-02-09 | 2015-02-03 | Densbits Technologies Ltd. | State responsive operations relating to flash memory cells |
US8996793B1 (en) | 2012-04-24 | 2015-03-31 | Densbits Technologies Ltd. | System, method and computer readable medium for generating soft information |
US8838937B1 (en) | 2012-05-23 | 2014-09-16 | Densbits Technologies Ltd. | Methods, systems and computer readable medium for writing and reading data |
US8879325B1 (en) | 2012-05-30 | 2014-11-04 | Densbits Technologies Ltd. | System, method and computer program product for processing read threshold information and for reading a flash memory module |
US9921954B1 (en) | 2012-08-27 | 2018-03-20 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Method and system for split flash memory management between host and storage controller |
US9368225B1 (en) | 2012-11-21 | 2016-06-14 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Determining read thresholds based upon read error direction statistics |
US9069659B1 (en) | 2013-01-03 | 2015-06-30 | Densbits Technologies Ltd. | Read threshold determination using reference read threshold |
US9081672B1 (en) | 2013-05-30 | 2015-07-14 | Richard Michael Nemes | Methods and apparatus for information storage and retrieval using a caching technique with external-chain hashing and dynamic resource-dependent data shedding |
US9136876B1 (en) | 2013-06-13 | 2015-09-15 | Densbits Technologies Ltd. | Size limited multi-dimensional decoding |
US9367454B2 (en) * | 2013-08-15 | 2016-06-14 | Applied Micro Circuits Corporation | Address index recovery using hash-based exclusive or |
US9229874B2 (en) * | 2013-09-27 | 2016-01-05 | Intel Corporation | Apparatus and method for compressing a memory address |
US9413491B1 (en) | 2013-10-08 | 2016-08-09 | Avago Technologies General Ip (Singapore) Pte. Ltd. | System and method for multiple dimension decoding and encoding a message |
US9348694B1 (en) | 2013-10-09 | 2016-05-24 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Detecting and managing bad columns |
US9397706B1 (en) | 2013-10-09 | 2016-07-19 | Avago Technologies General Ip (Singapore) Pte. Ltd. | System and method for irregular multiple dimension decoding and encoding |
US9786388B1 (en) | 2013-10-09 | 2017-10-10 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Detecting and managing bad columns |
US9536612B1 (en) | 2014-01-23 | 2017-01-03 | Avago Technologies General Ip (Singapore) Pte. Ltd | Digital signaling processing for three dimensional flash memory arrays |
US10120792B1 (en) | 2014-01-29 | 2018-11-06 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Programming an embedded flash storage device |
US20150256601A1 (en) * | 2014-03-10 | 2015-09-10 | Palo Alto Research Center Incorporated | System and method for efficient content caching in a streaming storage |
US9542262B1 (en) | 2014-05-29 | 2017-01-10 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Error correction |
US9892033B1 (en) | 2014-06-24 | 2018-02-13 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Management of memory units |
US9584159B1 (en) | 2014-07-03 | 2017-02-28 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Interleaved encoding |
US9972393B1 (en) | 2014-07-03 | 2018-05-15 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Accelerating programming of a flash memory module |
US9449702B1 (en) | 2014-07-08 | 2016-09-20 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Power management |
US9524211B1 (en) | 2014-11-18 | 2016-12-20 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Codeword management |
US10305515B1 (en) | 2015-02-02 | 2019-05-28 | Avago Technologies International Sales Pte. Limited | System and method for encoding using multiple linear feedback shift registers |
US10628255B1 (en) | 2015-06-11 | 2020-04-21 | Avago Technologies International Sales Pte. Limited | Multi-dimensional decoding |
US9851921B1 (en) | 2015-07-05 | 2017-12-26 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Flash memory chip processing |
US10025722B2 (en) * | 2015-10-28 | 2018-07-17 | International Business Machines Corporation | Efficient translation reloads for page faults with host accelerator directly accessing process address space without setting up DMA with driver and kernel by process inheriting hardware context from the host accelerator |
US9954558B1 (en) | 2016-03-03 | 2018-04-24 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Fast decoding of data stored in a flash memory |
US11544069B2 (en) * | 2018-10-25 | 2023-01-03 | Micron Technology, Inc. | Universal pointers for data exchange in a computer system having independent processors |
US10846239B2 (en) * | 2018-11-29 | 2020-11-24 | Marvell Asia Pte, Ltd. | Managing translation lookaside buffer entries based on associativity and page size |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4215402A (en) * | 1978-10-23 | 1980-07-29 | International Business Machines Corporation | Hash index table hash generator apparatus |
JPS5687282A (en) * | 1979-12-14 | 1981-07-15 | Nec Corp | Data processor |
US4682281A (en) * | 1983-08-30 | 1987-07-21 | Amdahl Corporation | Data storage unit employing translation lookaside buffer pointer |
US4731740A (en) * | 1984-06-30 | 1988-03-15 | Kabushiki Kaisha Toshiba | Translation lookaside buffer control system in computer or virtual memory control scheme |
US5060137A (en) * | 1985-06-28 | 1991-10-22 | Hewlett-Packard Company | Explicit instructions for control of translation lookaside buffers |
JPH083805B2 (ja) * | 1985-06-28 | 1996-01-17 | ヒューレット・パッカード・カンパニー | Tlb制御方法 |
US5253353A (en) * | 1990-01-02 | 1993-10-12 | Digital Equipment Corporation | System and method for efficiently supporting access to I/O devices through large direct-mapped data caches |
-
1994
- 1994-03-23 DE DE4410060A patent/DE4410060B4/de not_active Expired - Fee Related
- 1994-04-06 JP JP06849194A patent/JP3640978B2/ja not_active Expired - Fee Related
- 1994-04-07 KR KR1019940007217A patent/KR100297454B1/ko not_active IP Right Cessation
-
1996
- 1996-02-27 US US08/607,622 patent/US5724538A/en not_active Expired - Lifetime
Also Published As
Publication number | Publication date |
---|---|
US5724538A (en) | 1998-03-03 |
DE4410060B4 (de) | 2006-02-09 |
KR100297454B1 (ko) | 2001-10-24 |
KR940024591A (ko) | 1994-11-18 |
JPH0749812A (ja) | 1995-02-21 |
DE4410060A1 (de) | 1994-10-13 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3640978B2 (ja) | ページテーブル中のハッシュアドレスタグを用いたメモリアドレス制御装置 | |
JP4268332B2 (ja) | 仮想アドレスからページ・テーブル・インデックスを計算する方法および装置 | |
US5493660A (en) | Software assisted hardware TLB miss handler | |
US6145064A (en) | Method of efficiently updating hashed page tables | |
KR960001946B1 (ko) | 우선 변환 참조버퍼 | |
US5230045A (en) | Multiple address space system including address translator for receiving virtual addresses from bus and providing real addresses on the bus | |
US8151085B2 (en) | Method for address translation in virtual machines | |
US5123101A (en) | Multiple address space mapping technique for shared memory wherein a processor operates a fault handling routine upon a translator miss | |
US6408373B2 (en) | Method and apparatus for pre-validating regions in a virtual addressing scheme | |
US5956756A (en) | Virtual address to physical address translation of pages with unknown and variable sizes | |
US5526504A (en) | Variable page size translation lookaside buffer | |
US4774653A (en) | Hybrid hardware/software method and apparatus for virtual memory address translation using primary and secondary translation buffers | |
US6189074B1 (en) | Mechanism for storing system level attributes in a translation lookaside buffer | |
US6480950B1 (en) | Software paging system | |
US20040221128A1 (en) | Virtual to physical memory mapping in network interfaces | |
US5060137A (en) | Explicit instructions for control of translation lookaside buffers | |
US5630087A (en) | Apparatus and method for efficient sharing of virtual memory translations | |
JPH04232551A (ja) | 多重仮想アドレス変換方法及び装置 | |
US7493464B2 (en) | Sparse matrix | |
JPH04319747A (ja) | アドレス変換機構 | |
JPH11203199A (ja) | キャッシュ・メモリ | |
JP2012212440A (ja) | キャッシュされたメモリデータを伴うキャッシュメモリ属性インジケータ | |
JPH08272692A (ja) | 仮想アドレス変換方法 | |
US5319761A (en) | Directory look-aside table for a virtual storage system including means for minimizing synonym entries | |
EP0212129A2 (en) | Method of updating information in a translation lookaside buffer |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20040910 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20040921 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20041217 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20050118 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20050120 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20090128 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20090128 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100128 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100128 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110128 Year of fee payment: 6 |
|
LAPS | Cancellation because of no payment of annual fees |