JP2007520014A - 状況切換え環境中におけるアドレス変換技術 - Google Patents
状況切換え環境中におけるアドレス変換技術 Download PDFInfo
- Publication number
- JP2007520014A JP2007520014A JP2006551169A JP2006551169A JP2007520014A JP 2007520014 A JP2007520014 A JP 2007520014A JP 2006551169 A JP2006551169 A JP 2006551169A JP 2006551169 A JP2006551169 A JP 2006551169A JP 2007520014 A JP2007520014 A JP 2007520014A
- Authority
- JP
- Japan
- Prior art keywords
- virtual address
- address
- memory management
- management unit
- virtual
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/10—Address translation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/10—Address translation
- G06F12/1027—Address translation using associative or pseudo-associative address translation means, e.g. translation look-aside buffer [TLB]
- G06F12/1036—Address translation using associative or pseudo-associative address translation means, e.g. translation look-aside buffer [TLB] for multiple virtual address spaces, e.g. segmentation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/65—Details of virtual memory and virtual address translation
- G06F2212/656—Address space sharing
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
Description
計算機システムにおけるプロセッサは、仮想アドレスを物理アドレスにマップ(写像)するためにメモリ・マッピングを使用する。例えば、プロセッサの実行ユニットによって生成されるアドレス空間は、仮想アドレス空間と呼ばれる。システムで利用可能なハードウェアのメモリ位置に対応するアドレスは、物理アドレスと呼ばれる。
Claims (24)
- 仮想アドレスを受け取り、かつ対応する物理アドレスを提供するために形成されたメモリ管理ユニットにおいて、前記メモリ管理ユニットは、
仮想アドレスから物理アドレスへの1またはそれ以上の変換を含むストレージと、
前記仮想アドレスから修正仮想アドレスを生成する変換ロジックと、
前記修正仮想アドレスを前記対応する物理アドレスに変換するために形成されたページ・テーブル・ウォーク・ユニットと、
を含むことを特徴とするメモリ管理ユニット。 - 前記変換ロジックは、前記仮想アドレスの1またはそれ以上のビットが予め定める値を含む場合、前記仮想アドレスの前記1またはそれ以上のビットをプロセス識別子に置き換えるために形成されることを特徴とする請求項1記載のメモリ管理ユニット。
- 前記予め定める値は、0であることを特徴とする請求項2記載のメモリ管理ユニット。
- 前記メモリ管理ユニットは、算術論理演算ユニットから前記仮想アドレスを受け取るために形成されることを特徴とする請求項1記載のメモリ管理ユニット。
- 前記メモリ管理ユニットは、インクリメンタから前記仮想アドレスを受け取るために形成されることを特徴とする請求項1記載のメモリ管理ユニット。
- 前記仮想アドレスは、データ・アドレスを含むことを特徴とする請求項1記載のメモリ管理ユニット。
- 前記仮想アドレスは、命令アドレスを含むことを特徴とする請求項1記載のメモリ管理ユニット。
- 仮想アドレスから物理アドレスへの前記1またはそれ以上の変換は、プロセス識別子への更新で無効にされることを特徴とする請求項1記載のメモリ管理ユニット。
- 仮想アドレス部分に予め定める値と等しい1またはそれ以上のビットを有する仮想アドレスから物理アドレスへの変換だけが、プロセス識別子への更新で無効にされることを特徴とする請求項1記載のメモリ管理ユニット。
- 前記ストレージは、仮想アドレスから物理アドレスへの1またはそれ以上の直近に生成された変換を格納するために形成されることを特徴とする請求項1記載のメモリ管理ユニット。
- アンテナと、
メモリと、
前記アンテナおよび前記メモリに結合されたプロセッサと、を含むシステムにおいて、前記プロセッサは、
アドレス生成ユニット、および、
前記アドレス生成ユニットから仮想アドレスを受け取り、かつ対応する物理アドレスを提供するために形成されたメモリ管理ユニット、を含み、
前記メモリ管理ユニットは、
仮想アドレスから物理アドレスへの1またはそれ以上の変換を含むストレージ、
前記仮想アドレスから修正仮想アドレスを生成する変換ロジック、および、
前記修正仮想アドレスを前記対応する物理アドレスに変換するために形成されたページ・テーブル・ウォーク・ユニット、
を含むことを特著とするシステム。 - 前記変換ロジックは、前記仮想アドレスの1またはそれ以上のビットが予め定める値を含む場合、前記仮想アドレスの前記1またはそれ以上のビットをプロセス識別子に置き換えるために形成されることを特徴とする請求項11記載のシステム。
- 前記アドレス生成ユニットは、算術論理演算ユニットを含むことを特徴とする請求項11記載のシステム。
- 前記アドレス生成ユニットは、インクリメンタを含むことを特徴とする請求項11記載のシステム。
- 仮想アドレスから物理アドレスへの前記1またはそれ以上の変換は、プロセス識別子への更新で無効にされることを特徴とする請求項11記載のシステム。
- 仮想アドレス部分に予め定める値と等しい1またはそれ以上のビットを有する仮想アドレスから物理アドレスへの変換だけが、プロセス識別子への更新で無効にされることを特徴とする請求項11記載のシステム。
- 仮想アドレスを受け取る段階と、
前記仮想アドレスがストレージに物理アドレスに対する変換を有しているかどうか判断する段階と、
そうでない場合、前記仮想アドレスから修正仮想アドレスを生成する段階と、
前記修正仮想アドレスを物理アドレスに変換する段階と、
を含むことを特徴とする方法。 - 前記修正仮想アドレスを生成する段階は、前記仮想アドレスの1またはそれ以上のビットが予め定める値に等しい場合、前記仮想アドレスの前記1またはそれ以上のビットをプロセス識別子に置き換える段階を含むことを特徴とする請求項17記載の方法。
- 前記修正仮想アドレスを変換する段階は、ページ・テーブル・ウォークを実行する段階を含むことを特徴とする請求項17記載の方法。
- プロセス識別子が変化する場合、前記ストレージ中の変換をすべて無効にする段階をさらに含むことを特徴とする請求項17記載の方法。
- 予め定める値と等しい1またはそれ以上のビットからなる仮想アドレス部分を有する前記ストレージ中の変換だけを無効にする段階をさらに含むことを特徴とする請求項17記載の方法。
- 生成されたあらゆる変換を前記ストレージに置く段階をさらに含むことを特徴とする請求項17記載の方法。
- 前記仮想アドレスは、データ・アドレスであることを特徴とする請求項17記載の方法。
- 前記仮想アドレスは、命令アドレスであることを特徴とする請求項17記載の方法。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/773,847 US7519791B2 (en) | 2004-02-06 | 2004-02-06 | Address conversion technique in a context switching environment |
PCT/US2005/001234 WO2005078590A2 (en) | 2004-02-06 | 2005-01-14 | Address conversion technique in a context switching environment |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2010020031A Division JP2010134956A (ja) | 2004-02-06 | 2010-02-01 | 状況切換え環境中におけるアドレス変換技術 |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2007520014A true JP2007520014A (ja) | 2007-07-19 |
Family
ID=34826847
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2006551169A Pending JP2007520014A (ja) | 2004-02-06 | 2005-01-14 | 状況切換え環境中におけるアドレス変換技術 |
JP2010020031A Pending JP2010134956A (ja) | 2004-02-06 | 2010-02-01 | 状況切換え環境中におけるアドレス変換技術 |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2010020031A Pending JP2010134956A (ja) | 2004-02-06 | 2010-02-01 | 状況切換え環境中におけるアドレス変換技術 |
Country Status (6)
Country | Link |
---|---|
US (1) | US7519791B2 (ja) |
JP (2) | JP2007520014A (ja) |
KR (1) | KR100895715B1 (ja) |
MY (1) | MY140166A (ja) |
TW (1) | TWI295015B (ja) |
WO (1) | WO2005078590A2 (ja) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7676814B2 (en) * | 2004-03-25 | 2010-03-09 | Globalfoundries Inc. | Four layer architecture for network device drivers |
US20070011431A1 (en) * | 2005-06-27 | 2007-01-11 | Microsoft Corporation | ROM software breakpoints |
US20080005399A1 (en) * | 2006-05-16 | 2008-01-03 | Ati Technologies Inc. | Method and Apparatus for Determining the Status of Bus Requests and Responses |
US8250254B2 (en) * | 2007-07-31 | 2012-08-21 | Intel Corporation | Offloading input/output (I/O) virtualization operations to a processor |
US8140825B2 (en) * | 2008-08-05 | 2012-03-20 | International Business Machines Corporation | Systems and methods for selectively closing pages in a memory |
KR20120083160A (ko) | 2011-01-17 | 2012-07-25 | 삼성전자주식회사 | 메모리 관리 유닛, 이를 포함하는 장치들, 및 이의 동작 방법 |
KR102069273B1 (ko) * | 2013-03-11 | 2020-01-22 | 삼성전자주식회사 | 시스템 온 칩 및 그 동작방법 |
KR101821633B1 (ko) | 2013-03-14 | 2018-03-08 | 삼성전자주식회사 | 메모리 시스템 |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS5460528A (en) * | 1977-10-24 | 1979-05-16 | Hitachi Ltd | Multiple virtual memory control equipment |
JPS54111726A (en) * | 1978-02-22 | 1979-09-01 | Hitachi Ltd | Control unit for multiplex virtual memory |
US6061774A (en) * | 1997-05-23 | 2000-05-09 | Compaq Computer Corporation | Limited virtual address aliasing and fast context switching with multi-set virtual cache without backmaps |
GB2339037B (en) * | 1998-07-03 | 2002-11-20 | Advanced Risc Mach Ltd | Memory address translation in a data processing system |
JP2000067009A (ja) * | 1998-08-20 | 2000-03-03 | Hitachi Ltd | 主記憶共有型マルチプロセッサ |
US6751583B1 (en) * | 1999-10-29 | 2004-06-15 | Vast Systems Technology Corporation | Hardware and software co-simulation including simulating a target processor using binary translation |
US6754784B1 (en) * | 2000-02-01 | 2004-06-22 | Cirrus Logic, Inc. | Methods and circuits for securing encached information |
AU2001231165A1 (en) | 2000-02-01 | 2001-08-14 | Cirrus Logic, Inc. | Methods for synthesizing translation tables and systems using the same |
US6742103B2 (en) * | 2000-08-21 | 2004-05-25 | Texas Instruments Incorporated | Processing system with shared translation lookaside buffer |
US6907600B2 (en) * | 2000-12-27 | 2005-06-14 | Intel Corporation | Virtual translation lookaside buffer |
US6772315B1 (en) * | 2001-05-24 | 2004-08-03 | Rambus Inc | Translation lookaside buffer extended to provide physical and main-memory addresses |
US7103748B2 (en) * | 2002-12-12 | 2006-09-05 | International Business Machines Corporation | Memory management for real-time applications |
-
2004
- 2004-02-06 US US10/773,847 patent/US7519791B2/en not_active Expired - Fee Related
-
2005
- 2005-01-14 KR KR1020067015807A patent/KR100895715B1/ko not_active IP Right Cessation
- 2005-01-14 WO PCT/US2005/001234 patent/WO2005078590A2/en active Application Filing
- 2005-01-14 JP JP2006551169A patent/JP2007520014A/ja active Pending
- 2005-01-19 TW TW094101539A patent/TWI295015B/zh not_active IP Right Cessation
- 2005-02-04 MY MYPI20050444A patent/MY140166A/en unknown
-
2010
- 2010-02-01 JP JP2010020031A patent/JP2010134956A/ja active Pending
Also Published As
Publication number | Publication date |
---|---|
KR100895715B1 (ko) | 2009-04-30 |
US7519791B2 (en) | 2009-04-14 |
WO2005078590A3 (en) | 2006-03-30 |
WO2005078590A2 (en) | 2005-08-25 |
TWI295015B (en) | 2008-03-21 |
JP2010134956A (ja) | 2010-06-17 |
US20050177701A1 (en) | 2005-08-11 |
TW200534094A (en) | 2005-10-16 |
MY140166A (en) | 2009-11-30 |
KR20060120242A (ko) | 2006-11-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7089398B2 (en) | Address translation using a page size tag | |
JP4268332B2 (ja) | 仮想アドレスからページ・テーブル・インデックスを計算する方法および装置 | |
CN101315614B (zh) | 支持页属性的虚拟地址至物理地址的转换 | |
US5918251A (en) | Method and apparatus for preloading different default address translation attributes | |
US5479627A (en) | Virtual address to physical address translation cache that supports multiple page sizes | |
JP3640978B2 (ja) | ページテーブル中のハッシュアドレスタグを用いたメモリアドレス制御装置 | |
US7913058B2 (en) | System and method for identifying TLB entries associated with a physical address of a specified range | |
JP2010134956A (ja) | 状況切換え環境中におけるアドレス変換技術 | |
US8185692B2 (en) | Unified cache structure that facilitates accessing translation table entries | |
US8024546B2 (en) | Opportunistic page largification | |
US20060161758A1 (en) | Multiple page size address translation incorporating page size prediction | |
JP2011513808A (ja) | 変換例外修飾子を用いる動的アドレス変換 | |
JP2003067357A (ja) | 不均一メモリ・アクセス(numa)データ処理システムおよびその操作方法 | |
JPH04319747A (ja) | アドレス変換機構 | |
JPH04320553A (ja) | アドレス変換機構 | |
US20160283396A1 (en) | Memory management | |
CN114328295A (zh) | 存储管理装置、处理器、相关装置和相关方法 | |
US7100018B2 (en) | System and method for encoding page size information | |
CN114063934B (zh) | 数据更新装置、方法及电子设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20090427 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20090608 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20090615 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20090925 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20091013 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20100201 |