[go: up one dir, main page]

JPH07160583A - Virtual memory control method - Google Patents

Virtual memory control method

Info

Publication number
JPH07160583A
JPH07160583A JP5306247A JP30624793A JPH07160583A JP H07160583 A JPH07160583 A JP H07160583A JP 5306247 A JP5306247 A JP 5306247A JP 30624793 A JP30624793 A JP 30624793A JP H07160583 A JPH07160583 A JP H07160583A
Authority
JP
Japan
Prior art keywords
address
area
entry
translation table
address translation
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
JP5306247A
Other languages
Japanese (ja)
Inventor
Masaaki Hosouchi
昌明 細内
Toshiaki Arai
利明 新井
Masakatsu Abe
正克 阿部
Yoshio Ukai
良夫 鵜飼
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 JP5306247A priority Critical patent/JPH07160583A/en
Publication of JPH07160583A publication Critical patent/JPH07160583A/en
Pending legal-status Critical Current

Links

Landscapes

  • Memory System Of A Hierarchy Structure (AREA)

Abstract

(57)【要約】 【目的】 アドレス空間生成処理において下位レベルの
アドレス変換テーブルの作成処理を削減し、アドレス空
間生成処理を高速化する。また、参照または書込が発生
するまで下位レベルのアドレス変換テーブルを複数のア
ドレス空間の間で共有することにより、これらのアドレ
ス変換テーブルの所要メモリを削減する。 【構成】 アドレス空間生成時に生成要求側アドレス空
間の読込専用領域のページテーブルを共有し、書込可能
領域のセグメントをコピーオンライトまたはコピーオン
リファレンスする。書込可能領域内のいずれかのページ
を書込または参照したときに、ページテーブルのコピー
と、セグメント内の全ページのコピーまたはコピーオン
ライト、コピーオンリファレンスを行う。読込専用領域
と書込可能領域は、それぞれ別のセグメント境界属性を
持つ領域グループに割当てる。
(57) [Summary] [Purpose] To reduce the address translation table creation process at the lower level in the address space creation process and speed up the address space creation process. Further, by sharing the lower-level address conversion table among a plurality of address spaces until reference or writing occurs, the memory required for these address conversion tables is reduced. [Configuration] When an address space is generated, the page table of the read-only area of the generation request side address space is shared, and the segment of the writable area is copy-on-write or copy-on-reference. When any page in the writable area is written or referred to, the page table is copied, and all the pages in the segment are copied, copy-on-write, or copy-on-reference. The read-only area and the writable area are assigned to area groups having different segment boundary attributes.

Description

【発明の詳細な説明】Detailed Description of the Invention

【0001】[0001]

【産業上の利用分野】本発明は、多重仮想記憶方式を採
用している計算機システムにおける仮想記憶装置の昭御
方法に関する。
BACKGROUND OF THE INVENTION 1. Field of the Invention The present invention relates to a method of controlling a virtual memory device in a computer system which employs a multiple virtual memory system.

【0002】[0002]

【従来の技術】多重仮想記憶方式を採用している計算機
ジステムのオペレーティングシステム(Operating Syst
em:以下「OS」と略記す)において、新たなアドレス
空間を生成する方法のひとつとして、生成を要求したプ
ログラムが実行されているアドレス空間(以下「生成要
求側アドレス空間」と略記する)の仮想記憶領域の内容
を、生成したアドレス空間(以下「被生成アドレス空
間」と略記する)に複写する方法がある。例えば、UN
IX System Laboratories, Inc. が開発し、ライセン
スしているOSであるUNIXにおけるfork関数ではこ
の方法によりアドレス空間を生成する。このようなアド
レス空間生成方法では、仮想記憶領域の複写処理のた
め、アドレス空間生成時のオーバヘッドが大きくなると
いう問題がある。このため、領域共有、コピーオンライ
ト、コピーオンリファレンス等のアドレス空間生成に関
する高速化方法が考案されている。
2. Description of the Related Art An operating system (operating system) of a computer system adopting a multiple virtual memory system.
em: hereinafter abbreviated as “OS”), as one of the methods for generating a new address space, the address space in which the program requesting generation is executed (hereinafter abbreviated as “generation request side address space”) There is a method of copying the contents of the virtual storage area into a generated address space (hereinafter abbreviated as "generated address space"). For example, UN
The fork function in UNIX, which is an OS developed and licensed by IX System Laboratories, Inc., creates an address space by this method. In such an address space generation method, there is a problem that the overhead at the time of address space generation becomes large due to the copy processing of the virtual memory area. Therefore, a speed-up method for address space generation such as area sharing, copy-on-write, and copy-on-reference has been devised.

【0003】UNIXにおける領域共有は、生成要求側
アドレス空間及び被生成アドレス空間の間でページテー
ブルを共有することにより、実記憶装置の領域をこれら
のアドレス空間で共有する方法である。アドレス空間間
でページテーブルを共有するため、共有する実記憶領域
にマッピングされるページがこれらのアドレス空間の一
方で更新されると、他のアドレス空間においても同じ実
記憶領域にマッピングされるページが更新された状態と
なってしまう。このため、上記の領域共有は通常は読込
専用領域に適用される。
The area sharing in UNIX is a method of sharing the area of the real storage device by sharing the page table between the address space of the generation request side and the generated address space. Since the page table is shared between the address spaces, when a page mapped to the shared real storage area is updated in one of these address spaces, a page mapped to the same real storage area in other address spaces also becomes available. It will be updated. Therefore, the above area sharing is usually applied to the read-only area.

【0004】コピーオンライトは、生成要求側アドレス
空間及び被生成アドレス空間のいずれかにおいてページ
が更新されるまでページの複写を延期する方法である。
アドレス空間生成時にはページテーブルのみを複写し、
各ページに割当てられた実記憶領域を共有すると共に、
これらのページを書込保護の状態にする。そして、上記
アドレス空間のいずれかにおいて上記ページが更新され
る際、書込保護例解決処理において、新たに実記憶領域
を割当て、そのページの内容を複写する。
Copy-on-write is a method of deferring copying of a page until the page is updated in either the generation requesting address space or the generated address space.
When creating the address space, copy only the page table,
While sharing the real storage area allocated to each page,
Put these pages into write protected state. Then, when the page is updated in any of the address spaces, in the write protection example resolution process, a new real storage area is newly allocated and the content of the page is copied.

【0005】コピーオンリファレンスは、生成要求側ア
ドレス空間及び被生成アドレス空間のいずれかにおいて
ページへの参照または書込のいずれかのアクセスが発生
するまで、ページの複写を延期する方法である。コピー
オンライト同様、アドレス空間生成時はページテーブル
のみを複写し、各ページに割当てられた実記憶領域を共
有すると共にページテーブルエントリを無効化する。そ
して、上記アドレス空間のいずれか一方において上記ペ
ージがアクセスされる際、ページ変換例外解決処理にお
いて、新たに実記憶領域を割当て、ページの内容を複写
する。
Copy-on-reference is a method of deferring copying of a page until either a reference access or a write access to the page occurs in either the generation request side address space or the generated address space. Similar to copy-on-write, when the address space is generated, only the page table is copied, the real storage area allocated to each page is shared, and the page table entry is invalidated. Then, when the page is accessed in either one of the address spaces, a new real storage area is newly allocated in the page conversion exception resolution processing, and the content of the page is copied.

【0006】図2は、UNIXにおける仮想記憶装置の
制御方法を示す図である。各アドレス空間毎に仮想記憶
装置100は、OSカーネルが使用するシステム領域や
テキスト領域などの読込専用領域、データ領域やスタツ
フ領域などの書込可能領域から構成される。リージョン
テーブル140は、アドレス空間毎に仮想記憶装置10
0内の各領域のレイアウトを管理する。リージョンテー
ブル140の各エントリは、これらの各領域の先頭アド
レス、大きさ、ページテーブル120の先頭アドレス等
の情報を持つ。ページテーブル120は、上記の各領域
毎に存在し、その大きさは各領域の大きさに存在する。
FIG. 2 is a diagram showing a method of controlling a virtual storage device in UNIX. The virtual storage device 100 is composed of a read-only area such as a system area and a text area used by the OS kernel, and a writable area such as a data area and a stuff area for each address space. The region table 140 stores the virtual storage device 10 for each address space.
The layout of each area within 0 is managed. Each entry of the region table 140 has information such as the start address and size of each of these areas and the start address of the page table 120. The page table 120 exists for each of the above areas, and the size thereof is the size of each area.

【0007】このように、UNIXでは読込専用領域と
書込可能領域とを分離し、領域毎にページテーブルを設
けることにより、読込専用領域に対してはページテーブ
ルを共有し、書込可能領域に対しては、参照若しくは書
込時(コピーオンリファレンス)又は書込時(コピーオ
ンライト)にページを複写している。
As described above, in UNIX, the read-only area and the writable area are separated, and the page table is provided for each area, so that the page table is shared for the read-only area and the writable area is set. On the other hand, a page is copied at the time of reference or writing (copy on reference) or at the time of writing (copy on write).

【0008】仮想記憶装置の制御方法として、図2に示
した方法の他に、アドレス空間を複数レベルの単位で分
割し、複数回のアドレス変換テーブル参照により仮想記
憶領域を実記憶領域にマッピングする方法がある。すな
わち、各アドレス空間毎に、最上位レベルのアドレス変
換テーブルは該アドレス空間全体を管理し、その各エン
トリは上記単位の中で最大のレベルの単位でアドレス空
間を分割した領域に対応しており、各エントリ中に1レ
ベル下位のアドレス変換テーブルの先頭アドレスを保持
する。同様に、この下位レベルのアドレス変換テーブル
は前記エントリに対応する分割領域を管理し、該テーブ
ルの各エントリは1レベル下位の単位でこの分割領域を
分割した領域に対応しており、そのエントリ中に1レベ
ル下位のアドレス変換テーブルの先頭アドレスを保持す
る。そして、順次下位レベルのアドレス変換テーブルは
より小さい単位で分割された領域を管理し、最下位レベ
ルのアドレス変換テーブルの各エントリは最小単位であ
るページに対応し、そのエントリ中に該ページにマッピ
ングされた実記憶領域のアドレスを保持する。
As a method of controlling the virtual memory device, in addition to the method shown in FIG. 2, the address space is divided in units of a plurality of levels, and the virtual memory area is mapped to the real memory area by referring to the address conversion table a plurality of times. There is a way. That is, for each address space, the highest-level address conversion table manages the entire address space, and each entry corresponds to an area obtained by dividing the address space in the unit of the maximum level among the above units. , The top address of the address conversion table one level lower is held in each entry. Similarly, this lower-level address conversion table manages the divided area corresponding to the entry, and each entry of the table corresponds to the area obtained by dividing this divided area in units of one level lower. Holds the start address of the address conversion table one level lower. Then, the address conversion table of the lower level sequentially manages the area divided into smaller units, and each entry of the address conversion table of the lowest level corresponds to the page which is the minimum unit, and is mapped to the page in the entry. It holds the address of the real storage area that was created.

【0009】上記方法の具体的な場合として、仮想記憶
装置をセグメントとページの2レベルに分割し、アドレ
ス変換テーブルをセグメントテーブル及びページテーブ
ルで構成するセグメンテーションページング方式を採用
しているOSにおける仮想記憶装置の制御方法を図3に
示す。特開平2−202352号公報記載の多重仮想記
憶管理方式では、セグメンテーションページング方式の
OSにおいて、複数のアドレス空間の間でページテーブ
ルを共有することにより共通領域を設けることを可能と
している。この多重仮想記憶管理方法では、アドレス空
間間の共通領域は書込可能であり、書き込まれたデータ
は当該アドレス空間間で共有される。
As a specific case of the above method, a virtual memory in an OS adopting a segmentation paging system in which a virtual memory device is divided into two levels of a segment and a page, and an address translation table is composed of a segment table and a page table. The control method of the device is shown in FIG. In the multiple virtual memory management method described in Japanese Patent Application Laid-Open No. 2-202352, it is possible to provide a common area by sharing a page table among a plurality of address spaces in the OS of the segmentation paging method. In this multiple virtual memory management method, the common area between the address spaces can be written, and the written data is shared between the address spaces.

【0010】[0010]

【発明が解決しようとする課題】上述のUNIXにおけ
るコピーオンライト及びコピーオンリファレンスでは、
アドレス空間生成時、ページテーブルを複写する必要が
ある。このため、アドレス空間生成時、ページテーブル
の作成が必要であり、アドレス空間生成後に参照されな
いページに対してもページテーブルエントリを作成しな
ければならないという問題がある。
DISCLOSURE OF INVENTION Problems to be Solved by the Invention In the above-mentioned copy-on-write and copy-on-reference in UNIX,
It is necessary to copy the page table when creating the address space. Therefore, there is a problem that a page table needs to be created when the address space is created, and a page table entry must be created for a page that is not referred to after the address space is created.

【0011】上記の特開平2−202652号公報記載
の多重仮想記憶管理方式では、任意のアドレス空間の間
で領域を共有することができるが、コピーオンライン及
びコピーオンリファレンスができない。
In the multiple virtual memory management system described in the above-mentioned Japanese Patent Laid-Open No. 2-202652, an area can be shared between arbitrary address spaces, but copy online and copy on reference cannot be performed.

【0012】本発明の第一の目的は、多重仮想記憶方式
を採用するOSの計算機システムにおいて、アドレス空
間生成時のアドレス変換テーブル作成オーバヘッドを削
減することにより、アドレス空間生成処理を高速化する
ことである。
A first object of the present invention is to speed up an address space generation process by reducing an address conversion table preparation overhead at the time of address space generation in a computer system of an OS adopting a multiple virtual storage system. Is.

【0013】本発明の第二の目的は、セグメンテーショ
ンページング方式等の複数レベルのアドレス変換テーブ
ルを有する多重仮想記憶方式の計算機システムにおい
て、アドレス空間間の実記憶領域の共有、コピーオンラ
イト及びコピーオンリファレンスを実現することによっ
て、アドレス空間生成時の所要メモリ量を削減すること
である。
A second object of the present invention is to share a real storage area between address spaces, copy-on-write and copy-on in a computer system of a multiple virtual storage system having a plurality of levels of address translation tables such as a segmentation paging system. By realizing the reference, it is possible to reduce the required memory amount when the address space is generated.

【0014】[0014]

【課題を解決するための手段】上記目的は、一つのアド
レス空間で実行中のプログラムからの新たなアドレス空
間の生成要求に応じて、新たに生成するアドレス空間に
対して、最上位レベルのアドレス変換テーブルのみを作
成とともに、作成したアドレス変換テーブルに生成要求
側アドレス空間に対する最上位レベルのアドレス変換テ
ーブル中の実記憶領域割当済の領域を管理するエントリ
を複写し、最上位レベルよりも下位のアドレス変換テー
ブル及びそれらのアドレス変換テーブルに対応する領域
をこれらの二つのアドレス空間で共有することにより達
成される。
The above-mentioned object is to address the highest level address for a newly created address space in response to a request for creating a new address space from a program executing in one address space. Along with creating the translation table only, copy the entry that manages the real storage area allocated area in the highest-level address translation table for the address space of the generation request side into the created address translation table, and copy the entry below the highest level. This is achieved by sharing the address translation tables and the areas corresponding to those address translation tables in these two address spaces.

【0015】なお、新たなアドレス空間の生成要求に応
じてアドレス変換テーブルの作成及び複写を行う際、生
成要求側アドレス空間に対する各アドレス変換テーブル
が管理する領域が読込専用領域のみから構成されるかあ
るいは書込可能領域のみから構成されるかを判定し、い
ずれでもない場合は新たに生成するアドレス空間に対し
てこれらの領域を管理するアドレス変換テーブルを作成
し、アドレス変換テーブルが管理する領域が読込専用領
域のみから構成されるかあるいは書込可能領域のみから
構成される場合は、該アドレス変換テーブルを管理する
1レベル上位のアドレス変換テーブルエントリを新たに
生成するアドレス空間の対応するアドレス変換テーブル
に複写することにより、前記領域及びこの複域を管理す
るアドレス変換テーブルを二つのアドレス空間間で共有
するようにしてもよい。
When the address translation table is created and copied in response to a request for creating a new address space, is the area managed by each address translation table for the address space on the requesting side composed only of read-only areas? Alternatively, it is determined whether or not the area is composed only of the writable area, and if it is neither, an address conversion table for managing these areas is created for the newly created address space, and the area managed by the address conversion table is When it is composed only of a read-only area or only a writable area, an address conversion table corresponding to an address space for newly generating an address conversion table entry one level higher for managing the address conversion table The address translation table that manages the above area and this multiple area by copying Bull may be shared between the two address spaces.

【0016】さらに、本発明では、アドレス空間生成要
求に応じてアドレス変換テーブルのエントリを複写する
際、書込可能領域に対するエントリに対してコピーオン
リファレンスの対象とする旨を示すコピーオンリファレ
ンス判別子を設定し、該領域に対するアクセスに対して
コピーオンリファレンス処理を行う。即ち、書込可能領
域のページに対するアクセス要求に応じて、各アドレス
変換テーブルエントリが管理する領域が前記ページを含
みかつ該エントリに対するコピーオンリファレンス判別
子が設定されていれば、該判別子をリセットし、該エン
トリを含むアドレス変換テーブルよりも下位レベルかつ
前記ページを含む領域を管理するアドレス変換テーブル
をアクセス要求を発行したプログラムが実行されている
アドレス空間に対して作成し、対応する元のアドレス変
換テーブル中の前記ページを含まない領域に対するエン
トリを複写する。それとともに、該エントリに対してコ
ピーオンリファレンス判別子を設定し、作成した各アド
レス変換テーブルのアドレスを上位のアドレス変換テー
ブルの該当するエントリに設定し、前記ページの内容を
新たに割当てた実記憶装領域に複写するとともに、この
実記憶領域のアドレスをアクセス要求を発行しプログラ
ムが実行されているアドレス空間の最下位レベルのアド
レス変換テーブルの前記ページに対するエントリに設定
する。
Further, according to the present invention, when copying an entry in the address translation table in response to an address space generation request, a copy-on-reference discriminator indicating that the entry for the writable area is to be copy-on-referenced. Is set, and copy-on-reference processing is performed for access to the area. That is, if the area managed by each address translation table entry includes the page and the copy-on-reference discriminator for the entry is set, the discriminator is reset in response to an access request for the page of the writable area. Then, an address conversion table that manages an area including the page and a lower level than the address conversion table including the entry is created in the address space in which the program that issued the access request is executed, and the corresponding original address is created. Copy the entry for the area not including the page in the conversion table. At the same time, a copy-on-reference discriminator is set for the entry, the address of each created address translation table is set in the corresponding entry of the upper address translation table, and the contents of the page are newly assigned to the actual storage. At the same time as copying to the storage area, the address of this real storage area is set to the entry for the page in the address conversion table at the lowest level of the address space where the access request is issued and the program is executed.

【0017】さらに、望ましくは、読込専用領域と書込
可能領域とが別の領域グループに属するように仮想記憶
装置内の領域をグループ分けし、領域グループ毎に領域
が共有または複写のいずれかの対象であるか否かを示す
第一のフラグと、領域が読込専用領域であるか書込可能
領域であるかを判別する第二のフラグとを設け、一つの
アドレス空間で実行中のプログラムからの新たなアドレ
ス空間生成の要求に応じて、第一のフラグの判定結果が
共有または複写のいずれかの対象であることを示す領域
を生成要求側のアドレス空間及び新たに生成するアドレ
ス空間で共有するとともに、第二のフラグの判定結果が
書込可能領域であることを示す領域をコピーオンリファ
レンスの対象とする。
Further, preferably, the areas in the virtual storage device are divided into groups such that the read-only area and the writable area belong to different area groups, and the area is shared or copied for each area group. A first flag indicating whether or not it is a target and a second flag for determining whether the area is a read-only area or a writable area are provided, and a program running in one address space In response to a request to generate a new address space, the area indicating that the determination result of the first flag is a target of sharing or copying is shared by the address space of the generation requesting side and the newly generated address space. At the same time, the area indicating that the determination result of the second flag is the writable area is set as the copy-on-reference target.

【0018】なお、コピーオンリファレンスの代わり
に、書込要求発生時に複写するコピーオンライを用いる
ようにしてもよい。
Instead of copy-on-reference, copy-on-line for copying when a write request occurs may be used.

【0019】[0019]

【作用】一つのアドレス空間で実行中のプログラムが新
たにアドレス空間を生成するとき、生成要求側のアドレ
ス空間に実記憶領域割当済の仮想記憶領域に対する上位
レベルのアドレス変換テーブルのエントリを新たに生成
するアドレス空間の対応するアドレス変換テーブルに複
写し、下位レベルのアドレス変換テーブルをこれらのア
ドレス空間の間で共有することによって、メモリオーバ
ヘッドを削減することができる。
When a program running in one address space newly creates an address space, an entry in the higher-level address translation table for the virtual storage area to which the real storage area has been allocated is newly created in the address space of the generation request side. Memory overhead can be reduced by copying to the corresponding address translation table of the generated address space and sharing the lower level address translation table between these address spaces.

【0020】また、アドレス空間生成時に生成要求側ア
ドレス空間に実記憶領域割当済の書込可能領域に対する
上位レベルのアドレス変換テーブルの各エントリを新た
に生成するアドレス空間に複写し、これらのエントリが
管理する下位レベルのアドレス変換テーブルをコピーオ
ンリファレンス(又はコピーオンライト)の対象とする
ことにより、アドレス空間生成時におけるアドレス変換
テーブルの作成オーバヘッドを削減することができる。
Further, when the address space is generated, each entry of the higher-level address conversion table for the writable area that has been allocated to the real storage area in the address space of the generation request side is copied to the newly generated address space, and these entries are stored. By making the lower-level address translation table to be managed the copy-on-reference (or copy-on-write) target, the overhead of creating the address translation table at the time of address space generation can be reduced.

【0021】さらに、読込専用領域と書込可能領域とが
最上位のアドレス変換テーブルの異なるエントリに対応
する領域に属するようにアドレス空間内の領域を配置す
ることにより、読込専用領域を共有し、書込可能領域を
コピーオンリファレンス(又はコピーオンライト)の対
象とすることができる。
Further, the read-only area is shared by arranging the areas in the address space so that the read-only area and the writable area belong to the areas corresponding to different entries in the highest address conversion table. The writable area can be the target of copy-on reference (or copy-on-write).

【0022】[0022]

【実施例】以下、本発明の実施例を説明する。なお、本
実施例ではコピーオンリファレンスを用いたアドレス空
間生成方法を主に説明するが、コピーオンライトを用い
た方法でもよい。コピーオンリファレンス及びコピーオ
ンライトで相違点がある場合には、適宜コピーオンライ
トの場合について説明を補足する。また、以下において
はセグメントテーブル及びページテーブルの2レベルの
アドレス変換テーブルを有するセグメンテーションペー
ジング方式の計算機システムについて説明するが、3レ
ベル以上のアドレス変換テーブルを有する計算機システ
ムにも同様に実施可能であることは明らかであろう。
EXAMPLES Examples of the present invention will be described below. In this embodiment, an address space generation method using copy-on reference will be mainly described, but a method using copy-on-write may be used. When there is a difference between the copy-on-reference and the copy-on-write, the description of the copy-on-write case will be supplemented as appropriate. In the following, a segmentation paging type computer system having a two-level address conversion table of a segment table and a page table will be described, but the same is applicable to a computer system having three or more levels of address conversion tables. Would be obvious.

【0023】図1は、本発明を用いた計算機システムに
おける仮想記憶装置の制御方法を説明する図である。図
1において、100は仮想記憶装置である。本実施例の
計算機システムは多重仮想記憶方式を採用しているた
め、複数のアドレス空間が存在する。各アドレス空間の
うち、アドレス空間100aは新たなアドレス空間の生
成を要求したプログラムが実行されているアドレス空間
(生成要求側アドレス空間)である。アドレス空間10
0bは、アドレス空間100aで実行中のプログラムの
要求により生成されたアドレス空間(被生成アドレス空
間)であり、生成直後の内容は生成要求側のアドレス空
間100aと同一である。アドレス空間100cは、ア
ドレス空間100aやアドレス空間100bとは生成要
求や被生成等の関係がないアドレス空間である。
FIG. 1 is a diagram for explaining a method of controlling a virtual storage device in a computer system using the present invention. In FIG. 1, reference numeral 100 is a virtual storage device. Since the computer system of this embodiment employs the multiple virtual storage system, there are a plurality of address spaces. Of the respective address spaces, the address space 100a is an address space in which a program requesting the generation of a new address space is executed (generation request side address space). Address space 10
0b is an address space (generated address space) generated by a request of the program being executed in the address space 100a, and the content immediately after generation is the same as the address space 100a on the generation request side. The address space 100c is an address space that has no relationship with the address space 100a or the address space 100b such as generation request or generation target.

【0024】図1において、110はセグメントテーブ
ル、120はページテーブル、130は実記憶装置、1
60は仮想記憶装置を制御するプログラムなどを実行す
る中央処理装置である。本実施例の計算機システムはセ
グメンテーションページング方式を採用しているため、
各アドレス空間の領域は一定の大きさのセグメントに分
割され、さらに各セグメントは一定の大きさのページに
分割される。各ページは実記憶装置130中のページの
大きさの実記憶領域(以下、実ページという)131に
マッピングされる。また、各アドレス空間のセグメント
テーブル110およびページテーブル120は、それぞ
れ実記憶装置130中に存在する。
In FIG. 1, 110 is a segment table, 120 is a page table, 130 is a real storage device, 1
A central processing unit 60 executes a program for controlling the virtual storage device. Since the computer system of this embodiment uses the segmentation paging method,
The area of each address space is divided into segments of a certain size, and each segment is further divided into pages of a certain size. Each page is mapped to a real storage area (hereinafter referred to as a real page) 131 having the size of the page in the real storage device 130. Further, the segment table 110 and the page table 120 of each address space exist in the real storage device 130, respectively.

【0025】本発明では、図1の120bおよび120
cのように、ページテーブルを共有(コピーオンリファ
レンス状態及びコピーオンライト状態を含む)すること
により、生成要求側アドレス空間100aと被生成アド
レス空間100bのように関連するアドレス空間の間で
実記憶領域を共有可能にする点、及び読込専用領域と書
込可能領域とを別々のセグメントに配置する点に特徴が
ある。なお、アドレス空間間の関連としては、一つのア
ドレス空間とその被生成アドレス空間により生成された
アドレス空間や、共通のアドレス空間によって生成され
たアドレス空間同士のように、アドレス空間の生成要求
及び被生成の関係において、直接的な関係以外に間接的
に順次関連する場合を含む。
In the present invention, 120b and 120 of FIG.
By sharing the page table (including the copy-on-reference state and the copy-on-write state) like c, real storage is performed between the related address spaces such as the generation request side address space 100a and the generated address space 100b. It is characterized in that the area can be shared and that the read-only area and the writable area are arranged in different segments. As for the relationship between the address spaces, an address space generation request and a target address space are generated, such as an address space generated by one address space and its generated address space, or address spaces generated by a common address space. In the relation of generation, indirect relations other than the direct relation are included.

【0026】図4は、実ページ及びページテーブルが非
共有状態(複数のアドレス空間の間で共有されず、1つ
のアドレス空間のみに属する状態)のセグメントに関す
る仮想記憶装置の制御方法を示す図である。セグメント
テーブル110は、各セグメント毎にエントリ111を
有する。各エントリ111は、当該セグメントが無効で
あるか有効であるかを示すセグメント無効フラグ112
を含む。セグメントが無効の場合、当該セグメントにペ
ージテーブルは割当てられておらず、したがって、実記
憶装置の領域も割当てられていない。図4において、
‘−’はセグメントが有効であることを示す。
FIG. 4 is a diagram showing a method of controlling a virtual memory device regarding a segment in which a real page and a page table are in a non-shared state (a state where they are not shared among a plurality of address spaces and belong to only one address space). is there. The segment table 110 has an entry 111 for each segment. Each entry 111 has a segment invalid flag 112 indicating whether the segment is invalid or valid.
including. When the segment is invalid, the page table is not allocated to the segment, and therefore, the area of the real storage device is not allocated. In FIG.
"-" Indicates that the segment is valid.

【0027】同様に、ページテーブル120は、各ペー
ジ毎にエントリ121を有する。各エントリ121は、
当該ページが無効であるか有効であるかを示すページ無
効フラグ122を含む。ページが無効の場合、当該ペー
ジに実記憶装置130中の領域である実ページは割当て
られていない。セグメントテーブルエントリと同様、図
4において、‘−’はページが有効であることを示す。
Similarly, the page table 120 has an entry 121 for each page. Each entry 121 is
A page invalid flag 122 indicating whether the page is invalid or valid is included. When the page is invalid, the real page which is the area in the real storage device 130 is not allocated to the page. Similar to the segment table entry, in FIG. 4, '-' indicates that the page is valid.

【0028】実記憶装置130中の各領域の割当状態を
管理するため、実記憶管理テーブル150を設ける。実
記憶管理テーブル150は、実ページ(ページテーブル
及びセグメントテーブルに割当てられた実ページを含
む)毎にエントリ151を有する(ただし、セグメント
テーブルに対応するエントリは便宜上図面から省略)。
各エントリ151は、当該実ページに対するエントリを
有するページテーブル(通常の実ページの場合)あるい
はセグメントテーブル(ページテーブルに割当てられた
実ぺージの場合)の間の共有の度合いを示す共有度カウ
ンタ152、当該実ページが複数のページテーブルある
いはセグメントテーブルに共有されていることを示す共
有フラグ153、ページ(通常の実ページの場合)ある
いはセグメント(ページテーブルに割当てられた実ペー
ジの場合)がコピーオンリファレンス状態(コピーオン
ライトの場合は、コピーオンライト状態)にあることを
示す複写属性フラグ154等から構成される。図4で
は、実ページ131及びページテーブル120aはいず
れも共有されていないため、共有度カウンタ152は0
を示し、共有フラグ153および複写属性フラグ154
はオフ(‘−’)になっている。セグメントテーブルエ
ントリ111が管理する仮想記憶領域であるセグメント
に対して、該エントリ111中の無効フラグ112及び
該エントリ111が管理するページテーブル120に対
する複写属性フラグ154に基づき、該セグメントがコ
ピーオンリファレンスの対象であるか否か(コピーオン
ライトの場合、コピーオンライトの対象であるか否か)
を判別することができる。ページテーブルエントリ12
1が管理する仮想記憶領域であるページに対しても同様
である。
A real storage management table 150 is provided to manage the allocation state of each area in the real storage device 130. The real storage management table 150 has an entry 151 for each real page (including a real page assigned to a page table and a segment table) (however, the entry corresponding to the segment table is omitted from the drawing for convenience).
Each entry 151 is a sharing degree counter 152 indicating the degree of sharing between a page table (for a normal real page) or a segment table (for a real page assigned to the page table) having an entry for the real page. , A sharing flag 153 indicating that the real page is shared by a plurality of page tables or a segment table, a page (in the case of a normal real page) or a segment (in the case of a real page assigned to the page table) is copied on It is composed of a copy attribute flag 154 and the like indicating that it is in the reference state (in the case of copy-on-write, the copy-on-write state). In FIG. 4, since neither the real page 131 nor the page table 120a is shared, the sharing degree counter 152 indicates 0.
Shared flag 153 and copy attribute flag 154.
Is off ('-'). For a segment that is a virtual storage area managed by the segment table entry 111, the segment is a copy-on-reference based on the invalid flag 112 in the entry 111 and the copy attribute flag 154 for the page table 120 managed by the entry 111. Whether it is a target (in the case of copy-on-write, whether it is a target of copy-on-write)
Can be determined. Page table entry 12
The same applies to a page which is a virtual storage area managed by 1.

【0029】図4の状態にあるセグメントを含むアドレ
ス空間で実行中のプログラムが新たなアドレス空間の生
成を要求した場合、書込可能領域のセグメントは図5の
状態に変化する。即ち、アドレス空間生成処理では、生
成要求側アドレス空間のセグメントテーブル110a中
の書込可能領域のセグメントに対するセグメントテーブ
ルエントリ111を被生成アドレス空間のセグメントテ
ーブル110bに複写し、実記憶管理テーブル150中
の当該セグメントのページテーブルに対するエントリを
コピーオンリファレンス状態(コピーオンライトの場
合、コピーオンライト状態)にする。
When the program executing in the address space including the segment in the state of FIG. 4 requests the generation of a new address space, the segment of the writable area changes to the state of FIG. That is, in the address space generation process, the segment table entry 111 for the segment of the writable area in the segment table 110a of the generation requesting side address space is copied to the segment table 110b of the generated address space, and the segment table 110b in the real storage management table 150 is copied. The entry for the page table of the segment is set to the copy-on reference state (in the case of copy-on-write, the copy-on-write state).

【0030】同様に、読込専用領域のセグメントに対す
るセグメントテーブルエントリ111を生成要求側アド
レス空間のセグメントテーブル110aから被生成アド
レス空間のセグメントテーブル110bに複写すること
によって、当該セグメントに対応するページテーブル1
20及び実ページを共有する。
Similarly, by copying the segment table entry 111 for the segment of the read-only area from the segment table 110a of the address space of the requesting generation side to the segment table 110b of the address space to be generated, the page table 1 corresponding to the segment.
Share 20 and real pages.

【0031】アドレス空間生成処理のフローチャートを
図6に示す。まず、被生成アドレス空間のセグメントテ
ーブル110bやアドレス空間の管理情報から構成され
るアドレス空間管理テーブルなどを作成し、初期化する
(ステップ601)。次に、生成要求側アドレス空間の
各領域を管理するための仮想記憶管理用テーブル群を参
照し、共有対象領域(読込専用領域)及び複写対象領域
(書込可能領域)を判別する(ステップ602)。
A flow chart of the address space generation processing is shown in FIG. First, the segment table 110b of the generated address space and the address space management table including the management information of the address space are created and initialized (step 601). Next, the shared memory area (read-only area) and the copy area (writable area) are discriminated by referring to the virtual memory management table group for managing each area of the generation requesting side address space (step 602). ).

【0032】図7に、仮想記憶管理用テーブル群の方法
を示す。アドレス空間の各領域をグループに分け、その
際、読込専用領域と書込可能領域とは別の領域グループ
になるようにする。各領域グループは、領域グループ管
理テーブル700によって管理される。領域グループ管
理テーブル700には、読込専用領域の領域グループで
あるか書込可能領域の領域グループであるかを識別する
読込専用領域フラグ701、アドレス空間生成時に共有
または複写(コピーオンリファレンスによる複写、コピ
ーオンライトを用いたアドレス空間生成方法の場合はコ
ピーオンライトによる複写)の対象となる領域であるか
それ以外の領域であるかを識別する領域共有属性フラグ
702、割当てた領域の仮想記憶装置100上の先頭ア
ドレスや領域長などを管理する割当領域管理テーブル7
10へのポインタ、等の情報を含む。なお、共有または
複写の対象となる領域は、セグメント境界属性をもつ。
アドレス空間生成処理において、生成要求側アドレス空
間100a内の各領域に対応した領域グループ管理テー
ブル700のフラグ701及びフラグ702を参照する
ことにより、共有対象領域及び複写対象領域を識別す
る。
FIG. 7 shows a method of the virtual memory management table group. Each area of the address space is divided into groups, in which case the read-only area and the writable area are in different area groups. Each area group is managed by the area group management table 700. In the area group management table 700, a read-only area flag 701 for identifying whether the area group is a read-only area or a writable area, shared or copied at the time of address space generation (copy by copy-on-reference, In the case of the address space generation method using copy-on-write, an area-sharing attribute flag 702 for identifying whether the area is a target area for copy-on-write or other area, and a virtual storage device for the allocated area Allocation area management table 7 for managing the start address and area length on 100
It includes information such as a pointer to 10. The area to be shared or copied has a segment boundary attribute.
In the address space generation process, the shared target area and the copy target area are identified by referring to the flags 701 and 702 of the area group management table 700 corresponding to each area in the generation request side address space 100a.

【0033】アドレス空間生成後に新たに仮想記憶装置
の領域を割当てる場合、各領域グループ管理テーブル7
00のフラグ701及びフラグ702を参照し、割当て
る領域の種別(読込専用領域、書込可能領域、その他)
に応じて領域グループを選択する。そして、読込専用領
域または書込可能領域の場合、同一グループ内の割当済
領域に隣接した領域を割当てる。これにより、読込専用
領域と書込可能領域のセグメントを分離し、セグメント
単位で共有制御することが可能となる。
When a new area of the virtual storage device is allocated after the address space is generated, each area group management table 7
Type of area to be allocated by referring to flag 701 and flag 702 of 00 (read-only area, writable area, etc.)
Area group according to. Then, in the case of the read-only area or the writable area, an area adjacent to the allocated area in the same group is allocated. As a result, the read-only area and the writable area segments can be separated and shared control can be performed in segment units.

【0034】次に、生成要求側アドレス空間の複写対象
領域の各セグメントに対するセグメントテーブルエント
リ111の無効フラグ112をオン(‘I’)にする
(コピーオンライトの場合は、当該セグメント内の各ペ
ージの属性を書込不可にするため、対応するページテー
ブルの各エントリの書込保護フラグをオンにする)(ス
テップ603)。ここで、セグメントテーブルエントリ
111の無効フラグをオンにするかわりに、当該セグメ
ントのページテーブルの各エントリの無効フラグをオン
にしてもよい。
Next, the invalid flag 112 of the segment table entry 111 for each segment in the copy target area of the generation requesting address space is turned on ('I') (in the case of copy-on-write, each page in the segment is turned on). The write protection flag of each entry of the corresponding page table is turned on in order to make the attribute of the item writable (step 603). Here, instead of turning on the invalid flag of the segment table entry 111, the invalid flag of each entry of the page table of the segment may be turned on.

【0035】次に、上記処理により識別した共有対象領
域及び複写対象領域に対するセグメントテーブルエント
リ111を被生成アドレス空間のセグメントテーブル1
11に複写する(ステップ604)。また、これらの領
域に対する領域グループ管理テーブル700や割当領域
管理テーブル710等の仮想記憶管理用テーブル群も複
写する(ステップ605)。
Next, the segment table entry 111 for the shared target area and the copy target area identified by the above processing is set to the segment table 1 of the generated address space.
11 is copied (step 604). Further, the virtual memory management table group such as the area group management table 700 and the allocated area management table 710 for these areas is also copied (step 605).

【0036】さらに、共有及び複写対象領域の各セグメ
ントのページテーブルに対応する実記憶管理テーブルエ
ントリ151に対して、共有フラグ153をオン
(‘Y’)にするとともに、カウンタ152を1加算
し、複写対象領域に対応したエントリ151に対して
は、複写属性フラグ154もオン(‘Y’)にする(ス
テップ606)。
Further, the sharing flag 153 is turned on ('Y') and the counter 152 is incremented by 1 for the real storage management table entry 151 corresponding to the page table of each segment of the sharing and copying target area. For the entry 151 corresponding to the copy target area, the copy attribute flag 154 is also turned on ('Y') (step 606).

【0037】被生成アドレス空間において、図5の状態
にある書込可能領域のセグメント内のいずれかのページ
に対する最初の参照または書込のいずれかのアクセス
(コピーオンライトの場合は書込のみ)が発生すると、
アクセスが発生したページ以外のページは、実ページの
みを共有した図8の状態に変化する。即ち、ページへの
アクセスによりセグメント変換例外割込みが発生し、セ
グメント変換例外解決処理にて共有ページテーブルを複
写するとともにアクセスしたページのみを複写する(ア
ドレス空間生成処理のステップ603でページテーブル
の各エントリの無効フラグをオンにする場合、ページ変
換例外割込みが発生し、ページ変換例外解決処理におい
て共有ページテーブル及びアクセスしたページを複写す
る)ことにより、当該ページと同一セグメント内の他の
ページは実ページのみを共有した状態となる(コピーオ
ンライトの場合、書込により書込保護例外割込みが発生
し、書込保護例外解決処理にて同様に、共有ページテー
ブル及びアクセスしたページを複写する)。ただし、ア
クセスの発生したセグメント内の全ページを複写しても
良い。なお、図8においては被生成アドレス空間でアク
セスが発生した場合について示したが、生成要求側アド
レス空間やセグメントを共有している他のアドレス空間
でアクセスが発生した場合も同様である。以下、被生成
アドレス空間でアクセスが発生した場合について説明す
る。
In the generated address space, either the first reference or the write access to any page in the segment of the writable area in the state of FIG. 5 (only the write in the case of copy-on-write) Occurs,
Pages other than the accessed page change to the state of FIG. 8 in which only real pages are shared. That is, a segment conversion exception interrupt is generated by accessing a page, and the shared page table is copied in the segment conversion exception resolution process and only the accessed page is copied (each entry of the page table in step 603 of the address space generation process). When the invalid flag of is turned on, a page conversion exception interrupt occurs and the shared page table and the accessed page are copied in the page conversion exception resolution processing), so that other pages in the same segment as the page are real pages. Only the shared state is shared (in the case of copy-on-write, a write protection exception interrupt is generated by writing, and the shared page table and the accessed page are similarly copied in the write protection exception resolution processing). However, all pages in the accessed segment may be copied. Although FIG. 8 shows the case where the access is generated in the generated address space, the same is true when the access is generated in the generation requesting side address space or another address space sharing the segment. The case where an access occurs in the generated address space will be described below.

【0038】図9に、コピーオンリファレンスの場合に
おけるセグメント変換例外解決処理のフローチャートを
示す。コピーオンライトの場合には、書込保護例外解決
処理にて同様の処理を行う。
FIG. 9 shows a flowchart of the segment conversion exception resolution processing in the case of copy-on-reference. In the case of copy-on-write, similar processing is performed in the write protection exception resolution processing.

【0039】最初に、変換例外の発生したセグメントの
ページテーブル120bに対する実記憶管理テーブルエ
ントリ151の複写属性フラグ154がオンかどうかを
判定する(ステップ901)。フラグ154がオフなら
ば、従来と同様に、通常のセグメント変換例外として処
理する(ステップ902)。フラグ154がオンなら
ば、当該セグメントのセグメントテーブルエントリ11
1の無効フラグ112をオフ(‘−’)(コピーオンラ
イトの場合、当該セグメント内の各ページに対する各ペ
ージテーブルエントリの書込保護フラグをオフ)にした
後、前記エントリ151内の共有度カウンタ152を参
照し、その値が0か否かを判定する(ステップ90
3)。カウンタ152が0であれば、既に他のアドレス
空間でセグメント変換例外が発生してページテーブルが
複写されているので、フラグ153及びフラグ154を
オフにし、ページテーブルを変換例外が発生したアドレ
ス空間のみのものとする(ステップ904)。
First, it is determined whether the copy attribute flag 154 of the real storage management table entry 151 for the page table 120b of the segment in which the conversion exception has occurred is on (step 901). If the flag 154 is off, it is processed as a normal segment conversion exception as in the conventional case (step 902). If the flag 154 is ON, the segment table entry 11 of the segment
The invalidity flag 112 of 1 is turned off ('-') (in the case of copy-on-write, the write protection flag of each page table entry for each page in the segment is turned off), and then the sharing degree counter in the entry 151 is set. Referring to 152, it is determined whether the value is 0 (step 90).
3). If the counter 152 is 0, the segment conversion exception has already occurred in another address space and the page table has already been copied. Therefore, the flags 153 and 154 are turned off and only the address space in which the page table conversion exception has occurred is turned off. (Step 904).

【0040】カウンタ152が0でなければ、他に当該
ページテーブルを共有するアドレス空間が存在するた
め、カウンタ152を1減算したのち(ステップ90
5)、アクセスされたページに対するエントリ以外の当
該ページテーブル120b内のエントリ121の無効フ
ラグ122をオンにする(ステップ906)。次に、ペ
ージにアクセスした被生成アドレス空間のページテーブ
ル120aのために新たな実ページを割当ててページテ
ーブル120bの内容を複写し、対応する実記憶管理テ
ーブルエントリ151の共有度カウンタ152を0、共
有フラグ153及び複写属性フラグ154をオフに設定
するとともに、セグメントテーブルエントリに当該実ペ
ージのアドレスを設定し、無効フラグ112をオフにす
る(ステップ907)。そして、変換例外を起こしたペ
ージと同一セグメント内の他のページに対応する実記憶
管理テーブルエントリ151の複写属性フラグ154を
オンに設定することにより、これらのページをコピーオ
ンリファレンス状態(コピーオンライトの場合はコピー
オンライト状態)にする(ステップ908)。ここで、
変換例外を起こしたセグメント内の全ページを複写して
も良い。また、セグメント内の全ページをページアウト
して補助記憶を共有しても良い。さらに、変換例外を起
こしたページの内容を新たに割り当てた実ページに複写
し、対応する実記憶管理テーブルエントリ151の共有
度カウンタ152を0、共有フラグ153及び複写属性
フラグ154をオフに設定するとともに、アクセスが発
生したアドレス空間のページテーブル120a中の該当
するページテーブルエントリに当該実ページのアドレス
を設定する(ステップ909)。
If the counter 152 is not 0, there is another address space sharing the page table, so the counter 152 is decremented by 1 (step 90).
5) The invalid flag 122 of the entry 121 in the page table 120b other than the entry for the accessed page is turned on (step 906). Next, a new real page is allocated for the page table 120a of the generated address space that accessed the page, the contents of the page table 120b are copied, and the sharing degree counter 152 of the corresponding real storage management table entry 151 is set to 0, The share flag 153 and the copy attribute flag 154 are set to OFF, the address of the real page is set to the segment table entry, and the invalid flag 112 is set to OFF (step 907). Then, by setting the copy attribute flag 154 of the real storage management table entry 151 corresponding to another page in the same segment as the page in which the conversion exception has occurred to ON, these pages are set to the copy-on reference state (copy-on-write). If it is, the copy-on-write state is set (step 908). here,
All pages in the segment that caused the conversion exception may be copied. Alternatively, all pages in the segment may be paged out to share the auxiliary storage. Furthermore, the contents of the page that caused the conversion exception are copied to the newly allocated real page, and the sharing degree counter 152 of the corresponding real storage management table entry 151 is set to 0, and the sharing flag 153 and the copy attribute flag 154 are set to off. At the same time, the address of the real page is set in the corresponding page table entry in the page table 120a of the address space where the access occurred (step 909).

【0041】図8の状態にある書込可能領域のページに
対して参照または書込のいずれかのアクセス(コピーオ
ンライトの場合は書込のみ)が行われると、図10の状
態に変化する。即ち、アクセスによりページ変換例外割
込みが発生し、ページ変換例外解決処理にてページを複
写する(コピーオンライトの場合、書込保護例外割込み
が発生し、書込保護例外解決処理にてページを複写す
る)ことにより、アクセスされたページ及びページテー
ブルはともに非共有状態、即ち図4と同様の状態とな
る。
When a reference or a write access (write only in the case of copy-on-write) is performed on the page of the writable area in the state of FIG. 8, the state changes to that of FIG. . That is, a page conversion exception interrupt is generated by the access, and the page is copied in the page conversion exception resolution processing (in the case of copy-on-write, a write protection exception interrupt is generated and the page is copied in the write protection exception resolution processing. By doing so, the accessed page and page table are both in a non-shared state, that is, the same state as in FIG.

【0042】図11に、コピーオンリファレンスの場合
におけるページ変換例外解決処理のフローチャートを示
す。コピーオンライトの場合には、書込保護例外解決処
理にて同様の処理を行う。
FIG. 11 shows a flowchart of page conversion exception resolution processing in the case of copy-on-reference. In the case of copy-on-write, similar processing is performed in the write protection exception resolution processing.

【0043】まず、変換例外の発生したページに対する
実記憶管理テーブルエントリ151の複写属性フラグ1
54がオンかどうかを判定する(ステップ1101)。
複写属性フラグ154がオフならば、従来と同様に、ペ
ージ変換例外として新たな実ページを割当てる(ステッ
プ1102)。フラグ154がオンならば、当該ページ
のページテーブルエントリ121の無効フラグ122を
オフ(コピーオンライトの場合、当該エントリの書込保
護フラグをオフ)にした後、前記エントリ151内の共
有度カウンタ152を参照し、その値が0か否かを判定
する(ステップ1103)。カウンタ152が0であれ
ば、すでに他のアドレス空間でページ変換例外が発生し
てページが複写されているので、フラグ153及びフラ
グ154をオフにし、実ページテーブルを変換例外を起
こしたアドレス空間のみのものとする(ステップ110
4)。
First, the copy attribute flag 1 of the real storage management table entry 151 for the page in which the conversion exception has occurred
It is determined whether 54 is on (step 1101).
If the copy attribute flag 154 is off, a new real page is allocated as a page conversion exception as in the conventional case (step 1102). If the flag 154 is on, the invalidity flag 122 of the page table entry 121 of the page is turned off (in the case of copy-on-write, the write protection flag of the entry is turned off), and then the sharing degree counter 152 in the entry 151. Is checked to determine whether the value is 0 (step 1103). If the counter 152 is 0, the page conversion exception has already occurred in another address space and the page has been copied. Therefore, the flags 153 and 154 are turned off and only the address space in which the conversion exception has occurred in the real page table is turned off. (Step 110)
4).

【0044】カウンタ152が0でなければ、他にペー
ジを共有するアドレス空間が存在するため、カウンタ1
52を1減算したのち(ステップ1105)、新たな実
ページを割当ててページの内容を複写する(ステップ1
106)。そして、当該ページに対するページテーブル
エントリに当該実ページのアドレスを設定し、無効フラ
グ122をオフにする(ステップ1107)。
If the counter 152 is not 0, there is another address space sharing the page, so the counter 1
After subtracting 1 from 52 (step 1105), a new real page is allocated and the contents of the page are copied (step 1).
106). Then, the address of the real page is set in the page table entry for the page, and the invalid flag 122 is turned off (step 1107).

【0045】最後に、領域解放処理について説明する。
アドレス空間終了時等において共有ページまたは共有セ
グメントを解放する場合、これらの領域や当該セグメン
トのページテーブルに割当てられた実ページに対する実
記憶管理テーブルエントリ151中の共有度カウンタ1
52を減算するだけで、実ページ自体は解放しない。
Finally, the area release processing will be described.
When releasing a shared page or shared segment at the end of the address space, etc., the sharedness counter 1 in the real storage management table entry 151 for the real page allocated to these areas and the page table of the segment.
Only 52 is subtracted, the actual page itself is not released.

【0046】図12に、セグメントに対する領域解放処
理のフローチャートを示す。まず、解放対象のセグメン
トのページテーブルに対する実記憶管理テーブルエント
リ151中の共有度カウンタ152を参照し、その値が
0か否かを判定する(ステップ1201)。カウンタ1
52が0でなければ、他にページテーブルを共有してい
るアドレス空間があるため、当該カウンタ152を1減
算するだけで、ページテーブル及びセグメント内の各ペ
ージに割当てられた実ページを解放しない(ステップ1
202)。当該カウンタ152が0の場合は、セグメン
ト内の各ページについて、当該ページに割当てられた実
ページの共有有無を判定し(実ページに対する実記憶管
理テーブルエントリ151の共有度カウンタ152が0
ならば非共有、0でないならば共有)、共有されていな
ければ実ページを解放し、共有されていれば実ページを
解放せず、当該実ページに対する共有度カウンタ152
を1減算することのみ行う(ステップ1203)。そし
て、当該セグメントに対するセグメントテーブルエント
リの無効フラグをオンに設定するとともに、セグメント
のページテーブルに割当られた実ページを解放する(ス
テップ1204)。
FIG. 12 shows a flowchart of the area releasing process for the segment. First, the sharing degree counter 152 in the real storage management table entry 151 for the page table of the segment to be released is referred to, and it is determined whether or not the value is 0 (step 1201). Counter 1
If 52 is not 0, there is another address space that shares the page table, so the counter 152 is simply decremented, and the real page allocated to each page in the page table and segment is not released ( Step 1
202). If the counter 152 is 0, it is determined whether or not the real page allocated to the page is shared for each page in the segment (the share degree counter 152 of the real storage management table entry 151 for the real page is 0).
If it is not shared, the real page is released, if it is not shared, the real page is not released, and the sharing degree counter 152 for the real page is released.
Is subtracted by 1 (step 1203). Then, the invalid flag of the segment table entry for the segment is set to ON, and the real page allocated to the page table of the segment is released (step 1204).

【0047】ページに対する領域解放の場合、当該ペー
ジを含むセグメントのページテーブルが他のアドレス空
間により共有されていなければ、上記のステップ120
3と同様に行えばよい。また、ページテーブルが他のア
ドレス空間により共有されている場合は、ページテーブ
ルを複写して非共有状態にした後、上記ステップ120
3と同様に行えばよい。
In the case of area release for a page, if the page table of the segment including the page is not shared by another address space, the above step 120 is performed.
It may be performed in the same manner as 3. If the page table is shared by another address space, the page table is copied into a non-shared state, and then the above step 120 is performed.
It may be performed in the same manner as 3.

【0048】なお、セグメントやページ以外の単位で領
域が解放される場合については、どの領域が解放された
かを記憶しておき、セグメントまたはページ内の領域全
体が解放された時点で、上記手順で当該セグメントやペ
ージに対して領域解放処理を行えばよい。
When an area is released in units other than a segment or a page, which area is released is stored, and when the entire area in the segment or page is released, the procedure described above is used. The area release process may be performed on the segment or page.

【0049】3レベル以上のアドレス変換テーブルを有
する計算機システムの場合、最上位レベルのアドレス変
換テーブルはセグメントテーブルと同様にアドレス空間
生成時に複写し、他のレベルのアドレス変換テーブルに
対してはページテーブルと同様に参照または書込(コピ
ーオンライトの場合、書込のみ)が発生した時に複写す
るようにすればよい。
In the case of a computer system having three or more levels of address translation table, the highest level address translation table is copied at the time of address space generation like the segment table, and page tables are used for other level address translation tables. Similarly, the copying may be performed when reference or writing (in the case of copy-on-write, writing only) occurs.

【0050】また、3レベル以上のアドレス変換テーブ
ルを有する計算機システムの場合、読込専用領域及び書
込可能領域の大きさや境界属性に応じて、共有又はコピ
ーオンリファレンス若しくはコピーオンライトするアド
レス変換テーブルの範囲を決定するようにしてもよい。
即ち、アドレス空間生成時、読込専用領域及び書込可能
領域の大きさや境界属性に応じた範囲のアドレス変換テ
ーブルを共有するために、各アドレス変換テーブルが管
理する領域が読込専用領域のみから構成されるかあるい
は書込可能領域のみから構成されるかを判定する。その
いずれでもない場合、新たに生成したアドレス空間に対
して前記領域を管理するアドレス変換テーブルを作成
し、作成したアドレス変換テーブルのアドレスを該アド
レス変換テーブルを管理する1レベル上位のアドレス変
換テーブルの該当するエントリに設定する。前記判定に
おいてアドレス変換テーブルが管理する領域が読込専用
領域のみから構成されるか又は書込可能領域のみから構
成される場合、1レベル上位のアドレス変換テーブルの
該領域を管理するエントリを新たに生成したアドレス空
間の対応するアドレス変換テーブルに複写する。そし
て、該エントリによって管理されるアドレス変換テーブ
ル及び該アドレス変換テーブルよりも下位レベルのアド
レス変換テーブル並びに該アドレス変換テーブル群が管
理する実記憶領域を生成要求側アドレス空間及び新たに
生成したアドレス空間で共有する。
Further, in the case of a computer system having an address conversion table of three levels or more, an address conversion table for sharing or copy-on reference or copy-on-write depending on the size of the read-only area and the writable area and the boundary attribute. The range may be determined.
That is, when the address space is generated, the area managed by each address conversion table is composed of only the read-only area in order to share the address conversion table in the range according to the size and boundary attribute of the read-only area and the writable area. Or whether it is composed only of the writable area. If none of the above, an address translation table for managing the area is created for the newly created address space, and the address of the created address translation table is stored in the address translation table one level higher for managing the address translation table. Set in the corresponding entry. When the area managed by the address conversion table in the determination is composed of only the read-only area or the writable area, a new entry for managing the area of the address conversion table one level higher is newly generated. Copy to the corresponding address translation table in the specified address space. The address translation table managed by the entry, the address translation table at a lower level than the address translation table, and the real storage area managed by the address translation table group are created in the creation requesting address space and the newly created address space. Share.

【0051】[0051]

【発明の効果】本発明によれば、アドレス空間生成時に
ページテーブル等の下位レベルのアドレス変換テーブル
の作成が不要なため、アドレス空間生成処理のCPUオ
ーバヘッドを削減できる。また、参照または書込が発生
するまで下位レベルのアドレス変換テーブルを複数のア
ドレス空間の間で共有することにより、これらのアドレ
ス変換テーブルの所要メモリを削減することができる。
According to the present invention, since it is not necessary to create a lower-level address conversion table such as a page table when generating an address space, the CPU overhead of the address space generation processing can be reduced. Further, by sharing the lower-level address translation table among a plurality of address spaces until reference or writing occurs, it is possible to reduce the required memory of these address translation tables.

【図面の簡単な説明】[Brief description of drawings]

【図1】本発明の仮想記憶装置の制御方法を示す図。FIG. 1 is a diagram showing a method of controlling a virtual storage device of the present invention.

【図2】UNIXにおける仮想記憶装置の制御方法を示
す図。
FIG. 2 is a diagram showing a method of controlling a virtual storage device in UNIX.

【図3】セグメンテーションページング方式の仮想記憶
装置の制御方法を示す図。
FIG. 3 is a diagram illustrating a method of controlling a virtual storage device of a segmentation paging method.

【図4】非共有状態のセグメントに関する仮想記憶装置
の制御方法を示す図。
FIG. 4 is a diagram showing a method of controlling a virtual storage device regarding a segment in a non-shared state.

【図5】セグメント共有状態の仮想記憶装置の制御方法
を示す図。
FIG. 5 is a diagram showing a method of controlling a virtual storage device in a segment sharing state.

【図6】アドレス空間生成処理のフローチャート。FIG. 6 is a flowchart of address space generation processing.

【図7】仮想記憶管理用テーブル群の構造を示す図。FIG. 7 is a diagram showing the structure of a virtual memory management table group.

【図8】実ページ共有状態の仮想記憶装置の制御方法を
示す図。
FIG. 8 is a diagram showing a method of controlling a virtual storage device in a shared real page state.

【図9】セグメント変換例外解決処理のフローチャー
ト。
FIG. 9 is a flowchart of segment conversion exception resolution processing.

【図10】共有ページにアクセスした後の状態の仮想記
憶装置の制御方法を示す図。
FIG. 10 is a diagram showing a method of controlling a virtual storage device in a state after accessing a shared page.

【図11】ページ変換例外解決処理のフローチャート。FIG. 11 is a flowchart of page conversion exception resolution processing.

【図12】セグメントに対する領域解放処理のフローチ
ャート。
FIG. 12 is a flowchart of area release processing for a segment.

【符号の説明】[Explanation of symbols]

100…仮想記憶装置(アドレス空間)、110…セグ
メントテーブル、111…セグメントテーブルエント
リ、112…セグメント無効フラグ、120…ページテ
ーブル、121…ページテーブルエントリ、122…ペ
ージ無効フラグ、130…実記憶装置、131…実ペー
ジ、140…リージョンテーブル、150…実記憶管理
テーブル、151…実記憶管理テーブルエントリ、15
2…共有度カウンタ、153…共有フラグ、154…複
写属性フラグ、160…中央処理装置、700…領域グ
ループ管理テーブル、701…読込専用領域フラグ、7
02…領域共有属性フラグ、710…割当領域管理テー
ブル。
100 ... Virtual storage device (address space), 110 ... Segment table, 111 ... Segment table entry, 112 ... Segment invalid flag, 120 ... Page table, 121 ... Page table entry, 122 ... Page invalid flag, 130 ... Real storage device, 131 ... Real page, 140 ... Region table, 150 ... Real storage management table, 151 ... Real storage management table entry, 15
2 ... Shareability counter, 153 ... Share flag, 154 ... Copy attribute flag, 160 ... Central processing unit, 700 ... Area group management table, 701 ... Read-only area flag, 7
02 ... Area sharing attribute flag, 710 ... Allocation area management table.

───────────────────────────────────────────────────── フロントページの続き (72)発明者 鵜飼 良夫 神奈川県横浜市戸塚区戸塚町5030番地 株 式会社日立製作所ソフトウェア開発本部内 ─────────────────────────────────────────────────── ─── Continuation of the front page (72) Inventor Yoshio Ukai 5030 Totsuka-cho, Totsuka-ku, Yokohama-shi, Kanagawa Incorporated company Hitachi Ltd. Software Development Division

Claims (12)

【特許請求の範囲】[Claims] 【請求項1】複数レベルのアドレス変換テーブルを有す
る多重仮想記憶方式の計算機システムにおいて、第一の
アドレス空間で実行中のプログラムからの新たな第二の
アドレス空間生成の要求に応じて、前記第二のアドレス
空間に対する前記アドレス変換テーブルを作成する際に
最上位レベルのアドレス変換テーブルのみを作成し、該
最上位レベルのアドレス変換テーブルに、前記第一のア
ドレス空間に対する最上位レベルのアドレス変換テーブ
ル中の実記憶領域割当済の領域を管理するエントリを複
写することにより、前記最上位レベルのアドレス変換テ
ーブルよりも下位のアドレス変換テーブル及び該アドレ
ス変換テーブルに対応する領域を前記第一のアドレス空
間及び前記第二のアドレス空間の間で共有することを特
徴とする仮想記憶装置の制御方法。
1. A computer system of a multiple virtual memory system having a plurality of levels of address translation tables, wherein the first second address space is requested by a program being executed in the first address space to generate a new second address space. Only the highest level address translation table is created when creating the address translation table for the second address space, and the highest level address translation table is added to the highest level address translation table. By duplicating an entry for managing an area to which a real storage area has been allocated, an address conversion table lower than the highest-level address conversion table and an area corresponding to the address conversion table are set to the first address space. And a virtual memory which is shared between the second address space Method of controlling the location.
【請求項2】複数レベルのアドレス変換テーブルを有す
る多重仮想記憶方式の計算機システムにおいて、第一の
アドレス空間で実行中のプログラムからの新たな第二の
アドレス空間生成の要求に応じて、前記第一のアドレス
空間に対する前記アドレス変換テーブルについて、該ア
ドレス変換テーブルが管理する領域が読込専用領域のみ
から構成されるかあるいは書込可能領域のみから構成さ
れるかを判定し、いずれでもない場合、前記第二のアド
レス空間に対する前記領域を管理するアドレス変換テー
ブルを作成し、作成したアドレス変換テーブルのアドレ
スを該アドレス変換テーブルを管理する1レベル上位の
アドレス変換テーブルの該当するエントリに設定し、前
記判定において前記アドレス変換テーブルが管理する領
域が読込専用領域のみから構成されるか又は書込可能領
域のみから構成される場合、該アドレス変換テーブルを
管理する1レベル上位のアドレス変換テーブルの該当す
るエントリを該アドレス変換テーブルに対応する前記第
二のアドレス空間のアドレス変換テーブルに複写するこ
とにより、該エントリによって管理されるアドレス変換
テーブル及び該アドレス変換テーブルよりも下位レベル
のアドレス変換テーブル並びに該アドレス変換テーブル
群が管理する実記憶領域を前記第一のアドレス空間及び
前記第二のアドレス空間で共有することを特徴とする仮
想記憶装置の制御方法。
2. A computer system of a multi-virtual memory system having a plurality of levels of address translation tables, wherein said second address space is generated in response to a request from a program being executed in the first address space to generate a new second address space. With respect to the address conversion table for one address space, it is determined whether the area managed by the address conversion table is composed of only a read-only area or only a writable area. An address translation table that manages the area for the second address space is created, and the address of the created address translation table is set in the corresponding entry of the address translation table that is one level higher than the address translation table that is managed. In the above, the area managed by the address conversion table is a read-only area Only or only a writable area, the corresponding entry in the address translation table one level higher that manages the address translation table corresponds to the second address space corresponding to the address translation table. Of the address translation table managed by the entry, the address translation table at a lower level than the address translation table, and the real storage area managed by the address translation table group by copying to the first address. A method of controlling a virtual storage device, comprising: sharing the space and the second address space.
【請求項3】前記第二のアドレス空間生成の要求に応じ
て、前記第一のアドレス空間に対するアドレス変換テー
ブルのエントリを前記第二のアドレス空間の対応するア
ドレス変換テーブルに複写するときに、該エントリが管
理する領域がコピーオンリファレンスの対象であればそ
の旨を示す判別子を前記エントリに対して設定し、前記
第一のアドレス空間及び前記第二のアドレス空間のいず
れかのページに対する参照または書込のいずれかのアク
セス要求に応じて、各アドレス変換テーブルエントリに
ついて、該エントリが管理する領域が前記ページを含み
かつ該エントリに対する前記判別子が設定されていれ
ば、該判別子をリセットし、該エントリを含むアドレス
変換テーブルよりも下位レベルかつ前記ページを含む領
域を管理するアドレス変換テーブルを前記アクセス要求
が発生したアドレス空間に対して作成し、作成したアド
レス変換テーブルに該アドレス変換テーブルに対応する
元のアドレス変換テーブル中の前記ページを含まない領
域に対するエントリを複写するとともに、該エントリに
対して前記判別子を設定し、作成したアドレス変換テー
ブルのアドレスを該アドレス変換テーブルを管理する1
レベル上位のアドレス変換テーブルの該当するエントリ
に設定し、前記ページの内容を新たに割当てた実記憶領
域に複写するとともに、該実記憶領域のアドレスを前記
アクセス要求が発生したアドレス空間に対する最下位レ
ベルのアドレス変換テーブルの前記ページに対するエン
トリに設定することを特徴とする請求項1又は請求項2
のいずれか一に記載の仮想記憶装置の制御方法。
3. When copying an entry of an address translation table for the first address space to a corresponding address translation table of the second address space in response to a request for generating the second address space, If the area managed by the entry is a copy-on-reference target, a discriminator indicating that is set for the entry, and a reference to any page of the first address space and the second address space is set or In response to one of the write access requests, for each address translation table entry, if the area managed by the entry includes the page and the discriminator for the entry is set, the discriminator is reset. , An address which manages an area including the page at a lower level than the address conversion table including the entry. A translation table is created for the address space where the access request is generated, and an entry for an area not including the page in the original address translation table corresponding to the address translation table is copied to the created address translation table, Set the discriminator for the entry and manage the address of the created address translation table in the address translation table 1
The contents of the page are copied to a newly allocated real memory area by setting the corresponding entry in the address translation table of the higher level, and the address of the real memory area is set to the lowest level for the address space where the access request is issued. 3. The entry is set for the page in the address translation table of 1.
A method for controlling a virtual storage device according to any one of 1.
【請求項4】前記第二のアドレス空間生成の要求に応じ
て、前記第一のアドレス空間に対するアドレス変換テー
ブルのエントリを前記第二のアドレス空間の対応するア
ドレス変換テーブルに複写するときに、該エントリが管
理する領域がコピーオンリファレンスの対象であればそ
の旨を示す判別子を前記エントリに対して設定し、前記
第一のアドレス空間及び前記第二のアドレス空間のいず
れかのページに対する参照または書込のいずれかのアク
セス要求に応じて、各アドレス変換テーブルエントリに
ついて、該エントリが管理する領域が前記ページを含み
かつ該エントリに対する前記判別子が設定されていれ
ば、該判別子をリセットし、該エントリを含むアドレス
変換テーブルよりも下位レベルかつ前記ページを含む領
域を管理するアドレス変換テーブルを前記アクセス要求
が発生したアドレス空間に対して作成し、最下位レベル
以外の作成したアドレス変換テーブルに該アドレス変換
テーブルに対応する元のアドレス変換テーブル中の前記
ページを含まない領域に対するエントリを複写するとと
もに、該エントリに対して前記判別子を設定し、作成し
たアドレス変換テーブルのアドレスを該アドレス変換テ
ーブルを管理する1レベル上位のアドレス変換テーブル
の該当するエントリに設定し、前記ページに対するエン
トリを含む最下位レベルのアドレス変換テーブルの各エ
ントリに対し、該エントリが管理するページの内容を新
たに割当てた実記憶領域に複写するとともに、該エント
リに該実記憶領域のアドレスを設定することを特徴とす
る請求項1又は請求項2のいずれか一に記載の仮想記憶
装置の制御方法。
4. When copying an entry of an address translation table for the first address space to a corresponding address translation table of the second address space in response to a request for generation of the second address space, If the area managed by the entry is a copy-on-reference target, a discriminator indicating that is set for the entry, and a reference to any page of the first address space and the second address space is set or In response to one of the write access requests, for each address translation table entry, if the area managed by the entry includes the page and the discriminator for the entry is set, the discriminator is reset. , An address which manages an area including the page at a lower level than the address conversion table including the entry. An entry is made for an area that does not include the page in the original address translation table corresponding to the address translation table created in a created address translation table other than the lowest level, by creating a translation table for the address space where the access request occurs. And the discriminator is set for the entry, and the address of the created address translation table is set to the corresponding entry of the address translation table one level higher that manages the address translation table. For each entry of the lowest-level address conversion table including the entry, copy the contents of the page managed by the entry into a newly allocated real storage area, and set the address of the real storage area in the entry. Either claim 1 or claim 2 characterized in that The method of the virtual storage apparatus according.
【請求項5】読込専用領域と書込可能領域とが別の領域
グループに属するように仮想記憶装置内の領域をグルー
プ分けし、前記領域グループ毎に、該領域グループに属
する領域が共有または複写のいずれかの対象であるか否
かを示す第一のフラグと、該領域グループに属する領域
が読込専用領域であるか書込可能領域であるかを判別す
る第二のフラグとを設け、前記第二のアドレス空間生成
の要求に応じて、前記第一のフラグの判定結果が共有ま
たは複写のいずれかの対象であることを示す領域を前記
第一のアドレス空間及び前記第二のアドレス空間で共有
するとともに、前記第二のフラグの判定結果が書込可能
領域であることを示す領域をコピーオンリファレンスの
対象とすることを特徴とする請求項3又は請求項4のい
ずれか一に記載の仮想記憶装置の制御方法。
5. An area in a virtual storage device is divided into groups such that a read-only area and a writable area belong to different area groups, and areas belonging to the area group are shared or copied for each area group. And a second flag for determining whether the area belonging to the area group is a read-only area or a writable area. In response to a request for second address space generation, an area indicating that the determination result of the first flag is a target of sharing or copying is set in the first address space and the second address space. 5. The copy-on-reference is performed on an area which is shared and which indicates that the determination result of the second flag is a writable area, according to any one of claims 3 and 4. The method of virtual storage.
【請求項6】前記第二のアドレス空間生成の要求に応じ
て、前記第一のアドレス空間に対するアドレス変換テー
ブルのエントリを前記第二のアドレス空間の対応するア
ドレス変換テーブルに複写するときに、該エントリが管
理する領域がコピーオンライトの対象であればその旨を
示す判別子を前記エントリに対して設定し、前記第一の
アドレス空間及び前記第二のアドレス空間のいずれかの
ページに対する書込要求に応じて、各アドレス変換テー
ブルエントリについて、該エントリが管理する領域が前
記ページを含みなおかつ該エントリに対する前記判別子
が設定されていれば、該判別子をリセットし、該エント
リを含むアドレス変換テーブルよりも下位レベルかつ前
記ページを含む領域を管理するアドレス変換テーブルを
前記書込要求が発生したアドレス空間に対して作成し、
作成したアドレス変換テーブルに該アドレス変換テーブ
ルに対応する元のアドレス変換テーブル中の前記ページ
を含まない領域に対するエントリを複写するとともに、
該エントリに対して前記判別子を設定し、作成したアド
レス変換テーブルのアドレスを該アドレス変換テーブル
を管理する1レベル上位のアドレス変換テーブルの該当
するエントリに設定し、前記ページの内容を新たに割当
てた実記憶領域に複写するとともに、該実記憶領域のア
ドレスを前記書込要求が発生したアドレス空間に対する
最下位レベルのアドレス変換テーデルの前記ページに対
するエントリに設定することを特徴とする請求項1又は
請求項2のいずれか一に記載の仮想記憶装置の制御方
法。
6. When the entry of the address translation table for the first address space is copied to the corresponding address translation table of the second address space in response to the request for generating the second address space, If the area managed by the entry is a copy-on-write target, a discriminator indicating that is set for the entry, and writing to any page of the first address space and the second address space is performed. In response to a request, for each address translation table entry, if the area managed by the entry includes the page and the discriminator for the entry is set, the discriminator is reset and the address translation including the entry is performed. The write request is issued to the address translation table that manages the area including the page at a lower level than the table. Created for the address space,
While copying the entry for the area not including the page in the original address translation table corresponding to the address translation table to the created address translation table,
The discriminator is set for the entry, the address of the created address translation table is set in the corresponding entry of the address translation table one level higher that manages the address translation table, and the contents of the page are newly assigned. 2. The data is copied to the real storage area, and the address of the real storage area is set in the entry for the page of the lowest-level address translation tabler for the address space where the write request is generated. The control method of the virtual storage device according to claim 2.
【請求項7】前記第二のアドレス空間生成の要求に応じ
て、前記第一のアドレス空間に対するアドレス変換テー
ブルのエントリを前記第二のアドレス空間の対応するア
ドレス変換テーブルに複写するときに、該エントリが管
理する領域がコピーオンライトの対象であればその旨を
示す判別子を前記エントリに対して設定し、前記第一の
アドレス空間及び前記第二のアドレス空間のいずれかの
ページに対する書込要求に応じて、各アドレス変換テー
ブルエントリについて、該エントリが管理する領域が前
記ページを含みなおかつ該エントリに対する前記判別子
が設定されていれば、該判別子をリセットし、該エント
リを含むアドレス変換テーブルよりも下位レベルかつ前
記ページを含む領域を管理するアドレス変換テーブルを
前記書込要求が発生したアドレス空間に対して作成し、
最下位レベル以外の作成したアドレス変換テーブルに該
アドレス変換テーブルに対応する元のアドレス変換テー
ブル中の前記ページを含まない領域に対するエントリを
複写するとともに、該エントリに対して前記判別子を設
定し、作成したアドレス変換テーブルのアドレスを該ア
ドレス変換テーブルを管理する1レベル上位のアドレス
変換テーブルの該当するエントリに設定し、前記ページ
に対するエントリを含む最下位レベルのアドレス変換テ
ーブルの各エントリに対し、該エントリが管理するペー
ジの内容を新たに割当てた実記憶領域に複写するととも
に、該エントリに該実記憶領域のアドレスを設定するこ
とを特徴とする請求項1又は請求項2のいずれか一に記
載の仮想記憶装置の制御方法。
7. When copying an entry of an address translation table for the first address space to a corresponding address translation table of the second address space in response to a request for generation of the second address space, If the area managed by the entry is a copy-on-write target, a discriminator indicating that is set for the entry, and writing to any page of the first address space and the second address space is performed. In response to a request, for each address translation table entry, if the area managed by the entry includes the page and the discriminator for the entry is set, the discriminator is reset and the address translation including the entry is performed. The write request is issued to the address translation table that manages the area including the page at a lower level than the table. Created for the address space,
Copying an entry for an area not including the page in the original address translation table corresponding to the address translation table to the created address translation table other than the lowest level, and setting the discriminator for the entry, The address of the created address translation table is set to the corresponding entry of the address translation table of one level higher that manages the address translation table, and for each entry of the address translation table of the lowest level including the entry for the page, 3. The content of a page managed by an entry is copied to a newly allocated real storage area, and the address of the real storage area is set in the entry, according to any one of claims 1 and 2. Control method of virtual memory device of the above.
【請求項8】読込専用領域と書込可能領域とが別の領域
グループに属するように仮想記憶装置内の領域をグルー
プ分けし、前記領域グループ毎に、該領域グループに属
する領域が共有または複写のいずれかの対象であるか否
かを示す第一のフラグと、該領域グループに属する領域
が読込専用領域であるか書込可能領域であるかを判別す
る第二のフラグとを設け、前記第二のアドレス空間生成
の要求に応じて、前記第一のフラグの判定結果が共有ま
たは複写のいずれかの対象であることを示す領域を前記
第一のアドレス空間及び前記第二のアドレス空間で共有
するとともに、前記第二のフラグの判定結果が書込可能
領域であることを示す領域をコピーオンライトの対象と
することを特徴とする請求項6又は請求項7のいずれか
一に記載の仮想記憶装置の制御方法。
8. An area in a virtual storage device is divided into groups such that a read-only area and a writable area belong to different area groups, and the area belonging to the area group is shared or copied for each area group. And a second flag for determining whether the area belonging to the area group is a read-only area or a writable area. In response to a request for second address space generation, an area indicating that the determination result of the first flag is a target of sharing or copying is set in the first address space and the second address space. 8. The copy-on-write target is an area that is shared and indicates that the determination result of the second flag is a writable area. Virtual memo Method of controlling the apparatus.
【請求項9】前記アドレス変換テーブルエントリの無効
フラグ及び該エントリが管理する領域の複写方法を示す
複写属性フラグで該エントリに対する前記判別子を構成
し、各アドレス変換テーブルエントリに対する前記判別
子の設定有無を判定する際、該エントリの前記無効フラ
グの設定有無を判定し、該無効フラグが設定されている
場合さらに該エントリに対する前記複写属性フラグの設
定有無を判定し、該複写属性フラグが設定されていれば
該エントリに対して前記判別子が設定されていると判定
することを特徴とする請求項3乃至請求項8のいずれか
一に記載の仮想記憶装置の制御方法。
9. The discriminator for the entry is constituted by an invalid flag of the address translation table entry and a copy attribute flag indicating a copying method of an area managed by the entry, and the discriminator is set for each address translation table entry. When determining the presence or absence, it is determined whether or not the invalid flag of the entry is set, and when the invalid flag is set, it is further determined whether or not the copy attribute flag is set for the entry, and the copy attribute flag is set. 9. If it does, it is determined that the discriminator is set for the entry, and the method for controlling a virtual storage device according to any one of claims 3 to 8.
【請求項10】読込専用領域と書込可能領域とが前記最
上位のアドレス変換テーブルの異なるエントリに対応す
る領域に属するように前記アドレス空間内の領域を配置
することを特徴とする請求項1乃至請求項9のいずれか
一に記載の仮想記憶装置の制御方法。
10. The area in the address space is arranged such that the read-only area and the writable area belong to areas corresponding to different entries in the highest address conversion table. A method for controlling the virtual storage device according to claim 9.
【請求項11】2レベルのアドレス変換テーブルを有
し、前記最上位レベルのアドレス変換テーブルがセグメ
ントテーブルであり、前記最下位レベルのアドレス変換
テーブルがページテーブルであることを特徴とする請求
項1乃至請求項10のいずれか一に記載の仮想記憶装置
の制御方法。
11. A two-level address translation table, wherein the highest-level address translation table is a segment table and the lowest-level address translation table is a page table. A method for controlling a virtual storage device according to claim 10.
【請求項12】複数レベルのアドレス変換テーブルを有
する多重仮想記憶方式の計算機システムにおいて、第一
のアドレス空間で実行中のプログラムからの新たな第二
のアドレス空間生成の要求に応じて、前記第二のアドレ
ス空間に対する前記アドレス変換テーブルを作成するた
めの手段と、前記最上位レベルのアドレス変換テーブル
に前記第一のアドレス空間に対する最上位レベルのアド
レイ変換テーブル中の実記憶領域割当済の領域を管理す
るエントリを複写することにより、前記最上位レベルの
アドレス変換テーブルよりも下位のアドレス変換テーブ
ル及び該アドレス変換テーブルに対応する領域を前記第
一のアドレス空間及び前記第二のアドレス空間の間で共
有するための手段とを有し、前記アドレス変換テーブル
作成手段は最上位のアドレス変換テーブルのみを作成す
るように機能するものであることを特徴とする仮想記憶
装置の制御方法。
12. A computer system of a multiple virtual memory system having a plurality of levels of address translation tables, wherein the first second address space is requested in response to a new second address space generation request from a program being executed in the first address space. Means for creating the address translation table for the second address space, and an area already allocated to the real storage area in the highest level address translation table for the first address space in the highest level address translation table. By copying the entry to be managed, an address translation table lower than the highest-level address translation table and an area corresponding to the address translation table are provided between the first address space and the second address space. And a means for sharing, the address translation table creating means being the highest The method of the virtual storage apparatus characterized by and functions to create only the address conversion table.
JP5306247A 1993-12-07 1993-12-07 Virtual memory control method Pending JPH07160583A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP5306247A JPH07160583A (en) 1993-12-07 1993-12-07 Virtual memory control method

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP5306247A JPH07160583A (en) 1993-12-07 1993-12-07 Virtual memory control method

Publications (1)

Publication Number Publication Date
JPH07160583A true JPH07160583A (en) 1995-06-23

Family

ID=17954778

Family Applications (1)

Application Number Title Priority Date Filing Date
JP5306247A Pending JPH07160583A (en) 1993-12-07 1993-12-07 Virtual memory control method

Country Status (1)

Country Link
JP (1) JPH07160583A (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7055015B2 (en) 2002-02-25 2006-05-30 Ricoh Company, Ltd. Information processing apparatus in which processes can reduce overhead of memory access and efficiently share memory
JP2008077144A (en) * 2006-09-19 2008-04-03 Ricoh Co Ltd Virtualization system, memory management method, and control program
JP2015228227A (en) * 2008-02-25 2015-12-17 インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation Computer-readable program code logic, methods, and systems for facilitating management of storage in computing environments that support pageable guests
CN110347327A (en) * 2019-07-12 2019-10-18 网易(杭州)网络有限公司 Entry edit methods and touch control terminal

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7055015B2 (en) 2002-02-25 2006-05-30 Ricoh Company, Ltd. Information processing apparatus in which processes can reduce overhead of memory access and efficiently share memory
JP2008077144A (en) * 2006-09-19 2008-04-03 Ricoh Co Ltd Virtualization system, memory management method, and control program
JP2015228227A (en) * 2008-02-25 2015-12-17 インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation Computer-readable program code logic, methods, and systems for facilitating management of storage in computing environments that support pageable guests
US9542260B2 (en) 2008-02-25 2017-01-10 International Business Machines Corporation Managing storage protection faults
US9778869B2 (en) 2008-02-25 2017-10-03 International Business Machines Corporation Managing storage protection faults
US9971533B2 (en) 2008-02-25 2018-05-15 International Business Machines Corporation Managing storage protection faults
US10223015B2 (en) 2008-02-25 2019-03-05 International Business Machines Corporation Managing storage protection faults
US10768832B2 (en) 2008-02-25 2020-09-08 International Business Machines Corporation Managing storage protection faults
CN110347327A (en) * 2019-07-12 2019-10-18 网易(杭州)网络有限公司 Entry edit methods and touch control terminal

Similar Documents

Publication Publication Date Title
JP4160255B2 (en) Application programming interface that controls the allocation of physical memory in a virtual storage system by an application program
US5317728A (en) Storage management of a first file system using a second file system containing surrogate files and catalog management information
JP2575541B2 (en) Invalidation method of hierarchy of distributed cache
CA2275970C (en) Object and method for providing efficient multi-user access to shared operating system kernal code using instancing
US4742450A (en) Method to share copy on write segment for mapped files
US6085296A (en) Sharing memory pages and page tables among computer processes
JP2575543B2 (en) Simultaneous access management method
JP4718683B2 (en) Method and system for restoring physical memory state when focus is changed between application programs in a computer
US7528838B2 (en) Video memory management
US20090172337A1 (en) Cooperative mechanism for efficient application memory allocation
US5717926A (en) Efficient forking of a process
EP0232960A2 (en) Method for automatically extending the size of a segment in a page segmented virtual memory data processing system
EP0474395A2 (en) Data storage hierarchy with shared storage level
US7149873B2 (en) Methods and apparatus for a dual address space operating system
JPH05127995A (en) Method for securing consistency between pages which are in common with local cache
JP2001517829A (en) An application programming interface that controls the allocation of physical memory by classifying code or data by application programs in a virtual storage system.
Cranor et al. The UVM virtual memory system
US6457107B1 (en) Method and apparatus for reducing false sharing in a distributed computing environment
US5875487A (en) System and method for providing efficient shared memory in a virtual memory system
EP0747827B1 (en) System and method for providing shared memory in a multi-tasking environment
US6209061B1 (en) Integrated hierarchical memory overlay having invariant address space span that inactivates a same address space span in main memory
JP3485940B2 (en) Virtual storage control device and method
JPH07160583A (en) Virtual memory control method
US7444636B2 (en) Method and system of determining attributes of a functional unit in a multiple processor computer system
Heiser et al. A distributed single address-space operating system supporting persistence