JP2013537658A - 入力/出力アドレスをメモリ・アドレスに変換するための方法、コンピュータ・システム、およびコンピュータ・プログラム - Google Patents

入力/出力アドレスをメモリ・アドレスに変換するための方法、コンピュータ・システム、およびコンピュータ・プログラム Download PDF

Info

Publication number
JP2013537658A
JP2013537658A JP2013515734A JP2013515734A JP2013537658A JP 2013537658 A JP2013537658 A JP 2013537658A JP 2013515734 A JP2013515734 A JP 2013515734A JP 2013515734 A JP2013515734 A JP 2013515734A JP 2013537658 A JP2013537658 A JP 2013537658A
Authority
JP
Japan
Prior art keywords
address
bits
memory
adapter
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.)
Granted
Application number
JP2013515734A
Other languages
English (en)
Other versions
JP5636097B2 (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.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Publication of JP2013537658A publication Critical patent/JP2013537658A/ja
Application granted granted Critical
Publication of JP5636097B2 publication Critical patent/JP5636097B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/16Handling requests for interconnection or transfer for access to memory bus
    • 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
    • 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/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/0292User address space allocation, e.g. contiguous or non contiguous base addressing using tables or multilevel address translation means
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/20Employing a main memory using a specific memory technology
    • G06F2212/206Memory mapped I/O
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/34Addressing or accessing the instruction operand or the result ; Formation of operand address; Addressing modes
    • G06F9/355Indexed addressing

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)
  • Bus Control (AREA)
  • Executing Machine-Instructions (AREA)
  • Memory System (AREA)

Abstract

【課題】
【解決手段】アダプタによって発行された要求内に提供されたアドレスは、システム・メモリにアクセスする際に直接使用可能なアドレスに変換される。アドレスは複数のビットを含み、複数のビットはビットの第1の部分およびビットの第2の部分を含む。ビットの第2の部分は、変換を実行するためにアドレス変換テーブルの1つまたは複数のレベルにインデックス付けするために使用され、ビットの第1の部分は、変換については無視される。ビットの第1の部分は、アドレスを妥当性検査するために使用される。
【選択図】 図15

Description

本発明は、一般に、コンピューティング環境におけるアドレスの変換に関し、特に、入力/出力アドレスの、環境のシステム・メモリにアクセスする際に使用可能なメモリ・アドレスへの変換に関する。
システム・メモリは、読み取りおよび書き込みの要求によってアクセスされる。これらの要求は、中央処理ユニットならびにアダプタを含む、コンピューティング環境の様々な構成要素から発することができる。各要求は、システム・メモリにアクセスする際に使用されるアドレスを含む。しかしながらこのアドレスは、典型的には、システム・メモリ内の物理位置と1対1で対応している訳ではない。したがって、アドレス変換が実行される。
アドレス変換は、システム・メモリにアクセスする際に直接使用することのできない形で提供されたアドレスを、システム・メモリ内の物理位置にアクセスする際に直接使用できる他の形に変換するために使用される。たとえば、中央処理ユニットによって提供される要求に含められた仮想アドレスは、システム・メモリ内の実アドレスまたは絶対アドレスに変換される。他の例として、アダプタからの要求で提供されるPeripheral Component Interconnect(PCI)アドレスは、システム・メモリ内の絶対アドレスに変換可能である。
2008年7月10日付公告の、Greggによる「I/O Adapter LPAR Isolation In A Hypertransport Environment With Assigned Memory Space Indexing A TVT Via Unit Ids」という名称の米国公開第2008/0168208 A1号は、データ処理システム、およびシステム内の複数のI/Oアダプタを分離する方法について記載している。データ処理システムは、プロセッサのセット、ホスト・ブリッジ、ならびに、プロセッサのセットとホスト・ブリッジとを接続するシステム・バスも備えている。各I/OアダプタはそれぞれのIDを有し、I/OアダプタのIDのうちの1つまたは複数を含むコマンドを、ホスト・ブリッジに送信する。好ましい実施形態では、これらのIDはHyperTransport定義のユニットIDであり、I/Oアダプタによって発行されるコマンドは、I/OアダプタのユニットIDのうちの1つまたは複数を含むユニットIDを含む。ユニットIDはそれぞれ、固有の独立したシステム・メモリ・スペースを識別するように、TVTにインデックス付けするために使用される。
2009年7月16日付公告の、Greiner等による「Dynamic Addres Translation with Frame Management」という名称の米国公開第2009/0182966A1号は、コンピュータ・システムの機械体系に関して定義されたフレーム管理機能を開示している。一実施形態では、第1および第2の汎用レジスタを識別するフレーム管理命令が取得される。第1の汎用レジスタは、アクセス保護ビットおよびブロック・サイズ指示を備えたキー・フィールドを有するフレーム管理フィールドを含む。ブロック・サイズ指示が大きなブロックを示す場合、大きなデータ・ブロックのオペランド・アドレスが、第2の汎用レジスタから取得される。大きなデータ・ブロックは、複数の小さなブロックを有し、そのそれぞれが、複数のストレージ・キー・アクセス保護ビットを有する対応するストレージ・キーに関連付けられる。ブロック・サイズ指示が大きなブロックを示す場合、大きなブロック内の各小さなブロックの各対応するストレージ・キーのストレージ・キー・アクセス保護ビットには、キー・フィールドのアクセス保護ビットがセットされる。
米国公開第2008/0168208A1号 米国公開第2009/0182966A1号 米国特許証第6009261号 米国特許証第5574873号 米国特許証第5551013号 米国特許証第6308255号 米国特許証第6463582号 米国特許証第5790825号
コンピューティング環境においてアドレスを変換するためのコンピュータ・プログラム製品を提供することによって、従来技術の欠点が克服され、追加の利点が与えられる。
コンピュータ・プログラム製品は、処理回路によって読み取り可能であり、方法を実行するために処理回路によって実行するための命令を格納する、コンピュータ読み取り可能ストレージ・メディアを含む。方法は、たとえば、変換されることになるアドレスをアダプタから取得することであって、アドレスは複数のビットを含み、複数のビットはビットの第1の部分およびビットの第2の部分を含む、取得すること、許可されたアドレスの領域を示すアドレス領域値を受信すること、少なくともビットの第1の部分および受信したアドレス領域を使用してアドレスを妥当性検査すること、ならびに、このアドレスを、コンピューティング環境のメモリにアクセスする際に使用可能なメモリ・アドレスに変換することであって、変換することは、ビットの第1の部分を無視し、変換を実行するためのアドレス変換テーブルの1つまたは複数のレベルからアドレス情報を取得するためにビットの第2の部分を使用する、変換すること、を含む。
本明細書では、本発明の1つまたは複数の態様に関する方法およびシステムについても説明および主張する。
追加の特徴および利点は、本発明の技法を通じて実現される。本明細書では、本発明の他の実施形態および態様について詳細に説明され、主張された発明の一部とみなされる。
本発明の1つまたは複数の態様が特に注目され、明細書の終わりの特許請求の範囲で例として明確に主張される。本発明の前述および他の目的、特徴、および利点は、添付の図面に関連した以下の詳細な説明から明らかとなる。
本発明の1つまたは複数の態様を組み込んで使用するための、コンピューティング環境の一実施形態を示す図である。 本発明の態様に従った、図1のシステム・メモリおよびI/Oハブのさらなる細部の一実施形態を示す図である。 本発明の態様に従った、アダプタに関するDMA(ダイレクト・メモリ・アクセス)アドレス・スペースを登録するための論理の概要の一実施形態を示す図である。 本発明の態様に従った、アダプタに関するDMAアドレス・スペースの登録の様々な細部の一実施形態を示す図である。 本発明の態様に従った、DMA動作を処理するための論理の一実施形態を示す図である。 アドレスを変換するためおよびページにアクセスするために、アドレス変換テーブルにインデックス付けするためにアドレス全体が使用される場合に採用される、変換のレベルの一例を示す図である。 本発明の態様に従った、アドレス変換テーブルにインデックス付けする際にアドレスの一部が無視される場合に採用される、変換のレベルの一例を示す図である。 本発明の1つまたは複数の態様に従って使用可能な、様々なCPU DAT適合フォーマットの例を示す図である。 本発明の1つまたは複数の態様に従って使用可能な、様々なI/O拡張アドレス変換フォーマットの例を示す図である。 本発明の態様に従って使用される、PCI機能制御修正命令の一実施形態を示す図である。 本発明の態様に従った、図10のPCI機能制御修正命令によって使用されるフィールドの一実施形態を示す図である。 本発明の態様に従った、図10のPCI機能制御修正命令によって使用される他のフィールドの一実施形態を示す図である。 本発明の態様に従って使用される、機能情報ブロック(FIB)のコンテンツの一実施形態を示す図である。 本発明の態様に従った、PCI機能制御修正命令の論理の概要の一実施形態を示す図である。 本発明の態様に従った、PCI機能制御修正命令によって指定可能な、I/Oアドレス変換パラメータ登録動作に関連付けられた論理の一実施形態を示す図である。 本発明の態様に従った、PCI機能制御修正命令によって指定可能な、I/Oアドレス変換パラメータ登録解除動作に関連付けられた論理の一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んだコンピュータ・プログラム製品の一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するための、ホスト・コンピュータ・システムの一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するための、コンピュータ・システムの他の例を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するためのコンピュータ・ネットワークを備える、コンピュータ・システムの他の例を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するためのコンピュータ・システムの様々な要素の一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するための、図21のコンピュータ・システムの実行ユニットの一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するための、図21のコンピュータ・システムの分岐ユニットの一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するための、図21のコンピュータ・システムのロード/格納ユニットの一実施形態を示す図である。 本発明の1つまたは複数の態様を組み込んで使用するための、エミュレートされたホスト・コンピュータ・システムの一実施形態を示す図である。
本発明の態様によれば、コンピューティング環境においてアドレスを変換するための機能が提供される。一例では、変換されるアドレスは、アダプタによって提供されるアドレス(本明細書では、入力/出力(I/O)アドレスと呼ばれる)であり、システム・メモリにアクセスする際に使用可能なアドレスに変換されるものである。アドレス変換を実行するために、いくつかのレベルのアドレス変換が使用され、このレベルの数は、たとえば、アダプタに割り当てられたメモリ・アドレス・スペースのサイズ、変換に使用される1つまたは複数のアドレス変換テーブルのサイズ、または、アクセスされることになるページ(またはメモリの他の単位)のサイズ、あるいはそれらすべてに基づくものである。
変換されるアドレスは複数のビットを含み、一実施形態では、それらのビットの一部のみが、変換されたアドレスを取得するためにアドレス変換テーブルにインデックス付けするために使用される。他のビットは変換については無視される。たとえばアドレスは、(割り当てられたアドレス・スペースのサイズに基づいて)高位ビットおよび低位ビットを含む。この例では、ページ・テーブルを含むアドレス変換テーブルにインデックス付けするため、および、ページ自体にインデックス付けするために、低位ビットが使用される。高位ビットは、(値、すなわちゼロまたは非ゼロに関係なく)変換については無視され、アドレス変換テーブルにインデックス付けするためには使用されない。これにより、変換に使用されるアドレス変換テーブルのレベル数は減少する。(低位ビットおよび高位ビットの指示は、ビットがどのように番号付けされるかとは無関係である。)
一例では、変換は、System z(R)サーバなどの企業クラス・サーバに好適な保護を提供しながら、実行される。例として、メモリにアクセスする際にはフル・アドレス(たとえば64ビット・アドレス全体)が使用されるが、変換にはアドレスの一部のみが使用される。変換については無視されるアドレスの他の部分は、変換に使用されるアドレスの少なくとも一部と共に、妥当性検査(たとえば領域チェック)に使用される。変換のためにアドレスの一部のみを使用することによって、アドレス変換ルックアップは最小限に抑えられる。これは、アドレス自体のサイズではなく、たとえばアダプタによるアクセスに登録されたDMAアドレス・スペースのサイズに基づいて、いくつかのレベルの変換を実行することによって達成される。
本発明の1つまたは複数の態様を組み込んで使用するためのコンピューティング環境の一実施形態について、図1を参照しながら説明する。一例では、コンピューティング環境100は、インターナショナル・ビジネス・マシーンズ・コーポレーションによって提供されるSystem z(R)である。System z(R)は、インターナショナル・ビジネス・マシーンズ・コーポレーションによって提供されるz/Architecture(R)に基づくものである。z/Architecture(R)に関する詳細については、2009年2月、IBM(R)発行の「z/Architecture Principles of Operation」と題するIBM出版物第SA22−7832−07号で説明されている。IBM(R)、System z(R)、およびz/Architecture(R)は、ニューヨーク州アーモンクのインターナショナル・ビジネス・マシーンズ・コーポレーションの登録商標である。本明細書で使用される他の名前は、インターナショナル・ビジネス・マシーンズ・コーポレーションまたは他の会社の登録商標、商標、または製品名とすることができる。
一例では、コンピューティング環境100は、メモリ・コントローラ106を介してシステム・メモリ104(別名メイン・メモリ)に結合された、1つまたは複数の中央処理ユニット(CPU)102を含む。システム・メモリ104にアクセスするために、中央処理ユニット102は、システム・メモリにアクセスするために使用されるアドレスを含む、読み取りまたは書き込み要求を発行する。要求に含まれるアドレスは、通常、システム・メモリへのアクセスに直接使用することはできないため、システム・メモリへのアクセスに直接使用可能なアドレスに変換される。アドレスは、変換メカニズム(XLATE)108を介して変換される。たとえばアドレスは、たとえば動的アドレス変換(DAT)を使用して、仮想アドレスから実または絶対アドレスへと変換される。
変換済みアドレスを含む要求は、メモリ・コントローラ106によって受信される。一例では、メモリ・コントローラ106はハードウェアからなり、システム・メモリへのアクセスに関する調停(arbitrate)およびメモリの一貫性の維持のために使用される。この調停はCPU 102から受信される要求、ならびに1つまたは複数のアダプタ110から受信される要求に対して実行される。中央処理ユニットと同様に、アダプタは、システム・メモリにアクセスできるようにするための要求を発行する。
一例では、アダプタ110は、Peripheral Component Interconnect(PCI)、あるいは1つまたは複数のPCI機能を含むPCI Express(PCIe)アダプタである。PCI機能は、システム・メモリへのアクセスを必要とする要求を発行する。要求は、1つまたは複数のスイッチ(たとえばPCIeスイッチ)114を介して入力/出力ハブ112(たとえばPCIハブ)へと経路指定される。一例では、入力/出力ハブは、1つまたは複数の状態機械を含むハードウェアからなる。
本明細書で使用されるアダプタと言う用語は、任意のタイプのアダプタ(たとえば、ストレージ・アダプタ、ネットワーク・アダプタ、処理アダプタ、PCIアダプタ、暗号アダプタ、他のタイプの入力/出力アダプタなど)を含む。一実施形態では、アダプタは1つのアダプタ機能を含む。しかしながら、他の実施形態では、アダプタは複数のアダプタ機能を含むことができる。本発明の1つまたは複数の態様は、アダプタが1つのアダプタ機能または複数のアダプタ機能を含むかどうかにかかわらず、適用可能である。さらに、本明細書に提示された例では、特に注記されない限り、アダプタはアダプタ機能(たとえばPCI機能)と互換的に使用される。
入力/出力ハブは、たとえば、スイッチからの要求を受信するルート・コンプレックス(root complex)116を含む。要求は、変換されることになる入力/出力アドレスを含むため、ルート・コンプレックスはアドレス変換および保護ユニット118にアドレスを提供する。このユニットは、以下でより詳細に説明するように、たとえばI/Oアドレスを、システム・メモリ104にアクセスするために直接使用可能なアドレスに変換する、ハードウェア・ユニットである。
アダプタから開始された、変換済みアドレスを含む要求は、たとえばI/O−メモリ・バス(I/O-to-memory bus)120を介して、メモリ・コントローラ106へ提供される。メモリ・コントローラはその調停を実行し、要求を変換済みアドレスと共に適切な時点でシステム・メモリに転送する。
システム・メモリおよび入力/出力ハブに関するさらなる詳細について、図2を参照しながら説明する。この実施形態では、メモリ・コントローラは示されていない。しかしながら、I/Oハブを直接、またはメモリ・コントローラを介して、システム・メモリに結合することができる。一例では、システム・メモリ104は1つまたは複数のアドレス・スペース200を含む。アドレス・スペースとは、特定のアダプタなどのコンピューティング環境の特定の構成要素に割り当てられた、システム・メモリの特定部分である。一例では、アドレス・スペースには、アダプタによって開始されたダイレクト・メモリ・アクセス(DMA)によってアクセス可能であるため、本明細書の例では、アドレス・スペースはDMAアドレス・スペースと呼ばれる。しかしながら他の例では、アドレス・スペースにアクセスするためにダイレクト・メモリ・アクセスは使用されない。
さらに、一例では、システム・メモリ104は、システム・メモリにアクセスする際に直接使用できないアドレスから直接使用可能なアドレスへと、アドレスを変換する際に使用される、アドレス変換テーブル202を含む。一実施形態では、DMAアドレス・スペースに割り当てられた1つまたは複数のアドレス変換テーブルが存在し、それらの1つまたは複数のアドレス変換テーブルは、たとえば、割り当て先のアドレス・スペースのサイズ、アドレス変換テーブル自体のサイズ、または、ページ(またはメモリの他の単位)のサイズ、あるいはそれらすべてに基づいて、構成される。
一例では、アドレス変換テーブルの階層が存在する。たとえば図2に示されるように、IOATポインタ218(以下で説明)によってポイントされる第1レベル・テーブル202a(たとえばセグメント・テーブル)、および、第1レベル・テーブルのエントリ206aによってポイントされる第2の低レベル・テーブル202b(たとえばページ・テーブル)が存在する。特定の低レベル・テーブル202bを示す、特定のエントリ206aの位置を特定するため、テーブル202aにインデックス付けするために、受信アドレス204の1つまたは複数のビットが使用される。その後、そのテーブル内の特定のエントリ206bの位置を特定するために、アドレス204の1つまたは複数の他のビットが使用される。この例では、そのエントリは、正しいページの位置を特定するために使用されるアドレスを提供し、データ転送を実行するためにページ内の特定の位置208を特定するために、アドレス204内の追加のビットが使用される。すなわち、システム・メモリにアクセスするために直接使用可能なアドレスを提供するために、エントリ206b内のアドレス、および受信PCIアドレス204の選択されたビットが使用される。たとえば、直接使用可能なアドレスは、エントリ206b内のアドレスの高位ビット(たとえば、4Kページの例では、ビット63:12)と、受信PCIアドレスからの選択された低位ビット(たとえば、4Kページではビット11:0)との連結から、形成される。
一例では、これは、特定のアダプタにDMAアドレス・スペースを割り当てるオペレーティング・システムである。この割り当ては、登録プロセスを介して実行され、これによって、そのアダプタに関するデバイス・テーブル・エントリ210が(たとえば、信頼できるソフトウェアを介して)初期化される。デバイス・テーブル・エントリは、I/Oハブ112内に配置されたデバイス・テーブル211内に配置される。たとえば、デバイス・テーブル211は、I/Oハブのアドレス変換および保護ユニット内に配置される。
一例では、デバイス・テーブル・エントリ210は、以下のようないくつかのフィールドを含む。
フォーマット212:このフィールドは、たとえばアドレス変換・テーブルの上位レベル・テーブル(たとえばこの例では、第1レベル・テーブル)のアドレス変換フォーマット(レベルを含む)を含む、様々な情報を示すための複数のビットを含む。
ページ・サイズ213:このフィールドは、アクセスされることになるページ(またはメモリの他の単位)のサイズを示す。
PCIベース・アドレス214およびPCI限界216:これらの値は、DMAアドレス・スペースを定義し、受信したアドレス(たとえばPCIアドレス)が有効かどうかを検証するために使用される、領域を提供する。
IOAT(入力/出力アドレス変換)ポインタ218:このフィールドは、DMAアドレス・スペースに使用されるアドレス変換テーブルの最高レベルに対するポインタを含む。
他の実施形態では、DTEは、より多くの、より少ない、または、異なる情報を含むことができる。
一実施形態では、特定の変換で使用されることになるデバイス・テーブル・エントリは、アダプタに関連付けられたPCI機能220(またはアドレスの一部、あるいはその両方)によって発行される要求内に配置される、要求側識別子(RID)を使用して配置される。要求側ID(たとえば、バス番号、デバイス番号、および機能番号を指定する、16ビット値)は、要求、ならびに、システム・メモリへのアクセスに使用されることになるI/Oアドレス(たとえば、64ビットPCIeアドレス)内に含められる。RIDおよびI/Oアドレスを含む要求は、たとえば、インデックス値を提供するために使用される、たとえばスイッチ114を介して、コンテンツ・アドレス指定可能メモリ(CAM)230へと提供される。たとえば、CAMは複数のエントリを含み、各エントリはデバイス・テーブルへのインデックスに対応する。各CAMエントリは、RIDの値を含む。たとえば、受信したRIDが、CAM内のエントリに含まれる値と一致する場合、デバイス・テーブル・エントリの位置を特定するために、対応するデバイス・テーブル・インデックスが使用される。すなわち、CAMの出力は、デバイス・テーブル・エントリ210の位置を特定するために、デバイス・テーブル211へのインデック付けに使用される。一致しない場合、システム・メモリへのアクセスは実行されることなく、受信したパケットが廃棄される。(他の実施形態では、CAMまたは他のルックアップは不要であり、RIDはインデックスとして使用される。)
その後、デバイス・テーブル・エントリ内のフィールドは、アドレスの妥当性検査およびアドレス変換テーブルの構成を保証するために使用される。たとえば、要求内の着信アドレスは、アドレスを提供した要求のRIDを使用して位置が特定されたデバイス・テーブル・エントリに格納された、PCIベース・アドレス214およびPCI限界216によって画定された、境界内にあることを保証するために、I/Oハブのハードウェア(たとえば、アドレス変換および保護ユニット)によってチェックされる。これによって、アドレスが、事前に登録された領域内にあること、および、それに対してアドレス変換テーブルが有効に構成されることが保証される。
本発明の態様によれば、一実施形態において、I/Oアドレス(すなわち、I/Oサブシステムのアダプタまたは他の構成要素によって提供されるアドレス)を、システム・メモリ・アドレス(すなわち、システム・メモリへのアクセスに直接使用可能なアドレス)に変換するために、最初に、登録プロセスが実行される。この登録プロセスは、特定のアダプタまたはアダプタ機能などの、特定のアドレス・スペースを特定の要求側に登録する。この登録プロセスの概要の一例について、図3を参照しながら説明する。
最初に、ステップ300で、システム・メモリに結合された中央処理ユニットのうちの1つ内で実行するオペレーティング・システムが、アダプタがアクセスするアドレス・スペースのサイズおよび位置を決定する。一例では、アドレス・スペースのサイズは、オペレーティング・システムによって設定されたPCIベース・アドレスおよびPCI限界によって決定される。オペレーティング・システムは、1つまたは複数の基準を使用してベースおよび限界を決定する。たとえば、オペレーティング・システムがPCIアドレスをCPU仮想アドレスに直接マッピングさせたい場合、ベースおよび限界はそのように設定される。他の例では、アダプタまたはオペレーティング・システム・イメージまたはその両方の間の追加の分離が望ましい場合、非重複および独立のアドレス・スペースを提供するように、使用されているアドレスが選択される。位置もオペレーティング・システムによって指定され、たとえばアダプタの特徴に基づく。
その後、ステップ302で、そのDMAアドレス・スペースをカバーするために、1つまたは複数のアドレス変換テーブルが作成される。例として、テーブルはCPUアドレス変換テーブルに適合可能であるか、または、入力/出力ハブによってサポートされる固有のフォーマットが提供可能である。一例では、作成は、テーブルを構築すること、およびテーブル・エントリ内に適切なアドレスを配置することを含む。例として、変換テーブルのうちの1つは512の64ビット・エントリを有する4Kページ・テーブルであり、各エントリは、割り当てられたアドレス・スペースに適合可能な4Kページ・アドレスを含む。
その後、図4を参照しながらより詳細に説明するように、ステップ304で、アダプタに対してDMAアドレス・スペースが登録される。この例では、アダプタについて1つのPCI機能が存在し、したがってアダプタについて1つの要求側IDが存在するものと想定される。この論理は、たとえば、オペレーティング・システム要求に応答して、システム・メモリに結合された中央処理ユニットによって実行される。
最初に、一実施形態では、ステップ310で、アダプタの要求側IDに対応するように、使用可能なデバイス・テーブル・エントリが選択される。すなわち、デバイス・テーブル・エントリの位置を特定するために、要求側IDが使用されることになる。
加えて、ステップ312で、PCIベース・アドレスおよびPCI限界がデバイス・テーブル・エントリに格納される。さらに、ステップ314で、最高レベル・アドレス変換テーブルのフォーマットも、ならびにステップ316で、最高レベル・アドレス変換テーブルをポイントするために使用される入力/出力アドレス変換(IOAT)ポインタも、デバイス・テーブル・エントリ(たとえばフォーマット・フィールド)に格納される。これで登録プロセスが完了する。
登録の実行に応答して、DMAアドレス・スペースおよび対応するアドレス変換テーブル、ならびにデバイス・テーブル・エントリが使用できるようになる。システム・メモリにアクセスするために、アダプタなどの要求側によって発行される要求の処理に関する詳細について、図5を参照しながら説明する。以下で説明される処理は、I/Oハブによって実行される。一例では、これは、論理を実行するアドレス変換および保護ユニットである。一実施形態では、最初に、ステップ400で、入力/出力ハブでDMA要求が受信される。たとえばPCI機能は、たとえばPCIスイッチを介してPCIハブに転送される要求を発行する。要求内の要求側IDを使用して、ステップ402で、適切なデバイス・テーブル・エントリの位置が特定される。その後、照会404で、デバイス・テーブル・エントリが有効かどうかが決定される。一例では、有効性は、エントリ自体の有効性ビットをチェックすることによって決定される。このビットは、たとえばオペレーティング・システムによる有効化機能要求の実行に応答して、設定される。有効化されている場合、ビットは、たとえば1(すなわち有効)に設定され、有効化されていない場合、ゼロ(すなわち無効)のままである。他の例では、登録プロセスが完了した時点でビットを設定することができる。
デバイス・テーブル・エントリが無効の場合、ステップ405でエラーが提示される。無効でない場合、照会406で、要求内に提供されたPCIアドレスが、デバイス・テーブル・エントリに格納されたPCIベース・アドレスよりも小さいかどうかが決定される。小さい場合、アドレスは有効領域外にあり、ステップ407でエラーが提供される。しかしながら、PCIアドレスがベース・アドレスよりも大きいかまたは等しい場合、照会408で、PCIアドレスがデバイス・テーブル・エントリ内のPCI限界値よりも大きいかどうか、さらに決定される。PCIアドレスが限界よりも大きい場合、アドレスは有効領域外にあるため、ステップ409で再度エラーが提示される。しかしながら、アドレスが有効範囲内にある場合、処理は続行される。
一例では、ステップ410で、アドレス変換に使用されることになるアドレス内のPCIアドレス・ビットを決定するために、デバイス・テーブル・エントリ内に提供されるフォーマットが使用される。たとえば、フォーマットが、上位レベル・テーブルが4Kページを備えた第1レベル・テーブルであることを示す場合、第1レベル・テーブルにインデックス付けするためにアドレスのビット29:21が使用され、ページ・テーブルにインデックス付けするためにビット20:12が使用され、4Kページにインデックス付けするためにビット11:0が使用される。使用されるビットは、所与のサイズ・ページまたはテーブルにインデックス付けするためにどれだけのビットが必要であるかに依存する。たとえば、バイト・レベル・アドレス指定を伴う4Kページの場合、4096バイトのアドレス指定には12ビットが使用され、それぞれ8バイト、512エントリを伴う4Kページの場合、512エントリのアドレス指定には9ビットが使用される、などである。
次に、ステップ412で、PCIハブは、適切なアドレス変換テーブル・エントリをフェッチする。たとえば、最初に、デバイス・テーブル・エントリのIOATポインタを使用して、最高レベル変換テーブルの位置が特定される。その後、そのテーブル内の特定のエントリの位置を特定するために、アドレスのビット(変換ではなく有効性に使用される高位ビットの後:たとえば上記の例ではビット29:21)が使用される。
その後、照会414で、たとえば、位置が特定されたアドレス変換エントリが正しいフォーマットを有するかどうかに関して、デバイス・テーブル・エントリに提供されたフォーマットに基づいて決定される。たとえば、デバイス・テーブル・エントリ内のフォーマットが、アドレス変換エントリ内に示されるフォーマットと比較される。等しい場合、デバイス・テーブル・エントリに内のフォーマットは有効である。等しくない場合、ステップ415でエラーが提供され、そうでなければ、照会416で、これが処理される最後のテーブルであるかどうかの決定によって処理が続行される。すなわち、実または絶対アドレスを取得するために必要な他のアドレス変換テーブルが存在するかどうか、または、最低レベルのテーブル・エントリの位置が特定されたかどうかに関して、決定される。これは、提供されたフォーマットおよびすでに処理されているテーブルのサイズに基づいて決定される。最後のテーブルでない場合、ステップ412で処理が続行される。そうでなければ、I/Oハブはステップ418で、変換済みのアドレスでデータのフェッチまたは格納を実行可能にするための処理を続行する。一例では、I/Oハブは、変換済みアドレスをメモリ・コントローラに転送し、これは変換済みアドレスによって指定されたDMA位置でデータをフェッチまたは格納するために、アドレスを使用する。
前述のように、本発明の態様によれば、変換のレベル数、したがってさらに変換を実行するために必要なフェッチ数が減少する。これは、たとえば、変換中にアドレスの高位ビットを無視すること、および、たとえば、アダプタに割り当てられたDMAアドレス・スペースのサイズに基づく、変換テーブルをトラバースするために低位ビットのみを使用することによって、達成される。以下の例で、部分アドレスの使用対フル・アドレスの使用について示される。
最初に、図6を参照すると、アドレス変換/メモリ・アクセスでアドレス全体が使用される例が示されている。この従来技法では、ページ・テーブルを含む6レベルの変換テーブルが必要である。IOATポインタによって、最高レベル・テーブル(たとえばこの例では、第5レベル・テーブル)の開始がポイントされ、その後、テーブル内のエントリの位置を特定するために、PCIアドレスのビットが使用される。各変換テーブル・エントリは、低レベル変換テーブルの始まりまたはページをポイントする(たとえば、第5レベル・テーブル内のエントリは第4レベル・テーブルの始まりをポイントする)。
この例では、DMAアドレス・スペース(DMAAS)は6Mサイズであり、各テーブルは最大512の8バイト・エントリを有する4Kバイトである(アドレスのサイズに基づいて、128エントリを有する第5レベル・テーブルを除く)。たとえばアドレスは、64ビット:FFFF C000 0009 C600である。第5レベル・テーブルの始まりはIOATポインタによってポイントされ、第4レベル・テーブルの始まりの位置を特定するために第5レベル・テーブルにインデックス付けするためにPCIアドレスのビット63:57が使用され、第3レベル・テーブルの始まりの位置を特定するために第4レベル・テーブルにインデックス付けするためにPCIアドレスのビット56:48が使用され、第2レベル・テーブルの始まりの位置を特定するために第3レベル・テーブルにインデックス付けするためにビット47:39が使用され、第1レベル・テーブルの始まりの位置を特定するために第2レベル・テーブルにインデックス付けするためにビット38:30が使用され、ページ・テーブルの始まりの位置を特定するために第1レベル・テーブルにインデックス付けするためにビット29:21が使用され、ページの始まりの位置を特定するためにページ・テーブルにインデックス付けするためにビット20:12が使用され、4Kページ内のエントリの位置を特定するためにビット11:0が使用される。
これは、アドレス・スペースが同じサイズ(たとえば6M)であり、アドレスが同じであるが、変換技法が変換中にアドレス・ビットのいくつかを無視する、図7の例とは対照的である。この例では、アドレスのビット63:30は変換について無視される。IOATポインタは、第1レベル・テーブルの始まりをポイントし、ページ・テーブルの始まりの位置を特定するために第1レベル・テーブルにインデックス付けするためにビットPCIアドレスのビット29:21が使用され、ページの始まりの位置を特定するために適切なページ・テーブルにインデックス付けするためにビット20:12が使用され、4Kページにインデックス付けするためにビット11:0が使用される。
図に示されるように、第1レベル・テーブル500は3つのエントリ502を含み、それぞれが3つのページ・テーブル504のうちの1つにアドレスを提供する。したがって、必要なページ・テーブルの数、したがって他のレベルのテーブルの数は、たとえばDMAアドレス・スペースのサイズ、変換テーブルのサイズ、またはページのサイズ、あるいはそれらすべてに依存する。この例では、DMAアドレス・スペースは6Mであり、各ページ・テーブルは4Kで、512までのエントリを有する。したがって各ページ・テーブルは2Mまでのメモリをマッピングすることができる(4K%512エントリ)。したがって、6Mのアドレス・スペースには3つのページ・テーブルが必要である。第1レベル・テーブルは、各ページ・テーブルについて1つの、3つのエントリを保持することが可能であるため、この例では、他のレベルのアドレス変換テーブルは不要である。
他の実施形態では、アドレス変換に使用される異なるフォーマットのアドレス変換テーブルが存在可能であり、フォーマット内に変形が存在可能である。したがって、特定のテーブルまたはページにインデックス付けするために使用されるビットに、変形が存在する。これらの例のいくつかについて、図8および図9を参照しながら説明する。
たとえば、1つのフォーマットは、変換テーブルがCPU DAT変換に使用される変換テーブルに適合する、CPU DAT適合フォーマットである。様々なCPU DAT適合フォーマットが存在可能であり、その例について図8を参照しながら説明する。図に示されるように、例として、一方のCPU DAT適合フォーマットは4KページCPU DAT適合フォーマット550であり、他方は1MページCPU DAT適合フォーマット552である。示されたビット数は、そのページまたはテーブルにインデックス付けするため(またはそうでなければ、そのページまたはテーブル内のエントリの位置を特定するため)に使用されるアドレス・ビット数である。たとえば、PCIアドレスの12ビット554は、4Kページ556内へのバイト・オフセットとして使用され、8ビット558はページ・テーブル560内へのインデックスとして使用され、11ビット562はセグメント・テーブル564内へのインデックスとして使用される、などである。指定されたアドレス変換テーブルの下で位置が特定されるのは、そのアドレス変換テーブルによってサポートされるアドレス・スペースの最大サイズである。たとえば、ページ・テーブル560は1MのDMAアドレス・スペースをサポートし、セグメント・テーブル564は2GのDMAアドレス・スペースをサポートする、などである。この図、ならびに図9では、K=キロバイト、M=メガバイト、G=ギガバイト、T=テラバイト、P=ペタバイト、およびE=エクサバイトである。
図に示されるように、ページのサイズが大きくなるほど、変換テーブルのレベル数は減少する。たとえば4Kページ556の場合、ページ・テーブルが必要であるが、1Mページには必要ない。他の例および変形が可能である。
他のアドレス変換フォーマットは、拡張アドレス変換テーブルが使用されるI/O拡張アドレス変換フォーマットである。I/O拡張アドレス変換フォーマットの様々な例が、図9に示される。たとえば、4Kページを伴う4Kアドレス変換テーブル570、4Kページを伴う1Mアドレス変換テーブル572、および1Mページを伴う1Mアドレス変換テーブル574の、フォーマットが示されている。CPU DAT適合フォーマットと同様に、リスト表示されたビットの数は、特定のテーブル内でエントリの位置を特定するために使用されるビットである。たとえば参照番号576では、12ビットが4Kページ内へのオフセットである。同様に、参照番号578では、I/Oページ・テーブルにインデックス付けするために9ビットが使用される。このI/Oページ・テーブルでは、2MサイズのDMAアドレス・スペースが可能である。多くの他の例が存在する。
1つの特定の実装では、アダプタへのDMAアドレス・スペースの登録を実行するために、PCI機能制御修正(MPFC)命令と呼ばれる命令が使用される。たとえば、オペレーティング・システムは、どのアドレス変換フォーマットを使用したいかを決定し、そのフォーマットに対するアドレス変換テーブルを構築した後、命令のオペランドとしてそのフォーマットが含まれるMPFC命令を発行する。一例では、命令のフォーマットおよび他のオペランドが、命令のオペランドである機能情報ブロック(以下で説明)に含まれる。次にこの機能情報ブロックは、DTE、および一実施形態では、オプションで、アダプタの動作パラメータを含む機能テーブル・エントリ(FTE)を、更新するために使用される。
この命令に関する細部の一実施形態および、特に登録プロセスについて、図10〜図16を参照しながら説明する。図10を参照すると、PCI機能制御修正命令600は、たとえばPCI機能制御修正命令を示す命令コード602と、動作パラメータが確立されているアダプタ機能に関する様々な情報が含まれる位置を指定する第1のフィールド604と、PCI機能情報ブロック(FIB)のフェッチ元である位置を指定する第2のフィールド606と、を含む。フィールド1および2によって指定された位置のコンテンツについて、以下でさらに説明する。
一実施形態では、フィールド1は様々な情報を含む汎用レジスタを指定する。図11に示されるように、レジスタのコンテンツは、たとえば、どの修正命令が実行されているかの代わりに、アダプタ機能のハンドルを識別する機能ハンドル610と、機能ハンドルによって指定されたアダプタ機能に関連付けられたシステム・メモリ内のアドレス・スペースを指定するアドレス・スペース612と、アダプタ機能に関して実行される動作を指定する動作制御614と、事前定義されたコードによって命令が完了した場合に命令に関する状況を提供する状況616と、を含む。
一実施形態では、機能ハンドルは、たとえばハンドルが実行可能かどうかを示す実行可能インジケータと、アダプタ機能を識別する機能番号(これは静的識別子であり、機能テーブルにインデックス付けするために使用可能である)と、この機能ハンドルの特定のインスタンスを指定するインスタンス番号と、を含む。各アダプタ機能について1つの機能ハンドルが存在し、機能テーブル内の機能テーブル・エントリ(FTE)の位置を特定するために使用される。各機能テーブル・エントリは、動作パラメータまたはそのアダプタ機能に関連付けられた他の情報あるいはその両方を含む。一例では、機能テーブル・エントリは、以下を含む。
インスタンス番号:このフィールドは、機能テーブル・エントリに関連付けられたアダプタ機能ハンドルの特定のインスタンスを含む。
デバイス・テーブル・エントリ(DTE)インデックス1…n:1つまたは複数のデバイス・テーブル・インデックスが存在可能であり、各インデックスはデバイス・テーブル・エントリ(DTE)の位置を特定するためのデバイス・テーブルへのインデックスである。アダプタ機能につき1つまたは複数のデバイス・テーブル・エントリが存在し、各エントリは、アダプタ機能の要求(たとえば、DMA要求、MSI要求)を処理するために使用される情報、およびアダプタ機能に関連付けられた要求に関する情報(たとえばPCI命令)を含む、そのアダプタ機能に関連付けられた情報を含む。各デバイス・テーブル・エントリは、アダプタ機能に割り当てられたシステム・メモリ内の1つのアドレス・スペースに関連付けられる。アダプタ機能は、アダプタ機能に割り当てられたシステム・メモリ内の1つまたは複数のアドレス・スペースを有することができる。
ビジー・インジケータ:このフィールドは、アダプタ機能がビジーであるかどうかを示す。
永続的エラー状態インジケータ:このフィールドは、アダプタ機能が永続的エラー状態にあるかどうかを示す。
回復開始インジケータ:このフィールドは、アダプタ機能に関して回復が開始されたかどうかを示す。
許可インジケータ:このフィールドは、アダプタ機能の制御を試行しているオペレーティング・システムが、それを実行する権限を有するかどうかを示す。
実行可能インジケータ:このフィールドは、アダプタ機能が実行可能であるかどうかを示す(たとえば、1=実行可能、0=実行不可)。
要求側識別子(RID):これは、アダプタ機能の識別子であり、たとえばバス番号、デバイス番号、および機能番号を含む。
一例では、このフィールドはアダプタ機能の構成スペースのアクセスに使用される。(アダプタのメモリは、たとえば構成スペース、I/Oスペース、または、1つまたは複数のメモリ・スペース、あるいはそれらすべてを含む、アダプタ・スペースとして定義可能である。)一例では、構成スペースは、オペレーティング・システム(または他の構成)によってアダプタ機能に発行された命令内の構成スペースを指定することによってアクセス可能である。命令内に指定されるのは、構成スペース内へのオフセット、および、RIDを含む適切な機能テーブル・エントリの位置を特定するために使用される機能ハンドルである。ファームウェアは命令を受信し、これが構成スペース用であるかどうかを決定する。したがって、I/Oハブへの要求を生成するためにRIDを使用し、I/Oハブはアダプタにアクセスするための要求を作成する。アダプタ機能の位置はRIDに基づき、オフセットはアダプタ機能の構成スペース内へのオフセットを指定する。
本明細書で使用される場合、ファームウェアは、たとえばプロセッサのマイクロコード、ミリコード、またはマクロコード、あるいはそれらすべてを含む。これはたとえば、ハードウェア・レベル命令、または、高位レベル機械コードの実装で使用されるデータ構造、あるいはその両方を含む。一実施形態では、これは、たとえば、通常、基礎となるハードウェア特有の信頼できるソフトウェアまたはマイクロコードを含み、システム・ハードウェアへのオペレーティング・システム・アクセスを制御する、マイクロコードとして送達されるプロプライエタリ・コードを含む。
ベース・アドレス・レジスタ(BAR)(1からn):このフィールドは、最初に指定されたアダプタ機能に関連付けられ、その値もアダプタ機能に関連付けられたベース・アドレス・レジスタ内に格納される、BAR〜BARとして指定された、複数の符号なし整数を含む。例として、各BARは、アダプタ機能内のメモリ・スペースまたはI/Oスペースの開始アドレスを指定し、これが64または32ビットのメモリ・スペースであるか、あるいは32ビットのI/Oスペースであるかの、アドレス・スペースのタイプも示す。
一例では、これは、アダプタ機能のメモリ・スペースまたはI/Oスペースあるいはその両方にアクセスするために使用される。たとえば、アダプタ機能にアクセスするための命令内に提供されるオフセットは、アダプタ機能にアクセスするために使用されることになるアドレスを取得するために命令内に指定されたアドレス・スペースに関連付けられたベース・アドレス・レジスタ内の値に追加される。命令内に提供されるアドレス・スペース識別子は、アクセスされることになるアダプタ機能内のアドレス・スペースと、使用されることになる対応するBARとを識別する。
サイズ1…n:このフィールドは、SIZE〜SIZEとして指定された、複数の符号なし整数を含む。サイズ・フィールドの値は、非ゼロの場合、以前に説明されたBARに対応する各エントリを備えた各アドレス・スペースのサイズを表す。
BARおよびサイズに関する詳細について、以下で説明する。
1.BARがアダプタ機能に関して実装されない場合、BARフィールドおよびその対応するサイズ・フィールドはどちらのゼロとして格納される。
2.BARフィールドがI/Oアドレス・スペースまたは32ビット・メモリ・アドレス・スペースのいずれかを表す場合、対応するサイズ・フィールドは非ゼロであり、アドレス・スペースのサイズを表す。
3.BARフィールドが64ビット・メモリ・アドレス・スペースを表す場合、
a.BARフィールドは最下位アドレス・ビットを表す。
b.次の連続するBARn+1フィールドは、最上位アドレス・ビットを表す。
c.対応するSIZEフィールドは、非ゼロであり、アドレス・スペースのサイズを表す。
d.対応するSIZEn+1フィールドは有意ではなく、ゼロとして格納される。
内部ルーティング情報:この情報は、アダプタへの特定のルーティングを実行するために使用される。例として、たとえばこれは、ノード、プロセッサ・チップ、およびハブ・アドレス指定情報を含む。
状況指示:これは、ロード/格納動作が阻止されているか、またはアダプタがエラー状態にあるかの指示、ならびに他の指示を提供する。
一例では、ビジー・インジケータ、永続的エラー状態インジケータ、および回復開始インジケータは、ファームウェアによって実行されるモニタリングに基づいて設定される。さらに、許可インジケータは、たとえばポリシーに基づいて設定され、BAR情報は、プロセッサ(たとえばプロセッサのファームウェア)によるバス・ウォーク中に発見された構成情報に基づく。他のフィールドは、構成、初期化、またはイベント、あるいはそれらすべてに基づいて、設定可能である。他の実施形態では、機能テーブル・エントリは、より多い、より少ない、または異なる情報を、含むことができる。含まれる情報は、アダプタ機能によってサポートされるか、またはそれに対して実行可能化される、動作に依存することができる。
一例では、図12を参照すると、フィールド2は、関連付けられたアダプタ機能に関する情報を含む、PCI機能情報ブロック(FIB)の論理アドレス620を指定する。機能情報ブロックは、アダプタ機能に関連付けられた、デバイス・テーブル・エントリまたは機能テーブル・エントリ(または他の位置)、あるいはその両方を更新するために使用される。情報は、アダプタの初期化時または構成時、あるいはその両方で、または特定のイベントに応答して、あるいはその両方で、FIBに格納される。
機能情報ブロック(FIB)に関する他の詳細について、図13を参照しながら説明する。一実施形態では、機能情報ブロック650は、以下のフィールドを含む。
フォーマット651:このフィールドは、FIBのフォーマットを指定する。
遮断制御652:このフィールドは、ページ可能(pageable)モード・ゲストによる特有の命令のゲスト実行の結果、命令の遮断が生じるかどうかを示すために使用される。
エラー指示654:このフィールドは、ダイレクト・メモリ・アクセスおよびアダプタ割り込みに関するエラー状態指示を含む。ビットが設定された場合(たとえば1)、アダプタ機能に関するダイレクト・メモリ・アクセスまたはアダプタ割り込みの実行中に、1つまたは複数のエラーが検出されている。
ロード/格納阻止(blocked)656:このフィールドは、ロード/格納動作が阻止されるかどうかを示す。
PCI機能有効658:このフィールドは、アダプタ機能に関する実行可能化制御を含む。ビットが設定された場合(たとえば1)、アダプタ機能はI/O動作に対して実行可能化されるものとみなされる。
アドレス・スペース登録済み660:このフィールドは、アダプタ機能に関するダイレクト・メモリ・アクセス実行可能化制御を含む。フィールドが設定された場合(たとえば1)、ダイレクト・メモリ・アクセスは実行可能化される。
ページ・サイズ661:このフィールドは、DMAメモリ・アクセスによってアクセスされることになるページのサイズまたは他のメモリ単位を示す。
PCIベース・アドレス(PBA)662:このフィールドは、アダプタ機能に割り当てられるシステム・メモリ内のアドレス・スペースに関するベース・アドレスである。これは、アダプタ機能が、指定されたDMAアドレス・スペースへのダイレクト・メモリ・アクセスに使用可能である、最下位仮想アドレスを表す。
PCIアドレス限界(PAL)664:このフィールドは、アダプタ機能が、指定されたDMAアドレス・スペース内でアクセス可能である、最高位仮想アドレスを表す。
入力/出力アドレス変換ポインタ(IOAT)666:入力/出力アドレス変換ポインタは、PCI仮想アドレス変換によって使用される任意の変換テーブルのうちの第1を指定するか、または、変換の結果であるストレージのフレームの絶対アドレスを直接指定することができる。
割り込みサブクラス(ISC)668:このフィールドは、アダプタ機能に関するアダプタ割り込みを提示するために使用される、割り込みサブクラスを含む。
割り込みの数(NOI)670:このフィールドは、アダプタ機能用に受け入れられる別個の割り込みコードの数を指定する。さらにこのフィールドは、アダプタ割り込みビット・ベクトル・アドレスおよびアダプタ割り込みビット・ベクトル・オフセット・フィールドによって指定された、アダプタ割り込みビット・ベクトルのサイズを、ビット単位でも定義する。
アダプタ割り込みビット・ベクトル・アドレス(AIBV)672:このフィールドは、アダプタ機能に関するアダプタ割り込みビット・ベクトルのアドレスを指定する。このベクトルは割り込み処理で使用される。
アダプタ割り込みビット・ベクトル・オフセット674:このフィールドは、アダプタ機能に関する第1のアダプタ割り込みビット・ベクトル・ビットのオフセットを指定する。
アダプタ割り込み要約ビット・アドレス(AISB)676:このフィールドは、オプションで、割り込み処理で使用される、アダプタ割り込み要約ビットを指定するアドレスを提供する。
アダプタ割り込み要約ビット・オフセット678:このフィールドは、アダプタ割り込み要約ビット・ベクトルへのオフセットを提供する。
機能測定ブロック(FMB)680:このフィールドは、アダプタ機能に関する測定値を収集するために使用される、機能測定ブロックのアドレスを提供する。
機能測定ブロック・キー682:このフィールドは、機能測定ブロックにアクセスするためのアクセス・キーを含む。
要約ビット通知制御684:このフィールドは、使用されている要約ビット・ベクトルが存在するかどうかを示す。
命令認証トークン686:このフィールドは、ページ可能ストレージ・モード・ゲストがPCI命令の実行を認証されているかどうかを決定するために使用される。
一例では、z/Architecture(R)において、ページ可能ゲストは、レベル2の解釈で、解釈実行開始(SIE)命令を介して解釈的に(interpretively)実行される。たとえば、論理区画(LPAR)ハイパーバイザは、物理的な固定メモリにおける論理区画を開始するために、SIE命令を実行する。z/VM(R)がその論理区画におけるオペレーティング・システムである場合、そのV=V(仮想)ストレージにおいてそのゲスト(仮想)機会を実行するために、SIE命令を発行する。したがって、LPARハイパーバイザはレベル1のSIEを使用し、z/VM(R)ハイパーバイザはレベル2のSIEを使用し、さらに
アドレス変換フォーマット687:このフィールドは、変換で使用されることになる最高レベル変換テーブルのアドレス変換のために選択されたフォーマット(たとえば、最高レベル・テーブル(たとえば、セグメント・テーブル、領域第3など)の指示)を示す。
PCI機能制御修正命令内に指定された機能情報ブロックは、選択されたデバイス・テーブル・エントリ、機能テーブル・エントリ、または、命令内に指定されたアダプタ機能に関連付けられた他のファームウェア制御、あるいはそれらすべてを、修正するために使用される。デバイス・テーブル・エントリ、機能テーブル・エントリ、または他のファームウェア制御、あるいはそれらすべてを修正することによって、あるサービスがアダプタに提供される。これらのサービスは、たとえばアダプタ割り込み、アドレス変換、エラー状態リセット、ロード/格納阻止リセット、機能測定パラメータ設定、および遮断制御設定を含む。
PCI機能制御修正命令に関連付けられた論理の一実施形態について、図14を参照しながら説明する。一例では、この命令は、オペレーティング・システム(または他の構成)によって発行され、オペレーティング・システムを実行しているプロセッサ(たとえばファームウェア)によって実行される。本明細書の例では、命令およびアダプタ機能はPCIベースである。しかしながら、他の例では、異なるアダプタ・アーキテクチャおよび対応する命令が使用可能である。
一例では、オペレーティング・システムは、PCI機能ハンドル、DMAアドレス・スペース識別子、動作制御、および機能情報ブロックのアドレスの、オペランドを、(たとえば、命令によって指定された1つまたは複数のレジスタにおいて)命令に提供する。
図14を参照すると、最初に、照会700で、PCI機能制御修正命令を可能にする機構がインストールされるかどうかについて決定される。この決定は、たとえば制御ブロックに格納されたインジケータをチェックすることによって実行される。機構がインストールされない場合、ステップ702で例外条件が提供される。インストールされる場合、照会704で、ページ可能ストレージ・モード・ゲスト(または他のゲスト)によって命令が発行されたかどうかが決定される。発行された場合、ステップ706でホスト・オペレーティング・システムは、そのゲストに関する動作をエミュレートすることになる。
あるいは、照会708で、オペランドのうちの1つまたは複数が位置合わせされるかどうかについて決定される。たとえば、機能情報ブロックのアドレスがダブルワード境界上にあるかどうかについて決定される。一例では、これはオプションである。オペランドが位置合わせされない場合、ステップ710で例外条件が提供される。位置合わせされる場合、照会712で、機能情報ブロックにアクセス可能であるかどうかについて決定される。アクセス可能でない場合、ステップ714で例外条件が提供される。アクセス可能である場合、照会716で、PCI機能制御修正命令のオペランド内に提供されたハンドルが実行可能であるかどうかについて決定される。一例では、この決定は、ハンドル内の実行可能インジケータをチェックすることによって実行される。ハンドルが実行可能でない場合、ステップ718で例外条件が提供される。
ハンドルが実行可能である場合、ステップ720で、機能テーブル・エントリの位置を特定するためにハンドルが使用される。すなわち、動作パラメータが確立されることになるアダプタ機能に対応する機能テーブル・エントリの位置を特定するために、ハンドルの少なくとも一部が機能テーブルへのインデックスとして使用される。
照会722で、機能テーブル・エントリが見つかったかどうかについて決定される。見つからなかった場合、ステップ724で例外条件が提供される。見つかった場合、照会726で、命令を発行している構成がゲストであれば、ステップ728で例外条件(たとえばホストに対する遮断)が提供される。この照会は、指定されていれば、構成がゲストでない場合、または他の認証がチェックできる場合、無視することができる。
照会730で、機能が実行可能であるかどうかについて決定される。一例では、この決定は、機能テーブル・エントリ内の実行可能インジケータをチェックすることによって実行される。実行可能でない場合、ステップ732で例外条件が提供される。
機能が実行可能である場合、照会734で、回復がアクティブであるかどうかについて決定される。機能テーブル・エントリ内の回復インジケータによって決定された回復がアクティブである場合、ステップ736で例外条件が提供される。しかしながら回復がアクティブでない場合、照会738で、機能がビジーであるかどうかについてさらに決定される。この決定は、機能テーブル・エントリ内のビジー・インジケータをチェックすることによって実行される。機能がビジーである場合、ステップ740でビジー条件が提供される。このビジー条件で、ドロップする代わりに命令を再試行することができる。
機能がビジーでない場合、照会742で、機能情報ブロック・フォーマットが有効であるかどうかについて、さらに決定される。たとえば、このフォーマットがシステムによってサポートされているかどうかを決定するために、FIBのフォーマット・フィールドがチェックされる。無効である場合、ステップ744で例外条件が提供される。機能情報ブロック・フォーマットが有効である場合、照会746で、命令のオペランド内に指定された動作制御が有効であるかどうかについて、さらに決定される。すなわち、動作制御が、この命令に関して指定された動作制御のうちの1つであるかどうか、である。無効である場合、ステップ748で例外条件が提供される。しかしながら動作制御が有効である場合、指定されている特定の動作制御で処理が続行する。
指定可能な1つの動作制御は、アダプタに関するアドレス変換を制御する際に使用される、I/Oアドレス変換パラメータ登録動作である。この動作では、I/Oアドレス変換に関連するPCI機能パラメータが、DTE、FTE、または、FIBの適切なパラメータからの他の位置、あるいはそれらすべてで設定され、これは命令に対するオペランドである。これらのパラメータは、たとえば、PCIベース・アドレス、PCIアドレス限界(別名、PCI限界または限界)、アドレス変換フォーマット、ページ・サイズ、および、I/Oアドレス変換ポインタを含み、これらはこの動作に対するオペランドである。DMA開始アドレス(SDMA)およびDMA終了アドレス(EDMA)を含む暗黙(implied)オペランドも存在し、これらは、命令を実行しているプロセッサがアクセス可能な位置に格納される。
I/Oアドレス変換に関する動作パラメータを確立するための論理の一実施形態について、図15を参照しながら説明する。最初に、照会800で、FIB内のPCIベース・アドレスがFIB内のPCI限界よりも大きいかどうかについて決定される。ベース・アドレスと限界とのこの比較で、ベース・アドレスの方が限界よりも大きいものと示された場合、ステップ802で例外条件が認識される。しかしながら、ベース・アドレスの方が限界よりも小さいかまたは等しい場合、照会804で、アドレス変換フォーマットおよびページ・サイズが有効であるかどうかについてさらに決定される。これらが無効である場合、ステップ806で例外条件が提供される。しかしながら、これらが有効である場合、照会808で、(ベース・アドレスおよび限界に基づいて)アドレス・スペースのサイズが変換容量を超えているかどうかについて決定される。一例では、上位レベル・テーブルのフォーマットに基づいて、アドレス・スペースのサイズと、可能な最大のアドレス変換容量とが比較される。たとえば、上位レベル・テーブルがDAT適合セグメント・テーブルである場合、最大変換容量は2ギガバイトである。
アドレス・スペースのサイズが変換容量を超える場合、ステップ810で例外条件が提供される。超えない場合、照会812で、ベース・アドレスがDMA開始アドレスよりも小さいかどうかについてさらに決定される。小さい場合、ステップ814で例外条件が提供される。小さくない場合、照会816で、アドレス限界がDMA終了アドレスよりも大きいかどうかについてさらに決定される。大きい場合、ステップ818で例外条件が提供される。一例では、DMA開始アドレスおよびDMA終了アドレスは、システム規模のポリシーに基づくものである。
その後、照会820で、必要であれば、I/Oアドレス変換を実行するために十分なリソースが使用可能であるかどうかについて決定される。使用可能でない場合、ステップ822で例外条件が提供される。使用可能である場合、照会824で、I/Oアドレス変換パラメータがFTEおよびDTE内にすでに登録されているかどうかについて決定される。これは、FTE/DTE内のパラメータの値をチェックすることによって決定される。たとえば、FTE/DTE内の値がゼロかまたは他の定義済みの値である場合、登録は実行されていない。FTEの位置を特定するためには命令内に提供されたハンドルが使用され、DTEの位置を特定するためにはFTE内のデバイス・インデックスが使用される。
アドレス変換に関してアダプタ機能がすでに登録されている場合、ステップ826で例外条件が提供される。登録されていない場合、照会828で、指定されたDMAアドレス・スペースが有効であるかどうか(すなわち、DTEが実行可能なアドレス・スペースであるかどうか)について決定される。有効でない場合、ステップ830で例外条件が提供される。すべてのチェックが首尾よく行われた場合、ステップ832で、変換パラメータがデバイス・テーブル・エントリ内に、およびオプションで、対応する機能テーブル・エントリ(または他の指定された位置)内に、配置される。たとえば、I/Oアドレス変換に関するPCI機能パラメータが機能情報ブロックからコピーされ、DTE/FTE内に配置される。これらのパラメータは、たとえばPCIベース・アドレス、PCIアドレス限界、変換フォーマット、ページ・サイズ、およびI/Oアドレス変換ポインタを含む。この動作により、指定されたDMAアドレス・スペースへのDMAアクセスが実行可能となる。これにより、アダプタ機能に関するI/Oアドレス変換が実行可能となる。
PCI機能制御修正命令によって指定可能な他の動作制御は、I/Oアドレス変換パラメータ登録解除動作であり、その例について図16を参照しながら説明する。この動作では、I/Oアドレス変換に関連する機能パラメータがゼロにリセットされる。この動作で、指定されたDMAアドレス・スペースへのDMAアクセスが実行不可となり、そのDMAアドレス・スペースに対するI/O変換索引(lookaside)バッファ・エントリのパージ(purge)が実行される。これにより、アドレス変換が実行不可となる。
図16を参照すると、一実施形態では、照会900で、I/Oアドレス変換パラメータが登録されていないかどうかについて決定される。一例では、この決定は、FTEまたはDTE内の適切なパラメータの値をチェックすることによって実行される。それらのフィールドがゼロまたは何らかの指定された値である場合、それらは登録されていない。したがって、ステップ902で例外条件が提供される。それらが登録されている場合、照会904で、DMAアドレス・スペースが有効であるかどうかについて決定される。これが無効である場合、ステップ906で例外条件が提供される。DMAアドレス・スペースが有効である場合、ステップ908で、デバイス・テーブル・エントリ内、およびオプションで、対応する機能テーブル・エントリ内の、変換パラメータがクリアされる。
上記で、アダプタによってシステム・メモリ・アドレスに提供された入力/出力アドレスを変換するための効率的なメカニズムについて、詳細に説明した。一例では、メモリにアクセスする際に、フルPCIアドレス(たとえば64ビット・アドレス全体)が使用されるが、変換のためにアドレスの一部のみを使用することによって、アドレス変換ルックアップが最小限に抑えられる。フル・アドレスの使用によって保護は追加されるが、たとえば変換のために低位ビットのみを使用することで、低レベルの変換ルックアップによってより効率的な変換が可能となる。これにより、オペレーティング・システム仮想アドレスと共存可能な、または同じであることが可能なアドレスを使用する際に、オペレーティング・システムの柔軟性が可能となる。さらに、アダプタがCPUアドレス変換テーブルを共有できるようになり、I/Oはスキャンが必要なテーブルの数を減らすことができる。さらに、異なるアダプタまたはオペレーティング・システムあるいはその両方が、アドレス・スペース領域の切り離しを使用できるようにすることで、保護が追加される。
本明細書で説明される実施形態では、アダプタはPCIアダプタである。本明細書で使用されるPCIは、PCIまたはPCIeを含むがこれに限定されない、Peripheral Component Interconnect Special Interest Group(PCI−SIG)によって定義されるPCIベース規格に従って実装される、任意のアダプタを言い表す。特定の一例では、Peripheral Component Interconnect Express(PCIe)は、I/Oアダプタとホスト・システムとの間のトランザクションに関する双方向通信プロトコルを定義する、構成要素レベルの相互接続標準である。PCI通信は、PCIeバス上の伝送に関するPCIe標準に従ってパケット内にカプセル化される。I/Oアダプタから発せられ、ホスト・システムで終端するトランザクションは、上り方向(upbound)トランザクションと呼ばれる。ホスト・システムから発せられ、I/Oアダプタで終端するトランザクションは下り方向(downbound)トランザクションと呼ばれる。PCIeトポロジは、PCIeバスを形成するためにペア(たとえば、一方は上り方向リンク、一方は下り方向リンク)を成す2地点間一方向リンクに基づく。PCIe標準はPCI−SIGによって維持および公開される。
当業者であれば理解されるように、本発明の態様は、システム、方法、またはコンピュータ・プログラム製品として具体化することができる。したがって、本発明の態様は、完全にハードウェアの実施形態、完全にソフトウェアの実施形態(ファームウェア、常駐ソフトウェア、マイクロコードなど)、または、本明細書ではすべてが全体として「回路」、「モジュール」、または「システム」と呼ばれることのあるソフトウェアおよびハードウェアの態様を組み合わせた実施形態の、形を取ることができる。さらに、本発明の態様は、具体化されたコンピュータ読み取り可能プログラム・コードを有する1つまたは複数のコンピュータ読み取り可能メディア内に具体化された、コンピュータ・プログラム製品の形を取ることができる。
1つまたは複数のコンピュータ読み取り可能メディアの任意の組み合わせを使用することができる。コンピュータ読み取り可能メディアは、コンピュータ読み取り可能ストレージ・メディアとすることができる。コンピュータ読み取り可能ストレージ・メディアは、たとえば、電子、磁気、光、電磁、赤外線、または半導体の、システム、装置、またはデバイス、あるいはそれらの任意の好適な組み合わせとすることができるが、これらに限定されるものではない。コンピュータ読み取り可能ストレージ・メディアのさらに特定の例(非網羅的リスト)は、1本または複数本のワイヤを有する電気接続、ポータブル・コンピュータ・ディスケット、ハードディスク、ランダム・アクセス・メモリ(RAM)、読み取り専用メモリ(ROM)、消去可能プログラマブル読み取り専用メモリ(EEPROMまたはフラッシュ・メモリ)、光ファイバ、ポータブル・コンパクト・ディスク読み取り専用メモリ(CD−ROM)、光ストレージ・デバイス、磁気ストレージ・デバイス、またはそれらの任意の好適な組み合わせを含む。本書との関連で、コンピュータ読み取り可能ストレージ・メディアは、命令実行のシステム、装置、またはデバイスによって、またはそれらに関連して使用するためのプログラムを、含むかまたは格納可能な、任意の有形メディアとすることができる。
次に図17を参照すると、一例では、コンピュータ・プログラム製品1000は、たとえば、本発明の1つまたは複数の態様を提供および容易にするためにコンピュータ読み取り可能プログラム・コード手段または論理1004をその上に格納するための、1つまたは複数のコンピュータ読み取り可能ストレージ・メディア1002を含む。
コンピュータ読み取り可能メディア上に具体化されたプログラム・コードは、無線、有線、光ファイバ・ケーブル、RFなど、またはそれらの任意の好適な組み合わせを含むがこれらに限定されない、適切なメディアを使用して伝送可能である。
本発明の態様に関する動作を実行するためのコンピュータ・プログラム・コードは、Java、Smalltalk、C++などのオブジェクト指向プログラミング言語と、「C」プログラミング言語、アセンブラ、または同様のプログラミング言語などの、従来の手続き型プログラミング言語とを含む、1つまたは複数のプログラミング言語の任意の組み合わせで作成可能である。プログラム・コードは、完全にユーザのコンピュータ上で、部分的にユーザのコンピュータ上で、スタンドアロン型ソフトウェア・パッケージとして、部分的にユーザのコンピュータ上および部分的にリモート・コンピュータ上で、あるいは、完全にリモートのコンピュータまたはサーバ上で、実行可能である。後者のシナリオでは、リモート・コンピュータを、ローカル・エリア・ネットワーク(LAN)またはワイド・エリア・ネットワーク(WAN)を含む任意のタイプのネットワークを介してユーザのコンピュータに接続するか、あるいは、(たとえば、インターネット・サービス・プロバイダを使用し、インターネットを介して)外部コンピュータに接続することができる。
本明細書では、本発明の実施形態に従った方法、装置(システム)、およびコンピュータ・プログラム製品の、流れ図またはブロック図あるいはその両方を参照しながら、本発明の態様について説明する。流れ図またはブロック図あるいはその両方の各ブロック、および、流れ図またはブロック図あるいはその両方におけるブロックの組み合わせが、コンピュータ・プログラム命令によって実装可能であることを理解されよう。これらのコンピュータ・プログラム命令は、機械を生成するために、汎用コンピュータ、特定用途向けコンピュータ、または他のプログラマブル・データ処理装置の、プロセッサに提供可能であり、結果としてコンピュータまたは他のプログラマブル・データ処理装置のプロセッサを介して実行する命令が、流れ図またはブロック図あるいはその両方のブロック内に指定された機能/動作を実装するための手段を作成する。
コンピュータ、他のプログラマブル・データ処理装置、または他のデバイスに、特定の様式で機能するように指示することが可能な、これらのコンピュータ・プログラム命令を、コンピュータ読み取り可能メディアに格納することも可能であり、結果として、コンピュータ読み取り可能メディア内に格納された命令が、流れ図またはブロック図あるいはその両方のブロック内に指定された機能/動作を実装する命令を含む製品を生成する。
コンピュータ実装プロセスを生成するために、コンピュータ、他のプログラマブル装置、または他のデバイス上で一連の動作ステップを実行させるように、コンピュータ・プログラム命令を、コンピュータ、他のプログラマブル・データ処理装置、または他のデバイス上にロードすることも可能であり、結果として、コンピュータまたは他のプログラマブル装置上で実行する命令は、流れ図またはブロック図あるいはその両方のブロック内に指定された機能/動作を実装するための処理を提供する。
図面内の流れ図およびブロック図は、本発明の様々な実施形態に従った、システム、方法、およびコンピュータ・プログラム製品の可能な実装のアーキテクチャ、機能、および動作を示す。この点で、流れ図またはブロック図内の各ブロックは、指定された論理機能を実装するための1つまたは複数の実行可能命令を含む、モジュール、セグメント、またはコードの一部を表すことが可能である。いくつかの代替の実装では、ブロック内に示された機能が、図に示された順序外で実行可能であることにも留意されたい。たとえば、関連する機能に応じて、連続して示された2つのブロックを実際にはほぼ同時に実行することが可能であるか、またはこのブロックを逆の順序で実行することが可能である。ブロック図または流れ図あるいはその両方の各ブロック、および、ブロック図または流れ図あるいはその両方内のブロックの組み合わせが、指定された機能または動作を実行する特定用途向けハードウェアベース・システム、あるいは、特定用途向けハードウェアとコンピュータ命令との組み合わせによって、実装可能であることにも留意されよう。
上記に加えて、本発明の1つまたは複数の態様は、顧客環境の管理を提示するサービス・プロバイダによる、提供、提示、展開、管理、サービス提供などが可能である。たとえばサービス・プロバイダは、1人または複数の顧客に対して本発明の1つまたは複数の態様を実行する、コンピュータ・コードまたはコンピュータ・インフラストラクチャあるいはその両方を、作成、維持、サポートなどを実行することができる。次に、サービス・プロバイダは、例として、加入または料金契約あるいはその両方の下で、顧客からの支払いを受け取ることができる。加えて、または別の方法として、サービス・プロバイダは、1人または複数の第三者への広告コンテンツの販売から支払いを受け取ることができる。
本発明の一態様では、本発明の1つまたは複数の態様を実行するためのアプリケーションが展開可能である。一例として、アプリケーションの展開は、本発明の1つまたは複数の態様を実行するように動作可能なコンピュータ・インフラストラクチャを提供することを含む。
本発明の他の態様として、コンピュータ読み取り可能コードをコンピューティング・システムに統合することを含む、コンピューティング・インフラストラクチャが展開可能である。コードとコンピューティング・システムとを組み合わせて、本発明の1つまたは複数の態様を実行することができる。
本発明のさらに他の態様として、コンピュータ読み取り可能コードをコンピュータ・システムに統合することを含む、コンピューティング・インフラストラクチャを統合するためのプロセスが提供可能である。コンピュータ・システムはコンピュータ読み取り可能メディアを備え、コンピュータ・メディアは本発明の1つまたは複数の態様を含む。コードとコンピュータ・システムとを組み合わせて、本発明の1つまたは複数の態様を実行することができる。
上記で様々な実施形態について説明したが、これらは単なる例である。たとえば、他のアーキテクチャのコンピューティング環境は、本発明の1つまたは複数の態様を組み込んで使用することができる。例として、インターナショナル・ビジネス・マシーンズ・コーポレーションによって提示されたPower Systemsサーバまたは他のサーバ、あるいは他の企業のサーバなどの、System z(R)サーバ以外のサーバは、本発明の1つまたは複数の態様を含むこと、使用すること、またはそれらから恩恵を得ること、あるいはそれらすべてが可能である。さらに、本明細書の例では、アダプタおよびPCIハブはサーバの一部とみなされるが、他の実施形態では、それらは必ずしもサーバの一部とみなされる必要はなく、単に、コンピューティング環境のシステム・メモリまたは他の構成要素あるいはその両方に結合されているものとみなすことができる。コンピューティング環境はサーバである必要はない。さらに、変換テーブルについて説明しているが、任意のデータ構造を使用することが可能であり、テーブルという用語はすべてのこうしたデータ構造を含むものである。さらに、アダプタはPCIベースであるが、本発明の1つまたは複数の態様は、他のアダプタまたは他のI/O構成要素と共に使用可能である。アダプタおよびPCIアダプタは、単なる例である。さらに、本発明から逸脱することなく、他のサイズのアドレス・スペース、アドレス・テーブル、またはページ、あるいはそれらすべてを使用することができる。さらにDTEは、より多い、より少ない、または異なる情報を含むことができる。またさらに、本発明の1つまたは複数の態様を使用して、他のタイプのアドレスを変換することができる。多くの他の変形が可能である。
さらに、他のタイプのコンピューティング環境が、本発明の1つまたは複数の態様からの恩恵を得ることができる。例として、システム・バスを介して直接または間接的にメモリ要素に結合された少なくとも2つのプロセッサを含む、プログラム・コードの格納または実行あるいはその両方を行うために好適なデータ処理システムが使用可能である。メモリ要素は、たとえば、プログラム・コードの実際の実行中に採用されるローカル・メモリと、大容量ストレージと、実行中に大容量ストレージからコードを取り出さなければならない回数を低減させるために少なくともいくつかのプログラム・コードの一時ストレージを提供するキャッシュ・メモリとを、含む。
入力/出力またはI/Oデバイス(キーボード、ディスプレイ、ポインティング・デバイス、DASD、テープ、CD、DVD、サム・ドライブ、および他のメモリ・メディアなど)を、直接、または介在するI/Oコントローラを介して、システムに結合することができる。データ処理システムを、介在する専用または公衆のネットワークを介して、他のデータ処理システムあるいはリモートのプリンタまたはストレージ・デバイスに結合できるようにするために、ネットワーク・アダプタをシステムに結合することもできる。モデム、ケーブル・モデム、およびイーサネット・カードは、使用可能なネットワーク・アダプタのほんのいくつかのタイプである。
図18を参照すると、本発明の1つまたは複数の態様を実装するためのホスト・コンピュータ・システム5000の代表的な構成要素が示されている。代表的なホスト・コンピュータ5000は、コンピュータ・メモリ(すなわち中央ストレージ)5002と通信する1つまたは複数のCPU5001、ならびに、他のコンピュータまたはSANなどと通信するためのストレージ・メディア・デバイス5011およびネットワーク5010へのI/Oインターフェースを備える。CPU5001は、アーキテクチャ命令セットおよびアーキテクチャ機能を有するアーキテクチャに準拠している。CPU 5001は、プログラム・アドレス(仮想アドレス)をメモリの実アドレスに変換するための、ダイナミック・アドレス変換(DAT)5003を有することができる。DATは、コンピュータ・メモリ5002のブロックへのその後のアクセスが、アドレス変換の遅延を必要としないように、通常、変換をキャッシュに入れるための変換索引バッファ(TLB)5007を含む。通常、コンピュータ・メモリ5002とプロセッサ5001との間に、キャッシュ5009が採用される。キャッシュ5009は、複数のCPUが使用可能な大型キャッシュと、大型キャッシュと各CPUとの間の小型、高速(低レベル)キャッシュとを有する、階層型とすることができる。いくつかの実装では、低レベル・キャッシュは、命令フェッチおよびデータ・アクセスのための別の低レベル・キャッシュを提供するために、分割される。一実施形態では、命令は、キャッシュ5009を介して命令フェッチ・ユニット5004によってメモリ5002からフェッチされる。命令は、命令復号ユニット5006内で復号され、命令実行ユニット5008へと(いくつかの実施形態では他の命令と共に)ディスパッチされる。通常、たとえば演算実行ユニット、浮動小数点実行ユニット、および分岐命令実行ユニットなどの、いくつかの実行ユニット5008が採用される。この命令は、必要に応じて、命令指定レジスタまたはメモリからオペランドにアクセスする、実行ユニットによって実行される。オペランドがメモリ5002からアクセス(ロードまたは格納)されるものである場合、ロード/格納ユニット5005は、通常、実行される命令の制御の下にアクセスを処理する。命令は、ハードウェア回路内または内部マイクロコード(ファームウェア)内で、あるいはそれらの組み合わせによって、実行可能である。
上記のように、コンピュータ・システムは、ローカル(またはメイン)ストレージ内に、情報、ならびにアドレス指定、保護、および参照、ならびに変更記録を含む。アドレス指定のいくつかの態様は、アドレスのフォーマット、アドレス・スペースの概念、様々なタイプのアドレス、および、1つのタイプのアドレスが他のタイプのアドレスに変換される様式を含む。いくつかのメイン・ストレージは、永続的に割り当てられたストレージ位置を含む。メイン・ストレージは、直接アドレス指定可能なデータの高速アクセス・ストレージを、システムに提供する。データおよびプログラムはどちらも、処理される前に(入力デバイスから)メイン・ストレージ内にロードされることになる。
メイン・ストレージは、時にはキャッシュと呼ばれる、1つまたは複数の小型高速アクセス・バッファ・ストレージを含むことができる。キャッシュは、通常、CPUまたはI/Oプロセッサに物理的に関連付けられる。性能に関する以外の、別個のストレージ・メディアの物理構造および使用の効果は、通常、プログラムによって観察することはできない。
別々のキャッシュを、命令およびデータ・オペランドに対して維持することができる。キャッシュ内の情報は、キャッシュ・ブロックまたはキャッシュ・ライン(または単にライン)と呼ばれる整数境界(integral boundary)上の連続バイト内で維持される。モデルは、バイト単位のキャッシュ・ラインのサイズを戻す、キャッシュ属性抽出命令を提供する。モデルは、データまたは命令キャッシュへのストレージのプリフェッチまたはキャッシュからのデータの解放を実行する、データのプリフェッチ命令および比較的長いデータのプリフェッチ命令を提供することもできる。
ストレージは、長い水平のビットの文字列とみなされる。たいていの動作では、ストレージへのアクセスは左から右の順に進行する。ビットの文字列は、8ビット単位に細分化される。8ビット単位がバイトと呼ばれ、これがすべての情報フォーマットの基本構築ブロックである。ストレージ内の各バイト位置は、そのバイト位置のアドレスであるか、または単にバイト・アドレスである、固有の非負整数によって識別される。隣接するバイト位置は、左の0から始まり、左から右へと順に進んでいく、連続アドレスを有する。アドレスは符号なし2進整数であり、24、31、または64ビットである。
情報は、ストレージとCPUまたはチャネル・サブシステムとの間で、1回に1バイトまたはバイト・グループずつ送信される。特に指定のない限り、たとえばz/Architecture(R)では、ストレージ内のバイト・グループはグループの左端のバイトによってアドレス指定される。グループ内のバイト数は、実行される動作によって暗黙的または明示的に指定される。CPU動作で使用される場合、バイトのグループはフィールドと呼ばれる。バイトの各グループ内で、たとえばz/Architecture(R)では、ビットは左から右の順に番号付けされる。z/Architecture(R)では、左端のビットは時には「高位」ビットと呼ばれ、右端のビットは「低位」ビットと呼ばれる。しかしながら、ビット番号はストレージ・アドレスではない。バイトのみがアドレス指定可能である。ストレージ内のバイトの個別のビット上で動作するために、バイト全体がアクセスされる。バイト内のビットには、左から右へと、0から7の番号が付けられる(たとえばz/Architecture(R)の場合)。アドレス内のビットには、24ビット・アドレスの場合は8〜31または40〜63、あるいは31ビット・アドレスの場合は1〜31または33〜63の、番号を付けることが可能であり、64ビット・アドレスの場合は0〜63が番号付けされる。任意の他の複数バイトの固定長フォーマットでは、フォーマットを構成するビットには、0から始まる連続番号が付けられる。エラー検出のため、および好ましくは訂正のために、1つまたは複数のチェック・ビットを、各バイトまたはバイト・グループと共に伝送することができる。こうしたチェック・ビットは機械によって自動的に生成され、プログラムによって直接制御することはできない。ストレージ容量はバイト数で表される。ストレージ・オペランド・フィールドの長さが命令のオペレーション・コードによって暗示される場合、フィールドは、1、2、4、8、または16バイトとすることが可能な、固定長を有するものと言われる。いくつかの命令では、さらに大きいフィールドが暗示される場合がある。ストレージ・オペランド・フィールドの長さが暗示されず、明示的に示される場合、フィールドは可変長を有するものと言われる。可変長オペランドは、1バイトずつの増分(またはいくつかの命令では、2バイトの倍数または他の倍数)での長さの変化が可能である。情報がストレージ内に配置される場合、たとえストレージへの物理経路の幅が格納されているフィールドの長さよりも長い場合であっても、指定されたフィールドに含まれるそれらのバイト位置のコンテンツのみが置き換えられる。
情報の一定の単位は、ストレージ内の整数境界とされる。境界は、そのストレージ・アドレスがバイト単位の長さの倍数である場合、情報の単位に関する整数と呼ばれる。整数境界上の2、4、8、および16バイトのフィールドには、特別の名前が与えられる。ハーフワードは、2バイト境界上の2つの連続するバイトのグループであり、命令の基本構築ブロックである。ワードは、4バイト境界上の4つの連続するバイトのグループである。ダブルワードは、8バイト境界上の8つの連続するバイトのグループである。クワドワード(quadword)は、16バイト境界上の16の連続するバイトのグループである。ストレージ・アドレスがハーフワード、ワード、ダブルワード、およびクワドワードを指定する場合、アドレスの2進表現は、それぞれ右端に1つ、2つ、3つ、または4つのゼロビットを含む。命令は、2バイト整数境界上にあるものとされる。ほとんどの命令のストレージ・オペランドは、境界整列要件を有さない。
命令およびデータ・オペランドに対して別々のキャッシュを実装するデバイスでは、後で命令がフェッチされる元であるキャッシュ・ラインに、プログラムが格納する場合、格納が後でフェッチされる命令を変更するかどうかにかかわらず、大幅な遅延を経験する可能性がある。
一実施形態では、本発明は、ソフトウェア(時にはライセンス付き内部コード、ファームウェア、マイクロコード、ミリコード、ピココードなどと呼ばれ、そのいずれかは本発明と一致することになる)によって実施可能である。図18を参照すると、本発明を具体化するソフトウェア・プログラム・コードは、通常、CD−ROMドライブ、テープ・ドライブ、またはハード・ドライブなどの、長期ストレージ・メディア・デバイス5011からホスト・システム5000のプロセッサ5001によってアクセスされる。ソフトウェア・プログラム・コードは、ディスケット、ハード・ドライブ、またはCD−ROMなどの、データ処理システムと共に使用するための様々な知られたメディアのいずれかで、具体化することができる。コードは、こうしたメディア上で配布可能であるか、またはコンピュータ・メモリ5002からユーザへ、あるいは、ネットワーク5010を介して1つのコンピュータ・システムのストレージから他のコンピュータ・システムへ、こうした他のシステムのユーザが使用するために、配布可能である。
ソフトウェア・プログラム・コードは、様々なコンピュータ構成要素および1つまたは複数のアプリケーション・プログラムの機能および対話を制御する、オペレーティング・システムを含む。プログラム・コードは、通常、ストレージ・メディア・デバイス5011から、プロセッサ5001による処理に使用可能な比較的高速のコンピュータ・ストレージ5002へと、ページングされる。物理メディア上のメモリ内のソフトウェア・プログラム・コードを具体化するため、またはネットワークを介してソフトウェア・コードを配布するため、あるいはその両方のための技法および方法は、良く知られており、本明細書ではこれ以上考察しない。プログラム・コードは、有形メディア(電子メモリ・モジュール(RAM)、フラッシュ・メモリ、コンパクト・ディスク(CD)、DVD、磁気テープなどを含むがこれらに限定されない)上で作成および格納される場合、しばしば「コンピュータ・プログラム製品」と呼ばれる。コンピュータ・プログラム製品メディアは、通常、処理回路による実行のために、好ましくはコンピュータ・システム内の処理回路によって読み取り可能である。
図19は、内部で本発明が実施可能な、代表的なワークステーションまたはサーバ・ハードウェア・システムを示す。図19のシステム5020は、オプションの周辺デバイスを含む、パーソナル・コンピュータ、ワークステーション、またはサーバなどの、代表的な基本コンピュータ・システム5021を備える。基本コンピュータ・システム5021は、1つまたは複数のプロセッサ5026、ならびに、既知の技法に従ってプロセッサ5026とシステム5021の他の構成要素との間の通信を接続および実行可能にするために採用されたバスを含む。バスは、プロセッサ5026を、メモリ5025と、たとえばハード・ドライブ(たとえば磁気メディア、CD、DVD、およびフラッシュ・メモリのうちのいずれかを含む)またはテープ・ドライブを含むことが可能な長期ストレージ5027と、に接続する。システム5021は、バスを介してマイクロプロセッサ5026を、キーボード5024、マウス5023、プリンタ/スキャナ5030、または、タッチ・スクリーン、デジタル入力パッドなどの任意のユーザ・インターフェース・デバイスとすることが可能な他のインターフェース・デバイス、あるいはそれらすべてなどの、1つまたは複数のインターフェース・デバイスに接続する、ユーザ・インターフェース・アダプタも含む場合がある。バスは、ディスプレイ・アダプタを介して、LCDスクリーンまたはモニタなどのディスプレイ・デバイス5022を、マイクロプロセッサ5026にも接続する。
システム5021は、ネットワーク5029との通信5028が可能なネットワーク・アダプタを用いて、他のコンピュータまたはコンピュータのネットワークと通信可能である。ネットワーク・アダプタの例は、通信チャネル、トークン・リング、イーサネット、またはモデムである。別の方法として、システム5021は、CDPD(セルラ式デジタル・パケット・データ)カードなどの無線インターフェースを使用して、通信可能である。システム5021は、ローカル・エリア・ネットワーク(LAN)またはワイド・エリア・ネットワーク(WAN)におけるこうした他のコンピュータと関連付けることが可能であるか、または、システム5021は、他のコンピュータとのクライアント/サーバ配置構成におけるクライアントなどとすることができる。これらの構成ならびに適切な通信ハードウェアおよびソフトウェアのすべてが、当分野で知られている。
図20は、内部で本発明が実施可能なデータ処理ネットワーク5040を示す。データ処理システム5040は、それぞれが複数の個別のワークステーション5041、5042、5043、5044を含むことが可能な、無線ネットワークおよび有線ネットワークなどの複数の個別のネットワークを含むことができる。加えて、当業者であれば、1つまたは複数のLANを含めることが可能であることを理解し、LANはホスト・プロセッサに結合された複数のインテリジェント・ワークステーションを備えることができる。
さらに図20を参照すると、ネットワークは、ゲートウェイ・コンピュータ(クライアント・サーバ5046)、またはアプリケーション・サーバ(データ・リポジトリにアクセス可能であり、ワークステーション5045から直接アクセスすることも可能な、リモート・サーバ5048)などの、メインフレーム・コンピュータまたはサーバを含むこともできる。ゲートウェイ・コンピュータ5046は、各個別のネットワークへの入力ポイントとして働く。ゲートウェイは、一方のネットワーキング・プロトコルを他方に接続する場合に必要である。ゲートウェイ5046は、ゲートウェイ5046は、好ましくは、通信リンクによって他のネットワーク(たとえばインターネット5047)に結合することが可能である。ゲートウェイ5046は、通信リンクを使用して1つまたは複数のワークステーション5041、5042、5043、5044に直接結合することも可能である。ゲートウェイ・コンピュータは、インターナショナル・ビジネス・マシーンズ・コーポレーションから入手可能な、IBM eServer(TM)System z(R)サーバを使用して実装可能である。
図19および図20を同時に参照すると、CD−ROMドライブまたはハード・ドライブなどの、長期ストレージ・メディア5027から、システム5020のプロセッサ5026によって、本発明を具体化することが可能なソフトウェア・プログラミング・コードにアクセスすることができる。ソフトウェア・プログラミング・コードは、ディスケット、ハード・ドライブ、またはCD−ROMなどの、データ処理システムで使用するために、様々な既知のメディアのいずれかで具体化することができる。コードは、こうしたメディア上で配布可能であるか、または、1つのコンピュータ・システムのメモリまたはストレージから、ネットワークを介して他のコンピュータ・システムへと、こうした他のシステムのユーザが使用するために、ユーザ5050、5051に配布可能である。
別の方法として、プログラミング・コードは、メモリ5025内で具体化し、プロセッサ・バスを使用してプロセッサ5026によってアクセス可能である。こうしたプログラム・コードは、様々なコンピュータ構成要素および1つまたは複数のアプリケーション・プログラム5032の機能および対話を制御する、オペレーティング・システムを含む。プログラム・コードは、通常、ストレージ・メディア5027から、プロセッサ5026による処理に使用可能な高速メモリ5025へとページングされる。物理メディア上のメモリ内のソフトウェア・プログラム・コードを具体化するため、またはネットワークを介してソフトウェア・コードを配布するため、あるいはその両方のための技法および方法は、良く知られており、本明細書ではこれ以上考察しない。プログラム・コードは、有形メディア(電子メモリ・モジュール(RAM)、フラッシュ・メモリ、コンパクト・ディスク(CD)、DVD、磁気テープなどを含むがこれらに限定されない)上で作成および格納される場合、しばしば「コンピュータ・プログラム製品」と呼ばれる。コンピュータ・プログラム製品メディアは、通常、処理回路による実行のために、好ましくはコンピュータ・システム内の処理回路によって読み取り可能である。
プロセッサが最も容易に使用できるキャッシュ(通常はプロセッサの他のキャッシュより高速かつ小型)は、最低(L1またはレベル1)キャッシュであり、メイン・ストア(メイン・メモリ)は、最高レベル・キャッシュ(3レベルある場合はL3)である。最低レベル・キャッシュはしばしば、実行されることになる機械命令を保持する命令キャッシュ(Iキャッシュ)と、データ・オペランドを保持するデータ・キャッシュ(Dキャッシュ)とに分割される。
図21を参照すると、例示的プロセッサの実施形態がプロセッサ5026に関して示されている。通常、プロセッサの性能を向上させるために、キャッシュ5053の1つまたは複数のレベルがメモリ・ブロックをバッファに入れるために採用される。キャッシュ5053は、使用される可能性が高いメモリ・データのキャッシュ・ラインを保持する、高速バッファである。典型的なキャッシュ・ラインは、64、128、または256バイトのメモリ・データである。別々のキャッシュが、データのキャッシュよりも命令のキャッシュにしばしば採用される。キャッシュ・コヒーレンス(メモリおよびキャッシュ内のラインのコピーの同期化)は、しばしば、当分野で周知の様々な「スヌープ(snoop)」アルゴリズムによって提供される。プロセッサ・システムのメイン・メモリ・ストレージ5025は、しばしばキャッシュと呼ばれる。4レベルのキャッシュ5053を有するプロセッサ・システムでは、メイン・ストレージ5025は、通常はより高速であり、コンピュータ・システムが使用可能な不揮発性ストレージ(DASD、テープなど)の一部のみを保持するため、時にはレベル5(L5)と呼ばれる。メイン・ストレージ5025は、オペレーティング・システムによってメイン・ストレージ5025内におよびメイン・ストレージ5025外にページングされたデータのページを「キャッシュ」する。
プログラム・カウンタ(命令カウンタ)5061は、実行されることになる現行命令のアドレスを追跡する。z/Architecture(R)プロセッサ内のプログラム・カウンタは64ビットであり、前のアドレス指定限界をサポートするために31または24ビットまで切り詰めることができる。プログラム・カウンタは通常、コンテキスト切り換え時に持続するように、コンピュータのPSW(プログラム状況ワード)で具体化される。したがって、プログラム・カウンタ値を有する進行中のプログラムに、たとえばオペレーティング・システムが割り込むことができる(プログラム環境からオペレーティング・システム環境へのコンテキスト切り換え)。プログラムのPSWは、プログラムがアクティブでない間、プログラム・カウンタ値を維持し、オペレーティング・システムが実行している間、オペレーティング・システムの(PSWの)プログラム・カウンタが使用される。通常、プログラム・カウンタは、現行命令のバイト数に等しい数ずつ増分される。RISC(縮小命令セット・コンピューティング)命令は、通常、固定長であり、CISC(複数命令セット・コンピューティング)命令は、通常、可変長である。IBM z/Architecture(R)の命令は、2、4、または6バイトを有するCISC命令である。プログラム・カウンタ5061は、コンテキスト切り換え動作、または、たとえば分岐命令の分岐実行動作のいずれかによって修正される。コンテキスト切り換え動作では、実行されているプログラムに関する(条件コードなどの)他の状態情報と共に、現行プログラムのカウンタ値がプログラム状況ワードに保存され、実行されることになる新しいプログラム・モジュールの命令をポイントする、新しいプログラムのカウンタ値がロードされる。分岐命令の結果をプログラム・カウンタ5061にロードすることによって、プログラムがプログラム内で意思決定またはループできるようにするために、分岐実行動作が実行される。
通常、命令フェッチ・ユニット5055は、プロセッサ5026の代わりに命令をフェッチするために採用される。フェッチ・ユニットは、「次の順次命令」、分岐実行命令のターゲット命令、またはコンテキスト切り換えに続くプログラムの第1の命令の、いずれかをフェッチする。現在の命令フェッチ・ユニットは、しばしば、プリフェッチされた命令が使用される可能性に基づいて命令を投機的にプリフェッチするために、プリフェッチ技法を採用する。たとえば、フェッチ・ユニットは、次の順次命令および他の順次命令の追加バイトを含む、16バイトの命令をフェッチすることができる。
フェッチされた命令は、その後、プロセッサ5026によって実行される。ある実施形態では、フェッチされた命令がフェッチ・ユニットのディスパッチ・ユニット5056に渡される。ディスパッチ・ユニットは命令を復号し、復号された命令に関する情報を適切なユニット5057、5058、5060に転送する。実行ユニット5057は、通常、復号された算術命令に関する情報を、命令フェッチ・ユニット5055から受信し、命令のオペレーション・コードに従って、オペランド上で算術演算を実行することになる。オペランドは、好ましくはメモリ5025、アーキテクチャ・レジスタ5029、または実行されている命令の即時フィールドの、いずれかから、実行ユニット5057に提供される。実行の結果は、格納される場合、メモリ5025、レジスタ5029、または(制御レジスタ、PSWレジスタなどの)他の機械ハードウェアの、いずれかに格納される。
プロセッサ5026は、通常、命令の機能を実行するための1つまたは複数のユニット5057、5058、5060を有する。図22を参照すると、実行ユニット5057は、アーキテクチャ汎用レジスタ5059、復号/ディスパッチ・ユニット5056、ロード/格納ユニット5060、およびその他5065のプロセッサ・ユニットと、インターフェース論理5071によって通信することができる。実行ユニット5057は、算術論理ユニット(ALU)5066が動作することになる情報を保持するために、いくつかのレジスタ回路5067、5068、5069を採用することができる。ALUは、加算、減算、乗算、および除算などの算術演算、ならびに、論理積、論理和、および排他的論理和(XOR)、回転およびシフトなどの、論理機能を実行する。好ましくは、ALUは、設計に依存した特別な演算をサポートする。他の回路は、たとえば条件コードおよび回復サポート論理を含む、他のアーキテクチャ機構5072を提供することができる。通常、ALU演算の結果は、結果を様々な他の処理機能に転送できる出力レジスタ回路5070内に保持される。プロセッサ・ユニットには多くの配置構成があるが、この説明では、一実施形態の代表的な理解を与えることのみが意図されている。
たとえばADD命令は、算術および論理機能を有する実行ユニット5057内で実行されるが、たとえば浮動小数点命令は、特別な浮動小数点機能を有する浮動小数点実行内で実行される。好ましくは、実行ユニットは、オペランド上でオペレーション・コード定義機能を実行することによって、命令によって識別されたオペランド上で動作する。たとえば、加算命令は、命令のレジスタ・フィールドによって識別された2つのレジスタ5059内で見つかったオペランド上で、実行ユニット5057によって実行されることが可能である。
実行ユニット5057は、2つのオペランド上で算術加算を実行し、その結果を第3のオペランドに格納するが、この第3のオペランドは、第3のレジスタ、または2つのソース・レジスタのうちの1つとすることができる。実行ユニットは、好ましくは、シフト、回転、論理積、論理和、および排他的論理和などの、様々な論理機能、ならびに、加算、減算、乗算、除算のいずれかを含む、様々な算術機能を実行することが可能な、演算論理ユニット(ALU)5066を使用する。ALU5066のいくつかはスカラー演算用に、いくつかは浮動小数点用に設計されている。データは、アーキテクチャに応じて、ビッグ・エンディアン(Big Endian)(最高バイト・アドレスに最下位バイトがある)またはリトル・エンディアン(最低バイト・アドレスに最下位バイトがある)とすることができる。IBM z/Architecture(R)はビッグ・エンディアンである。符号付きフィールドは、アーキテクチャに応じて、符号付き絶対値、1の補数、または2の補数とすることが可能である。2の補数内の負の値または正の値のいずれかがALU内で加算のみを必要とすることから、ALUは減算機能を設計する必要がないという点において、2の補数が有利である。数は通常、省略表現で記述され、たとえば12ビット・フィールドは4096バイト・ブロックのアドレスを画定し、一般に4Kバイト(キロバイト)ブロックと記述される。
図23を参照すると、分岐命令を実行するための分岐命令情報は、通常、他の条件付き演算が完了する前に分岐の結果を予測するために、分岐履歴テーブル5082などの分岐予測アルゴリズムをしばしば採用する、分岐ユニット5058へと送信される。現行の分岐命令のターゲットはフェッチされ、条件付き演算が完了する前に投機的に実行される。条件付き演算が完了した場合、投機的に実行された分岐命令は、条件付き演算の条件および投機された結果に基づいて、完了または廃棄される。典型的な分岐命令は、条件コードをテストし、条件コードが分岐命令の分岐要件に合致する場合、ターゲット・アドレスに分岐することが可能であり、ターゲット・アドレスは、たとえば、命令のレジスタ・フィールドまたは即時フィールド内で見つかった中のいくつかの数に基づいて算出可能である。分岐ユニット5058は、複数の入力レジスタ回路5075、5076、5077および出力レジスタ回路5080を有する、ALU5074を採用することができる。分岐ユニット5058は、汎用レジスタ5059、復号ディスパッチ・ユニット5056、または、たとえば他の回路5073と通信することができる。
命令グループの実行は、たとえば、オペレーティング・システムによって開始されるコンテキスト切り換え、コンテキスト切り換えを発生させるプログラム例外またはエラー、複数のプログラム(マルチスレッド環境の場合)のコンテキスト切り換えまたはマルチスレッド・アクティビティを発生させるI/O割り込み信号を含む、多様な理由で、割り込まれる可能性がある。好ましくは、コンテキスト切り換え動作は、現在実行中のプログラムに関する状態情報を保存し、その後、呼び出された他のプログラムに関する状態情報をロードする。状態情報は、たとえばハードウェア・レジスタまたはメモリ内に保存することができる。状態情報は、好ましくは、実行されることになる次の命令をポイントするプログラム・カウンタ値、条件コード、メモリ変換情報、およびアーキテクチャ・レジスタ・コンテンツを含む。コンテキスト切り換えアクティビティは、ハードウェア回路、アプリケーション・プログラム、オペレーティング・システム・プログラム、またはファームウェア・コード(マイクロコード、ピココード、またはライセンス付き内部コード(LIC))単独で、あるいはそれらの組み合わせによって、行使することが可能である。
プロセッサは、命令定義の方法に従ってオペランドにアクセスする。命令は、命令の一部の値を使用して即時オペランドを提供すること、汎用レジスタまたは特定用途向けレジスタ(たとえば浮動小数点レジスタ)のいずれかを明示的にポイントする1つまたは複数のレジスタ・フィールドを提供することが、可能である。命令は、オペレーション・コード・フィールドによってオペランドとして識別された、暗黙レジスタを使用することができる。命令は、オペランドに関するメモリ位置を使用することができる。命令が、たとえばメモリ内のオペランドのアドレスを提供するためにまとめて追加される、基本レジスタ、インデックス・レジスタ、および即時フィールド(変位フィールド)を定義する、z/Architecture(R)の長変位機構(long displacement facility)によって例示されるように、オペランドのメモリ位置は、レジスタ、即時フィールド、またはレジスタと即時フィールドとの組み合わせによって提供可能である。本明細書では、特に指定がない限り、位置とはメイン・メモリ(メイン・ストレージ)内の位置を示唆する。
図24を参照すると、プロセッサはロード/格納ユニット5060を使用してストレージにアクセスする。ロード/格納ユニット5060は、メモリ5053内のターゲット・オペランドのアドレスを取得すること、およびこのオペランドをレジスタ5059または他のメモリ5053位置内にロードすることによって、ロード動作を実行することが可能であるか、あるいは、メモリ5053内のターゲット・オペランドのアドレスを取得すること、および、レジスタ5059または他のメモリ5053位置から取得したデータをメモリ5053内のターゲット・オペランド位置に格納することによって、格納動作を実行することが可能である。ロード/格納ユニット5060は投機的とすることが可能であり、命令シーケンスとは順序外れのシーケンスでメモリにアクセスすることが可能であるが、ロード/格納ユニット5060は、その命令が順序通りに実行されたようにプログラムに対して表示することを維持するものである。ロード/格納ユニット5060は、汎用レジスタ5059、復号/ディスパッチ・ユニット5056、キャッシュ/メモリ・インターフェース5053、または他の要素5083との通信が可能であり、ストレージ・アドレスを計算するため、および、動作を順番に維持するためのパイプライン・シーケンシングを提供するための、様々なレジスタ回路、ALU5085、および制御論理5090を備える。いくつかの動作は順序外れとすることが可能であるが、ロード/格納ユニットは、当分野で周知のように、プログラムに対して順序外れ動作を順序通りに実行されたように表すための機能を提供する。
好ましくは、アプリケーション・プログラムが「見る」アドレスは、しばしば仮想アドレスと呼ばれる。仮想アドレスは、時には「論理アドレス」および「有効アドレス」と呼ばれる。これらの仮想アドレスは、単に仮想アドレスにオフセット値をプレフィックス付けすること、仮想アドレスを1つまたは複数の変換テーブルを介して変換することを含むが、これらに限定されない、様々な動的アドレス変換(DAT)技術のうちの1つによって物理メモリ位置にリダイレクトされるという点で、仮想であり、変換テーブルは、好ましくは少なくともセグメント・テーブルおよびページ・テーブルを単独またはそれらの組み合わせで含み、好ましくは、セグメント・テーブルはページ・テーブルをポイントするエントリを有する。z/Architecture(R)では、領域第1テーブル、領域第2テーブル、領域第3テーブル、セグメント・テーブル、およびオプション・ページ・テーブルを含む、変換の階層が提供される。アドレス変換の性能は、仮想アドレスを関連付けられた物理メモリ位置にマッピングするエントリを備える変換索引バッファ(TLB)を使用することによって、しばしば向上される。エントリは、DATが変換テーブルを使用して仮想アドレスを変換した場合に作成される。その後の仮想アドレスの使用は、低速逐次変換テーブル・アクセスではなく高速TLBのエントリを使用することができる。TLBコンテンツは、LRU(最長時間未使用法)を含む様々な置換アルゴリズムによって管理可能である。
プロセッサがマルチプロセッサ・システムのプロセッサである場合、各プロセッサは、コヒーレンシに関してインターロックされた、I/O、キャッシュ、TLB、およびメモリなどの、共有リソースを維持する責務を有する。通常、キャッシュ・コヒーレンシを維持する際には、「スヌープ」技術が使用される。スヌープ環境では、各キャッシュ・ラインは、共有を容易にするために、共有状態、排他的状態、変更状態、無効状態などのうちのいずれかとしてマーク付けすることが可能である。
I/Oユニット5054(図21)は、たとえばテープ、ディスク、プリンタ、ディスプレイ、およびネットワークを含む、周辺デバイスに接続するための手段を、プロセッサに提供する。I/Oユニットは、しばしば、ソフトウェア・ドライバによってコンピュータ・プログラムに提示される。IBM(R)からのSystem z(R)などのメインフレームでは、チャネル・アダプタおよびオープン・システム・アダプタが、オペレーティング・システムと周辺デバイスとの間に通信を提供するメインフレームのI/Oユニットである。
さらに、他のタイプのコンピューティング環境も、本発明の1つまたは複数の態様から恩恵を受けることができる。例として、環境は、エミュレータ(たとえばソフトウェアまたは他のエミュレーション・メカニズム)を含むことが可能であり、ここでは、特定のアーキテクチャ(たとえば命令実行、アドレス変換などのアーキテクチャ機能、およびアーキテクチャ・レジスタを含む)またはそのサブセットが(たとえば、プロセッサおよびメモリを有するネイティブ(native)・コンピュータ・システム上で)エミュレートされる。こうした環境では、たとえ、エミュレータを実行するコンピュータがエミュレートされる機能以外の異なるアーキテクチャを有する可能性がある場合であっても、エミュレータの1つまたは複数のエミュレーション機能は、本発明の1つまたは複数の態様を実装することが可能である。一例として、エミュレーション・モードでは、エミュレートされている特定の命令または動作が復号され、個別の命令または動作を実装するために適切なエミュレーション機能が構築される。
エミュレーション環境では、ホスト・コンピュータは、たとえば命令およびデータを格納するためのメモリと、メモリから命令をフェッチするため、およびオプションでフェッチされた命令に対してローカル・バッファリングを提供するための、命令フェッチ・ユニットと、フェッチされた命令を受け取るため、およびフェッチされた命令のタイプを決定するための、命令復号ユニットと、命令を実行するための命令実行ユニットと、を含む。実行は、データをメモリからレジスタにロードすること、データをレジスタからメモリに再度格納すること、または、復号ユニットによって決定されるように、いくつかのタイプの算術または論理演算を実行することを、含むことができる。一例では、各ユニットはソフトウェア内に実装される。たとえば、ユニットによって実行されている動作は、1つまたは複数のサブルーチンとしてエミュレータ・ソフトウェア内に実装される。
より具体的には、現在では通常「C」プログラマであるプログラマによって、しばしばコンパイラ・アプリケーションを用いて、メインフレーム内でアーキテクチャ機械命令が使用される。ストレージ・メディアに格納されたこれらの命令は、z/Architecture(R) IBM(R)では、あるいは他のアーキテクチャを実行する機械では、ネイティブに実行することができる。それらは、既存の、および今後のIBM(R)メインフレーム・サーバ内で、およびIBM(R)の他の機械(たとえばPower SystemサーバおよびSystem x(R)サーバ)で、エミュレートすることができる。それらは、IBM(R)、Intel(R)、AMD(TM)、その他によって製造されるハードウェアを使用して、多様な機械上でLinuxを実行している機械内で実行可能である。z/Architecture(R)の下でのそのハードウェア上での実行に加えて、Linux、ならびに、TurboHercules(www.turbohercules.com/)、Hercules(www.hercules−390.org/)、またはFSI(Fundamental Software,Inc)(www.funsoft.com/)によるエミュレーションを使用する、一般に実行がエミュレーション・モードである機械が使用可能である。エミュレーション・モードでは、エミュレートされたプロセッサのアーキテクチャをエミュレートするために、エミュレーション・ソフトウェアがネイティブ・プロセッサによって実行される。
ネイティブ・プロセッサは、通常、エミュレートされたプロセッサのエミュレーションを実行するための、ファームウェアまたはネイティブ・オペレーティング・システムのいずれかを含む、エミュレーション・ソフトウェアを実行する。エミュレーション・ソフトウェアは、エミュレートされたプロセッサ・アーキテクチャのフェッチおよび実行命令に対する責務を負う。エミュレーション・ソフトウェアは、一度に1つまたは複数のエミュレートされた機械命令をフェッチし、ネイティブ・プロセッサによる実行のために、この1つまたは複数のエミュレートされた機械命令を対応するネイティブ機械命令のグループに変換することができる。これらの変換された命令は、高速変換が達成可能なようにキャッシュすることができる。それにもかかわらず、エミュレーション・ソフトウェアは、エミュレートされたプロセッサ用に作成されたオペレーティング・システムおよびアプリケーションが正しく動作するのを保証するように、エミュレートされたプロセッサ・アーキテクチャのアーキテクチャ規則を維持するものである。さらに、エミュレーション・ソフトウェアは、エミュレートされたプロセッサ上で実行するように設計されたオペレーティング・システムまたはアプリケーション・プログラムが、エミュレーション・ソフトウェアを有するネイティブ・プロセッサ上で実行可能なように、制御レジスタ、汎用レジスタ、浮動小数点レジスタ、たとえばセグメント・テーブルおよびページ・テーブルを含む動的アドレス変換機能、割り込みメカニズム、コンテキスト切り換えメカニズム、時刻(TOD)時計、および、I/Oサブシステムへのアーキテクチャ・インターフェースを含むが、これらに限定されない、エミュレートされたプロセッサ・アーキテクチャによって識別されたリソースを提供するものである。
エミュレートされている特定の命令が復号され、個別の命令の機能を実行するためにサブルーチンが呼び出される。エミュレートされたプロセッサの機能をエミュレートするエミュレーション・ソフトウェア機能は、好ましい実施形態の説明を理解した当業者であればわかるように、たとえば、「C」サブルーチンまたはドライバ内に、あるいは、特定のハードウェアに対するドライバを提供する何らかの他の方法内に、実装される。Beausoleil等による「Multiprocessor for Hardware Emulation」という名称の米国特許証第5551013号、および、Scalzi等による「Preprocessing of Stored Target Routines for Emulating Incompatible Instructions on a Target Processor」という名称の米国特許証第6009261号、および、Davidian等による「Decoding Guest Instruction to Directly Access Emulation Routines that Emulate the Guest Instructions」という名称の米国特許証第5574873号、および、Grorishek等による「Symmetrical Multiprocessing Bus and Chipset Used for Coprocessor Support Allowing Non−Native Code to Run in a System」という名称の米国特許証第6308255号、および、Lethin等による「Dynamic Optimizing Object Code Translator for Architecture Emulation and Dynamic Optimizing Object Code Translation Method」という名称の米国特許証第6463582号、および、Eric Trautによる「Method for Emulating Guest Instructions on a Host Computer Through Dynamic Recompilation of Host Instructions」という名称の米国特許証第5790825号、および多くのその他を含むが、それらに限定されない、様々なソフトウェアおよびハードウェアのエミュレーション特許は、当業者が使用可能なターゲット機械に対して、異なる機械のために構成された命令フォーマットのエミュレーションを達成する、様々な知られた方法を示している。
図25では、ホスト・アーキテクチャのホスト・コンピュータ・システム5000’をエミュレートする、エミュレートされたホスト・コンピュータ・システム5092の例が提供されている。エミュレートされたホスト・コンピュータ・システム5092では、ホスト・プロセッサ(CPU)5091はエミュレートされたホスト・プロセッサ(または仮想ホスト・プロセッサ)であり、ホスト・コンピュータ5000’のプロセッサ5091のそれとは異なるネイティブ命令セット・アーキテクチャを有するエミュレーション・プロセッサ5093を備える。エミュレートされたホスト・コンピュータ・システム5092は、エミュレーション・プロセッサ5093がアクセス可能なメモリ5094を有する。この実施形態例では、メモリ5094は、ホスト・コンピュータ・メモリ5096部分とエミュレーション・ルーチン5097部分とに区分される。ホスト・コンピュータ・メモリ5096は、ホスト・コンピュータ・アーキテクチャに従って、エミュレートされたホスト・コンピュータ5092のプログラムによって使用可能である。エミュレーション・プロセッサ5093は、エミュレートされたプロセッサ5091以外のアーキテクチャのアーキテクチャ命令セットのネイティブ命令を実行し、ネイティブ命令はエミュレーション・ルーチン・メモリ5097から取得され、アクセスされたホスト命令の機能をエミュレートするためのネイティブ命令実行ルーチンを決定するために、アクセスされたホスト命令を復号することが可能な、シーケンスおよびアクセス/復号ルーチンで取得された1つまたは複数の命令を採用することによって、ホスト・コンピュータ・メモリ5096内のプログラムから実行のためにホスト命令にアクセスすることが可能である。ホスト・コンピュータ・システム5000’アーキテクチャ用に定義された他の機構は、たとえば、汎用レジスタ、制御レジスタ、ダイナミック・アドレス変換、ならびにI/Oサブシステム・サポートおよびプロセッサ・キャッシュなどの機構を含む、アーキテクチャ機構ルーチンによってエミュレート可能である。エミュレーション・ルーチンは、エミュレーション・ルーチンの性能を向上させるために、エミュレーション・プロセッサ5093内で使用可能な(汎用レジスタおよび仮想アドレスの動的変換などの)機能を利用することも可能である。ホスト・コンピュータ5000’の機能をエミュレートする際に、プロセッサ5093を支援するために特別なハードウェアおよびオフロード・エンジンを提供することも可能である。
本明細書で使用される用語は、特定の実施形態を説明するためのみのものであり、本発明を限定することは意図されていない。本明細書で使用される場合、単数形「a」、「an」、および「the」は、コンテキストが特に明確に示していない限り、複数形も含むことが意図されている。「備える(comprises)」または「備えている(comprising)」あるいはその両方の用語は、本明細書で使用される場合、示された機能、整数、ステップ、動作、要素、または構成要素、あるいはそれらすべての存在を指定するが、1つまたは複数の他の機能、整数、ステップ、動作、要素、構成要素、またはそれらのグループ、あるいはそれらすべての存在または追加を排除するものではないことを、さらに理解されよう。
以下の特許請求の範囲内のすべての手段またはステップならびに機能要素の、対応する構造、材料、動作、および等価物は、もしもあれば、具体的に請求された他の請求要素と組み合わせてこの機能を実行するための任意の構造、材料、または動作を含むことが意図される。本発明の説明は、例示および説明の目的で提示されたものであるが、開示された形の本発明を網羅するかまたはこれに限定されることは意図されていない。当業者であれば、本発明の範囲を逸脱することのない多くの修正および変形が明らかとなろう。実施形態は、本発明の原理および実際の適用例を最も適切に説明するために、ならびに、企図された特定の用途に好適な様々な修正を伴う様々な実施形態について、他の当業者が本発明を理解できるように、選択および説明されたものである。

Claims (21)

  1. コンピューティング環境においてアドレスを変換するための方法であって、
    変換されることになるアドレスをアダプタから取得することであって、前記アドレスは複数のビットを含み、前記複数のビットはビットの第1の部分およびビットの第2の部分を含む、取得すること、
    許可されたアドレスの領域を示すアドレス領域値を受信すること、
    少なくとも前記ビットの第1の部分および前記受信したアドレス領域を使用して前記アドレスを妥当性検査すること、および、
    前記アドレスを、前記コンピューティング環境のメモリにアクセスする際に使用可能なメモリ・アドレスに変換することであって、前記変換することが、前記ビットの第1の部分を無視し、前記変換を実行するためのアドレス変換テーブルの1つまたは複数のレベルからアドレス情報を取得するために前記ビットの第2の部分を使用する、変換すること、
    を含む、方法。
  2. 前記ビットの第1の部分は前記アドレスの高位ビットを備え、前記ビットの第2の部分は前記アドレスの低位ビットを備え、前記低位ビットが、前記メモリ・アドレスを含む割り当てられたアドレス・スペースのサイズに基づいて決定される、請求項1に記載の方法。
  3. アドレス変換テーブルのレベルの数は、前記メモリ・アドレスを含む割り当てられたアドレス・スペースのサイズ、前記変換で使用されることになる1つまたは複数のアドレス変換テーブルのサイズ、および、前記メモリ・アドレスによってアクセスされるメモリの単位のサイズの少なくとも1つに基づくものである、請求項1に記載の方法。
  4. 前記変換することが、前記アドレスの変換に使用されることになるアドレス変換テーブルを選択することを含み、前記選択することは、前記変換で使用されるデバイス・テーブル・エントリ内でのポインタを使用する、請求項1に記載の方法。
  5. 前記方法が、前記デバイス・テーブル・エントリの位置を特定することをさらに含み、前記位置を特定することは、前記変換されることになるアドレスまたは前記アドレスの一部を含む要求を発行する前記アダプタの要求側識別子のうちの少なくとも1つを使用する、請求項4に記載の方法。
  6. 前記方法が、前記選択されたアドレス変換テーブルのフォーマットを決定することをさらに含み、前記決定することは、前記デバイス・テーブル・エントリのフォーマット・フィールドを使用する、請求項4に記載の方法。
  7. 前記アドレスを妥当性検査するために、前記アドレス領域が、前記デバイス・テーブル・エントリの基本フィールドおよび限界フィールドのうちの少なくとも1つによって画定される、請求項4に記載の方法。
  8. 前記アドレスを前記妥当性検査することが、
    前記ビットの第1の部分がアドレス領域の対応するビットの領域内にある旨の決定に応答して実行を許可することであって、前記アドレス領域の前記対応するビットがすべて0ではない、許可すること、および
    前記ビットの第1の部分がアドレス領域の対応するビットの領域内にない旨の決定に応答して実行を許可しないことであって、前記アドレス領域の前記対応するビットがすべて0ではない、許可しないこと、
    を含む、請求項7に記載の方法。
  9. 前記アダプタがPeripheral Component Interconnect機能を備える、請求項1に記載の方法。
  10. コンピューティング環境においてアドレスを変換するためのコンピュータ・システムであって、
    メモリと、
    前記メモリと通信するプロセッサと、
    変換されることになるアドレスをアダプタから取得するためのアドレス取得器であって、前記アドレスは複数のビットを含み、前記複数のビットはビットの第1の部分およびビットの第2の部分を含む、アドレス取得器と、
    許可されたアドレスの領域を示すアドレス領域値を受信するための受信器と、
    少なくとも前記ビットの第1の部分および前記受信したアドレス領域を使用して前記アドレスを妥当性検査するための妥当性検査器と、
    前記アドレスを、前記コンピューティング環境のメモリにアクセスする際に使用可能なメモリ・アドレスに変換するための変換器であって、前記変換器が、前記ビットの第1の部分を無視し、前記変換を実行するためのアドレス変換テーブルの1つまたは複数のレベルからアドレス情報を取得するために前記ビットの第2の部分を使用する、変換器と、
    を備える、コンピュータ・システム。
  11. コンピュータ・システム内にロードされ、そこで実行されると、前記コンピュータ・システムに、請求項1から9のいずれか一項に記載の方法のすべてのステップを実行させるために、コンピュータ読み取り可能メディア上に格納されたコンピュータ・プログラム・コードを備える、コンピュータ・プログラム。
  12. コンピューティング環境においてアドレスを変換するためのコンピュータ・システムであって、
    メモリと、
    前記メモリと通信するプロセッサと、を備え、前記コンピュータ・システムは、
    変換されることになるアドレスをアダプタから取得することであって、前記アドレスは複数のビットを含み、前記複数のビットはビットの第1の部分およびビットの第2の部分を含む、取得すること、
    許可されたアドレスの領域を示すアドレス領域値を受信すること、
    少なくとも前記ビットの第1の部分および前記受信したアドレス領域を使用して前記アドレスを妥当性検査すること、および、
    前記アドレスを、前記コンピューティング環境のメモリにアクセスする際に使用可能なメモリ・アドレスに変換することであって、前記変換することが、前記ビットの第1の部分を無視し、前記変換を実行するためのアドレス変換テーブルの1つまたは複数のレベルからアドレス情報を取得するために前記ビットの第2の部分を使用する、変換すること、
    を含む方法を実行するように構成された、コンピュータ・システム。
  13. 前記ビットの第1の部分は前記アドレスの高位ビットを備え、前記ビットの第2の部分は前記アドレスの低位ビットを備え、前記低位ビットが、前記メモリ・アドレスを含む割り当てられたアドレス・スペースのサイズに基づいて決定される、請求項12に記載のコンピュータ・システム。
  14. アドレス変換テーブルのレベルの数は、前記メモリ・アドレスを含む割り当てられたアドレス・スペースのサイズ、前記変換で使用されることになる1つまたは複数のアドレス変換テーブルのサイズ、および、前記メモリ・アドレスによってアクセスされるメモリの単位のサイズの少なくとも1つに基づくものである、請求項12に記載のコンピュータ・システム。
  15. 前記変換することが、前記アドレスの変換に使用されることになるアドレス変換テーブルを選択することを含み、前記選択することは、前記変換で使用されるデバイス・テーブル・エントリ内のポインタを使用する、請求項12に記載のコンピュータ・システム。
  16. 前記方法が、前記デバイス・テーブル・エントリの位置を特定することをさらに含み、前記位置を特定することは、前記変換されることになるアドレスまたは前記アドレスの一部を含む要求を発行する前記アダプタの要求側識別子のうちの少なくとも1つを使用する、請求項15に記載のコンピュータ・システム。
  17. 前記方法が、前記選択されたアドレス変換テーブルのフォーマットを決定することをさらに含み、前記決定することは、前記デバイス・テーブル・エントリのフォーマット・フィールドを使用する、請求項15に記載のコンピュータ・システム。
  18. 前記アドレスを妥当性検査するために、前記アドレス領域が、前記デバイス・テーブル・エントリの基本フィールドおよび限界フィールドのうちの少なくとも1つによって画定される、請求項15に記載のコンピュータ・システム。
  19. 前記アドレスを前記妥当性検査することが、
    前記ビットの第1の部分がアドレス領域の対応するビットの領域内にある旨の決定に応答して実行を許可することであって、前記アドレス領域の前記対応するビットがすべて0ではない、許可すること、および
    前記ビットの第1の部分がアドレス領域の対応するビットの領域内にない旨の決定に応答して実行を許可しないことであって、前記アドレス領域の前記対応するビットがすべて0ではない、許可しないこと、
    を含む、請求項18に記載のコンピュータ・システム。
  20. 前記アダプタがPeripheral Component Interconnect機能を備える、請求項12に記載のコンピュータ・システム。
  21. コンピューティング環境においてアドレスを変換するためのコンピュータ・プログラムであって、
    処理回路によって読み取り可能であり、請求項1から9のいずれか一項に記載の方法を実行するために、前記処理回路による実行に関する命令を格納する、コンピュータ読み取り可能ストレージ・メディアを備える、コンピュータ・プログラム。
JP2013515734A 2010-06-23 2010-11-08 入力/出力アドレスをメモリ・アドレスに変換するための方法、コンピュータ・システム、およびコンピュータ・プログラム Active JP5636097B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US12/821,170 2010-06-23
US12/821,170 US8635430B2 (en) 2010-06-23 2010-06-23 Translation of input/output addresses to memory addresses
PCT/EP2010/067043 WO2011160722A1 (en) 2010-06-23 2010-11-08 Translation of input/output addresses to memory addresses

Publications (2)

Publication Number Publication Date
JP2013537658A true JP2013537658A (ja) 2013-10-03
JP5636097B2 JP5636097B2 (ja) 2014-12-03

Family

ID=43805638

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2013515734A Active JP5636097B2 (ja) 2010-06-23 2010-11-08 入力/出力アドレスをメモリ・アドレスに変換するための方法、コンピュータ・システム、およびコンピュータ・プログラム

Country Status (20)

Country Link
US (3) US8635430B2 (ja)
EP (1) EP2430555B1 (ja)
JP (1) JP5636097B2 (ja)
KR (1) KR101455544B1 (ja)
CN (1) CN102906719B (ja)
AU (1) AU2010355813B2 (ja)
BR (1) BR112012033815B1 (ja)
CA (1) CA2800636C (ja)
DK (1) DK2430555T3 (ja)
ES (1) ES2428822T3 (ja)
HK (1) HK1180793A1 (ja)
HR (1) HRP20130820T1 (ja)
MX (1) MX2012014859A (ja)
PL (1) PL2430555T3 (ja)
PT (1) PT2430555E (ja)
RU (1) RU2547705C2 (ja)
SG (1) SG186098A1 (ja)
SI (1) SI2430555T1 (ja)
WO (1) WO2011160722A1 (ja)
ZA (1) ZA201209649B (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2013534667A (ja) * 2010-06-23 2013-09-05 インターナショナル・ビジネス・マシーンズ・コーポレーション アダプタに関する操作パラメータの選択的設定の制御

Families Citing this family (59)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8549182B2 (en) 2010-06-23 2013-10-01 International Business Machines Corporation Store/store block instructions for communicating with adapters
US8650337B2 (en) 2010-06-23 2014-02-11 International Business Machines Corporation Runtime determination of translation formats for adapter functions
US8510599B2 (en) * 2010-06-23 2013-08-13 International Business Machines Corporation Managing processing associated with hardware events
US8650335B2 (en) 2010-06-23 2014-02-11 International Business Machines Corporation Measurement facility for adapter functions
US9195623B2 (en) 2010-06-23 2015-11-24 International Business Machines Corporation Multiple address spaces per adapter with address translation
US8635430B2 (en) 2010-06-23 2014-01-21 International Business Machines Corporation Translation of input/output addresses to memory addresses
US8468284B2 (en) 2010-06-23 2013-06-18 International Business Machines Corporation Converting a message signaled interruption into an I/O adapter event notification to a guest operating system
US8621112B2 (en) 2010-06-23 2013-12-31 International Business Machines Corporation Discovery by operating system of information relating to adapter functions accessible to the operating system
US8566480B2 (en) 2010-06-23 2013-10-22 International Business Machines Corporation Load instruction for communicating with adapters
US8626970B2 (en) 2010-06-23 2014-01-07 International Business Machines Corporation Controlling access by a configuration to an adapter function
US8572635B2 (en) 2010-06-23 2013-10-29 International Business Machines Corporation Converting a message signaled interruption into an I/O adapter event notification
US9213661B2 (en) 2010-06-23 2015-12-15 International Business Machines Corporation Enable/disable adapters of a computing environment
US8639858B2 (en) 2010-06-23 2014-01-28 International Business Machines Corporation Resizing address spaces concurrent to accessing the address spaces
US9104327B2 (en) * 2011-05-17 2015-08-11 Sandisk Technologies Inc. Fast translation indicator to reduce secondary address table checks in a memory device
US20130132061A1 (en) * 2011-11-18 2013-05-23 Michael J. Rieschl Just-in-time static translation system for emulated computing environments
US9355146B2 (en) 2012-06-29 2016-05-31 International Business Machines Corporation Efficient partitioned joins in a database with column-major layout
US9355032B2 (en) 2012-10-08 2016-05-31 International Business Machines Corporation Supporting multiple types of guests by a hypervisor
US9600419B2 (en) 2012-10-08 2017-03-21 International Business Machines Corporation Selectable address translation mechanisms
US9280488B2 (en) 2012-10-08 2016-03-08 International Business Machines Corporation Asymmetric co-existent address translation structure formats
US9355040B2 (en) 2012-10-08 2016-05-31 International Business Machines Corporation Adjunct component to provide full virtualization using paravirtualized hypervisors
US9740624B2 (en) 2012-10-08 2017-08-22 International Business Machines Corporation Selectable address translation mechanisms within a partition
US9348757B2 (en) 2012-10-08 2016-05-24 International Business Machines Corporation System supporting multiple partitions with differing translation formats
US9647838B2 (en) * 2013-01-25 2017-05-09 Ralph John Hilla Restructuring the computer and its association with the internet
US8806098B1 (en) * 2013-03-15 2014-08-12 Avalanche Technology, Inc. Multi root shared peripheral component interconnect express (PCIe) end point
US9619387B2 (en) * 2014-02-21 2017-04-11 Arm Limited Invalidating stored address translations
US20150261701A1 (en) * 2014-03-14 2015-09-17 International Business Machines Corporation Device table in system memory
US9465768B2 (en) * 2014-03-14 2016-10-11 International Business Machines Corporation PCI function measurement block enhancements
US9715449B2 (en) * 2014-03-31 2017-07-25 International Business Machines Corporation Hierarchical translation structures providing separate translations for instruction fetches and data accesses
US9824021B2 (en) 2014-03-31 2017-11-21 International Business Machines Corporation Address translation structures to provide separate translations for instruction fetches and data accesses
US9734083B2 (en) 2014-03-31 2017-08-15 International Business Machines Corporation Separate memory address translations for instruction fetches and data accesses
US10248567B2 (en) 2014-06-16 2019-04-02 Hewlett-Packard Development Company, L.P. Cache coherency for direct memory access operations
US9952980B2 (en) 2015-05-18 2018-04-24 Red Hat Israel, Ltd. Deferring registration for DMA operations
US10055136B2 (en) 2015-07-29 2018-08-21 Red Hat Israel, Ltd. Maintaining guest input/output tables in swappable memory
CN105141429A (zh) * 2015-09-01 2015-12-09 武汉沃思财务外包服务有限公司 用户验证方法、装置和服务器
US10593421B2 (en) * 2015-12-01 2020-03-17 Cnex Labs, Inc. Method and apparatus for logically removing defective pages in non-volatile memory storage device
US10114743B2 (en) * 2016-04-06 2018-10-30 Sandisk Technologies Inc. Memory erase management
US10095620B2 (en) * 2016-06-29 2018-10-09 International Business Machines Corporation Computer system including synchronous input/output and hardware assisted purge of address translation cache entries of synchronous input/output transactions
JP2018041204A (ja) * 2016-09-06 2018-03-15 東芝メモリ株式会社 メモリ装置及び情報処理システム
US10120813B2 (en) * 2017-03-08 2018-11-06 Arm Limited Address translation
JP2018206084A (ja) * 2017-06-05 2018-12-27 株式会社東芝 データベース管理システムおよびデータベース管理方法
US10387325B2 (en) 2017-11-28 2019-08-20 International Business Machines Corporation Dynamic address translation for a virtual machine
KR102651408B1 (ko) * 2018-02-20 2024-03-26 삼성전자주식회사 스토리지 디바이스 및 스토리지 디바이스의 동작 방법
US10997066B2 (en) 2018-02-20 2021-05-04 Samsung Electronics Co., Ltd. Storage devices that support cached physical address verification and methods of operating same
WO2019177608A1 (en) * 2018-03-15 2019-09-19 Hewlett-Packard Development Company, L.P. Address verification for direct memory access requests
RU2714219C1 (ru) 2018-09-14 2020-02-13 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для планирования передачи операций ввода/вывода
RU2731321C2 (ru) 2018-09-14 2020-09-01 Общество С Ограниченной Ответственностью "Яндекс" Способ определения потенциальной неисправности запоминающего устройства
RU2718215C2 (ru) 2018-09-14 2020-03-31 Общество С Ограниченной Ответственностью "Яндекс" Система обработки данных и способ обнаружения затора в системе обработки данных
RU2721235C2 (ru) 2018-10-09 2020-05-18 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для маршрутизации и выполнения транзакций
RU2714602C1 (ru) 2018-10-09 2020-02-18 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для обработки данных
RU2711348C1 (ru) 2018-10-15 2020-01-16 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для обработки запросов в распределенной базе данных
CN112970037B (zh) * 2018-11-06 2024-02-02 创惟科技股份有限公司 用于实施神经网络应用的多芯片系统、适用于多芯片系统的数据处理方法、和非暂时性计算机可读介质
RU2714373C1 (ru) 2018-12-13 2020-02-14 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для планирования выполнения операций ввода/вывода
US11030144B2 (en) * 2018-12-14 2021-06-08 Texas Instruments Incorporated Peripheral component interconnect (PCI) backplane connectivity system on chip (SoC)
RU2749649C2 (ru) 2018-12-21 2021-06-16 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для планирования обработки операций ввода/вывода
RU2720951C1 (ru) 2018-12-29 2020-05-15 Общество С Ограниченной Ответственностью "Яндекс" Способ и распределенная компьютерная система для обработки данных
RU2746042C1 (ru) 2019-02-06 2021-04-06 Общество С Ограниченной Ответственностью "Яндекс" Способ и система для передачи сообщения
US11204752B1 (en) * 2019-06-11 2021-12-21 American Megatrends International, Llc Intelligent migration of firmware configuration settings
US11860792B2 (en) * 2021-05-04 2024-01-02 Red Hat, Inc. Memory access handling for peripheral component interconnect devices
CN117056157B (zh) * 2023-10-11 2024-01-23 沐曦集成电路(上海)有限公司 一种寄存器层次化验证方法、存储介质和电子设备

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6273347A (ja) * 1985-09-27 1987-04-04 Hitachi Ltd アドレス変換装置
JPH0250744A (ja) * 1988-08-12 1990-02-20 Nec Corp アドレス変換方式
JPH0619798A (ja) * 1992-02-26 1994-01-28 Microsoft Corp セレクタの値のロードを回避する方法とシステム
WO2009087133A1 (en) * 2008-01-11 2009-07-16 International Business Machines Corporation Dynamic address translation with fetch protection

Family Cites Families (244)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3976979A (en) 1974-01-02 1976-08-24 Honeywell Information Systems, Inc. Coupler for providing data transfer between host and remote data processing units
US4028668A (en) 1975-12-22 1977-06-07 Honeywell Information Systems, Inc. Apparatus for selectively addressing sections and locations in a device controller's memory
US4323963A (en) 1979-07-13 1982-04-06 Rca Corporation Hardware interpretive mode microprocessor
EP0090804A1 (en) 1981-10-13 1983-10-12 International Business Machines Corporation Method and apparatus for measurements of channel operation
JPS5981724A (ja) 1982-11-02 1984-05-11 Hitachi Electronics Eng Co Ltd Dma制御装置アドレス空間の拡張方法
JPS6279557A (ja) 1985-10-03 1987-04-11 Fujitsu Ltd 直接メモリアクセス方式
US5053952A (en) 1987-06-05 1991-10-01 Wisc Technologies, Inc. Stack-memory-based writable instruction set computer having a single data bus
JPH0282343A (ja) 1988-09-20 1990-03-22 Hitachi Ltd マルチプロセッサシステムの割込処理方式
US5282274A (en) 1990-05-24 1994-01-25 International Business Machines Corporation Translation of multiple virtual pages upon a TLB miss
US5170472A (en) 1991-03-28 1992-12-08 International Business Machines Corp. Dynamically changing a system i/o configuration definition
JPH0553973A (ja) 1991-08-28 1993-03-05 Matsushita Electric Ind Co Ltd 情報処理システム
US5465355A (en) 1991-09-04 1995-11-07 International Business Machines Corporation Establishing and restoring paths in a data processing I/O system
JP2664827B2 (ja) 1991-10-07 1997-10-22 日本電信電話株式会社 実時間情報転送制御方法
JPH05165715A (ja) 1991-12-12 1993-07-02 Nec Corp 情報処理装置
JPH0821015B2 (ja) 1992-01-20 1996-03-04 インターナショナル・ビジネス・マシーンズ・コーポレイション コンピュータならびにそのシステム再構成化装置および方法
US5617554A (en) 1992-02-10 1997-04-01 Intel Corporation Physical address size selection and page size selection in an address translator
US5600805A (en) 1992-06-15 1997-02-04 International Business Machines Corporation Pass-through for I/O channel subsystem call instructions for accessing shared resources in a computer system having a plurality of operating systems
US5265240A (en) 1992-07-24 1993-11-23 International Business Machines Corporation Channel measurement method and means
US5465332A (en) 1992-09-21 1995-11-07 International Business Machines Corporation Selectable 8/16 bit DMA channels for "ISA" bus
JP2500101B2 (ja) 1992-12-18 1996-05-29 インターナショナル・ビジネス・マシーンズ・コーポレイション 共用変数の値を更新する方法
WO1994027215A1 (en) 1993-05-07 1994-11-24 Apple Computer, Inc. Method for decoding guest instructions for a host computer
US5535352A (en) 1994-03-24 1996-07-09 Hewlett-Packard Company Access hints for input/output address translation mechanisms
US5551013A (en) 1994-06-03 1996-08-27 International Business Machines Corporation Multiprocessor for hardware emulation
KR100306636B1 (ko) 1994-06-28 2001-11-30 피터 엔. 데트킨 Pci-isa인터럽트프로토콜컨버터및선택메카니즘
US5748950A (en) 1994-09-20 1998-05-05 Intel Corporation Method and apparatus for providing an optimized compare-and-branch instruction
US5802590A (en) 1994-12-13 1998-09-01 Microsoft Corporation Method and system for providing secure access to computer resources
US5901312A (en) 1994-12-13 1999-05-04 Microsoft Corporation Providing application programs with unmediated access to a contested hardware resource
WO1996023260A1 (de) * 1995-01-27 1996-08-01 Gmd - Forschungszentrum Informationstechnik Gmbh Verfahren zum betreiben einer adressumsetzvorrichtung
JPH08263424A (ja) 1995-03-20 1996-10-11 Fujitsu Ltd コンピュータ装置
EP0747872B1 (en) 1995-06-07 1999-03-03 International Business Machines Corporation Video processor with addressing mode control
US5790825A (en) 1995-11-08 1998-08-04 Apple Computer, Inc. Method for emulating guest instructions on a host computer through dynamic recompilation of host instructions
US5960213A (en) 1995-12-18 1999-09-28 3D Labs Inc. Ltd Dynamically reconfigurable multi-function PCI adapter device
US5974440A (en) 1996-03-25 1999-10-26 Texas Instruments Incorporated Microprocessor with circuits, systems, and methods for interrupt handling during virtual task operation
US5819053A (en) 1996-06-05 1998-10-06 Compaq Computer Corporation Computer system bus performance monitoring
US5761448A (en) 1996-08-30 1998-06-02 Ncr Corporation Physical-to-logical bus mapping scheme for computer systems having multiple PCI bus configuration
US5838960A (en) 1996-09-26 1998-11-17 Bay Networks, Inc. Apparatus for performing an atomic add instructions
US5826084A (en) 1997-03-25 1998-10-20 Texas Instruments Incorporated Microprocessor with circuits, systems, and methods for selectively bypassing external interrupts past the monitor program during virtual program operation
US6507898B1 (en) 1997-04-30 2003-01-14 Canon Kabushiki Kaisha Reconfigurable data cache controller
KR100263672B1 (ko) 1997-05-08 2000-09-01 김영환 가변적인 페이지 크기를 지원하는 어드레스 변환장치
US5914730A (en) 1997-09-09 1999-06-22 Compaq Computer Corp. System and method for invalidating and updating individual GART table entries for accelerated graphics port transaction requests
US6067595A (en) 1997-09-23 2000-05-23 Icore Technologies, Inc. Method and apparatus for enabling high-performance intelligent I/O subsystems using multi-port memories
US5864703A (en) 1997-10-09 1999-01-26 Mips Technologies, Inc. Method for providing extended precision in SIMD vector arithmetic operations
US6078970A (en) 1997-10-15 2000-06-20 International Business Machines Corporation System for determining adapter interrupt status where interrupt is sent to host after operating status stored in register is shadowed to host memory
US6009261A (en) 1997-12-16 1999-12-28 International Business Machines Corporation Preprocessing of stored target routines for emulating incompatible instructions on a target processor
US6023736A (en) 1997-12-19 2000-02-08 International Business Machines Corporation System for dynamically configuring I/O device adapters where a function configuration register contains ready/not ready flags corresponding to each I/O device adapter
US6021458A (en) 1998-01-21 2000-02-01 Intel Corporation Method and apparatus for handling multiple level-triggered and edge-triggered interrupts
US6223299B1 (en) 1998-05-04 2001-04-24 International Business Machines Corporation Enhanced error handling for I/O load/store operations to a PCI device via bad parity or zero byte enables
US6308255B1 (en) 1998-05-26 2001-10-23 Advanced Micro Devices, Inc. Symmetrical multiprocessing bus and chipset used for coprocessor support allowing non-native code to run in a system
US6615305B1 (en) 1998-08-27 2003-09-02 Intel Corporation Interrupt pacing in data transfer unit
US6463582B1 (en) 1998-10-21 2002-10-08 Fujitsu Limited Dynamic optimizing object code translator for architecture emulation and dynamic optimizing object code translation method
US6408347B1 (en) 1998-12-10 2002-06-18 Cisco Technology, Inc. Integrated multi-function adapters using standard interfaces through single a access point
US6519645B2 (en) 1999-02-19 2003-02-11 International Business Machine Corporation Method and apparatus for providing configuration information using a queued direct input-output device
US6349380B1 (en) 1999-03-12 2002-02-19 Intel Corporation Linear address extension and mapping to physical memory using 4 and 8 byte page table entries in a 32-bit microprocessor
US6557035B1 (en) 1999-03-30 2003-04-29 International Business Machines Corporation Rules-based method of and system for optimizing server hardware capacity and performance
US6330656B1 (en) 1999-03-31 2001-12-11 International Business Machines Corporation PCI slot control apparatus with dynamic configuration for partitioned systems
JP2000293476A (ja) 1999-04-09 2000-10-20 Nec Corp Pciデバイスへのリソース割当方式及びその方法
US6578191B1 (en) 1999-05-17 2003-06-10 International Business Machines Corporation Method and apparatus for dynamic generation of adapters
US6330647B1 (en) 1999-08-31 2001-12-11 Micron Technology, Inc. Memory bandwidth allocation based on access count priority scheme
US6772097B1 (en) 1999-09-30 2004-08-03 Intel Corporation Retrieving I/O processor performance monitor data
US6493741B1 (en) 1999-10-01 2002-12-10 Compaq Information Technologies Group, L.P. Method and apparatus to quiesce a portion of a simultaneous multithreaded central processing unit
US6970992B2 (en) 1999-10-04 2005-11-29 Intel Corporation Apparatus to map virtual pages to disparate-sized, non-contiguous real pages and methods relating thereto
US6651126B1 (en) 1999-10-29 2003-11-18 Texas Instruments Incorporated Snapshot arbiter mechanism
US7509391B1 (en) 1999-11-23 2009-03-24 Texas Instruments Incorporated Unified memory management system for multi processor heterogeneous architecture
US6529978B1 (en) 2000-02-23 2003-03-04 International Business Machines Corporation Computer input/output (I/O) interface with dynamic I/O adaptor processor bindings
US6963940B1 (en) 2000-03-30 2005-11-08 International Business Machines Corporation Measuring utilization of individual components of channels
US6581130B1 (en) 2000-04-04 2003-06-17 Hewlett Packard Development Company, L.P. Dynamic remapping of address registers for address translation between multiple busses
US6629175B1 (en) 2000-04-14 2003-09-30 International Business Machines Corporation Efficient adapter context switching
US6772264B1 (en) 2000-05-22 2004-08-03 International Business Machines Corporation Enabling a docking station for ISA adapters
US6715011B1 (en) 2000-05-31 2004-03-30 International Business Machines Corporation PCI/PCI-X bus bridge with performance monitor
US6654818B1 (en) 2000-06-22 2003-11-25 International Business Machines Corporation DMA access authorization for 64-bit I/O adapters on PCI bus
US6704831B1 (en) 2000-11-16 2004-03-09 Sun Microsystems, Inc. Method and apparatus for converting address information between PCI bus protocol and a message-passing queue-oriented bus protocol
US6611883B1 (en) 2000-11-16 2003-08-26 Sun Microsystems, Inc. Method and apparatus for implementing PCI DMA speculative prefetching in a message passing queue oriented bus system
US6658521B1 (en) 2000-12-22 2003-12-02 International Business Machines Corporation Method and apparatus for address translation on PCI bus over infiniband network
US6721839B1 (en) 2000-12-27 2004-04-13 International Business Machines Corporation Method of mapping multiple address spaces into single PCI bus
US6938138B2 (en) * 2001-01-11 2005-08-30 International Business Machines Corporation Method and apparatus for managing access to memory
TW499795B (en) 2001-03-19 2002-08-21 Realtek Semiconductor Corp PCI extended function interface and the PCI device using the same
US6792492B1 (en) 2001-04-11 2004-09-14 Novell, Inc. System and method of lowering overhead and latency needed to service operating system interrupts
US6820164B2 (en) 2001-04-17 2004-11-16 International Business Machines Corporation Peripheral component interconnect bus detection in logically partitioned computer system involving authorizing guest operating system to conduct configuration input-output operation with functions of pci devices
US20020161907A1 (en) 2001-04-25 2002-10-31 Avery Moon Adaptive multi-protocol communications system
US6968446B1 (en) 2001-08-09 2005-11-22 Advanced Micro Devices, Inc. Flags handling for system call instructions
US6842870B2 (en) 2001-09-20 2005-01-11 International Business Machines Corporation Method and apparatus for filtering error logs in a logically partitioned data processing system
US6801993B2 (en) 2001-09-28 2004-10-05 International Business Machines Corporation Table offset for shortening translation tables from their beginnings
US20040025166A1 (en) 2002-02-02 2004-02-05 International Business Machines Corporation Server computer and a method for accessing resources from virtual machines of a server computer via a fibre channel
US6901537B2 (en) 2002-02-27 2005-05-31 International Business Machines Corporation Method and apparatus for preventing the propagation of input/output errors in a logical partitioned data processing system
US6907510B2 (en) 2002-04-01 2005-06-14 Intel Corporation Mapping of interconnect configuration space
US7302692B2 (en) 2002-05-31 2007-11-27 International Business Machines Corporation Locally providing globally consistent information to communications layers
US20040049603A1 (en) 2002-09-05 2004-03-11 International Business Machines Corporation iSCSI driver to adapter interface protocol
US7299266B2 (en) * 2002-09-05 2007-11-20 International Business Machines Corporation Memory management offload for RDMA enabled network adapters
US7197585B2 (en) 2002-09-30 2007-03-27 International Business Machines Corporation Method and apparatus for managing the execution of a broadcast instruction on a guest processor
US7054972B2 (en) 2002-12-13 2006-05-30 Lsi Logic Corporation Apparatus and method for dynamically enabling and disabling interrupt coalescing in data processing system
KR100449807B1 (ko) 2002-12-20 2004-09-22 한국전자통신연구원 호스트 버스 인터페이스를 갖는 데이터 전송 프로토콜제어 시스템
US7065598B2 (en) 2002-12-20 2006-06-20 Intel Corporation Method, system, and article of manufacture for adjusting interrupt levels
US20040139305A1 (en) 2003-01-09 2004-07-15 International Business Machines Corporation Hardware-enabled instruction tracing
US20040139304A1 (en) 2003-01-09 2004-07-15 International Business Machines Corporation High speed virtual instruction execution mechanism
JP4256693B2 (ja) 2003-02-18 2009-04-22 株式会社日立製作所 計算機システム、i/oデバイス及びi/oデバイスの仮想共有方法
JP2004248985A (ja) 2003-02-21 2004-09-09 Air Water Inc 注射器およびそれに用いるパッキン
US7073002B2 (en) 2003-03-13 2006-07-04 International Business Machines Corporation Apparatus and method for controlling resource transfers using locks in a logically partitioned computer system
US7107382B2 (en) 2003-04-03 2006-09-12 Emulex Design & Manufacturing Corporation Virtual peripheral component interconnect multiple-function device
US7139940B2 (en) 2003-04-10 2006-11-21 International Business Machines Corporation Method and apparatus for reporting global errors on heterogeneous partitioned systems
US7010633B2 (en) 2003-04-10 2006-03-07 International Business Machines Corporation Apparatus, system and method for controlling access to facilities based on usage classes
US7281075B2 (en) 2003-04-24 2007-10-09 International Business Machines Corporation Virtualization of a global interrupt queue
US7139892B2 (en) * 2003-05-02 2006-11-21 Microsoft Corporation Implementation of memory access control using optimizations
US7130938B2 (en) 2003-05-12 2006-10-31 International Business Machines Corporation Method, system and program products for identifying communications adapters of a computing environment
US7130949B2 (en) 2003-05-12 2006-10-31 International Business Machines Corporation Managing input/output interruptions in non-dedicated interruption hardware environments
US7174550B2 (en) 2003-05-12 2007-02-06 International Business Machines Corporation Sharing communications adapters across a plurality of input/output subsystem images
US7290070B2 (en) 2003-05-12 2007-10-30 International Business Machines Corporation Multiple logical input/output subsystem facility
US7127599B2 (en) 2003-05-12 2006-10-24 International Business Machines Corporation Managing configurations of input/output system images of an input/output subsystem, wherein a configuration is modified without restarting the input/output subsystem to effect a modification
US6996638B2 (en) 2003-05-12 2006-02-07 International Business Machines Corporation Method, system and program products for enhancing input/output processing for operating system images of a computing environment
US7177961B2 (en) 2003-05-12 2007-02-13 International Business Machines Corporation Managing access, by operating system images of a computing environment, of input/output resources of the computing environment
US7000036B2 (en) 2003-05-12 2006-02-14 International Business Machines Corporation Extended input/output measurement facilities
US7134052B2 (en) 2003-05-15 2006-11-07 International Business Machines Corporation Autonomic recovery from hardware errors in an input/output fabric
US6931460B2 (en) 2003-05-19 2005-08-16 Emulex Design & Manufacturing Corporation Dynamically self-adjusting polling mechanism
US7420931B2 (en) 2003-06-05 2008-09-02 Nvidia Corporation Using TCP/IP offload to accelerate packet filtering
US8417852B2 (en) 2003-06-05 2013-04-09 Nvidia Corporation Uploading TCP frame data to user buffers and buffers in system memory
EP1489491A1 (en) 2003-06-19 2004-12-22 Texas Instruments Incorporated Dynamically changing the semantic of an instruction
US7013358B2 (en) 2003-08-09 2006-03-14 Texas Instruments Incorporated System for signaling serialized interrupts using message signaled interrupts
US7979548B2 (en) 2003-09-30 2011-07-12 International Business Machines Corporation Hardware enforcement of logical partitioning of a channel adapter's resources in a system area network
JP2005122640A (ja) 2003-10-20 2005-05-12 Hitachi Ltd サーバシステム及びi/oスロット共有方法。
US7552436B2 (en) 2003-11-25 2009-06-23 International Business Machines Memory mapped input/output virtualization
US7146482B2 (en) 2003-11-25 2006-12-05 International Business Machines Corporation Memory mapped input/output emulation
US7277968B2 (en) 2004-01-23 2007-10-02 International Business Machines Corporation Managing sets of input/output communications subadapters of an input/output subsystem
US7107384B1 (en) 2004-03-01 2006-09-12 Pericom Semiconductor Corp. Dynamic PCI-bus pre-fetch with separate counters for commands of commands of different data-transfer lengths
JP2005309553A (ja) 2004-04-19 2005-11-04 Hitachi Ltd 計算機
US7530071B2 (en) 2004-04-22 2009-05-05 International Business Machines Corporation Facilitating access to input/output resources via an I/O partition shared by multiple consumer partitions
US7209994B1 (en) 2004-05-11 2007-04-24 Advanced Micro Devices, Inc. Processor that maintains virtual interrupt state and injects virtual interrupts into virtual machine guests
US7941799B2 (en) 2004-05-27 2011-05-10 International Business Machines Corporation Interpreting I/O operation requests from pageable guests without host intervention
US20050289271A1 (en) 2004-06-29 2005-12-29 Martinez Alberto J Circuitry to selectively produce MSI signals
US20060005083A1 (en) 2004-06-30 2006-01-05 International Business Machines Corporation Performance count tracing
US7418572B2 (en) 2004-08-18 2008-08-26 International Business Machines Corporation Pretranslating input/output buffers in environments with multiple page sizes
JP4788124B2 (ja) 2004-09-16 2011-10-05 株式会社日立製作所 データ処理システム
TWI252397B (en) 2004-09-17 2006-04-01 Ind Tech Res Inst Method and apparatus of built-in self-diagnosis and repair in a memory with syndrome identification
US7334107B2 (en) 2004-09-30 2008-02-19 Intel Corporation Caching support for direct memory access address translation
US7340582B2 (en) 2004-09-30 2008-03-04 Intel Corporation Fault processing for direct memory access address translation
US7444493B2 (en) 2004-09-30 2008-10-28 Intel Corporation Address translation for input/output devices using hierarchical translation tables
US7373446B2 (en) 2004-11-05 2008-05-13 Microsoft Corporation Method and system for dynamically patching an operating system's interrupt mechanism
US7296120B2 (en) 2004-11-18 2007-11-13 International Business Machines Corporation Mechanism that provides efficient multi-word load atomicity
US7188346B2 (en) 2004-11-29 2007-03-06 International Business Machines Corporation Method, system and program product for correlating data between operating environments
US7284112B2 (en) 2005-01-14 2007-10-16 International Business Machines Corporation Multiple page size address translation incorporating page size prediction
US7886086B2 (en) 2005-02-03 2011-02-08 International Business Machines Corporation Method and apparatus for restricting input/output device peer-to-peer operations in a data processing system to improve reliability, availability, and serviceability
US7562366B2 (en) 2005-02-03 2009-07-14 Solarflare Communications, Inc. Transmit completion event batching
US20060195617A1 (en) 2005-02-25 2006-08-31 International Business Machines Corporation Method and system for native virtualization on a partially trusted adapter using adapter bus, device and function number for identification
US7493425B2 (en) 2005-02-25 2009-02-17 International Business Machines Corporation Method, system and program product for differentiating between virtual hosts on bus transactions and associating allowable memory access for an input/output adapter that supports virtualization
US7260664B2 (en) 2005-02-25 2007-08-21 International Business Machines Corporation Interrupt mechanism on an IO adapter that supports virtualization
US7464191B2 (en) 2005-02-25 2008-12-09 International Business Machines Corporation System and method for host initialization for an adapter that supports virtualization
US7475166B2 (en) 2005-02-28 2009-01-06 International Business Machines Corporation Method and system for fully trusted adapter validation of addresses referenced in a virtual host transfer request
US7567567B2 (en) 2005-04-05 2009-07-28 Sun Microsystems, Inc. Network system including packet classification for partitioned resources
US7200704B2 (en) 2005-04-07 2007-04-03 International Business Machines Corporation Virtualization of an I/O adapter port using enablement and activation functions
US7260663B2 (en) 2005-04-07 2007-08-21 International Business Machines Corporation System and method for presenting interrupts
US7478178B2 (en) 2005-04-22 2009-01-13 Sun Microsystems, Inc. Virtualization for device sharing
US7502872B2 (en) * 2005-05-23 2009-03-10 International Bsuiness Machines Corporation Method for out of user space block mode I/O directly between an application instance and an I/O adapter
US7225287B2 (en) 2005-06-01 2007-05-29 Microsoft Corporation Scalable DMA remapping on a computer bus
US20060288130A1 (en) 2005-06-21 2006-12-21 Rajesh Madukkarumukumana Address window support for direct memory access translation
US7631097B2 (en) 2005-07-21 2009-12-08 National Instruments Corporation Method and apparatus for optimizing the responsiveness and throughput of a system performing packetized data transfers using a transfer count mark
US8028154B2 (en) 2005-07-29 2011-09-27 Broadcom Corporation Method and system for reducing instruction storage space for a processor integrated in a network adapter chip
US7657662B2 (en) 2005-08-31 2010-02-02 International Business Machines Corporation Processing user space operations directly between an application instance and an I/O adapter
US7546487B2 (en) 2005-09-15 2009-06-09 Intel Corporation OS and firmware coordinated error handling using transparent firmware intercept and firmware services
US20070073955A1 (en) 2005-09-29 2007-03-29 Joseph Murray Multi-function PCI device
JP5100996B2 (ja) 2005-10-13 2012-12-19 ヤマシンフィルタ株式会社 濾過装置
US7882489B2 (en) 2005-11-22 2011-02-01 International Business Machines Corporation Integrated code generation for adapter-specific property template
US20070136554A1 (en) 2005-12-12 2007-06-14 Giora Biran Memory operations in a virtualized system
US7475183B2 (en) 2005-12-12 2009-01-06 Microsoft Corporation Large page optimizations in a virtual machine environment
US7398343B1 (en) 2006-01-03 2008-07-08 Emc Corporation Interrupt processing system
US7548999B2 (en) 2006-01-17 2009-06-16 Advanced Micro Devices, Inc. Chained hybrid input/output memory management unit
US7673116B2 (en) 2006-01-17 2010-03-02 Advanced Micro Devices, Inc. Input/output memory management unit that implements memory attributes based on translation data
US7653803B2 (en) 2006-01-17 2010-01-26 Globalfoundries Inc. Address translation for input/output (I/O) devices and interrupt remapping for I/O devices in an I/O memory management unit (IOMMU)
US7849232B2 (en) 2006-02-17 2010-12-07 Intel-Ne, Inc. Method and apparatus for using a single multi-function adapter with different operating systems
US7739422B2 (en) 2006-03-21 2010-06-15 International Business Machines Corporation Method to improve system DMA mapping while substantially reducing memory fragmentation
US7412589B2 (en) 2006-03-31 2008-08-12 International Business Machines Corporation Method to detect a stalled instruction stream and serialize micro-operation execution
US8621120B2 (en) 2006-04-17 2013-12-31 International Business Machines Corporation Stalling of DMA operations in order to do memory migration using a migration in progress bit in the translation control entry mechanism
US7613847B2 (en) 2006-05-16 2009-11-03 Hewlett-Packard Development Company, L.P. Partially virtualizing an I/O device for use by virtual machines
US7954099B2 (en) 2006-05-17 2011-05-31 International Business Machines Corporation Demultiplexing grouped events into virtual event queues while in two levels of virtualization
JP4961833B2 (ja) 2006-05-19 2012-06-27 日本電気株式会社 クラスタシステム、負荷分散方法、最適化クライアントプログラム、及び調停サーバプログラム
TW200801952A (en) 2006-06-02 2008-01-01 Via Tech Inc Method for setting up a peripheral component interconnect express (PCIE)
US7571307B2 (en) 2006-07-26 2009-08-04 International Business Machines Corporation Capacity upgrade on-demand for I/O adapters
US7546398B2 (en) 2006-08-01 2009-06-09 International Business Machines Corporation System and method for distributing virtual input/output operations across multiple logical partitions
US7496707B2 (en) 2006-08-22 2009-02-24 International Business Machines Corporation Dynamically scalable queues for performance driven PCI express memory traffic
US8725914B2 (en) 2006-08-28 2014-05-13 International Business Machines Corporation Message signaled interrupt management for a computer input/output fabric incorporating platform independent interrupt manager
US7627723B1 (en) 2006-09-21 2009-12-01 Nvidia Corporation Atomic memory operators in a parallel processor
US20080126652A1 (en) 2006-09-27 2008-05-29 Intel Corporation Managing Interrupts in a Partitioned Platform
US7552298B2 (en) 2006-09-28 2009-06-23 Broadcom Corporation Method and system for deferred pinning of host memory for stateful network interfaces
US9135951B2 (en) 2006-10-10 2015-09-15 Qualcomm Incorporated System and method for dynamic audio buffer management
US20080091868A1 (en) 2006-10-17 2008-04-17 Shay Mizrachi Method and System for Delayed Completion Coalescing
US7587575B2 (en) 2006-10-17 2009-09-08 International Business Machines Corporation Communicating with a memory registration enabled adapter using cached address translations
US20080098197A1 (en) 2006-10-20 2008-04-24 International Business Machines Corporation Method and System For Address Translation With Memory Windows
US7849287B2 (en) 2006-11-13 2010-12-07 Advanced Micro Devices, Inc. Efficiently controlling special memory mapped system accesses
JP2008123298A (ja) 2006-11-13 2008-05-29 Canon Inc 情報処理方法及びシステム
US7624235B2 (en) 2006-11-30 2009-11-24 Apple Inc. Cache used both as cache and staging buffer
US7984454B2 (en) 2006-12-19 2011-07-19 International Business Machines Corporation Migration of single root stateless virtual functions
US7529860B2 (en) 2006-12-19 2009-05-05 International Business Machines Corporation System and method for configuring an endpoint based on specified valid combinations of functions
US7617340B2 (en) 2007-01-09 2009-11-10 International Business Machines Corporation I/O adapter LPAR isolation with assigned memory space
US20080168208A1 (en) 2007-01-09 2008-07-10 International Business Machines Corporation I/O Adapter LPAR Isolation In A Hypertransport Environment With Assigned Memory Space Indexing a TVT Via Unit IDs
JP5119686B2 (ja) 2007-03-06 2013-01-16 日本電気株式会社 情報処理装置および設定方法
EP2075696A3 (en) 2007-05-10 2010-01-27 Texas Instruments Incorporated Interrupt- related circuits, systems and processes
JP5018252B2 (ja) 2007-06-06 2012-09-05 株式会社日立製作所 デバイス割り当て変更方法
US7617345B2 (en) 2007-07-02 2009-11-10 International Business Machines Corporation Prioritization of interrupts in a storage controller based on interrupt control directives received from hosts
US20090024823A1 (en) 2007-07-20 2009-01-22 Wenjeng Ko Overlayed separate dma mapping of adapters
US8250254B2 (en) * 2007-07-31 2012-08-21 Intel Corporation Offloading input/output (I/O) virtualization operations to a processor
US8127296B2 (en) 2007-09-06 2012-02-28 Dell Products L.P. Virtual machine migration between processors having VM migration registers controlled by firmware to modify the reporting of common processor feature sets to support the migration
US8762999B2 (en) 2007-09-27 2014-06-24 Oracle America, Inc. Guest-initiated resource allocation request based on comparison of host hardware information and projected workload requirement
US8141094B2 (en) 2007-12-03 2012-03-20 International Business Machines Corporation Distribution of resources for I/O virtualized (IOV) adapters and management of the adapters through an IOV management partition via user selection of compatible virtual functions
US7689734B2 (en) 2007-12-18 2010-03-30 International Business Machines Corporation Method for toggling non-adjacent channel identifiers during DMA double buffering operations
US7913030B2 (en) 2007-12-28 2011-03-22 Sandisk Il Ltd. Storage device with transaction logging capability
US8151083B2 (en) 2008-01-11 2012-04-03 International Business Machines Corporation Dynamic address translation with frame management
US8037221B2 (en) 2008-01-16 2011-10-11 International Business Machines Corporation Dynamic allocation of DMA buffers in input/output adaptors
US7996628B2 (en) 2008-02-14 2011-08-09 International Business Machines Corporation Cross adapter shared address translation tables
US8332846B2 (en) 2008-02-28 2012-12-11 Sony Mobile Communications Ab Selective exposure to USB device functionality for a virtual machine by filtering descriptors
JP2009249108A (ja) 2008-04-04 2009-10-29 Mitsubishi Electric Building Techno Service Co Ltd エレベーター押ボタン一体型位置表示器
US20090276774A1 (en) 2008-05-01 2009-11-05 Junji Kinoshita Access control for virtual machines in an information system
US7743189B2 (en) 2008-05-05 2010-06-22 International Business Machines Corporation PCI function south-side data management
US8032680B2 (en) 2008-06-27 2011-10-04 Microsoft Corporation Lazy handling of end of interrupt messages in a virtualized environment
US8359408B2 (en) 2008-06-30 2013-01-22 Intel Corporation Enabling functional dependency in a multi-function device
CN101634975B (zh) 2009-08-20 2011-09-14 广东威创视讯科技股份有限公司 一种实现dma数据传输的方法及装置
JP5266590B2 (ja) 2009-09-18 2013-08-21 株式会社日立製作所 計算機システムの管理方法、計算機システム及びプログラム
US8850166B2 (en) 2010-02-18 2014-09-30 International Business Machines Corporation Load pair disjoint facility and instruction therefore
US20110314263A1 (en) 2010-06-22 2011-12-22 International Business Machines Corporation Instructions for performing an operation on two operands and subsequently storing an original value of operand
US8914619B2 (en) 2010-06-22 2014-12-16 International Business Machines Corporation High-word facility for extending the number of general purpose registers available to instructions
US8683108B2 (en) 2010-06-23 2014-03-25 International Business Machines Corporation Connected input/output hub management
US8745292B2 (en) 2010-06-23 2014-06-03 International Business Machines Corporation System and method for routing I/O expansion requests and responses in a PCIE architecture
US8468284B2 (en) 2010-06-23 2013-06-18 International Business Machines Corporation Converting a message signaled interruption into an I/O adapter event notification to a guest operating system
US8645606B2 (en) 2010-06-23 2014-02-04 International Business Machines Corporation Upbound input/output expansion request and response processing in a PCIe architecture
US8615645B2 (en) 2010-06-23 2013-12-24 International Business Machines Corporation Controlling the selectively setting of operational parameters for an adapter
US8639858B2 (en) 2010-06-23 2014-01-28 International Business Machines Corporation Resizing address spaces concurrent to accessing the address spaces
US8504754B2 (en) 2010-06-23 2013-08-06 International Business Machines Corporation Identification of types of sources of adapter interruptions
US8478922B2 (en) 2010-06-23 2013-07-02 International Business Machines Corporation Controlling a rate at which adapter interruption requests are processed
US8417911B2 (en) 2010-06-23 2013-04-09 International Business Machines Corporation Associating input/output device requests with memory associated with a logical partition
US8566480B2 (en) 2010-06-23 2013-10-22 International Business Machines Corporation Load instruction for communicating with adapters
US8677180B2 (en) 2010-06-23 2014-03-18 International Business Machines Corporation Switch failover control in a multiprocessor computer system
US8549182B2 (en) 2010-06-23 2013-10-01 International Business Machines Corporation Store/store block instructions for communicating with adapters
US8656228B2 (en) 2010-06-23 2014-02-18 International Business Machines Corporation Memory error isolation and recovery in a multiprocessor computer system
US8650335B2 (en) 2010-06-23 2014-02-11 International Business Machines Corporation Measurement facility for adapter functions
US9213661B2 (en) 2010-06-23 2015-12-15 International Business Machines Corporation Enable/disable adapters of a computing environment
US8918573B2 (en) 2010-06-23 2014-12-23 International Business Machines Corporation Input/output (I/O) expansion response processing in a peripheral component interconnect express (PCIe) environment
US9195623B2 (en) 2010-06-23 2015-11-24 International Business Machines Corporation Multiple address spaces per adapter with address translation
US8572635B2 (en) 2010-06-23 2013-10-29 International Business Machines Corporation Converting a message signaled interruption into an I/O adapter event notification
US9342352B2 (en) 2010-06-23 2016-05-17 International Business Machines Corporation Guest access to address spaces of adapter
US8510599B2 (en) 2010-06-23 2013-08-13 International Business Machines Corporation Managing processing associated with hardware events
US8650337B2 (en) 2010-06-23 2014-02-11 International Business Machines Corporation Runtime determination of translation formats for adapter functions
US8615622B2 (en) 2010-06-23 2013-12-24 International Business Machines Corporation Non-standard I/O adapters in a standardized I/O architecture
US8635430B2 (en) 2010-06-23 2014-01-21 International Business Machines Corporation Translation of input/output addresses to memory addresses
US8626970B2 (en) 2010-06-23 2014-01-07 International Business Machines Corporation Controlling access by a configuration to an adapter function
US8645767B2 (en) 2010-06-23 2014-02-04 International Business Machines Corporation Scalable I/O adapter function level error detection, isolation, and reporting
US8621112B2 (en) 2010-06-23 2013-12-31 International Business Machines Corporation Discovery by operating system of information relating to adapter functions accessible to the operating system
US8505032B2 (en) 2010-06-23 2013-08-06 International Business Machines Corporation Operating system notification of actions to be taken responsive to adapter events
US9851969B2 (en) 2010-06-24 2017-12-26 International Business Machines Corporation Function virtualization facility for function query of a processor

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6273347A (ja) * 1985-09-27 1987-04-04 Hitachi Ltd アドレス変換装置
JPH0250744A (ja) * 1988-08-12 1990-02-20 Nec Corp アドレス変換方式
JPH0619798A (ja) * 1992-02-26 1994-01-28 Microsoft Corp セレクタの値のロードを回避する方法とシステム
WO2009087133A1 (en) * 2008-01-11 2009-07-16 International Business Machines Corporation Dynamic address translation with fetch protection
JP2011509470A (ja) * 2008-01-11 2011-03-24 インターナショナル・ビジネス・マシーンズ・コーポレーション フェッチ保護を有する動的アドレス変換

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2013534667A (ja) * 2010-06-23 2013-09-05 インターナショナル・ビジネス・マシーンズ・コーポレーション アダプタに関する操作パラメータの選択的設定の制御

Also Published As

Publication number Publication date
US20140129796A1 (en) 2014-05-08
CA2800636C (en) 2018-03-13
ES2428822T3 (es) 2013-11-11
AU2010355813A1 (en) 2012-12-20
US20130067194A1 (en) 2013-03-14
PL2430555T3 (pl) 2013-11-29
RU2012147515A (ru) 2014-05-20
ZA201209649B (en) 2014-05-28
US20110320758A1 (en) 2011-12-29
BR112012033815A2 (pt) 2018-04-17
DK2430555T3 (da) 2013-09-30
US8635430B2 (en) 2014-01-21
BR112012033815B1 (pt) 2020-11-03
PT2430555E (pt) 2013-10-03
CN102906719A (zh) 2013-01-30
RU2547705C2 (ru) 2015-04-10
WO2011160722A1 (en) 2011-12-29
KR101455544B1 (ko) 2014-10-27
CA2800636A1 (en) 2011-12-29
EP2430555A1 (en) 2012-03-21
HRP20130820T1 (en) 2013-10-11
KR20130048762A (ko) 2013-05-10
JP5636097B2 (ja) 2014-12-03
SG186098A1 (en) 2013-01-30
HK1180793A1 (en) 2013-10-25
US9626298B2 (en) 2017-04-18
CN102906719B (zh) 2015-07-08
MX2012014859A (es) 2013-02-01
AU2010355813B2 (en) 2014-05-22
US8631222B2 (en) 2014-01-14
SI2430555T1 (sl) 2013-10-30
EP2430555B1 (en) 2013-08-28

Similar Documents

Publication Publication Date Title
JP5636097B2 (ja) 入力/出力アドレスをメモリ・アドレスに変換するための方法、コンピュータ・システム、およびコンピュータ・プログラム
JP5731641B2 (ja) アダプタ機能に関する変換フォーマットのランタイム決定のための方法、システム、およびコンピュータ・プログラム
JP5607825B2 (ja) コンピューティング環境のシステム・メモリの管理を容易にする方法、システム、コンピュータ・プログラム
JP5629373B2 (ja) コンピューティング環境においてアダプタへのアクセスを制御する方法、プログラム、および、コンピュータ・システム
JP5736044B2 (ja) アダプタに関する操作パラメータの選択的設定の制御
JP5536956B2 (ja) コンピューティング環境においてアドレス空間を管理するための方法、コンピュータ・システム、コンピュータ・プログラム
JP5731642B2 (ja) アダプタのアドレス・スペースへのゲスト・アクセスのための方法、システム、およびコンピュータ・プログラム
JP5649200B2 (ja) アダプタ割り込みのソース・タイプの識別
JP5669938B2 (ja) コンピューティング環境のアダプタを使用可能にするための方法、システム、およびコンピュータ・プログラム
JP5739524B2 (ja) アダプタと通信するための保存/保存ブロック命令

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20130802

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20140327

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20140507

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20140724

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20140731

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20140904

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20140930

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20141017

R150 Certificate of patent or registration of utility model

Ref document number: 5636097

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150