JP4755390B2 - メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置 - Google Patents

メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置 Download PDF

Info

Publication number
JP4755390B2
JP4755390B2 JP2002561695A JP2002561695A JP4755390B2 JP 4755390 B2 JP4755390 B2 JP 4755390B2 JP 2002561695 A JP2002561695 A JP 2002561695A JP 2002561695 A JP2002561695 A JP 2002561695A JP 4755390 B2 JP4755390 B2 JP 4755390B2
Authority
JP
Japan
Prior art keywords
data
memory
lcp
descriptor
adapter
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
JP2002561695A
Other languages
English (en)
Other versions
JP2004523035A (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 JP2004523035A publication Critical patent/JP2004523035A/ja
Application granted granted Critical
Publication of JP4755390B2 publication Critical patent/JP4755390B2/ja
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

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/38Information transfer, e.g. on bus
    • G06F13/40Bus structure
    • 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/38Information transfer, e.g. on bus
    • G06F13/40Bus structure
    • G06F13/4004Coupling between buses
    • G06F13/4022Coupling between buses using switching circuits, e.g. switching matrix, connection or expansion network

Description

本発明は、ホスト・コンピュータ・システムとデータ通信ネットワークの間でデータを通信するホスト・コンピュータ・システムおよびデータ通信インターフェースなどの第1および第2のデータ処理システムの間でメモリを介してデータのフローを制御する方法および装置に関する。
従来のデータ処理ネットワークには、イーサネット(R)・アーキテクチャなどの中間のネットワーク・アーキテクチャによってすべてが相互接続される複数のホスト・コンピュータ・システムおよび複数の付加デバイスが含まれる。ネットワーク・アーキテクチャには、通常は、1つまたは複数のデータ通信交換機が含まれる。ホスト・コンピュータ・システムおよび付加デバイスのそれぞれが、データ処理ネットワーク内のノードを形成する。各ホスト・コンピュータ・システムには、通常は、PCIバス・アーキテクチャなどのバス・アーキテクチャによって相互接続される、複数の中央処理装置およびデータ・ストレージ・メモリ・デバイスが含まれる。ネットワーク・アダプタも、ホスト・コンピュータ・システムとデータ処理ネットワーク内の他のノードの間でネットワーク・アーキテクチャを介してデータを通信するためにバス・アーキテクチャに接続される。
ホスト・コンピュータ・システムとネットワーク・アーキテクチャの間のデータおよび制御情報の転送をできる限り効率的に促進することが望ましい。
本発明によれば、メモリを介して第1および第2のデータ処理システムの間でデータのフローを制御する装置であって、メモリ内の位置と第2データ処理システムの間で通信されるデータ・パケットを定義するフレーム記述子およびメモリ内の位置を識別するポインタ記述子を含む複数の記述子を生成する記述子ロジックと、第1および第2のデータ処理システムによるアクセスのために記述子ロジックによって生成された記述子を保管する記述子テーブルとを含む装置が提供される。
記述子ロジックおよび記述子テーブルによって、ホスト・コンピュータ・システムとデータ通信ネットワークの間でデータを通信するホスト・コンピュータ・システムとデータ通信インターフェースなどの第1および第2のデータ処理システムの間のデータ・フロー制御の効率が改善される。
記述子テーブルは、ホスト・コンピュータ・システムのメモリに保管することができる。代替案では、記述子テーブルが、データ通信インターフェースのメモリに保管される。記述子ロジックは、記述子テーブル内の別の記述子へのリンクを含む分岐記述子も生成することができる。記述子テーブルに、その中の分岐記述子を介して一緒に順次リンクされた複数の記述子リストを含めることができる。代替案では、記述子テーブルに、循環記述子リストが含まれる。
本発明は、メモリを有するホスト処理システムと、ホスト・コンピュータ・システムとデータ通信ネットワークの間でデータを通信するデータ通信インターフェースと、ホスト・コンピュータ・システムのメモリとデータ通信インターフェースの間でのデータのフローを制御する、上に記載の装置とを含むデータ処理システムに拡張される。
もう1つの態様から本発明を見ると、メモリを介して第1および第2のデータ処理システムの間でデータのフローを制御する方法であって、記述子ロジックによって、メモリ内の位置と第2データ処理システムの間で通信されるデータ・パケットを定義するフレーム記述子およびメモリ内の位置を識別するポインタ記述子を含む複数の記述子を生成することと、第1および第2のデータ処理システムによるアクセスのために、記述子ロジックによって生成された記述子を記述子テーブルに保管することとを含む方法が提供される。
本発明の好ましい実施形態を、例のみとして、添付図面に関してこれから説明する。
まず図1を参照すると、本発明を実施するデータ処理ネットワークの例に、InfiniBandネットワーク・アーキテクチャ(InfiniBandはInfiniBandTrade Association社の商標である)などの中間ネットワーク・アーキテクチャ30によって相互接続された、複数のホスト・コンピュータ・システム10および複数の付加デバイス20が含まれる。ネットワーク・アーキテクチャ30には、通常は、複数のデータ通信交換機40が含まれる。ホスト・コンピュータ・システム10および付加デバイス20のそれぞれが、データ処理ネットワーク内のノードを形成する。各ホスト・コンピュータ・システム10に、PCIバス・アーキテクチャなどのバス・アーキテクチャ70によって相互接続される、複数の中央処理装置(CPU)50およびメモリ60が含まれる。ネットワーク・アダプタ80も、ホスト・コンピュータ・システム10と、データ処理ネットワーク内の他のノードとの間で、ネットワーク・アーキテクチャ30を介してデータを通信するために、バス・アーキテクチャに接続される。
図2を参照すると、本発明の特に好ましい実施形態では、ネットワーク・アダプタ80に、ホスト・コンピュータ・システム10のバス・アーキテクチャ70への取外し可能な挿入のためのエッジ・コネクタなどのコネクタを有するプラグ可能オプション・カードが含まれる。オプション・カードは、コネクタ270を介してバス・アーキテクチャ70に接続可能な特定用途向け集積回路(ASIC)またはインテグレーテッド・システム・オン・ア・チップ(Integrated System on a Chip、ISOC)120、ISOC120に接続される1つまたは複数の第3レベル・メモリ・モジュール250、および、ネットワーク・アーキテクチャ30の媒体とISOC120の間でデータを通信するためにISOC120に接続されたインターポーザ260を担持する。インターポーザ260は、ネットワーク30への物理的接続を提供する。本発明のいくつかの実施形態では、インターポーザ260を、単一のASIC内で実施することができる。しかし、本発明の他の実施形態では、インターポーザ260を、複数の構成要素によって実施することができる。たとえば、ネットワーク30に光ネットワークが含まれる場合に、インターポーザ260に、別の光トランシーバを駆動するリタイマ(retimer)を含めることができる。メモリ250は、SRAM、SDRAM、またはその組合せによって実施することができる。他の形態のメモリも、メモリ250の実施に使用することができる。ISOC120には、第1および第2のメモリが含まれる。アダプタ80のメモリ・サブシステムを、すぐに説明する。以下の説明から明らかになるように、この配置は、データ処理ネットワークで動作する分散アプリケーションの改良された性能、改良されたシステム・スケーラビリティ、ある範囲の通信プロトコルとの互換性、およびホスト・コンピュータ・システムでの減らされた処理要件を提供する。具体的に言うと、この配置では、アダプタ80とホスト・システム10の間の異種通信プロトコルの共存が可能になる。そのようなプロトコルは、さまざまなアプリケーションをサービスし、同一のアダプタ80を使用し、データ構造の事前定義の組を使用することができ、これによって、ホストとアダプタ80の間のデータ転送が機能強化される。並列にオープンすることができるアプリケーション・チャネルの数は、アダプタ80に割り振られるメモリ・リソースの量によって決定され、アダプタに組み込まれる処理能力に依存しない。下記から、複数の構成要素を単一の集積回路チップに統合するというISOC120の概念によって、有利なことに、製造コストが最小になり、再利用可能なシステム基本構成要素が提供される。しかし、本発明の他の実施形態で、ISOC120の要素を、別個の構成要素によって実施できることも諒解されたい。
以下の説明では、用語「フレーム」が、ホスト・コンピュータ・システム10で稼動するソフトウェアとアダプタ80の間で転送されるデータ単位またはメッセージを指す。各フレームに、フレーム・ヘッダおよびデータ・ペイロードが含まれる。データ・ペイロードに、ユーザ・データ、高水準プロトコル・ヘッダ・データ、肯定応答、フロー制御、またはこれらの任意の組合せを含めることができる。フレーム・ヘッダの内容を、詳細にすぐに説明する。アダプタ80は、フレーム・ヘッダだけを処理する。アダプタ80は、フレームを、ネットワーク・アーキテクチャ30でより効率的に移送される、より小さいパケットに断片化することができる。しかし、そのような断片化では、一般に、データ・ペイロードは変換されない。
本発明の特に好ましい実施形態では、データが、ネットワーク・アーキテクチャ30上で、以下でパケットと称するアトミックな単位で移送される。各パケットには、経路情報と、その後のハードウェア・ヘッダ・データおよびペイロード・データが含まれる。本発明の通常の例では、1024バイトまでのパケット・サイズが使用される。より大きいサイズのフレームは、1024バイト・パケットに断片化される。本発明の他の実施形態で、異なるパケット・サイズを使用できることを諒解されたい。
本発明の好ましい実施形態では、アダプタ80と、ホスト・コンピュータ・システム10で稼動する複数のアプリケーションとの間の通信が、論理通信ポート(Logical Communication Port)アーキテクチャ(LCP)を介してもたらされる。アダプタ80には、異なる内部データ構造へのアクセス待ち時間の最適化を可能にするメモリ階層が含まれる。このメモリ階層を、すぐに説明する。本発明の好ましい実施形態では、アダプタ80が、ネットワーク・アーキテクチャ30に宛てられたアウトバウンド(TX)データとホスト・コンピュータ・システム10に宛てられたインバウンド(RX)データに別々のパスを提供する。各パスには、それ自体のデータ転送エンジン、ヘッダ処理ロジック、およびネットワーク・アーキテクチャ・インターフェースが含まれる。これらのパスも、詳細にすぐに説明する。
図3を参照すると、LCPアーキテクチャによって、ホスト・コンピュータ・システム10で稼動するローカル・コンシューマとアダプタ80の間のインターフェースのフレームワークが定義される。そのようなコンシューマの例に、アプリケーションとスレッドの両方が含まれる。コンピュータ・システム10を、ユーザ・アプリケーション空間90とカーネル空間110に副分割することができる。LCPアーキテクチャは、各コンシューマにネットワーク・アーキテクチャ30への論理ポートを与える。このポートには、ユーザ空間90から直接にアクセスすることができる。本発明の特に好ましい実施形態では、ハードウェア保護機構が、アクセス許可を解決する。LCP登録が、データ・フレームの転送の前に、カーネル空間110によって実行される。LCPアーキテクチャでは、通信プロトコルを定義する必要がない。そうではなく、LCPアーキテクチャでは、データおよび制御情報を転送するための、アプリケーションとアダプタ80の間のインターフェースが定義される。その代わりに、通信プロトコルの詳細を、アプリケーションおよびアダプタ80で実行されるプログラム・コードによってセットすることができる。アダプタ80で使用できるチャネルの数は、LCP関連情報に使用可能なアダプタ・カード80上のメモリの量だけによって制限される。各LCPポートを、特定の特徴の組を有するようにプログラムすることができる。特徴の組は、特定のプロトコルに従って、ホスト・コンピュータ・システム内のメモリ60とアダプタ80の間でのデータ転送を最もよくサポートするように選択される。さまざまな通信プロトコルを、各プロトコルで異なるLCPポートを使用して、同時にサポートすることができる。
LCPアーキテクチャには、LCPクライアント100、カーネル空間110に常駐するLCPマネージャ130、および、アダプタ80に常駐する1つまたは複数のLCPコンテキスト140が含まれる。
各LCPクライアント100は、LCPポートに接続された、単一方向アプリケーション・エンド・ポイントである。LCPクライアント100を、ユーザ・アプリケーション空間90またはカーネル110内に配置することができる。動作中に、各LCPクライアント100は、メモリ60から読み取られ、アダプタ80によってTX LCPチャネルを介して転送されるコマンドおよびデータを作るか、アダプタ80によってメモリ60へRX LCPチャネルを介して転送されるデータを消費する。
LCPマネージャ130は、LCPチャネルの割振りおよび割振り解除と、チャネルごとのメモリ60内の読取/書込区域の登録の要求をサービスする、信頼される構成要素である。LCPマネージャ130は、他の通信動作、アプリケーション、またはホスト・コンピュータ・システム10のオペレーティング・システムを危険にさらさずに、ユーザ空間アプリケーションが、アダプタ80のリソースを使用できるようにする。
各LCPコンテキスト140は、特定のLCPクライアント100をサービスするのにアダプタ80が必要とする制御情報の組である。LCPコンテキスト140には、可能なコマンド、ポインタ構造、およびバッファ記述子定義など、チャネルの存在全体を通じて一定のLCPチャネル属性を含めることができる。LCPコンテキスト140には、サービスを待っているデータの量、関連するLCPチャネルにアクセスするための次のアドレスなど、LCPチャネルに関する特定のLCPサービス情報も含めることができる。LCPコンテキスト140は、アダプタ80に常駐するメモリに保管されて、アダプタ80があるチャネルのサービスを停止し、別のチャネルのサービスを開始する時の高速LCPコンテキスト切替が可能になっている。
LCPポートの開始を要求するLCPクライアント100は、LCPマネージャ130に頼り、LCPチャネルの割振りを要求する。LCPチャネル属性は、この時に決定され、これによって、LCPポートの挙動およびLCPクライアント100がLCPポートに関連して実行を許可される動作が規定される。LCPクライアント100は、一意の保護された形でアダプタ80にアクセスするのに使用されるアドレスを許可される。このアドレスを、ドアベル(Doorbell)アドレスと称する。
LCPマネージャ130は、アダプタによる仮想アドレスから物理アドレスへの変換を可能にし、ユーザ空間クライアントが他のプログラムを改竄せずにこれらのホスト・メモリ区域にアクセスできるようにするために、ホスト・メモリ60の区域を登録する責任も負う。
新しいバッファの登録および前のバッファの登録解除は、実行時中に各LCPクライアント100が要求することができる。そのような変更は、LCPクライアント100、LCPマネージャ130、およびアダプタ80の間の情報交換のシーケンスを必要とする。
各LCPクライアント100およびポートは、LCPポートによってコマンド実行のために送られる保留中の要求をサービスするためにアダプタ80が必要とするすべての情報を提供するLCPコンテキスト140に関連する。
LCPクライアント100とアダプタ80の間のメモリ転送を開始し、フレームの送信を開始するために、LCPクライアント100は、特定の動作に関する情報を保持する記述子を用意する。LCPクライアント100は、アダプタ80にマッピングされたドアベル・アドレスへの入出力書込を実行する。ドアベル・アドレスに書き込むことによって、アダプタ80のLCPコンテキスト140が更新され、新しい要求が実行のために追加される。
アダプタ80は、保留中の要求を有するさまざまな送信LCPポートの間で調停し、次にサービスされる送信LCPポートを選択する。
データの受信時に、受信されたパケットのフレームおよびLCPが、識別される。記述子を生成して、受信されたLCPに必要な動作を定義する。アダプタ80のLCPエンジンによるこれらの記述子の実行によって、着信データが、ホスト・コンピュータ・システム10のメモリ60内でLCPチャネルに割り振られた適当なデータ・バッファに保管される。
サービスされるLCPチャネルごとに、アダプタ80は、関連するLCPコンテキスト情報をロードし、この情報を使用して、データ転送の所望の組を実行する。その後、アダプタ80は、次に選択されるLCPコンテキスト140の処理に継続する。
図4を参照すると、前に述べたように、ISOC120に、第1メモリ空間220および230と第2メモリ空間240が含まれ、アダプタ80に、さらに、第3レベル・メモリ250が含まれる。第1、第2、および第3のメモリは、アダプタ80のメモリ・サブシステム210のために間隔を空ける。本発明の好ましい実施形態では、ISOC120に、データ送信動作専用のTXプロセッサ(TX MPC)150と、データ受信動作専用のRXプロセッサ(RX MPC)160が含まれる。本発明の特に好ましい実施形態では、プロセッサ150および160が、IBM PowerPC 405 RISCマイクロプロセッサなどの縮小命令セット・コンピューティング(RISC)マイクロプロセッサによって実施される。メモリ・サブシステム210内で、ISOC120に、第1および第2のメモリ空間の他に、TXプロセッサ150に関連するデータ・キャッシュ180および命令キャッシュ170が、RXプロセッサ160に関連する第2データ・キャッシュ190および第2命令キャッシュ200と共に含まれる。3つのレベルの間の相違は、メモリのサイズおよび関連するアクセス時間である。すぐに明らかになるように、メモリ・サブシステム210は、TXプロセッサ150およびRXプロセッサ160の両方による命令およびデータへの便利なアクセスと、スケーラビリティと、削減された製造コストのためのTXプロセッサ150およびRXプロセッサ160の間のリソースの共用とを容易にする。
第1レベル・メモリ空間(M1)220および230に、TX−M1メモリ空間220およびRX−M1メモリ空間230が含まれる。TX−M1メモリ220は、TXプロセッサ150によってのみアクセスでき、RX−M1メモリ230は、RXプロセッサ160によってのみアクセスできる。動作中に、第1レベル・メモリ空間220および230は、一時データ構造、ヘッダ・テンプレート、スタックなどを保持するのに使用される。第1レベル・メモリ空間220および230の両方が、0待ち状態に反応する。第1レベル・メモリ空間220および230のそれぞれは、プロセッサ150および160の対応する1つのデータ・インターフェースだけに接続され、命令インターフェースには接続されない。この配置によって、キャッシュ可能およびキャッシュ不能の両方の第1レベル・メモリ区域を使用可能にすることができるのと同時に、第1レベル・メモリ空間220および230内のデータへの効率的なアクセスを維持できるようになる。
第2レベル・メモリ空間(M2)240は、プロセッサ150および160の両方、アダプタ80の他の構成要素、およびホスト・コンピュータ・システム10から使用可能な共用メモリである。第2レベル・メモリ空間240へのアクセスは、第1レベル・メモリ区域220および230へのアクセスより低速である。というのは、第2レベル・メモリ空間240が、共用される内部バスを介してより多くのエージェントによって使用されるからである。第3レベル・メモリ空間250も、共用リソースである。本発明の特に好ましい実施形態では、アダプタ80に、その上で第1レベル・メモリ空間220および230と第2レベル・メモリ空間240の両方がプロセッサ150および160と同一のASICに集積される、コンピュータ周辺回路カードが含まれる。共用メモリ空間240および250は、一般に、高速で頻繁なアクセス・サイクルを必要としないデータ・タイプに使用される。そのようなデータ・タイプには、LCPコンテキスト140および仮想アドレス変換テーブルが含まれる。この共用メモリ空間240および250は、プロセッサ150および160の命令インターフェースおよびデータ・インターフェースの両方からアクセス可能である。
アダプタ80は、送信データ・フローと受信データ・フローを別々に処理する。送信パスおよび受信パスのプロセッサ150および160は、タスク間の切替のオーバーヘッドを防止し、あるパス内の一時的な処理負荷を他のパスから分離し、着信データ・ストリームおよび発信データ・ストリームの処理に2つの組込みプロセッサを使用することを促進する。図5を参照すると、ISOC120に、送信パス・ロジック280および受信パス・ロジック290と、共用ロジック300が含まれる。送信パス・ロジック280には、各LCPチャネルの詳細をデコードし、LCP関連コマンドを実行のために取り出すLCP TXエンジン310と、アダプタ80へのフレームの転送を制御するTXロジック320と、TXフレームおよびパケット処理の管理用の前述のTXプロセッサ150と、命令および一時データ構造を保持する前述の第1レベルTXメモリ220と、リンク・ロジック330と、フレームのデータ・パケットへの断片化の経路指定処理などのデータ・フロー処理およびパケット処理を管理する際にTXプロセッサ150を支援するロジックとが含まれる。TXプロセッサ150は、プロセッサが例外およびエラーの際にのみ割り込まれる、ポーリングのみ方式に基づいてタスクを直列に処理する。第1レベルTXメモリ220は、プロセッサ150によって、TXロジック320との通信に使用される。受信パス・ロジック290には、リンク・ロジック340と、着信パケットのヘッダ処理およびそのようなパケットのフレームへの変換または組立の際に前述のRXプロセッサ160を支援するハードウェアと、RXフレームおよびパケット処理用の前述のRXプロセッサ160と、命令を保持する前述の第1レベルRXメモリ230と、ネットワーク・アーキテクチャ30からのフレームの転送を制御するRXロジック350と、各LCPチャネルの詳細をデコードし、関連するLCPデータ構造内の着信データをホスト・コンピュータ・システムのメモリ60に保管し、LCPクライアント100によってアダプタ80による使用のために供給される時に、空フレーム・バッファへのポインタを受け入れ、登録する、LCP RXエンジン360とが含まれる。RXプロセッサ160は、RXプロセッサ160が例外およびエラーの際にのみ割り込まれる、ポーリングのみ方式を使用してタスクを直列に処理する。第1レベルRXメモリ230は、RXプロセッサ160によって、RXロジック350との通信に使用される。
前に述べたように、ISOC手法では、アダプタ80および、回路ボードおよび他のサポート・モジュールなどのアダプタの他の構成要素に関連する製造コストの削減が可能になる。ISOC手法では、アダプタ80の単純さも高まり、これによって信頼性が高まる。ISOC120の要素の間の接続の数は、効果的に無制限である。したがって、複数の幅広い相互接続パスを実施することができる。ホスト・コンピュータ・システム10でのデータ処理オーバーヘッドを減らすために、ホスト・メモリ60との間のデータ転送動作は、大部分がISOC120によって実行される。ISOC120は、着信パケットおよび発信パケットのヘッダの処理も実行する。送信中に、ISOC120は、ヘッダを作り、ネットワーク・アーキテクチャ30に経路指定する。受信中に、アダプタ80は、システムのメモリ内でのヘッダの位置を判定するためにヘッダを処理する。レベル1メモリ220および230は、0待ち状態メモリであり、スタック、テンプレート、テーブル、および一時保管場所などのプロセッサ・データ空間を提供する。本発明の特に好ましい実施形態では、送信パス・ロジック280、受信パス・ロジック290、および共用ロジック300が、コアと称する、より小さい論理要素から作られる。用語コアが使用されるのは、これらの要素が、それらを異なる応用例に使用できるようにする独立型の特性を有する個々のロジックとして設計されるからである。
前に示したように、送信パス・ロジック280は、送信フレームまたは発信フレームを処理する責任を負う。フレーム送信は、バス・アーキテクチャ70を介して、ホスト・コンピュータ・システム10のCPU50などのCPUによって開始される。ISOC120には、バス・アーキテクチャ70と通信するバス・インターフェース・ロジック370が含まれる。ISOC120には、バス・インターフェース・ロジック370をISOC120のプロセッサ・ローカル・バス(PLB)390に接続するバス・ブリッジング・ロジック380も含まれる。LCP TXエンジン310は、コマンドおよびフレームをホスト・メモリ60から取り出す。TXプロセッサ150は、各フレームのヘッダを処理して、ネットワーク・アーキテクチャ30上でパケットとして送信するのに適するフォーマットにする。TXロジック320は、フレーム・データを修正なしで転送する。リンク・ロジック330は、送信される各パケットを処理して、ネットワーク・アーキテクチャ30での送信用の最終的な形にする。リンク・ロジック330には、それぞれがネットワーク・アーキテクチャ30に接続可能である1つまたは複数のポートを含めることができる。
前に示したように、受信パス・ロジック290は、着信パケットを処理する責任を負う。まず、ネットワーク・アーキテクチャ30から受信されたパケットが、リンク・ロジック340によって処理される。リンク・ロジック340は、ヘッダおよびペイロードのフォーマットのパケットを再作成する。パケット・フォーマットおよびホスト・メモリ60内での宛先を判定するために、ヘッダが、RXプロセッサ160によって処理される。リンク・ロジック340には、それぞれがネットワーク・アーキテクチャ30に接続可能である1つまたは複数のポートを含めることができる。RX LCPエンジンは、バス・アーキテクチャ370を介してデータをホスト・メモリ60に転送する責任を負う。
送信パス・ロジック280には、TX LCPエンジン310とTXプロセッサ150の間のHeaderIn先入れ先出しメモリ(FIFO)400が含まれる。受信パス・ロジックには、RXプロセッサ160とRX LCPエンジン360の間のHeaderOut FIFO410が含まれる。追加のFIFOおよびキューを、TXロジック320内およびRXロジック350内に設けることができる。これらのFIFOおよびキューを、すぐに説明する。
共用ロジック300には、送信パス・ロジック280および受信パス・ロジック290によって共用されるすべての要素が含まれる。この要素には、前述のバス・インターフェース・ロジック370、バス・ブリッジング・ロジック380、PLB390、第2レベル・メモリ240、およびリモート第3レベル・メモリ250へのアクセスを提供するコントローラ420が含まれる。バス・インターフェース・ロジック370は、バス・アーキテクチャ70上でマスタおよびスレーブの両方として動作する。スレーブとして、バス・インターフェース・ロジックは、CPU50が、第2レベル・メモリ240に、コントローラ420を介して第3レベル・メモリ250に、および、ISOC120の構成レジスタおよび状況レジスタにもアクセスできるようにする。そのようなレジスタは、一般に、CPU50、TXプロセッサ150、およびRXプロセッサ160によってアクセスすることができる。マスタとして、バス・インターフェース・ロジックは、TX LCPエンジン310およびRX LCPエンジン360が、ホスト・コンピュータ・システム10のメモリ60にアクセスできるようにする。図5では、「M」がマスタ接続、「S」がスレーブ接続を示す。
図6を参照すると、ISOC120を通るパケットフローは、一般に対称である。言い換えると、フローの全般的な構造は、送信方向と受信方向の両方で類似する。ISOC120は、第1インターフェース・ロジック440と、第1制御ロジック460と、プロセッサ・ロジック480と、第2制御ロジック470と、第2インターフェース・ロジック450とを含むとみなすことができる。パケットは、下記の形で処理される。
A.送信方向では、情報が、バス・アーキテクチャ70から第1インターフェース・ロジックを介してISOC120に持ってこられる。受信方向では、情報が、ネットワーク・アーキテクチャ30から第2インターフェース・ロジック450を介してISOC120に持ってこられる。
B.送信方向では、第1インターフェース・ロジック440を介してISOC120に持ってこられた情報が、第1制御ロジック460によって処理される。受信方向では、第2インターフェース・ロジック450を介してISOCに持ってこられた情報が、第2制御ロジック470によって処理される。
C.送信方向では、フレーム・ヘッダが、第1制御ロジック460で発信フレームについて抽出され、プロセッサ・ロジック480によって処理される。プロセッサ・ロジック480は、フレーム・ヘッダに基づいて、第2制御ロジック470用の命令を生成する。発信フレームのペイロードは、第2制御ロジック470に渡される。受信方向では、フレーム・ヘッダが、第2制御ロジック470で着信フレームから抽出され、プロセッサ・ロジック480によって処理される。プロセッサ・ロジック480は、フレーム・ヘッダに基づいて、第1制御ロジック460用の命令を生成する。着信フレームのペイロードは、第1制御ロジック460に渡される。両方の方向で、プロセッサ480は、ペイロード・データを直接には処理しない。
D.送信方向では、第2制御ロジック470が、プロセッサ・ロジック480から受け取った命令に従って発信ペイロード・データをパッケージする。受信方向では、第1制御ロジック460が、プロセッサ・ロジック480から受け取った命令に従って着信ペイロード・データをパッケージする。
E.送信方向では、情報が、第2インターフェース・ロジック450からその宛先へネットワーク・アーキテクチャ30を介して移動される。受信方向では、情報が、第1インターフェース・ロジックからその宛先へバス・アーキテクチャ70を介して移動される。
ホスト・コンピュータ・システム10で動作するソフトウェアへのインターフェースを、430に示す。同様に、プロセッサの入力および出力で動作するマイクロコードへのインターフェースを、490および500に示す。
図7を参照して、以下は、ISOC120を通る送信データ・フレームのフローの1例のより詳細な説明である。ISOC120は、ISOC120内の情報のさまざまなフォーマットに基づいて、LCPコンテキスト・ドメイン510、フレーム・ドメイン520、およびネットワーク・ドメイン530に分割することができる。TX LCPエンジン310には、LCP要求FIFO550、直接メモリ・アクセス(DMA)ロジック560、フレーム・ロジック580、および前述のLCPコンテキスト・ロジック140が含まれる。LCP要求FIFO550、DMAロジック560、およびLCP TXコンテキスト・ロジック590は、LCPコンテキスト・ドメイン510に常駐する。フレーム・ロジック580は、フレーム・ドメイン520に常駐する。TXロジック320、第1レベルTXメモリ空間220、およびTXプロセッサ150は、フレーム・ドメイン520とネットワーク・ドメイン530の境界にまたがる。TXリンク・ロジック330は、ネットワーク・ドメイン530に常駐する。本発明の特に好ましい実施形態では、HeaderIn FIFO400が、第1レベルTXメモリ空間220に一体化される。一般に、ホスト・コンピュータ・システム10で実行されるアプリケーションが、フレームを作成する。フレームは、その後、アダプタ80のTX LCPチャネルを使用して送信される。アプリケーションとアダプタ80の間のハンドシェークは、LCPマネージャ130によって前に実行された初期化を前提とする。LCPサービス要求を追加するために、LCPクライアント100が、アダプタ80に、1つまたは複数の追加の送信フレームが実行の準備ができていることを知らせる。これは、ドアベルに制御ワードを書き込むことによって実行される。ドアベルのアドレスは、LCPポートに一意に関連し、他のプロセスによるアクセスから保護されるアドレスを使用して、書込動作が、バス・アーキテクチャ70上での物理書込サイクルに変換される形で割り振られる。アダプタ80は、書込動作を検出し、特定のLCPクライアント100の前の要求の項目を増分することによって、新しい要求をログに記録する。これは、関係するLCPコンテキスト140の一部である。アダプタ80のメモリ・サブシステム210内に保持される調停リストも、更新される。単純な例では、調停で、保留中の要求を有するすべての送信LCPチャネルの間で前述のFIFO方式550が使用される。あるLCPチャネルがサービスされている間に、次のLCPチャネルが選択される。サービス・サイクルは、対応するLCPコンテキストがTX LCPエンジン310にロードされる時に開始される。その後、LCPコンテキスト140にアクセスして、LCPチャネルをサービスするアトミック・オペレーションを導出し、そのような動作のパラメータを判定する。たとえば、そのようなアトミック・オペレーションは、LCPコンテキスト140に記録されたLCPチャネル属性に基づくものとすることができる。完全なサービス・サイクルに、通常は、LCPクライアント100によって作成される複数のアトミックな記述子をフェッチし、実行するためにアダプタ80によって実行されるアクティビティの組が含まれる。TX LCPチャネルの場合に、サービス・サイクルに、一般に、ホスト・メモリ60からアダプタ80のメモリ・サブシステム210に複数のフレームを読み取ることが含まれる。最後に、修正を必要とするすべてのLCPコンテキスト情報(言い換えると、LCPサービス情報)が、アダプタ80のメモリ・サブシステム210内で更新される。一般に、アダプタ80によってLCPサービス・サイクル内で最初に実行される動作は、次に処理される記述子を取り出すことである。
ISOC120による送信フレームの処理には、通常は下記のステップが含まれる。
A.後続LCPポート・フレーム記述子の取出
次に取り出される記述子のアドレスは、LCPチャネルのコンテキスト140の一部として保管される。アダプタ80は、ホスト・メモリ60から記述子を読み取り、LCPチャネル属性に基づいてその記述子をデコードする。記述子によって、新しいフレーム・ヘッダのサイズ、データ・ペイロードのサイズ、およびこれらの項目の位置が定義される。
B.仮想アドレスの物理アドレスへの変換
データ・バッファが、アプリケーション内で仮想メモリ・アドレスによって参照される場合に、そのアドレスは、アドレス変換という追加処理を受けなければならない。この場合に、アプリケーションによって使用される仮想アドレスが、アダプタ80がホスト・メモリ60にアクセスする間にアダプタ80によって使用可能な物理アドレスに変換される。これは、ページ境界を超えることを監視し、LCPマネージャ130によってアダプタ80のメモリ・サブシステム210に書き込まれる物理ページ位置情報を使用することによって行われる。仮想アドレスから物理アドレスへの変換処理は、記述子テーブルが、信頼されないLCPクライアント100によって作成される場合のセキュリティ手段としても働く。これによって、ホスト・メモリ60の無関係な区域への許可されないアクセスが防止される。
C.フレーム・ヘッダの読取
物理アドレッシングを使用して、TXフレームのヘッダおよびペイロード・データが、ホスト・メモリ60内のバッファから読み取られる。その後、ヘッダが、TX HeaderIn FIFO400に保管される。ヘッダ取出が完了した時に、アダプタ80は、ヘッダの処理をTXプロセッサ150によって開始できることを示す内部フラグをセットする。
D.フレーム・データの読取
ペイロード・データが、ホスト・メモリ60から読み取られ、アダプタ80によってデータFIFO570に保管される。データFIFO570は、図7では、TXロジック320に常駐するものとして図示されている。しかし、データFIFO570を、第1レベルTXメモリ空間220に一体化することもできる。データ読取トランザクションは、送信されるデータのすべてがアダプタ80のメモリ・サブシステム210に保管されるまで継続する。読取動作の完了に続いて、状況指示が、LCPクライアント100に返される。ヘッダがHeaderIn FIFO400に読み取られてすぐに、ヘッダの処理を開始できることに留意されたい。データ全体が読み取られるのを待つ必要はない。
E.フレーム・ヘッダの処理
ヘッダ処理は、TXプロセッサ150によって実行される。ヘッダ処理は、プロトコル依存であり、LCPアーキテクチャの外部のプロトコル情報が用いられる。TXプロセッサ150は、TXプロトコル・ヘッダ・マイクロコードを実行し、プロトコルおよび経路指定初期化シーケンス中にアダプタ80のメモリ・サブシステム210に既に保管された経路指定テーブルおよび他の関連情報にアクセスする。TXプロセッサ150は、新しいヘッダがHeaderIn FIFO400内で待っていることの指示を受け取る時に、ヘッダ処理を開始する。ヘッダ処理では、ネットワーク・アーキテクチャ30を介してパケットを送信するのに使用されるフォーマットであり、経路指定情報を含む、1つまたは複数のパケット・ヘッダが作られる。ペイロード・サイズが、ネットワーク・アーキテクチャ30によって許容される最大パケット・サイズより大きい場合には、元のペイロード・データの連続するデータ・セグメントに関してそれぞれが使用される複数のパケット・ヘッダを生成して、ネットワーク・アーキテクチャ30を介する通信用のパケットを形成することによって、ペイロードを断片化する。
F.送信用のパケット・ヘッダのキューイング
パケットのヘッダ・ワード数およびデータ・ワード数を定義するコマンドおよびパケット・ヘッダ自体が、TXプロセッサ150によって、第1レベル・メモリ空間220内のTX HeaderOut FIFO540に書き込まれる。
G.送信用のパケット・ヘッダおよびパケット・データのマージ
ネットワーク・アーキテクチャ30でのパケットの送信は、コマンドがHeaderOut FIFO540内で準備ができており、データFIFO570に、関連するパケットの送信を完了するのに十分なデータが含まれる時に、必ずトリガされる。巡回冗長検査(CRC)を、各パケットのヘッダおよびデータに追加することができる。各完全なパケットが、TXリンク・ロジック330を介してネットワーク・アーキテクチャ30に転送される。
各フレームの送信処理は、すべてのフレーム・データが、1つまたは複数のパケットによってネットワーク・アーキテクチャ30で送信された時に完了する。アダプタ80によって処理されるフレームごとに、第2のLCPクライアント100を介してアプリケーションに状況を返すことができる。この状況は、ホスト・メモリ60からアダプタ80へのフレーム・データ転送の完了、フレーム送信自体の完了、または他のレベルの送信状況とすることができる。
どの瞬間でも、アダプタ80は、次にサービスされるLCPの選択、LCPチャネルAのサービスの開始、LCPチャネルBの最後のフレームのデータのDMA取出の実行、LCPチャネルCのフレーム・ヘッダの処理および断片化、LCPチャネルDから発するパケットの送信のうちの一部またはすべてを平行に実行することができる。
図8を参照して、以下は、例のみとして、RX LCPポートを使用するアプリケーションによるデータ・フレーム受信の説明である。ISOC120の動作は、LCPによってサポートされるプロトコルのタイプに応じて変更することができる。アプリケーションとアダプタ80の間のハンドシェークは、LCPマネージャ130によって前に実行された初期化を前提とする。RX LCPエンジン360には、LCP割振りロジック620、LCPコンテキスト・ロジック610、およびDMAロジック630が含まれ、これらのすべてが、LCPコンテキスト・ドメイン510に常駐する。RXプロセッサ160、第1レベルRXメモリ空間230、およびRXロジック350のすべてが、フレーム・ドメイン520とネットワーク・ドメイン530の間の境界にまたがる。RXリンク・ロジック340およびパケット援助ロジック600は、ネットワーク・ドメイン530に常駐する。本発明の特に好ましい実施形態では、HeaderOut FIFO410が、第1レベルRXメモリ空間230内に配置される。ISOC120によってネットワーク・アーキテクチャ30から受信されたフレームは、ホスト・メモリ60内のLCPクライアント・バッファに書き込まれる。メモリ・バッファの可用性は、LCP RXクライアント100によって判定され、着信データ・フレームの挿入のためにアダプタ80に示される。LCPクライアント100は、送信される準備ができた新しいフレームについて送信パス・ロジック280が知らされる前に述べた形に似て、ISOC120の受信ドアベルに書き込むことによってバッファを提供する。ドアベル・レジスタ・アドレスは、書込動作がバス・アーキテクチャ70への物理書込サイクルに変換されるように割り振られる。アダプタ80は、書込動作を検出し、特定のLCP RXクライアント100の使用可能なワード項目の数を増分することによって、空のメモリ区域の新たな提供をログに記録する。使用可能なワード・カウントは、関係するLCPコンテキスト140の一部である。アプリケーションは、バッファ内の受信したフレームの処理を完了する時に、必ずドアベルに書き込む。この書込サイクルによって、新たに使用可能なメモリ空間のワード数が示される。LCPコンテキスト内のカウントが、その量だけ増分される。ネットワーク・アーキテクチャ30から受信されたパケットは、アダプタ80によってホスト・メモリ60内の連続する空間に組み立てられる、より大きいフレームの一部である場合がある。ISOC120による受信されたフレームの処理には、一般に、下記のステップが含まれる。
A.パケット・ヘッダとデータの分離
RXリンク・ロジック340は、ネットワーク・アーキテクチャ30からの情報をパケットのストリームに変換する。受信されたパケットのそれぞれが、RXリンク・ロジック340によって処理されて、パケット・ヘッダがペイロード・データから分離される。ヘッダは、第1レベルRXメモリ空間230内のRX HeaderIn FIFO640にプッシュされる。ペイロードは、RXロジック350内のRXデータFIFO650にプッシュされる。RXデータFIFO650は、第1レベルRXメモリ空間230内で実施することもできる。
B.パケット・ヘッダのデコードおよびLCPフレーム・ヘッダの生成。
パケット・ヘッダをデコードして、パケットが属するフレームのID、ペイロードのサイズ、およびフレーム・データのサイズを示すフィールドを提供する。パケット・ヘッダが、RX HeaderIn FIFO640に関するリーダーになるならば、指示が、RXプロセッサ160に送られる。RXプロセッサは、パケット・ヘッダ情報を処理し、パケット・データの転送に必要な情報を含むLCP関連コマンドを生成する。そのような情報には、パケットのアドレスおよび長さが含まれる。ヘッダ処理の終りに、記述子または記述子の組が、LCP RX HeaderOut FIFO410に書き込まれ、指示がトリガされる。
C.RX LCPコンテキスト内のデータの転送
記述子が、RX LCPエンジン360によってRX HeaderOut FIFO410から取り出され、デコードされる。記述子には、LCP番号、パケット・アドレス、パケット・データ長、および、アダプタ80のメモリ・サブシステム210に転送されるデータのソース・アドレスが含まれる。RX LCPエンジン340は、LCPコンテキスト情報を使用して、ホスト・メモリ60内の書き込まれるターゲット物理アドレス(または、ページにまたがる場合には複数のアドレス)を作成し、DMA転送を開始して、データを書き込む。
D.ISOC DMAトランザクション
ISOC120は、適当なバス・コマンドを選択し、可能な最長のバーストを実行することによって、バス・アーキテクチャ70でのトランザクションの最適化を目指す。
どの瞬間でも、アダプタ80は、LCPチャネルXのバッファ割振りの処理、LCPチャネルAのインバウンド・データ書込サービスの開始、LCPチャネルBのデータのDMAストアの実行、LCPチャネルC宛のパケットのフレーム組立の処理、およびLCPチャネルDのパケットの受信の一部またはすべてを並列に実行することができる。
RXプロセッサ160およびTXプロセッサ150でのフレーム処理オーバーヘッドを最小にするために、パケット援助ロジック600に、フレーム断片化ロジック、CRCおよびチェックサム計算ロジック、およびマルチキャスト処理ロジックが含まれる。
TX LCPエンジン310およびRX LCPエンジン360の両方とホスト10の間のデータ・フローを、これから詳細に説明する。TX LCPポートおよびRX LCPポートの両方で、データ転送用のメモリ・バッファと、そのようなメモリ・バッファをポイントする記述子構造が使用される。記述子構造は、データ・プロバイダとデータ・コンシューマの間でデータ・バッファを管理し、データ・プロバイダによって使用される空のメモリ・バッファを返すのに使用される。記述子は、物理アドレスまたは仮想アドレスのいずれかに基づいてメモリ・バッファをポイントする。
TX LCPチャネルは、ホスト・メモリ60からISOC120のバッファへのデータ転送の責任を負う。ロジックの他の層は、ISOC120のバッファからネットワーク30にデータを転送する責任を負う。RX LCPチャネルは、ネットワーク30から受信されたデータのホスト・メモリ60への転送の責任を負う。
TX LCPエンジン310およびRX LCPエンジン360は、比較的多数のLCPチャネルを扱うことができる。各LCPチャネルは、それに固有のすべての情報を含むパラメータの組を有する。この情報には、チャネルの構成、現在の状態、および状況が含まれる。あるチャネルに関連するLCPコンテキスト140が、チャネルの初期化中にLCPマネージャ130によってセットされる。チャネル動作中に、LCPコンテキスト140の内容が、ISOC120のみによって更新される。LCPコンテキスト140は、アダプタ80のメモリ・サブシステム210内のコンテキスト・テーブルに保管される。LCPチャネルのLCPコンテキスト140へのアクセスは、LCP番号に従って実行される。LCPのRXチャネルおよびTXチャネルでは、異なるLCPコンテキスト構造が使用される。
データ・バッファは、ホスト10のメモリ60内のピン止めされた区域である。送信バッファには、送信用のデータが保持される。TX LCPエンジン310は、これらのバッファに置かれたデータをISOC120の内部バッファに移動する。ネットワーク・アーキテクチャ30から受信される着信データは、RX LCPエンジン360によって、ホスト10のメモリ60内のバッファに移動される。バッファの所有権は、ホスト10内のソフトウェアとISOC120の間で交番する。LCP TXチャネルでのイベントの順序は、次の通りである。
A.ホスト10のソフトウェアが、ホスト10のメモリ60内で、送信されるデータと共にバッファを準備する。
B.ソフトウェアが、バッファ内のデータが送信の準備ができていることをISOC120に通知する。
C.ISOC120が、バッファからデータを読み取る。
D.ISOC120が、ホスト10のソフトウェアに対して、読み取られ、新しいデータを転送するためにホスト10のソフトウェアによって再利用することができるバッファを識別する。
LCP RXチャネルでのイベントの順序は、次の通りである。
A.ホスト10のソフトウェアが、ISOC120が受信されたデータを書き込むことができるバッファを準備する。
B.ソフトウェアが、空きバッファがホストのメモリ60内で準備ができていることをISOC120に通知する。
C.ISOC120が、データをバッファに書き込む。
D.ISOC120が、ホスト10のソフトウェアに対して、受信されたデータが書き込まれ、ソフトウェアによって処理されることができるバッファを識別する。
ソフトウェアが、ISOC120によって使用されるバッファを準備する時に、バッファ情報が、ドアベル・レジスタを介して追跡される。ISOC120によって使用されるバッファに関する情報は、状況更新を使用してまたは完了キューを介して、ソフトウェアに返される。TX LCPチャネルについて、バッファに、TX LCPエンジン310によってISOC120に転送され、処理されて、ネットワーク30での送信用の1つまたは複数のパケットになるデータおよびヘッダの情報が含まれる。ヘッダは、ISOC120のTXプロセッサ150によって、ネットワーク30で送信されるパケットのヘッダを生成するのに使用される。RX LCPチャネルについて、空きバッファが、ホスト10のソフトウェアによってアダプタ80に割り当てられる。アダプタ80は、受信されたパケットをバッファに書き込む。
記述子によって、ISOC120およびホスト10のソフトウェアの両方に既知のデータ構造が定義されている。ソフトウェアは、記述子を使用して、ISOC120に制御情報を転送する。制御情報は、所望の機能に応じて、フレーム記述子、ポインタ記述子、または分岐記述子の形とすることができる。ソフトウェア内およびISOC120内の記述子ロジックは、行われる制御手段に従って記述子を生成し、修正する。そのような手段を、すぐに説明する。フレーム記述子には、パケットの記述子(たとえば、データ長、ヘッダ長など)が含まれる。ポインタ記述子には、データ位置の記述子が含まれる。分岐記述子には、記述子位置の記述(たとえば、記述子のリンク・リスト)が含まれる。記述子内の情報は、TX LCPエンジン310およびRX LCPエンジン360によって実行されるデータ移動動作の、ホスト10内のソフトウェアによる制御に使用される。TXパケット・ヘッダを生成するためにフレームを処理するのに使用される情報は、フレームのヘッダに配置される。図9を参照すると、記述子を、単一のテーブル700内に設けることができ、LCPコンテキスト140が、テーブル700の先頭をポイントする。図10を参照すると、記述子を、リンクされた記述子テーブル720から740の構造で配置することもできる。LCPチャネル初期化の後に、LCPコンテキスト140は、構造内の最初の記述子テーブル720の先頭をポイントする。分岐記述子750から770は、テーブル720から740のリンク・リストを生成するのに使用され、ここで、記述子テーブル720から740の終りの分岐記述子750から770は、別のテーブル720から740の始めをポイントする。図9に戻ると、分岐記述子は、循環バッファを生成するのにも使用することができ、ここで、テーブル700の終りの分岐記述子710は、同一のテーブル700の始めをポイントする。循環バッファは、受信パスで使用することもできる。この場合に、LCPコンテキスト140が、バッファの先頭をポイントするように開始される。バッファは、ISOC120がその終りに達した時に、ラップ・アラウンドされる。ホスト10のソフトウェアは、ホスト10のメモリ60に(受信パスと送信パスの両方について)、またはアダプタ80のメモリ250に(送信パスのみについて)記述子を書き込むことができる。アダプタ80のメモリ・サブシステム210への記述子の書込には、ホスト10のソフトウェアによる入出力動作が含まれ、アダプタ80のメモリ・サブシステム210が占有される。ホスト10のメモリ60での記述子の書込は、アダプタ80が、新しい記述子を読み取らなければならない時に、必ずホスト10のメモリ60にアクセスすることを必要とする。ソフトウェア記述子の位置は、LCPチャネルごとに独立に、LCPマネージャ130によって定義される。記述子の位置は、システム性能最適化に従って定義される。記述子は、キューの構成での柔軟性を提供する。
TX LCPエンジン310およびRX LCPエンジン360は、記述子テーブル内の記述子にアクセスし、データ・バッファにアクセスするのに、アドレスを使用する。アドレスは、物理アドレスまたは仮想アドレスのいずれかとすることができる。用語物理アドレスは、ISOC120が、そのままでバス70に駆動できるアドレスを指す。用語仮想アドレスは、物理アドレスではなく、ソフトウェアまたはマイクロコードによって使用されるアドレスを指す。仮想アドレスは、物理アドレスを生成するために、マッピングを受けなければならない。TX LCPエンジン310およびRX LCPエンジン360によって使用されるアドレスは、LCPチャネル・コンテキスト140内のポインタ、ホスト10で稼動するソフトウェアによって準備される記述子内のポインタ、RXプロセッサ160によって準備される記述子内のポインタ、およびTXプロセッサ150によって準備される記述子内のポインタ(完了メッセージを返すのに使用される)という異なるソースを有することができる。ポインタは、記述子またはデータ・バッファをポイントすることができる。TX LCPエンジン310およびRX LCPエンジン360によって使用されるすべてのアドレスを、任意選択として、バス70上の物理アドレスとして使用される新しいアドレスにマッピングすることができる。アドレス・マッピングは、TX LCPエンジン310およびRX LCPエンジン360によって行われる。ISOC120は、ローカル・メモリ210を使用して、変換テーブルを保持する。LCPマネージャ130は、メモリ登録中にアダプタ80に変換テーブルを書き込む。アドレス・マッピングによって、バッファまたは記述子テーブルに仮想アドレスを使用できるようになる。仮想アドレッシングによって、物理的に複数の物理ページに配置される仮想バッファの管理が可能になる。アドレス・マッピングによって、ホスト10が、ソフトウェアのための変換プロセッサを必要とせずに、仮想アドレスを使用するアプリケーションを直接に扱えるようになる。
図11を参照すると、この図には、ホスト10のソフトウェアから見えるバッファ880のイメージ800が示されている。ホスト10内のメモリ60にアクセスするのに使用される、アドレスの物理マッピング810も示されている。仮想ポインタが、バッファ内の位置を820ポイントする。この例のバッファは、ホスト10のメモリ60内の少数の連続しないページ840から870を占める仮想バッファである。LCPエンジン310および360は、変換テーブル830を介してアドレスを変換することによってマッピングを実行する。変換テーブルは、仮想バッファ880からマッピングされる各物理バッファ840から870の先頭への物理アドレス・ポインタを保持する。アダプタ80内でのアドレス・マッピングによって、ホスト10のメモリ60内で記述子およびデータ・バッファをマッピングする時の柔軟性が可能になる。アダプタ80内でのアドレス・マッピングによって、ホスト10のソフトウェアが物理アドレスへのアドレス変換を実行することを必要とせずに、仮想アドレスを使用するソフトウェア・バッファへの直接接続も可能になる。
アダプタ80がホストのメモリ60に書き込む各パケットは、それに関連する状況を有する。状況を用いると、アダプタ80とホスト10のソフトウェアの間の同期化が可能になる。状況は、パケットの異なる信頼性レベルを示すのに使用することができる。ISOC120は、下記の状況ライト・バックを提供する:送信DMA完了は、TXパケット内のデータがアダプタ80に読み込まれたことを示し;信頼される送信は、ネットワーク30でのデータ送信の完了を示すために返され;受信DMA完了は、メモリ60への受信データ転送の完了を示し;信頼される受信は、ネットワーク30内の宛先ノードによる送信パケットの受信を示す。
TXフレーム記述子には、2バイトの状況フィールドが含まれる。状況ライト・バックは、トランザクション状態が記述子にライト・バックされることを意味する。状況には、ホスト10のソフトウェアがポーリングできる完了ビットが含まれる。ホスト10のソフトウェアは、セットされた完了ビットを見つけた時に、そのフレーム記述子によって定義されるフレームに関連するバッファを再利用することができる。
完了キューは、RX LCPチャネルによって実施される。完了キューによって使用されるLCPチャネルは、どのRX LCPチャネルによっても実施することができる柔軟性および特性のすべてを有する。TXプロセッサ150およびRXプロセッサ160は、状況ライト・バックを生成して、信頼される送信、信頼される受信、受信DMA完了、または送信DMA完了を示す。フレームに関連する異なる指示を、異なる場合に使用することができる。たとえば、信頼される送信の場合に、TXプロセッサ150は、パケット送信の状況を示す内部レジスタを読み取る。信頼される受信の場合に、RXプロセッサ160が、肯定応答を含む受信されたパケットとして完了指示を得る。受信DMA完了の場合に、RXプロセッサ160が、フレーム完了情報を使用する。送信DMA完了の場合に、TXプロセッサ150が、アダプタ80での送信用フレームの受信を示す。完了キューは、単一のTX LCPチャネルまたは単一のRX LCPチャネルによって使用することができ、あるいは、複数のチャネルによって共用することができる。アダプタ80のマイクロ・コードが、RX LCPエンジン360のコマンド・キューへのフレーム記述子を開始することによって、状況キューを更新する。図12を参照すると、状況は、完了キュー920を含む完了状況LCP900を介してホスト10のメモリ60に転送される。完了キュー920は、連続し(物理的にまたは仮想的にのいずれか)、ホスト10のメモリ60内に配置される。たとえば、完了キューを、連続するバッファ内に保持することができる。完了キューの項目930は、固定されたサイズを有することが好ましい。各項目が、受信LCP910に関連するバッファ950の先頭へのポインタ940を保持する。バッファ950には、完了状況に関連するパケット960が書き込まれる。
TXソフトウェア/アダプタ・ハンドシェークに、TX LCPポートよび完了RX LCPポートが含まれる。各LCP送信チャネルでは、下記のデータ構造が使用される。
メモリ・マップされたアドレスとして実施され、記述子およびデータを処理する増分要求についてアダプタ80に知らせる、ドアベル項目。各プロセスは、ドアベル・アクセスに使用されるメモリ・マッピングされたアドレスの単一のページへの一意のアクセスを有する。
LCP属性フィールドおよび状況フィールドを含む、アダプタ・メモリ空間210内のLCPコンテキスト項目。
送信記述子の構造。この構造は、ホスト10のメモリ60内の複数の物理ページにまたがることができる。仮想アドレッシングが、記述子について使用される場合に、変換テーブルを使用して、あるページから次のページに移動する。物理アドレッシングが、記述子について使用される場合に、分岐記述子が、あるページから次のページへの移動に使用される。送信記述子には、アダプタ80への記述子関連データのすべての転送の後に更新することができる状況フィールドが含まれる。
ポインタ記述子によってポイントされる、ホスト10のメモリ60内でピン止めされた送信データ・バッファ。仮想アドレッシングが、データ・バッファについて使用される場合に、変換テーブルによって、ポインタが、アダプタ80によってホスト10のメモリ60にアクセスするのに使用される物理アドレスに変換される。
アダプタ・メモリ空間210内の変換テーブルおよび保護ブロックが、アドレス・マッピングに使用される。
図13を参照すると、送信パケットのフローに、ステップ1000で、ホスト10のソフトウェア1020が、送信されるデータをバッファ1030に書き込むことが含まれる。ステップ1010で、ソフトウェア1020が、記述子1040を更新する。記述子1040は、ホスト10のメモリ60内またはアダプタ80のメモリ・サブシステム210内のいずれかとすることができる。ステップ1050で、ソフトウェア1020が、ドアベルを鳴らして、新しいデータの送信の準備ができていることをアダプタ80に通知する。ステップ1060で、アダプタ80が、異なるLCPチャネルからの要求の間の調停を管理する。あるチャネルが調停に勝った時に、アダプタ80が、新しい記述子1040を読み取る。ステップ1070で、アダプタ80が、データを読み取る。ステップ1080で、データが、ネットワーク30に送信される。ステップ1090で、状況が、記述子1040内または完了キュー内で更新される。
TX LCPチャネルでは、データ・バッファにアクセスする時にアドレス変換を使用することができる。この場合に、データ・バッファは、複数のメモリ・ページからなる。この処理に関する限り、これらのメモリ・ページは、連続する仮想メモリ空間内にある。しかし、アダプタ80に関する限り、これらのメモリ・ページは、連続しない物理メモリ空間内にある場合がある。完了状況構造に、送信されたフレームの状況を示す情報が含まれる。これは、別々のLCPチャネルとして実施される。すべてのフレームの最初の記述子であるフレーム記述子は、フレームがアダプタ80に転送された後に更新することができる任意選択の状況フィールドを有する。
図14を参照すると、送信LCPチャネル・フローの例で、記述子1100が、ホスト10のメモリ60に配置される。記述子1100およびパケット1120を保管するバッファ1110へのアクセスは、アダプタ80に配置される変換テーブル1130を介するアドレス変換を必要とする。バッファ1110によって、ホスト10のソフトウェアの仮想アドレス空間内の連続するスペースが使用される。各フレーム1120は、2タイプの記述子すなわち、パケットに関係する情報を与えるフレーム記述子1140と、データ1120を保持するバッファ1110をポイントするポインタ記述子1150とによって記述される。各パケットに、データ・ペイロード1170と、同一のバッファ1180でそれに先行するヘッダ1160が含まれる。
ドアベルへの書込トランザクション1190によって、アダプタ80による使用に使用可能なワード数1200が更新される。この情報は、LCPコンテキスト140に保管される。送信LCPコンテキスト140には、送信されるデータを保持するバッファ1110の先頭へのポインタ1210が含まれる。LCPチャネルが、ISOC120の内部調停に勝つ時に、ISOC120は、LCPコンテキスト140内のポインタ1210に従ってLCPチャネルの記述子を読み取る。LCPチャネルの記述子1100およびバッファ1110の両方に関する仮想アドレスは、アダプタ80のメモリ・サブシステム210内に配置される変換テーブル1130を使用して物理アドレスに変換される。変換テーブル1130は、メモリ・バッファの登録中にLCPマネージャ130によって更新される。ISOC120は、データおよびフレーム・ヘッダをバッファ1110からアダプタ80へ読み取る。フレーム・ヘッダ1160が、ISOC上でネットワーク30のヘッダに置換される1320。パケット・ヘッダおよび対応するデータが、ネットワーク30に送信される。
RX LCPポートは、着信データをISOC120からホスト10で稼動するソフトウェア・アプリケーションによって使用されるメモリ60に転送するのに使用される。TX LCPチャネルは、完全に、ホスト10のソフトウェアによって開始される記述子を介して制御される。RX LCPチャネルでは、ホスト10のソフトウェアおよびISOC120の両方からの記述子が使用される。ISOC120によって開始される記述子は、LCPチャネル動作を制御して、ホスト10のメモリ60内の受信されたフレームの宛先を定義するのに使用される。ホスト10のソフトウェアによって開始される記述子は、バッファが変換テーブル内のマッピングを介して定義されない場合に、バッファの位置を定義するのに使用することができる。ホスト10のソフトウェアとアダプタ80の間のハンドシェークを実施するために、2つのLCPチャネルすなわち、受信された着信データ構造を扱うRX LCPチャネルと、完了状況キューを扱うRX LCPチャネルが使用されることが好ましい。この完了状況は、アダプタ80が、ホスト10のソフトウェアに、ホスト10のメモリ60へのフレーム転送が完了したことをシグナリングするのに使用される。項目が、完了キュー構造の順次アドレスに挿入される。完了状況項目のそれぞれに、アダプタ80によってマークされ、項目所有権がアダプタ80からホスト10のソフトウェアに転送されたことを検査するためにホスト10のソフトウェアによってポーリングされるフィールドが含まれる。1つまたは複数のRX LCPチャネルが、同一の完了状況キューを使用することができる。複数のRX LCPチャネルによる完了状況キューの共用は、ISOC120によって実行される。
RX LCPチャネルは、着信パケットの宛先アドレスを示す情報を必要とする。ISOC120は、空きバッファの位置を見つけるための下記の2つのアドレッシングを有する。
直接アドレッシング・モードは、バッファをポイントするのにポインタ記述子を使用しないLCPチャネルを指す。宛先アドレスは、ISOC120のマイクロコードによって定義されるか、コンテキスト140から読み取られる。
間接アドレッシング・モードは、記述子構造内でデータ・バッファへのポインタを維持するLCPチャネルを指す。記述子は、ホスト10のメモリ60内に配置されることが好ましい。
直接アドレッシングでは、アダプタ80を介する着信パケットの処理の待ち時間が、実質的に短縮される。しかし、直接アドレッシングでは、アダプタ80での仮想アドレスから物理アドレスへの変換情報の保管を含めて、LCPマネージャ130によるメモリ・バッファの登録が必要である。ホスト10のソフトウェアは、チャネル・ドアベルに書き込んで、チャネルによって使用可能な空きバッファに追加されるワード数を示す。直接モードでは、下記のステップを使用して、宛先バッファのアドレスを判定する。
A.アドレスAが、LCPエンジンへのコマンドとして駆動される。
B.(任意選択)アドレスAをアドレスA’にマッピングする。
C.アドレスA’(ステップBが実行される場合)またはA(ステップBが実行されない場合)が、宛先バッファの基底アドレスになる。
間接モードでは、アダプタ80が、記述子を使用して、データ・バッファのアドレスを見つける。記述子は、ホスト10のソフトウェアによって管理される。記述子は、ホスト10のメモリ60に配置されることが好ましい。用語「間接」は、アダプタ80が、宛先アドレスを定義するために追加情報を読み取ることを強調するのに使用される。アダプタ80は、実行時中にこの情報にアクセスする。間接アドレッシングでは、変換テーブルを保管するのに必要なアダプタ80のメモリの量が削減される。記述子は、通常は、ホスト10のメモリ60に配置される。間接モードでは、宛先バッファのアドレスを判定するのに、下記のステップが使用される。
A.アドレスAが、LCPエンジンに対するコマンドとして駆動される。
B.(任意選択)アドレスAをアドレスA’にマッピングする。
C.アドレスA’(ステップBが実行される場合)またはA(ステップBが実行されない場合)が、ポインタ記述子のアドレスになる。
D.バッファへのポインタすなわちアドレスBを、記述子から読み取る。
E.(任意選択)アドレスBをアドレスB’にマッピングする。
F.アドレスB’(ステップEが実行される場合)またはB(ステップEが実行されない場合)が、宛先バッファの基底アドレスになる。
各RX LCPチャネルでは、下記のデータ構造が使用される。
メモリ・マッピングされたアドレスとして実施される、ドアベルへのアクセスによって、追加データについてまたはアダプタ80がパケット・データを書き込むのに使用可能な記述子について、アダプタ80が知らされる。
アダプタ80のメモリ・サブシステム210内のLCPコンテキスト項目に、LCP属性、状況、構成、および状況フィールドが含まれる。
間接モードで使用されるメモリ・バッファをポイントする記述子。
ホスト10のメモリ60内の連続する仮想アドレス空間内のバッファ。
アドレス・マッピング用の、アダプタ80のメモリ空間210内の変換テーブルおよび保護ブロック。
パケットの受信のフローは、下記の特性に依存する。
直接または間接の、アドレッシング・モード。
間接モードについて、記述子がホスト10のメモリ60内に配置される。
直接モードについて、アドレス・マッピングを、記述子へのアクセス中に使用してもしなくてもよい。
アドレス・マッピングを、バッファへのアクセス中に使用してもしなくてもよい。
間接モードについて、アドレス保護を、記述子へのアクセス中に使用してもしなくてもよい。
アドレス保護を、バッファへのアクセス中に使用してもしなくてもよい。
これらの特性は、LCPチャネルごとに、LCPチャネル初期化中にチャネルのコンテキスト140の一部としてセットされる。
図15を参照すると、パケット受信のフローに、ステップ1300での、受信されたデータ用の空きバッファ1320の、ホスト10内のソフトウェア1310による準備が含まれる。ステップ1330で、間接モードで、ホスト10のソフトウェア1310が、記述子1340を更新する。記述子1340は、ホスト10のメモリ60に配置される。ステップ1350で、ホスト10のソフトウェアが、ドアベルを鳴らして、空きバッファ空間についてアダプタ80に通知する。間接モードでは、ドアベルが、新しい記述子1340を示す情報を提供する。直接モードでは、ドアベルが、追加された空きバッファ空間を示す情報を提供する。この段階で、アダプタ80は、ネットワーク30からホスト10のメモリ60に受信データを転送する準備ができている。ステップ1300、1330、および1350は、ホスト10のソフトウェア1310が、RX LCPチャネルに空きバッファ1320を追加する時に、必ず繰り返される。ISOC120は、受信されたパケットごとに下記のステップを繰り返す。ステップ1360で、アダプタ80が、データを受信する。ステップ1370で、間接モードで、アダプタ80が、空きデータ・バッファ1320の位置をポイントする記述子1340を読み取る。ステップ1380で、データおよびヘッダが、データ・バッファ1320に書き込まれる。ステップ1390で、状況が、完了キュー内で更新される。
図16を参照すると、受信LCPチャネル・フローの例で、ポインタ記述子が使用されない。さらに、変換テーブルが使用されない。データ・バッファ1400で、バッファ1400を使用するホスト10内のソフトウェアの物理アドレス空間の連続する空間が使用される。ヘッダおよびデータ・ペイロードの両方が、バッファ1400に書き込まれる。ドアベルへの書込トランザクション1410によって、アダプタ80による使用のために使用可能なデータ空間が更新される。この情報は、LCPコンテキスト140に保管される。受信/完了LCPコンテキスト140に、新しいデータ/完了項目の書込に使用される次/現在のアドレスへの、バッファ1400の先頭へのポインタ1420とオフセット1430が含まれる。アダプタ80は、パケットを受信する時に、次のパケット位置へのオフセット1430を増分し、使用可能なデータ空間を更新する。完了項目1440が、フレーム受信の完了時、フレーム・タイムアウト時、またはLCPクライアント100が知ることを必要とする他のフレーム・イベントについて、完了LCP1450に追加される。完了項目1440には、LCPデータ・バッファ1400内でフレームを突き止めるためにLCPクライアント100が必要とするすべての情報が含まれる。ホスト10のソフトウェアは、完了項目1440内のフィールドを使用して、完了項目1440の所有権を与えられていることを認識する。
ISOC120は、アダプタ80のメモリ・サブシステム210とホスト10のメモリ60の間でデータを移動するのにLCPチャネルを使用できるようにする。ホスト10のメモリ60からアダプタ80にデータを転送するために、送信チャネルが使用される。アダプタ80からホスト10のメモリ60にデータを転送するために、受信チャネルが使用される。データが、ホスト10のメモリ60からアダプタ80に転送される時に、フレーム記述子に、ISOC120のバス390での宛先アドレスが含まれる。このアドレスによって、フレーム・データ・ペイロードの宛先が定義される。パケット・ヘッダは、通常の形で転送される。これによって、ISOC120のメモリ空間へのテーブルおよびコードのロードが可能になる。ISOC120のメモリ空間からホスト10のメモリ60に受信チャネルを介してデータを転送するために、記述子が、RXプロセッサ160によって開始される。この記述子には、ホスト10のメモリ60での宛先アドレスとソース・アドレスの両方を示す情報が含まれる。
上で説明した本発明の好ましい実施形態では、アダプタ80が、バス・アーキテクチャ70を介してホスト・コンピュータ・システム10のCPU50およびメモリ60に接続される。しかし、本発明の他の実施形態では、アダプタ80を、バス・アーキテクチャ70とは独立にホスト・コンピュータ・システム10に統合することができる。たとえば、本発明の他の実施形態で、アダプタ80を、ホスト・メモリ60に接続されたメモリ・コントローラを介してホスト・システムに統合することができる。
さらに、上で説明した本発明の好ましい実施形態では、アダプタ80が、ホスト・コンピュータ・システム10に挿入されるプラグ可能アダプタ・カードの形で実施された。しかし、本発明の他の実施形態で、アダプタ80の異なる実施形態が可能であることを諒解されたい。たとえば、アダプタ80を、CPU50およびメモリ60と共に、ホスト・コンピュータ・システムのマザー・ボード上に配置することができる。
データ処理ネットワークの例のブロック図である。 データ処理ネットワークのネットワーク・インターフェース・アダプタ・カードのブロック図である。 データ・ネットワークのホスト・システムの例のブロック図である。 ネットワーク・アダプタ・カードのインテグレーテッド・システム・オン・ア・チップ(ISOC)の例のブロック図である。 ISOCのもう1つのブロック図である。 ISOCを通る情報のフローを示すISOCのブロック図である。 ISOCを通る論理送信パスのブロック図である。 ISOCを通る論理受信パスのブロック図である。 循環記述子テーブルのブロック図である。 記述子テーブルのリンクされた組のブロック図である。 仮想バッファおよびその物理的に対応するバッファのブロック図である。 完了キューのブロック図である。 ホストからネットワークへのデータの送信フローのブロック図である。 ホストからネットワークへのデータの送信フローのもう1つのブロック図である。 ネットワークからホストへのデータの受信フローのブロック図である。 ネットワークからホストへのデータの受信フローのもう1つのブロック図である。

Claims (4)

  1. 記述子により、メモリを介してホスト・コンピュータ・システムである第1のデータ処理システムが、前記ホスト・コンピュータ・システムとデータ通信ネットワークとでデータを通信するデータ通信インターフェースを含む第2のデータ処理システムからデータのフローを送信する装置であって、第1のデータ処理システムと前記装置はバス・アーキテクチャで接続され、第2のデータ処理システムと前記装置はデータ通信ネットワークにより接続される前記装置であって、
    モリ内と第2データ処理システムとの間で通信されるデータ・パケットを定義するフレーム記述子およびメモリ内の位置を識別するポインタ記述子を含む複数の記述子を生成する記述子ロジックと、
    前記第1および第2のデータ処理システムによるアクセスのために記述子ロジックによって生成された記述子を保管する記述子テーブルを前記メモリに含み、
    前記メモリから前記通信ネットワークへ転送するチャネルと、ネットワークから受信されたデータの前記メモリへ転送する受信チャネルと、
    前記記述子ロジックにより生成されるメモリ転送を開始し、、第1のデータ処理システムのメモリから前記装置へのメモリ転送を開始し、前記装置からのフレーム送信を前記データ通信ネットワークへ前記転送するチャネルで開始するための特定のコマンドとしての動作に関する情報と、受信チャネルに必要な動作の情報を保持する記述子と、1つまたは複数の送信フレームが実行の準備ができていることを前記通信ネットワークへ転送するチャネルに知らせるための制御ワードが書き込まれたドアベル・レジスタを含む装置。
  2. 記述子ロジックが、記述子テーブル内の別の記述子へのリンクを含む分岐記述子を生成する、請求項1に記載の装置。
  3. 記述子テーブルが、その中の分岐記述子を介して一緒に順次リンクされる複数の記述子リストを含む、請求項2に記載の装置。
  4. 記述子テーブルが、循環記述子リストを含む、請求項2に記載の装置。
JP2002561695A 2001-01-31 2001-01-31 メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置 Expired - Lifetime JP4755390B2 (ja)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/IB2001/000122 WO2002061592A1 (en) 2001-01-31 2001-01-31 Method and apparatus for controlling flow of data between data processing systems via a memory

Publications (2)

Publication Number Publication Date
JP2004523035A JP2004523035A (ja) 2004-07-29
JP4755390B2 true JP4755390B2 (ja) 2011-08-24

Family

ID=11004037

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2002561695A Expired - Lifetime JP4755390B2 (ja) 2001-01-31 2001-01-31 メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置

Country Status (10)

Country Link
US (1) US7320041B2 (ja)
EP (1) EP1358562B8 (ja)
JP (1) JP4755390B2 (ja)
KR (1) KR100773013B1 (ja)
CN (1) CN1307570C (ja)
CA (1) CA2432387A1 (ja)
CZ (1) CZ20032078A3 (ja)
HU (1) HUP0302879A3 (ja)
PL (1) PL362792A1 (ja)
WO (1) WO2002061592A1 (ja)

Families Citing this family (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002061593A1 (en) 2001-01-31 2002-08-08 International Business Machines Corporation Method and apparatus for controlling flow of data between data processing systems via a memory
JP4755390B2 (ja) 2001-01-31 2011-08-24 インターナショナル・ビジネス・マシーンズ・コーポレーション メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置
US20050078704A1 (en) * 2003-10-14 2005-04-14 International Business Machines Corporation Method and apparatus for translating data packets from one network protocol to another
US20060106853A1 (en) * 2004-11-17 2006-05-18 International Business Machines Corporation Allocation and Scaling of Descriptor Lists.
US7831749B2 (en) * 2005-02-03 2010-11-09 Solarflare Communications, Inc. Including descriptor queue empty events in completion events
US7414975B2 (en) * 2005-03-24 2008-08-19 Ixia Protocol stack
US7586936B2 (en) * 2005-04-01 2009-09-08 International Business Machines Corporation Host Ethernet adapter for networking offload in server environment
US7865624B1 (en) 2005-04-04 2011-01-04 Oracle America, Inc. Lookup mechanism based on link layer semantics
US7843926B1 (en) * 2005-04-05 2010-11-30 Oracle America, Inc. System for providing virtualization of network interfaces at various layers
US7561531B2 (en) * 2005-04-19 2009-07-14 Intel Corporation Apparatus and method having a virtual bridge to route data frames
US7710969B2 (en) * 2005-05-13 2010-05-04 Texas Instruments Incorporated Rapid I/O traffic system
US7639715B1 (en) * 2005-09-09 2009-12-29 Qlogic, Corporation Dedicated application interface for network systems
US7773630B2 (en) * 2005-11-12 2010-08-10 Liquid Computing Corportation High performance memory based communications interface
US7676192B1 (en) * 2005-12-21 2010-03-09 Radio Shack, Corp. Radio scanner programmed from frequency database and method
US7735099B1 (en) 2005-12-23 2010-06-08 Qlogic, Corporation Method and system for processing network data
US7764676B1 (en) * 2006-07-31 2010-07-27 Qlogic, Corporation Method and system for processing network information
US20080126600A1 (en) * 2006-08-31 2008-05-29 Freescale Semiconductor, Inc. Direct memory access device and methods
US7613887B1 (en) 2006-09-18 2009-11-03 Marvell International Ltd. System and method for managing a memory storage device
US8127113B1 (en) 2006-12-01 2012-02-28 Synopsys, Inc. Generating hardware accelerators and processor offloads
US8706987B1 (en) 2006-12-01 2014-04-22 Synopsys, Inc. Structured block transfer module, system architecture, and method for transferring
US8289966B1 (en) * 2006-12-01 2012-10-16 Synopsys, Inc. Packet ingress/egress block and system and method for receiving, transmitting, and managing packetized data
US8325633B2 (en) * 2007-04-26 2012-12-04 International Business Machines Corporation Remote direct memory access
US7889657B2 (en) * 2007-05-04 2011-02-15 International Business Machines Corporation Signaling completion of a message transfer from an origin compute node to a target compute node
US7948999B2 (en) * 2007-05-04 2011-05-24 International Business Machines Corporation Signaling completion of a message transfer from an origin compute node to a target compute node
US7890670B2 (en) * 2007-05-09 2011-02-15 International Business Machines Corporation Direct memory access transfer completion notification
US7779173B2 (en) * 2007-05-29 2010-08-17 International Business Machines Corporation Direct memory access transfer completion notification
US8037213B2 (en) 2007-05-30 2011-10-11 International Business Machines Corporation Replenishing data descriptors in a DMA injection FIFO buffer
US7765337B2 (en) * 2007-06-05 2010-07-27 International Business Machines Corporation Direct memory access transfer completion notification
US8018951B2 (en) 2007-07-12 2011-09-13 International Business Machines Corporation Pacing a data transfer operation between compute nodes on a parallel computer
US8478834B2 (en) * 2007-07-12 2013-07-02 International Business Machines Corporation Low latency, high bandwidth data communications between compute nodes in a parallel computer
US8959172B2 (en) * 2007-07-27 2015-02-17 International Business Machines Corporation Self-pacing direct memory access data transfer operations for compute nodes in a parallel computer
US20090031001A1 (en) * 2007-07-27 2009-01-29 Archer Charles J Repeating Direct Memory Access Data Transfer Operations for Compute Nodes in a Parallel Computer
US7890597B2 (en) * 2007-07-27 2011-02-15 International Business Machines Corporation Direct memory access transfer completion notification
GB2455347B (en) * 2007-12-07 2012-04-11 Virtensys Ltd Control path I/O virtualisation
US9009350B2 (en) * 2008-04-01 2015-04-14 International Business Machines Corporation Determining a path for network traffic between nodes in a parallel computer
US9225545B2 (en) * 2008-04-01 2015-12-29 International Business Machines Corporation Determining a path for network traffic between nodes in a parallel computer
US8214614B2 (en) * 2008-10-24 2012-07-03 Microsoft Corporation Avoiding information disclosure when direct mapping non-page aligned buffers
US8811411B2 (en) * 2008-12-24 2014-08-19 Entropic Communications, Inc. Packet aggregation and fragmentation at layer-2 over a managed network
US8943507B2 (en) * 2009-04-27 2015-01-27 Deepak Mital Packet assembly module for multi-core, multi-thread network processors
US9444757B2 (en) 2009-04-27 2016-09-13 Intel Corporation Dynamic configuration of processing modules in a network communications processor architecture
US9461930B2 (en) 2009-04-27 2016-10-04 Intel Corporation Modifying data streams without reordering in a multi-thread, multi-flow network processor
US9037810B2 (en) * 2010-03-02 2015-05-19 Marvell Israel (M.I.S.L.) Ltd. Pre-fetching of data packets
US8544026B2 (en) 2010-02-09 2013-09-24 International Business Machines Corporation Processing data communications messages with input/output control blocks
JP5153843B2 (ja) * 2010-09-10 2013-02-27 シャープ株式会社 サーバ装置、メールサーバ装置、及びfaxサーバ装置
US8949453B2 (en) 2010-11-30 2015-02-03 International Business Machines Corporation Data communications in a parallel active messaging interface of a parallel computer
US8495265B2 (en) 2011-06-01 2013-07-23 International Business Machines Corporation Avoiding non-posted request deadlocks in devices by holding the sending of requests
US8903966B2 (en) * 2011-06-01 2014-12-02 International Business Machines Corporation Re-programming programmable hardware devices without system downtime
US8949328B2 (en) 2011-07-13 2015-02-03 International Business Machines Corporation Performing collective operations in a distributed processing system
US8930962B2 (en) 2012-02-22 2015-01-06 International Business Machines Corporation Processing unexpected messages at a compute node of a parallel computer
US8880756B1 (en) 2013-07-01 2014-11-04 Atmel Corporation Direct memory access controller
GB2524561A (en) * 2014-03-27 2015-09-30 St Microelectronics Res & Dev Methods and apparatus for storing content
CN104052676B (zh) * 2014-06-13 2017-12-05 华为技术有限公司 一种发送通路装置及发送通路的数据处理方法
US9817776B2 (en) * 2015-01-19 2017-11-14 Microsoft Technology Licensing, Llc Memory descriptor list caching and pipeline processing
CN112347003A (zh) * 2020-11-26 2021-02-09 北京泽石科技有限公司 一种高效的闪存颗粒微码控制方法
US11630668B1 (en) * 2021-11-18 2023-04-18 Nxp B.V. Processor with smart cache in place of register file for providing operands
TWI779938B (zh) * 2021-11-29 2022-10-01 瑞昱半導體股份有限公司 存取系統記憶體的方法及設置於網路卡上的處理電路

Family Cites Families (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0175398A3 (en) * 1984-08-17 1989-08-30 Koninklijke Philips Electronics N.V. Data processing system comprising a memory access controller which is provided for combining descriptor bits of different descriptors associated with virtual addresses
FR2665040B1 (fr) 1990-07-20 1994-08-05 Thomson Csf Procede et dispositif de pontage entre reseaux locaux.
US5359730A (en) * 1992-12-04 1994-10-25 International Business Machines Corporation Method of operating a data processing system having a dynamic software update facility
US5448702A (en) 1993-03-02 1995-09-05 International Business Machines Corporation Adapters with descriptor queue management capability
EP0712220A1 (en) * 1994-11-08 1996-05-15 International Business Machines Corporation Hop-by-hop flow control in an ATM network
US6002667A (en) * 1995-07-19 1999-12-14 Fujitsu Network Communications, Inc. Minimum guaranteed cell rate method and apparatus
US5751951A (en) * 1995-10-30 1998-05-12 Mitsubishi Electric Information Technology Center America, Inc. Network interface
US5933632A (en) 1995-12-21 1999-08-03 Intel Corporation Ring transitions for data chunks
US5805844A (en) 1996-10-07 1998-09-08 Gustin; Jay W. Control circuit for an interface between a PCI bus and a module bus
US6028843A (en) 1997-03-25 2000-02-22 International Business Machines Corporation Earliest deadline first communications cell scheduler and scheduling method for transmitting earliest deadline cells first
JP4086345B2 (ja) * 1997-09-09 2008-05-14 キヤノン株式会社 通信制御方法及び装置及び通信システム
US6226267B1 (en) * 1998-04-10 2001-05-01 Top Layer Networks, Inc. System and process for application-level flow connection of data processing networks
US6522188B1 (en) * 1998-04-10 2003-02-18 Top Layer Networks, Inc. High-speed data bus for network switching
US6570850B1 (en) * 1998-04-23 2003-05-27 Giganet, Inc. System and method for regulating message flow in a digital data network
US6466581B1 (en) * 1998-08-03 2002-10-15 Ati Technologies, Inc. Multistream data packet transfer apparatus and method
US6327615B1 (en) * 1998-09-30 2001-12-04 Stmicroelectronics, Inc. Method and system of controlling transfer of data by updating descriptors in descriptor rings
US6202107B1 (en) * 1998-11-19 2001-03-13 Sun Microsystems, Inc. Host controller interface descriptor fetching unit
JP3107077B2 (ja) * 1999-02-22 2000-11-06 住友電気工業株式会社 通信方法及び通信装置
US6324595B1 (en) * 1999-03-15 2001-11-27 Advanced Micro Devices, Inc. Dedication of space in descriptor for minimizing data processing during communications between a peripheral device and a host system
JP2000295281A (ja) * 1999-04-05 2000-10-20 Sumitomo Electric Ind Ltd マルチキャストパケットのフロー制御装置および方法
US6697330B1 (en) * 1999-11-26 2004-02-24 Hewlett-Packard Development Company L.P. Method and system for output flow control in network multiplexers
US6832273B2 (en) * 2000-12-21 2004-12-14 Microsoft Corporation System and method to specify extended configuration descriptor information in USB devices
US7058978B2 (en) * 2000-12-27 2006-06-06 Microsoft Corporation Security component for a computing device
WO2002061593A1 (en) * 2001-01-31 2002-08-08 International Business Machines Corporation Method and apparatus for controlling flow of data between data processing systems via a memory
JP4755390B2 (ja) 2001-01-31 2011-08-24 インターナショナル・ビジネス・マシーンズ・コーポレーション メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置

Also Published As

Publication number Publication date
HUP0302879A3 (en) 2004-08-30
US20040057380A1 (en) 2004-03-25
KR20030071857A (ko) 2003-09-06
KR100773013B1 (ko) 2007-11-05
EP1358562A1 (en) 2003-11-05
EP1358562B1 (en) 2011-11-16
CZ20032078A3 (cs) 2003-11-12
JP2004523035A (ja) 2004-07-29
WO2002061592A1 (en) 2002-08-08
US7320041B2 (en) 2008-01-15
EP1358562B8 (en) 2012-03-28
CN1307570C (zh) 2007-03-28
CA2432387A1 (en) 2002-08-08
PL362792A1 (en) 2004-11-02
CN1488105A (zh) 2004-04-07
HUP0302879A2 (hu) 2003-12-29

Similar Documents

Publication Publication Date Title
JP4755390B2 (ja) メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置
JP4755391B2 (ja) メモリを介してデータ処理システムの間でデータのフローを制御する方法および装置
JP4317365B2 (ja) 周辺デバイスからホスト・コンピュータ・システムに割込みを転送する方法および装置
US7076569B1 (en) Embedded channel adapter having transport layer configured for prioritizing selection of work descriptors based on respective virtual lane priorities
US6622193B1 (en) Method and apparatus for synchronizing interrupts in a message passing queue oriented bus system
US7126952B2 (en) Multiprotocol decapsulation/encapsulation control structure and packet protocol conversion method
US6611883B1 (en) Method and apparatus for implementing PCI DMA speculative prefetching in a message passing queue oriented bus system
US7181541B1 (en) Host-fabric adapter having hardware assist architecture and method of connecting a host system to a channel-based switched fabric in a data network
EP1374521A2 (en) Methodology and mechanism for remote key validation for ngio/infinibandtm applications
US20020049875A1 (en) Data communications interfaces
US20160055112A1 (en) Return available ppi credits command
US20020049878A1 (en) Data communications interfaces
US7266614B1 (en) Embedded channel adapter having link layer configured for concurrent retrieval of payload data during packet transmission
Liaaen et al. Dolphin SCI Adapter Cards.
Lindenstruth et al. 10. SCI Physical Layer API

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20060904

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20060912

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20061117

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20061127

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20070302

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20070731

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20071031

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20080422

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080821

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20080826

A912 Re-examination (zenchi) completed and case transferred to appeal board

Free format text: JAPANESE INTERMEDIATE CODE: A912

Effective date: 20081121

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20110214

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20110217

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20110315

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20110318

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20110412

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20110527

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20140603

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4755390

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

EXPY Cancellation because of completion of term