JP6246140B2 - データを命令が指示する指定されたメモリ境界までロードするためのコンピュータ・プログラム、コンピュータ・システムおよび方法 - Google Patents
データを命令が指示する指定されたメモリ境界までロードするためのコンピュータ・プログラム、コンピュータ・システムおよび方法 Download PDFInfo
- Publication number
- JP6246140B2 JP6246140B2 JP2014561526A JP2014561526A JP6246140B2 JP 6246140 B2 JP6246140 B2 JP 6246140B2 JP 2014561526 A JP2014561526 A JP 2014561526A JP 2014561526 A JP2014561526 A JP 2014561526A JP 6246140 B2 JP6246140 B2 JP 6246140B2
- Authority
- JP
- Japan
- Prior art keywords
- operand
- register
- field
- block
- boundary
- 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
- 238000004590 computer program Methods 0.000 title claims description 33
- 238000000034 method Methods 0.000 title claims description 29
- 238000012545 processing Methods 0.000 claims description 44
- 238000006073 displacement reaction Methods 0.000 claims description 20
- 238000004891 communication Methods 0.000 claims description 8
- 239000013598 vector Substances 0.000 description 129
- 238000003860 storage Methods 0.000 description 70
- 230000006870 function Effects 0.000 description 31
- 238000013519 translation Methods 0.000 description 18
- 230000014616 translation Effects 0.000 description 18
- 238000010586 diagram Methods 0.000 description 12
- 230000001343 mnemonic effect Effects 0.000 description 7
- 230000009471 action Effects 0.000 description 6
- 238000006243 chemical reaction Methods 0.000 description 5
- 230000000295 complement effect Effects 0.000 description 5
- 230000008901 benefit Effects 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 238000004422 calculation algorithm Methods 0.000 description 3
- 230000000694 effects Effects 0.000 description 3
- 230000007774 longterm Effects 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 230000002093 peripheral effect Effects 0.000 description 3
- 230000003139 buffering effect Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000001934 delay Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 239000000463 material Substances 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000009466 transformation Effects 0.000 description 2
- 238000012884 algebraic function Methods 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 150000001875 compounds Chemical class 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 239000000839 emulsion Substances 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 230000014759 maintenance of location Effects 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000007781 pre-processing Methods 0.000 description 1
- 238000005215 recombination Methods 0.000 description 1
- 230000006798 recombination Effects 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 229920000638 styrene acrylonitrile Polymers 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 210000003813 thumb Anatomy 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 238000000844 transformation Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/3004—Arrangements for executing specific machine instructions to perform operations on memory
- G06F9/30043—LOAD or STORE instructions; Clear instruction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/30036—Instructions to perform operations on packed data, e.g. vector, tile or matrix operations
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/30036—Instructions to perform operations on packed data, e.g. vector, tile or matrix operations
- G06F9/30038—Instructions to perform operations on packed data, e.g. vector, tile or matrix operations using a mask
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/3004—Arrangements for executing specific machine instructions to perform operations on memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/3004—Arrangements for executing specific machine instructions to perform operations on memory
- G06F9/30047—Prefetch instructions; cache control instructions
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30098—Register arrangements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30098—Register arrangements
- G06F9/3012—Organisation of register space, e.g. banked or distributed register file
- G06F9/3013—Organisation of register space, e.g. banked or distributed register file according to data content, e.g. floating-point registers, address registers
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30145—Instruction analysis, e.g. decoding, instruction word fields
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3824—Operand accessing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3861—Recovery, e.g. branch miss-prediction, exception handling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
- G06F9/45516—Runtime code conversion or optimisation
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- Executing Machine-Instructions (AREA)
- Advance Control (AREA)
Description
0−命令の第1ベクトル・レジスタ指定のための最上位ビット。
1−もしあれば、命令の第2ベクトル・レジスタ指定のための最上位ビット。
2−もしあれば、命令の第3ベクトル・レジスタ指定のための最上位ビット。
3−もしあれば、命令の第4ベクトル・レジスタ指定のための最上位ビット。
コード 境界
0 64−バイト
1 128−バイト
2 256−バイト
3 512−バイト
4 1K−バイト
5 2K−バイト
6 4K−バイト
ベクトル・ストリング・ファシリティ
→
命令
別に指定しない限り、全てのオペランドはベクトル・レジスタ・オペランドである。アセンブラ構文における「V」は、ベクトル・オペランドを指示する。
VECTOR FIND ANY EQUAL
左から右へ進み、第2のオペランドの全ての符合なし2進整数要素は、第3のオペランドの符合なし2進整数要素の各々と、及びM5フィールド内にZero Search(ゼロ検索)フラグが設定されている場合には随意的にゼロと、等値性に関して比較される。
M5フィールド内のResult Type(RT)フラグが1である場合、第3のオペランド内の一要素と一致するか又はゼロである第2のオペランド内の左端要素のバイト・インデックスが、第1のオペランドのバイト7に格納される。
0−バイト
1−ハーフワード
2−ワード
3〜15−予約される
・Result Type(RT):ゼロの場合、結果の各要素は、その要素に関する全範囲比較のマスクとなる。1の場合、バイト・インデックスが第1のオペランドのバイト7に格納され、ゼロが全ての他の要素に格納される。
・Zero Search(ゼロ検索)(ZS):1の場合、第2のオペランドの各要素は、ゼロとも比較される。
・Condition Code Set(条件コード設定)(CC):ゼロの場合、条件コードは設定されず、変更されないままである。1の場合、条件コードは、以下の節で指定されるように設定される。
指定例外が認識され、以下のいずれかが生じた場合、他のいずれのアクションもとられない。
1.M4フィールドが3から15までの値を含む。
2.M5フィールドのビット0がゼロでない。
CCフラグがゼロである場合、コードは変更されないままである。
CCフラグが1である場合、コードは以下のように設定される。
0 ZSビットが設定されている場合、第2のオペランド内のゼロより下位のインデックス付き要素内に一致が存在しなかった。
1 第2のオペランドの幾つかの要素が、第3のオペランド内の少なくとも1つの要素と一致する。
2 第2のオペランド内の全ての要素が、第3のオペランド内の少なくとも1つの要素と一致した。
3 第2のオペランド内の要素は、第3のオペランド内のいずれの要素とも一致しない。
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定(予約されたES値)
・トランザクション制限
左から右へ進み、第2のオペランドの符合なし2進整数要素が、第3のオペランドの対応する符合なし2進整数要素と比較される。2つの要素が等しい場合、左端等値要素の最初のバイトのバイト・インデックスが、第1のオペランドのバイト7に入れられる。第1のオペランドの残りのバイトにゼロが格納される。どのバイトも等しくないか、又は、ゼロ比較が設定されている場合にゼロである場合、ベクトル内のバイト数に等しいインデックスが、第1のオペランドのバイト7に格納される。残りのバイトにはゼロが格納される。
0−バイト
1−ハーフワード
2−ワード
3〜15−予約される
M5フィールドのビットは、以下のように定義される。
・Reserved(予約される):ビット0−1は予約されており、ゼロでなければならない。そうでない場合には、指定例外が認識される。
・Zero Search(ZS):1の場合、第2のオペランドの各要素は、ゼロとも比較される。
・Condition Code Set(CC):ゼロの場合、条件コードは変更されないままである。1の場合、条件コードは、以下の節で指定されるように設定される。
指定例外が認識され、以下のいずれかが生じた場合、他のいずれのアクションもとられない。
1.M4フィールドが3から15までの値を含む。
2.M5フィールドのビット0−1がゼロでない。
M5フィールドのビット3が1に設定されている場合、コードは以下のように設定される:
0 ゼロ比較ビットが設定されている場合、比較により、第2のオペランド内のゼロ要素がいずれの等値比較よりも小さいインデックスを有する要素内で検出された。
1 比較により、第2のオペランドと第3のオペランドとの間で何らかの要素の一致が検出された。ゼロ比較ビットが設定されている場合、この一致は、ゼロ比較要素より小さい又はこれに等しいインデックスを有する要素において生じた。
2 −−
3 比較したいずれの要素も等値でない。
M5フィールドのビット3がゼロである場合、コードは変更されないままである。
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定(予約されたES値)
・トランザクション制限
1.バイト・インデックスは、いずれの要素サイズに関しても常に第1のオペランド内に格納される。例えば、要素サイズがハーフワードに設定され、第2のインデックス付きハーフワードが等値比較された場合、4のバイト・インデクッスが格納される。
2.第3のオペランドは、ゼロ値を有する要素を含んではならない。第3のオペランドがゼロを含み、且つ、他のいずれかの等値比較の前に第2のオペランド内のゼロ要素と一致した場合、ゼロ比較ビットの設定に関わらず、条件コード1が設定される。
左から右へ進み、第2のオペランドの符合なし2進整数要素が、第3のオペランドの対応する符合なし2進整数要素と比較される。2つの要素が等しくない場合、左端の非等値要素のバイト・インデックスが、第1のオペランドのバイト7に入れられ、他の全てのバイトにゼロが格納される。M5フィールド内のCondition Code Set(CC)ビットが1に設定されている場合、条件コードはどのオペランドがより大きかったかを示すように設定される。全ての要素が等しかった場合、ベクトル・サイズに等しいバイト・インデックスが第1のオペランドのバイト7に入れられ、他の全てのバイト位置にはゼロが配置される。CCビットが1である場合、条件コード3が設定される。
0−バイト
1−ハーフワード
2−ワード
3〜15−予約される
M5フィールドのビットは、以下のように定義される。
・Zero Search(ZS):1の場合、第2のオペランドの各要素は、ゼロとも比較される。
・Condition Code Set(CC):ゼロの場合、条件コードは設定されず変更されないままである。1の場合、条件コードは以下の節で指定されるように設定される。
指定例外が認識され、以下のいずれかが生じた場合、その他のいずれのアクションもとられない。
1.M4フィールドが3から15までの値を含む。
2.M5フィールドのビット0−1がゼロでない。
M5フィールドのビット3が1に設定されている場合、コードは以下のように設定される:
0 ゼロ、比較ビットが設定されている場合、比較により、両オペランド内のゼロ要素がいずれの非等値比較よりも下位のインデックス付き要素内で検出された。
1 要素不一致が検出され、VR2内の要素がVR3内の要素より小さい。
2 要素不一致が検出され、VR2内の要素がVR3内の要素より大きい。
3 比較された全ての要素が等値であり、ゼロ比較ビットが設定されている場合、第2のオペランド内にゼロ要素が見出されなかった。
M5フィールドのビット3がゼロである場合、コードは変更されないままである。
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定(予約されたES値)
・トランザクション制限
左から右へ進み、第2のオペランドの符合なし2進整数要素が、第3及び第4のオペランド内の要素の偶数−奇数対によって定義される値の範囲と比較される。第4のオペランドからの制御値との組み合わせが、実施される比較の範囲を定める。ある要素が第3及び第4のオペランドによって指定された範囲のいずれかと一致する場合、一致であると見なされる。
・Equal(等しい)(EQ):1のとき、等値比較がなされる。
・Grater Than(大なり)(GT):1のとき大なり(greater than)比較が実施される。
・Less Than(小なり)(LT):1のとき、小なり(less than)比較が実施される。
・全ての他のビットは、予約され、将来の互換性を保証するためにゼロにすべきである。
0−バイト
1−ハーフワード
2−ワード
3〜15−予約される
M6フィールドのビットは。以下のように定義される。
・Invert Result(反転結果)(IN):ゼロの場合、制御ベクトル内の値の対について比較が続けられる。1の場合、その範囲内の比較の対の結果が反転される。
・Result Type(RT):ゼロの場合、結果の各要素は、その要素についての全ての範囲比較のマスクとなる。1の場合、インデックスが第1のオペランドのバイト7に格納される。残りのバイトにはゼロが格納される。
・Zero Search(ZS):1の場合、第2のオペランドの各要素は、ゼロとも比較される。
・Condition Code Set(CC):ゼロの場合、条件コードは設定されず、変更されないままである。1の場合、条件コードは、以下の節で指定されるように設定される。
指定例外が認識され、以下のいずれかが生じた場合、他のいずれのアクションもとられない。
1.M4フィールドが3から15までの値を含む。
0 ZS=1であり、且つ、いずれの比較よりも下位のインデクス付き要素内にゼロが見出される場合
1 比較が見出される
2 −−
3 比較が見出されない
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定(予約されたES値)
・トランザクション制限
上限16とされた指定ブロック境界を超えることなく、第2のオペランド位置からロードすることが可能なバイト数を含んだ32ビットの符合なし2進整数が、第1のオペランドに入れられる。
変位は、12ビットの符号なし整数として扱われる。
第2のオペランド・アドレスは、データをアドレス指定するのには使用されない。
M3フィールドは、ロードされる可能なバイト数を計算するためのブロック境界サイズに関してCPUに信号を送るのに用いられるコードを指定する。予約値が指定された場合には、指定例外が認識される。
0 64バイト
1 128バイト
2 256バイト
3 512バイト
4 1Kバイト
5 2Kバイト
6 4Kバイト
7〜15 予約される
0 オペランド1が16である
1 −−
2 −−
3 オペランド1が16より小さい
プログラム例外:
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定
M4フィールド内のES値で指定されたサイズの、第2のオペランド・アドレスでインデックス付けされた第3のオペランドの要素が、第1のオペランド位置内に入れられる。第3のオペランドは、ベクトル・レジスタである。第1のオペランドは、汎用レジスタである。第2のオペランド・アドレスによって指定されたインデックスが、指定された要素サイズの第3のオペランド内の最高番号を付された要素よりも大きい場合、第1のオペランド内のデータは、予測不可能である。
ベクトル・レジスタ要素がダブルワードより小さい場合、要素は64ビット汎用レジスタ内で右寄せされ、残りのビットにゼロが入れられる。
0−バイト
1−ハーフワード
2−ワード
3−ダブルワード
4〜15−予約されており、変更されない。
プログラム例外:
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定(予約されたES値)
・トランザクション制限
第1のオペランドが、第2のオペランドからのバイトを伴うゼロでインデックス付けされたバイト要素で開始して、ロードされる。境界条件に遭遇した場合、第1のオペランドの残りは予測不可能である。ロードされていないバイトに対して、アクセス例外は認識されない。
VLBBの変位は、12ビットの符合なし整数として取り扱われる。
M3フィールドは、ロードするためのブロック境界サイズに関してCPUに信号を送るのに用いられるコードを指定する。予約値が指定された場合には、指定例外が認識される。
0 64バイト
1 128バイト
2 256バイト
3 512バイト
4 1Kバイト
5 2Kバイト
6 4Kバイト
7〜15 予約される
プログラム例外:
・アクセス(フェッチ、オペランド2)
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・指定(予約されたブロック境界コード)
・トランザクション制限
1.ある特定の状況において、データがブロック境界を超えてロードされることがある。しかしながら、これは、そのデータについてのアクセス例外がない場合にのみ生じる。
プログラム例外:
・アクセス(ストア、オペランド2)
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・トランザクション制限
左から右へ進み、第1のオペランドからのバイトが、第2のオペランド位置に格納される。汎用レジスタにより指定された第3のオペランドは、格納する最高のインデックス付きバイトを表す値を含む32ビットの符号なし整数を含む。第3のオペランドが、ベクトルの最高バイト・インデックスより大きいか又はこれに等しい値を含む場合、第1のオペランドの全てのバイトが格納される。
VECTOR STORE WITH LENGTHに関する変位は、12ビットの符号なし整数として取り扱われる。
プログラム例外:
・アクセス(ストア、オペランド2)
・DXC FEを伴うデータ、ベクトル・レジスタ
・ベクトル拡張ファシリティがインストールされていない場合の演算
・トランザクション制限
全てのベクトル命令は、命令のビット36−40において、RXBとラベル付けされたフィールドを有する。このフィールドは、ベクトル・レジスタが指示する全てのオペランドの最上位ビットを含む。命令によって指定されていないレジスタ指示のためのビットは、予約され、ゼロに設定されるべきであり、さもなければ、プログラムは、将来、互換的に動作することができない。その最上位ビットが4ビット・レジスタ指示の左に連結されて、5ビットのベクトル・レジスタ指定が作成される。
ビットは以下のように定義される:
0.命令のビット8−11内のベクトル・レジスタ指示のための最上位ビット。
1.命令のビット12−15内のベクトル・レジスタ指示のための最上位ビット。
2.命令のビット16−19内のベクトル・レジスタ指示のための最上位ビット。
3.命令のビット32−35内のベクトル・レジスタ指示のための最上位ビット。
ベクトル・レジスタ及び命令は、制御レジスタ・ゼロ内のベクトル・イネーブルメント制御(ビット46)及びAFPレジスタ制御(ビット45)の両方が1に設定されている場合にのみ使用することができる。ベクトル・ファシリティがインストールされ、ベクトル命令がイネーブルメント・ビットの設定なしに実行される場合、DXC EF hexによるデータ例外が認識される。ベクトル・ファシリティがインストールされていない場合、演算例外が認識される。
102、202:プロセッサ(CPU)
104、204:メモリ
106、206:入力/出力デバイス(インターフェース)
108、208:バス
210:ネイティブ・レジスタ
212:エミュレータ・コード
250:ゲスト命令
252:命令フェッチ・ユニット
254:命令変換ルーチン
256:ネイティブ命令
260:エミュレーション制御ユニット
300:Vector Load To Block Boundary命令
302a、302b:操作コード・フィールド
304:ベクトル・レジスタ・フィールド
306:インデックス・フィールド
308:ベース・フィールド
310:変位フィールド
312:マスク・フィールド
314:RXBフィールド
402:境界サイズ
404:境界マスク
412:開始アドレス
414:ベクトル・サイズ
422:終了アドレス
600:レジスタ・ファイル
602:ベクトル・レジスタ
604:浮動小数点レジスタ
Claims (20)
- コンピュータ・システムの中央演算処理ユニットにおいてマシン命令を実行するためのコンピュータ・プログラムであって、前記コンピュータ・プログラムは、
前記コンピュータ・システムに、
前記中央演算処理ユニットにより、実行のためのマシン命令を取得させ、
前記マシン命令を実行させる
コンピュータ・プログラムであり、
前記マシン命令は、コンピュータ・アーキテクチャに従ったコンピュータ実行のために定められ、且つ、
前記マシン命令は、
load to block boundary操作を識別する操作コードを与えるための少なくとも1つの操作コード・フィールドと、
第1のオペランドを含むレジスタを指定するために用いられるレジスタ・フィールドと、
主メモリ内における第2のオペランドの位置を指し示すための少なくとも1つのフィールドと、
前記第2のオペランドのブロックの指定されたブロック境界を指示するためのブロック境界サイズ・インジケータと、
を含み、
前記マシン命令を実行することは、前記ブロック内のデータだけを前記第1のオペランドにロードすることを保証しながら、前記第2のオペランドのブロックから、可変量のデータを第1のオペランドにロードすることを含み、
前記ロードすることは、前記マシン命令によって与えられる、前記第2のオペランドの前記ブロック内の開始アドレスで開始し、且つ、前記第2のオペランドの前記ブロックの前記指定されたブロック境界で又はその前で終了し、ロードされる前記可変量のデータは、前記開始アドレスと、前記ブロック境界サイズ・インジケータに基づいて判断された前記指定されたブロック境界とに基づいており、前記可変量のデータのバイト数は、(前記第1のオペランドのバイト数、又は、前記開始アドレスから前記指定されたブロック境界までのロードされるバイト数)の最小値である、
コンピュータ・プログラム。 - 前記少なくとも1つのフィールドは、変位フィールド、ベース・フィールド、及びインデックス・フィールドを含み、前記ベース・フィールド及び前記インデックス・フィールドは、前記変位フィールドのコンテンツに加算されるコンテンツを有する汎用レジスタを指し示すためのものであり、前記開始アドレスは、前記汎用レジスタが有するコンテンツと前記変位フィールドのコンテンツを加算することに基づいて形成されるものであり、前記マシン命令は、前記ブロック境界サイズ・インジケータを指定するマスク・フィールドをさらに含む、請求項1に記載のコンピュータ・プログラム。
- 前記ブロック境界は、前記マスク・フィールドによって指定可能な複数のブロック境界のうちの1つのブロック境界である、請求項2に記載のコンピュータ・プログラム。
- 前記第2のオペランドのアドレスは、データを第1のオペランドにロードする、メモリ内の開始アドレスである、前記請求項1から請求項3のいずれかに記載のコンピュータ・プログラム。
- 前記実行することは、ロードすることを停止する終了アドレスを判断することをさらに含み、前記ロードすることは前記終了アドレスで停止する、請求項4に記載のコンピュータ・プログラム。
- 前記終了アドレスを判断することは、
境界サイズは互いに隣り合うブロック境界間のデータサイズであり、境界マスクは0−境界サイズに等しく、レジスタ・サイズは前記レジスタの指定された長さである場合に、
終了アドレス=(開始アドレス+(境界サイズ−(開始アドレス AND NOT 境界マスク)),開始アドレス+レジスタ・サイズ)の最小値となる、
ように前記終了アドレスを計算することを含む、請求項5に記載のコンピュータ・プログ
ラム。 - 前記ロードすることは、前記第1のオペランドを左から右にロードすること、又は前記第1のオペランドを右から左にロードすることの一方を含む、前記請求項1から請求項6のいずれかに記載のコンピュータ・プログラム。
- 前記ロードの方向は、実行時に与えられる、請求項7に記載のコンピュータ・プログラム。
- 前記マシン命令は、1つ又は複数のレジスタを指定するのに用いられる延長フィールドをさらに含み、前記レジスタ・フィールドは、前記レジスタを指定するための前記延長フィールドの少なくとも一部分と組み合わせられる、請求項1から請求項8のいずれかに記載のコンピュータ・プログラム。
- 前記第1のオペランドにロードすることは、前記第1のオペランドのインデックス付きバイト0で始まり、前記レジスタの最大バイト・インデックスであるバイトまでのいずれかのバイトまで続行する、請求項1から請求項9のいずれかに記載のコンピュータ・プログラム。
- 中央演算処理ユニットにおいてマシン命令を実行するためのコンピュータ・システムであって、前記コンピュータ・システムは、
メモリと、
前記メモリと通信する前記中央演算処理ユニットと、
を含み、
前記コンピュータ・システムは、
前記中央演算処理ユニットにより、実行のためのマシン命令を取得し、
前記マシン命令を実行する
コンピュータ・システムであり、
前記マシン命令は、コンピュータ・アーキテクチャに従ったコンピュータ実行のために定められ、且つ、
前記マシン命令は、
load to block boundary操作を識別する操作コードを与えるための少なくとも1つの操作コード・フィールドと、
第1のオペランドを含むレジスタを指定するために用いられるレジスタ・フィールドと、
主メモリ内における第2のオペランドの位置を指し示すための少なくとも1つのフィールドと、
前記第2のオペランドのブロックの指定されたブロック境界を指示するためのブロック境界サイズ・インジケータと、
を含み、
前記マシン命令を実行することは、前記ブロック内のデータだけが前記第1のオペランドにロードされることを保証しながら、前記第2のオペランドのブロックから、可変量のデータを第1のオペランドにロードすることを含み、
前記ロードすることは、前記マシン命令によって与えられる、前記第2のオペランドの前記ブロック内の開始アドレスで開始し、且つ、前記第2のオペランドの前記ブロックの前記指定されたブロック境界で又はその前で終了し、ロードされる前記可変量のデータは、前記開始アドレスと、前記ブロック境界サイズ・インジケータに基づいて判断された前記指定されたブロック境界とに基づいており、前記可変量のデータのバイト数は、(前記第1のオペランドのバイト数、又は、前記開始アドレスから前記指定されたブロック境界までのロードされるバイト数)の最小値である、
コンピュータ・システム。 - 前記少なくとも1つのフィールドは、変位フィールド、ベース・フィールド、及びインデックス・フィールドを含み、前記ベース・フィールド及び前記インデックス・フィールドは、前記変位フィールドのコンテンツに加算されるコンテンツを有する汎用レジスタを指し示すためのものであり、前記開始アドレスは、前記汎用レジスタが有するコンテンツと前記変位フィールドのコンテンツを加算することに基づいて形成されるものであり、前記マシン命令は、前記ブロック境界サイズ・インジケータを指定するマスク・フィールドをさらに含む、請求項11に記載のコンピュータ・システム。
- 前記第2のオペランドのアドレスは、データを第1のオペランドにロードする、メモリ内の開始アドレスであり、前記実行することは、ロードすることを停止する終了アドレスを判断することをさらに含み、前記ロードすることは前記終了アドレスで停止する、請求項11又は請求項12に記載のコンピュータ・システム。
- 前記終了アドレスを判断することは、
境界サイズは互いに隣り合うブロック境界間のデータサイズであり、境界マスクは0−境界サイズに等しく、レジスタ・サイズは前記レジスタの指定された長さである場合に、
終了アドレス=(開始アドレス+(境界サイズ−(開始アドレス AND NOT 境界マスク)),開始アドレス+レジスタ・サイズ)の最小値となる、
ように前記終了アドレスを計算することを含む、請求項13に記載のコンピュータ・システム。 - 前記ロードすることは、前記第1のオペランドを左から右にロードすること、又は前記第1のオペランドを右から左にロードすることの一方を含む、請求項11から請求項14までのいずれかに記載のコンピュータ・システム。
- 前記ロードの方向は、実行時に与えられる、請求項15に記載のコンピュータ・システム。
- 前記マシン命令は、1つ又は複数のレジスタを指定するのに用いられる延長フィールドをさらに含み、前記レジスタ・フィールドは、前記レジスタを指定するための前記延長フィールドの少なくとも一部分と組み合わせられる、請求項11から請求項16までのいずれかに記載のコンピュータ・システム。
- コンピュータ・システムの中央演算処理ユニットにおいてマシン命令を実行するための方法であって、
前記中央演算処理ユニットにより、実行のためのマシン命令を取得すること、
前記マシン命令を実行すること
とを含み、
前記マシン命令は、コンピュータ・アーキテクチャに従ったコンピュータ実行のために定められ、且つ、
前記マシン命令は、
load to block boundary操作を識別する操作コードを与えるための少なくとも1つの操作コード・フィールドと、
第1のオペランドを含むレジスタを指定するために用いられるレジスタ・フィールドと、
主メモリ内における第2のオペランドの位置を指し示すための少なくとも1つのフィールドと、
前記第2のオペランドのブロックの指定されたブロック境界を指示するためのブロック境界サイズ・インジケータと、
を含み、
前記マシン命令を実行することは、前記ブロック内のデータだけが前記第1のオペランドにロードされることを保証しながら、前記第2のオペランドのブロックから、可変量のデータを第1のオペランドにロードすることを含み、
前記ロードすることは、前記マシン命令によって与えられる、前記第2のオペランドの前記ブロック内の開始アドレスで開始し、且つ、前記第2のオペランドの前記ブロックの前記指定されたブロック境界で又はその前で終了し、ロードされる前記可変量のデータは、前記開始アドレスと、前記ブロック境界サイズ・インジケータに基づいて判断された前記指定されたブロック境界とに基づいており、前記可変量のデータのバイト数は、(前記第1のオペランドのバイト数、又は、前記開始アドレスから前記指定されたブロック境界までのロードされるバイト数)の最小値である、
方法。 - 前記第2のオペランドのアドレスは、データを第1のオペランドにロードする、メモリ内の開始アドレスである、請求項18に記載の方法。
- 前記実行することは、ロードすることを停止する終了アドレスを判断することをさらに含み、前記ロードすることは前記終了アドレスで停止するものであり、
前記終了アドレスを判断することは、
境界サイズは互いに隣り合うブロック境界間のデータサイズであり、境界マスクは0−境界サイズに等しく、レジスタ・サイズは前記レジスタの指定された長さである場合に、
終了アドレス=(開始アドレス+(境界サイズ−(開始アドレス AND NOT 境界マスク)),開始アドレス+レジスタ・サイズ)の最小値となる、
ように前記終了アドレスを計算することを含む、請求項19に記載の方法。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/421,456 | 2012-03-15 | ||
US13/421,456 US9459867B2 (en) | 2012-03-15 | 2012-03-15 | Instruction to load data up to a specified memory boundary indicated by the instruction |
PCT/IB2012/056434 WO2013136143A1 (en) | 2012-03-15 | 2012-11-15 | Instruction to load data up to a specified memory boundary indicated by the instruction |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2015516622A JP2015516622A (ja) | 2015-06-11 |
JP6246140B2 true JP6246140B2 (ja) | 2017-12-13 |
Family
ID=49158799
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2014561526A Active JP6246140B2 (ja) | 2012-03-15 | 2012-11-15 | データを命令が指示する指定されたメモリ境界までロードするためのコンピュータ・プログラム、コンピュータ・システムおよび方法 |
Country Status (24)
Country | Link |
---|---|
US (4) | US9459867B2 (ja) |
EP (1) | EP2769305B1 (ja) |
JP (1) | JP6246140B2 (ja) |
KR (1) | KR101662420B1 (ja) |
CN (1) | CN104205067B (ja) |
AU (1) | AU2012373734B2 (ja) |
BR (1) | BR112014022727B1 (ja) |
CA (1) | CA2867088C (ja) |
DK (1) | DK2769305T3 (ja) |
ES (1) | ES2680147T3 (ja) |
HK (1) | HK1201352A1 (ja) |
HR (1) | HRP20181117T1 (ja) |
HU (1) | HUE038976T2 (ja) |
IL (1) | IL232815B (ja) |
LT (1) | LT2769305T (ja) |
MX (1) | MX343372B (ja) |
PL (1) | PL2769305T3 (ja) |
PT (1) | PT2769305T (ja) |
RU (1) | RU2565496C2 (ja) |
SG (1) | SG11201404823QA (ja) |
SI (1) | SI2769305T1 (ja) |
TW (1) | TWI533206B (ja) |
WO (1) | WO2013136143A1 (ja) |
ZA (1) | ZA201406610B (ja) |
Families Citing this family (34)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9715383B2 (en) | 2012-03-15 | 2017-07-25 | International Business Machines Corporation | Vector find element equal instruction |
US9459864B2 (en) | 2012-03-15 | 2016-10-04 | International Business Machines Corporation | Vector string range compare |
US9454367B2 (en) | 2012-03-15 | 2016-09-27 | International Business Machines Corporation | Finding the length of a set of character data having a termination character |
US9459867B2 (en) | 2012-03-15 | 2016-10-04 | International Business Machines Corporation | Instruction to load data up to a specified memory boundary indicated by the instruction |
US9710266B2 (en) | 2012-03-15 | 2017-07-18 | International Business Machines Corporation | Instruction to compute the distance to a specified memory boundary |
US9454366B2 (en) | 2012-03-15 | 2016-09-27 | International Business Machines Corporation | Copying character data having a termination character from one memory location to another |
US9280347B2 (en) | 2012-03-15 | 2016-03-08 | International Business Machines Corporation | Transforming non-contiguous instruction specifiers to contiguous instruction specifiers |
US9268566B2 (en) | 2012-03-15 | 2016-02-23 | International Business Machines Corporation | Character data match determination by loading registers at most up to memory block boundary and comparing |
US9459868B2 (en) | 2012-03-15 | 2016-10-04 | International Business Machines Corporation | Instruction to load data up to a dynamically determined memory boundary |
US9588762B2 (en) | 2012-03-15 | 2017-03-07 | International Business Machines Corporation | Vector find element not equal instruction |
US9715385B2 (en) | 2013-01-23 | 2017-07-25 | International Business Machines Corporation | Vector exception code |
US9778932B2 (en) | 2013-01-23 | 2017-10-03 | International Business Machines Corporation | Vector generate mask instruction |
US9513906B2 (en) | 2013-01-23 | 2016-12-06 | International Business Machines Corporation | Vector checksum instruction |
US9471308B2 (en) | 2013-01-23 | 2016-10-18 | International Business Machines Corporation | Vector floating point test data class immediate instruction |
US9804840B2 (en) | 2013-01-23 | 2017-10-31 | International Business Machines Corporation | Vector Galois Field Multiply Sum and Accumulate instruction |
US9823924B2 (en) | 2013-01-23 | 2017-11-21 | International Business Machines Corporation | Vector element rotate and insert under mask instruction |
US9582413B2 (en) * | 2014-12-04 | 2017-02-28 | International Business Machines Corporation | Alignment based block concurrency for accessing memory |
US9703721B2 (en) | 2014-12-29 | 2017-07-11 | International Business Machines Corporation | Processing page fault exceptions in supervisory software when accessing strings and similar data structures using normal load instructions |
US9569127B2 (en) | 2014-12-29 | 2017-02-14 | International Business Machines Corporation | Computer instructions for limiting access violation reporting when accessing strings and similar data structures |
US9792098B2 (en) * | 2015-03-25 | 2017-10-17 | International Business Machines Corporation | Unaligned instruction relocation |
US9904614B2 (en) * | 2015-04-03 | 2018-02-27 | NodeSource, Inc. | Source code inspection and verification |
US20160335294A1 (en) * | 2015-05-15 | 2016-11-17 | Bjorn J. Gruenwald | System and Method for Organizing Data |
US10061539B2 (en) | 2015-06-30 | 2018-08-28 | International Business Machines Corporation | Inaccessibility status indicator |
US10310854B2 (en) | 2015-06-30 | 2019-06-04 | International Business Machines Corporation | Non-faulting compute instructions |
GB2541714B (en) * | 2015-08-27 | 2018-02-14 | Advanced Risc Mach Ltd | An apparatus and method for controlling instruction execution behaviour |
US10338920B2 (en) * | 2015-12-18 | 2019-07-02 | Intel Corporation | Instructions and logic for get-multiple-vector-elements operations |
US10095517B2 (en) * | 2015-12-22 | 2018-10-09 | Intel Corporation | Apparatus and method for retrieving elements from a linked structure |
US10282204B2 (en) * | 2016-07-02 | 2019-05-07 | Intel Corporation | Systems, apparatuses, and methods for strided load |
US20180054374A1 (en) * | 2016-08-19 | 2018-02-22 | Andes Technology Corporation | Trace information encoding apparatus, encoding method thereof, and readable computer medium |
US10713048B2 (en) * | 2017-01-19 | 2020-07-14 | International Business Machines Corporation | Conditional branch to an indirectly specified location |
US10564965B2 (en) * | 2017-03-03 | 2020-02-18 | International Business Machines Corporation | Compare string processing via inline decode-based micro-operations expansion |
US11347860B2 (en) | 2019-06-28 | 2022-05-31 | Seagate Technology Llc | Randomizing firmware loaded to a processor memory |
US11347506B1 (en) | 2021-01-15 | 2022-05-31 | Arm Limited | Memory copy size determining instruction and data transfer instruction |
GB2602814B (en) * | 2021-01-15 | 2023-06-14 | Advanced Risc Mach Ltd | Load Chunk instruction and store chunk instruction |
Family Cites Families (98)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS62276668A (ja) * | 1985-07-31 | 1987-12-01 | Nec Corp | ベクトルマスク演算制御ユニツト |
US5073864A (en) | 1987-02-10 | 1991-12-17 | Davin Computer Corporation | Parallel string processor and method for a minicomputer |
US5222225A (en) | 1988-10-07 | 1993-06-22 | International Business Machines Corporation | Apparatus for processing character string moves in a data processing system |
JPH0831032B2 (ja) | 1990-08-29 | 1996-03-27 | 三菱電機株式会社 | データ処理装置 |
US5465374A (en) | 1993-01-12 | 1995-11-07 | International Business Machines Corporation | Processor for processing data string by byte-by-byte |
WO1994027215A1 (en) | 1993-05-07 | 1994-11-24 | Apple Computer, Inc. | Method for decoding guest instructions for a host computer |
EP0704073A1 (en) | 1993-06-14 | 1996-04-03 | Apple Computer, Inc. | Method and apparatus for finding a termination character within a variable length character string or a processor |
JPH0721034A (ja) | 1993-06-28 | 1995-01-24 | Fujitsu Ltd | 文字列複写処理方法 |
US5509129A (en) | 1993-11-30 | 1996-04-16 | Guttag; Karl M. | Long instruction word controlling plural independent processor operations |
US6185629B1 (en) | 1994-03-08 | 2001-02-06 | Texas Instruments Incorporated | Data transfer controller employing differing memory interface protocols dependent upon external input at predetermined time |
US5551013A (en) | 1994-06-03 | 1996-08-27 | International Business Machines Corporation | Multiprocessor for hardware emulation |
AU696903B2 (en) | 1994-09-27 | 1998-09-24 | Jfe Steel Corporation | Zinciferous plated steel sheet and method for manufacturing same |
US5790825A (en) | 1995-11-08 | 1998-08-04 | Apple Computer, Inc. | Method for emulating guest instructions on a host computer through dynamic recompilation of host instructions |
US5812147A (en) | 1996-09-20 | 1998-09-22 | Silicon Graphics, Inc. | Instruction methods for performing data formatting while moving data between memory and a vector register file |
US5931940A (en) | 1997-01-23 | 1999-08-03 | Unisys Corporation | Testing and string instructions for data stored on memory byte boundaries in a word oriented machine |
US6338057B1 (en) | 1997-11-24 | 2002-01-08 | British Telecommunications Public Limited Company | Information management and retrieval |
US6009261A (en) | 1997-12-16 | 1999-12-28 | International Business Machines Corporation | Preprocessing of stored target routines for emulating incompatible instructions on a target processor |
US6094695A (en) | 1998-03-11 | 2000-07-25 | Texas Instruments Incorporated | Storage buffer that dynamically adjusts boundary between two storage areas when one area is full and the other has an empty data register |
US6334176B1 (en) | 1998-04-17 | 2001-12-25 | Motorola, Inc. | Method and apparatus for generating an alignment control vector |
US6308255B1 (en) | 1998-05-26 | 2001-10-23 | Advanced Micro Devices, Inc. | Symmetrical multiprocessing bus and chipset used for coprocessor support allowing non-native code to run in a system |
US7100026B2 (en) | 2001-05-30 | 2006-08-29 | The Massachusetts Institute Of Technology | System and method for performing efficient conditional vector operations for data parallel architectures involving both input and conditional vector values |
US20020147969A1 (en) | 1998-10-21 | 2002-10-10 | Richard A. Lethin | Dynamic optimizing object code translator for architecture emulation and dynamic optimizing object code translation method |
JP3564395B2 (ja) * | 1998-11-27 | 2004-09-08 | 松下電器産業株式会社 | アドレス生成装置および動きベクトル検出装置 |
US6192466B1 (en) | 1999-01-21 | 2001-02-20 | International Business Machines Corporation | Pipeline control for high-frequency pipelined designs |
US8127121B2 (en) | 1999-01-28 | 2012-02-28 | Ati Technologies Ulc | Apparatus for executing programs for a first computer architechture on a computer of a second architechture |
US6189088B1 (en) | 1999-02-03 | 2001-02-13 | International Business Machines Corporation | Forwarding stored dara fetched for out-of-order load/read operation to over-taken operation read-accessing same memory location |
US6499116B1 (en) | 1999-03-31 | 2002-12-24 | International Business Machines Corp. | Performance of data stream touch events |
US6802056B1 (en) | 1999-06-30 | 2004-10-05 | Microsoft Corporation | Translation and transformation of heterogeneous programs |
US6381691B1 (en) | 1999-08-13 | 2002-04-30 | International Business Machines Corporation | Method and apparatus for reordering memory operations along multiple execution paths in a processor |
US6513107B1 (en) * | 1999-08-17 | 2003-01-28 | Nec Electronics, Inc. | Vector transfer system generating address error exception when vector to be transferred does not start and end on same memory page |
US6513109B1 (en) | 1999-08-31 | 2003-01-28 | International Business Machines Corporation | Method and apparatus for implementing execution predicates in a computer processing system |
US6820195B1 (en) * | 1999-10-01 | 2004-11-16 | Hitachi, Ltd. | Aligning load/store data with big/little endian determined rotation distance control |
US6449706B1 (en) | 1999-12-22 | 2002-09-10 | Intel Corporation | Method and apparatus for accessing unaligned data |
JP2001236249A (ja) | 2000-02-24 | 2001-08-31 | Nec Corp | メモリ管理装置およびメモリ管理方法 |
US6625724B1 (en) | 2000-03-28 | 2003-09-23 | Intel Corporation | Method and apparatus to support an expanded register set |
US6349361B1 (en) | 2000-03-31 | 2002-02-19 | International Business Machines Corporation | Methods and apparatus for reordering and renaming memory references in a multiprocessor computer system |
US6701424B1 (en) | 2000-04-07 | 2004-03-02 | Nintendo Co., Ltd. | Method and apparatus for efficient loading and storing of vectors |
US6408383B1 (en) | 2000-05-04 | 2002-06-18 | Sun Microsystems, Inc. | Array access boundary check by executing BNDCHK instruction with comparison specifiers |
KR100852563B1 (ko) | 2000-10-18 | 2008-08-18 | 코닌클리즈케 필립스 일렉트로닉스 엔.브이. | 디지털 신호 처리 장치 및 방법 |
US7487330B2 (en) | 2001-05-02 | 2009-02-03 | International Business Machines Corporations | Method and apparatus for transferring control in a computer system with dynamic compilation capability |
JP3900863B2 (ja) | 2001-06-28 | 2007-04-04 | シャープ株式会社 | データ転送制御装置、半導体記憶装置および情報機器 |
US6839828B2 (en) | 2001-08-14 | 2005-01-04 | International Business Machines Corporation | SIMD datapath coupled to scalar/vector/address/conditional data register file with selective subpath scalar processing mode |
US6907443B2 (en) | 2001-09-19 | 2005-06-14 | Broadcom Corporation | Magnitude comparator |
US6570511B1 (en) | 2001-10-15 | 2003-05-27 | Unisys Corporation | Data compression method and apparatus implemented with limited length character tables and compact string code utilization |
US7853778B2 (en) * | 2001-12-20 | 2010-12-14 | Intel Corporation | Load/move and duplicate instructions for a processor |
US20100274988A1 (en) | 2002-02-04 | 2010-10-28 | Mimar Tibet | Flexible vector modes of operation for SIMD processor |
US7089371B2 (en) | 2002-02-12 | 2006-08-08 | Ip-First, Llc | Microprocessor apparatus and method for prefetch, allocation, and initialization of a block of cache lines from memory |
US7441104B2 (en) | 2002-03-30 | 2008-10-21 | Hewlett-Packard Development Company, L.P. | Parallel subword instructions with distributed results |
US7373483B2 (en) | 2002-04-02 | 2008-05-13 | Ip-First, Llc | Mechanism for extending the number of registers in a microprocessor |
US7376812B1 (en) | 2002-05-13 | 2008-05-20 | Tensilica, Inc. | Vector co-processor for configurable and extensible processor architecture |
US6918010B1 (en) | 2002-10-16 | 2005-07-12 | Silicon Graphics, Inc. | Method and system for prefetching data |
US7103754B2 (en) | 2003-03-28 | 2006-09-05 | International Business Machines Corporation | Computer instructions for having extended signed displacement fields for finding instruction operands |
US20040215924A1 (en) | 2003-04-28 | 2004-10-28 | Collard Jean-Francois C. | Analyzing stored data |
US7035986B2 (en) | 2003-05-12 | 2006-04-25 | International Business Machines Corporation | System and method for simultaneous access of the same line in cache storage |
US20040250027A1 (en) | 2003-06-04 | 2004-12-09 | Heflinger Kenneth A. | Method and system for comparing multiple bytes of data to stored string segments |
US7539714B2 (en) | 2003-06-30 | 2009-05-26 | Intel Corporation | Method, apparatus, and instruction for performing a sign operation that multiplies |
US7610466B2 (en) | 2003-09-05 | 2009-10-27 | Freescale Semiconductor, Inc. | Data processing system using independent memory and register operand size specifiers and method thereof |
US7904905B2 (en) | 2003-11-14 | 2011-03-08 | Stmicroelectronics, Inc. | System and method for efficiently executing single program multiple data (SPMD) programs |
GB2409066B (en) * | 2003-12-09 | 2006-09-27 | Advanced Risc Mach Ltd | A data processing apparatus and method for moving data between registers and memory |
GB2411973B (en) | 2003-12-09 | 2006-09-27 | Advanced Risc Mach Ltd | Constant generation in SMD processing |
US20060095713A1 (en) | 2004-11-03 | 2006-05-04 | Stexar Corporation | Clip-and-pack instruction for processor |
JP4837305B2 (ja) * | 2005-05-10 | 2011-12-14 | ルネサスエレクトロニクス株式会社 | マイクロプロセッサ及びマイクロプロセッサの制御方法 |
US7421566B2 (en) | 2005-08-12 | 2008-09-02 | International Business Machines Corporation | Implementing instruction set architectures with non-contiguous register file specifiers |
US20070106883A1 (en) | 2005-11-07 | 2007-05-10 | Choquette Jack H | Efficient Streaming of Un-Aligned Load/Store Instructions that Save Unused Non-Aligned Data in a Scratch Register for the Next Instruction |
US9436468B2 (en) | 2005-11-22 | 2016-09-06 | Intel Corporation | Technique for setting a vector mask |
US8010953B2 (en) | 2006-04-04 | 2011-08-30 | International Business Machines Corporation | Method for compiling scalar code for a single instruction multiple data (SIMD) execution engine |
US7565514B2 (en) | 2006-04-28 | 2009-07-21 | Freescale Semiconductor, Inc. | Parallel condition code generation for SIMD operations |
CN101097488B (zh) | 2006-06-30 | 2011-05-04 | 2012244安大略公司 | 从接收的文本中学习字符片段的方法及相关手持电子设备 |
US9069547B2 (en) | 2006-09-22 | 2015-06-30 | Intel Corporation | Instruction and logic for processing text strings |
JP2008077590A (ja) * | 2006-09-25 | 2008-04-03 | Toshiba Corp | データ転送装置 |
US7536532B2 (en) | 2006-09-27 | 2009-05-19 | International Business Machines Corporation | Merge operations of data arrays based on SIMD instructions |
US7991987B2 (en) | 2007-05-10 | 2011-08-02 | Intel Corporation | Comparing text strings |
EP2160692A1 (en) | 2007-05-21 | 2010-03-10 | Incredimail Ltd | Interactive message editing system and method |
US20090063410A1 (en) | 2007-08-29 | 2009-03-05 | Nils Haustein | Method for Performing Parallel Data Indexing Within a Data Storage System |
US7870339B2 (en) | 2008-01-11 | 2011-01-11 | International Business Machines Corporation | Extract cache attribute facility and instruction therefore |
US7739434B2 (en) | 2008-01-11 | 2010-06-15 | International Business Machines Corporation | Performing a configuration virtual topology change and instruction therefore |
US7895419B2 (en) | 2008-01-11 | 2011-02-22 | International Business Machines Corporation | Rotate then operate on selected bits facility and instructions therefore |
US7877582B2 (en) | 2008-01-31 | 2011-01-25 | International Business Machines Corporation | Multi-addressable register file |
EP2245529A1 (en) | 2008-02-18 | 2010-11-03 | Sandbridge Technologies, Inc. | Method to accelerate null-terminated string operations |
DK176835B1 (da) | 2008-03-07 | 2009-11-23 | Jala Aps | Fremgangsmåde til skanning, medium indeholdende et program til udövelse af fremgangsmåden samt system til udövelse af fremgangsmåden |
US8386547B2 (en) | 2008-10-31 | 2013-02-26 | Intel Corporation | Instruction and logic for performing range detection |
US20120023308A1 (en) | 2009-02-02 | 2012-01-26 | Renesas Electronics Corporation | Parallel comparison/selection operation apparatus, processor, and parallel comparison/selection operation method |
JP5471082B2 (ja) | 2009-06-30 | 2014-04-16 | 富士通株式会社 | 演算処理装置および演算処理装置の制御方法 |
US8595471B2 (en) | 2010-01-22 | 2013-11-26 | Via Technologies, Inc. | Executing repeat load string instruction with guaranteed prefetch microcode to prefetch into cache for loading up to the last value in architectural register |
JP2011212043A (ja) | 2010-03-31 | 2011-10-27 | Fujifilm Corp | 医用画像再生装置および方法並びにプログラム |
US20110314263A1 (en) | 2010-06-22 | 2011-12-22 | International Business Machines Corporation | Instructions for performing an operation on two operands and subsequently storing an original value of operand |
US8972698B2 (en) | 2010-12-22 | 2015-03-03 | Intel Corporation | Vector conflict instructions |
US9009447B2 (en) | 2011-07-18 | 2015-04-14 | Oracle International Corporation | Acceleration of string comparisons using vector instructions |
US9268566B2 (en) | 2012-03-15 | 2016-02-23 | International Business Machines Corporation | Character data match determination by loading registers at most up to memory block boundary and comparing |
US9459868B2 (en) * | 2012-03-15 | 2016-10-04 | International Business Machines Corporation | Instruction to load data up to a dynamically determined memory boundary |
US9454366B2 (en) | 2012-03-15 | 2016-09-27 | International Business Machines Corporation | Copying character data having a termination character from one memory location to another |
US9588762B2 (en) | 2012-03-15 | 2017-03-07 | International Business Machines Corporation | Vector find element not equal instruction |
US9459867B2 (en) | 2012-03-15 | 2016-10-04 | International Business Machines Corporation | Instruction to load data up to a specified memory boundary indicated by the instruction |
US9710266B2 (en) | 2012-03-15 | 2017-07-18 | International Business Machines Corporation | Instruction to compute the distance to a specified memory boundary |
US9715383B2 (en) | 2012-03-15 | 2017-07-25 | International Business Machines Corporation | Vector find element equal instruction |
US9459864B2 (en) | 2012-03-15 | 2016-10-04 | International Business Machines Corporation | Vector string range compare |
US9454367B2 (en) | 2012-03-15 | 2016-09-27 | International Business Machines Corporation | Finding the length of a set of character data having a termination character |
US9280347B2 (en) | 2012-03-15 | 2016-03-08 | International Business Machines Corporation | Transforming non-contiguous instruction specifiers to contiguous instruction specifiers |
-
2012
- 2012-03-15 US US13/421,456 patent/US9459867B2/en active Active
- 2012-11-15 LT LTEP12871072.0T patent/LT2769305T/lt unknown
- 2012-11-15 CA CA2867088A patent/CA2867088C/en active Active
- 2012-11-15 MX MX2014010946A patent/MX343372B/es active IP Right Grant
- 2012-11-15 RU RU2012148582/08A patent/RU2565496C2/ru active
- 2012-11-15 EP EP12871072.0A patent/EP2769305B1/en active Active
- 2012-11-15 BR BR112014022727-6A patent/BR112014022727B1/pt active IP Right Grant
- 2012-11-15 SG SG11201404823QA patent/SG11201404823QA/en unknown
- 2012-11-15 DK DK12871072.0T patent/DK2769305T3/en active
- 2012-11-15 AU AU2012373734A patent/AU2012373734B2/en active Active
- 2012-11-15 HU HUE12871072A patent/HUE038976T2/hu unknown
- 2012-11-15 PT PT128710720T patent/PT2769305T/pt unknown
- 2012-11-15 JP JP2014561526A patent/JP6246140B2/ja active Active
- 2012-11-15 CN CN201280071426.5A patent/CN104205067B/zh active Active
- 2012-11-15 KR KR1020147028777A patent/KR101662420B1/ko active IP Right Grant
- 2012-11-15 WO PCT/IB2012/056434 patent/WO2013136143A1/en active Application Filing
- 2012-11-15 SI SI201231340T patent/SI2769305T1/sl unknown
- 2012-11-15 ES ES12871072.0T patent/ES2680147T3/es active Active
- 2012-11-15 PL PL12871072T patent/PL2769305T3/pl unknown
-
2013
- 2013-03-01 TW TW102107379A patent/TWI533206B/zh active
- 2013-03-03 US US13/783,337 patent/US9383996B2/en active Active
-
2014
- 2014-05-27 IL IL232815A patent/IL232815B/en active IP Right Grant
- 2014-09-09 ZA ZA2014/06610A patent/ZA201406610B/en unknown
-
2015
- 2015-02-18 HK HK15101816.3A patent/HK1201352A1/xx unknown
-
2016
- 2016-01-14 US US14/995,337 patent/US9946542B2/en active Active
- 2016-01-14 US US14/995,358 patent/US9959117B2/en active Active
-
2018
- 2018-07-18 HR HRP20181117TT patent/HRP20181117T1/hr unknown
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6246140B2 (ja) | データを命令が指示する指定されたメモリ境界までロードするためのコンピュータ・プログラム、コンピュータ・システムおよび方法 | |
JP6278906B2 (ja) | データを動的に判断されたメモリ境界までロードする方法、システムおよびコンピュータ・プログラム | |
JP6138175B2 (ja) | 指定されたメモリ境界までの距離を計算するためのコンピュータ・プログラム、コンピュータ・システムおよび方法 | |
JP6238243B2 (ja) | Vector find element equal命令 | |
JP6238241B2 (ja) | Vector string range compare | |
JP6238242B2 (ja) | Vector find element not equal命令 | |
JP6305351B2 (ja) | 終了文字を有する文字データ・セットの長さを見出す | |
JP6108362B2 (ja) | 不連続命令指定子の連続命令指定子への変換 | |
JP6323837B2 (ja) | Vector Checksum命令を実行するためのコンピュータ・プログラム、コンピュータ・システム及び方法 | |
JP6184426B2 (ja) | 終端文字を有する文字データのメモリ位置間でのコピーのための方法、システム、およびコンピュータ・プログラム(終端文字を有する文字データのメモリ位置間でのコピー) | |
JP6338066B2 (ja) | Vector galois field multiply sum and accumulate命令を処理するためのコンピュータ・システム、コンピュータ・プログラム及び方法 | |
JP6128532B2 (ja) | ゾーン形式から10進浮動小数点形式への変換 | |
JP2019145164A (ja) | ベクトル例外コードを処理するコンピュータ・プログラム、コンピュータ・システム及び方法 | |
JP6410238B2 (ja) | Vectorfloatingpointtestdataclassimmediate命令を処理するためのコンピュータ・システム、コンピュータ・プログラム及び方法 | |
JP6380955B2 (ja) | Vector generate mask命令を処理するためのコンピュータ・プログラム、コンピュータ・システム及び方法 | |
JP6399522B2 (ja) | Vector element rotate and insert under mask命令を処理するためのコンピュータ・プログラム、コンピュータ・システム及び方法 | |
JP6115920B2 (ja) | 10進浮動小数点形式からゾーン形式への変換 | |
AU2012373736B2 (en) | Instruction to compute the distance to a specified memory boundary |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20151110 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20161129 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20161228 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20170324 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20170404 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20170703 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20170711 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20171010 |
|
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: 20171024 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20171114 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6246140 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |