JP2017152016A - 単一命令でシフト・アンド・排他的論理和演算を行うシステム - Google Patents
単一命令でシフト・アンド・排他的論理和演算を行うシステム Download PDFInfo
- Publication number
- JP2017152016A JP2017152016A JP2017076187A JP2017076187A JP2017152016A JP 2017152016 A JP2017152016 A JP 2017152016A JP 2017076187 A JP2017076187 A JP 2017076187A JP 2017076187 A JP2017076187 A JP 2017076187A JP 2017152016 A JP2017152016 A JP 2017152016A
- Authority
- JP
- Japan
- Prior art keywords
- source operand
- shift
- instruction
- processor
- bit
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/14—Handling requests for interconnection or transfer
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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 OR CALCULATING; 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
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/3001—Arithmetic instructions
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/30029—Logical and Boolean instructions, e.g. XOR, NOT
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/30032—Movement instructions, e.g. MOVE, SHIFT, ROTATE, SHUFFLE
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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 OR CALCULATING; 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
- G06F9/3016—Decoding the operand specifier, e.g. specifier format
- G06F9/30167—Decoding the operand specifier, e.g. specifier format of immediate specifier, e.g. constants
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/3802—Instruction prefetching
- G06F9/3816—Instruction alignment, e.g. cache line crossing
 
- 
        - G—PHYSICS
- G06—COMPUTING OR CALCULATING; 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/3885—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
- G06F9/3893—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units controlled in tandem, e.g. multiplier-accumulator
 
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Mathematical Physics (AREA)
- Computational Mathematics (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Mathematical Analysis (AREA)
- Executing Machine-Instructions (AREA)
- Advance Control (AREA)
- Complex Calculations (AREA)
Abstract
【解決手段】実行ユニット108は、整数および浮動小数点演算を実行する論理を含み、プロセッサ102内に常駐している。プロセッサ102はさらに、一定のマクロ命令のマイクロコードを格納するマイクロコード(uコード)ROMを含む。実行ユニット108は、パック命令セット109を処理する論理を含む。パック命令セット109は、複数のオペランドにシフト・アンド・XORを行う、パック・シフト・アンド・XOR命令を含む。
【選択図】図1A
Description
本実施形態によれば、以下の各項目もまた開示される。
(項目1)
第1の値を所与のシフト量だけシフトして、前記シフトされた値を第2の値でXORする、シフト・アンド・XOR命令を実行する論理を備えるプロセッサ。
(項目2)
前記第1の値は左シフトされる項目1に記載のプロセッサ。
(項目3)
前記第1の値は右シフトされる項目1に記載のプロセッサ。
(項目4)
前記第1の値は論理シフトされる項目1に記載のプロセッサ。
(項目5)
前記第1の値は算術シフトされる項目1に記載のプロセッサ。
(項目6)
シフタとXOR回路とを備える項目1に記載のプロセッサ。
(項目7)
前記シフト・アンド・XOR命令は、前記第2の値を格納する第1のフィールドを含む項目1に記載のプロセッサ。
(項目8)
前記第1の値は、パックデータタイプである項目1に記載のプロセッサ。
(項目9)
シフト・アンド・XOR演算を実行させる第1の命令を格納するストレージと、
第1の値を所与のシフト量だけシフトして、前記シフトされた値を第2の値でXORする、シフト・アンド・XOR命令を実行する論理を実行するプロセッサと
を備えるシステム。
(項目10)
前記第1の値は左シフトされる項目9に記載のシステム。
(項目11)
前記第1の値は右シフトされる項目9に記載のシステム。
(項目12)
前記第1の値は論理シフトされる項目9に記載のシステム。
(項目13)
前記第1の値は算術シフトされる項目9に記載のシステム。
(項目14)
シフタとXOR回路とを備える項目9に記載のシステム。
(項目15)
前記シフト・アンド・XOR命令は、前記第2の値を格納する第1のフィールドを含む項目9に記載のシステム。
(項目16)
前記第1の値は、パックデータタイプである項目9に記載のシステム。
(項目17)
第1の値を所与のシフト量だけシフトして、前記シフトされた値を第2の値でXORする、シフト・アンド・XOR命令を実行する段階を備える方法。
(項目18)
前記第1の値は左シフトされる項目17に記載の方法。
(項目19)
前記第1の値は右シフトされる項目17に記載の方法。
(項目20)
前記第1の値は論理シフトされる項目17に記載の方法。
(項目21)
前記第1の値は算術シフトされる項目17に記載の方法。
(項目22)
シフタとXOR回路とを備える項目17に記載の方法。
(項目23)
前記シフト・アンド・XOR命令は、前記第2の値を格納する第1のフィールドを含む項目17に記載の方法。
(項目24)
前記第1の値は、パックデータタイプである項目17に記載の方法。
(項目25)
命令を格納する機械可読媒体であって、前記命令は機械により実行されると、前記機械に、
第1の値を所与のシフト量だけシフトする段階と、
前記シフトされた値を第2の値でXORする段階と
を含む方法を実行させる機械可読媒体。
(項目26)
前記第1の値は左シフトされる項目25に記載の方法。
(項目27)
前記第1の値は右シフトされる項目25に記載の方法。
(項目28)
前記第1の値は論理シフトされる項目25に記載の方法。
(項目29)
前記第1の値は算術シフトされる項目25に記載の方法。
(項目30)
シフタとXOR回路とを備える項目25に記載の方法。
(項目31)
前記シフト・アンド・XOR命令は、前記第2の値を格納する第1のフィールドを含む項目25に記載の方法。
(項目32)
前記第1の値は、パックデータタイプである項目25に記載の方法。
(項目33)
第1のシフト値と第2のビット反映値との間で排他的論理和(XOR)演算を実行して、実行結果を第1のレジスタに格納する段階と、
前記実行結果の先頭のゼロの最小数をチェックする段階と
を備える方法。
(項目34)
先頭のゼロの最小数が前記実行結果にある場合に、前記実行結果が第1のチャンクに対応していることを示す項目33に記載の方法。
(項目35)
前記第1のシフト値は、1ビットに相当する位置だけ左シフトされる項目34に記載の方法。
(項目36)
前記第1のシフト値は、1ビットに相当する位置だけ右シフトされる項目34に記載の方法。
Claims (37)
-  レベル1(L1)キャッシュを含む複数レベルのキャッシュと、
 複数の整数レジスタと、
 2つの64ビット倍精度浮動小数点データエレメントを有する128ビットパックダブルオペランドを含む複数の浮動小数点データエレメントを格納する複数の浮動小数点レジスタと、
 複数のステータスレジスタと、
 命令ポインタレジスタと、
 命令をフェッチする命令プリフェッチャと、
 第1ソースオペランドを特定する第1ソースオペランド識別子と、第2ソースオペランドを識別する第2ソースオペランド識別子と、シフト量を指定する即値フィールドと、第1ソースオペランド及び第2ソースオペランドが32ビットソースオペランドか64ビットソースオペランドのいずれかを指定するフィールドとを有しシフト・アンド・XOR演算を実行する命令を含む、フェッチされた複数の命令をデコードするデコーダと、
 前記デコーダに接続される実行ユニットと、
 浮動小数点データエレメントを処理する浮動小数点ユニットと、
 を備え、
 前記シフト・アンド・XOR演算を実行する命令に応じて、
 スカラー値の前記第1ソースオペランドを前記即値フィールドにより指定されたシフト量分シフトし、
 シフトされた前記第1ソースオペランドと前記第2ソースオペランドとをXORし、
 シフトされXORされた結果の値を、スカラーレジスタであるデスティネーションレジスタに格納する
 プロセッサ。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分右シフトする請求項1に記載のプロセッサ。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分左シフトする請求項1に記載のプロセッサ。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分論理シフトする請求項1に記載のプロセッサ。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分算術シフトする請求項1に記載のプロセッサ。
-  前記シフト・アンド・XOR演算を実行する命令は、前記シフト・アンド・XOR演算の種類をエンコードする少なくとも1つのフィールドを有する請求項1から5のいずれか一項に記載のプロセッサ。
-  前記浮動小数点ユニットは、64ビット対64ビットの浮動小数点除算を実行する請求項1から6のいずれか一項に記載のプロセッサ。
-  前記プロセッサは、縮小命令セットコンピュータ(RISC)アーキテクチャを有する請求項1から7のいずれか一項に記載のプロセッサ。
-  レジスタリネーム論理を更に備える請求項1から8のいずれか一項に記載のプロセッサ。
-  前記第1ソースオペランドは64ビットソースオペランドであり、前記デスティネーションレジスタは64ビットレジスタである請求項1から9のいずれか一項に記載のプロセッサ。
-  ディスプレイコントロールと、
 メモリインターフェースと、
 プロセッサと、
 を備え、
 前記プロセッサは、
 レベル1(L1)キャッシュを含む複数レベルのキャッシュと、
 複数の整数レジスタと、
 2つの64ビット倍精度浮動小数点データエレメントを有する128ビットパックダブルオペランドを含む複数の浮動小数点データエレメントを格納する複数の浮動小数点レジスタと、
 複数のステータスレジスタと、
 命令ポインタレジスタと、
 命令をフェッチする命令プリフェッチャと、
 第1ソースオペランドを特定する第1ソースオペランド識別子と、第2ソースオペランドを識別する第2ソースオペランド識別子と、シフト量を指定する即値フィールドと、第1ソースオペランド及び第2ソースオペランドが32ビットソースオペランドか64ビットソースオペランドのいずれかを指定するフィールドとを有しシフト・アンド・XOR演算を実行する命令を含む、フェッチされた複数の命令をデコードするデコーダと、
 前記デコーダに接続される実行ユニットと、
 浮動小数点データエレメントを処理する浮動小数点ユニットと、
 を有し、
 前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、
 スカラー値の前記第1ソースオペランドを前記即値フィールドにより指定されたシフト量分シフトし、
 シフトされた前記第1ソースオペランドと前記第2ソースオペランドとをXORし、
 シフトされXORされた結果の値を、スカラーレジスタであるデスティネーションレジスタに格納する
 システム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分右シフトする請求項11に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分左シフトする請求項11に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分論理シフトする請求項11に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分算術シフトする請求項11に記載のシステム。
-  前記シフト・アンド・XOR演算を実行する命令は、前記シフト・アンド・XOR演算の種類をエンコードする少なくとも1つのフィールドを有する請求項11から15のいずれか一項に記載のシステム。
-  前記浮動小数点ユニットは、64ビット対64ビットの浮動小数点除算を実行する請求項11から16のいずれか一項に記載のシステム。
-  前記プロセッサは、縮小命令セットコンピュータ(RISC)アーキテクチャを有する請求項11から17のいずれか一項に記載のシステム。
-  前記プロセッサは、レジスタリネーム論理を更に備える請求項11から18のいずれか一項に記載のシステム。
-  前記第1ソースオペランドは64ビットソースオペランドであり、前記デスティネーションレジスタは64ビットレジスタである請求項11から19のいずれか一項に記載のシステム。
-  ランダムアクセスメモリ(RAM)と、
 無線トランシーバと、
 前記RAMおよび前記無線トランシーバに接続されるプロセッサと、
 を備え、
 前記プロセッサは、
 レベル1(L1)キャッシュを含む複数レベルのキャッシュと、
 複数の整数レジスタと、
 2つの64ビット倍精度浮動小数点データエレメントを有する128ビットパックダブルオペランドを含む複数の浮動小数点データエレメントを格納する複数の浮動小数点レジスタと、
 複数のステータスレジスタと、
 命令ポインタレジスタと、
 命令をフェッチする命令プリフェッチャと、
 第1ソースオペランドを特定する第1ソースオペランド識別子と、第2ソースオペランドを識別する第2ソースオペランド識別子と、シフト量を指定する即値フィールドと、第1ソースオペランド及び第2ソースオペランドが32ビットソースオペランドか64ビットソースオペランドのいずれかを指定するフィールドとを有しシフト・アンド・XOR演算を実行する命令を含む、フェッチされた複数の命令をデコードするデコーダと、
 前記デコーダに接続される実行ユニットと、
 浮動小数点データエレメントを処理する浮動小数点ユニットと、
 を有し、
 前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、
 スカラー値の前記第1ソースオペランドを前記即値フィールドにより指定されたシフト量分シフトし、
 シフトされた前記第1ソースオペランドと前記第2ソースオペランドとをXORし、
 シフトされXORされた結果の値を、スカラーレジスタであるデスティネーションレジスタに格納する
 システム。
-  オーディオコントローラを更に備える請求項21に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分右シフトする請求項21または22に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分左シフトする請求項21または22に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分論理シフトする請求項21または22に記載のシステム。
-  前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、前記第1ソースオペランドを前記シフト量分算術シフトする請求項21または22に記載のシステム。
-  前記シフト・アンド・XOR演算を実行する命令は、前記シフト・アンド・XOR演算の種類をエンコードする少なくとも1つのフィールドを有する請求項21から26のいずれか一項に記載のシステム。
-  前記浮動小数点ユニットは、64ビット対64ビットの浮動小数点除算を実行する請求項21から27のいずれか一項に記載のシステム。
-  前記プロセッサは、縮小命令セットコンピュータ(RISC)アーキテクチャを有する請求項21から28のいずれか一項に記載のシステム。
-  前記プロセッサは、レジスタリネーム論理を更に備える請求項21から29のいずれか一項に記載のシステム。
-  前記第1ソースオペランドは64ビットソースオペランドであり、前記デスティネーションレジスタは64ビットレジスタである請求項21から30のいずれか一項に記載のシステム。
-  レベル1(L1)キャッシュを含む複数レベルのキャッシュと、
 複数の整数レジスタと、
 2つの64ビット倍精度浮動小数点データエレメントを有する128ビットパックダブルオペランドを含む複数の浮動小数点データエレメントを格納する複数の浮動小数点レジスタと、
 複数のステータスレジスタと、
 命令ポインタレジスタと、
 命令をフェッチする命令プリフェッチャと、
 第1ソースオペランドを特定する第1ソースオペランド識別子と、第2ソースオペランドを識別する第2ソースオペランド識別子と、シフト量を指定する即値フィールドとを有し、前記第1ソースオペランドおよび前記第2ソースオペランドが64ビットソースオペランドであるシフト・アンド・XOR演算を実行する命令を含む、フェッチされた複数の命令をデコードするデコーダと、
 前記デコーダに接続される実行ユニットと、
 浮動小数点データエレメントを処理する浮動小数点ユニットと、
 を備え、
 前記シフト・アンド・XOR演算を実行する命令に応じて、
 スカラー値の前記第1ソースオペランドを前記即値フィールドにより指定されたシフト量分左シフトし、
 左シフトされた前記第1ソースオペランドと前記第2ソースオペランドとをXORし、
 左シフトされXORされた結果の値を、スカラーレジスタである64ビットデスティネーションレジスタに格納する、
 縮小命令セットコンピュータ(RISC)アーキテクチャを有する
 プロセッサ。
-  前記シフト・アンド・XOR演算を実行する命令は、前記シフト・アンド・XOR演算の種類をエンコードする1以上のフィールドを有する請求項32に記載のプロセッサ。
-  ディスプレイコントロールと、
 メモリインターフェースと、
 縮小命令セットコンピュータ(RISC)アーキテクチャを有するプロセッサと、
 を備え、
 前記プロセッサは、
 レベル1(L1)キャッシュを含む複数レベルのキャッシュと、
 複数の整数レジスタと、
 2つの64ビット倍精度浮動小数点データエレメントを有する128ビットパックダブルオペランドを含む複数の浮動小数点データエレメントを格納する複数の浮動小数点レジスタと、
 複数のステータスレジスタと、
 命令ポインタレジスタと、
 命令をフェッチする命令プリフェッチャと、
 第1ソースオペランドを特定する第1ソースオペランド識別子と、第2ソースオペランドを識別する第2ソースオペランド識別子と、シフト量を指定する即値フィールドとを有し、前記第1ソースオペランドおよび前記第2ソースオペランドが64ビットソースオペランドであるシフト・アンド・XOR演算を実行する命令を含む、フェッチされた複数の命令をデコードするデコーダと、
 前記デコーダに接続される実行ユニットと、
 浮動小数点データエレメントを処理する浮動小数点ユニットと、
 を有し、
 前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、
 スカラー値の前記第1ソースオペランドを前記即値フィールドにより指定されたシフト量分左シフトし、
 左シフトされた前記第1ソースオペランドと前記第2ソースオペランドとをXORし、
 左シフトされXORされた結果の値を、スカラーレジスタである64ビットデスティネーションレジスタに格納する
 システム。
-  前記シフト・アンド・XOR演算を実行する命令は、前記シフト・アンド・XOR演算の種類をエンコードする1以上のフィールドを有する請求項34に記載のシステム。
-  ランダムアクセスメモリ(RAM)と、
 無線トランシーバと、
 前記RAMおよび前記無線トランシーバに接続される、縮小命令セットコンピュータ(RISC)アーキテクチャを有するプロセッサと、
 を備え、
 前記プロセッサは、
 レベル1(L1)キャッシュを含む複数レベルのキャッシュと、
 複数の整数レジスタと、
 2つの64ビット倍精度浮動小数点データエレメントを有する128ビットパックダブルオペランドを含む複数の浮動小数点データエレメントを格納する複数の浮動小数点レジスタと、
 複数のステータスレジスタと、
 命令ポインタレジスタと、
 命令をフェッチする命令プリフェッチャと、
 第1ソースオペランドを特定する第1ソースオペランド識別子と、第2ソースオペランドを識別する第2ソースオペランド識別子と、シフト量を指定する即値フィールドとを有し、前記第1ソースオペランドおよび前記第2ソースオペランドが64ビットソースオペランドであるシフト・アンド・XOR演算を実行する命令を含む、フェッチされた複数の命令をデコードするデコーダと、
 前記デコーダに接続される実行ユニットと、
 浮動小数点データエレメントを処理する浮動小数点ユニットと、
 を有し、
 前記プロセッサは、前記シフト・アンド・XOR演算を実行する命令に応じて、
 スカラー値の前記第1ソースオペランドを前記即値フィールドにより指定された左シフト量分シフトし、
 左シフトされた前記第1ソースオペランドと前記第2ソースオペランドとをXORし、
 左シフトされXORされた結果の値を、スカラーレジスタである64ビットデスティネーションレジスタに格納する
 システム。
-  前記シフト・アンド・XOR演算を実行する命令は、前記シフト・アンド・XOR演算の種類をエンコードする1以上のフィールドを有する請求項36に記載のシステム。
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title | 
|---|---|---|---|
| US12/653,704 US9747105B2 (en) | 2009-12-17 | 2009-12-17 | Method and apparatus for performing a shift and exclusive or operation in a single instruction | 
| US12/653,704 | 2009-12-17 | 
Related Parent Applications (1)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| JP2015088424A Division JP6126162B2 (ja) | 2009-12-17 | 2015-04-23 | 単一命令でシフト・アンド・排他的論理和演算を行う方法および装置 | 
Publications (2)
| Publication Number | Publication Date | 
|---|---|
| JP2017152016A true JP2017152016A (ja) | 2017-08-31 | 
| JP6615819B2 JP6615819B2 (ja) | 2019-12-04 | 
Family
ID=44152595
Family Applications (5)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| JP2012516393A Active JP5567668B2 (ja) | 2009-12-17 | 2010-10-29 | 単一命令でシフトおよび排他的論理和演算を行う方法および装置 | 
| JP2014092408A Active JP5941493B2 (ja) | 2009-12-17 | 2014-04-28 | 単一命令でシフトおよび排他的論理和演算を行う方法および装置 | 
| JP2014126121A Active JP5941498B2 (ja) | 2009-12-17 | 2014-06-19 | 単一命令でシフトおよび排他的論理和演算を行う方法および装置 | 
| JP2015088424A Active JP6126162B2 (ja) | 2009-12-17 | 2015-04-23 | 単一命令でシフト・アンド・排他的論理和演算を行う方法および装置 | 
| JP2017076187A Active JP6615819B2 (ja) | 2009-12-17 | 2017-04-06 | 単一命令でシフト・アンド・排他的論理和演算を行うシステム | 
Family Applications Before (4)
| Application Number | Title | Priority Date | Filing Date | 
|---|---|---|---|
| JP2012516393A Active JP5567668B2 (ja) | 2009-12-17 | 2010-10-29 | 単一命令でシフトおよび排他的論理和演算を行う方法および装置 | 
| JP2014092408A Active JP5941493B2 (ja) | 2009-12-17 | 2014-04-28 | 単一命令でシフトおよび排他的論理和演算を行う方法および装置 | 
| JP2014126121A Active JP5941498B2 (ja) | 2009-12-17 | 2014-06-19 | 単一命令でシフトおよび排他的論理和演算を行う方法および装置 | 
| JP2015088424A Active JP6126162B2 (ja) | 2009-12-17 | 2015-04-23 | 単一命令でシフト・アンド・排他的論理和演算を行う方法および装置 | 
Country Status (8)
| Country | Link | 
|---|---|
| US (5) | US9747105B2 (ja) | 
| JP (5) | JP5567668B2 (ja) | 
| KR (1) | KR101411064B1 (ja) | 
| CN (7) | CN104699457B (ja) | 
| DE (1) | DE112010004887B4 (ja) | 
| GB (2) | GB2483575B (ja) | 
| TW (5) | TWI610235B (ja) | 
| WO (1) | WO2011084214A2 (ja) | 
Families Citing this family (37)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| JP4930251B2 (ja) * | 2007-07-31 | 2012-05-16 | 富士通セミコンダクター株式会社 | 誤り訂正装置及びデスクランブル回路 | 
| US8515052B2 (en) | 2007-12-17 | 2013-08-20 | Wai Wu | Parallel signal processing system and method | 
| US9747105B2 (en) | 2009-12-17 | 2017-08-29 | Intel Corporation | Method and apparatus for performing a shift and exclusive or operation in a single instruction | 
| US9665371B2 (en) * | 2011-11-30 | 2017-05-30 | Intel Corporation | Providing vector horizontal compare functionality within a vector register | 
| US10318291B2 (en) | 2011-11-30 | 2019-06-11 | Intel Corporation | Providing vector horizontal compare functionality within a vector register | 
| US10564966B2 (en) | 2011-12-22 | 2020-02-18 | Intel Corporation | Packed data operation mask shift processors, methods, systems, and instructions | 
| US9336000B2 (en) | 2011-12-23 | 2016-05-10 | Intel Corporation | Instruction execution unit that broadcasts data values at different levels of granularity | 
| US9424327B2 (en) | 2011-12-23 | 2016-08-23 | Intel Corporation | Instruction execution that broadcasts and masks data values at different levels of granularity | 
| WO2013097071A1 (en) * | 2011-12-26 | 2013-07-04 | Intel Corporation | Direct link synchronization communication between co-processors | 
| WO2013101198A1 (en) | 2011-12-30 | 2013-07-04 | Intel Corporation | Simd variable shift and rotate using control manipulation | 
| US9128698B2 (en) * | 2012-09-28 | 2015-09-08 | Intel Corporation | Systems, apparatuses, and methods for performing rotate and XOR in response to a single instruction | 
| JP6219631B2 (ja) * | 2013-07-29 | 2017-10-25 | 学校法人明星学苑 | 論理演算装置 | 
| EP3001307B1 (en) * | 2014-09-25 | 2019-11-13 | Intel Corporation | Bit shuffle processors, methods, systems, and instructions | 
| US10001995B2 (en) * | 2015-06-02 | 2018-06-19 | Intel Corporation | Packed data alignment plus compute instructions, processors, methods, and systems | 
| US10423411B2 (en) | 2015-09-26 | 2019-09-24 | Intel Corporation | Data element comparison processors, methods, systems, and instructions | 
| US9916159B2 (en) * | 2016-01-14 | 2018-03-13 | International Business Machines Corporation | Programmable linear feedback shift register | 
| CN107534445B (zh) * | 2016-04-19 | 2020-03-10 | 华为技术有限公司 | 用于分割哈希值计算的向量处理 | 
| US10275243B2 (en) * | 2016-07-02 | 2019-04-30 | Intel Corporation | Interruptible and restartable matrix multiplication instructions, processors, methods, and systems | 
| US10606587B2 (en) | 2016-08-24 | 2020-03-31 | Micron Technology, Inc. | Apparatus and methods related to microcode instructions indicating instruction types | 
| US20180121202A1 (en) * | 2016-11-02 | 2018-05-03 | Intel Corporation | Simd channel utilization under divergent control flow | 
| CN107145334B (zh) * | 2017-04-26 | 2020-10-09 | 龙芯中科技术有限公司 | 常量获取方法、装置、处理器及计算机可读存储介质 | 
| US10698685B2 (en) * | 2017-05-03 | 2020-06-30 | Intel Corporation | Instructions for dual destination type conversion, mixed precision accumulation, and mixed precision atomic memory operations | 
| EP3619810A4 (en) * | 2017-07-31 | 2020-12-23 | Hewlett-Packard Development Company, L.P. | XOR PROCESSING OF VOXELS OF THREE-DIMENSIONAL MODELS | 
| CN107612684B (zh) * | 2017-10-20 | 2020-09-15 | 中博龙辉装备集团股份有限公司 | 基于国产化处理器平台专有指令集的数据对称加密方法 | 
| CN110058884B (zh) * | 2019-03-15 | 2021-06-01 | 佛山市顺德区中山大学研究院 | 用于计算型存储指令集运算的优化方法、系统及存储介质 | 
| CN109976705B (zh) * | 2019-03-20 | 2020-06-02 | 上海燧原智能科技有限公司 | 浮点格式数据处理装置、数据处理设备及数据处理方法 | 
| CN110221807B (zh) * | 2019-06-06 | 2021-08-03 | 龙芯中科(合肥)技术有限公司 | 数据移位方法、装置、设备及计算机可读存储介质 | 
| US11467834B2 (en) * | 2020-04-01 | 2022-10-11 | Samsung Electronics Co., Ltd. | In-memory computing with cache coherent protocol | 
| US11269631B2 (en) * | 2020-07-29 | 2022-03-08 | Ghost Locomotion Inc. | Extending fused multiply-add instructions | 
| US12393422B2 (en) * | 2021-06-26 | 2025-08-19 | Intel Corporation | Apparatus and method for vector packed signed/unsigned shift, round, and saturate | 
| US12204903B2 (en) | 2021-06-26 | 2025-01-21 | Intel Corporation | Dual sum of quadword 16×16 multiply and accumulate | 
| US20230129750A1 (en) * | 2021-10-27 | 2023-04-27 | International Business Machines Corporation | Performing a floating-point multiply-add operation in a computer implemented environment | 
| CN114296798B (zh) * | 2021-12-10 | 2024-08-13 | 龙芯中科技术股份有限公司 | 向量移位方法、处理器及电子设备 | 
| US12197921B2 (en) * | 2022-12-22 | 2025-01-14 | Intel Corporation | Accelerating eight-way parallel Keccak execution | 
| CN116055278B (zh) * | 2022-12-30 | 2024-10-18 | 中国科学院计算技术研究所 | 一种基于可配置非标准浮点数据的5g通信内接收机 | 
| US12086596B2 (en) * | 2023-02-06 | 2024-09-10 | Intel Corporation | Instructions for accelerating Keccak execution in a processor | 
| US12436771B2 (en) | 2023-12-29 | 2025-10-07 | Qualcomm Incorporated | Performing fused shift and logical operations in processor-based devices | 
Citations (18)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US4467444A (en) * | 1980-08-01 | 1984-08-21 | Advanced Micro Devices, Inc. | Processor unit for microcomputer systems | 
| JPH08137666A (ja) * | 1994-11-14 | 1996-05-31 | Matsushita Electric Ind Co Ltd | 演算装置およびその演算方法 | 
| JPH1040078A (ja) * | 1996-07-24 | 1998-02-13 | Hitachi Ltd | 先行0、1数予測回路、浮動小数点演算装置、マイクロプロセッサおよび情報処理装置 | 
| JPH10512070A (ja) * | 1994-12-02 | 1998-11-17 | インテル・コーポレーション | 複合オペランドのパック演算機能を有するマイクロプロセッサ | 
| US5909520A (en) * | 1997-08-25 | 1999-06-01 | The United States Of America As Represented By The Secretary Of The Navy | Noise coding processor | 
| US5917914A (en) * | 1997-04-24 | 1999-06-29 | Cirrus Logic, Inc. | DVD data descrambler for host interface and MPEG interface | 
| JPH11511575A (ja) * | 1995-08-31 | 1999-10-05 | インテル・コーポレーション | パック・データを処理する1組の命令 | 
| US6223320B1 (en) * | 1998-02-10 | 2001-04-24 | International Business Machines Corporation | Efficient CRC generation utilizing parallel table lookup operations | 
| JP2001256105A (ja) * | 2000-02-18 | 2001-09-21 | Texas Instr Inc <Ti> | 非整列循環アドレス指定を用いるマイクロプロセッサ | 
| JP2004135172A (ja) * | 2002-10-11 | 2004-04-30 | Motorola Inc | ガロア体掛け算器の制御方法 | 
| JP2004513592A (ja) * | 2000-11-15 | 2004-04-30 | アドバンスト・コミュニケーションズ・テクノロジーズ(オーストラリア)ピーティーワイ・リミテッド | シフトレジスタの更新方法 | 
| JP2006172486A (ja) * | 1994-12-01 | 2006-06-29 | Intel Corp | 算術演算装置及び算術演算方法 | 
| WO2008036945A1 (en) * | 2006-09-22 | 2008-03-27 | Intel Corporation | Instruction and logic for processing text strings | 
| JP2008077663A (ja) * | 2006-09-20 | 2008-04-03 | Intel Corp | ドット積演算を行うための命令および論理 | 
| US7395294B1 (en) * | 2003-01-10 | 2008-07-01 | Altera Corporation | Arithmetic logic unit | 
| US20080177996A1 (en) * | 2007-01-22 | 2008-07-24 | Laurence Ray Simar | Method for Design of Programmable Data Processors | 
| WO2009140142A1 (en) * | 2008-05-12 | 2009-11-19 | Sandbridge Technologies, Inc. | Implementation of arbitrary galois field arithmetic on a programmable processor | 
| US20090310775A1 (en) * | 2008-06-13 | 2009-12-17 | Shay Gueron | Using a single instruction multiple data (SIMD) instruction to speed up galois counter mode (GCM) computations | 
Family Cites Families (46)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US3781819A (en) * | 1971-10-08 | 1973-12-25 | Ibm | Shift unit for variable data widths | 
| JPS53147593A (en) | 1977-05-27 | 1978-12-22 | Hitachi Ltd | Oxygen density measuring device | 
| US4356549A (en) * | 1980-04-02 | 1982-10-26 | Control Data Corporation | System page table apparatus | 
| JPS6491228A (en) * | 1987-09-30 | 1989-04-10 | Takeshi Sakamura | Data processor | 
| US5504914A (en) * | 1993-06-23 | 1996-04-02 | National Science Council | Multi-level instruction boosting method using plurality of ordinary registers forming plurality of conjugate register pairs that are shadow registers to each other with different only in MSB | 
| US5559730A (en) * | 1994-02-18 | 1996-09-24 | Matsushita Electric Industrial Co., Ltd. | Shift operation unit and shift operation method | 
| US5864344A (en) * | 1995-07-03 | 1999-01-26 | Ikedo; Tsuneo | Computer graphics circuit | 
| JPH09115298A (ja) * | 1995-10-19 | 1997-05-02 | Mitsubishi Electric Corp | 半導体記憶装置 | 
| TW325552B (en) | 1996-09-23 | 1998-01-21 | Advanced Risc Mach Ltd | Data processing condition code flags | 
| US6009451A (en) * | 1996-11-22 | 1999-12-28 | Lucent Technologies Inc. | Method for generating barrel shifter result flags directly from input data | 
| US5896406A (en) | 1997-03-31 | 1999-04-20 | Adaptec, Inc. | Shift register-based XOR accumulator engine for generating parity in a data processing system | 
| GB9707861D0 (en) | 1997-04-18 | 1997-06-04 | Certicom Corp | Arithmetic processor | 
| US6134597A (en) | 1997-05-28 | 2000-10-17 | International Business Machines Corporation | CRC hash compressed server object identifier | 
| JP2001142694A (ja) * | 1999-10-01 | 2001-05-25 | Hitachi Ltd | データフィールドのエンコード方法、情報フィールドの拡張方法、及び、コンピュータシステム | 
| US6889319B1 (en) | 1999-12-09 | 2005-05-03 | Intel Corporation | Method and apparatus for entering and exiting multiple threads within a multithreaded processor | 
| US7046802B2 (en) | 2000-10-12 | 2006-05-16 | Rogaway Phillip W | Method and apparatus for facilitating efficient authenticated encryption | 
| US6810398B2 (en) | 2000-11-06 | 2004-10-26 | Avamar Technologies, Inc. | System and method for unorchestrated determination of data sequences using sticky byte factoring to determine breakpoints in digital sequences | 
| TWI261968B (en) | 2001-09-13 | 2006-09-11 | Macronix Int Co Ltd | Shifting apparatus for bit-shifting manipulation in a digital processor device | 
| DE10201441A1 (de) | 2002-01-16 | 2003-08-14 | Infineon Technologies Ag | Schiebevorrichtung und Verfahren zum Verschieben | 
| US7114116B2 (en) | 2002-09-13 | 2006-09-26 | Sun Microsystems, Inc. | Accelerated Galois data integrity crosscheck system and method | 
| WO2004034581A1 (ja) * | 2002-10-11 | 2004-04-22 | Fujitsu Limited | Pn符号発生器、gold符号発生器、pn符号逆拡散器、pn符号発生方法、gold符号発生方法、pn符号逆拡散方法、及びコンピュータプログラム | 
| JP4228728B2 (ja) | 2003-03-06 | 2009-02-25 | 日立工機株式会社 | 遠心分離機及び遠心分離機用スイングロ−タ | 
| US7539714B2 (en) | 2003-06-30 | 2009-05-26 | Intel Corporation | Method, apparatus, and instruction for performing a sign operation that multiplies | 
| KR100960095B1 (ko) | 2003-10-23 | 2010-05-31 | 마이크로칩 테크놀로지 인코포레이티드 | 마이크로컨트롤러 명령어 셋트 | 
| GB2411975B (en) | 2003-12-09 | 2006-10-04 | Advanced Risc Mach Ltd | Data processing apparatus and method for performing arithmetic operations in SIMD data processing | 
| JP3845636B2 (ja) * | 2004-01-21 | 2006-11-15 | 株式会社東芝 | 関数近似値の演算器 | 
| JP4418713B2 (ja) | 2004-06-11 | 2010-02-24 | キヤノン株式会社 | 乱数発生方法及び乱数発生装置 | 
| US7653674B2 (en) * | 2004-10-07 | 2010-01-26 | Infoprint Solutions Company Llc | Parallel operations on multiple signed elements in a register | 
| US8209366B2 (en) * | 2005-02-28 | 2012-06-26 | Hitachi Global Storage Technologies Netherlands B.V. | Method, apparatus and program storage device that provides a shift process with saturation for digital signal processor operations | 
| US8195922B2 (en) | 2005-03-18 | 2012-06-05 | Marvell World Trade, Ltd. | System for dynamically allocating processing time to multiple threads | 
| US7590930B2 (en) | 2005-05-24 | 2009-09-15 | Intel Corporation | Instructions for performing modulo-2 multiplication and bit reflection | 
| US8253751B2 (en) | 2005-06-30 | 2012-08-28 | Intel Corporation | Memory controller interface for micro-tiled memory access | 
| JP2007174312A (ja) * | 2005-12-22 | 2007-07-05 | Sanyo Electric Co Ltd | 符号化回路およびデジタル信号処理回路 | 
| CN100495322C (zh) | 2006-05-18 | 2009-06-03 | 中国科学院计算技术研究所 | 对预处理微指令发生异常多层嵌套进行处理的设备及方法 | 
| US7941435B2 (en) | 2006-08-01 | 2011-05-10 | Cisco Technology, Inc. | Substring search algorithm optimized for hardware acceleration | 
| US20080077772A1 (en) | 2006-09-22 | 2008-03-27 | Ronen Zohar | Method and apparatus for performing select operations | 
| DK176721B1 (da) | 2007-03-06 | 2009-04-27 | I/S Boewind V/Chr. I S Boewind V Chr | Fremgangsmode til akkumulering og udnyttelse af vedvarende energi | 
| US8001446B2 (en) * | 2007-03-26 | 2011-08-16 | Intel Corporation | Pipelined cyclic redundancy check (CRC) | 
| US8762345B2 (en) | 2007-05-31 | 2014-06-24 | Netapp, Inc. | System and method for accelerating anchor point detection | 
| US20090083507A1 (en) | 2007-09-24 | 2009-03-26 | Moore Charles H | Shift-add mechanism | 
| US7729185B2 (en) * | 2007-11-01 | 2010-06-01 | Arm Limited | Apparatus and method for detection of address decoder open faults | 
| IL188089A (en) * | 2007-12-12 | 2013-02-28 | Nds Ltd | Bit generator | 
| US8042025B2 (en) * | 2007-12-18 | 2011-10-18 | Intel Corporation | Determining a message residue | 
| US7689816B2 (en) | 2008-01-31 | 2010-03-30 | International Business Machines Corporation | Branch prediction with partially folded global history vector for reduced XOR operation time | 
| JP2012516393A (ja) | 2009-01-28 | 2012-07-19 | ナムローゼ・フェンノートシャップ・ベーカート・ソシエテ・アノニム | 楕円形コードの芯として構成された波形状偏平ワイヤ | 
| US9747105B2 (en) | 2009-12-17 | 2017-08-29 | Intel Corporation | Method and apparatus for performing a shift and exclusive or operation in a single instruction | 
- 
        2009
        - 2009-12-17 US US12/653,704 patent/US9747105B2/en active Active
 
- 
        2010
        - 2010-10-29 KR KR1020127012770A patent/KR101411064B1/ko active Active
- 2010-10-29 WO PCT/US2010/054754 patent/WO2011084214A2/en active IP Right Grant
- 2010-10-29 GB GB1119720.9A patent/GB2483575B/en active Active
- 2010-10-29 JP JP2012516393A patent/JP5567668B2/ja active Active
- 2010-10-29 GB GB1715480.8A patent/GB2552117B/en active Active
- 2010-10-29 DE DE112010004887.8T patent/DE112010004887B4/de active Active
- 2010-11-08 TW TW105143628A patent/TWI610235B/zh active
- 2010-11-08 TW TW104117447A patent/TWI575456B/zh active
- 2010-11-08 TW TW099138315A patent/TWI531969B/zh active
- 2010-11-08 TW TW104117444A patent/TWI575455B/zh active
- 2010-11-08 TW TW104117445A patent/TWI562067B/zh active
- 2010-12-15 CN CN201510098269.2A patent/CN104699457B/zh active Active
- 2010-12-15 CN CN201410855924.XA patent/CN104598203B/zh active Active
- 2010-12-15 CN CN201410855932.4A patent/CN104598204B/zh active Active
- 2010-12-15 CN CN201410857443.2A patent/CN104699456B/zh active Active
- 2010-12-15 CN CN201010601696.5A patent/CN102103487B/zh active Active
- 2010-12-15 CN CN201510098293.6A patent/CN104679478B/zh active Active
- 2010-12-15 CN CN201510098245.7A patent/CN104699459B/zh active Active
 
- 
        2014
        - 2014-04-28 JP JP2014092408A patent/JP5941493B2/ja active Active
- 2014-06-19 JP JP2014126121A patent/JP5941498B2/ja active Active
- 2014-12-01 US US14/556,931 patent/US9495165B2/en active Active
- 2014-12-01 US US14/557,372 patent/US9501281B2/en active Active
- 2014-12-01 US US14/557,360 patent/US9495166B2/en active Active
 
- 
        2015
        - 2015-04-23 JP JP2015088424A patent/JP6126162B2/ja active Active
 
- 
        2017
        - 2017-04-06 JP JP2017076187A patent/JP6615819B2/ja active Active
- 2017-08-25 US US15/686,889 patent/US10684855B2/en active Active
 
Patent Citations (18)
| Publication number | Priority date | Publication date | Assignee | Title | 
|---|---|---|---|---|
| US4467444A (en) * | 1980-08-01 | 1984-08-21 | Advanced Micro Devices, Inc. | Processor unit for microcomputer systems | 
| JPH08137666A (ja) * | 1994-11-14 | 1996-05-31 | Matsushita Electric Ind Co Ltd | 演算装置およびその演算方法 | 
| JP2006172486A (ja) * | 1994-12-01 | 2006-06-29 | Intel Corp | 算術演算装置及び算術演算方法 | 
| JPH10512070A (ja) * | 1994-12-02 | 1998-11-17 | インテル・コーポレーション | 複合オペランドのパック演算機能を有するマイクロプロセッサ | 
| JPH11511575A (ja) * | 1995-08-31 | 1999-10-05 | インテル・コーポレーション | パック・データを処理する1組の命令 | 
| JPH1040078A (ja) * | 1996-07-24 | 1998-02-13 | Hitachi Ltd | 先行0、1数予測回路、浮動小数点演算装置、マイクロプロセッサおよび情報処理装置 | 
| US5917914A (en) * | 1997-04-24 | 1999-06-29 | Cirrus Logic, Inc. | DVD data descrambler for host interface and MPEG interface | 
| US5909520A (en) * | 1997-08-25 | 1999-06-01 | The United States Of America As Represented By The Secretary Of The Navy | Noise coding processor | 
| US6223320B1 (en) * | 1998-02-10 | 2001-04-24 | International Business Machines Corporation | Efficient CRC generation utilizing parallel table lookup operations | 
| JP2001256105A (ja) * | 2000-02-18 | 2001-09-21 | Texas Instr Inc <Ti> | 非整列循環アドレス指定を用いるマイクロプロセッサ | 
| JP2004513592A (ja) * | 2000-11-15 | 2004-04-30 | アドバンスト・コミュニケーションズ・テクノロジーズ(オーストラリア)ピーティーワイ・リミテッド | シフトレジスタの更新方法 | 
| JP2004135172A (ja) * | 2002-10-11 | 2004-04-30 | Motorola Inc | ガロア体掛け算器の制御方法 | 
| US7395294B1 (en) * | 2003-01-10 | 2008-07-01 | Altera Corporation | Arithmetic logic unit | 
| JP2008077663A (ja) * | 2006-09-20 | 2008-04-03 | Intel Corp | ドット積演算を行うための命令および論理 | 
| WO2008036945A1 (en) * | 2006-09-22 | 2008-03-27 | Intel Corporation | Instruction and logic for processing text strings | 
| US20080177996A1 (en) * | 2007-01-22 | 2008-07-24 | Laurence Ray Simar | Method for Design of Programmable Data Processors | 
| WO2009140142A1 (en) * | 2008-05-12 | 2009-11-19 | Sandbridge Technologies, Inc. | Implementation of arbitrary galois field arithmetic on a programmable processor | 
| US20090310775A1 (en) * | 2008-06-13 | 2009-12-17 | Shay Gueron | Using a single instruction multiple data (SIMD) instruction to speed up galois counter mode (GCM) computations | 
Non-Patent Citations (5)
| Title | 
|---|
| ▲高▼田美樹, アセンブリ言語スタートブック, vol. 初版第1刷, JPN6019022558, 1 June 2009 (2009-06-01), pages 201 - 205, ISSN: 0004057155 * | 
| ANDREW N. SLOSS,DOMINIC SYMES,CHRIS WRIGHT著,アーム(株)監訳, ARM組み込みソフトウェア入門, vol. 初版, JPN6018029153, 15 August 2007 (2007-08-15), pages 14 - 23, ISSN: 0004057154 * | 
| PENTIUM PROファミリ・ディベロッパーズ・マニュアル 中巻:プログラマーズ・リファレンス・マニュアル, vol. 初版, JPN6019022559, 1996, pages 6 - 22, ISSN: 0004057156 * | 
| SUNG DAE KIM, SUNG HYUN JEONG, MYUNG HOON SUNWOO, KYUNG HO KIM: "NOVEL BIT MANIPULATION UNIT FOR COMMUNICATION DIGITAL SIGNAL PROCESSORS", PROCEEDINGS OF THE INTERNATIONAL SYMPOSIUM ON CIRCUITS AND SYSTEMS 2004 (ISCAS '04), vol. 2, JPN6015033823, 23 May 2004 (2004-05-23), pages 385 - 388, XP010720186, ISSN: 0004057157 * | 
| 小林達也: "ARMのアーキテクチャと最新コアに見る技術", ASCII.TECHNOLOGIES, vol. 第14巻,第8号, JPN6018029154, 1 August 2009 (2009-08-01), JP, pages 82 - 89, ISSN: 0004057158 * | 
Also Published As
Similar Documents
| Publication | Publication Date | Title | 
|---|---|---|
| JP6615819B2 (ja) | 単一命令でシフト・アンド・排他的論理和演算を行うシステム | |
| CN105022605B (zh) | 用于执行点积运算的指令和逻辑 | |
| JP2019220236A (ja) | プロセッサ、システム及び方法 | 
Legal Events
| Date | Code | Title | Description | 
|---|---|---|---|
| A521 | Request for written amendment filed | Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20170508 | |
| A621 | Written request for application examination | Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20170508 | |
| A977 | Report on retrieval | Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20180619 | |
| A131 | Notification of reasons for refusal | Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20180731 | |
| A601 | Written request for extension of time | Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20181030 | |
| A601 | Written request for extension of time | Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20181228 | |
| A521 | Request for written amendment filed | Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20190130 | |
| A131 | Notification of reasons for refusal | Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20190618 | |
| A521 | Request for written amendment filed | Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20190917 | |
| 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: 20191008 | |
| A61 | First payment of annual fees (during grant procedure) | Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20191106 | |
| R150 | Certificate of patent or registration of utility model | Ref document number: 6615819 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 | |
| R250 | Receipt of annual fees | Free format text: JAPANESE INTERMEDIATE CODE: R250 |