[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

JP2635058B2 - アドレス変換方式 - Google Patents

アドレス変換方式

Info

Publication number
JP2635058B2
JP2635058B2 JP62283279A JP28327987A JP2635058B2 JP 2635058 B2 JP2635058 B2 JP 2635058B2 JP 62283279 A JP62283279 A JP 62283279A JP 28327987 A JP28327987 A JP 28327987A JP 2635058 B2 JP2635058 B2 JP 2635058B2
Authority
JP
Japan
Prior art keywords
address
segment
compartment
conversion
size
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
Application number
JP62283279A
Other languages
English (en)
Other versions
JPH01125640A (ja
Inventor
泰弘 稲上
由子 玉置
重夫 長島
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.)
Hitachi Ltd
Original Assignee
Hitachi Ltd
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 Hitachi Ltd filed Critical Hitachi Ltd
Priority to JP62283279A priority Critical patent/JP2635058B2/ja
Priority to US07/269,058 priority patent/US4992936A/en
Publication of JPH01125640A publication Critical patent/JPH01125640A/ja
Application granted granted Critical
Publication of JP2635058B2 publication Critical patent/JP2635058B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related 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/1009Address translation using page tables, e.g. page table structures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/65Details of virtual memory and virtual address translation
    • G06F2212/652Page size control

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)
  • Memory System (AREA)

Description

【発明の詳細な説明】 [産業上の利用分野] 本発明は、ディジタル計算機システムに係り、主記憶
の有効利用をはかるアドレス変換方式に関する。
[従来の技術] 計算機システムにおいては、機能・性能・使い勝手の
よい主記憶システムの実現のために仮想記記憶の手法が
広く取り入れられ、一般化している。仮想記憶において
は、プログラムで指定される主記憶のアドレスは論理ア
ドレスであり、この論理アドレスは計算機システムが用
意するアドレス変換機構によりアドレス変換が行われ
る。アドレス変換された結果は実アドレスとして、実際
に主記憶をアクセスする際に使用される。アドレス変換
の方式は、セグメンテーションやページングなど様々で
あり、計算機システムごとにそれぞれのシステムに適し
た形で実現されている。
仮想記憶方式の概念や具体例は種々の教科書や文献に
示されている。例えば、岩波書店発行岩波講座情報科学
−15「計算機アーキテクチャ」の122頁から140頁におい
て論じられている。
仮想記憶のアドレス変換の中には、日本出願特許特開
昭62-73347にあるような、PSWにアドレス変換サイズを
示すビットがあって、プログラム対応にアドレス変換サ
イズが変更できるようにしたものもある。
[発明が解決しようとする問題点] 従来の計算機システムのアドレス変換では、アドレス
変換のサイズ(セグメントサイズやページサイズなどと
呼換されることが多く、その大きさは4キロバイトとか
1メガバイトといったものが採用されている)がそのシ
ステムで一定であった。また、仮に複数のサイズを選択
できても、それはプログラム単位で固定的である。
昨今の半導体技術の進歩などから計算機システムに多
くの機能を持たせることができるようになり、科学技術
計算指向のスーパーコンピュータなど特定の応用分野を
指向した計算機システムが開発されている。このような
特定応用分野指向の計算機システムにおいても、ユーザ
にとって使い易いシステム使用環境を提供することが重
要であり、TSSやその他汎用計算機システムで実現され
ているようなシステム制御機能が要求される。
汎用的な、しかも特定応用分野で威力を発揮する計算
機システムにおいては、システム制御に係わるタスクを
特定応用分野の処理のタスクとが同居することになる
が、それぞれのタスクの処理に最適の制御を行うために
要求される機能が異なる場合が多い。
このような計算機システムの主記憶制御方式について
考えてみると、例えば科学技術計算指向の計算機システ
ムの場合には、システム制御に係わるタスクにおいては
比較的小規模容量の記憶単位でアドレス変換を行い、大
規模行列データを扱うことが多い技術計算では比較的大
規模容量の記憶単位でアドレス変換を行った方が、主記
憶の有効活用が図られるだけでなく、アドレス変換に必
要な変換テーブル量を削減できる(変換テーブル量はア
ドレス変換サイズに逆比例するため)など記憶制御の簡
素化にもつながる。しかしながら、従来のようにアドレ
ス変換サイズが1つのプログラム内で動的に変更できな
い方式においては上述のようなきめ細かな主記憶管理が
実現できないという問題があった。
本発明の目的は、性質を異にするいくつかの要求を処
理する計算機システムなどにおいて、それぞれの処理要
求に適したアドレス変換サイズを動的に変更できる手段
を設けることによって、効率のよい主記憶管理を可能と
するところにある。さらに、1個のプログラムやタスク
の中に性質の異なるモジュールが存在するときには、そ
れらのモジュールごとにアドレス変換サイズを対応させ
る、言いかえれば、1個のプログラムやタスクの中で論
理アドレス対応にアドレス変換サイズが変更できるよう
にするところにある。
[問題点を解決するための手段] 上記の目的は、複数のページからなるセグメントと、
複数の前記セグメントからなるコンパートメントと、複
数の前記コンパートメントからなる仮想記憶空間を実記
憶装置上に構成し、前記仮想記憶空間に対応するコンパ
ートメントテーブルと、前記コンパートメントに対応す
るセグメントテーブルと、前記セグメントに対応するペ
ージテーブルとを用いて、仮想アドレスから実アドレス
へのアドレス変換を行う仮想計算機システムにおいて、
前記仮想アドレスが属するコンパートメントに対するア
ドレス変換単位がコンパートメント単位かコンパートメ
ント単位以外かを選択し、選択結果がコンパートメント
単位の場合、前記コンパートメントテーブルの前記コン
パートメントに対応するエントリに指定されたアドレス
と前記仮想アドレスの前記コンパートメント内の変位か
ら実アドレスを生成し、選択結果がコンパートメント単
位以外の場合、前記コンパートメントに対応する前記セ
グメントテーブルの第1のアドレスを前記コンパートメ
ントテーブルの前記コンパートメントに対応するエント
リから求め、前記仮想アドレスが属するセグメントに対
するアドレス変換単位がセグメント単位かページ単位か
を選択し、選択結果がセグメント単位の場合、前記第1
のアドレスが指示するセグメントテーブルの前記セグメ
ントに対応するエントリに指定されたアドレスと前記仮
想アドレスの前記セグメント内の変位から実アドレスを
生成し、選択結果がページ単位の場合、前記セグメント
に対応する前記ページテーブルのアドレスを前記第1の
アドレスが指示するセグメントテーブルの前記セグメン
トに対応するエントリから求め、前記ページテーブルの
前記仮想アドレスが属するページに対応するエントリに
指定されたアドレスと前記仮想アドレスの前記ページ内
の変位から実アドレスを生成することにより達成され
る。
[作用] 上記の手段が以下のように機能することにより前述の
目的が達成される。
アドレス変換テーブルには、主記憶管理を司るオペレ
ーティング・システム等が主記憶の使用状況に従って内
容を設定する。すなわち、論理アドレスと実アドレスの
対応を登録すると共に、仮想記憶空間上に割付けられる
各種タスクの性質に従って決定されるアドレス変換サイ
ズに対応して有効アドレス変換サイズ表示手段を設定す
る。これらの処理はタスクの生成、消滅に呼応して動的
に行なわれていく。
プログラムで指定される論理アドレスから各アドレス
変換サイズに応じて決まるビットを抽出して、これらを
各アドレス変換サイズに対応するアドレス変換テーブル
のエントリ指定情報として各アドレス変換テーブルのエ
ントリを同定する。次に、各アドレス変換サイズ毎に同
定されたエントリの内容を調べ、その中から有効アドレ
ス変換サイズ表示手段が有効を表示しているエントリを
選択し、そのエントリに登録されている情報により論理
アドレスから実アドレスへのアドレス変換を行う。
以上により、個々の処理要求(タクス)に適したアド
レス変換サイズを動的に管理し、アドレス変換処理を行
うことができる。
[実施例] 以下、実施例により本発明の詳細を説明する。
最初に、本実施例における主記憶アドレスの指定方式
について説明する。第2図は本実施例における(論理)
アドレスのフォーマットを示している。アドレスは32ビ
ット長で指定される。バイト単位のアドレス付けとする
と、4ギガバイト(1ギガバイトは232バイト、以下GB
と略す)のアドレス空間を構成する。32ビット長のアド
レスはアドレス変換に関連して4つの部分から構成され
る。第2図に示すように、32ビット長のアドレスのビッ
ト0〜7の8ビットがコンパートメントインデクス(CX
と略す)、ビット8〜11の4ビットがセグメントインデ
クス(SXと略す)、ビット12〜19の8ビットがページイ
ンデクス(PXと略す)、ビット20〜31の12ビットがバイ
トインデクス(BXと略す)を示す。すなわち、コンパー
トメントは16メガバイト(1メガバイトは224バイト、
以下MBと略す)単位の区画、セグメントは1MB(=220
イト)の区画、ページは4キロバイト(1キロバイトは
210バイト、以下KBと略す)の区画である。本実施例の
主記憶では、4GBの総アドレス空間は、256個のコンパー
トメント、1個のコンパートメントの中は8個のセグメ
ント、1個のセグメントは256個のページという形で構
成されることになる。
本実施例の主記憶においては、アドレス変換サイズと
して上記のコンパートメント、セグメント、ページのい
ずれかを論理アドレスに対応して選択することができ
る。
次に第1図により本実施例におけるアドレス変換テー
ブルの構成およびアドレス変換方式を説明する。
本実施例においては、アドレス変換テーブルはアドレ
ス変換サイズ対応に設ける。すなわち、コンパートメン
トに対応するコンパートメント変換テーブル、セグメン
トに対応するセグメント変換テーブル、ページに対応す
るページ変換テーブルがある。これら変換テーブルの各
エントリには、論理アドレスに対応する実アドレスある
いは他アドレス変換テーブルの所在を示すアドレスおよ
びそのエントリの有効性等を示す情報が格納される。変
換テーブルエントリの実施例を第3図に示す。実施例に
おいては変換テーブルエントリは32ビット長であり、ビ
ット0〜29の30ビットが実アドレスまたは他アドレス変
換テーブル先頭アドレスを格納するフィールド、ビット
30がアドレス変換サイズ有効ビットT、ビット31がイン
バリッドビットIである。次にこれら情報のもつ意味に
ついて説明する。アドレス変換サイズ有効ビットTはア
ドレス変換サイズを制御するのに用いられるビットであ
る。本ビットが1のときは、そのエントリに対応するア
ドレス変換サイズ、例えばセグメント変換テーブルのエ
ントリであればセグメント、がアドレス変換サイズにあ
ることを示す。このときには、そのエントリのビット0
〜19の20ビットを論理アドレスのビット0〜19(CX部,S
X部,PX部)に対応する実アドレスのビット0〜19とし
て、これに論理アドレスのビット20〜31(BX部)を連結
した32ビットを実アドレスとする。アドレス変換サイズ
有効ビットTが0のときは、そのエントリに対応するア
ドレス変換サイズ以外のアドレス変換サイズによりアド
レス変換が行われることを示す。このときには、エント
リのビット0〜19の情報は論理アドレスに対する実アド
レスの情報ではなく、そのエントリに対応するアドレス
変換サイズよりも下位のアドレス変換サイズ(コンパー
トメントならセグメント、セグメントならページ)に対
応するアドレス変換テーブルの先頭アドレスを保持す
る。すなわち、そのエントリに対応するアドレス変換サ
イズ以外のアドレス変換サイズでアドレス変換が行われ
ることを示し、かつアドレス変換情報を別のアドレス変
換テーブルに求めるきっかけとして、下位のアドレス変
換サイズに対応するアドレス変換テーブルの所在を示す
情報をもつ。
インバリッドビットIは、値が0のときそのエントリ
中の情報の意味があることを示し、値が1のときはエン
トリ中の情報が無効であることを示す。このビットは、
エントリに対応する仮想記憶空間の区画が実記憶にない
といったことを簡単に表現する手段を提供する。
なお、本実施例では示していないが、各エントリに
は、例えば記憶保護に関するビットなどその他のフィー
ルドを設けてもよい。
次に本実施例におけるアドレス変換の過程に第1図を
用いて説明する。第1図において、1は論理アドレス、
2ないし4は実アドレスを示す。ここで、2はアドレス
変換サイズとしてコンパートメント、3はアドレス変換
サイズとしてセグメント、4はアドレス変換サイズとし
てページがそれぞれ選択された場合の実アドレスであ
る。5ないし7はアドレス変換の過程で用いられるアド
レス変換テーブルであり、各テーブルのエントリの書式
は第3図に示した通りである。アドレス変換テーブルは
アドレス変換サイズ対応に用意されており、5はコンパ
ートメント単位の変換に係わるコンパートメント変換テ
ーブル、6はセグメント単位の変換に係わるセグメント
変換テーブル、7はページ単位の変換に係わるページ変
換テーブルである。これらのアドレス変換テーブルは通
常は主記憶に置かれるが、レジスタ等特定の記憶領域に
置いても良い。8はコンパートメント変換テーブルの所
在(テーブルが主記憶に置かれるなら主記憶アドレス)
を保持するレジスタ(CTOR,Compartment Table Origin
Register)であり、従来の計算機システムでも実現され
ているような多重化想記憶を実現するときに空間切替を
行う手段を提供するものである。11〜14は加算処理を示
す。
さて、以下具体的によりアドレス変換の過程を詳細に
説明するが、次のような前提条件が設定されているもの
とする。以下のような条件設定は通常オペレーティング
システム等のシステムソフトウェアが行うが、その詳し
い処理は後述する。
(1)CX部がa,SX部がP,PX部がx,BX部がnの論理アドレ
スは、アドレス変換サイズを‘ページ’としてアドレス
変換が行われる。またこの論理アドレスに係わるコンパ
ートメント変換テーブル、セグメント変換テーブル、ペ
ージ変換テーブルのエントリはそれぞれa′,p′,x′で
ある。
(2)CX部がb,SXがq,PX部がy,BX部がmの論理アドレス
は、アドレス変換サイズをセグメントとしてアドレス変
換が行われる。またこの論理アドレスに係わるコンパー
トメント変換テーブル,セグメント変換テーブル,ペー
ジ変換テーブルのエントリはそれぞれb′,q′,y′であ
る。
(3)CX部がC,SX部がr,PX部がZ,BX部がlの論理アドレ
スは、アドレス変換サイズをコンパートメントとしてア
ドレス変換が行われる。またこの論理アドレスに係わる
コンパートメント変換テーブル、セグメント変換テーブ
ル、ページ変換テーブルのエントリはそれぞれC′,
r′,z′,l′である。
(4)上記(1)〜(3)の条件に合致するよう、コン
パートメント変換テーブル,セグメント変換テーブル,
ページ変換テーブルの内容が設定されている。
さて、CX部がc,SX部がr,PX部がz,BX部がlの論理アドレ
スが指定されたときに実アドレスが求まる過程を説明す
る。8のCTORとCX部の値cとを加算して、指定された論
理アドレスに対応するコンパートメント変換テーブルの
エントリc′を特定し、その内容を調べる。このエント
リのインバリッドビットIの値は0であり、アドレス変
換サイズ有効ビットTの値が1であるので、指定された
論理アドレスに対してはアドレス変換サイズとしてコン
パートメントが選択される。従って、このエントリのビ
ット0〜19の20ビットで論理アドレスのビット0〜19
(CX部,SX部,PX部)が置きかえられ、実アドレス2を得
る。
CX部がb,SX部がq,PX部がy,BX部がmの論理アドレスが
指定されたときに実アドレスが求まる過程を説明する。
まずCTORとCX部の値bとを加算して指定された論理アド
レスに対応するコンパートメント変換テーブルのエント
リbを特定し、その内容を調べる。このエントリのイン
バリッドビットの値は0であり、またアドレス変換サイ
ズ有効ビットTの値が0であるから、アドレス変換サイ
ズ学コンパートメントでないことが認識される。従っ
て、次にセグメント変換テーブルが参照される。参照す
べきセグメント変換テーブルの先頭アドレスは、今参照
したコンパートメント変換テーブルのエントリb′のビ
ット0〜29に格納されており、この値にSX部の値qを加
算して、指定された論理アドレスに対応するセグメント
変換テーブルのエントリq′を特定し、その内容を調べ
る。エントリq′のインバリッドビットの値は0であ
り、アドレス変換サイズ有効ビットの値が0であるの
で、指定された論理アドレスに対してはアドレス変換サ
イズとしてセグメントが選択される。従って、エントリ
q′のビット0〜19の20ビットで論理アドレスのビット
0〜19(CX部,SX部,PX部)が置きかえられ、実アドレス
3を得る。
CX部がa,SX部がp,PX部がx,BX部がnの論理アドレスが
指定されたときに実アドレスが求まる過程を説明する。
先の例と同様に、CTORとCX部の値aとから、指定された
論理アドレスに対応するコンパートメント変換テーブル
のエントリa′を特定し、その内容を調べるが、インバ
リッドビットの値が0,アドレス変換サイズ有効ビットの
値が0であるので、アドレス変換サイズがコンパートメ
ントでないことを認識し、次にセグメント変換テーブル
を参照する。参照すべきセグメント変換テーブルのエン
トリは、コンパートメント変換テーブルのエントリa′
のビット0〜19の値と論理アドレスSX部の値pとから得
られ、エントリp′を特定する。エントリp′のインバ
リッドの値は0,またはアドレス変換サイズ有効ビットの
値も0であるので、セグメントがアドレス変換サイズで
ないことが認識される。従って、引き続きページ変換テ
ーブルを参照する。参照すべきページ変換テーブルの先
頭アドレスは、セグメント変換テーブルのエントリp′
のビット0〜29に格納されている。この値と論理アドレ
スのPX部の値xとを加算して、ページ変換テーブルのエ
ントリx′を特定する。エントリx′のインバリッドビ
ットの値は0であり、アドレス変換サイズ有効ビットの
値が1であるので、ページがアドレス変換サイズである
ことが認識され、アドレス変換が行われる。すなわち、
エントリx′のビット0〜19の20ビットで論理アドレス
のビット0〜19(CX部,SX部,PX部)を置きかえ、実アド
レス4を得る。
以上、アドレス変換の過程を説明したが、1個の論理
アドレスに係わる各種アドレス変換テーブルのエントリ
のアドレス変換サイズ有効ビットの値が、例えば全て0
であるとかあるいは2つ以上のエントリで1つであると
いった矛盾が登録あるいは発見された場合には、アドレ
ス変換例外などの例外処理により割込みを発生させるな
どの手段により保全性を向上させてもよい。
以上アドレス変換の過程の詳細を説明したが、次に第
1図に示した各種のアドレス変換テーブルによりアドレ
ス変換サイズを動的に変更して主記憶を管理する過程を
具体例により説明する。
第4図は、ある時点での仮想記憶空間のマップを示し
ている。この場合、論理アドレスの16MBから48MBまでの
領域(CX部が1又は2)は大規模計算プログラムが配置
されるため、コンパートメント単位のアドレス変換が行
われるようにする。論理アドレスの96MB〜112MBの領域
(CX部が6)は中規模のプログラムが配置されるためセ
グメント単位のアドレス変換が行われるようにする。論
理アドレスの112MB〜128MBおよび256MB〜272MBの領域
(CX部が7または16)は、システム制御に係わるプログ
ラム群が配置されるが個々のプログラムの性質に従って
セグメント又はページのいずれかのサイズでアドレス変
換されるようにする。例えば112MB〜128MBの領域では、
最初の1MB(SX部が0)がセグメント単位、残りの15MB
(SX部が1〜15)はページ単位のアドレス変換、256MB
〜272MBの領域では最初の1MB(SX部が0)がページ単
位、残りの15MB(SX部が1〜15)はセグメント単位のア
ドレス変換が行われるようにする。
このとき、オペレーティング・システム等のシステム
ソフトウェアは各アドレス変換テーブルを次のように準
備する。
(1)コンパートメント変換テーブル 1番目,2番目のエンリトはアドレス変換サイズ有効ビッ
トTの値を1にするとともに、対応するコンパートメン
トが配置されている実記憶上のアドレスをそれぞれビッ
ト0〜19に設定する。
6番目,7番目,16番目のエントリはアドレス変換サイズ
有効ビットの値を0にし、かつ対応するセグメント変換
テーブル(これらをそれぞれST-6,ST-7,ST-16と略す)
の先頭アドレスをそれぞれビット0〜29に設定する。
(2)セグメント変換テーブル ST-6の各エントリには、アドレス変換サイズ有効ビット
値を1とし、かつ対応するセグメントが配置される実記
憶上のアドレスをビット0〜19に設定する。
ST-7については、0番目のエントリはアドレス変換サイ
ズ有効ビットの値を1にし、かつビット0〜19に、対応
するセグメントが配置される実記憶上のアドレスが設定
される。1番目から15番目までの各エントリについては
アドレス変換サイズ有効ビットの値を0にし、ビット0
〜29に対応するページ変換テーブルの先頭アドレスをそ
れぞれ登録する。
ST-16についても同様に、0番目のエントリはアドレス
変換サイズ有効ビットを0とし、対応するページ変換テ
ーブルの先頭のアドレスを登録する。他のエントリにつ
いては、アドレス変換サイズ有効ビットを1とし、対応
するセグメントが配置される実記憶上のアドレスを設定
する。
(3)ページ変換テーブル ページ単位でアドレス変換が行われる部分について作
成する。アドレス変換サイズ有効ビットを1にし、対応
するページが配置される実記憶上のアドレスを設定す
る。
以上のような各種アドレス変換テーブルを設定すること
により、第4図のマップに示したアドレス変換サイズに
従ってアドレス変換を行うことができる。
なお、アドレス変換サイズがコンパートメントである
部分に係わるセグメント変換テーブルおよびページ変換
テーブル、アドレス変換サイズがセグメントである部分
に係わるページ変換テーブルは作成する必要がない。
さて、第4図に示したマップに従って処理が進み、論
理アドレスの112MB〜128MBの領域にあったプログラムが
不要となり、この領域に新たに大規模計算プログラムを
置き、かつアドレス変換サイズをコンパートメントに変
更するとき、次のような処理をオペレーティングシステ
ムが行えばよい。すなわち、コンパートメント変換テー
ブルの7番目のエントリのアドレス変換サイズ有効ビッ
トTの値を0から1に変更し、かつそのビット0〜19
に、対応するコンパートメントが配置される実記憶上の
アドレスを設定する。また、この領域に関して作成され
ていたセグメント変換テーブルおよびページ変換テーブ
ルを削除する。
また、論理アドレスの256MB〜272MBの領域に関し、15
番目のセグメント(SX部が15)のアドレス変換サイズを
セグメントからページに変更することになった場合は、
ST-16(前述、論理アドレスの256MB〜272MBの領域に係
わるセグメント変換テーブル)のエントリ番号15のアド
レス変換サイズ有効ビットの値を1から0に変更し、か
つ対応するページ変換テーブルの先頭アドレスを設定す
るとともに、ページ変換テーブルを作成すればよい。
このように、各種アドレス変換テーブルの各エントリ
のアドレス変換サイズ有効ビットを適宜操作し、かつ各
アドレス変換サイズに対応した必要最小限のアドレス変
換テーブルに設定することにより、仮想記憶上の各領域
に対して異なったアドレス変換サイズを動的に対応付け
ることができる。次に、第5図により本発明のアドレス
変換を実現するアドレス変換回路の一実施例を説明す
る。
第5図に於いて、500命令解読ユニット、100はアドレ
ス変換部である。命令解読ユニット500は、命令を読み
出して解読し、プロセッサ内の各種制御部に必要な信号
を送出する回路である。本ユニットは本発明の特長的な
部分ではないのでその詳細な説明は省略する。
次に、アドレス変換部100の動作の詳細を説明する。
命令解読ユニット500が一つの命令を解読し、その命
令で使用するオペランドの論理アドレスの計算を完了す
ると、アドレス変換部100に対し信号線301を介してアド
レス変換開始の指示が送られてくる。それと同時に信号
線302を介して命令解読ユニット500で計算された論理ア
ドレスが送られてくる。信号線302により送られてきた
論理アドレスは、信号線301により送られてくるアドレ
ス変換開始の指示信号をセット信号として、レジスタ11
0にセットされる。
第5図において、120はレジスタであり、コンパート
メント変換テーブルの先頭アドレスを保持するものであ
る(CTOR)。CTORの内容の読み出しあるいは書き込みは
命令によって行なわれ、情報のやりとりは信号線303を
介して行なわれる。
第5図において、130はレジスタであり、どのアドレ
ス変換サイズでアドレス変換を行なうかを表示するレジ
スタである。レジスタ130が保持する状態としては、 (1)アドレス変換サイズがコンパートメントである、
(2)アドレス変換サイズがセグメントである、(3)
アドレス変換サイズがページである、のいずれかであ
る。第5図において、140はアドレス変換サイズ管理部
であり、レジスタ130の状態の設定、変更を司る機能を
持つ。命令解読ユニット500から信号線301を介してアド
レス変換開始の指示が来ると、アドレス変換サイズ管理
部140は、レジスタ130の状態を、“アドレス変換サイズ
がコンパートメントである”に初期設定する。レジスタ
130の状態は、信号線201に反映される。
第5図において、202ないし206はそれぞれ信号線であ
る。信号線202にはレジスタ120(CTOR)の内容が反映さ
れる。信号線203,204,205,206にはそれぞれ、レジスタ1
10に保持されている論理アドレスのうち、コンパートメ
ントインデクス部(CX),セグメントインデクス部(S
X),ページインデクス部(PX),バイトインデクス部
(BX)が反映される。
第5図において、141および142はそれぞれ選択回路で
あって、選択回路141は信号線211と202のいずれかの値
を選択して、それを信号線207に反映させる。選択回路1
42は、信号線203,204,205の何れかの値を選択して、そ
れを信号線208に反映させる。選択回路141及び142の選
択制御信号は、信号線201にその状態が反映されている
レジスタ130の内容である。レジスタ130の状態が“アド
レス変換サイズがコンパートメントである”のときに
は、選択回路141においては信号線202が選択され、選択
回路142においては、信号線203(CX)が選択される。レ
ジスタ130の状態が“アドレス変換サイズがセグメント
である”のときには、選択回路141においては信号線211
が選択され、選択回路142においては、信号線204(SX)
が選択される。レジスタ130の状態が“アドレス変換サ
イズがページである”のときには、選択回路141におい
ては信号線211が選択され、選択回路142においては、信
号線205(PX)が選択される。
第5図において、150は演算回路であり、信号線207に
反映されている値と、信号線208に反映されている値と
から、アドレス変換情報を保持するアドレス変換テーブ
ルのエントリのアドレスを計算する回路である。すなわ
ち、信号線208に反映されている値を4倍し(アドレス
変換テーブルの1エントリのサイズは4バイトであるか
ら、エントリの番号を4倍してエントリの相対アドレス
を得る)、それに信号線207に反映されている値を加算
する。信号線207にはアドレス変換サイズに対応するア
ドレス変換テーブルの先頭アドレスが反映されている
(詳細は後述)。
第5図において、151はレジスタであり、演算回路150
の結果を保持するレジスタであり。レジスタ151の内容
は信号線209に反映され、主記憶インタフェース部400に
送られる。主記憶インタフェース部400は信号線209を介
して送られてくる情報、すなわち参照するアドレス変換
テーブルのアドレス情報を受け取り、信号線410により
主記憶装置(図面では省略)に対して参照要求を出す。
この参照要求に対し、主記憶装置は指定されたアドレス
にある情報を信号線420により主記憶インタフェース部4
00に返送してくる。これら一連の処理は本発明の特長的
な処理ではないので詳細な説明は省略する。信号線420
により送られてきた情報は、アドレス変換に用いるアド
レス変換テーブルのエントリの内容であり、主記憶イン
タフェース部400はこの情報を信号線210に乗せ、レジス
タ152に送る。
第5図において、152はレジスタであり、アドレス変
換情報として読み出したアドレス変換テーブルのエント
リの内容を保持するものである。レジスタ152に保持さ
れる情報の書式は第3図に示した書式と同一である。従
って、レジスタ152のビット30はアドレス変換サイズ有
効ビット(Tビット)であり、またビット31はエントリ
のインバリッド(Iビット)である。残りの部分は実ア
ドレスあるいは下位アドレス変換テーブルの先頭アドレ
ス(ADDR部)を保持する。ADDR部の内容は信号線211,T
ビットの内容は信号線212,Iビットの内容は信号線213に
反映される。
第5図において、160は例外処理部であり、アドレス
変換処理の過程で発生する例外を処理し、例外が発生し
た場合にはそれを命令解読ユニット500に通知する機能
をもつ。
レジスタ152に設定された情報のIビットが1である
場合には、読み出したアドレス変換テーブルエントリが
無効であるから、アドレス変換例外を発生させる必要が
ある。例外処理部160は信号線213によりIビットの値を
受け取り、値が1である場合にはアドレス変換例外を検
出して、その旨を信号線304により命令解読ユニット500
に通知する。
レジスタ152に設定された情報はTビットは、現在レ
ジスタ130に表示されているアドレス変換サイズが有効
であるかどうかを示すビットである。Tビットの値が1
である時にはレジスタ152のADDR部の内容により実アド
レスを求める。Tビットの値が0である時には現在レジ
スタ130に表示されているアドレス変換サイズよりも下
位のアドレス変換サイズでのアドレス変換処理に移る。
第5図において、153はレジスタであり、アドレス変
換の結果得られた実アドレスを保持するのに使用され
る。信号線212に反映されるTビットの値はレジスタ153
のセット信号として使われる。信号線212の値が1の時
には信号線211に反映されているレジスタ152のADDR部の
情報(実アドレス情報)、および信号線206に反映され
ているレジスタ110のBX部の情報が連結して設定され
る。このようにしてレジスタ153に設定された情報は、
アドレス変換の結果である実アドレスである。レジスタ
153に設定された実アドレスは信号線154を経由して主記
憶インタフェース部400に送られ、主記憶データの参照
に移る。Tビットの値が1であるときにはこの一連の処
理が行なわれる。
Tビットの値が0であるときには、それが信号線212
に反映され、アドレス変換管理部140に伝えられる。ア
ドレス変換管理部140では信号線212から送られてくるT
ビットの値と、信号線201より送られてくるレジスタ130
の内容、すなわち現在有効なアドレス変換サイズに関す
る情報とから次に選択すべきアドレス変換サイズを次の
ようにして決定し、必要な情報を設定する。すなわち、
信号線212からTビットの値として0が送られてくれ
ば、信号線201の値により次のような処理を行う。
(1)信号線201が「アドレス変換サイズがコンパート
メントである」を示していれば、次に選択すべきアドレ
ス変換サイズがセグメントであるから、レジスタ130に
「アドレス変換サイズがセグメントである」を設定す
る。
(2)信号線201が「アドレス変換サイズがセグメント
である」を示してあれば、次に選択すべきアドレス変換
サイズがページであるから、レジスタ130に「アドレス
変換サイズがページである」を設定する。
(3)信号線201が「アドレス変換サイズがページであ
る」を示していれば、コンパートメント,セグメント,
ページのいずれの変換サイズも選択されなかったことに
なるから、例外的な条件が発生したと判断し、その旨を
信号線214により例外処理部160に通知する。
例外処理部160は信号線304によりこれを命令解読ユニッ
ト500に伝える。
(1),(2)の場合はレジスタ130に新たなアドレス
変換サイズが設定され、これまでに述べたようなアドレ
ス変換の処理が続けられる。(3)の場合は、有効なア
ドレス変換サイズ指定されないままコンパートメント変
換テーブル、セグメント変換テーブル,ページ変換テー
ブルの全てを参照したことを意味し、例外を検出して命
令解読ユニット500に通知する。
[発明の効果] 以上示したように、本発明によれば、性質と異にする
いくつかの要求を処理する計算機などにおいて、主記憶
上に種々のプログラム(タスク)を配置するとき、各プ
ログラムの特性に従って適切なアドレス変換サイズを選
択でき、かつプログラムの処理状況に従って動的にアド
レス変換サイズを変更できるので、効率良い主記憶管理
が実現できると共に、アドレス変換に必要なアドレス変
換テーブルの量を必然最小限にとどめることができると
いう効果がある。
【図面の簡単な説明】
第1図は本発明の一実施例のアドレス変換方式を説明す
る図、第2図は本発明の実施例の論理アドレス指定書
式、第3図は本発明の一実施例のアドレス変換テーブル
のエントリの書式、第4図は本発明の一実施例における
主記憶管理を説明する図、第5図は本発明のアドレス変
換方式を実現するアドレス変換回路の一実施例を示す図
である。 5……コンパートメント変換テーブル、6……セグメン
ト変換テーブル、7……ページ変換テーブル、7……ペ
ージ変換テーブル、100……アドレス変換部。
───────────────────────────────────────────────────── フロントページの続き (56)参考文献 特開 昭60−117350(JP,A) 特開 昭62−237547(JP,A) 特開 昭64−17137(JP,A) 特公 平8−12640(JP,B2)

Claims (1)

    (57)【特許請求の範囲】
  1. 【請求項1】複数のページからなるセグメントと、複数
    の前記セグメントからなるコンパートメントと、複数の
    前記コンパートメントからなる仮想記憶空間を実記憶装
    置上に構成し、前記仮想記憶空間に対応するコンパート
    メントテーブルと、前記コンパートメントに対応するセ
    グメントテーブルと、前記セグメントに対応するページ
    テーブルとを用いて、仮想アドレスから実アドレスへの
    アドレス変換を行う仮想計算機システムにおいて、 前記仮想アドレスが属するコンパートメントに対するア
    ドレス変換単位がコンパートメント単位かコンパートメ
    ント単位以外かを選択し、 選択結果がコンパートメント単位の場合、前記コンパー
    トメントテーブルの前記コンパートメントに対応するエ
    ントリに指定されたアドレスと前記仮想アドレスの前記
    コンパートメント内の変位から実アドレスを生成し、 選択結果がコンパートメント単位以外の場合、前記コン
    パートメントに対応する前記セグメントテーブルの第1
    のアドレスを前記コンパートメントテーブルの前記コン
    パートメントに対応するエントリから求め、 前記仮想アドレスが属するセグメントに対するアドレス
    変換単位がセグメント単位かページ単位かを選択し、 選択結果がセグメント単位の場合、前記第1のアドレス
    が指示するセグメントテーブルの前記セグメントに対応
    するエントリに指定されたアドレスと前記仮想アドレス
    の前記セグメント内の変位から実アドレスを生成し、 選択結果がページ単位の場合、前記セグメントに対応す
    る前記ページテーブルのアドレスを前記第1のアドレス
    が指示するセグメントテーブルの前記セグメントに対応
    するエントリから求め、前記ページテーブルの前記仮想
    アドレスが属するページに対応するエントリに指定され
    たアドレスと前記仮想アドレスの前記ページ内の変位か
    ら実アドレスを生成することを特徴とするアドレス変換
    方法。
JP62283279A 1987-11-11 1987-11-11 アドレス変換方式 Expired - Fee Related JP2635058B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP62283279A JP2635058B2 (ja) 1987-11-11 1987-11-11 アドレス変換方式
US07/269,058 US4992936A (en) 1987-11-11 1988-11-09 Address translation method and apparatus therefor

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP62283279A JP2635058B2 (ja) 1987-11-11 1987-11-11 アドレス変換方式

Publications (2)

Publication Number Publication Date
JPH01125640A JPH01125640A (ja) 1989-05-18
JP2635058B2 true JP2635058B2 (ja) 1997-07-30

Family

ID=17663394

Family Applications (1)

Application Number Title Priority Date Filing Date
JP62283279A Expired - Fee Related JP2635058B2 (ja) 1987-11-11 1987-11-11 アドレス変換方式

Country Status (2)

Country Link
US (1) US4992936A (ja)
JP (1) JP2635058B2 (ja)

Families Citing this family (51)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0290349A (ja) * 1988-09-28 1990-03-29 Hitachi Ltd 仮想記憶システムのアドレス空間制御装置
US5226132A (en) * 1988-09-30 1993-07-06 Hitachi, Ltd. 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
JPH02165241A (ja) * 1988-12-19 1990-06-26 Toshiba Corp ファイルアクセス方式
JP2765954B2 (ja) * 1989-06-05 1998-06-18 株式会社日立製作所 スキャンアドレス変換機構
JP2858795B2 (ja) * 1989-07-14 1999-02-17 株式会社日立製作所 実記憶割り当て方法
US5375213A (en) * 1989-08-29 1994-12-20 Hitachi, Ltd. Address translation device and method for managing address information using the device
US5197130A (en) * 1989-12-29 1993-03-23 Supercomputer Systems Limited Partnership Cluster architecture for a highly parallel scalar/vector multiprocessor system
US5412787A (en) * 1990-11-21 1995-05-02 Hewlett-Packard Company Two-level TLB having the second level TLB implemented in cache tag RAMs
EP0506236A1 (en) * 1991-03-13 1992-09-30 International Business Machines Corporation Address translation mechanism
EP0508577A1 (en) * 1991-03-13 1992-10-14 International Business Machines Corporation Address translation mechanism
US5305454A (en) * 1991-08-12 1994-04-19 International Business Machines Corporation Notification of event handlers in broadcast or propagation mode by event management services in a computer system
US5625821A (en) * 1991-08-12 1997-04-29 International Business Machines Corporation Asynchronous or synchronous operation of event signaller by event management services in a computer system
US5237684A (en) * 1991-08-12 1993-08-17 International Business Machines Corporation Customized and versatile event monitor within event management services of a computer system
US5355484A (en) * 1991-08-12 1994-10-11 International Business Machines Corporation Dynamically established event monitors in event management services of a computer system
US5465337A (en) * 1992-08-13 1995-11-07 Sun Microsystems, Inc. Method and apparatus for a memory management unit supporting multiple page sizes
US6735685B1 (en) * 1992-09-29 2004-05-11 Seiko Epson Corporation System and method for handling load and/or store operations in a superscalar microprocessor
FR2787216B1 (fr) * 1998-12-11 2001-07-27 Bull Cp8 Procede de stockage et d'exploitation d'unites d'information dans un module de securite, et module de securite associe
US6836836B2 (en) 2001-01-19 2004-12-28 Sony Corporation Memory protection control device and method
US7296139B1 (en) 2004-01-30 2007-11-13 Nvidia Corporation In-memory table structure for virtual address translation system with translation units of variable range size
US7334108B1 (en) 2004-01-30 2008-02-19 Nvidia Corporation Multi-client virtual address translation system with translation units of variable-range size
US7278008B1 (en) 2004-01-30 2007-10-02 Nvidia Corporation Virtual address translation system with caching of variable-range translation clusters
US8843727B2 (en) * 2004-09-30 2014-09-23 Intel Corporation Performance enhancement of address translation using translation tables covering large address spaces
US20060253682A1 (en) * 2005-05-05 2006-11-09 International Business Machines Corporation Managing computer memory in a computing environment with dynamic logical partitioning
JP4972928B2 (ja) * 2005-12-21 2012-07-11 富士通株式会社 画像メモリ管理装置、画像メモリ管理方法、およびそのプログラム
US7827381B2 (en) * 2006-06-05 2010-11-02 Oracle America, Inc. Hybrid techniques for memory virtualization in a computer system
US20080028181A1 (en) * 2006-07-31 2008-01-31 Nvidia Corporation Dedicated mechanism for page mapping in a gpu
US8151083B2 (en) 2008-01-11 2012-04-03 International Business Machines Corporation Dynamic address translation with frame management
US8019964B2 (en) * 2008-01-11 2011-09-13 International Buisness Machines Corporation Dynamic address translation with DAT protection
US8037278B2 (en) * 2008-01-11 2011-10-11 International Business Machines Corporation Dynamic address translation with format control
US8041922B2 (en) * 2008-01-11 2011-10-18 International Business Machines Corporation Enhanced dynamic address translation with load real address function
US8417916B2 (en) * 2008-01-11 2013-04-09 International Business Machines Corporation Perform frame management function instruction for setting storage keys and clearing blocks of main storage
US8041923B2 (en) * 2008-01-11 2011-10-18 International Business Machines Corporation Load page table entry address instruction execution based on an address translation format control field
US8335906B2 (en) * 2008-01-11 2012-12-18 International Business Machines Corporation Perform frame management function instruction for clearing blocks of main storage
US8677098B2 (en) * 2008-01-11 2014-03-18 International Business Machines Corporation Dynamic address translation with fetch protection
US8117417B2 (en) 2008-01-11 2012-02-14 International Business Machines Corporation Dynamic address translation with change record override
US8082405B2 (en) * 2008-01-11 2011-12-20 International Business Machines Corporation Dynamic address translation with fetch protection
US8103851B2 (en) * 2008-01-11 2012-01-24 International Business Machines Corporation Dynamic address translation with translation table entry format control for indentifying format of the translation table entry
US8086811B2 (en) 2008-02-25 2011-12-27 International Business Machines Corporation Optimizations of a perform frame management function issued by pageable guests
US8095773B2 (en) 2008-02-26 2012-01-10 International Business Machines Corporation Dynamic address translation with translation exception qualifier
US8095772B2 (en) * 2009-05-08 2012-01-10 Oracle America, Inc. Large memory pages for shared libraries
US8693133B1 (en) 2010-03-22 2014-04-08 Western Digital Technologies, Inc. Systems and methods for improving sequential data rate performance using sorted data zones for butterfly format
US9330715B1 (en) 2010-03-22 2016-05-03 Western Digital Technologies, Inc. Mapping of shingled magnetic recording media
US8687306B1 (en) 2010-03-22 2014-04-01 Western Digital Technologies, Inc. Systems and methods for improving sequential data rate performance using sorted data zones
US8699185B1 (en) 2012-12-10 2014-04-15 Western Digital Technologies, Inc. Disk drive defining guard bands to support zone sequentiality when butterfly writing shingled data tracks
US8856438B1 (en) * 2011-12-09 2014-10-07 Western Digital Technologies, Inc. Disk drive with reduced-size translation table
US9213493B1 (en) 2011-12-16 2015-12-15 Western Digital Technologies, Inc. Sorted serpentine mapping for storage drives
US9092359B2 (en) 2012-06-14 2015-07-28 International Business Machines Corporation Identification and consolidation of page table entries
US9811472B2 (en) * 2012-06-14 2017-11-07 International Business Machines Corporation Radix table translation of memory
US9753860B2 (en) 2012-06-14 2017-09-05 International Business Machines Corporation Page table entry consolidation
US9495303B2 (en) * 2015-02-03 2016-11-15 Intel Corporation Fine grained address remapping for virtualization
JP7238178B2 (ja) * 2020-02-04 2023-03-13 キオクシア株式会社 メモリ装置及びメモリ装置を制御する方法

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB1443064A (en) * 1973-07-18 1976-07-21 Int Computers Ltd Microprogramme unit for a data processor
US4079453A (en) * 1976-08-20 1978-03-14 Honeywell Information Systems Inc. Method and apparatus to test address formulation in an advanced computer system
US4453212A (en) * 1981-07-13 1984-06-05 Burroughs Corporation Extended address generating apparatus and method
JPS60117350A (ja) * 1983-11-30 1985-06-24 Toshiba Corp メモリマッピング装置
JPS6273347A (ja) * 1985-09-27 1987-04-04 Hitachi Ltd アドレス変換装置
US4727485A (en) * 1986-01-02 1988-02-23 Motorola, Inc. Paged memory management unit which locks translators in translation cache if lock specified in translation table
JPS62237547A (ja) * 1986-04-09 1987-10-17 Hitachi Ltd アドレス変換方式
JPS6417137A (en) * 1987-07-13 1989-01-20 Nippon Telegraph & Telephone Control system for large-capacity page
JP2989477B2 (ja) * 1994-06-27 1999-12-13 旭化成工業株式会社 超高純度アセトニトリルおよび粗アセトニトリルの精製方法

Also Published As

Publication number Publication date
US4992936A (en) 1991-02-12
JPH01125640A (ja) 1989-05-18

Similar Documents

Publication Publication Date Title
JP2635058B2 (ja) アドレス変換方式
JP2833062B2 (ja) キャッシュメモリ制御方法とこのキャッシュメモリ制御方法を用いたプロセッサおよび情報処理装置
US4577274A (en) Demand paging scheme for a multi-ATB shared memory processing system
US4410941A (en) Computer having an indexed local ram to store previously translated virtual addresses
US5182805A (en) Method and system for determining copy-on-write condition
EP0506236A1 (en) Address translation mechanism
EP0690385A1 (en) Method and apparatus for managing memory in a computer system
JPS63502224A (ja) 複数のアドレス空間を選択的にサポ−トできるペ−ジ式記憶装置管理ユニット
EP0408058A2 (en) Microprocessor
JPH0552540B2 (ja)
JPH0654479B2 (ja) 仮想記憶方式
JPH0652511B2 (ja) 情報処理装置のアドレス変換方式
JP2000227874A (ja) コンピュ―タ・システムにおいてディレクトリ構造を含むメイン・メモリの内容にアドレスするための方法および装置
JPH0312339B2 (ja)
KR910001314B1 (ko) 데이타 처리 시스템에서의 가상 메모리 사용방법
JPH0351011B2 (ja)
JP2930071B2 (ja) 情報処理装置およびプロセッサ
JP2768503B2 (ja) 仮想記憶アドレス空間アクセス制御方式
US4984150A (en) Virtual memory control management system
JP2537550B2 (ja) 仮想アドレスから物理アドレスへの翻訳機構ならびに仮想記憶空間を備えたコンピュ―タシステム及び翻訳バッファのロ―ディング方法
US5544293A (en) Buffer storage system and method using page designating address and intra-page address and detecting valid data
JPS6136264B2 (ja)
CA2011394C (en) Ring reduction logic mechanism
JPS6149703B2 (ja)
JP3061818B2 (ja) マイクロ・プロセッサ用アクセス・モニタ装置

Legal Events

Date Code Title Description
LAPS Cancellation because of no payment of annual fees