JP7120943B2 - Fpgaベースの加速のための新たなssd基本構造 - Google Patents
Fpgaベースの加速のための新たなssd基本構造 Download PDFInfo
- Publication number
- JP7120943B2 JP7120943B2 JP2019034068A JP2019034068A JP7120943B2 JP 7120943 B2 JP7120943 B2 JP 7120943B2 JP 2019034068 A JP2019034068 A JP 2019034068A JP 2019034068 A JP2019034068 A JP 2019034068A JP 7120943 B2 JP7120943 B2 JP 7120943B2
- Authority
- JP
- Japan
- Prior art keywords
- fpga
- description
- acceleration
- storage device
- processor
- 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.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/10—Program control for peripheral devices
- G06F13/102—Program control for peripheral devices where the program performs an interfacing function, e.g. device driver
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
- G06F13/1668—Details of memory controller
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/16—Handling requests for interconnection or transfer for access to memory bus
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
- G06F13/20—Handling requests for interconnection or transfer for access to input/output bus
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4004—Coupling between buses
- G06F13/4027—Coupling between buses using bus bridges
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4282—Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2455—Query execution
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
- G06F3/0611—Improving I/O performance in relation to response time
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
- G06F3/0658—Controller construction arrangements
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2213/00—Indexing scheme relating to interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F2213/0024—Peripheral component interconnect [PCI]
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2213/00—Indexing scheme relating to interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F2213/0026—PCI express
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Computer Hardware Design (AREA)
- Computational Linguistics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Information Transfer Systems (AREA)
- Advance Control (AREA)
- Bus Control (AREA)
- Stored Programmes (AREA)
- Air Bags (AREA)
Description
加速モジュールはハードウェアを使用して具現されて加速コマンドを実行するための加速モジュールの加速プラットフォームマネージャ(APM-F)を包含できる。
ストレージデバイスは、加速モジュールと通信するためのストレージデバイスのエンドポイントと、ストレージデバイスの動作を管理するためのコントローラと、アプリケーションに対するアプリケーションデータを格納するためのストアと、加速コマンドを実行する際に加速モジュールの加速プラットフォームマネージャ(APM-F)を補助するためのストレージデバイスの加速プラットフォームマネージャ(APM-S)と、をさらに包含できる。
プロセッサ、加速モジュール、及びストレージデバイスはPCIe(Peripheral Component Interconnect Exchange)バスを介して通信できる。
加速モジュールは、アプリケーションデータをメモリにロード(load)せずに、アプリケーションのためのストレージデバイス上のアプリケーションデータに対する加速コマンドの遂行を支援できる。
プロセッサ上でアプリケーションが実行され得る。加速モジュールは、PCIe(Peripheral Component Interconnect Exchange)バスを使用して、プロセッサ及びストレージデバイスと通信できる。
加速モジュールは、プロセッサと関連されたメモリにアプリケーションデータをロードせずに、アプリケーションに対するストレージデバイス上のアプリケーションのデータに対して加速コマンドの遂行を支援できる。
加速モジュールは、プロセッサと関連されたメモリにアプリケーションプログラムに対するアプリケーションデータをロードすることなく、ストレージデバイス上のアプリケーションデータに対する加速コマンドの遂行を支援できる。プロセッサ、加速モジュール、及びストレージデバイスは、PCIeバスを使用して通信できる。
バックエンドSSDはPCIeエンドポイント及び不揮発性メモリエクスプレス(NVMe)コントローラを具現する。従って、ホストは、直接NVMeプロトコルをバックエンドSSDに伝達する。つまり、FPGAを介してホストからバックエンドSSDに連結されるPCIeインタフェースは通過(pass-through)特性である。SSDは直接メモリアクセス(DMA)を介してホストシステムメモリとのデータ伝送を遂行する。FPGAダウンストリームポート(DSP)は、PCIeトランザクションフィルタとして使用されるメモリのフィルタドレス範囲(FAR)でプログラミングされる。 DSPは、FARウィンドウに属する全てのPCIeトランザクションをフィルタリングして、それらをFPGAのロジック及びメモリに伝達する。プログラミングされたFARウィンドウに属していない全てのPCIeトランザクションは、ホストシステムのメモリに属し、ホストに直接伝達される。SSDコントローラは、PCIe VDM(Vendor Defined Message)メカニズム又はI2C/SMバスのような他のサイドバンドバスを使用するFPGAで適切なFARウィンドウをプログラムする。SSDコントローラは、PCIe BAR(Base Address Register、ベースアドレスレジスタ)を介してホストにアドレス範囲のブロックを要請する。ホストのBIOSが要請されたアドレスブロックをSSDコントローラに割り当てた後、SSDコントローラは、FPGA DSPでそのアドレス範囲のサブセットをFARウィンドウでプログラムする。DSPにプログラムされたアドレスの範囲は、SSDコントローラとFPGAとが通信し合うために使用される。つまり、ホストがアドレスブロックを割り当てると、SSDとFPGAがPCIe階層で互いに又は他のPCIeデバイスを干渉せずにホストトランザクションとPCIeバスを共有できる。SSDコントローラは、共有PCIeバスを介してFARウィンドウを使用してFPGAに加速コマンドとデータを提供できる。FPGA又はホストが共有PCIeバス及び前記のアドレス範囲を使用してSSDコントローラから加速のためのデータを要請することもできる。FPGAは、同じメカニズムを使用して加速の結果をSSDコントローラに再び提供することもできる。提案された基本構造及びメカニズムは、低コスト及びFPGAデバイスを使用しているSSDベースのアプリケーション加速のための低消費電力の解決策を具現できる。
ホスト(プロセッサ110)がストレージデバイス120に通信を送り得る。本発明の実施例で、このような全てのトラフィックは、加速モジュール145を通過し、加速モジュール145によってストレージデバイス120に到達することから遮断されてはならない。斯かるトラフィックの実施例は、ストレージデバイス120からデータを読み出すための、及び/又はストレージデバイス120にデータを記録するためのコマンドを含み得る。つまり、ストレージデバイス120によって提供される他のコマンドもこのようなトラフィックに含まれ得る。
ASM130は、特定の加速コマンドが遂行されるように要請できる。何れにせよ、本発明の特定の実施例にかかわらず、加速モジュール145は、ASM130から加速コマンドを受信しなければならない。
加速コマンドを遂行するために、加速モジュール145は、ストレージデバイス130からデータをフェッチ又は受信する必要が有り得る。
PCIeトランザクションが加速コマンドを含む場合、HILは処理のためにPCIeトランザクション(又はPCIeトランザクションから圧縮解除(unpack、解凍)された加速コマンドそのもの)をAPM-S(315)に伝送できる。APM-S(315)は、ファームウェア単独又はハードウェアとファームウェアの組み合わせを使用して具現され得る。
そうでない場合、即ち、PCIeトランザクションが加速コマンドを含まない場合、HIL310は、FTL320にPCIeトランザクション(又は圧縮解除されたNVMeコマンド)を伝達でき、FTLは、図1のアプリケーション125によって使用される論理ブロックアドレス(LBA)を物理ブロックアドレス(PBA)に変換し、フラッシュメディア325に格納されたデータにアクセスできる。
プロセッサ110は、SSD120に、該特定のコマンド/加速コマンドをトンネリングするためにNVMeコマンドを使用できる。 HIL310は、APM-S(315)に伝達され得る、この特定のコマンドをインタセプトできる。その後に、APM-S(315)は、該特定のコマンドに応答して加速コマンドを生成でき、該特定のコマンドは該加速コマンドを遂行するためにFPGA145に返送され得る。この特定のコマンドは、例として、実行されるべき加速コマンドの特定のタイプ及び該加速コマンドが遂行されるべきデータをエンコーディングできる。
SSD120からダウンストリームポート335でFPGA145によって受信された、ダウンストリームFAR420を含んでいない任意の通信は、アップストリームポート330を介してFPGA145によりプロセッサ110に伝達され得る(FPGA145がアップストリームポート330で、プロセッサ110から受信する任意の通信は、ダウンストリームポート335を介して自動的にSSD120に伝達され得る)。
斯かる加速コマンドは、メッセージのメールボックス355を使用してダウンストリームポート335からメッセージとして受信され得るが、本発明の実施例は、APM-Fが加速コマンドを受信するための他のメカニズムに拡張され得る。一度加速コマンドが受信されると、APM-F(340)は、加速コマンドを処理できる。例として、FPGA145が加速コマンドを遂行できる、十分な情報を有する場合、APM-F(340)は、加速コマンドを加速エンジン(350-1及び350-2)のような任意の利用可能な加速エンジンでスケジューリングできるスケジューラ(「ランタイムスケジューラ」とも称され得る)345に加速コマンドを手渡し(pass)得る。
一方、図3は、2つの加速エンジン(350-1、350-2)を図示するが、本発明の実施例は、任意の所望の数の加速エンジンを含み得る。つまり、図3に示された2つは単に例示的な目的のためである。代案的に、FPGA145が加速コマンドを遂行するための追加情報を必要とする場合、例えば、加速コマンドが遂行されるべきデータをFPGA145が必要とする場合、APM-F(340)は、PCIeトランザクションを、必要なデータを要請するSSD120に送るなどの他の動作をとり得る。
その後、ダウンストリームフィルタ360が、図4のダウンストリームFAR420内のアドレスを使用するPCIeトランザクションを識別するとき、FPGA145は、PCIeトランザクションを、加速コマンドを含むものと識別し、PCIeトランザクションをインタセプトできる。SSD120は、任意の所望の方式でダウンストリームフィルタ360をプログラミングできる。例として、SSD120は、ダウンストリームフィルタ360をプログラミングするために、内部の集積回路バス(I2Cバス)、又はシステム管理バス(SMバス)のようなサイドバンドバス365を使用できる。また、SSD120は、ダウンストリームフィルタ360をプログラミングするために、PCIe VDM(Vendor Defined Message)を使用できる。SSD120はまた、ダウンストリームフィルタ360をプログラミングするために他のメカニズムを使用できる。
例として、ダウンストリームポート335とダウンストリームフィルタ360は、(ここで後者は、SSD120から受信された何れのPCIeトランザクションが加速コマンドを含むことを識別し、従ってプロセッサ120に伝達する代わりにAPM-F(340)にリダイレクトする責任がある)、FPGA145とSSD120との間のブリッジ構成要素(図3に図示せず)に配置され得る。これらのブリッジの構成要素は、FPGA145及びSSD120と通信するために必要なので、この場合、FPGA145は相変わらずダウンストリームポート335(又はブリッジ構成要素との通信を可能にする代案的な構造(structure))を含むが、ダウンストリームフィルタ360は、FPGA145から除去され得る。
例として、SSD120は、図4のダウンストリームFAR365と同様に、アップストリームFARを定義でき、サイドバンドバス365、PCIe、VDM、又は任意の他のメカニズムを介してアップストリームFARを用いてアップストリームフィルタ505をプログラミングする。その後に、FPGA145がアップストリームポート330で、プロセッサ110からPCIeトランザクションを受信するとき、アップストリームフィルタ505は、アップストリームフィルタ505がアップストリームFAR内のアドレスを包含するかを見るためにPCIeトランザクションを検査できる。もしそうならば、該PCIeトランザクションは加速コマンドであり、FPGA145は、該PCIeトランザクションをSSD120に伝達せず、むしろ、プロセッサのために該PCIeトランザクションをAPM-F(340)にルーティングできる。
従って、本発明の第2実施例で、アップストリームポート330及びアップストリームフィルタ335は、第1ブリッジ構成要素及びダウンストリームポート335に配置され得、ダウンストリームフィルタ360は、各々が図5の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する第2ブリッジ構成要素に配置され得る。
選択的に、斯かるブリッジ構成要素の中で単に一つだけが使用され得、(その場合、FPGA145は、他のソース(source)からの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタリングを処理するために使用され得る。
しかし、SSD120の仮想機能を表現する代わりに、VF710は、FPGA145を「露出」できる。つまり、VF710は、FPGA145の機能を示し得る。(VF710は、相変わらずFPGA145の一部ではなく、SSD120の一部である。しかし、FPGA145を露出するための専用VF710を使用すれば、VF710と関連された任意のメモリアドレスは、他のデバイスと衝突しないであろう。)PCIeデバイスが羅列されとき、PF及びVFがプロセッサ110によって発見され得るので、プロセッサ110は、VF710を介してFPGA145を間接的に発見できるが、それ自身が直接発見することはできない。
ダウンストリームFAR420は、PF705に対するブロック805のサブセットとして選択され得る。よって、アップストリームFAR605は、VF710に対するブロック810の全体であり得る。なお、アップストリームFAR605は、単にブロック810のサブセットとして選択され得る。しかし、ブロック810は、VF710による専用となり、VF710はFPGA145を効果的に露出する以外の他の目的を有し得ないので、アップストリームFAR605の一部として使用されていないブロック810の任意のメモリアドレスは、無駄になり得る。SSD120が、各ブロックに対し割り当てられたアドレスの範囲を知り得るようにするため、ブロック(805及び810)の各々は、別個のBARを有する。
その後に、FPGA145がアップストリームポート330で、プロセッサ110からPCIeトランザクションを受信するとき、VFフィルタ715は、該PCIeトランザクションがアップストリームFAR605内のアドレスを包含するか否かを知るためにPCIeトランザクションを検査できる。もしそうなら、該PCIeトランザクションは加速コマンドであり、FPGA145は、該PCIeトランザクションをSSD120に伝達せず、むしろ、プロセッサのために該PCIeトランザクションをAPM-F(340)にルーティングできる。
従って、本発明の第3実施例で、アップストリームポート330及びVFフィルタ715は、第1ブリッジ構成要素に配置され得、ダウンストリームポート335及びダウンストリームフィルタ360は、各々が図7の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する第2ブリッジ構成要素に配置できる。選択的に、斯かるブリッジ構成要素の中で単に一つだけが使用され得、(その場合、FPGA145は、他のソースからの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタを処理するために使用され得る。
(PFフィルタ715は、動作中の図7のVFフィルタ715と実質的に同一であり、名前の変更は、PFフィルタ715がVFフィルタ715とは異なるように動作する故ではなく、むしろ、FPGA145を露出するために使用される機能のタイプと関連付けるためである。PFフィルタ715は、ダウンストリームフィルタ360と類似の方式で、プロセッサ110(アップストリームポート330を介して受信された)から来るPCIeトランザクションをフィルタリングできる。例として、SSD120は、サイドバンドバス365、PCIe VDM、又は任意の他のメカニズムを使用してアップストリームFAR605でVFフィルタ715をプログラムできる。その後に、FPGA145がアップストリームポート330で、プロセッサ110からPCIeトランザクションを受信するとき、PFフィルタ715は、PCIeトランザクションがアップストリームFAR605にアドレスを包含するかを知るためにPCIeトランザクションを検査できる。もしそうならば、該PCIeトランザクションは加速コマンドであり、FPGA145は、該PCIeトランザクションをSSD120に伝達せず、むしろ、プロセッサのために該PCIeトランザクションをAPM-F(340)にルーティングできる。
従って、本発明の第4実施例で、アップストリームポート330及びPFフィルタ715は、第1ブリッジ構成要素に配置され得、一方、ダウンストリームポート335及びダウンストリームフィルタ360は、第2ブリッジ構成要素に配置され得、各々は、図9の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する。
選択的に、斯かるブリッジ構成要素の中で単に一つだけが使用され得(その場合、FPGA145は、他のソースからの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタリングを処理するために使用され得る。
この事実は、エンドポイント(EP)1105及びルートポート(RP)1110が、図12を参照して以下に説明されるように、それら自身のPCIeの構成空間を含むことを意味する。しかし、エンドポイント(EP)1105及びルートポート(RP)1110は、通信のための終端点なので、プロセッサ110及びSSD120は、通信を相互に向けるよりも、各々のエンドポイント(EP)1105及びルートポート(RP)1110にそれらの通信を指示する。
前記した本発明の第3及び第4実施例の場合と同様に、エンドポイント1105は、PFを識別するPCIeトランザクションに含まれているタグによって、又はPCIeトランザクションと関連されたアドレスによって(再言すると、図12を参照して下記に説明される)、どのPFがアドレスされるかを識別できる。PF1115を識別するPCIeトランザクションは、SSD120を目的地とすると見なされ得、ルートポート1110を介してFPGA145によってSSD120に伝送され得る。PF1120を識別するPCIeトランザクションは、加速コマンドを含むものと見なされ得、APM-F(340)にルーティングされ得る。
FPGA145は、プロセッサ110が、加速コマンドについてAPM-F(340)と通信するためのメカニズムを提供しつつ、PF1120のためのブロック1220を要請できる。ブロック(1215及び1220)は、各々2つの分離されたBARにより識別され得る。本発明の他の実施例で、FPGA145とSSD120との間の通信を容易にするために、ダウンストリームFAR420としてブロック1205の一部分を使用可能である。
従って、本発明の第5実施例で、エンドポイント1105及びPF(1115と1120)は、第1ブリッジ構成要素に配置され得、一方、ルートポート1110及びダウンストリームフィルタ360は、第2ブリッジ構成要素に配置され得、各々は、図11の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する。
選択的に、斯かるブリッジ構成要素の中で単に一つだけが使用され得、(その場合、FPGA145は、他のソース(source)からの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタリングを処理するために使用され得る。
(何故なら、図11及び13におけるFPGA145は、関連されたPFに基づき、従来のPCIeトランザクションと加速コマンドとを峻別できるからである)。この利点に対するオフセットは、SSD120が、各々FPGA145のルートポート(1110及び1305)と通信するために2つのエンドポイント(305及び1310)を要することである。
従って、本発明の第6実施例で、エンドポイント1105及びPF(1115と1120)は第1ブリッジ構成要素に配置され得、一方、ルートポート(1110と1305)は第2ブリッジ構成要素に配置され得、各々は、図13の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する。
選択的に、このようなブリッジ構成要素の中で単に一つだけが使用され得、(その場合、FPGA145は、他のソース(source)からの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタリングを処理するために使用され得る。
従って、本発明の第7実施例で、エンドポイント(1105、1505)は第1ブリッジ構成要素に配置され得、一方、ルートポート(1110、1305)は第2ブリッジ構成要素に配置され得、各々は、図15の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する。
選択的に、斯かるブリッジ構成要素の中で単に一つだけが使用され得、(その場合、FPGA145は、他のソースからの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタリングを処理するために使用され得る。
従って、本発明の第8実施例で、エンドポイント(1105、1505)は第1ブリッジ構成要素に配置され得、一方、ルートポート1110及びダウンストリームフィルタ360は第2ブリッジ構成要素に配置され得、各々は、図17の相異なる構成要素を有するPCIeトランザクションのフィルタリングを処理する。
選択的に、斯かるブリッジ構成要素の中で単に一つだけが使用され得(その場合、FPGA145は、他のソースからの通信のために、それ自体のフィルタリングを処理する)、又は、PCIeトランザクションのソースに関係なく、単一のブリッジ構成要素がFPGA145に対する全てのフィルタリングを処理するために使用され得る。
FPGA145のアップストリーム及びダウンストリームインタフェースの一部として図示されたのと類似の具現であるので、ブリッジ構成要素(1905及び1910)の特定の具現は、図19に示されない。
SSD120がサイドバンドバス365を介してダウンストリームFAR420をダウンストリームフィルタ360でプログラミングする場合、この関係は、自動的に発生できるか、又は、この関係は、FPGA145による積極的ステップを必要とし得る(例として、SSD120がダウンストリームFAR420を含むFPGA145にPCIe VDMを伝送する場合)。破線2209で示されたように、本発明の幾つかの実施例で、ブロック(2203及び2206)は、スキップされることに注目する。本発明の幾つかの実施例で、ダウンストリームFAR420は、FPGA145それ自体によって提供され得る。
図26において、ブロック2305で、FPGA145は、図21のPCIeトランザクション2005に関連されたアドレスがアップストリームFAR605でのアドレスを含んでいるか否かを判断できる。ブロック2315で、図21のPCIeトランザクション2005がアップストリームフィルタ715と関連されたるPF又はVFの識別子を含むと、FPGA145は、判断できる。ブロック2315で、FPGA145は、エンドポイント1505のような加速コマンド専用のポートで図21のPCIeトランザクション2005が受信される場合、FPGA145は、判断できる。
これらのテストの何れかの結果が、図21のPCIeトランザクション2005が図21の加速コマンド2045を含むことを示すと、ブロック2320(図27)において、FPGA145は、図21のPCIeトランザクション2005が図21の加速コマンド2045を含むと知る。そうでなければ、ブロック2320のFPGA145は、図21のPCIeトランザクション2005が図21の加速コマンド2045を含まないと知る。
図28において、ブロック2405で、FPGA145は、図20のPCIeトランザクション2020に関連されたアドレスがダウンストリームFAR420内のアドレスを含んでいるか否かを判断できる。ブロック2410において、ループポート1305のような加速コマンド専用のポートで図20のPCIeトランザクション2020が受信される場合、FPGA145は、判断できる。これらのテストの結果の何れかが、図20のPCIeトランザクション2020が図20の加速コマンド2015を含むことを示すと、ブロック2415でFPGA145は、図20のPCIeトランザクション2020が図20の加速コマンド2015を含むと知る。従って、そうでなければ、ブロック2420においてFPGA145は、図20のPCIeトランザクション2020が図20の加速コマンド2015を包含しないと知る。
もしそうなら、ブロック2765で、HIL310は、PCIeトランザクション(又は圧縮解除された加速コマンド)を処理するためにAPM-S(315)に伝送できる。APM-S(315)は、加速コマンドへの応答を生成でき、これは、図20の加速コマンド2025、又は(PCIeトランザクションがプロセッサ110から由来された場合)加速データ2025であり得る(PCIeトランザクションがFPGA145のAPM-F(340)から由来した場合)。何れの場合でも、ブロック2770で、APM-S(315)は、応答をFPGA145に伝送できる。
ブロック2810で、SSD120は、PCIeトランザクションがAPM-F(340)から由来するか否かを判断できる。これは、APM-F(340)が図20及び図21の加速データ2025を要請している場合か、又は、APM-F(340)が、図20の結果2030をSSD120に伝送している場合に発生し得る。ブロック2810のテストは、任意の所望の方式で遂行され得る。つまり、例として、PCIeトランザクションは、PCIeトランザクションが加速コマンドであることを示すタグを包含するか、又は、PCIeトランザクションがダウンストリーム内のアドレスと関連付けられる方式で遂行され得る。
ブロック2815で、SSD120は、PCIeトランザクションがエンドポイント1310などの加速コマンド専用のポートで受信されるかを判断できる。これらのテストの結果の中の何れかがPCIeトランザクションに加速コマンドが含まれていることを示すと、ブロック2820(図35)で、SSD120は、PCIeトランザクションが加速コマンドを包含していると知る。そうでない場合、ブロック2825で、SSD120は、PCIeトランザクションが加速コマンドを含まないと知る。
アプリケーションを実行するプロセッサと、
前記プロセッサ上で実行中の前記アプリケーションによって使用されるデータを格納するメモリと、
前記プロセッサと通信するためのアップストリームインタフェースと、
ストレージデバイスと通信するためのダウンストリームインタフェースと、
ハードウェアを使用して具現されて加速コマンドを実行するための加速プラットフォームマネージャ(APM-F)を含む加速モジュールと、を包含し、
前記ストレージデバイスは、
前記加速モジュールと通信するための前記ストレージデバイスのエンドポイントと、
前記ストレージデバイスの動作を管理するためのコントローラと、
前記アプリケーションに対するアプリケーションデータを格納するためのストアと、
前記加速コマンドを実行するのに前記加速プラットフォームマネージャ(APM-F)を補助するためのストレージデバイスの加速プラットフォームマネージャ(APM-S)と、をさらに包含し、
前記プロセッサ、前記加速モジュール及び前記ストレージデバイスは、PCIe(Peripheral Component Interconnect Exchange)バスを介して通信し、
前記加速モジュールは、前記アプリケーションデータを前記メモリにローディングすることなく、前記アプリケーションのための前記ストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援する。
前記プロセッサと前記加速モジュールとの間の通信を連結(bridging)し、前記アップストリームインタフェースを含む第1ブリッジ構成要素と、及び
前記加速モジュールと前記ストレージデバイスとの間の通信を連結し、前記ダウンストリームインタフェースを含む第2ブリッジ構成要素と、をさらに包含する。
前記加速モジュールは、FPGA(Field Programmable Gate Array)を使用して具現され、
前記加速モジュールは、前記アップストリームインタフェース及び前記ダウンストリームインタフェースを包含し、
前記ストレージデバイスは、SSD(Solid State Drive)を含む。
加速エンジンと、
前記加速エンジンに前記加速コマンドをスケジューリングするランタイムスケジューラ(run-time scheduler)と、をさらに含む。
前記アップストリームインタフェースは、FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、構成空間を支援するFPGAのルートポートを包含し、
前記FPGAは、第1 PF、第2 PF及び前記FPGAルートポートと関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記SSDから受信された第1加速コマンドをインタセプトするように動作し、前記APM-Fにダウンストリームフィルタのアドレス範囲(FAR)と関連される前記第1加速コマンドを伝達するように動作し、
前記FPGAは、前記第1 PFに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、前記第2 PFに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作し、前記プロセッサから受信された第1 PCIeトランザクションを、前記SSDに伝達するように動作し、前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するように動作し、
前記第1 PCIeトランザクションは、前記第1 PFの第1識別子と関連され、
前記第2加速コマンドは、前記第2 PFの第2識別子と関連される。
前記SSDは、前記プロセッサから前記ホストシステムのブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARのように、前記ホストシステムのブロックのサブセットを選択するように動作する。
前記コントローラは、前記結果を前記SSDの前記エンドポイントを介して前記プロセッサに伝達するように動作する。
前記FPGAはアップストリームポートで前記プロセッサから受信されたアップストリームFARと関連されていない第3PCIeトランザクションを、前記SSDに伝達するように動作する。
前記コントローラは、前記ダウンストリームFARとして、前記ホストシステムアドレスの前記ブロックの第1サブセット及びアップストリームFARとして、前記ホストシステムアドレスの前記ブロックの第2サブセットを選択するように動作する。
前記APM-Fは、前記ダウンストリームポート及び前記SSDの前記エンドポイントを介して前記APM-Sに結果を伝送するように動作し、
前記コントローラは、前記結果を前記SSDの前記エンドポイントを介して前記プロセッサに伝達するように動作する。
前記SSDは物理機能(PF)及び仮想機能(VF)を包含し、前記PFは前記SSDを露出するために動作し、前記VFは前記FPGAを露出するために動作し、
前記FPGAは、前記アップストリームポートと関連された前記アップストリームフィルタと、をさらに包含し、前記アップストリームフィルタは、前記プロセッサから受信された第2加速コマンドをインタセプトし、前記第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記FPGAは、前記アップストリームポートで前記プロセッサから受信された前記アップストリームフィルタによってインタセプトされない第3PCIeトランザクションを、前記SSDに伝達するように動作する
前記PFは、前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARとして、前記ホストシステムアドレスの前記ブロックの第1サブセットを選択するように動作する。
前記第2加速コマンドは、前記アップストリームFARと関連し、
前記アップストリームフィルタは、アップストリームFARと関連された前記第2加速コマンドをインタセプトするように動作する。
前記第2加速コマンドは、前記VFの識別子を包含し、
前記アップストリームフィルタは、前記VFの前記識別子に関連された前記第2加速コマンドをインタセプトするように動作する。
前記APM-Fは、前記のダウンストリームポート及び前記SSDのエンドポイントを介して前記APM-Sに結果を伝送するように動作し、
前記コントローラは、前記結果を前記SSDの前記エンドポイントを介して前記プロセッサに伝達するように動作する。
前記SSDは、前記SSDを露出するように動作する第1PF及び前記FPGAを露出するように動作する第2PFを包含し、
前記FPGAは、前記アップストリームポートと関連されたアップストリームフィルタと、をさらに包含し、前記アップストリームフィルタは、前記プロセッサから受信された第2加速コマンドをインタセプトするように動作して、前記第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記FPGAはアップストリームポートで前記プロセッサから受信された前記アップストリームフィルタによってインタセプトされない第3PCIeトランザクションを、前記SSDに伝達する。
前記第1 PFは、前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARとして、前記ホストシステムアドレスの前記ブロックの第1サブセットを選択するように動作する。
前記第2加速コマンドは、前記アップストリームFARと関連し、
前記アップストリームフィルタは、前記アップストリームFARに関連した前記第2の加速コマンドをインタセプトするように動作する。
前記第2加速コマンドは、前記第2 VFの識別子を包含し、
前記アップストリームフィルタは、前記第2VFの前記識別子に関連された前記第2加速コマンドをインタセプトするように動作する。
前記APM-Fは、前記ダウンストリームポート及び前記SSDの前記エンドポイントを介して前記APM-Sに結果を伝送するように動作し、
前記コントローラの前記の結果を前記SSDの前記エンドポイントを介して前記プロセッサに伝達するように動作する。
前記アップストリームインタフェースは、FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、構成空間を支援するFPGAのルートポートを包含し、
前記FPGAは、第1 PF、第2 PF、及び前記FPGAルートポートと関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記ストレージデバイスから受信された第1加速コマンドをインタセプトするように動作して前記第1加速コマンドを前記APM-Fに伝達するように動作し、
前記第1加速コマンドは、ダウンストリームフィルタのアドレス範囲(FAR)と関連付けられ、
前記FPGAは、前記第1 PFに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、前記第2 PFに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作し、
前記FPGAは、前記プロセッサから受信されたPCIeトランザクションを前記ストレージデバイスに伝達するように動作し、前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するように動作し、
前記PCIeトランザクションは、前記第1 PFの第1識別子と関連付けられ、
前記第2加速コマンドは、前記第2 PFの第2識別子と関連付けられる。
前記SSDは、前記FPGAから前記ダウンストリームFARを含むFPGAアドレスのブロックを要請するように動作し、
前記ホストシステムアドレスの前記第2ブロックは、少なくとも前記FPGAアドレスの前記ブロックほど大きく、
前記コントローラは、前記ダウンストリームFARのように、前記FPGAアドレスの前記ブロックのサブセットを選択するように動作する。
前記アップストリームインタフェースは、FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、第1構成空間を支援する第1 FPGAのルートポート及び第2構成空間を支援する第2 FPGAのルートポートを包含し、
前記SSDの前記エンドポイントは、前記第1 FPGAのルートポートと関連し、
前記SSDは、前記第2のFPGAのルートポートと関連された前記SSDの第2エンドポイントと、をさらに包含し、
前記FPGAは、第1 PF及び第2 PFを包含し、
前記FPGAは、前記第1 PFに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作して前記第2 PFに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作し、
前記FPGAは、
前記プロセッサから受信された第1 PCIeトランザクションを前記第1 FPGAのルートポート及び前記SSDの前記エンドポイントを介して前記SSDに伝送するように動作し、
前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するように動作し、
前記第1 FPGAのルートポートで、前記SSDから受信された第2PCIeトランザクションを前記プロセッサに伝達するように動作し、
前記第2のFPGAのルートポートで、前記SSDから受信された第1加速コマンドを前記APM-Fに伝達するように動作し、
前記第1 PCIeトランザクションは、前記第1 PFの第1識別子と関連付けられ、
前記第2加速コマンドは、前記第2 PFの第2識別子と関連付けられる。
前記アップストリームインタフェースは、第2 FPGAのエンドポイントと、をさらに包含し、
前記FPGAは、前記FPGAエンドポイントにおいて、前記プロセッサから受信された第1 PCIeトランザクションを前記第1 FPGAのルートポート及び前記SSDのエンドポイントを介して前記SSDに伝達するようにさらに動作し、前記第2 FPGAのエンドポイントで、前記プロセッサから受信された前記第2加速コマンドを前記APM-Fに伝達するように、さらに動作する。
前記アップストリームインタフェースは、第1 FPGAエンドポイント及び第2 FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、構成空間を支援するFPGAのルートポートを包含し、
前記FPGAは、前記FPGAルートポートに関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記SSDから受信された第1加速コマンドをインタセプトするように動作して、前記APM-Fに前記第1加速コマンドを伝達するように動作し、
前記第1加速コマンドは、ダウンストリームFARと関連し、
前記FPGAは、
前記FPGAエンドポイントにおいて、前記プロセッサから受信された第1 PCIeトランザクションを前記第1 FPGAのルートポート及び前記SSDの前記エンドポイントを介して前記SSDに伝達するように動作し、
前記第2FPGAのエンドポイントにおいて、前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記第1 FPGAのルートポートで、前記SSDから受信された前記ダウンストリームFARと関連されていない第2PCIeトランザクションを、前記FPGAエンドポイントを介して前記プロセッサに伝達するように動作し、
前記第2FPGAのルートポートで、前記SSDから受信された第1加速コマンドを前記APM-Fに伝達するように動作する。
前記SSDは、前記ダウンストリームFARを含むFPGAアドレスのブロックを前記FPGAから要請するように動作し、
前記FPGAは、少なくとも前記FPGAアドレスの前記ブロックほど大きなホストシステムアドレスのブロックを前記第1 FPGAエンドポイントに対する前記プロセッサから要請するように動作し、
前記コントローラは、前記ダウンストリームFARとして前記FPGAアドレスの前記ブロックのサブセットを選択するように動作する。
加速コマンドを実行するための加速プラットフォームマネージャ(APM-F)と、
プロセッサと通信するためのアップストリームインタフェースと、
前記加速コマンドを実行するのに前記APM-Fを補助するためのストレージデバイスの加速プラットフォームマネージャ(APM-S)を含むストレージデバイスと通信するためのダウンストリームインタフェースを包含し、
前記プロセッサ上でアプリケーションが実行され、
前記加速モジュールは、PCIe(Peripheral Component Interconnect Exchange)バスを使用して前記プロセッサ及び前記ストレージデバイスと通信し、
前記加速モジュールは、前記プロセッサと関連されたメモリにアプリケーションのデータをローディングすることなく、前記アプリケーションに対する前記ストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援する。
加速エンジンと、
前記加速エンジンで前記加速コマンドをスケジューリングするランタイムスケジューラ(run-time scheduler)と、をさらに含む。
前記アップストリームインタフェースはアップストリームポートを包含し、
前記ダウンストリームインタフェースはダウンストリームポートを包含し、
前記FPGAは、前記アップストリームポートで前記プロセッサから受信された第1 PCIeトランザクションを前記ストレージデバイスに伝達するように動作し、
前記FPGAは、前記ダウンストリームポートに関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記ストレージデバイスから受信された加速コマンドをインタセプトするように動作して前記APM-Fに前記加速コマンドを伝達するように動作し、
前記加速コマンドは、ダウンストリームフィルタのアドレス範囲(FAR)と関連付けられ、
前記FPGAは、ダウンストリームポートで、前記ストレージデバイスから受信された前記ダウンストリームFARと関連していない第2PCIeトランザクションを前記プロセッサに伝送するように動作する。
前記FPGAは、前記アップストリームポートと関連されたアップストリームフィルタと、をさらに包含し、
前記アップストリームフィルタは、前記プロセッサから受信された第2加速コマンドをインタセプトするよう動作し、アップストリームFARと関連付けられる前記第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記FPGAはアップストリームポートで前記プロセッサから受信された前記アップストリームFARと関連されていない第3PCIeトランザクションを前記ストレージデバイスに伝送するように動作する。
前記FPGAは、前記ストレージデバイスの仮想機能(VF)により露出され、
前記FPGAは、前記アップストリームポートと関連されたアップストリームフィルタと、をさらに包含し、
前記アップストリームフィルタは、前記プロセッサから受信された第2加速コマンドをインタセプトするよう動作し、前記第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記FPGAは、前記アップストリームポートで前記プロセッサから受信された前記アップストリームフィルタによってインタセプトされていない第3PCIeトランザクションを前記ストレージデバイスに伝送するように動作する。
前記第2加速コマンドは、前記アップストリームFARと関連し、
前記アップストリームフィルタは、アップストリームFARと関連された前記第2加速コマンドをインタセプトするように動作する。
前記第2加速コマンドは、前記VFの識別子を包含し、
前記アップストリームフィルタは、前記VFの前記識別子に関連された前記第2加速コマンドをインタセプトするように動作する。
前記FPGAは、前記ストレージデバイスの物理機能(PF)により露出され、
前記FPGAは、前記アップストリームポートと関連されたアップストリームフィルタと、をさらに包含し、
前記アップストリームフィルタは、前記プロセッサから受信された第2加速コマンドをインタセプトするよう動作し、前記第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記FPGAは、前記アップストリームポートで前記プロセッサから受信された前記アップストリームフィルタによってインタセプトされていない第3PCIeトランザクションを前記ストレージデバイスに伝送するように動作する。
前記第2加速コマンドは、前記アップストリームFARと関連し、
前記アップストリームフィルタは、アップストリームFARに関連された前記第2加速コマンドをインタセプトするように動作する。
前記第2加速コマンドは、前記PFの識別子を包含し、
前記アップストリームフィルタは、前記PFの前記識別子に関連された前記第2加速コマンドをインタセプトするように動作する。
前記アップストリームインタフェースは、FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、構成空間を支援するFPGAのルートポートを包含し、
前記FPGAは、第1 PF、第2 PF、及び前記FPGAルートポートに関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記ストレージデバイスから受信された第1加速コマンドをインタセプト するように動作し、前記第1加速コマンドを前記APM-Fに伝達するよう動作し、
前記第1加速コマンドは、ダウンストリームフィルタのアドレス範囲(FAR)と関連付けられ、
前記FPGAは、前記第1 PFに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、前記第2 PFに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作し、
前記FPGAは、前記プロセッサから受信されたPCIeトランザクションを前記ストレージデバイスに伝達するように動作し、前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記PCIeトランザクションは、前記第1 PFの第1識別子と関連付けられ、
前記第2加速コマンドは、前記第2 PFの第2識別子と関連付けられる。
前記FPGAは、前記FPGAから前記ダウンストリームFARを含むFPGAアドレスのブロックに対する要請を前記ストレージデバイスから受信するように動作し、
前記FPGAは、前記構成空間から前記FPGAアドレスの前記ブロックを割り当てるように動作し、
前記ホストシステムアドレスの前記第1ブロックは、少なくとも前記FPGAアドレスの前記ブロックほど大きい。
前記アップストリームインタフェースは、FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、第1構成空間を支援する第1 FPGAのルートポート及び第2構成空間を支援する第2 FPGAのルートポートを包含し、
前記SSDの前記エンドポイントは、前記第1 FPGAのルートポートと関連し、
前記SSDは、前記第2FPGAのルートポートと関連された前記SSDの第2エンドポイントと、をさらに包含し、
前記FPGAは、第1 PF及び第2 PFを包含し、
前記FPGAは、前記第1 PFに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作して前記第2 PFに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作し、
前記FPGAは、
前記プロセッサから受信された第1 PCIeトランザクションを前記第1 FPGAのルートポート及び前記SSDの前記エンドポイントを介して前記SSDに伝送するように動作し、
前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記第1 FPGAのルートポートで、前記SSDから受信された第2PCIeトランザクションを前記プロセッサに伝達するよう動作し、
前記第2FPGAのルートポートで、前記SSDから受信された第1加速コマンドを前記APM-Fに伝達するように動作する。
前記アップストリームインタフェースは、第2 FPGAのエンドポイントと、をさらに包含し、
前記FPGAは、前記FPGAエンドポイントにおいて、前記プロセッサから受信された第1 PCIeトランザクションを前記第1 FPGAのルートポート及び前記SSDのエンドポイントを介して前記SSDに伝達するように、さらに動作し、前記第2 FPGAのエンドポイントで、前記プロセッサから受信された前記第2加速コマンドを前記APM-Fに伝達するように、さらに動作する。
前記アップストリームインタフェースは、第1 FPGAエンドポイント及び第2 FPGAのエンドポイントを包含し、
前記ダウンストリームインタフェースは、構成空間を支援するFPGAのルートポートを包含し、
前記FPGAは、前記FPGAルートポートに関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記SSDから受信された第1加速コマンドをインタセプトするように動作して、前記APM-Fに前記第1加速コマンドを伝達するように動作し、
前記第1加速コマンドは、ダウンストリームFARと関連し、
前記FPGAは、
前記FPGAエンドポイントにおいて、前記プロセッサから受信された第1 PCIeトランザクションを、前記第1 FPGAのルートポート及び前記SSDの前記エンドポイントを介して前記SSDに伝達するように動作し、
前記第2FPGAのエンドポイントにおいて、前記プロセッサから受信された第2加速コマンドを前記APM-Fに伝達するよう動作し、
前記第1 FPGAのルートポートで、前記SSDから受信された前記ダウンストリームFARと関連されていない第2PCIeトランザクションを前記FPGAエンドポイントを介して前記プロセッサに伝達するよう動作し、
前記第2FPGAのルートポートで、前記SSDから受信された第1加速コマンドを前記APM-Fに伝達するように動作する。
前記FPGAは、前記FPGAから前記ダウンストリームFARを含むFPGAアドレスのブロックの要請を前記ストレージデバイスから受信するように動作し、
前記FPGAは、前記構成空間から前記FPGAアドレスの前記ブロックを割り当てるように動作し、
前記FPGAは、前記第1 FPGAのプロセッサから少なくとも前記FPGAアドレスの前記ブロックほど大きなホストシステムアドレスのブロックを要請するように動作する。
プロセッサと通信するためのアップストリームインタフェースと、
加速モジュール及びストレージデバイスと通信するためのダウンストリームインタフェースを包含し、
前記プロセッサ上でアプリケーションが実行され、
前記第1ブリッジ構成要素(コンポーネント)は、PCIe(Peripheral Component Interconnect Exchange)バスを使用して、前記プロセッサ、前記加速モジュール及び前記ストレージデバイスと通信し、
前記ダウンストリームインタフェースは、前記PCIeトランザクションが加速コマンドを包含しているか否かに応じて前記プロセッサから前記加速モジュール又は前記ストレージデバイスにPCIeトランザクションを伝達するように動作する。
説明171において、
前記加速モジュールは、FPGA(Field Programmable Gate Array)を使用して具現され、
前記ストレージデバイスは、SSD(Solid State Drive)を含む。
前記プロセッサ及び前記加速モジュールと通信するための第2アップストリームインタフェースと、及び
前記ストレージデバイスと通信するための第2ダウンストリームインタフェースを包含し、
前記第2ブリッジコンポーネントは、PCIe(Peripheral Component Interconnect Exchange)バスを使用して、前記プロセッサ、前記加速モジュール及び前記ストレージデバイスと通信し、
前記第2アップストリームインタフェースは、前記第2PCIeトランザクションが第2加速コマンドを包含しているか否かに応じて前記ストレージデバイスから前記プロセッサ又は前記加速モジュールに第2 PCIeトランザクションを伝達するように動作する。
アップストリームポートと、及び
前記アップストリームポートに関連されたアップストリームフィルタを包含し、
前記アップストリームフィルタは、前記プロセッサから受信されたアップストリームFARに関連された第2加速コマンドを識別するように動作し、
前記ダウンストリームインタフェースは、前記第2加速コマンドを前記加速モジュールに伝達するように動作し、前記アップストリームポートで前記プロセッサから受信されたアップストリームFARと関連されていない第3PCIeトランザクションを前記ストレージデバイスに伝送するように動作する。
前記アップストリームインタフェースは、前記ストレージデバイスの仮想機能(VF)により露出され、
前記アップストリームインタフェースは、
アップストリームポートと、
前記アップストリームポートと関連されたアップストリームフィルタを包含し、
前記アップストリームフィルタは、前記加速モジュールに対する第2加速コマンドを識別するように動作し、
前記ダウンストリームインタフェースは、前記第2加速コマンドを前記加速モジュールに伝達するように動作し、前記アップストリームポートで前記プロセッサから受信された前記アップストリームフィルタによってインタセプトされていない第3PCIeトランザクションを前記ストレージデバイスに伝送するように動作する。
前記第2加速コマンドは、前記アップストリームFARと関連し、
前記アップストリームフィルタは、アップストリームFARに関連された前記第2加速コマンドをインタセプトするように動作する。
前記第2加速コマンドは、前記VFの識別子を包含し、
前記アップストリームフィルタは、前記VFの前記識別子に関連された前記第2加速コマンドをインタセプトするように動作する。
前記アップストリームインタフェースは、前記ストレージデバイスの物理機能(PF)により露出され、
前記アップストリームインタフェースは、
アップストリームポートと、
前記アップストリームポートと関連されたアップストリームフィルタを包含し、
前記アップストリームフィルタは、前記加速モジュールに対する第2加速コマンドを識別するように動作し、
前記ダウンストリームインタフェースは、前記第2加速コマンドを前記加速モジュールに伝送するように動作し、前記アップストリームポートで前記プロセッサから受信された前記アップストリームフィルタによってインタセプトされていない第3PCIeトランザクションを前記ストレージデバイスに伝送するように動作する。
前記第2加速コマンドは、前記アップストリームFARと関連し、
前記アップストリームフィルタは、前記アップストリームFARに関連された前記第2加速コマンドをインタセプトするように動作する。
前記第2加速コマンドは、前記PFの識別子を包含し、
前記アップストリームフィルタは、前記PFの前記識別子に関連された前記第2加速コマンドをインタセプトするように動作する。
前記アップストリームインタフェースは、
エンドポイントと、
第1 PFと、及び
第2 PFを包含し、
前記ダウンストリームインタフェースは、前記プロセッサから受信されたPCIeトランザクションを前記ストレージデバイスに伝送するように動作して、前記プロセッサから受信された第2加速コマンドを前記加速モジュールに伝送するように動作し、
前記PCIeトランザクションは、前記第1 PFの第1識別子と関連し、
前記第2加速コマンドは、前記第2 PFの第2識別子と関連する。
前記アップストリームインタフェースは、
第1エンドポイントと、
第2エンドポイントを包含し、
前記ダウンストリームインタフェースは、前記プロセッサから受信された前記第1エンドポイントに関連されたPCIeトランザクションを前記ストレージデバイスに伝達するように動作して、前記プロセッサから受信された第2加速コマンドを前記加速モジュールに伝達するよう動作し、
前記第2加速コマンドは、前記第2エンドポイントと関連している。
プロセッサと加速モジュールと通信するためのアップストリームインタフェースと、
ストレージデバイスと通信するためのダウンストリームインタフェースを包含し、
前記第1ブリッジコンポーネントは、PCIe(Peripheral Component Interconnect Exchange)バスを使用して、前記プロセッサ、前記加速モジュール及び前記ストレージデバイスと通信し、
前記アップストリームインタフェースは、前記PCIeトランザクションが加速コマンドを包含しているか否かに応じて前記ストレージデバイスから前記プロセッサ又は前記加速モジュールにPCIeトランザクションを伝達するように動作する。
前記加速モジュールは、FPGA(Field Programmable Gate Array)を使用して具現され、
前記ストレージデバイスは、SSD(Solid State Drive)を含む。
ダウンストリームインタフェースは、
ダウンストリームポートと、及び
前記ストレージデバイスから受信したダウンストリームフィルタのアドレス範囲(FAR)に関連される加速コマンドを識別するように動作するダウンストリームフィルタを包含し、
前記ダウンストリームインタフェースは、前記加速コマンドを前記加速モジュールに伝送するように動作して、前記ダウンストリームポートで、前記ストレージデバイスから受信された前記ダウンストリームFARと関連されていない第2PCIeトランザクションを前記プロセッサに伝達するように動作する。
ダウンストリームインタフェースは、
ルートポートと、
前記ルートポートに関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記ストレージデバイスから受信したダウンストリームフィルタのアドレス範囲(FAR)と関連された加速コマンドを識別するように動作し、
前記ダウンストリームインタフェースは、前記加速コマンドを前記加速モジュールに伝達するように動作して、前記ダウンストリームポートで、前記ストレージデバイスから受信された前記ダウンストリームFARと関連されていない第2PCIeトランザクションを前記プロセッサに伝達するように動作する。
ダウンストリームインタフェースは、
第1ルートポートと、
第2ルートポートを包含し、
前記ダウンストリームインタフェースは、前記第1ルートポートで、前記ストレージデバイスから受信された第2PCIeトランザクションを前記プロセッサに伝達するように動作し、前記第2ルートポートで、前記ストレージデバイスから受信された加速コマンドを前記加速モジュールに伝送するように動作する。
加速プラットフォームマネージャ(APM-F)を含む加速モジュールと通信するための前記ストレージデバイスのエンドポイントと、
前記ストレージデバイスの動作を管理するためのコントローラと、
アプリケーションに対するアプリケーションデータを格納するストアと、及び
前記加速コマンドを実行するのに前記APM-Fを補助するためのストレージデバイスの加速プラットフォームマネージャ(APM-S)を包含し、
前記ストレージデバイス及び前記加速モジュールは、PCIe(Peripheral Component Interconnect Exchange)バスを使用して通信し、
前記加速モジュールは、プロセッサと関連されたメモリに、前記アプリケーションデータをローディングすることなく、前記アプリケーションに対するストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援する。
前記SSDはダウンストリームFARに関連された加速コマンドを前記加速モジュールに伝送するように動作し、
前記第1 PCIeトランザクションは、前記APM-Fのために具現され、
前記SSDは、前記ダウンストリームFARと関連されていない第1 PCIeトランザクションを、前記加速モジュールに伝送するように動作し、
前記第1 PCIeトランザクションは、前記プロセッサのために具現される。
前記SSDは、前記プロセッサから前記ホストシステムのブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARのように、前記ホストシステムのブロックのサブセットを選択するように動作する。
前記PFは、前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARとして、前記ホストシステムアドレスの前記ブロックの第1サブセットを選択するように動作する。
前記第1 PFは、前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARのように、前記ホストシステムアドレスの前記ブロックの第1サブセットを選択するように動作する。
前記SSDは、前記プロセッサから加速モジュールのブロックを要請するように動作し、
前記コントローラは、前記ダウンストリームFARのように、前記加速モジュールの前記ブロックのサブセットを選択するように動作する。
前記SSDの前記エンドポイントは、前記プロセッサと通信するために使用され、
前記SSDの前記第2エンドポイントは、前記APM-Fと通信するために使用される。
加速モジュールで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップと、
前記加速モジュールにおいて、前記PCIeトランザクションが加速コマンドか否かを判断するステップと、
前記PCIeトランザクションが、前記加速コマンドであることを判断することについて、少なくとも部分的に基づいて、前記加速モジュールの加速プラットフォームマネージャ(APM-F)において、前記PCIeトランザクションを処理するステップと、及び
前記PCIeトランザクションが、前記加速コマンドではないことを判断することに少なくとも部分的に基づいて、前記PCIeトランザクションを第2デバイスに伝達するステップを包含し、
前記加速モジュールは、プロセッサと関連されたメモリにアプリケーションのデータをローディングすることなく、アプリケーションに対するストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援し、
前記プロセッサ、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信する。
前記加速モジュールにおいて、前記第1デバイスから前記PCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAのエンドポイントにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記PCIeトランザクションが、前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが前記FPGAの第1 PFの識別子を有するタグを含んでいるか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップを含む。
前記FPGAの前記ルートポートで、前記ストレージデバイスから第1 PCIeトランザクションを受信するステップと、
前記FPGAのダウンストリームを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、
前記ダウンストリームFARを前記FPGAの前記ルートポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMはダウンストリームFARを含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが前記FPGAの前記アップストリームポートと関連されたアップストリームフィルタドレス範囲(FAR)内のアドレスに関連されるか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第1 PCIeトランザクションが前記第2加速コマンドであることを判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第1 PCIeトランザクションが前記第2の加速コマンドではないことを判断することに少なくとも部分的に基づいて、前記FPGAの前記ダウンストリームポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記アップストリームFARを受信するステップと、及び
前記アップストリームFARを前記FPGAの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMはアップストリームFARを含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが前記ストレージデバイスによって露出される仮想機能(VF)と関連されるか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第1 PCIeトランザクションが前記第2加速コマンドであることを判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、
前記第1 PCIeトランザクションが前記第2加速コマンドではないことを判断することに少なくとも部分的に基づいて、前記FPGAの前記ダウンストリームポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記VFの前記識別子を受信するステップと、及び
前記VFの前記識別子を前記FPGAの前記アップストリームポートに連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記VFの前記識別子を含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが前記ストレージデバイスによって露出される物理機能(PF)と関連されるか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第1 PCIeトランザクションが前記第2加速コマンドであることを判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第1 PCIeトランザクションが前記第2加速コマンドではないことを判断することに少なくとも部分的に基づいて、前記FPGAの前記ダウンストリームポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記ストレージデバイスから、前記FPGAにおいて、前記PFの前記識別子を受信するステップと、及び
前記PFの前記識別子を前記FPGAの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記PFの前記識別子を含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAのエンドポイントにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記PCIeトランザクションが、前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが前記FPGAの第1 PFの第1識別子を有するタグを含んでいるか、又は前記FPGAの第2 PFの第2識別子を有するタグを含んでいるか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2のデバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップを含む。
前記FPGAの前記ルートポートで、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記FPGAで前記第2 PCIeトランザクションが、前記FPGAの前記ルートポートに関連されたダウンストリームFAR内のアドレスと関連されているか否かを判断することにより、前記第2PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第2 PCIeトランザクションが前記第2加速コマンドであると判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第2 PCIeトランザクションが前記第2加速コマンドではないと判断することに少なくとも部分的に基づいて、前記FPGAの前記エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、及び
前記ダウンストリームFARを前記FPGAの前記ルートポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記ダウンストリームFARを含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記ルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、
前記FPGAのエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAのエンドポイントにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記PCIeトランザクションが、前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが前記FPGAの第1 PFの第1識別子を有するタグを含んでいるか、又は前記FPGAの第2 PFの第2識別子を持つタグを含んでいるか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションを第2ストレージデバイスに伝達するステップを含む。
前記FPGAにおいて、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記第2 PCIeトランザクションが前記FPGAの第1ルートポートで受信されるか、又は前記FPGAの第2ルートポートで受信されるか否かを判断するステップと、
前記第2 PCIeトランザクションが、前記FPGAの前記第1のルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、及び
前記第2 PCIeトランザクションが、前記FPGAの前記第2のルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記FPGAの前記AMP-Fで前記第2 PCIeトランザクションを処理するステップと、をさらに含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記第1のルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記FPGAの前記エンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記FPGAで前記第1 PCIeトランザクションが前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが第1エンドポイント及び第2エンドポイントを含む前記FPGAの第1エンドポイントにおいて、前記プロセッサから受信されるか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、第1ルートポート及び第2ルートポートを含む前記FPGAの第1ルートポートを使用して前記第1 PCIeトランザクションをストレージデバイスに伝達するステップを含む。
前記FPGAにおいて、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記第2 PCIeトランザクションが前記FPGAの第1ルートポートで受信されるか、又は前記FPGAの第2ルートポートで受信されるか否かを判断することにより、前記第2のPCIeトランザクションが、前記加速コマンドか否かを判断するステップと、
前記第2 PCIeトランザクションが、前記FPGAの前記第1ルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記第1エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、及び
前記第2 PCIeトランザクションが、前記FPGAの前記第2ルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記FPGAの前記AMP-Fで前記第2 PCIeトランザクションを処理するステップと、をさらに含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記第1ルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、
前記FPGAの前記第1のエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記第1 PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが第1エンドポイント及び第2エンドポイントを含む前記FPGAの第1エンドポイントにおいて、前記プロセッサから受信されるか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションをストレージデバイスに伝達するステップを含む。
前記FPGAの前記ルートポートで、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記FPGAで前記第2 PCIeトランザクションが前記FPGAのルートポートと関連されたダウンストリームFAR内のアドレスと関連されるか否かを判断することにより、前記第2PCIeトランザクションが、前記加速コマンドか否かを判断するステップと、
前記第2 PCIeトランザクションが、前記加速コマンドか否かを判断することに、少なくとも部分的に基づいて、前記第2 PCIeトランザクションを前記FPGAの前記APM-Fで処理するステップと、及び
前記第2 PCIeトランザクションが、前記加速コマンドではないか判断することに、少なくとも部分的に基づいて、前記FPGAの前記第1エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、及び
前記ダウンストリームFARを前記FPGAの前記ルートポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMはダウンストリームFARを含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記ルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記FPGAの前記第1エンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
第1ブリッジコンポーネントで、プロセッサからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップと、
前記第1ブリッジコンポーネントで、前記PCIeトランザクションが加速コマンドか否かを判断するステップと、
前記PCIeトランザクションが、前記加速コマンドであると判断することについて、少なくとも部分的に基づいて、前記PCIeトランザクションを加速モジュールに伝達するステップと、及び
前記PCIeトランザクションが、前記加速コマンドではないと判断することに少なくとも部分的に基づいて、前記PCIeトランザクションをストレージデバイスに伝達するステップを包含し、
前記プロセッサ、前記加速モジュール及び前記ストレージ装デバイスは、PCIeバスを使用して通信する。
前記加速モジュールは、FPGAを使用して具現され、
前記ストレージデバイスは、SSDを含む。
前記第1ブリッジコンポーネントで、前記PCIeトランザクションが加速コマンドか否かを判断するステップは、前記PCIeトランザクションが第1ブリッジコンポーネントのアップストリームポートに関連されたアップストリームFAR内のアドレスと関連されているか否かを判断するステップと、をさらに含む。
前記第1ブリッジコンポーネントにおいて、前記ストレージデバイスから前記アップストリームFARを受信するステップと、及び
前記アップストリームFARを前記第1ブリッジコンポーネントの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記アップストリームFARを含む。
前記第1ブリッジコンポーネントで、前記PCIeトランザクションが加速コマンドか否かを判断するステップは、前記PCIeトランザクションが前記ストレージデバイスによって露出される仮想機能(VF)と関連されるか否かを判断するステップを含む。
前記第1ブリッジコンポーネントにおいて、前記ストレージデバイスから前記VFの前記識別子を受信するステップと、及び
前記VFの前記識別子を前記第1ブリッジコンポーネントの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記VFの前記識別子を含む。
前記第1ブリッジコンポーネントにおいて、前記ストレージデバイスから前記PFの前記識別子を受信するステップと、及び
前記PFの前記識別子を前記第1ブリッジコンポーネントの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びイSMバスを含むセットから得られる。
前記PCIe VDMは、前記PFの前記識別子を含む。
前記第1ブリッジ構成要素の構成モニタを使用して、前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記第1構成要素のエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
前記第1ブリッジ構成要素の構成モニタを使用して、前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、
前記第1構成要素のエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
第2ブリッジコンポーネントでストレージからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップと、
前記第2ブリッジコンポーネントで、前記PCIeトランザクションが加速コマンドか否かを判断するステップと、
前記PCIeトランザクションが、前記加速コマンドであると判断することについて、少なくとも部分的に基づいて、前記PCIeトランザクションを加速モジュールに伝達するステップと、及び
前記PCIeトランザクションが、前記加速コマンドではないと判断することに少なくとも部分的に基づいて、前記PCIeトランザクションをストレージデバイスに伝達するステップを包含し、
前記プロセッサ、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信する。
前記加速モジュールは、FPGA(Field Programmable Gate Array)を使用して具現され、
前記ストレージデバイスは、SSD(Solid State Drive)を含む。
前記第2ブリッジコンポーネントで、前記PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第2ブリッジコンポーネントにおいて、前記第2 PCIeトランザクションが前記第2ブリッジコンポーネントのダウンストリームポートと関連されたダウンストリームFAR内のアドレスと関連されているか否かを判断するステップと、をさらに含む。
前記第2ブリッジコンポーネントにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、及び
前記ダウンストリームFARを前記第2ブリッジコンポーネントの前記ダウンストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記ダウンストリームFARを含む。
ストレージデバイスで加速モジュールから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが仮想コマンドであるか否かを判断するステップと、
前記第1 PCIeトランザクションが前記仮想コマンドであるかを判断することに、少なくとも部分的に基づいて、
前記ストレージデバイスのAPM-Sを使用して、第2 PCIeトランザクションを生成するステップと、及び
前記第2 PCIeトランザクションを前記ストレージデバイスから前記加速モジュールに伝送するステップを包含し、
プロセッサ、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信し、
前記加速モジュールは、前記プロセッサと関連されたメモリに、前記アプリケーションデータをローディングすることなく、前記のプロセッサ上で実行中の前記アプリケーションに対するストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援する。
ストレージデバイスの加速モジュールから第1 PCIeトランザクションを受信するステップは、前記SSDのエンドポイントにおいて、前記加速モジュールから前記第1 PCIeトランザクションを受信するステップを包含し、
前記第1 PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションがプロセッサからの特定のコマンドを含んでいるか、又は前記第1 PCIeトランザクションが前記加速モジュールの前記APM-Fから由来するか否かを判断するステップを包含し、
前記ストレージデバイスのAPM-Sを使用して、第2のPCIeトランザクションを生成するステップは、前記第1 PCIeトランザクションに応答して、前記SSDのAPM-Sにより、前記第2のPCIeトランザクションを生成するステップを包含し、
前記第2 PCIeトランザクションを前記ストレージデバイスから前記加速モジュールに伝送するステップは、前記第2 PCIeトランザクションをストレージデバイスの前記エンドポイントから前記加速モジュールに伝送するステップを含む。
前記プロセッサからホストシステムアドレスのブロックを要請するステップと、
ダウンストリームFARのように、前記ホストシステムアドレスの前記ブロックのサブセットを選択するステップと、
前記加速モジュールのダウンストリームポートを前記ダウンストリームFARでプログラミングするステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
アップストリームFARのように、前記ホストシステムアドレスの前記ブロックの第2サブセットを選択するステップと、及び
前記加速モジュールのアップストリームポートを前記アップストリームFARでプログラミングするステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記プロセッサからホストシステムアドレスのブロックを要請するステップと、
ダウンストリームFARのように、前記ホストシステムアドレスの前記ブロックの前記サブセットを選択するステップと、及び
前記加速モジュールのルートポートを前記加速モジュールでプログラミングするステップと、をさらに含む。
前記SSDの前記エンドポイントから前記加速モジュールから前記第1 PCIeトランザクションの結果を受信するステップと、及び
前記SSDの前記エンドポイントを使用して前記第1 PCIeトランザクションの前記の結果を前記プロセッサに伝達するステップと、をさらに含む。
前記SSDを露出する物理機能(PF)を提供するステップと、
前記加速モジュールを露出する仮想機能(VF)を提供するステップと、をさらに含む。
前記SSDを露出する第1 PFを提供するステップと、及び
前記加速モジュールを露出する第2 PFを提供するステップと、をさらに含む。
ストレージデバイスの加速モジュールから第1 PCIeトランザクションを受信するステップは、前記SSDのエンドポイントにおいて、前記加速モジュールから前記第1 PCIeトランザクションを受信するステップを包含し、
前記第1 PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが第2エンドポイントで第1エンドポイント及び前記第2エンドポイントを含むSSDによって受信されるか否かを判断するステップを包含し、
前記ストレージデバイスのAPM-Sを使用して、第2PCIeトランザクションを生成するステップは、前記第1 PCIeトランザクションに応答して、前記SSDのAPM-Sにより、前記第2PCIeトランザクションを生成するステップを包含し、
前記第2 PCIeトランザクションを前記ストレージデバイスから前記加速モジュールに伝送するステップは、前記第2 PCIeトランザクションを前記ストレージデバイスの前記エンドポイントから前記加速モジュールに伝送するステップを含む。
加速モジュールで第1デバイスからPCIeトランザクションを受信するステップと、
前記PCIeトランザクションが仮想コマンドであるか否かを判断するステップと、
前記PCIeトランザクションが、前記仮想コマンドであるかを判断することに、少なくとも部分的に基づいて前記加速モジュールのAPM-Fで前記PCIeトランザクションを処理するステップと、
前記PCIeトランザクションが、前記仮想コマンドであるが否かを判断することに、少なくとも部分的に基づいて前記PCIeトランザクションを第2デバイスに伝送するステップを包含し、
前記加速モジュールは、前記プロセッサと関連されたメモリに、前記アプリケーションデータをローディングすることなく、前記アプリケーションに対するストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援し、
前記プロセッサ、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信する。
前記FPGAで前記第1デバイスから前記PCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAのエンドポイントにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記PCIeトランザクションが、前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが前記FPGAの第1 PFの識別子を有するタグを含んでいるか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップを含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、及び
前記FPGAの前記ダウンストリームプロセッサを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、及び
前記ダウンストリームFARを前記FPGAの前記ダウンストリームポートと連結するステップと、をさらに含む方法。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記ダウンストリームFARを含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが前記FPGAの前記アップストリームポートと関連されたアップストリームFAR内の第2アドレスと関連されているか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第1 PCIeトランザクションが前記第2の加速コマンドであると判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第1 PCIeトランザクションが前記第2の加速コマンドではないと判断することに少なくとも部分的に基づいて、前記FPGAの前記ダウンストリームポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記アップストリームFARを受信するステップと、及び
前記アップストリームFARを前記FPGAの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMはアップストリームFARを含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが前記ストレージデバイスによって露出する仮想機能(VF)と関連されているか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第1 PCIeトランザクションが前記第2加速コマンドであると判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第1 PCIeトランザクションが前記第2加速コマンドではないと判断することに少なくとも部分的に基づいて、前記FPGAの前記ダウンストリームポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記VFの前記識別子を受信するステップと、及び
前記ダウンストリームFARを前記FPGAの前記アップストリームポートに連結するステップと、をさらに含む方法。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記VFの前記識別子を含む。
前記FPGAの前記アップストリームポートで前記プロセッサから第1 PCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが前記ストレージデバイスによって露出する仮想機能(VF)と関連されているか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第1 PCIeトランザクションが前記第2加速コマンドであると判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第1 PCIeトランザクションが前記第2加速コマンドではないと判断することに少なくとも部分的に基づいて、前記FPGAの前記ダウンストリームポートを使用して前記第1 PCIeトランザクションを前記ストレージデバイスに伝達するステップと、をさらに含む。
前記ストレージデバイスから、前記FPGAにおいて、前記PFの前記識別子を受信するステップと、及び
前記PFの前記識別子を前記FPGAの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記PFの前記識別子を含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAのエンドポイントにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記PCIeトランザクションが、前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが前記FPGAの第1 PFの識別子を有するタグを含んでいるか、又は前記FPGAの第2 PFの第2識別子を有するタグを含んでいるか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションを第2のストレージデバイスに伝達するステップを含む。
前記FPGAの前記ルートポートで、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記FPGAで前記第2 PCIeトランザクションが、前記FPGAの前記ルートポートに関連されたダウンストリームFAR内のアドレスと関連されるか否かを判断することにより、前記第2PCIeトランザクションが第2加速コマンドか否かを判断するステップと、
前記第2 PCIeトランザクションが前記第2の加速コマンドであると判断することに、少なくとも部分的に基づいて、前記FPGAの前記APM-Fで、前記第1 PCIeトランザクションを処理するステップと、及び
前記第2 PCIeトランザクションが前記第2の加速コマンドではないと判断することに少なくとも部分的に基づいて、前記FPGAの前記エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップを含む。
前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、及び
前記ダウンストリームFARを前記FPGAの前記ルートポートと連結するステップを含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記ダウンストリームFARを含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記ルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記FPGAのエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAのエンドポイントにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記PCIeトランザクションが、前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが前記FPGAの第1 PFの第1識別子を有するタグを含んでいるか、又は前記FPGAの第2 PFの第2識別子を有するタグを含んでいるか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションを第2ストレージデバイスに伝達するステップを含む。
前記FPGAにおいて、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記第2 PCIeトランザクションが前記FPGAの第1ルートポートで受信されるか、又は前記FPGAの第2ルートポートで受信されるか否かを判断するステップと、
前記第2 PCIeトランザクションが、前記FPGAの前記第1のルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、及び
前記第2 PCIeトランザクションが、前記FPGAの前記第2のルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記FPGAの前記AMP-Fで前記第2 PCIeトランザクションを処理するステップと、をさらに含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記第1のルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記FPGAの前記エンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記FPGAで前記第1 PCIeトランザクションが前記加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが第1エンドポイント及び第2エンドポイントを含む前記FPGAの第1エンドポイントにおいて、前記プロセッサから受信されるかか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに伝達するステップは、第1ルートポート及び第2ルートポートを含む前記FPGAの第1ルートポートを使用して前記第1 PCIeトランザクションをストレージデバイスに伝達するステップを含む。
前記FPGAにおいて、前記記憶装置から第2 PCIeトランザクションを受信するステップと、
前記第2 PCIeトランザクションが前記FPGAの第1ルートポートで受信されるか、又は前記FPGAの第2ルートポートで受信されるか否かを判断することにより、前記第2PCIeトランザクションが、前記加速コマンドか否かを判断するステップと、
前記第2 PCIeトランザクションが、前記FPGAの前記第1のルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記第1エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、及び
前記第2 PCIeトランザクションが、前記FPGAの前記第2ルートポートで受信されるかを判断することに、少なくとも部分的に基づいて、前記FPGAの前記AMP-Fで前記第2 PCIeトランザクションを処理するステップと、をさらに含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記第1ルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記FPGAの前記第1エンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
FPGAで第1デバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップは、前記FPGAにおいて、前記プロセッサから第1 PCIeトランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記第1 PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが第1エンドポイント及び第2エンドポイントを含む前記FPGAの第1エンドポイントにおいて、前記プロセッサから受信されるか否かを判断することにより、前記第1 PCIeトランザクションが第2加速コマンドか否かを判断するステップを包含し、
前記PCIeトランザクションを前記第2デバイスに転送するステップは、前記FPGAのルートポートを使用して前記第1 PCIeトランザクションをストレージデバイスに伝達するステップを含む。
前記FPGAの前記ルートポートで、前記ストレージデバイスから第2 PCIeトランザクションを受信するステップと、
前記FPGAで前記第2 PCIeトランザクションが前記FPGAのルートポートと関連されたダウンストリームFAR内のアドレスと関連されているか否かを判断することにより、前記第2PCIeトランザクションが、前記加速コマンドか否かを判断するステップと、
前記第2 PCIeトランザクションが、前記加速コマンドであるかを判断することに、少なくとも部分的に基づいて、前記第2 PCIeトランザクションを前記FPGAの前記APM-Fで処理するステップと、及び
前記第2 PCIeトランザクションが、前記加速コマンドではないか判断することに、少なくとも部分的に基づいて、前記FPGAの前記第1エンドポイントを使用して前記第2 PCIeトランザクションを前記プロセッサに伝達するステップと、をさらに含む。
前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、及び
前記ダウンストリームFARを前記FPGAの前記ルートポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMはダウンストリームFARを含む。
前記FPGAの構成モニタを使用して、前記FPGAの前記ルートポートと通信する前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、及び
前記FPGAの前記第1エンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
ストレージデバイスで加速モジュールからPCIeトランザクションを受信するステップと、
前記第1 PCIeトランザクションが仮想コマンドであるか否かを判断するステップと、
前記第1 PCIeトランザクションが前記仮想コマンドであるかを判断することに、少なくとも部分的に基づいて、前記ストレージデバイスのAPM-Sを使用して、第2PCIeトランザクションを生成するステップと、
前記第2 PCIeトランザクションを前記ストレージデバイスから前記加速モジュールに伝送するステップと、
前記第1 PCIeトランザクションが前記仮想コマンドではないかを判断することに、少なくとも部分的に基づいて前記ストレージデバイスに格納されたデータに対して前記第1 PCIeトランザクションを実行するステップを包含し、
プロセッサ、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信し、
前記加速モジュールは、前記プロセッサと関連されたメモリに、前記アプリケーションデータをローディングすることなく、前記のプロセッサ上で実行中の前記アプリケーションに対するストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援する。
ストレージデバイスの加速モジュールから第1 PCIeトランザクションを受信するステップは、前記SSDエンドポイントにおいて、前記加速モジュールから前記第1 PCIeトランザクションを受信するステップを包含し、
前記第1 PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションがプロセッサからの特定のコマンドを含んでいるか、又は前記第1 PCIeトランザクションが前記加速モジュールの前記APM-Fから由来するか否かを判断するステップを包含し、
前記ストレージデバイスのAPM-Sを使用して、第2PCIeトランザクションを生成するステップは、前記第1 PCIeトランザクションに応答して、前記SSDのAPM-Sにより、前記第2PCIeトランザクションを生成するステップを包含し、
前記第2 PCIeトランザクションを前記ストレージデバイスから前記加速モジュールに伝送するステップは、前記第2 PCIeトランザクションを前記ストレージデバイスの前記エンドポイントから前記加速モジュールに伝送するステップを含む。
前記プロセッサからホストシステムアドレスのブロックを要請するステップと、
ダウンストリームFARのように、前記ホストシステムアドレスの前記ブロックのサブセットを選択するステップと、
前記加速モジュールのダウンストリームポートを前記ダウンストリームFARでプログラミングするステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
アップストリームFARのように、前記ホストシステムアドレスの前記ブロックの第2サブセットを選択するステップと、
前記加速モジュールのアップストリームポートを前記アップストリームFARでプログラミングするステップと。をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記プロセッサからホストシステムアドレスのブロックを要請するステップと、
ダウンストリームFARのように、前記ホストシステムアドレスの前記ブロックの前記サブセットを選択するステップと、
前記加速モジュールのルートポートを前記加速モジュールでプログラミングするステップと、をさらに含む。
前記SSDの前記エンドポイントを使用して前記第1 PCIeトランザクションの前記結果を前記プロセッサに伝達するステップと、をさらに含む。
前記SSDを露出する物理機能(PF)を提供するステップと、
前記加速モジュールを露出する仮想機能(VF)を提供するステップと、をさらに含む。
前記SSDを露出する第1 PFを提供するステップと、
前記加速モジュールを露出する第2 PFを提供するステップと、をさらに含む。
ストレージデバイスの加速モジュールから第1 PCIeトランザクションを受信するステップは、前記SSDのエンドポイントにおいて、前記加速モジュールから前記第1 PCIeトランザクションを受信するステップを包含し、
前記第1 PCIeトランザクションが加速コマンドか否かを判断するステップは、前記第1 PCIeトランザクションが第2エンドポイントで第1エンドポイント及び前記第2エンドポイントを含むSSDによって受信されるか否かを判断するステップを包含し、
前記ストレージデバイスのAPM-Sを使用して、第2のPCIeトランザクションを生成するステップは、前記第1 PCIeトランザクションに応答して、前記SSDのAPM-Sにより、前記第2のPCIeトランザクションを生成するステップを包含し、
前記第2 PCIeトランザクションを前記ストレージデバイスから前記加速モジュールに伝送するステップは、前記第2 PCIeトランザクションを前記ストレージデバイスの前記エンドポイントから前記加速モジュールに伝送するステップを含む。
第1ブリッジコンポーネントで第1デバイスからPCIeトランザクションを受信するステップと、
前記第1ブリッジコンポーネントで、前記PCIeトランザクションが仮想コマンドであるかど否かを判断するステップと、
前記PCIeトランザクションが、前記仮想コマンドであるかを判断することに、少なくとも部分的に基づいて前記PCIeトランザクションを加速モジュールに伝達するステップと、
前記PCIeトランザクションが、前記仮想コマンドではないかを判断することに、少なくとも部分的に基づいて前記PCIeトランザクションをストレージデバイスに伝達するステップを包含し、
前記プロセッサ、前記第1ブリッジのコンポーネント、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信する。
前記加速モジュールは、FPGAを使用して具現され、
前記ストレージデバイスは、SSDを含む。
前記第1ブリッジコンポーネントにおいて、前記ストレージデバイスから前記アップストリームFARを受信するステップと、
前記アップストリームFARを前記第1ブリッジコンポーネントの前記アップストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記アップストリームFARを含む。
前記第1ブリッジコンポーネントで、前記ストレージデバイスから前記VFの前記識別子を受信するステップと、
前記VFの前記識別子を前記第1ブリッジコンポーネントの前記アップストリームポートと連結するステップと、をさらに含む方法。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記VFの前記識別子を含む。
前記第1ブリッジコンポーネントで、前記ストレージデバイスから前記PFの前記識別子を受信するステップと、
前記PFの前記識別子を前記第1ブリッジコンポーネントの前記アップストリームポートと連結するステップと、をさらに含む方法。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記PFの前記識別子を含む。
前記第1ブリッジコンポーネントの構成モニタを使用して、前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、
前記第1コンポーネントのエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
前記第1ブリッジコンポーネントの構成モニタを使用して、前記ストレージデバイスの前記エンドポイントの構成を判断するステップと、
前記第1コンポーネントのエンドポイントを使用して、前記ストレージデバイス上の前記エンドポイントの前記構成をコピーするステップと、をさらに含む。
第2ブリッジコンポーネントでストレージデバイスからPCIe(Peripheral Component Interconnect Exchange)トランザクションを受信するステップと、
前記第2ブリッジコンポーネントで、前記PCIeトランザクションが加速コマンドか否かを判断するステップと、
前記PCIeトランザクションが、前記加速コマンドであると判断することについて、少なくとも部分的に基づいて、前記PCIeトランザクションを加速モジュールに伝達するステップと、
前記PCIeトランザクションが、前記加速コマンドではないと判断することに少なくとも部分的に基づいて、前記PCIeトランザクションをプロセッサに伝達するステップを包含し、
前記プロセッサ、前記第2ブリッジコンポーネント、前記加速モジュール及び前記ストレージデバイスは、PCIeバスを使用して通信する。
前記加速モジュールは、FPGA(Field Programmable Gate Array)を使用して具現され、
前記ストレージデバイスは、SSD(Solid State Drive)を含む。
前記第2ブリッジコンポーネントにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、
前記ダウンストリームFARを前記第2ブリッジコンポーネントの前記ダウンストリームポートと連結するステップと、をさらに含む。
前記サイドバンドバスはI2Cバス及びSMバスを含むセットから得られる。
前記PCIe VDMは、前記ダウンストリームFARを含む。
110 プロセッサ
115 デバイスドライバ
120 SSD、ストレージデバイス
125 アプリケーション
130 アプリケーションサービスマネージャ(ASM)
135 メモリコントローラ
140 主メモリ
145 加速モジュール(又はFPGA)
205 クロック
210 ネットワークコネクタ
215 バス
220 ユーザインタフェース
225 I/Oエンジン
305、1105、1310、1505 エンドポイント(EP)
310 ホストインタフェース層(HIL)
315 SSD加速プラットフォームマネージャ(APM-S)
320 フラッシュ変換階層(FTL)
325 フラッシュメディア
330 アップストリームポート(USP)
335 ダウンストリームポート(DSP)
340 FPGA加速プラットフォームマネージャ(APM-F)
345 スケジューラ
350-1、350-2 加速エンジン
355 メッセージメールボックス
360 ダウンストリームフィルタ(DSF)
365 サイドバンドバス(I2Cバス、又はSMバス)
370 SSDコントローラ
405、805、810 ブロック
410 サブセット(NVMe向け)
415 他のサブセット420 サブセット、ダウンストリームFAR(フィルタアドレスレンジ)
505 アップストリームフィルタ(USF)
605 サブセット、アップストリームFAR(フィルタアドレスレンジ)
705、905、1115、1120 物理機能(PF、physical_function)
710 仮想機能(VF、virtual_function))
715 VFフィルタ、PFフィルタ
1005、1010、1215,1220、1405、2105、2125、2203、2206、2215、2221,2227,2230など ブロック
1110、1305 ルートポート(RP)
1125 構成モニタ、構成モジュール
1205、1215、1220、1405 メモリアドレスのブロック
1210 FPGAメモリアドレスマップ1
1410 FPGAメモリアドレスマップ2
1905、1910 ブリッジ構成要素(ブリッジコンポーネント)
2005、2020 PCIeトランザクション
2015 加速コマンド
2030、2035、2040 結果
BAR ベースアドレスレジスタ(Base Address Register)
FTL Flash Translation Layer
HIL ホストインタフェースロジック
OS オペレーティングシステム
RT ランタイム
TLP トランザクション階層パケット(PCIeトランザクション)
VDM ベンダ定義メッセージ(Vendor Defined Messages)
Claims (20)
- アプリケーションを実行するプロセッサと、
前記プロセッサ上で実行中の前記アプリケーションに関連したデータを格納するメモリと、
前記プロセッサと通信するための第1インタフェースと、
ストレージデバイスと通信するための第2インタフェースと、
ハードウェアを使用して具現されて加速コマンドを実行するための第1加速マネージャを含む加速モジュールと、
前記ストレージデバイスと、を備え、
前記ストレージデバイスは、
前記加速モジュールと通信するための前記ストレージデバイスの第3インタフェースと、
前記ストレージデバイスの動作を管理するためのコントローラと、
前記アプリケーションに対するアプリケーションデータを格納するためのストアと、
前記加速コマンドを実行する際に前記第1加速マネージャを補助するための第2加速マネージャと、を含み、
前記プロセッサ、前記加速モジュール、及び前記ストレージデバイスは、少なくとも1つのバスを介して通信し、
前記加速モジュールは、前記アプリケーションのための前記ストレージデバイス上の前記アプリケーションデータに対する前記加速コマンドを遂行することを支援する、ことを特徴とするシステム。 - 前記プロセッサと前記加速モジュールとの間の通信を連結(bridging)し、前記第1インタフェースを含む第1ブリッジコンポーネントと、
前記加速モジュールと前記ストレージデバイスとの間の通信を連結し、前記第2インタフェースを含む第2ブリッジコンポーネントと、をさらに備える、ことを特徴とする請求項1に記載のシステム。 - 前記加速モジュールは、FPGA(Field Programmable Gate Array、フィールドプログラマブルゲートアレイ)を使用して具現され、
前記加速モジュールは、前記第1インタフェース及び前記第2インタフェースを包含し、
前記ストレージデバイスは、SSD(Solid State Drive、ソリッドステートドライブ)を包含する、ことを特徴とする請求項1に記載のシステム。 - 前記第2インタフェースは、構成空間を支援し、
前記FPGAは、第4インタフェース、第5インタフェース、及び前記第2インタフェースと関連されたダウンストリームフィルタ(DSF)を包含し、
前記ダウンストリームフィルタは、前記SSDから受信された第1加速コマンドをインタセプトするように動作して、前記第1加速マネージャへダウンストリームFAR(フィルタアドレスレンジ)と関連される前記第1加速コマンドを伝達するように動作し、
前記FPGAは、前記第4インタフェースに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作して前記第5インタフェースに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作して、前記プロセッサから受信された第1トランザクションを、前記SSDに伝達するように動作して、前記プロセッサから受信された第2加速コマンドを前記第1加速マネージャに伝達するよう動作し、
前記第1トランザクションは、前記第4インタフェースの第1識別子と関連され、
前記第2加速コマンドは、前記第5インタフェースの第2識別子と関連される、ことを特徴とする請求項3に記載のシステム。 - 前記SSDは、前記FPGAから前記ダウンストリームFARを含むFPGAアドレスのブロックを要請するように動作し、
前記ホストシステムアドレスの前記第2ブロックは、少なくとも前記FPGAアドレスのブロックと同じ大きさを有し、
前記コントローラは、前記ダウンストリームFARとして、前記FPGAアドレスのブロックのサブセットを選択するように動作する、ことを特徴とする請求項4に記載のシステム。 - 前記コントローラは、前記ダウンストリームフィルタを、前記ダウンストリームFARを用いてプログラミングするように動作する、ことを特徴とする請求項5に記載のシステム。
- 前記第1加速マネージャは、前記第1インタフェースを介して前記プロセッサに結果を伝送するように動作する、ことを特徴とする請求項4に記載のシステム。
- ハードウェアを利用して具現された加速モジュールであって、
加速コマンドを実行するための第1加速マネージャと、
アプリケーションを実行するプロセッサと通信するための第1インタフェースと、
前記加速コマンドを実行する際に前記第1加速マネージャを補助するための第2加速マネージャを含むストレージデバイスと通信するための第2インタフェースと、を備え、
前記加速モジュールは、少なくとも1つのバスを使用して、前記プロセッサ及び前記ストレージデバイスと通信し、
前記加速モジュールは、前記アプリケーションに対する前記ストレージデバイス上のアプリケーションデータに対して前記加速コマンドを遂行することを支援する、ことを特徴とする加速モジュール。 - 前記加速モジュールは、FPGAを使用して具現される、ことを特徴とする請求項8に記載の加速モジュール。
- 前記第2インタフェースは、構成空間を支援し、
前記FPGAは、第4インタフェース、第5インタフェース、及び前記第2インタフェースと関連されたダウンストリームフィルタを包含し、
前記ダウンストリームフィルタは、前記ストレージデバイスから受信された第1加速コマンドをインタセプトするように動作して前記第1加速コマンドを前記第1加速マネージャに伝達するよう動作し、
前記第1加速コマンドは、ダウンストリームFAR(フィルタアドレスレンジ)と関連付けられ、
前記FPGAは、前記第4インタフェースに対する前記プロセッサからホストシステムアドレスの第1ブロックを要請するように動作して、前記第5インタフェースに対する前記プロセッサからホストシステムアドレスの第2ブロックを要請するように動作し、
前記FPGAは、前記プロセッサから受信されたトランザクションを前記ストレージデバイスに伝達するように動作して、前記プロセッサから受信された第2加速コマンドを前記第1加速マネージャに伝達するよう動作し、
前記トランザクションは、前記第4インタフェースの第1識別子と関連付けられ、
前記第2加速コマンドは、前記第5インタフェースの第2識別子に関連付けられる、ことを特徴とする請求項9に記載の加速モジュール。 - 前記FPGAは、前記FPGAから前記ダウンストリームFARを含むFPGAアドレスのブロックに対する要請を前記ストレージデバイスから受信するように動作し、前記FPGAは、前記構成空間から前記FPGAアドレスのブロックを割り当てるように動作し、前記ホストシステムアドレスの第1ブロックは、少なくとも前記FPGAアドレスのブロックと同じ大きさを有する、ことを特徴とする請求項10に記載の加速モジュール。
- 前記FPGAの前記ダウンストリームフィルタ内の前記ダウンストリームFARは、前記ストレージデバイスによってプログラミングされる、ことを特徴とする請求項11に記載の加速モジュール。
- 前記第1加速マネージャは、前記第1インタフェースを介して前記プロセッサに結果を伝送するように動作する、ことを特徴とする請求項10に記載の加速モジュール。
- 前記FPGAは、前記ストレージデバイスの第3インタフェースの性能を前記第1インタフェースにコピーするための構成モニタをさらに包含する、ことを特徴とする請求項10に記載の加速モジュール。
- 加速モジュールにおいて第1デバイスからトランザクションを受信するステップと、
前記加速モジュールにおいて、前記トランザクションが加速コマンドであるか否かを判断するステップと、
前記トランザクションが、前記加速コマンドであるとの判断に少なくとも部分的に基づいて、前記加速モジュールの加速マネージャにおいて前記トランザクションを処理するステップと、
前記トランザクションが、前記加速コマンドではないとの判断に少なくとも部分的に基づいて、前記トランザクションを第2デバイスに伝達するステップを包含し、
前記加速モジュールは、アプリケーションプログラムのためのストレージデバイス上のアプリケーションデータに対する前記加速コマンドを遂行することを支援し、
プロセッサ、前記加速モジュール、及び前記ストレージデバイスは、少なくとも1つのバスを使用して通信する、ことを特徴とする方法。 - 前記加速モジュールは、FPGAを用いて具現される、ことを特徴とする請求項15に記載の方法。
- FPGAにおいて第1デバイスからトランザクションを受信するステップは、前記FPGAの第3インタフェースにおいて、前記プロセッサから第1トランザクションを受信するステップを包含し、
前記加速モジュールにおいて、前記トランザクションが、加速コマンドであるか否かを判断するステップは、前記第1トランザクションが前記FPGAの第4インタフェースの識別子を有するタグを含んでいるか否かを判断するステップを包含し、前記トランザクションを第2デバイスに伝達するステップは、前記FPGAのルートポートを使用して前記第1トランザクションを前記ストレージデバイスに伝達するステップを包含する、ことを特徴とする請求項16に記載の方法。 - 前記FPGAの前記ルートポートで、前記ストレージデバイスから第2トランザクションを受信するステップと、
前記第2トランザクションが、前記FPGAの前記ルートポートと関連されたダウンストリームFAR(フィルタアドレスレンジ)内のアドレスに関連されるか否かを、前記FPGAにおいて判断することにより、前記第2トランザクションが第2加速コマンドであるか否かを判断するステップと、
前記第2トランザクションが前記第2加速コマンドであるとの判断に少なくとも部分的に基づいて、前記FPGAの前記加速マネージャにおいて、前記第1トランザクションを処理するステップと、
前記第2トランザクションが前記第2加速コマンドではないとの判断に少なくとも部分的に基づいて、前記FPGAの前記第3インタフェースを使用して前記第2トランザクションを前記プロセッサに伝達するステップと、をさらに包含する、ことを特徴とする請求項17に記載の方法。 - 前記FPGAにおいて、前記ストレージデバイスから前記ダウンストリームFARを受信するステップと、
前記ダウンストリームFARを前記FPGAの前記ルートポートと連結するステップと、をさらに包含する、ことを特徴とする請求項18に記載の方法。 - 前記FPGAの前記第3インタフェースを使用して前記第1トランザクションの結果を前記プロセッサに伝送するステップと、をさらに包含する、ことを特徴とする請求項17に記載の方法。
Applications Claiming Priority (8)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US201862638904P | 2018-03-05 | 2018-03-05 | |
| US62/638,904 | 2018-03-05 | ||
| US201862641267P | 2018-03-09 | 2018-03-09 | |
| US62/641,267 | 2018-03-09 | ||
| US201862642568P | 2018-03-13 | 2018-03-13 | |
| US62/642,568 | 2018-03-13 | ||
| US16/122,865 US10585819B2 (en) | 2018-03-05 | 2018-09-05 | SSD architecture for FPGA based acceleration |
| US16/122,865 | 2018-09-05 |
Publications (3)
| Publication Number | Publication Date |
|---|---|
| JP2019153297A JP2019153297A (ja) | 2019-09-12 |
| JP2019153297A5 JP2019153297A5 (ja) | 2022-02-15 |
| JP7120943B2 true JP7120943B2 (ja) | 2022-08-17 |
Family
ID=67768071
Family Applications (3)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| JP2019034068A Active JP7120943B2 (ja) | 2018-03-05 | 2019-02-27 | Fpgaベースの加速のための新たなssd基本構造 |
| JP2019038574A Active JP7120945B2 (ja) | 2018-03-05 | 2019-03-04 | システム及びそのアクセラレーション方法並びにアクセラレーションモジュール |
| JP2019038498A Active JP7252789B2 (ja) | 2018-03-05 | 2019-03-04 | Ssdに対するfpgaベースのアクセラレーションモジュール及びシステムとその動作方法 |
Family Applications After (2)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| JP2019038574A Active JP7120945B2 (ja) | 2018-03-05 | 2019-03-04 | システム及びそのアクセラレーション方法並びにアクセラレーションモジュール |
| JP2019038498A Active JP7252789B2 (ja) | 2018-03-05 | 2019-03-04 | Ssdに対するfpgaベースのアクセラレーションモジュール及びシステムとその動作方法 |
Country Status (5)
| Country | Link |
|---|---|
| US (4) | US10585819B2 (ja) |
| JP (3) | JP7120943B2 (ja) |
| KR (2) | KR102427561B1 (ja) |
| CN (3) | CN110232034B (ja) |
| TW (3) | TWI772611B (ja) |
Families Citing this family (64)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US10496548B2 (en) | 2018-02-07 | 2019-12-03 | Alibaba Group Holding Limited | Method and system for user-space storage I/O stack with user-space flash translation layer |
| WO2019222958A1 (en) | 2018-05-24 | 2019-11-28 | Alibaba Group Holding Limited | System and method for flash storage management using multiple open page stripes |
| US11816043B2 (en) | 2018-06-25 | 2023-11-14 | Alibaba Group Holding Limited | System and method for managing resources of a storage device and quantifying the cost of I/O requests |
| US10921992B2 (en) | 2018-06-25 | 2021-02-16 | Alibaba Group Holding Limited | Method and system for data placement in a hard disk drive based on access frequency for improved IOPS and utilization efficiency |
| US10996886B2 (en) | 2018-08-02 | 2021-05-04 | Alibaba Group Holding Limited | Method and system for facilitating atomicity and latency assurance on variable sized I/O |
| US11327929B2 (en) | 2018-09-17 | 2022-05-10 | Alibaba Group Holding Limited | Method and system for reduced data movement compression using in-storage computing and a customized file system |
| US10977122B2 (en) | 2018-12-31 | 2021-04-13 | Alibaba Group Holding Limited | System and method for facilitating differentiated error correction in high-density flash devices |
| US11061735B2 (en) | 2019-01-02 | 2021-07-13 | Alibaba Group Holding Limited | System and method for offloading computation to storage nodes in distributed system |
| US11132291B2 (en) | 2019-01-04 | 2021-09-28 | Alibaba Group Holding Limited | System and method of FPGA-executed flash translation layer in multiple solid state drives |
| US11200337B2 (en) | 2019-02-11 | 2021-12-14 | Alibaba Group Holding Limited | System and method for user data isolation |
| US10970212B2 (en) | 2019-02-15 | 2021-04-06 | Alibaba Group Holding Limited | Method and system for facilitating a distributed storage system with a total cost of ownership reduction for multiple available zones |
| US11061834B2 (en) | 2019-02-26 | 2021-07-13 | Alibaba Group Holding Limited | Method and system for facilitating an improved storage system by decoupling the controller from the storage medium |
| US10891065B2 (en) | 2019-04-01 | 2021-01-12 | Alibaba Group Holding Limited | Method and system for online conversion of bad blocks for improvement of performance and longevity in a solid state drive |
| US10922234B2 (en) | 2019-04-11 | 2021-02-16 | Alibaba Group Holding Limited | Method and system for online recovery of logical-to-physical mapping table affected by noise sources in a solid state drive |
| US10908960B2 (en) | 2019-04-16 | 2021-02-02 | Alibaba Group Holding Limited | Resource allocation based on comprehensive I/O monitoring in a distributed storage system |
| US11169873B2 (en) | 2019-05-21 | 2021-11-09 | Alibaba Group Holding Limited | Method and system for extending lifespan and enhancing throughput in a high-density solid state drive |
| US10860223B1 (en) * | 2019-07-18 | 2020-12-08 | Alibaba Group Holding Limited | Method and system for enhancing a distributed storage system by decoupling computation and network tasks |
| US11074124B2 (en) | 2019-07-23 | 2021-07-27 | Alibaba Group Holding Limited | Method and system for enhancing throughput of big data analysis in a NAND-based read source storage |
| US11617282B2 (en) | 2019-10-01 | 2023-03-28 | Alibaba Group Holding Limited | System and method for reshaping power budget of cabinet to facilitate improved deployment density of servers |
| US11126561B2 (en) | 2019-10-01 | 2021-09-21 | Alibaba Group Holding Limited | Method and system for organizing NAND blocks and placing data to facilitate high-throughput for random writes in a solid state drive |
| FR3104280B1 (fr) * | 2019-12-06 | 2021-11-26 | Thales Sa | Systeme electronique securise comportant un processeur et un composant memoire ; composant programmable associe |
| US11507522B2 (en) * | 2019-12-06 | 2022-11-22 | Advanced Micro Devices, Inc. | Memory request priority assignment techniques for parallel processors |
| US11449455B2 (en) | 2020-01-15 | 2022-09-20 | Alibaba Group Holding Limited | Method and system for facilitating a high-capacity object storage system with configuration agility and mixed deployment flexibility |
| US11379447B2 (en) | 2020-02-06 | 2022-07-05 | Alibaba Group Holding Limited | Method and system for enhancing IOPS of a hard disk drive system based on storing metadata in host volatile memory and data in non-volatile memory using a shared controller |
| US11150986B2 (en) | 2020-02-26 | 2021-10-19 | Alibaba Group Holding Limited | Efficient compaction on log-structured distributed file system using erasure coding for resource consumption reduction |
| US11200114B2 (en) | 2020-03-17 | 2021-12-14 | Alibaba Group Holding Limited | System and method for facilitating elastic error correction code in memory |
| US11449386B2 (en) | 2020-03-20 | 2022-09-20 | Alibaba Group Holding Limited | Method and system for optimizing persistent memory on data retention, endurance, and performance for host memory |
| US11169881B2 (en) | 2020-03-30 | 2021-11-09 | Alibaba Group Holding Limited | System and method for facilitating reduction of complexity and data movement in erasure coding merging on journal and data storage drive |
| US11385833B2 (en) | 2020-04-20 | 2022-07-12 | Alibaba Group Holding Limited | Method and system for facilitating a light-weight garbage collection with a reduced utilization of resources |
| US11301173B2 (en) | 2020-04-20 | 2022-04-12 | Alibaba Group Holding Limited | Method and system for facilitating evaluation of data access frequency and allocation of storage device resources |
| US11281575B2 (en) | 2020-05-11 | 2022-03-22 | Alibaba Group Holding Limited | Method and system for facilitating data placement and control of physical addresses with multi-queue I/O blocks |
| US11494115B2 (en) | 2020-05-13 | 2022-11-08 | Alibaba Group Holding Limited | System method for facilitating memory media as file storage device based on real-time hashing by performing integrity check with a cyclical redundancy check (CRC) |
| US11461262B2 (en) | 2020-05-13 | 2022-10-04 | Alibaba Group Holding Limited | Method and system for facilitating a converged computation and storage node in a distributed storage system |
| US11218165B2 (en) | 2020-05-15 | 2022-01-04 | Alibaba Group Holding Limited | Memory-mapped two-dimensional error correction code for multi-bit error tolerance in DRAM |
| US11507499B2 (en) | 2020-05-19 | 2022-11-22 | Alibaba Group Holding Limited | System and method for facilitating mitigation of read/write amplification in data compression |
| US11556277B2 (en) | 2020-05-19 | 2023-01-17 | Alibaba Group Holding Limited | System and method for facilitating improved performance in ordering key-value storage with input/output stack simplification |
| US11263132B2 (en) | 2020-06-11 | 2022-03-01 | Alibaba Group Holding Limited | Method and system for facilitating log-structure data organization |
| US11354200B2 (en) | 2020-06-17 | 2022-06-07 | Alibaba Group Holding Limited | Method and system for facilitating data recovery and version rollback in a storage device |
| US11422931B2 (en) | 2020-06-17 | 2022-08-23 | Alibaba Group Holding Limited | Method and system for facilitating a physically isolated storage unit for multi-tenancy virtualization |
| US11354233B2 (en) | 2020-07-27 | 2022-06-07 | Alibaba Group Holding Limited | Method and system for facilitating fast crash recovery in a storage device |
| US11372774B2 (en) | 2020-08-24 | 2022-06-28 | Alibaba Group Holding Limited | Method and system for a solid state drive with on-chip memory integration |
| US11487465B2 (en) | 2020-12-11 | 2022-11-01 | Alibaba Group Holding Limited | Method and system for a local storage engine collaborating with a solid state drive controller |
| EP4254207A4 (en) * | 2020-12-21 | 2024-01-10 | Huawei Technologies Co., Ltd. | DATA PROCESSING DEVICE AND METHOD AND ASSOCIATED DEVICE |
| US11734115B2 (en) | 2020-12-28 | 2023-08-22 | Alibaba Group Holding Limited | Method and system for facilitating write latency reduction in a queue depth of one scenario |
| US11416365B2 (en) | 2020-12-30 | 2022-08-16 | Alibaba Group Holding Limited | Method and system for open NAND block detection and correction in an open-channel SSD |
| US11726699B2 (en) | 2021-03-30 | 2023-08-15 | Alibaba Singapore Holding Private Limited | Method and system for facilitating multi-stream sequential read performance improvement with reduced read amplification |
| US11461173B1 (en) | 2021-04-21 | 2022-10-04 | Alibaba Singapore Holding Private Limited | Method and system for facilitating efficient data compression based on error correction code and reorganization of data placement |
| US11476874B1 (en) | 2021-05-14 | 2022-10-18 | Alibaba Singapore Holding Private Limited | Method and system for facilitating a storage server with hybrid memory for journaling and data storage |
| EP4105771B1 (en) | 2021-06-17 | 2025-04-02 | Samsung Electronics Co., Ltd. | Computational storage device |
| KR102365312B1 (ko) | 2021-06-17 | 2022-02-23 | 삼성전자주식회사 | 스토리지 컨트롤러, 연산 스토리지 장치, 및 연산 스토리지 장치의 동작 방법 |
| US12210470B2 (en) * | 2021-08-03 | 2025-01-28 | Samsung Electronics Co., Ltd. | Systems, methods, and apparatus to identify functions for computational devices |
| KR20230037906A (ko) | 2021-09-10 | 2023-03-17 | 삼성전자주식회사 | 연산 스토리지 장치, 및 상기 연산 스토리지 장치를 포함하는 스토리지 시스템 |
| US12293097B2 (en) | 2021-09-24 | 2025-05-06 | Samsung Electronics Co., Ltd. | Systems and methods for near-storage processing in solid state drives |
| US20230198740A1 (en) * | 2021-12-21 | 2023-06-22 | Samsung Electronics Co., Ltd. | Systems and methods for integrating fully homomorphic encryption (fhe) with a storage device |
| CN114327281B (zh) * | 2021-12-30 | 2023-12-05 | 深圳忆联信息系统有限公司 | 用于ssd的tcg软硬件加速方法、装置、计算机设备及存储介质 |
| US12169636B2 (en) | 2022-01-10 | 2024-12-17 | Korea Advanced Institute Of Science And Technology | Computational SSD accelerating deep learning service on large-scale graphs |
| US12346257B2 (en) | 2022-09-07 | 2025-07-01 | Samsung Electronics Co., Ltd. | Systems and methods for processing storage transactions |
| US12566703B2 (en) * | 2022-09-21 | 2026-03-03 | Samsung Electronics Co., Ltd. | Remote access solution for compute express link (CXL) memory interface configured to send information regarding a capacity, a latency, or bandwidth of memory via interface |
| CN115857805B (zh) * | 2022-11-30 | 2023-06-27 | 合肥腾芯微电子有限公司 | 人工智能可计算存储系统 |
| US20240311318A1 (en) * | 2023-03-14 | 2024-09-19 | Samsung Electronics Co., Ltd. | Systems and methods for a cache-coherent interconnect protocol storage device |
| US12541326B2 (en) | 2023-03-16 | 2026-02-03 | Samsung Electronics Co., Ltd. | Device cache engine for a cache-coherent interconnect memory expansion |
| CN115994107B (zh) * | 2023-03-22 | 2023-07-14 | 苏州浪潮智能科技有限公司 | 存储设备的存取加速系统 |
| CN116756070B (zh) * | 2023-08-15 | 2023-10-27 | 无锡沐创集成电路设计有限公司 | PCIe互联系统、数据处理方法、设备、存储介质及产品 |
| CN121029426A (zh) * | 2025-10-28 | 2025-11-28 | 苏州元脑智能科技有限公司 | 集成背板的数据处理方法及电子设备 |
Citations (4)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20120144098A1 (en) | 2009-04-30 | 2012-06-07 | Velobit, Inc. | Multiple locality-based caching in a data storage system |
| US20150149695A1 (en) | 2013-11-27 | 2015-05-28 | Jawad B. Khan | System and method for computing message digests |
| US20150220409A1 (en) | 2014-02-05 | 2015-08-06 | Futurewei Technologies, Inc. | Per-Function Downstream Port Containment |
| US20180052766A1 (en) | 2016-08-16 | 2018-02-22 | Western Digital Technologies, Inc. | Non-volatile storage system with compute engine to accelerate big data applications |
Family Cites Families (51)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US6604158B1 (en) | 1999-03-11 | 2003-08-05 | Realtime Data, Llc | System and methods for accelerated data storage and retrieval |
| CA2759064C (en) | 2003-05-23 | 2017-04-04 | Washington University | Intellegent data storage and processing using fpga devices |
| US7606954B2 (en) * | 2005-09-29 | 2009-10-20 | Intel Corporation | Data storage using compression |
| US7860930B2 (en) | 2006-12-19 | 2010-12-28 | International Business Machines Corporation | Communication between host systems using a transaction protocol and shared memories |
| US20090307416A1 (en) * | 2008-06-04 | 2009-12-10 | Intitio Corporation | Ssd with a controller accelerator |
| US9110706B2 (en) | 2009-02-09 | 2015-08-18 | Microsoft Technology Licensing, Llc | General purpose distributed data parallel computing using a high level language |
| US8504750B1 (en) * | 2009-06-23 | 2013-08-06 | Qlogic, Corporation | System and method to process event reporting in an adapter |
| TWI407304B (zh) * | 2010-05-26 | 2013-09-01 | Speed up access to data | |
| TWI480738B (zh) * | 2010-07-01 | 2015-04-11 | Neodana Inc | 藉由最佳化叢集特定組態之使用的處理種類來分割叢集間之處理 |
| TW201230038A (en) * | 2011-01-04 | 2012-07-16 | Key Technology Corp | Control system for composite solid-state drive |
| US20120310917A1 (en) | 2011-05-31 | 2012-12-06 | International Business Machines Corporation | Accelerated Join Process in Relational Database Management System |
| US8700834B2 (en) | 2011-09-06 | 2014-04-15 | Western Digital Technologies, Inc. | Systems and methods for an enhanced controller architecture in data storage systems |
| US20130343181A1 (en) | 2012-06-21 | 2013-12-26 | Jonathan Stroud | Systems and methods of data processing using an fpga-implemented hash function |
| US9141529B2 (en) * | 2012-08-14 | 2015-09-22 | OCZ Storage Solutions Inc. | Methods and apparatus for providing acceleration of virtual machines in virtual environments |
| US10161993B2 (en) * | 2013-02-21 | 2018-12-25 | Advantest Corporation | Tester with acceleration on memory and acceleration for automatic pattern generation within a FPGA block |
| US8909605B1 (en) | 2013-02-28 | 2014-12-09 | Emc Corporation | Method and system for accelerating data movement using change information concerning difference between current and previous data movements |
| US9772793B2 (en) | 2013-09-20 | 2017-09-26 | Oracle International Corporation | Data block movement offload to storage systems |
| US10324642B2 (en) * | 2013-06-07 | 2019-06-18 | Sanmina Corporation | Peripheral component interconnect express (PCIe) solid state drive (SSD) accelerator |
| WO2014207511A1 (fr) * | 2013-06-27 | 2014-12-31 | Genbiotech | Utilisation d'un filtre a centrifuger pour decongeler des cellules |
| WO2015081308A2 (en) | 2013-11-26 | 2015-06-04 | Dynavisor, Inc. | Dynamic i/o virtualization |
| US10185499B1 (en) | 2014-01-07 | 2019-01-22 | Rambus Inc. | Near-memory compute module |
| WO2015121912A1 (ja) | 2014-02-12 | 2015-08-20 | 株式会社日立製作所 | データ記憶装置 |
| US9887008B2 (en) | 2014-03-10 | 2018-02-06 | Futurewei Technologies, Inc. | DDR4-SSD dual-port DIMM device |
| US9852779B2 (en) | 2014-03-12 | 2017-12-26 | Futurewei Technologies, Inc. | Dual-port DDR4-DIMMs of SDRAM and NVRAM for SSD-blades and multi-CPU servers |
| JP6181860B2 (ja) | 2014-04-28 | 2017-08-16 | 株式会社日立製作所 | ストレージ装置とそのデータ処理方法及びストレージシステム |
| WO2016038710A1 (ja) | 2014-09-11 | 2016-03-17 | 株式会社日立製作所 | ストレージシステム |
| US20160094619A1 (en) | 2014-09-26 | 2016-03-31 | Jawad B. Khan | Technologies for accelerating compute intensive operations using solid state drives |
| EP3248161A1 (en) * | 2015-01-22 | 2017-11-29 | Greydog Ventures Ltd. | User controlled profiles |
| WO2016126701A1 (en) * | 2015-02-02 | 2016-08-11 | Northwestern University | Systems, methods, and apparatus for esophageal panometry |
| US9715351B2 (en) | 2015-02-13 | 2017-07-25 | Red Hat, Inc. | Copy-offload on a device stack |
| US10467176B2 (en) | 2015-02-25 | 2019-11-05 | Hitachi, Ltd. | Information processing apparatus |
| CN104657308A (zh) * | 2015-03-04 | 2015-05-27 | 浪潮电子信息产业股份有限公司 | 一种用fpga实现的服务器硬件加速的方法 |
| US10067893B2 (en) | 2015-04-03 | 2018-09-04 | Futurewei Technologies, Inc. | Acceleration framework with direct data transfer mechanism |
| US10025747B2 (en) * | 2015-05-07 | 2018-07-17 | Samsung Electronics Co., Ltd. | I/O channel scrambling/ECC disassociated communication protocol |
| US20170091127A1 (en) * | 2015-09-25 | 2017-03-30 | Intel Corporation | Techniques to Couple with a Storage Device via Multiple Communication Ports |
| US9946659B2 (en) | 2015-11-16 | 2018-04-17 | International Business Machines Corporation | Near-memory accelerator for offloading pointer chasing operations from a processing element |
| CN105677595A (zh) * | 2016-01-21 | 2016-06-15 | 方一信息科技(上海)有限公司 | 一种同时实现计算加速和pciessd存储的fpga方法 |
| US10210121B2 (en) | 2016-01-27 | 2019-02-19 | Quanta Computer Inc. | System for switching between a single node PCIe mode and a multi-node PCIe mode |
| KR101923661B1 (ko) | 2016-04-04 | 2018-11-29 | 주식회사 맴레이 | 플래시 기반 가속기 및 이를 포함하는 컴퓨팅 디바이스 |
| US10282308B2 (en) | 2016-06-23 | 2019-05-07 | Advanced Micro Devices, Inc. | Method and apparatus for reducing TLB shootdown overheads in accelerator-based systems |
| US9923755B2 (en) | 2016-08-01 | 2018-03-20 | Data I/O Corporation | Device programming with system generation |
| US9927975B2 (en) | 2016-08-03 | 2018-03-27 | Micron Technology, Inc. | Hybrid memory drives, computer system, and related method for operating a multi-mode hybrid drive |
| US10503635B2 (en) | 2016-09-22 | 2019-12-10 | Dell Products, Lp | System and method for adaptive optimization for performance in solid state drives based on segment access frequency |
| CN106371773A (zh) * | 2016-11-07 | 2017-02-01 | 北京得瑞领新科技有限公司 | Ssd单元、ssd设备以及基于ssd设备的数据处理方法 |
| US10860508B2 (en) * | 2017-05-25 | 2020-12-08 | Western Digital Technologies, Inc. | Offloaded disaggregated storage architecture |
| US10719474B2 (en) * | 2017-10-11 | 2020-07-21 | Samsung Electronics Co., Ltd. | System and method for providing in-storage acceleration (ISA) in data storage devices |
| US10599568B2 (en) | 2018-04-09 | 2020-03-24 | Intel Corporation | Management of coherent links and multi-level memory |
| US11200186B2 (en) | 2018-06-30 | 2021-12-14 | Intel Corporation | Apparatuses, methods, and systems for operations in a configurable spatial accelerator |
| US12147353B2 (en) | 2019-05-24 | 2024-11-19 | Texas Instruments Incorporated | Methods and apparatus for read-modify-write support in multi-banked data RAM cache for bank arbitration |
| US11360772B2 (en) | 2020-03-31 | 2022-06-14 | International Business Machines Corporation | Instruction sequence merging and splitting for optimized accelerator implementation |
| US11500833B2 (en) | 2020-07-10 | 2022-11-15 | International Business Machines Corporation | Archiving accelerator-only database tables |
-
2018
- 2018-09-05 US US16/122,865 patent/US10585819B2/en active Active
- 2018-09-06 US US16/124,183 patent/US10592443B2/en active Active
- 2018-12-05 KR KR1020180155576A patent/KR102427561B1/ko active Active
-
2019
- 2019-01-30 KR KR1020190012295A patent/KR102428317B1/ko active Active
- 2019-02-14 TW TW108104998A patent/TWI772611B/zh active
- 2019-02-14 TW TW108104984A patent/TWI765138B/zh active
- 2019-02-14 TW TW108104966A patent/TWI770358B/zh active
- 2019-02-27 JP JP2019034068A patent/JP7120943B2/ja active Active
- 2019-03-04 JP JP2019038574A patent/JP7120945B2/ja active Active
- 2019-03-04 JP JP2019038498A patent/JP7252789B2/ja active Active
- 2019-03-04 CN CN201910161758.6A patent/CN110232034B/zh active Active
- 2019-03-04 CN CN201910161732.1A patent/CN110232036B/zh active Active
- 2019-03-04 CN CN201910161298.7A patent/CN110232037B/zh active Active
-
2020
- 2020-01-24 US US16/752,612 patent/US11132310B2/en active Active
-
2021
- 2021-02-26 US US17/187,735 patent/US11892957B2/en active Active
Patent Citations (4)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US20120144098A1 (en) | 2009-04-30 | 2012-06-07 | Velobit, Inc. | Multiple locality-based caching in a data storage system |
| US20150149695A1 (en) | 2013-11-27 | 2015-05-28 | Jawad B. Khan | System and method for computing message digests |
| US20150220409A1 (en) | 2014-02-05 | 2015-08-06 | Futurewei Technologies, Inc. | Per-Function Downstream Port Containment |
| US20180052766A1 (en) | 2016-08-16 | 2018-02-22 | Western Digital Technologies, Inc. | Non-volatile storage system with compute engine to accelerate big data applications |
Also Published As
| Publication number | Publication date |
|---|---|
| CN110232034A (zh) | 2019-09-13 |
| US20200159679A1 (en) | 2020-05-21 |
| KR20190105492A (ko) | 2019-09-17 |
| JP2019153304A (ja) | 2019-09-12 |
| TW201939269A (zh) | 2019-10-01 |
| KR20190105497A (ko) | 2019-09-17 |
| JP7120945B2 (ja) | 2022-08-17 |
| JP2019153297A (ja) | 2019-09-12 |
| CN110232037B (zh) | 2021-11-09 |
| CN110232037A (zh) | 2019-09-13 |
| CN110232036B (zh) | 2022-08-09 |
| JP2019153305A (ja) | 2019-09-12 |
| US11892957B2 (en) | 2024-02-06 |
| US20190272240A1 (en) | 2019-09-05 |
| JP7252789B2 (ja) | 2023-04-05 |
| TW201939305A (zh) | 2019-10-01 |
| KR102428317B1 (ko) | 2022-08-02 |
| US20190272242A1 (en) | 2019-09-05 |
| US11132310B2 (en) | 2021-09-28 |
| TW201939294A (zh) | 2019-10-01 |
| US20210182221A1 (en) | 2021-06-17 |
| TWI772611B (zh) | 2022-08-01 |
| CN110232036A (zh) | 2019-09-13 |
| CN110232034B (zh) | 2024-07-30 |
| KR102427561B1 (ko) | 2022-08-01 |
| US10585819B2 (en) | 2020-03-10 |
| US10592443B2 (en) | 2020-03-17 |
| TWI765138B (zh) | 2022-05-21 |
| TWI770358B (zh) | 2022-07-11 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| JP7120943B2 (ja) | Fpgaベースの加速のための新たなssd基本構造 | |
| US20240119014A1 (en) | Novel ssd architecture for fpga based acceleration | |
| JP2015537310A (ja) | データ処理システム及びデータ処理方法 | |
| TW202101951A (zh) | 輕量橋接器電路以及用於多實體功能模擬的方法及物品 | |
| JP2021515318A (ja) | NVMeベースのデータ読み取り方法、装置及びシステム | |
| CN115858434A (zh) | 一种计算设备及请求处理方法 | |
| US20230198740A1 (en) | Systems and methods for integrating fully homomorphic encryption (fhe) with a storage device | |
| EP4332748B1 (en) | Systems and methods for integrating fully homomorphic encryption (fhe) with a storage device | |
| US20230195320A1 (en) | Systems and methods for integrating a compute resource with a storage device | |
| CN114327248A (zh) | 存储节点、存储设备及网络芯片 | |
| EP4332747B1 (en) | Systems and methods for integrating a compute resource with a storage device | |
| CN112131166B (zh) | 轻量桥接器电路及其操作方法 |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220204 |
|
| A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20220204 |
|
| A871 | Explanation of circumstances concerning accelerated examination |
Free format text: JAPANESE INTERMEDIATE CODE: A871 Effective date: 20220204 |
|
| A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20220426 |
|
| A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220711 |
|
| 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: 20220726 |
|
| A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20220804 |
|
| R150 | Certificate of patent or registration of utility model |
Ref document number: 7120943 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
| R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |