JP6633119B2 - 自律的メモリの方法及びシステム - Google Patents

自律的メモリの方法及びシステム Download PDF

Info

Publication number
JP6633119B2
JP6633119B2 JP2018072998A JP2018072998A JP6633119B2 JP 6633119 B2 JP6633119 B2 JP 6633119B2 JP 2018072998 A JP2018072998 A JP 2018072998A JP 2018072998 A JP2018072998 A JP 2018072998A JP 6633119 B2 JP6633119 B2 JP 6633119B2
Authority
JP
Japan
Prior art keywords
memory
instructions
packet
instruction
parser
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
Application number
JP2018072998A
Other languages
English (en)
Other versions
JP2018139118A (ja
Inventor
エム. クレウィッツ,ケネス
エム. クレウィッツ,ケネス
エス. エイラート,ショーン
エス. エイラート,ショーン
ディー. アケル,アミーン
ディー. アケル,アミーン
ワン,ホンギュ
Original Assignee
マイクロン テクノロジー,インク.
マイクロン テクノロジー,インク.
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 マイクロン テクノロジー,インク., マイクロン テクノロジー,インク. filed Critical マイクロン テクノロジー,インク.
Publication of JP2018139118A publication Critical patent/JP2018139118A/ja
Application granted granted Critical
Publication of JP6633119B2 publication Critical patent/JP6633119B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/061Improving I/O performance
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/22Parsing or analysis of headers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • G06F3/0659Command handling arrangements, e.g. command buffers, queues, command scheduling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input 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/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0683Plurality of storage devices
    • G06F3/0688Non-volatile semiconductor memory arrays
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3885Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Software Systems (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Computer Security & Cryptography (AREA)
  • Executing Machine-Instructions (AREA)
  • Advance Control (AREA)
  • Memory System Of A Hierarchy Structure (AREA)
  • Memory System (AREA)
  • Dram (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Description

[優先出願]
本出願は、2013年12月2日に出願された米国特許出願第14/094,273号に対する優先権の利益を主張し、その全体が本明細書に参考により組み込まれる。
一般にメモリデバイスは、コンピュータまたは他の電子デバイスにおける内部半導体集積回路として提供される。ランダムアクセスメモリ(RAM)、読出専用メモリ(ROM)、ダイナミックランダムアクセスメモリ(DRAM)、同期式ダイナミックランダムアクセスメモリ(SDRAM)、及び不揮発性メモリ(例えばフラッシュメモリ)を含む、数多くの異なる種類のメモリが存在する。
いくつかの不揮発性メモリデバイスを組み合わせて、コンピュータシステムにおいて機械的に作動するハードディスクドライブをエミュレートし得るソリッドステートドライブ(SSD)を作ることが可能である。ソリッドステートドライブは、可動部品がないので、機械的ハードドライブよりもより速く、より信頼性のあるアクセスを提供可能である。
コンピュータシステムの高性能化に少なくとも一部起因して、メモリ及びソリッドステートドライブの製造業者には、コンピュータシステムの高性能化に遅れをとらないように自社製品のメモリを高性能化するという継続的な圧力がかかり得る。コンピュータシステムに対する任意の動作負荷を軽減するために、メモリに対する読出し及び書込みをより効率的にするという一般的ニーズがある。
上記の課題を解決するために、本発明の方法は、記憶メモリ及びメモリ処理装置を含むメモリデバイスで実行される方法であって、前記メモリ処理装置は、少なくとも1つの実行ユニットと、パケットパーサと、パケットジェネレータとを含み、前記方法は、
前記メモリ処理装置で、前記パケットパーサを用いて命令一式を受信し且つ構文解析することと、
前記少なくとも1つの実行ユニットを用いて前記命令一式を実行して、前記メモリデバイスの前記記憶メモリからデータを取り出すことを試みることと、
前記パケットジェネレータを用いて、前記命令一式を、前記少なくとも1つの実行ユニットによる前記命令一式の前記実行に応じて前記メモリデバイスの前記記憶メモリから取り出された任意のデータと組み合わせて、パケットを生成することと、
前記パケットジェネレータを用いて前記パケットを送信することであって、前記パケットは、前記メモリ処理装置から、前記メモリデバイスに接続されたメモリコントローラへ転送される、ことと、
を含み、
前記メモリ処理装置の、前記少なくとも1つの実行ユニット、前記パケットパーサ、及び前記パケットジェネレータは、前記記憶メモリと同一のハードウェアコンポーネント内に配置されている、ことを特徴とする。
自律的メモリ処理装置の実施形態の機能的ブロック図を例示する。 図1の実施形態による、パケットパーサの実施形態のブロック図を例示する。 図1の実施形態による、プログラムカウンタの実施形態のブロック図を例示する。 図1の実施形態による、命令メモリの実施形態のブロック図を例示する。 図1の実施形態による、デコードロジックの実施形態のブロック図を例示する。 図1の実施形態による、レジスタファイルの実施形態のブロック図を例示する。 図1の実施形態による、実行ユニットの実施形態のブロック図を例示する。 図1の実施形態による、プログラムカウンタ実行ユニットの実施形態のブロック図を例示する。 図1の実施形態による、パーサの実施形態のブロック図を例示する。 図1の実施形態による、パケットジェネレータの実施形態のブロック図を例示する。 図1の実施形態による、命令実行フォーマットの実施形態の図解を例示する。 メモリシステムの実施形態のブロック図を例示する。 自律的メモリデバイスにおける自律的メモリ処理装置の作動の実施形態のフローチャートを例示する。
以下の詳細説明において、本明細書の一部を形成し、例示のために特定の実施形態が示される添付図面を参照する。図面において同じ番号は、いくつかの図を通して実質的に同様の構成要素を説明する。他の実施形態が使用可能であり、そして本開示の範囲から逸脱することなく構造的、論理的、及び電気的変更を行うことが可能である。従って、以下の詳細説明は、限定的な意味で解釈されるべきではない。
本開示は、いかなる1つの種類のメモリにも限定されない。自律的メモリ処理装置は、任意の種類のメモリデバイス、メモリデバイス群、または半導体メモリ、光学メモリ、磁気メモリを含むメモリ技術に対応付けることが可能である。例えば、メモリは、不揮発性(例えばNANDフラッシュ、NORフラッシュ、相変化メモリ(PCM))、または揮発性(例えばDRAM、SRAM)を含み得る。
本明細書で使用される場合、ノードは、受信パケットを構文解析するパケットパーサと、ノードからネットワークへ送信されるパケットを生成するパケットジェネレータと、任意のネットワークにノードをインターフェイス接続可能なネットワークポートとを備え得る。ノードはその上、ノードの作動を制御する処理要素と、並びにデータを記憶するメモリとを備え得る。別の実施形態において、ノードは、追加機能のための追加ハードウェア及び/またはソフトウェア/ファームウェアを備え得る。自律的処理装置を有する自律的メモリデバイスは、ノードとみなされ得る。
図1は、自律的メモリ処理装置の実施形態の機能的ブロック図を例示する。このような装置は、メモリ100に対応付けられ、中央処理装置(CPU)ベースのコンピューティングシステムにおけるボトルネックメモリ帯域幅の渋滞を軽減するのに使用され得る。自律的メモリ処理装置は、自律的メモリデバイス内に配置され得る。
自律的メモリ処理装置は、パケットパーサ101と、プログラムカウンタ107と、命令メモリ105と、デコードロジック103と、レジスタファイル109と、パーサ115と、パケットジェネレータ111と、1つまたは複数の実行ユニット(EU)113と、ページバッファ117とを備え得る。図1の構成要素及び構成は、他の実施形態が他の構成要素及び他の構成を使用することができるので、例示のみを目的とする。
図2は、パケットパーサ101のブロック図を例示する。パケットパーサ101はネットワークに接続され、ネットワークから(例えば外部ネットワークからメモリ100へ)のデータパケットを受け入れ得る。パケットパーサ101がネットワークからのパケットにおいて受信したプログラムカウント(例えば命令メモリ位置)をプログラムカウンタ107にロードできるように、パケットパーサ101はプログラムカウンタ107の入力にも接続され得る。プログラムカウンタ107が現在のプログラムカウント(例えば命令メモリ位置)をパケットパーサ101にロードできるように、パケットパーサ101はプログラムカウンタ107の出力にも接続され得る。パケットパーサ101はさらに、ネットワークからのパケットにおいて受信したデータ(例えば命令)を命令メモリ105及びレジスタファイル109へロードできるように、命令メモリ105及びレジスタファイル109の入力にも接続され得る。
図3は、プログラムカウンタ107のブロック図を例示する。例示のため、プログラムカウンタ107は、32ビットカウンタとして示される。しかしながら、他の実施形態は、他のプログラムカウンタサイズを使用可能である。
プログラムカウンタ107は、パケットパーサ101と、1つまたは複数の実行ユニット113から成る部であり得るプログラムカウンタ実行ユニット(PCEU)114とからの入力を有し得る。プログラムカウンタ107は、命令メモリ105に接続された出力を有し得る。
プログラムカウンタ107は、プログラム(例えば実行可能命令)を含み得る命令メモリ105における特定の命令位置へアクセスするプログラムカウント値(例えば命令メモリ位置)を含み得る。プログラムカウント値は、パケットパーサ101により特定されパケットパーサから受信された、受信パケット内の特定のデータフィールドにより、またはプログラムカウンタ実行ユニット114からの計算値により、設定され得る。そしてプログラムカウンタ107は、プログラムカウント値(例えば32ビットレジスタ)を命令メモリ105に出力し得る。
図4は、命令メモリ105のブロック図を例示する。命令メモリ105は、プログラム(例えば実行可能命令)を記憶するいくつかのレジスタを備え得る。パケットパーサ101は、命令メモリ105の書込ポートに接続され得る。命令メモリ105はパケットパーサ101により書込可能であり、それによってパケットパーサ101により特定される受信パケット内の受信命令は、当該パケットから命令メモリ105へロードされ得る。
命令メモリ105は、命令メモリ105内の特定位置にアクセスするためのアドレスを各自受入可能な2つのアドレスポートを備え得る。1つのアドレスは、プログラムカウンタ107から送られ得る。他方のアドレスは、パケットジェネレータ111から送られ得る。
1つの動作中に、命令メモリ105は、プログラムカウンタ107のアドレスが示す位置から、命令(例えばデータポート)を出力し得る。行う演算に関して実行ユニット113に指示するために、この命令は実行ユニット113により解読及び実行され得る。この命令は、実行ユニット113にオペランドを与え、並びに処理のため何のデータを実行ユニット113に出力するかに関してレジスタファイル109に指示するために、レジスタファイル109にインデックスを与え得る。
図5は、デコードロジック103のブロック図を例示する。デコードロジック103は、実行ユニットデコードロジック501と、パーサデコードロジック502と、多重分離機能503(例えばデマルチプレクサ)とを備え得る。
多重分離機能503への入力は、命令メモリ105の出力からの命令ストリームに接続され得る。命令ストリーム内の1つまたは複数の制御ビットは、命令ストリーム内の特定命令の行先(例えEUデコードロジック501、パーサデコードロジック502)を選択するのに使用され得る。
命令がEUデコードロジック501へ送られた場合、EUデコードロジック501は、命令を実行ユニット113のうちの1つに送るため命令を処理し得る。命令は、何の種類の演算を行うのかに関して、並びに命令の実行中に使用するオペランドを実行ユニット113のうちの1つに与えるように、実行ユニット113のうちの1つに指示し得る。オペランドは、レジスタファイル109のレジスタに対し指標を付け、実行ユニット113のうちの1つがデータを処理できるように何のデータを出力するかに関してそのレジスタに指示し得る。
多重分離機能503はまた、命令をパーサ115に接続されたパーサデコードロジック502へ送信し得る。命令はパーサデコードロジック502を制御し、今度はパーサデコードロジック502が、処理のためにページバッファ117の特定セグメントからのデータを実行ユニット113のうちの1つへ読込むために、ページバッファ117のどのセグメントにアクセスするかパーサに指示する。
図6は、レジスタファイル109のブロック図を例示する。レジスタファイル109は、パケットパーサ101、パケットジェネレータ111、実行ユニット113のうちの1つまたは複数、及びメモリ読出指示からの入力を備え得る。メモリ読出指示は、パーサ115により生成される、メモリ動作が完了したことを示す信号であり得る。レジスタファイル109は、パケットジェネレータ111、実行ユニット113、及びパーサ115への出力を備え得る。
レジスタファイル109は、実行ユニット113による処理が起こっている間に変数を記憶するメモリ(例えば複数のレジスタ)を備え得る。これらの変数は、1つまたは複数の命令に応答してメモリから取得されたデータを含み得る。レジスタファイル109は、レジスタに初期条件を設定するためパケットパーサ101により書込まれ、パケットジェネレータ111により読出され得る。それぞれの実行ユニット113は、多重化機能を介してレジスタファイル109から引数を受信し得る。パケットジェネレータ111への出力は、レジスタファイル109のレジスタに記憶されているデータを、ネットワークへ送信するためのパケットにまとめるのに使用され得る。
図7Aは、一般の実行ユニット113(例えば実行ユニット(0−N))の実施形態のブロック図を例示する一方、図7Bは、特にプログラムカウンタ実行ユニット114の実施形態のブロック図を例示する。PCEU114は、実行ユニット113群の一部とみなされ得るが、他の実行ユニット113とは異なる構成を有し得る。
特定の自律的メモリ処理装置に、特定の数の実行ユニット113が含まれ得る必要はない。1つの装置は単一の実行ユニット113を有し得る一方、別の装置は複数(例えば100個)の実行ユニットを有し得る。
図7Aは、実行ユニット113が4つの演算論理装置(ALU)701〜704を備え得ることを例示する。ALU1703及びALU2704の出力は、多重化機能706に対する入力であり得る。ALU703、704の出力のうちどちらを選ぶかは、CompALU702の出力により決定され得る。CompALU702の出力は、多重化機能706に対する選択信号として使用され得る。4番目のALUであるALUOut701は、実行ユニット113により行われた演算の結果を記憶する場所をレジスタファイル109に指示し得る、レジスタファイル109に対するレジスタアドレスRとしての出力を有し得る。
下の3つのALU702〜704及び多重化機能706は、if−then−else演算を行い得る。多重化機能706は、CompALU702により決定される条件の「ある条件の時」を提供し得る。従って、条件が真である場合、1つのALU(例えばALU1703)の出力がCompALU702の出力により選択される、それ以外の場合、別のALU(例えばALU2704)の出力がCompALU702の出力により選択される。
例えば、ALU1703がオペランド入力のOPERAND1(R)及びOPERAND2(R)とコマンド入力のOPERATOR1を有し、ALU2704がオペランド入力のOPERAND3(R)及びOPERAND4(R)とコマンド入力のOPERATOR2を有すると仮定する場合、if−then−else文は以下のように表され得、
if(条件)
then
Operand1 OPERATOR1 Operand2
else
Operand3 OPERATOR2 Operand4
ここで「Operand1 OPERATOR1 Operand2」はALU1703により提供され、「Operand3 OPERATOR2 Operand4」はALU2704により提供され、そして「if(条件)」はCompALU702及び多重化機能706より提供され得る。
図10の命令フォーマットに関連して後述されるように、オペランドと演算子は、命令により提供され得るか、命令がどのレジスタにオペランド値が配置されているかを示し得る。例えば、OPERAND1(R1)はレジスタRに配置され、OPERAND(R2)はレジスタRに配置され、OPERAND(R3)はレジスタRに配置され、OPERAND(R4)はレジスタRに配置され得る。
ALU1703及びALU2704は、同一の演算または異なる演算を行い得る。言い換えると、OPERATOR1はOPERATOR2と同じであり得る、またはOPERATOR1はOPERATOR2とは異なり得る。
ALU Out701は、オペランド入力R、及びR(例えばレジスタR、R)とコマンド入力OPERATOR3を有し得る。ALUOut701がRとRの値に対しコマンドOPERATOR3を行うことにより生成される結果Rは、実行ユニット113の結果がどこに記憶されるかを決定する。
CompALU702は、オペランド入力R、R(例えばレジスタR、R)とコマンド入力OPERATOR4を有し得る。前述のように、RとRの値に対しコマンドOPERATOR4を行うことにより得られる結果が、多重化機能106の選択を決定する。
前述のALU701〜704におけるコマンド(例えばOPERATOR1、OPERATOR2、OPERATOR3、OPERATOR4)として使用され得る一般演算には、加算、減算、論理AND、論理OR、論理NOT、論理NOR、〜と等しい、〜以下、〜未満、〜以外、〜以上、または〜より大きいが含まれ得る。これらの演算は、他の実施形態が他の演算を使用可能であるので、例示のみを目的とする。
図7Bは、プログラムカウンタ実行ユニット(PCEU)114の構成を例示する。この構成は、実行ユニット0〜n113と同様であり得るが、ALUOut701を有さない。PCEU114はプログラムカウンタ107に対する新たなアドレスを特定することを専門とし、PCEU114の演算の結果を記憶する場所はプログラムカウンタ107であるため、ALUOut701は含まれない。
PCEU114は、オペランド入力R9、R10とコマンド入力OPERATOR5を有するCompALU710を備え得る。ALU1711は、オペランド入力R11、R12とコマンド入力OPERATOR6を含み得る。ALU2712は、オペランド入力R13、R14とコマンド入力OPERATOR7を含み得る。
ALU1711及びALU2712の出力は、多重化機能714に対する入力であり得る。CompALU710の出力は、多重化機能714に対する選択信号を提供し得る。従って、前述の実行ユニット113の場合と同様に、PCEU114は、CompALU710により決定される条件の「ある条件の時」を多重化機能714が提供する、if−then−else文を提供し得る。従って、条件が真である場合、1つのALU(例えばALU1711)の出力がCompALU710の出力により選択される、それ以外の場合、別のALU(例えばALU2712)の出力がCompALU710の出力により選択される。結果は、プログラムカウンタ107へロードされ得る。
前述の実行ユニット113の場合と同様に、PCEU114において使用される演算子及びコマンドは、命令メモリの命令からロードされ得るか、命令がどのレジスタが値を含み得るかを示し得る。
図8は、パーサ115のブロック図を例示する。パーサ115は、書込むアドレス並びにデータを含むメモリ書込ポートを備え得る。メモリ読出アドレスポートは、読出すアドレスをメモリに提供し、それによって読出されたデータは、メモリ読出データポートに読込まれ得る。パーサ115はまた、メモリ読出動作が完了すると、メモリ読出完了指示信号を出力し得る。パーサ115はさらに、実行ユニット113への出力と、レジスタファイル109からの入力と、及びパーサデコードロジック502からの設定入力とを備え得る。
パーサ115は、メモリ100のページバッファ117からの直接読出し、またはページバッファ117への直接書込みができるように、メモリ100への直接アクセスを有し得る。パーサ115は、ページバッファ117の全長に対しアクセス権を有するので、処理をより管理しやすいように、ページバッファ117をより小さいセグメント(例えば規則正しく定義されたセグメント)に細分化し得る。例えば、パーサ115は、ページバッファの最初の100バイトに対し作動し、それから次の100バイトに対し作動し、そしてページバッファ117全体の読出し/書込みが完了するまで、これを続け得る。これを達成するために、ページバッファ117のどのセグメントを読出すかを特定する、パケットパーサ101からのアドレスがパーサ115に与えられ得る。
パーサ115は、ページバッファ117の内容をどのように構文解析するかパーサ115に指示し得る設定入力をレジスタファイル109から受信し得る。パーサ115は、新たな内容がレジスタファイル109において利用可能であることを実行プログラムに指示するメモリ読出完了指示信号を生成し得る。
図9は、パケットジェネレータ111の実施形態のブロック図を例示する。パケットジェネレータは、命令メモリ105及びレジスタファイル109からの入力と、命令メモリ105及びレジスタファイル109への出力とを備え得る。パケットジェネレータ111はその上、任意の生成パケットを出力するために、ネットワークへの出力を有する。
パケットジェネレータ111は、命令メモリ105及びレジスタファイル109からデータを読出すために、命令メモリ105に対するアドレスと、レジスタファイル109に対するアドレスを生成し得る。そしてパケットジェネレータ111は、レジスタファイル109から読出されたデータ(例えば命令メモリ105からの命令及びコンテキスト(例えばデータ、メモリ読出しの結果、行われた演算の結果))を使用して、このデータをまとめ、ネットワーク上に送信するパケットを生成する。
図10は、図1の実施形態による、命令実行フォーマットの実施形態を例示する。各命令1001〜1003は、実行ユニット113により実行されるために、命令メモリに記憶され得る。
命令の例示された実施形態には、4つの命令1000〜1003が含まれる。各命令は、実行ユニット113の異なるALUに対応付けられ得る。従って、実行ユニット113が異なる数のALUを含む場合、実行フォーマットは異なる数の命令1000〜1003を含み得る。以下の論述においては、図10と図7AのALUの両方を参照する。
第1命令1000(例えば命令D)は、実行ユニット113のうちの1つによる演算の結果の行先レジスタ(例えばR)を示し得る。前述のように、ALUOut701は、実行ユニット113の結果を記憶するための行先レジスタRのアドレスを生成し得る。従って、ALUOut701は、レジスタRを生成するために、第1命令1000に対応付けられ得る。
第2命令1001(例えば命令C)は、実行ユニット113により実行されるif−then−else文の条件を示し得る。例示された実施形態において、条件は比較値Vにより表される。前述のように、CompALU702は、多重化機能706に対する選択信号として使用される条件を生成し得る。従って、CompALU702は、Vが真か否かを比較するために、第2命令1001に対応付けられ得る。
第3命令1002(例えば命令T)は、実行ユニット113により実行されるif−then−else文の「then」(真の場合)の結果を示し得る。例示された実施形態において、「then」の結果はV、すなわち真の場合の値により表される。前述のように、ALU1703は、「then」の結果を生成し得る。従って、ALU1703は、Vである「then」の結果のための第3命令1002に対応付けられ得る。
第4命令1003(例えば命令F)は、実行ユニット113により実行されるif−then−else文の「else」(偽の場合)の結果を示し得る。例示された実施形態において、elseの結果はV、すなわち偽の場合の値により表される。前述のように、ALU2704は、「else」の結果を生成し得る。従って、ALU2704は、「else」の結果Vのため、第4命令1003に対応付けられ得る。
条件のV、thenの結果のV、elseの結果のV、及び結果レジスタのRを使用すると、if−then−else文は以下のように表され得る。
if(V==TRUE)
then
Reg[R]:=V
else
Reg[R]:=V
図11は、図1の自律的メモリ処理装置130を組み込み得るメモリシステムの実施形態のブロック図を例示する。メモリシステムは、ネットワーク1120を介して1つまたは複数のメモリデバイス(例えばSSD)1101、1102と通信し得るコントローラ1100(例えばCPU)を備え得る。ネットワーク1120は、有線バス、または無線通信(例えばWiFi)であり得る。
メモリデバイス1101は、メモリデバイス1101のストレージ部を構成するローカルメモリ100(例えばRAM、DRAM、SRAM、NANDフラッシュ、NORフラッシュ、相変化メモリ(PCM))と、並びに図1の自律的メモリ処理装置130とを備え得る。自律的メモリ処理装置130は、メモリ100に相対的に近い所(例えば同じダイ、同じダイスタック、同じメモリモジュール)に配置され得る。例えば、自律的メモリ処理装置130は、メモリ100のバンクレベルの回路に含まれ得る。各バンクが異なる自律的メモリ処理装置130を含み得、そのために1つのメモリチップは、ほぼ同時に作動する自律的メモリ処理装置130の複数のインスタンスを有し得る。本明細書において使用される場合、ローカルメモリ100は、ネットワークを介さずに自律的メモリ処理装置130に接続されるメモリであり得る。
図11のシステムのそれぞれのデバイスは、ノードとみなされ得る。各ノードは他のノードとネットワーク1120を介して通信し得る。それぞれのノードは実質的に同様であり得る、またはノードのうちの1つまたは複数は異なる構成を有し得る。例えば、第1メモリデバイス1101は、プログラムカウンタ実行ユニット114に加えて単一実行ユニット113のみを有し得る一方、第2メモリデバイス1102は、プログラムカウンタ実行ユニット114に加えて複数の実行ユニット113を有し得る。
従って、後述のように、コントローラ1100(例えばソースノード)は、命令及びソースノードの現在の処理状態を含むメッセージ(例えばパケット)を、メモリデバイス1101(例えば目標ノード)へ送信し得る。別の実施形態において、第1メモリデバイス1101がソースノードであり得る一方、第2メモリデバイス1102が目標ノードであり得る。
命令は、メモリデバイス1101に対するコマンド(例えば、検索、ソート、比較)を含み得る。メモリデバイス1101は、コントローラの介在なしに、コマンドにより指示されたタスクを行い得る。自律的メモリ処理装置130は、他のノード1100、1102へメッセージの送信、他のノード1100、1102からメッセージの受信、他のノード1100、1102へ処理命令及び処理状態の送信、他のノード1100、1102から処理命令及び処理状態の受信、プログラム状態の復元及び保存、処理命令の実行、ローカルメモリの読出し及び書込み、及び/または単一ノードにおける多重処理コンテキストの支援を行い得る。
自律的メモリ処理装置130の構成により、動的で滞りがなく柔軟性のある実行ユニット113(例えばALUを含む)の追加及び削除が可能となり、従ってノードは必要に応じて追加の処理能力が与えられる。自律的メモリ処理装置130における実行ユニット113の動的な追加及び削除は、以下の作動実施例において例示され得る。
標準的な先行技術のプログラムは、以下のように生成され得る。
命令1(ADDレジスタ1、レジスタ2、レジスタ3)
命令2(SUBレジスタ2、レジスタ3、レジスタ4)
標準的な先行技術のCPUシステムの場合のように、これらの命令には暗黙の従属性が含まれる。例えば、命令1が実行機会を有する前に、レジスタ2の値が書換えられ得るので、命令2は命令1の前に(または命令1と同じサイクルにおいて)実行不可能であり得る。
プログラムを実行するのに必要なサイクル数を削減するために、自律的メモリ処理装置構成において、より複雑な実行ユニット(EU)構成が使用され得る。各EUは、それぞれが別個のタスクを行ういくつかの異なるALU(例えば4つのALU)を含み得る。従って、自律的メモリ処理装置のために書かれたプログラムは、以下のように生成され得る(1つのEUに加えPCEUを有する構成と仮定した場合)。
[PCEU命令1][EU1命令1]
[PCEU命令2][EU1命令2]
各[EU#命令#]は、図10に例示されるように、以下のように現れる。
[行先命令][比較命令][If−true命令][If−false命令]
また、自律的メモリ処理装置の構成の一部として、プロセッサはその内部に、異なる数のEUを組み込み得る。これにより4つのEUと1つのPCEUを有する構成は、例えば以下のことが可能になり得る。
[PCEU命令1][EU1命令1][EU2命令1][EU3命令1][EU4命令1]
[PCEU命令2][EU1命令2][EU2命令2][EU3命令2][EU4命令2]
当サイクルにおいて実行する追加作業は存在し得ないという事実に基づいて、これらのEU命令のうちのいずれか1つは空であり得る。これは、プログラムの特定の段階において、並列処理がないことに起因し得る。
自律的メモリ処理装置の構成により、システムにおける異種の自律的メモリ処理装置エンジン(例えば1つの装置「A」は1つのEUに加えPCEUを有し得る一方、同じ相互接続システムにおける別の装置「B」は4つのEUに加えPCEUを有し得る)一式内の対話が可能になり得る。当シナリオにおいて、装置Aが装置「B」に対しコンテキストを送る必要があると仮定した場合、プログラムは命令の連続ストリーム内に装入され、装置「B」へ送り出され得る。装置「B」は、そこで、それ自体のハードウェア上にそれら命令を以下同様にスケジュールし得る。
[PCEU命令1][EU1命令1][空][空][空]
[PCEU命令2][EU1命令2][空][空][空]
...
全てのプログラムは最終的に、最も精密な自律的メモリ処理装置の並列処理に臨み得るため、これはシステムにおいて非効率性を生じる無駄な並列処理へと導き得る。
命令間に従属性が何もないことを確かめずに、命令を並列EUへまとめて渡すことはあり得ない。標準的な先行技術のシステムにおいて、このような種類の比較は計算上コストが高くあり得るため、自律的メモリ処理装置は、「フェンス」フラグという命令の概念を使用し得る。「フェンス」フラグにより、アプリケーションの作者またはアプリケーションの作成者は、命令ストリームがそのストリームにおける前の命令に対する従属性をもう有さないということを示すことが可能になる。当情報により、命令ストリームは、重要処理のオーバーヘッドなしで、異種プロセッサ一式上で回され、スケジュールされることが可能になり得る。
例えば、以下の命令ストリーム[PCEU命令][EU命令1][EU命令2][EU命令3][フェンスマーカ/命令][EU命令4][EU命令5][EU命令6][EU命令7][フェンスフラグ/命令]は、自律的メモリ処理装置「A」上において[PCEU][1][PCEU][2][F][PCEU][3][PCEU][4][PCEU][5][PCEU][6][F][PCEU][7]のようにスケジュールされ([F]は「フェンス」マーカを示す)、そして自律的メモリ処理装置「B」において[PCEU][1][2][3][X][F][PCEU][4][5][6][7]としてスケジュールされ得る。
「フェンス」命令は、所定の自律的メモリ処理装置(例えば「A」または「B」)の命令メモリへロードされている間に、パケット内論理により処理され得る。「フェンス」フラグの存在は、命令メモリに記憶され得るが、スケジューリングコンテキスト外では意味がない場合がある。しかしながら、これは命令メモリにおいてフラグとして記憶され、そのためパケット送信論理により元のストリームが再構成され得る。
自律的メモリ処理装置の作動実施例として(例えばメモリ検索)、パケットは、ネットワーク(例えばメモリネットワーク)からパケットパーサ101により受信され得る。パケットパーサ101は、パケットをセグメントに分解し得る。いくつかのセグメントは、パケットが前のノードから送られた時の前のノードの状態を表すレジスタ内容を含み得るため、コンテキストであり得る。
パケットは、プログラムが実行される、命令メモリ105における開始位置を含み得る。この開始点は、プログラムカウンタ107へロードされ得る。パケットはまた、命令メモリ105へロードされる命令一式と、レジスタファイル109へロードされ得る初期条件一式とを含み得る。初期条件は、前のノードからの命令により送られた変数であり得る。初期条件はまた、現行の実行プログラムにより使用される定数でもあり得る。
プログラムカウンタ107の値は、どの命令を実行のために命令メモリ105から読出すかを決定する。プログラムカウンタ107の次の値は、前の値より増加した値であり得る、またはプログラムカウンタ実行ユニット114により決定される計算値であり得る。
命令は、パーサ115の構成を設定し得る。パーサ115は、命令の実行を通して、変数をページバッファ117から取出し、最終的にメモリ読出動作を行うように構成され得る。
メモリ読出動作が起こると、変数はページバッファ117の内容からリアルタイムに取り出され、実行ユニット113に対し入力として提供され得る。プログラム命令により決定されるように、別の可能入力がレジスタファイルから読出され、処理のため実行ユニット113へ提供され得る。前述のように、「フェンス」により、いくつかの連続命令を並行して実行することが可能になり得る。並列実行不可能な命令は、延期され、次のサイクル中に実行され得る。
実行ユニット113は、これらの入力引数を、各セットが並列処理される複数の入力引数セットとして処理し得る。従って、複数の実行ユニット113が、レジスタファイルへ戻され得る、あるいは1つまたは複数のメモリ書込動作のためのデータとして最終的にページバッファ117へ書込まれるようにパーサ115へ移動され得る、出力変数を生成し得る。すなわち出力変数は、ある特定の活動を生み出すためにレジスタファイルへ入り得る。動作は、パケットジェネレータ111によりパケットを生成する、あるいは新たなメモリ読出動作またはメモリ書込動作を開始するためのものであり得る。
ページバッファ117の内容(例えば検索コマンドの結果)は、ネットワークを介して要求ノードへ送信されるパケットに含まれるように、パケットジェネレータ111に提供され得る。パケットには、タスク(例えば検索)が完了したこと、及びその結果がパケットに含まれていることを示す要求ノードに対するメッセージが含まれ得る。
作動に関するより広範な実施例として、ネットワークは、それぞれが少なくとも1つの自律的メモリ処理装置を備える複数の自律的メモリデバイスから成る機構を含み得る。データ群はメモリデバイス機構の至る所に記憶され得る。特定のデータリストについてデータ群全体の検索が望まれる時、検索プログラムが1つの自律的メモリデバイスにプッシュされ、当該デバイスにおいて特定のデータリストが検索され得る。その特定の自律的メモリデバイスに記憶されているデータが検索され、リストの全てのデータは存在しないことがプログラムにより判定されると、プログラムは1つまたは複数のパケットにまとめられ、別の自律的メモリデバイスに転送され、この別のデバイスの自律的メモリ処理装置が検索を継続し得る。このプログラムをまとめる動作は、自律的メモリデバイスの機構全体が検索されるまで、またはデータリストが完了するまで、続けられ得る。いくつかの実施形態において、特定の自律的メモリデバイスにおいて見つかったデータもまた、転送するプログラムと一緒にパケット(複数可)にまとめられ得る。
そのような実施形態が、図12のフローチャートにおいて例示される。例示された方法は、図11のシステムにおいて、自律的メモリデバイス1101内の自律的メモリ処理装置130により実行され得る。
メモリデバイス1101は、自律的メモリ処理装置130に提供されるパケットを受信し得る1201。装置130は、前述のように、命令、プログラムカウンタ、データを取り出すために、パケットを構文解析し得る1203。そしてメモリ100に記憶されているデータに対し所望のタスクを行うために、命令が実行され得る1205。そして命令と命令により生成された任意のデータが、ネットワーク上で送信するために1209、パケットにまとめられ得る1207。
装置は回路、集積回路ダイ、メモリデバイス、メモリアレイ、またはシステムとして定義され得る。
[結論]
自律的メモリデバイス内の自律的メモリ処理装置の1つまたは複数の実施形態は、従来のCPUベースのコンピューティングシステムにおけるメモリ帯域幅のボトルネックを軽減するために、命令の処理を行い得る。命令(例えばプログラム)一式及び/またはデータを含むパケットはノード間で転送され得、そのためにこれらのノード内のメモリに記憶されたデータは、ソースノードまたはCPUによる制御とは独立した命令により処理され得る。
特定の実施形態が本明細書において例示され説明されたが、同じ目的を達成する意図の任意の配置が、示された特定の実施形態と置換えられ得ることを、当業者は理解するであろう。当業者にとって、数多くの適応形態が明らかであろう。従って、本出願は、任意の適応形態または変形を含めることが意図される。

Claims (19)

  1. 記憶メモリ及びメモリ処理装置を含むメモリデバイスで実行される方法であって、前記メモリ処理装置は、少なくとも1つの実行ユニットと、パケットパーサと、パケットジェネレータとを含み、前記方法は、
    前記メモリ処理装置で、前記パケットパーサを用いて命令一式を受信し且つ構文解析することと、
    前記少なくとも1つの実行ユニットを用いて前記命令一式を実行して、前記メモリデバイスの前記記憶メモリからデータを取り出すことを試みることと、
    前記パケットジェネレータを用いて、前記命令一式を、前記少なくとも1つの実行ユニットによる前記命令一式の前記実行に応じて前記メモリデバイスの前記記憶メモリから取り出された任意のデータと組み合わせて、パケットを生成することと、
    前記パケットジェネレータを用いて前記パケットを送信することであって、前記パケットは、前記メモリ処理装置から、前記メモリデバイスに接続されたメモリコントローラへ転送される、ことと、
    を含み、
    前記メモリ処理装置の、前記少なくとも1つの実行ユニット、前記パケットパーサ、及び前記パケットジェネレータは、前記記憶メモリと同一のハードウェアコンポーネント内に配置されている、方法。
  2. 前記命令一式を受信し且つ構文解析することは、前記メモリデバイスに結合されたネットワークから前記命令一式を受信することを含み、前記パケットを送信することは、前記パケットを前記ネットワークへ送信することを含む、請求項1に記載の方法。
  3. 前記命令一式を受信し且つ構文解析することは、
    前記受信された命令一式に関連付けられた初期プログラムカウンタ値をプログラムカウンタにロードすることと、
    前記命令一式を命令メモリにロードすることと、
    前記命令一式に関連付けられた初期条件一式をレジスタファイルにロードすることと、
    によって、前記命令一式を含むパケットを受信し且つ構文解析することを含む、請求項1に記載の方法。
  4. 前記命令一式を実行することは、
    前記命令一式のうちの第1の命令を実行した後に、新たなプログラムカウンタ値を計算することと、
    前記新たなプログラムカウンタ値を前記プログラムカウンタに記憶させることと、
    を含む、請求項3に記載の方法。
  5. 前記命令一式を実行することは、第1の実行ユニットで第1の命令を実行することと、第2の実行ユニットで第2の命令を実行することとを含み、前記第1及び第2の命令の前記実行は並列である、請求項1に記載の方法。
  6. 前記メモリデバイスは、複数のメモリデバイスノードのうちの第1のノードであり、前記メモリデバイスから前記パケットを送信することは、前記パケットを、前記複数のメモリデバイスノードのうちの第2のノードへ送信することを含む、請求項1に記載の方法。
  7. 前記複数のメモリデバイスノードのうちの第3のノードから初期条件を受信することと、
    前記初期条件をファイルレジスタに記憶させることと、
    を更に含む、請求項6に記載の方法。
  8. 前記命令一式はフェンスフラグを含み、前記命令一式を記憶させることは、前記フェンスフラグよりも前の1つ以上の命令を命令メモリに記憶させ、前記フェンスフラグよりも後の1つ以上の命令を前記命令メモリに記憶させることを含む、請求項1に記載の方法。
  9. 第1の実行ユニットで、前記フェンスフラグよりも前の前記1つ以上の命令を実行することと、
    第2の実行ユニットで、前記フェンスフラグよりも後の前記1つ以上の命令を実行することと、
    を更に含む、請求項8に記載の方法。
  10. 前記フェンスフラグよりも前の前記1つ以上の命令を実行することは、前記フェンスフラグよりも後の前記1つ以上の命令を実行することと同時に行われる、請求項9に記載の方法。
  11. 前記実行ユニットを用いて前記命令一式を実行することは、
    複数のオペランドをプログラムカウンタ実行ユニットに提供することと、
    演算子を前記プログラムカウンタ実行ユニットに提供することと、
    前記複数のオペランドに対して前記演算子を実行した結果に応じて、更新されたプログラムカウンタ値を生成することと、
    を含む、請求項1に記載の方法。
  12. 前記メモリ処理装置及び前記記憶メモリは、同一のダイ、同一のダイスタック、又は同一のメモリモジュールのうちの1つに含まれており、
    前記記憶メモリは、ランダムアクセスメモリ(RAM)、ダイナミックランダムアクセスメモリ(DRAM)、同期式ランダムアクセスメモリ(SRAM)、NANDフラッシュ、NORフラッシュ、又は相変化メモリ(PCM)を含む、請求項1に記載の方法。
  13. 前記メモリ処理装置は、前記メモリデバイス内に配置された複数のメモリ処理装置のうちの1つである、請求項1に記載の方法。
  14. 記憶メモリとメモリ処理装置とを備えるメモリデバイス装置であって、
    前記メモリ処理装置は、
    命令一式と開始位置とを含むパケットを受信するように構成されたパケットパーサと、
    前記パケットパーサに結合され、前記命令一式を受信するように構成された命令メモリと、
    前記命令メモリ及び前記パケットパーサに結合されたプログラムカウンタであって、初めに前記パケットパーサから前記開始位置を受信し、前記命令メモリにおける前記開始位置から命令を取り出すように構成されたプログラムカウンタと、
    前記命令メモリに結合された、前記命令一式を実行するための複数の実行ユニットと、
    前記複数の実行ユニットに結合されたパーサであって、ローカルメモリからのデータの読み出しを制御するように構成されたパーサと、
    前記パーサ及び前記命令メモリに結合され、前記パーサ及び前記パケットパーサからのデータを記憶するように構成されたレジスタと、
    前記命令メモリ及び前記レジスタに結合されたパケットジェネレータであって、前記命令一式及び前記データを含む送信用パケットを生成するように構成されたパケットジェネレータと、
    を備え、
    前記メモリ処理装置の、前記パケットパーサ、前記命令メモリ、前記プログラムカウンタ、前記複数の実行ユニット、前記パーサ、前記レジスタ、及び前記パケットジェネレータは、前記記憶メモリと同一のハードウェアコンポーネント内に配置されている、メモリデバイス装置。
  15. 前記複数の実行ユニットの各々は、
    複数の演算論理ユニット(ALU)と、
    前記複数の演算論理ユニットのうちの少なくとも2つの出力の間に結合された多重化機能と、
    を備える、請求項14に記載のメモリデバイス装置。
  16. 前記複数のALUは、前記命令一式の各命令に関連付けられたALUを含む、請求項15に記載のメモリデバイス装置。
  17. 前記複数の実行ユニットの各々はif−then−else文を実施する、請求項15に記載のメモリデバイス装置。
  18. 前記メモリ処理装置及び前記記憶メモリは、同一のダイ、同一のダイスタック、又は同一のメモリモジュールのうちの1つに含まれており、
    前記記憶メモリは、ランダムアクセスメモリ(RAM)、ダイナミックランダムアクセスメモリ(DRAM)、同期式ランダムアクセスメモリ(SRAM)、NANDフラッシュ、NORフラッシュ、又は相変化メモリ(PCM)を含む、請求項14に記載のメモリデバイス装置。
  19. 前記メモリ処理装置は、前記メモリデバイス装置内に配置された複数のメモリ処理装置のうちの1つである、請求項14に記載のメモリデバイス装置。
JP2018072998A 2013-12-02 2018-04-05 自律的メモリの方法及びシステム Active JP6633119B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14/094,273 US10003675B2 (en) 2013-12-02 2013-12-02 Packet processor receiving packets containing instructions, data, and starting location and generating packets containing instructions and data
US14/094,273 2013-12-02

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2016535174A Division JP6449287B2 (ja) 2013-12-02 2014-12-01 自律的メモリの方法及びシステム

Publications (2)

Publication Number Publication Date
JP2018139118A JP2018139118A (ja) 2018-09-06
JP6633119B2 true JP6633119B2 (ja) 2020-01-22

Family

ID=53265363

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2016535174A Active JP6449287B2 (ja) 2013-12-02 2014-12-01 自律的メモリの方法及びシステム
JP2018072998A Active JP6633119B2 (ja) 2013-12-02 2018-04-05 自律的メモリの方法及びシステム

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2016535174A Active JP6449287B2 (ja) 2013-12-02 2014-12-01 自律的メモリの方法及びシステム

Country Status (6)

Country Link
US (2) US10003675B2 (ja)
EP (1) EP3077911B1 (ja)
JP (2) JP6449287B2 (ja)
KR (1) KR101812912B1 (ja)
CN (1) CN105874436B (ja)
WO (1) WO2015084728A1 (ja)

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9779057B2 (en) 2009-09-11 2017-10-03 Micron Technology, Inc. Autonomous memory architecture
US9779138B2 (en) 2013-08-13 2017-10-03 Micron Technology, Inc. Methods and systems for autonomous memory searching
US10003675B2 (en) 2013-12-02 2018-06-19 Micron Technology, Inc. Packet processor receiving packets containing instructions, data, and starting location and generating packets containing instructions and data
KR102395190B1 (ko) 2017-07-31 2022-05-06 삼성전자주식회사 호스트와 인터페이스를 수행하는 스토리지 장치, 호스트 및 스토리지 장치의 동작방법
US11289137B2 (en) * 2017-11-16 2022-03-29 Micron Technology, Inc. Multi-port storage-class memory interface
US11119946B2 (en) * 2019-05-16 2021-09-14 Micron Technology, Inc. Codeword rotation for zone grouping of media codewords
CN110933001B (zh) * 2019-11-18 2020-11-27 清华大学 一种可扩展的可重构交换机包解析器基本处理单元结构
JP2022010951A (ja) 2020-06-29 2022-01-17 キオクシア株式会社 半導体記憶装置

Family Cites Families (115)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH062038B2 (ja) 1987-11-18 1994-01-12 江口 光市郎 イワシ肉消臭加工法
US5134711A (en) 1988-05-13 1992-07-28 At&T Bell Laboratories Computer with intelligent memory system
GB8816413D0 (en) 1988-07-09 1988-08-17 Int Computers Ltd Data processing system
US5105425A (en) 1989-12-29 1992-04-14 Westinghouse Electric Corp. Adaptive or fault tolerant full wafer nonvolatile memory
DE69132495T2 (de) 1990-03-16 2001-06-13 Texas Instruments Inc., Dallas Verteilter Verarbeitungsspeicher
JPH04132356A (ja) 1990-09-21 1992-05-06 Ricoh Co Ltd 内線電話交換方式
GB9023096D0 (en) 1990-10-24 1990-12-05 Int Computers Ltd Database search processor
JPH052610A (ja) 1991-06-25 1993-01-08 Mitsubishi Electric Corp リレーシヨナルデータベースにおける集約演算処理方式
JP2579419B2 (ja) 1992-05-22 1997-02-05 インターナショナル・ビジネス・マシーンズ・コーポレイション マルチプロセッサ・メモリ・システム
US5671430A (en) * 1993-06-30 1997-09-23 Gunzinger; Anton Parallel data processing system with communication apparatus control
US5835755A (en) 1994-04-04 1998-11-10 At&T Global Information Solutions Company Multi-processor computer system for operating parallel client/server database processes
CA2145106C (en) 1994-04-22 1999-08-24 Abhaya Asthana Intelligent memory-based input/output system
US6101620A (en) 1995-04-18 2000-08-08 Neomagic Corp. Testable interleaved dual-DRAM architecture for a video memory controller with split internal/external memory
US5754948A (en) 1995-12-29 1998-05-19 University Of North Carolina At Charlotte Millimeter-wave wireless interconnection of electronic components
JP3289101B2 (ja) 1996-01-25 2002-06-04 東京エレクトロン株式会社 フラッシュ・ディスク・システムの初期化方法及び装置
KR100359414B1 (ko) 1996-01-25 2003-01-24 동경 엘렉트론 디바이스 주식회사 데이타독출/기록방법및그를이용한메모리제어장치및시스템
US6047334A (en) * 1997-06-17 2000-04-04 Intel Corporation System for delaying dequeue of commands received prior to fence command until commands received before fence command are ordered for execution in a fixed sequence
AU9604698A (en) 1997-10-10 1999-05-03 Rambus Incorporated Method and apparatus for two step memory write operations
US6105130A (en) 1997-12-23 2000-08-15 Adaptec, Inc. Method for selectively booting from a desired peripheral device
JPH11232180A (ja) 1998-02-10 1999-08-27 Hitachi Ltd データ処理装置
US6751606B1 (en) 1998-12-23 2004-06-15 Microsoft Corporation System for enhancing a query interface
US7610559B1 (en) 1999-07-27 2009-10-27 Samsung Electronics Co., Ltd. Device customized home network top-level information architecture
US20020009119A1 (en) 2000-02-11 2002-01-24 Matthew William T. Environmental heat stress monitor
CA2402018A1 (en) * 2000-03-03 2001-09-13 Tenor Networks, Inc. High-speed data processing using internal processor memory space
US20020161848A1 (en) 2000-03-03 2002-10-31 Willman Charles A. Systems and methods for facilitating memory access in information management environments
US20020124137A1 (en) 2001-01-29 2002-09-05 Ulrich Thomas R. Enhancing disk array performance via variable parity based load balancing
US6516380B2 (en) 2001-02-05 2003-02-04 International Business Machines Corporation System and method for a log-based non-volatile write cache in a storage controller
US6526491B2 (en) 2001-03-22 2003-02-25 Sony Corporation Entertainment Inc. Memory protection system and method for computer architecture for broadband networks
US6586276B2 (en) 2001-07-11 2003-07-01 Intel Corporation Method for fabricating a microelectronic device using wafer-level adhesion layer deposition
US7356568B2 (en) 2002-12-12 2008-04-08 International Business Machines Corporation Method, processing unit and data processing system for microprocessor communication in a multi-processor system
US20040186832A1 (en) 2003-01-16 2004-09-23 Jardin Cary A. System and method for controlling processing in a distributed system
US7581080B2 (en) 2003-04-23 2009-08-25 Micron Technology, Inc. Method for manipulating data in a group of processing elements according to locally maintained counts
GB2406399A (en) 2003-09-23 2005-03-30 Ibm Seaching within a computer network by entering a search term and optional URI into a web browser
US7050351B2 (en) 2003-12-30 2006-05-23 Intel Corporation Method and apparatus for multiple row caches per bank
US7380039B2 (en) 2003-12-30 2008-05-27 3Tera, Inc. Apparatus, method and system for aggregrating computing resources
US7487288B2 (en) 2004-05-14 2009-02-03 International Business Machines Corporation Dynamic loading of virtual volume data in a virtual tape server
US7490354B2 (en) 2004-06-10 2009-02-10 International Business Machines Corporation Virus detection in a network
US7243200B2 (en) 2004-07-15 2007-07-10 International Business Machines Corporation Establishing command order in an out of order DMA command queue
US7242216B1 (en) 2004-11-08 2007-07-10 Herman Schmit Embedding memory between tile arrangement of a configurable IC
US7978682B2 (en) 2005-05-09 2011-07-12 At&T Intellectual Property I, Lp Methods, systems, and computer-readable media for optimizing the communication of data packets in a data network
US7634622B1 (en) * 2005-06-14 2009-12-15 Consentry Networks, Inc. Packet processor that generates packet-start offsets to immediately store incoming streamed packets using parallel, staggered round-robin arbitration to interleaved banks of memory
US20070005922A1 (en) 2005-06-30 2007-01-04 Swaminathan Muthukumar P Fully buffered DIMM variable read latency
US20070165457A1 (en) 2005-09-30 2007-07-19 Jin-Ki Kim Nonvolatile memory system
US7558859B2 (en) 2005-10-17 2009-07-07 Microsoft Corporation Peer-to-peer auction based data distribution
US8275949B2 (en) 2005-12-13 2012-09-25 International Business Machines Corporation System support storage and computer system
US20070150699A1 (en) 2005-12-28 2007-06-28 Schoinas Ioannis T Firm partitioning in a system with a point-to-point interconnect
US7609561B2 (en) 2006-01-18 2009-10-27 Apple Inc. Disabling faulty flash memory dies
JP4786354B2 (ja) * 2006-01-27 2011-10-05 株式会社日立製作所 iSCSI通信制御方法とそれを用いた記憶システム
DE102006009027A1 (de) 2006-02-27 2007-08-30 Infineon Technologies Ag Speicheranordnung
US7756898B2 (en) 2006-03-31 2010-07-13 Isilon Systems, Inc. Systems and methods for notifying listeners of events
TW200743991A (en) 2006-05-18 2007-12-01 Realtek Semiconductor Corp Data search method and apparatus thereof
US7647454B2 (en) 2006-06-12 2010-01-12 Hewlett-Packard Development Company, L.P. Transactional shared memory system and method of control
US8850411B2 (en) 2006-06-21 2014-09-30 Element Cxi, Llc Compiler system, method and software for a resilient integrated circuit architecture
US7941579B2 (en) 2006-06-30 2011-05-10 Brother Kogyo Kabushiki Kaisha Communication system for authenticating authority of host device for accessing storage medium set to periphery device
US8601155B2 (en) 2006-08-16 2013-12-03 Oracle America, Inc. Telemetry stream performance analysis and optimization
US7952184B2 (en) 2006-08-31 2011-05-31 Micron Technology, Inc. Distributed semiconductor device methods, apparatus, and systems
US7788243B2 (en) 2006-09-08 2010-08-31 Sybase, Inc. System and methods for optimizing data transfer among various resources in a distributed environment
US7657705B2 (en) 2006-09-27 2010-02-02 Lsi Corporation Method and apparatus of a RAID configuration module
US7477535B2 (en) 2006-10-05 2009-01-13 Nokia Corporation 3D chip arrangement including memory manager
US7761485B2 (en) 2006-10-25 2010-07-20 Zeugma Systems Inc. Distributed database
US8285707B2 (en) 2006-11-08 2012-10-09 International Business Machines Corporation Method of querying relational database management systems
US8510481B2 (en) 2007-01-03 2013-08-13 Apple Inc. Memory access without internal microprocessor intervention
US7761687B2 (en) 2007-06-26 2010-07-20 International Business Machines Corporation Ultrascalable petaflop parallel supercomputer
US8037270B2 (en) 2007-06-27 2011-10-11 International Business Machines Corporation Structure for memory chip for high capacity memory subsystem supporting replication of command data
US8433842B2 (en) * 2007-06-29 2013-04-30 Sandisk Technologies Inc. Method for communicating with a non-volatile memory storage device
US8320373B2 (en) * 2007-08-23 2012-11-27 Qualcomm Incorporated Packet-based processing system
US7895151B2 (en) 2008-06-23 2011-02-22 Teradata Us, Inc. Fast bulk loading and incremental loading of data into a database
US7623365B2 (en) 2007-08-29 2009-11-24 Micron Technology, Inc. Memory device interface methods, apparatus, and systems
US7913033B2 (en) 2007-10-09 2011-03-22 Micron Technology, Inc. Non-volatile memory device having assignable network identification
US7816934B2 (en) 2007-10-16 2010-10-19 Micron Technology, Inc. Reconfigurable connections for stacked semiconductor devices
TWI346289B (en) * 2007-12-19 2011-08-01 Ralink Technology Corp Peripheral complying with sdio standard and method for managing sdio command
US8621138B2 (en) * 2007-12-27 2013-12-31 Sandisk Enterprise Ip Llc Flash storage controller execute loop
US8194433B2 (en) 2008-02-20 2012-06-05 Ovonyx, Inc. Method and apparatus for accessing a bidirectional memory
JP2009211233A (ja) 2008-03-01 2009-09-17 Toshiba Corp メモリシステム
US7979757B2 (en) 2008-06-03 2011-07-12 Micron Technology, Inc. Method and apparatus for testing high capacity/high bandwidth memory devices
WO2009153687A1 (en) 2008-06-18 2009-12-23 Petascan Ltd Distributed hardware-based data querying
US8407399B2 (en) 2008-10-29 2013-03-26 Sandisk Il Ltd. Method and apparatus for enforcing a flash memory caching policy
US20100161914A1 (en) 2008-12-23 2010-06-24 Eilert Sean S Autonomous memory subsystems in computing platforms
US8493979B2 (en) * 2008-12-30 2013-07-23 Intel Corporation Single instruction processing of network packets
US20100180182A1 (en) 2009-01-09 2010-07-15 Seagate Technology Llc Data memory device and controller with interface error detection and handling logic
US8261019B2 (en) 2009-02-13 2012-09-04 Oracle America, Inc. Conveying critical data in a multiprocessor system
US8549092B2 (en) 2009-02-19 2013-10-01 Micron Technology, Inc. Memory network methods, apparatus, and systems
TWI406130B (zh) 2009-03-10 2013-08-21 Phison Electronics Corp 資料處理系統、控制器及其搜尋特定記憶體區的方法
US8427952B1 (en) * 2009-03-24 2013-04-23 Packet Plus, Inc. Microcode engine for packet processing
US8259506B1 (en) 2009-03-25 2012-09-04 Apple Inc. Database of memory read thresholds
US8942113B2 (en) 2009-05-07 2015-01-27 Verizon Patent And Licensing Inc. System and method for dynamically adjusting routing metrics based on power consumption
CN102014011A (zh) 2009-09-04 2011-04-13 中兴通讯股份有限公司 环网保护方法与系统
US8972627B2 (en) 2009-09-09 2015-03-03 Fusion-Io, Inc. Apparatus, system, and method for managing operations for data storage media
US9779057B2 (en) 2009-09-11 2017-10-03 Micron Technology, Inc. Autonomous memory architecture
US9015440B2 (en) 2009-09-11 2015-04-21 Micron Technology, Inc. Autonomous memory subsystem architecture
US8374022B2 (en) 2009-12-21 2013-02-12 Intel Corporation Programming phase change memories using ovonic threshold switches
US8954714B2 (en) * 2010-02-01 2015-02-10 Altera Corporation Processor with cycle offsets and delay lines to allow scheduling of instructions through time
US10803066B2 (en) 2010-06-29 2020-10-13 Teradata Us, Inc. Methods and systems for hardware acceleration of database operations and queries for a versioned database based on multiple hardware accelerators
KR20120004162A (ko) 2010-07-06 2012-01-12 삼성전자주식회사 데이터베이스 관리 방법 및 이를 이용한 데이터베이스 서버 시스템
US9792307B2 (en) 2010-07-27 2017-10-17 Oracle International Corporation Enterprise-based searching of new and updated data
US8930618B2 (en) 2010-08-24 2015-01-06 Futurewei Technologies, Inc. Smart memory
US8595414B2 (en) * 2010-09-30 2013-11-26 Apple Inc. Selectively combining commands for a system having non-volatile memory
US10026458B2 (en) 2010-10-21 2018-07-17 Micron Technology, Inc. Memories and methods for performing vector atomic memory operations with mask control and variable data length and data unit size
JP5238791B2 (ja) 2010-11-10 2013-07-17 株式会社東芝 転送機能を有するメモリノードを相互に接続したストレージ装置及びデータ処理方法
JP2012159903A (ja) 2011-01-31 2012-08-23 Fujitsu Semiconductor Ltd データ処理システム、データ処理装置、及びデータ処理方法
US8478736B2 (en) 2011-02-08 2013-07-02 International Business Machines Corporation Pattern matching accelerator
US8756405B2 (en) * 2011-05-09 2014-06-17 Freescale Semiconductor, Inc. Selective routing of local memory accesses and device thereof
KR101306622B1 (ko) 2011-06-22 2013-09-11 주식회사 에이디칩스 명령어 큐 제어장치
JP2013045378A (ja) 2011-08-26 2013-03-04 Fujitsu Ltd ストレージ制御方法、情報処理装置およびプログラム
US8917534B2 (en) 2011-09-09 2014-12-23 Intel Corporation Path isolation in a memory device
US8775685B1 (en) * 2011-10-13 2014-07-08 Xilinx, Inc. Parallel processing of network packets
CN102521535A (zh) * 2011-12-05 2012-06-27 苏州希图视鼎微电子有限公司 通过特定指令集来进行相关运算的信息安全协处理器
US20130173655A1 (en) 2012-01-04 2013-07-04 International Business Machines Corporation Selective fetching of search results
US9245926B2 (en) 2012-05-07 2016-01-26 Micron Technology, Inc. Apparatuses and methods including memory access in cross point memory
US8675423B2 (en) 2012-05-07 2014-03-18 Micron Technology, Inc. Apparatuses and methods including supply current in memory
US8780635B2 (en) 2012-11-09 2014-07-15 Sandisk Technologies Inc. Use of bloom filter and improved program algorithm for increased data protection in CAM NAND memory
US9424202B2 (en) 2012-11-19 2016-08-23 Smartfocus Holdings Limited Database search facility
US10089043B2 (en) 2013-03-15 2018-10-02 Micron Technology, Inc. Apparatus and methods for a distributed memory system including memory nodes
US9779138B2 (en) 2013-08-13 2017-10-03 Micron Technology, Inc. Methods and systems for autonomous memory searching
US10003675B2 (en) 2013-12-02 2018-06-19 Micron Technology, Inc. Packet processor receiving packets containing instructions, data, and starting location and generating packets containing instructions and data

Also Published As

Publication number Publication date
CN105874436A8 (zh) 2016-09-21
EP3077911B1 (en) 2022-05-04
JP6449287B2 (ja) 2019-01-09
US10778815B2 (en) 2020-09-15
KR101812912B1 (ko) 2018-01-30
WO2015084728A1 (en) 2015-06-11
CN105874436B (zh) 2019-03-08
US20150153963A1 (en) 2015-06-04
US20190007529A1 (en) 2019-01-03
US10003675B2 (en) 2018-06-19
EP3077911A4 (en) 2017-08-02
KR20160092007A (ko) 2016-08-03
EP3077911A1 (en) 2016-10-12
JP2017504870A (ja) 2017-02-09
JP2018139118A (ja) 2018-09-06
CN105874436A (zh) 2016-08-17

Similar Documents

Publication Publication Date Title
JP6633119B2 (ja) 自律的メモリの方法及びシステム
US9292291B2 (en) Instruction merging optimization
US9092275B2 (en) Store operation with conditional push of a tag value to a queue
JP3752224B2 (ja) コンピュータ・システムにおいて命令を処理する方法および装置
US8996788B2 (en) Configurable flash interface
JP2006338538A (ja) ストリームプロセッサ
EP3407184A2 (en) Near memory computing architecture
JP2007034392A (ja) 情報処理装置及びデータ処理方法
JP6250447B2 (ja) 半導体装置及び命令読み出し制御方法
WO2009098737A1 (ja) 外部デバイスアクセス装置、その制御方法及びシステムlsi
KR20200123799A (ko) 디바이스를 디버깅할 때 메타데이터에 액세스하기 위한 장치 및 방법
US20150006765A1 (en) Direct memory access descriptor-based synchronization
US20080209085A1 (en) Semiconductor device and dma transfer method
US10803007B1 (en) Reconfigurable instruction
KR102028729B1 (ko) 정적 스케쥴 프로세서의 논블로킹 실행 장치 및 방법
US20150363227A1 (en) Data processing unit and method for operating a data processing unit
US10216453B1 (en) Reverse slot invalidation for pointer rings
Ünsalan et al. Memory Operations
US10606498B2 (en) Method for allocating memory
JP6138482B2 (ja) 組み込みシステム
CN117666944A (zh) 用于执行数据处理功能的方法和存储装置
JP2006268487A (ja) エミュレーション装置及びエミュレーション方法、並びに、エミュレーションプログラム
JP2001134448A (ja) 情報処理装置及び割込み処理方法
JP2017045134A (ja) 情報処理装置、コンパイル方法及びコンパイラ

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180420

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20180420

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20190219

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20190402

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190612

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20191211

R150 Certificate of patent or registration of utility model

Ref document number: 6633119

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250