JPH09222987A - 共用データ構造体のバッファ内のデータの転送の方法およびシステム - Google Patents

共用データ構造体のバッファ内のデータの転送の方法およびシステム

Info

Publication number
JPH09222987A
JPH09222987A JP8195282A JP19528296A JPH09222987A JP H09222987 A JPH09222987 A JP H09222987A JP 8195282 A JP8195282 A JP 8195282A JP 19528296 A JP19528296 A JP 19528296A JP H09222987 A JPH09222987 A JP H09222987A
Authority
JP
Japan
Prior art keywords
buffer
mutex
data
ring
software
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
JP8195282A
Other languages
English (en)
Other versions
JP3762810B2 (ja
Inventor
Denny E Gentry
デントン・イー・ジェントリー
Prakash Kashyap
プラカシュ・カシュヤプ
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.)
Sun Microsystems Inc
Original Assignee
Sun Microsystems Inc
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 Sun Microsystems Inc filed Critical Sun Microsystems Inc
Publication of JPH09222987A publication Critical patent/JPH09222987A/ja
Application granted granted Critical
Publication of JP3762810B2 publication Critical patent/JP3762810B2/ja
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Classifications

    • 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/46Multiprogramming arrangements
    • G06F9/52Program synchronisation; Mutual exclusion, e.g. by means of semaphores

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Transfer Systems (AREA)
  • Exchange Systems With Centralized Control (AREA)
  • Storage Device Security (AREA)

Abstract

(57)【要約】 【課題】 メモリ内の共用データ構造体のデータ転送に
おけるハードウェアとソフトウェアの対話のための方法
および装置を提供する。 【解決の手段】 この方法および装置は、同じデータに
異なるソフトウェアがアクセスを試みるのを防ぐのに必
要なミューテックス・ロッキングの数を少なくし、バッ
ファ置換とパケット到着の間の衝突を防ぐために使用中
の各バッファの索引値を保持する。本発明の方法および
装置の一実施形態では、コンピュータ・システムの受信
ハードウェアが、使用中の各バッファの索引値を保持す
る。この索引値はミューテックスによって保護された完
了リングに入れられ、ミューテックスによって保護され
たソフトウェア・キューに入れられる。これらのミュー
テックスによって、所与の索引を所与の時点で1つのス
レッドのみが処理することが保証される。ソフトウェア
・アドレスおよび関連情報が入ったバッファ・テーブル
は、ミューテックス・ロッキングを必要としない。

Description

【発明の詳細な説明】
【0001】
【発明の属する技術分野】本発明は、コンピュータ・シ
ステムにおける共用データ構造体によるハードウェアと
ソフトウェアの対話の分野に関する。特に、本発明の方
法および装置は、システム全体のパフォーマンスを向上
させる、共用データ構造体のバッファ・アドレスの索引
付けに関する。
【0002】
【従来の技術】コンピュータに関するメモリとは、一般
に、命令を実行するために使用される処理装置内および
他の内部記憶装置内のアドレス可能記憶空間のすべてで
ある。コンピュータ・システムおよびその他の「インテ
リジェント」システムがホスト・メモリを備えることは
周知である。一般に、ホスト・メモリは、所定のアドレ
ス範囲内にある任意のバイト・サイズのいくつかのデー
タ・バッファを含む。これらのデータ・バッファは、所
定のアドレス範囲内で固有にアドレスされて、データへ
の選択的なアクセスを可能にし、それに続く処理または
送信を可能にする。データ・バッファはメモリ内のバッ
ファ・リングの一部として循環的な順序で配列すること
ができる。
【0003】図1に、多くのミューテックス・ロッキン
グを使用して共用データ構造体のデータ転送を管理する
従来技術の方法の実施例を示す。記述子リング100は
1つまたは複数のバッファ102を有することができ
る。バッファ・テーブル104によって、バッファ・ア
ドレスを含むバッファ情報がリストされる。完了リング
106も1つまたは複数のバッファを有することができ
る。
【0004】ミューテックス1(MUTEX_1)、
2、および3は、所与の時点に、同じ共用変数またはク
リティカル・セクションのグループの実行メンバーに、
1つの非同期プロシージャしかアクセスすることができ
ないようにするルーチンである。より明確には、ミュー
テックスとは相互排除の概念を指す。本明細書で使用す
る限りでは、ミューテックスとは、一度に1つのソフト
ウェア・アプリケーションだけが、記述子リングおよび
バッファ・テーブルにアクセスし使用すること、ができ
るようにするルーチンを指す。アプリケーションがミュ
ーテックス・ロックを獲得することができるようにミュ
ーテックスを自動的に獲得するルーチンもある。ミュー
テックス・ロックは、バッファ・テーブル内と記述子リ
ング内とを問わず同じ場所を異なるスレッドが選択しな
いようにする。
【0005】従来の方法および装置の実施例では、ソフ
トウェアは一般に、ハードウェアが使用できるようにい
くつかのバッファ・アドレスを記述子リング100にキ
ューイングする。ハードウェアは記述子リング100を
読み取ってバッファ・アドレスを取り出す。次に、ハー
ドウェアは記述子リング100に書き戻し、ビットをク
リアし、それによってハードウェアがそのバッファ・ア
ドレスをピックアップしたことをソフトウェアに知らせ
る。ハードウェアはパケットの処理を終了すると、その
記述子を完了リング106に入れる。
【0006】バッファA 102のアドレスAは、ハー
ドウェアがバッファA 102にアクセスするためと、
そのバッファにデータをDMA(ダイレクト・メモリ・
アクセス)によって送るために使用するアドレスであ
る。このアドレスは入出力バス上にのみ存在するため、
ソフトウェアはこのアドレスを使用することができな
い。したがって、ソフトウェアは、入出力アドレスおよ
び対応するカーネル・アドレスをリストしたバッファー
・テーブル104を使用して、必要なバッファ情報を指
すアドレスAを入手する。記述子リング100上にバッ
ファ・アドレスを置くために、ソフトウェアは記述子リ
ング100とバッファ・テーブル104をミューテック
ス・ロックして、記述子リング100およびバッファ・
テーブルの同じアドレスに他のソフトウェアが同時にア
クセスを試みることができないようにする。
【0007】ソフトウェアがバッファ・テーブル104
を更新し、記述子リング100上にバッファを置いた後
は、ソフトウェアは両方のミューテックスを放棄する。
その後、ハードウェアはそのバッファをピックアップし
て、必要なデータをその中にDMAし、完了リング10
6上に置き、割込みを開始することができる。次にソフ
トウェアは完了リング106のミューテックス3と、再
びバッファ・テーブル104のミューテックス2を獲得
する。ソフトウェアが完了リング106からバッファA
102を取り出して、バッファ・テーブル104内の
バッファAアドレスを探索(サーチ)し、バッファ・テ
ーブル104から必要な情報を取り出し、バッファ内の
データを所望により処理する。
【0008】したがって、従来の方法および装置は、共
用データ構造体にアクセスを試みるいくつかの実行スレ
ッドを有することができるマルチスレッド装置ドライバ
を使用する。競合を避けるために、ミューテックスによ
って共有データ構造体を保護し、スレッド・アクセスを
逐次化する。この従来の方法および装置の欠点は、逐次
化によって全体的なシステム・パフォーマンスが損なわ
れることである。言い換えると、従来の方法および装置
を使用すると、ソフトウェア・アプリケーションは、ハ
ードウェアが使用するように記述子リング上にバッファ
を置くために、記述子リングのミューテックスを獲得し
なければならず、バッファ・テーブルのためのもう1つ
のミューテックスを獲得しなければならない。
【0009】図2は、図1に図示するようなリングおよ
びバッファ・テーブルを必要とするデータ・パケット転
送のための従来の方法および装置がたどる一般的なステ
ップを示す流れ図である。ステップ201で、ソフトウ
ェア・アプリケーションがミューテックス1およびミュ
ーテックス2を獲得する。ミューテックスは、ミューテ
ックス・ロッキングが行われて、たとえば記述子リング
またはバッファ・テーブルへのアクセスが1つのソフト
ウェア・アプリケーションのみに制限されたときに「獲
得」される。ステップ202で、ソフトウェアはバッフ
ァAの情報によってバッファ・テーブルを更新し、バッ
ファAを記述子リング上に置く。
【0010】ステップ203で、データ・パケットがメ
ディアに到着する。ステップ204で、コンピュータ・
システムの回路内部にある制御RAMなどのハードウェ
アがそのデータ・パケットをバッファAにDMAし、A
を完了リング上に置く。ステップ205で、ソフトウェ
アがミューテックス2およびミューテックス3を獲得す
る。ステップ206で、ソフトウェアは、バッファ・テ
ーブルでバッファAを検索するために、バッファ・テー
ブルをハッシュする。
【0011】従来の技術の方法および装置には多くの欠
点がある。たとえば、バッファをキューイングするため
に、ソフトウェアはニューテックス1とミューテックス
2を必要とする。バッファを解放するために、ソフトウ
ェアはミューテックス2とミューテックス3を必要とす
る。したがって、1つの欠点は2つの操作によってミュ
ーテックス2に関して競合が生じ、それによって全体的
なシステム・パフォーマンスが制限されることである。
第2の欠点は、特定のバッファAがバッファ・テーブル
内のどこにあってもよいことである。したがって、ハッ
シュしてバッファAを探索(サーチ)する必要がある。
第3に、ハッシュするとき、「ヒット」を見つける必要
があることである。たとえば、Aをバッファ・テーブル
にハッシュするために、Aをバッファ・テーブルに格納
してヒットを見つけなければならない。したがって、従
来の方法および装置は、バッファ・テーブルにAを格納
するために、この追加のメモリ空間が必要である。
【0012】
【発明が解決しようとする課題】したがって、共有デー
タ構造体のデータ転送操作を行う際に生じる衝突を防止
し、全体的なシステム・パフォーマンスを向上させる方
法および装置があることが望ましい。
【0013】
【課題を解決するための手段】メモリ内の共有データ構
造体のデータ転送におけるハードウェアとソフトウェア
の対話のための方法および装置を開示する。
【0014】特に、本発明の方法および装置は、同じデ
ータへのアクセスを試みる異なるソフトウェア間の衝突
を防ぐのに必要なミューテックス・ロッキングの数を減
らし、バッファ置換とパケット到着の間の衝突を防ぐた
めに、使用中の各バッファの索引値を保持する。
【0015】本発明の方法および装置の実施例では、コ
ンピュータ・システムの受信ハードウェアが使用中の各
バッファの索引値を保持する。この索引値はミューテッ
クスによって保護された完了リングに入れられ、ミュー
テックスによって保護されたソフトウェア・キューに入
れられる。ミューテックスにより、所与の時点で所与の
索引を1つのスレッドのみが保有するように保証され
る。
【0016】本発明を使用すると、ソフトウェア・アド
レスおよび関連情報が入ったバッファー・テーブルのミ
ューテックス・ロッキングが不要である。これは、バッ
ファ置換とパケット到着との間の衝突を防ぐために、使
用中の各バッファの索引値をハードウェアが保持するか
らである。さらに、バッファの索引値によって、ハッシ
ングと探索(サーチ)が不要なため、バッファ・テーブ
ル内のソフトウェア・アドレスおよび関連情報の参照を
迅速化することができる。さらに、本発明はソフトウェ
ア・アドレスおよび関連情報をバッファ・テーブルから
検索するためにバッファ・メモリに入出力アドレスを格
納する必要がない。したがって、本発明の方法および装
置は従来の技術よりメモリ使用量が少なく、また、本発
明によってミューテックス・ロッキングの必要数が少な
くなり、共有データ構造体に係わるデータ転送操作中の
バッファ・テーブルのハッシングと探索が不要になる。
【0017】
【発明の実施の形態】本発明の特徴と利点は、以下の本
発明の詳細な説明から明らかになろう。
【0018】バッファ置換とパケット到着の間の衝突を
防ぐために、ハードウェアが使用中の各バッファの索引
値を保持しておくメモリ内の共有データ構造体に関する
方法および装置を開示する。
【0019】図3に、本発明のデータ転送調整の方法お
よび装置を使用するATM(非同期転送方式)ネットワ
ーク・インタフェース回路を組み込んだコンピュータ・
システム・ネットワークの例を示す。このコンピュータ
・システム・ネットワーク10は、ATMの、1つまた
は複数のネットワーク・インタフェース回路(NIC)
12を組み込んだホスト・コンピュータ・システム(図
示せず)を含む。NIC 12は、ローカルATM交換
機14を介して公衆ATM交換機16に結合され、ネッ
トワーク10に結合されたホスト・コンピュータ・シス
テム間でのデータの非同期通信を可能にする。あるい
は、NIC12は公衆ATM交換機16に直接結合する
こともできる。図3に示すように、このコンピュータ・
システム・ネットワーク10は、ATMネットワークを
サポート・フレームワークとして使用するイーサネット
またはトークン・リング・ネットワーク17などの他の
ネットワークを接続する、ゲートウェイとして機能する
ローカル・エリア・ネットワーク(LAN)エミュレー
ション15の使用を組み込んだコンピュータ・システム
も含むことができる。
【0020】図4は、図3のATM NIC 12のア
ーキテクチャを示す略システム図である。ATM NI
C 12は、このATM NIC 12は、システム・
バス38を介して結合されているホスト・コンピュータ
・システムを、ATMプロトコルに従って動作するネッ
トワーク媒体40とインタフェースさせる。
【0021】図4のATM NIC 12は、システム
・バス・インタフェース20、汎用入出力(GIO)イ
ンタフェース24、システムおよびATM層コア22、
ローカル・スレーブ・インタフェース26、1アレイの
送信(TX)FIFO 28、1アレイの受信(RX)
FIFO 30、媒体インタフェース32、外部バッフ
ァ・メモリ・インタフェース34、およびクロック合成
回路36を備える。
【0022】NIC 12のこれらの要素20〜36が
組み合わさって協調動作し、ホスト・コンピュータ48
とネットワーク内の他のコンピュータの間で、複数の帯
域幅グループの複数の動的に割り振られたチャネルを介
してデータを非同期的に転送する。ネットワーク・イン
タフェース回路12の要素は集合的に、ホスト・コンピ
ュータ・システムのシステム・バス38に結合された多
重チャネル・インテリジェント・ダイレクト・メモリ・
アクセス(DMA)コントローラとして機能する。好ま
しい実施形態では、複数の送受信チャネルが、全二重1
55/622Mbps物理リンクを使用する仮想接続と
して処理される。システム・バス38を経由して外部バ
ッファ・メモリ・インタフェース34を介して外部バッ
ファ・メモリ42まで様々なチャネルに加入するデータ
の複数のパケットが、システムおよびATM層コア22
によって送信セルにセグメント化され、媒体インタフェ
ース32を介して媒体40に送信される。
【0023】外部バッファ・メモリ42は、RXデータ
・バッファを含むRXバッファ・メモリ44を有する。
RXデータ・バッファは主として着信セルをバッファリ
ングするために使用される。一実施例では、バッファ・
メモリの一部を1024本の受信チャネルの情報を保持
するためにも使用し、そのうちの128本をNIC12
内部でキャッシュする。データ・バッファ・メモリは、
48バイトのバケットの集まりとして編成される。各バ
ケットにはATMセルのペイロードが入る。データ・バ
ッファ・メモリは、その48バイト・バケットが様々な
チャネルの着信セルに動的に割り当てられる共有メモリ
・プールである。動的バケット割振りによって、チャネ
ルにそれぞれの必要に応じて空きバケットが割り当てら
れ、メモリが十分に使用される。極端な場合には、1本
のチャネルがメモリ・プール内のすべてバケットを占有
することができ、あるいは、完全に近いインタリーブ・
セルを使用してバケットを多くのチャネルに割り当てる
ことができる。
【0024】コア22は、受信パケットの再組立てを容
易にする再組立てロジックも含む。TX FIFO 2
8およびRX FIFO 30はコア22と媒体インタ
フェース32との間に結合され、それぞれ送信パケット
と受信パケットの送信セル・ペイロードと受信セル・ペ
イロードをステージングするために使用される。媒体イ
ンタフェース32は、クロック合成回路36によって供
給されるクロック信号によって駆動され、ネットワーク
の媒体40との間でセルを送受信する。この媒体と媒体
インタフェース32は、ATMフォーラム特別仕様に記
載されているUniversal Test and
Operations Physical Inter
face for ATM(UTOPIA)標準に準拠
していることが好ましい。UTOPIA仕様に準拠する
ために、クロック合成回路36は20MHzまたは40
MHzのクロック信号を供給して媒体インタフェース3
2をイネーブルし、155Mbpsの場合、20MHz
で1バイト・ストリーム、622Mbpsデータ・スト
リームの場合、40MHzで16ビット・ストリームを
サポートする。
【0025】この実施形態では、媒体インタフェース3
2は、TX FIFO 28からそれぞれ4バイトのセ
ル・ヘッダと48バイトのペイロードを有する52バイ
トのデータ・セルを受信する。媒体インタフェース32
は、媒体40に53バイトのデータ・セルを供給する前
に、各セルにセル・ヘッダに続く5番目のバイトとして
チェックサムを挿入する。逆に、媒体インタフェース3
2が媒体40からセルを受信するときは、各セルの5番
目のバイトに入っているチェックサムを検査して、チェ
ックサムが正しいかどうかを判断する。正しい場合、チ
ェックサムを表すバイトをセルから除去してそのセルを
RX FIFO 30に転送する。正しくない場合はセ
ル全体を廃棄する。
【0026】ネットワーク・インタフェース回路12
は、ホスト・コンピュータ・システム上で稼動している
アプリケーションから非同期転送のセル記述詳細を遮蔽
もする。この実施例では、ホスト・コンピュータ・シス
テム上で稼動しているアプリケーションは、パケット・
インタフェースとともに循環送受信リングを使用してデ
ータの送受信を管理する。しかし、本発明は、他のデー
タ構造体を使用してデータの送受信を管理するホスト・
コンピュータ・システム上で稼動するアプリケーション
とともに実施することもできる。
【0027】システム・バス・インタフェース20と汎
用入出力インタフェース24は、媒体40への転送の詳
細からホスト・コンピュータ・システムを遮蔽する。更
に、コア22はシステム38バスおよびホスト・データ
構造体の詳細から遮蔽されている。好ましい実施形態で
はシステム・バスは、電気電子学会(IEEE)標準1
496仕様で規定されているSバスである。システム・
バス・インタフェース20は、この好ましい実施形態で
はSバスである、システム・バスの仕様に従って通信す
るように構成される。
【0028】システム・バス・インタフェース20は、
異なるホスト・コンピュータ・システム・バスに準拠す
るように構成可能であることが企図される。また、シス
テム・バス・インタフェース20は、汎用入出力インタ
フェース24によって指定されたプロトコルに従ってデ
ータを送受信するようにも構成される。汎用入出力イン
タフェース24は、コア22がホスト・コンピュータと
通信するための単一のインタフェースを提供する。した
がって、コア22は、様々なホスト・コンピュータ・シ
ステムおよびバスとインタフェースするNIC 12の
様々な実施態様について変わらない。
【0029】共用データ構造体のデータ転送のための本
発明の方法および装置の実施態様は、ホスト・メモリ5
0に記憶されている共用データ構造体に適用することが
できる。ホスト・メモリ50はシステム・バス38に結
合されている。記述子リング52と完了リング54は両
方ともホスト・メモリ50に入っている。データには、
ホスト・メモリ50からネットワーク・インタフェース
回路12に直接メモリ・アクセスすることができる。ネ
ットワーク・インタフェース回路12が媒体40からの
パケットの受信を開始すると、パケットが媒体インタフ
ェース32を通り、システム・コア22を通って、外部
バッファ・メモリ42に流れる。パケットは次に、シス
テム・コア22を介してネットワーク・インタフェース
回路12に送り戻され、ホスト・メモリ50に入れられ
る。ハードウェアは、受信パケットに対して確認応答
し、記述子リング52から読み取る。ハードウェアはD
MA状態を入手すると、パケットに入ったデータをバッ
ファ56に入れ、DMA状態を完了リング54に置く。
このプロセスの詳細は以下で述べる。
【0030】図5は、データ受信に使用するホスト・メ
モリの好ましいデータ構造の概要図である。ホスト・メ
モリは受信(RX)空きターゲット(ユーザ・データ)
データ記述子リング580a〜580mと、RX空き非
ターゲット(カーネル)記述子リング581と、RX完
了リング590とを備える。
【0031】RX空きターゲット(ユーザ・データ)デ
ータ記述子リング580a〜580mとRX空き非ター
ゲット(カーネル)記述子リング581は、2つの異な
るタイプのRX空きバッファ記述子リングである。各V
C(仮想回路)はこの2つのタイプのいずれか一方に加
入する。複数のVCが使用することができる共通の空き
バッファ・プールがある。2番目のタイプは、各VC専
用空きバッファ・プールを備える。共通空きバッファ・
プールに加入するVCを非ターゲットVCと呼び、各V
C専用空きバッファ・プールをターゲットVCと呼ぶ。
データとプロトコル・ヘッダの分割が、ターゲットと非
ターゲットの両方のVCによってサポートされる。ター
ゲットVCはバッファ・チェーン化特権を持つが、非タ
ーゲットVCは持たない。
【0032】RX空きターゲット(ユーザ・データ)記
述子リング580a〜580mは、ネットワーク・イン
タフェース回路(NIC)によってサポートされる通常
はデータ転送レートが異なる複数のチャネルと、RXデ
ータ・バッファとに対応する数のデータ構造体である。
各RXデータ記述子リング580a〜580mは、
「1」から「K」までの番号が付けられた複数個「K」
のリング項目585を含み、これらの項目にはソフトウ
ェアが順次に循環方式でアクセスする。値「K」は整数
であり、少なくとも64であることが好ましい。各リン
グ項目は、所望のデータ・パケットが入っているそれぞ
れのRXデータ・バッファ内の場所を指す少なくとも1
つのポインタを含む「データ記述子」を格納するのに十
分な大きさ(たとえば64バイト)である。したがっ
て、ターゲット・チャネルとしてプログラムされた各受
信チャネルは、それ自身の空きバッファ・リングを有す
ることになる。最高1,024本のターゲット接続のた
めに最高1,024個の空きバッファ・リングがあるこ
とになる。特定のチャネルが空きバッファを使い果た
し、パケットが到着した場合、ハードウェアは共通空き
バッファ・プールにアクセスして空きバッファを取り出
す。空きターゲット・データ・リングは記述子所有権を
示すために「OWN」ビットを使用する。
【0033】非ターゲット・チャネルとしてプログラム
された、主として多重受信チャネルのパケットを格納す
るための1つの共通RX空きデータ・リング581があ
る。非ターゲット・チャネルは通常、NFS(ネットワ
ーク・ファイル・システム)などのカーネル空間に宛て
られたパケットに使用される。RX空き非ターゲット記
述子リング581は、個別ターゲット・チャネル(ユー
ザ・アプリケーションに直接結びつけられたチャネル)
が空きバッファを使い果たしたときに、補助バッファ・
プールとしても使用することができる。一実施形態で
は、1つの記述子について2つのバッファ・ポインタ項
目がある。一方のバッファ・ポインタはプロトコル・ヘ
ッダを格納するために使用され、他方はパケットのデー
タ部分に使用される。ヘッダ・バッファとデータ・バッ
ファは、それぞれ2048バイトと64Kバイトに制限
されている。RX空き非ターゲット・データ・リング5
81は記述子所有権を示す「OWN」ビットを使用す
る。
【0034】RX完了リング590は、複数のリング項
目を有するデータ構造体であり、RXデータ記述子リン
グ580a〜580mとは異なり、ポインタには依存せ
ずにリング項目内に必要なすべての情報が含まれる。多
重チャネルの受信データ・パケットは、ターゲットと非
ターゲットの両方のVCについて単一のRX完了リング
590で報告される。好ましい実施形態では、RX完了
リング590は64バイト境界上の1,024個のリン
グ項目を通して64Kバイトのホスト・メモリを占有す
る。RX完了リング590には、ソフトウェアとハード
ウェアの両方がアクセス可能であり、NICがRX完了
リング590の所有権を持つと設定される各記述子内の
OWNビットを必要とする。
【0035】図6に共有データ構造体にアクセスするソ
フトウェアの必要ミューテックス数を少なくすることに
よってデータ転送における全体的システム・パフォーマ
ンスを向上させる方法および装置を示す。本発明の実施
形態では、記述子リング52は、索引P 606を持つ
バッファA 604の記述子602を有する。バッファ
A 604の索引606はPであり、バッファ・テーブ
ル608においてバッファAのアドレスをリストしたそ
れに対応する項目は、バッファA 604の記述子60
2によってポインタされる項目P内で見つけられる。ソ
フトウェアが記述子リング52上でバッファA 604
を使用可能にすると、ハードウェアはそのバッファを取
り出すことができる。ハードウェアが、たとえばバッフ
ァ604にパケットを挿入することによってバッファ6
04の使用を完了すると、ハードウェアはそのバッファ
を完了リング54上に置く。ソフトウェアがバッファ6
04を記述子リング52上に置くときは、ミューテック
ス1によって記述子リング52の同じアドレスに他のソ
フトウェア・アプリケーションがバッファを置かないよ
うにする。ここで言及するミューテックスとは、「従来
の技術」の項で説明したミューテックスと同じであるた
め、それ以上の説明は要しない。
【0036】記述子は、バッファA 604を指す索引
値606を有して、バッファ・テーブル608内のバッ
ファA 604の項目の正確な場所を示すため、バッフ
ァ・テーブル608に対するミューテックス・ロッキン
グは不要である。具体的には、バッファA 604のア
ドレス指定情報が入った項目の場所が索引Pによって示
されるため、バッファ・テーブル608をハッシュした
り探索したりする必要がない。さらに、ミューテックス
1のために、1つのソフトウェアだけが索引P606を
使用することが保証され、バッファ・テーブル608の
ミューテックス・ロッキングが不要である。
【0037】図7に本発明の実施に使用することができ
るポインタの例を示す。バッファ置換とパケット到着の
間の衝突を防ぐため、ワード700とワード704は両
方とも、バッファ・テーブル内のバッファの項目を示す
索引値を有する。例示するワード700は索引702を
有し、ワード704は索引702の残りの部分を有す
る。
【0038】図8は、本発明の実施形態においてたどる
一般的なステップを示す流れ図である。前の図6に図示
されている構成要素を参照しながら説明すると、ステッ
プ801でソフトウェアは記述子リング600をミュー
テックス・ロッキングするためにミューテックス1を獲
得する。ステップ802で、ソフトウェアはバッファ・
テーブル608の索引P 606の項目をバッファAの
情報で更新する。ステップ803で、ソフトウェアは、
バッファ・テーブル608内のバッファA 604情報
の場所を示す索引P 606を持つ記述子602を記述
子リング600に置く。
【0039】ステップ804で媒体40にパケットが到
着する。ステップ805で、ハードウェアがダイレクト
・メモリ・アクセスしてパケットをバッファA 604
に入れる。ステップ806で、ハードウェアはバッファ
A 604を指す記述子602に格納されている索引値
P 606を入念に保持する。ステップ807でソフト
ウェアがミューテックス・ロッキング完了リング610
からミューテックス3を獲得する。次にソフトウェア
は、ステップ808で完了リング610から索引P 6
06を検索(レトリーブ)し、バッファ・テーブル60
8内の場所Pに直接アクセスする。
【0040】本発明の方法および装置を使用すると、索
引606がソフトウェアによって「所有(OWN)」さ
れている限りバッファ・テーブル608のミューテック
ス・ロッキングが不要である。さらに、本発明によっ
て、従来の技術の方法および装置の場合のようなバッフ
ァ置換とパケット到着の衝突が起こらない。
【0041】以上、使用中の各バッファ値の索引値を保
持して、共用データ構造体のデータ転送中に必要なミュ
ーテックス・ロッキングの数を減らす方法および装置に
ついて説明した。
【0042】特定の実施形態について詳細に説明し、添
付図面に図示したが、このような実施形態は単に例示的
なものに過ぎず、広い本発明を限定するものではなく、
当業者なら他の様々な変更を思いつくと考えられるため
に本発明は図示および説明されている特定の構成および
構造には限定されないものと理解すべきである。
【0043】具体的には、本発明の方法および装置は図
3および図4に図示するATMを使用した実施態様には
限定されない。図に示されている特定の実施態様は例示
に過ぎない。本発明は共有データ構造体へのアクセス中
にミューテックス・ロッキングを必要とするどのような
フレームワークにおいても実施することができる。
【図面の簡単な説明】
【図1】従来の方法を示す図である。
【図2】共有データ構造体に関するデータ転送のための
従来の方法および装置がたどる一般的なステップを示す
流れ図である。
【図3】本発明を実施するために使用することができる
コンピュータ・システム・ネットワークの例を示す図で
ある。
【図4】図3のATM NIC 12のアーキテクチャ
を示す略システム図である。
【図5】データ送信に使用するホスト・メモリの好まし
いデータ構造体を示す概要図である。
【図6】必要なミューテックスの数を減らすことによっ
て、ハードウェアがバッファを使用することができるよ
うにするときの全体的パフォーマンスを向上させる方法
および装置を示す図である。
【図7】共有データ構造体を調整する方法および装置を
示す図である。
【図8】本発明の実施形態がたどる一般的ステップを示
す流れ図である。
【符号の説明】
10 コンピュータ・システム・ネットワーク 12 ATMネットワーク・インタフェース回路 14 ローカルATM交換機 16 公衆ATM交換機 22 システムおよびATM層コア 20 システム・バス・インタフェース 24 汎用入出力インタフェース 26 ローカル・スレーブ・インタフェース 28 送信FIFO 30 受信FIFO 32 媒体インタフェース 34 外部バッファ・メモリ・インタフェース 36 クロック合成回路 38 システム・バス 40 ネットワーク媒体 42 外部バッファ・メモリ 48 ホスト・コンピュータ・システム 50 ホスト・メモリ 52 RXデータ記述子リング 54 完了リング 56 バッファ 580 RXデータ記述子リング 581 RX空き非ターゲット記述子リング 590 RX完了リング 602 記述子 604 バッファ 606 索引 608 バッファ・テーブル 700 ワード 702 索引
───────────────────────────────────────────────────── フロントページの続き (72)発明者 プラカシュ・カシュヤプ アメリカ合衆国 94555 カリフォルニア 州・フレモント・レマー テラス・5898

Claims (2)

    【特許請求の範囲】
  1. 【請求項1】 共用データ構造体内のバッファ・テーブ
    ルに格納されたバッファ情報とカーネル・アドレスとを
    含むバッファ内のデータの転送の方法であって、 使用中の各バッファの索引値を前記共用データ構造体に
    保管するステップと、 前記索引値を使用してバッファ・テーブルに格納されて
    いる前記バッファのカーネル・アドレスを参照してソフ
    トウェアがアクセスすることができるようにするステッ
    プとを含む方法。
  2. 【請求項2】 共用データ構造体におけるデータ転送の
    ためのコンピュータ・システムにおいて、 ホスト・メモリであって、複数のバッファを保持する共
    用データ構造体と、 前記複数のバッファのうちの少なくとも1つのバッファ
    のカーネル・アドレスおよび関連情報を含むバッファ・
    テーブルと、前記バッファのカーネル・アドレスに対応
    する前記バッファ・テーブルの項目を指す索引値を備え
    る、前記複数のバッファのうちの1つであるバッファに
    対する記述子と、を有するホスト・メモリを備え;前記
    共用データ構造体におけるデータを処理するプロセッサ
    を備えている、コンピュータ・システム。
JP19528296A 1995-07-07 1996-07-08 共用データ構造体のバッファ内のデータの転送の方法およびシステム Expired - Lifetime JP3762810B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/499483 1995-07-07
US08/499,483 US5740448A (en) 1995-07-07 1995-07-07 Method and apparatus for exclusive access to shared data structures through index referenced buffers

Publications (2)

Publication Number Publication Date
JPH09222987A true JPH09222987A (ja) 1997-08-26
JP3762810B2 JP3762810B2 (ja) 2006-04-05

Family

ID=23985431

Family Applications (1)

Application Number Title Priority Date Filing Date
JP19528296A Expired - Lifetime JP3762810B2 (ja) 1995-07-07 1996-07-08 共用データ構造体のバッファ内のデータの転送の方法およびシステム

Country Status (4)

Country Link
US (1) US5740448A (ja)
EP (1) EP0752651A3 (ja)
JP (1) JP3762810B2 (ja)
SG (1) SG74564A1 (ja)

Families Citing this family (41)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5870628A (en) * 1996-06-11 1999-02-09 International Business Machines Corporation Adaptor for receiving and processing asynchronous transfer mode cells within a computer network
JP3139392B2 (ja) * 1996-10-11 2001-02-26 日本電気株式会社 並列処理システム
US5905889A (en) 1997-03-20 1999-05-18 International Business Machines Corporation Resource management system using next available integer from an integer pool and returning the integer thereto as the next available integer upon completion of use
US6154460A (en) * 1997-05-30 2000-11-28 Alcatel Usa Sourcing, L.P. Data packet transmission system and method
US6021446A (en) * 1997-07-11 2000-02-01 Sun Microsystems, Inc. Network device driver performing initial packet processing within high priority hardware interrupt service routine and then finishing processing within low priority software interrupt service routine
JPH1165969A (ja) * 1997-08-19 1999-03-09 Toshiba Corp サーバ装置および通信接続方法並びに通信の接続を行うプログラムを記録した記録媒体
US6065070A (en) * 1998-03-18 2000-05-16 National Semiconductor Corporation DMA configurable channel with memory width N and with steering logic comprising N multiplexors, each multiplexor having a single one-byte input and N one-byte outputs
US6526451B2 (en) * 1998-09-30 2003-02-25 Stmicroelectronics, Inc. Method and network device for creating circular queue structures in shared memory
US6898617B2 (en) * 1999-11-18 2005-05-24 International Business Machines Corporation Method, system and program products for managing thread pools of a computing environment to avoid deadlock situations by dynamically altering eligible thread pools
US6901357B1 (en) * 1999-12-14 2005-05-31 Microsoft Corporation System and method for simulating network connection characteristics
US7266490B2 (en) 2000-12-28 2007-09-04 Robert Marc Zeidman Apparatus and method for connecting hardware to a circuit simulation
US8160863B2 (en) * 2000-03-28 2012-04-17 Ionipas Transfer Company, Llc System and method for connecting a logic circuit simulation to a network
USRE42227E1 (en) 2000-03-28 2011-03-15 Ionipas Transfer Company, Llc Apparatus and method for connecting hardware to a circuit simulation
US7487152B1 (en) 2000-05-31 2009-02-03 International Business Machines Corporation Method for efficiently locking resources of a global data repository
US6681225B1 (en) 2000-05-31 2004-01-20 International Business Machines Corporation Method, system and program products for concurrent write access to a global data repository
US20070016396A9 (en) * 2000-12-28 2007-01-18 Zeidman Robert M Apparatus and method for connecting a hardware emulator to a computer peripheral
US7233928B2 (en) * 2002-04-12 2007-06-19 Vendavo, Inc. Rule-based system for determining price adjustments in a product catalog
US7308421B2 (en) * 2002-04-12 2007-12-11 Vendavo, Inc. System and method for grouping products in a catalog
CA2392809A1 (en) * 2002-07-09 2004-01-09 Greg Lehman Parallel software download
US7912792B2 (en) * 2002-07-12 2011-03-22 Vendavo, Inc. Systems and methods for making margin-sensitive price adjustments in an integrated price management system
US7015912B2 (en) * 2003-01-13 2006-03-21 Vendavo, Inc. System and method for the visual display of data in an interactive zebra chart
US20050169259A1 (en) * 2004-01-29 2005-08-04 Rdc Semiconductor Co., Ltd, Taiwan, R.O.C. Switching hub architecture and index-shared packet transfer method thereof
US20060004861A1 (en) * 2004-05-28 2006-01-05 Albanese Michael J System and method for displaying price modeling data
US7640198B1 (en) 2004-05-28 2009-12-29 Vendavo, Inc. System and method for generating and displaying indexed price modeling data
US20050278227A1 (en) * 2004-05-28 2005-12-15 Niel Esary Systems and methods of managing price modeling data through closed-loop analytics
US8458060B2 (en) * 2004-05-28 2013-06-04 Vendavo, Inc. System and method for organizing price modeling data using hierarchically organized portfolios
US20060031179A1 (en) * 2004-08-09 2006-02-09 Vendavo, Inc. Systems and methods for making margin-sensitive price adjustments in an integrated price management system
US7613626B1 (en) 2004-08-09 2009-11-03 Vendavo, Inc. Integrated price management systems with future-pricing and methods therefor
US8396814B1 (en) 2004-08-09 2013-03-12 Vendavo, Inc. Systems and methods for index-based pricing in a price management system
US20060047574A1 (en) * 2004-08-27 2006-03-02 Shankar Sundaram Methods and systems for managing hierarchically organized objects in a pricing adjustment system
US7360697B1 (en) 2004-11-18 2008-04-22 Vendavo, Inc. Methods and systems for making pricing decisions in a price management system
US20080126264A1 (en) * 2006-05-02 2008-05-29 Tellefsen Jens E Systems and methods for price optimization using business segmentation
US20090259522A1 (en) * 2006-05-02 2009-10-15 Jamie Rapperport System and methods for generating quantitative pricing power and risk scores
US8301487B2 (en) * 2006-05-02 2012-10-30 Vendavo, Inc. System and methods for calibrating pricing power and risk scores
US20070294192A1 (en) * 2006-05-15 2007-12-20 Tellefsen Jens E Systems and methods for price setting and triangulation
US7680686B2 (en) * 2006-08-29 2010-03-16 Vendavo, Inc. System and methods for business to business price modeling using price change optimization
US7904355B1 (en) 2007-02-20 2011-03-08 Vendavo, Inc. Systems and methods for a revenue causality analyzer
US8412598B2 (en) 2008-02-06 2013-04-02 John Early Systems and methods for a causality analyzer
US7970963B2 (en) * 2009-06-29 2011-06-28 Oracle America, Inc. Efficient buffer management in a multi-threaded network interface
US9235449B1 (en) 2012-06-22 2016-01-12 Adtran, Inc. Systems and methods for reducing contention for a software queue in a network element
WO2018176397A1 (zh) * 2017-03-31 2018-10-04 华为技术有限公司 一种锁分配的方法、装置和计算设备

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4833603A (en) * 1986-05-30 1989-05-23 Bull Hn Information Systems Inc. Apparatus and method for implementation of a page frame replacement algorithm in a data processing system having virtual memory addressing
US4956771A (en) * 1988-05-24 1990-09-11 Prime Computer, Inc. Method for inter-processor data transfer
US5136582A (en) * 1990-05-29 1992-08-04 Advanced Micro Devices, Inc. Memory management system and method for network controller
US5303347A (en) * 1991-12-27 1994-04-12 Digital Equipment Corporation Attribute based multiple data structures in host for network received traffic
DE69328320T2 (de) * 1992-01-09 2000-11-30 Cabletron Systems Inc Vorrichtung und Verfahren zur Datenübertragung zu und von einem Wirtrechnersystem
GB9209840D0 (en) * 1992-05-07 1992-06-24 Int Computers Ltd Data buffering mechanism
US5299313A (en) * 1992-07-28 1994-03-29 3Com Corporation Network interface with host independent buffer management
US5434872A (en) * 1992-07-28 1995-07-18 3Com Corporation Apparatus for automatic initiation of data transmission
US5307459A (en) * 1992-07-28 1994-04-26 3Com Corporation Network adapter with host indication optimization
US5438677A (en) * 1992-08-17 1995-08-01 Intel Corporation Mutual exclusion for computer system
US5392406A (en) * 1992-09-18 1995-02-21 3Com Corporation DMA data path aligner and network adaptor utilizing same
US5530874A (en) * 1993-02-02 1996-06-25 3Com Corporation Network adapter with an indication signal mask and an interrupt signal mask
US5442758A (en) * 1993-07-19 1995-08-15 Sequent Computer Systems, Inc. Apparatus and method for achieving reduced overhead mutual exclusion and maintaining coherency in a multiprocessor system utilizing execution history and thread monitoring

Also Published As

Publication number Publication date
EP0752651A2 (en) 1997-01-08
JP3762810B2 (ja) 2006-04-05
SG74564A1 (en) 2000-08-22
US5740448A (en) 1998-04-14
EP0752651A3 (en) 2004-02-04

Similar Documents

Publication Publication Date Title
JP3762810B2 (ja) 共用データ構造体のバッファ内のデータの転送の方法およびシステム
US6021446A (en) Network device driver performing initial packet processing within high priority hardware interrupt service routine and then finishing processing within low priority software interrupt service routine
JP3336816B2 (ja) マルチメディア通信装置及び方法
US5778180A (en) Mechanism for reducing data copying overhead in protected memory operating systems
US5790804A (en) Computer network interface and network protocol with direct deposit messaging
US5875352A (en) Method and apparatus for multiple channel direct memory access control
US5732094A (en) Method for automatic initiation of data transmission
US5923660A (en) Switching ethernet controller
US6724767B1 (en) Two-dimensional queuing/de-queuing methods and systems for implementing the same
JP4205181B2 (ja) Atmパケット・ヘッダおよびデータをホスト・コンピュータ・システムにバースト転送するための方法および装置
US5752078A (en) System for minimizing latency data reception and handling data packet error if detected while transferring data packet from adapter memory to host memory
US8542693B2 (en) Managing free packet descriptors in packet-based communications
US6442137B1 (en) Apparatus and method in a network switch for swapping memory access slots between gigabit port and expansion port
US7774374B1 (en) Switching systems and methods using wildcard searching
US9678866B1 (en) Transactional memory that supports put and get ring commands
US20040243739A1 (en) Method and apparatus for local and distributed data memory access ("DMA") control
JPH09160870A (ja) ハードウェアとソフトウェアの間でデータ転送を報告する方法および装置
JPH09325947A (ja) コマンドおよびデータ情報を装置に原子的に転送する方法及び装置
US6577636B1 (en) Decision making engine receiving and storing a portion of a data frame in order to perform a frame forwarding decision
JPH02131048A (ja) アダプタ間のパケツト転送方法、競合解消装置、及びトークン・リング装置
KR20010043460A (ko) 디지털 통신 프로세서
US20040039787A1 (en) Methods and apparatus for processing packets including accessing one or more resources shared among processing engines
US6904043B1 (en) Apparatus and methods for storing and processing header information in a network switch
US5146560A (en) Apparatus for processing bit streams
US7039054B2 (en) Method and apparatus for header splitting/splicing and automating recovery of transmit resources on a per-transmit granularity

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20050712

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20050719

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20051019

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: 20051220

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20060116

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Free format text: PAYMENT UNTIL: 20090120

Year of fee payment: 3

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

Free format text: PAYMENT UNTIL: 20100120

Year of fee payment: 4

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

Free format text: PAYMENT UNTIL: 20110120

Year of fee payment: 5

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

Free format text: PAYMENT UNTIL: 20110120

Year of fee payment: 5

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

Free format text: PAYMENT UNTIL: 20120120

Year of fee payment: 6

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

Free format text: PAYMENT UNTIL: 20130120

Year of fee payment: 7

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

Free format text: PAYMENT UNTIL: 20130120

Year of fee payment: 7

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

EXPY Cancellation because of completion of term