JP2007528545A - データ・ワードの中へビットを挿入する装置および方法 - Google Patents
データ・ワードの中へビットを挿入する装置および方法 Download PDFInfo
- Publication number
- JP2007528545A JP2007528545A JP2007502375A JP2007502375A JP2007528545A JP 2007528545 A JP2007528545 A JP 2007528545A JP 2007502375 A JP2007502375 A JP 2007502375A JP 2007502375 A JP2007502375 A JP 2007502375A JP 2007528545 A JP2007528545 A JP 2007528545A
- Authority
- JP
- Japan
- Prior art keywords
- register
- shift
- value
- data
- logic means
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims description 18
- 238000012545 processing Methods 0.000 claims abstract description 57
- 230000004044 response Effects 0.000 claims description 8
- 238000003780 insertion Methods 0.000 claims description 7
- 230000037431 insertion Effects 0.000 claims description 7
- 238000007906 compression Methods 0.000 description 5
- 230000006835 compression Effects 0.000 description 5
- 101100534231 Xenopus laevis src-b gene Proteins 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 230000001143 conditioned effect Effects 0.000 description 1
- 238000013144 data compression Methods 0.000 description 1
- 238000012856 packing 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
-
- 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/30018—Bit or string 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/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; 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
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)
- Image Processing (AREA)
- Advance Control (AREA)
Abstract
Description
使用されるデータ値を記憶する動作が可能な複数のレジスタと、
前記複数のレジスタに記憶された1つ以上のデータ値についてデータ処理動作を実行することが可能な処理ロジック手段と、
プログラム命令によって指定されたデータ処理動作を実行するために、前記処理ロジック手段を制御する前記プログラム命令に応答する命令デコーダと、を有し、
前記命令デコーダは、
所定の結果値を持つ結果を生成するシフトおよび挿入データ処理動作を実行するために、前記処理ロジック手段を制御するシフトおよび挿入命令に応答し、
前記所定の結果値は、
Nシフトされたビットを有するシフト値を形成するために、Nビット位置(positions)のシフト量で、第1レジスタに記憶された第1データ値をシフトするとともに、
前記Nシフトされたビットに対応する第2レジスタ内の第2データ値内のビットは変更せずに、前記第2レジスタ内の第2データ値における対応するビット位置に、前記シフト値の各ビットにおける前記Nシフトされたビット以外を挿入することによって形成されるものであり、
前記Nは、複数の異なるゼロでない値の一つであることを特徴とするデータ処理装置
を提供する。
複数のレジスタに使用されるデータ値を記憶するステップと、
前記複数のレジスタに記憶された1つ以上のデータ値について処理ロジック手段を使用してデータ処理動作を実行するステップと、
プログラム命令に対応して、前記プログラム命令で指定されたデータ処理動作を実行するために前記処理ロジック手段を制御する命令デコーダを使用するステップとを有し、
前記命令デコーダは、
所定の結果値を持つ結果を生成するシフトおよび挿入データ処理動作を実行するために、前記処理ロジック手段を制御するシフトおよび挿入命令に応答し、
前記所定の結果値は、
Nシフトされたビットを有するシフト値を形成するために、Nビット位置(positions)のシフト量で、第1レジスタに記憶された第1データ値をシフトするとともに、
前記Nシフトされたビットに対応する第2レジスタ内の第2データ値内のビットは変更せずに、前記第2レジスタ内の第2データ値における対応するビット位置に、前記シフト値の各ビットにおける前記Nシフトされたビット以外を挿入することによって形成されるものであり、
前記Nは、複数の異なるゼロでない値の一つであることを特徴とするデータを処理する方法である。
4 レジスタ・バンク
6 乗算器
8 シフタ
10 加算機
12 命令デコーダ
14 命令パイプライン
16 レジスタ
18 データ部分
20 レジスタ(宛先値)
22 ソースレジスタ
24 左シフタ
26 シフト値
28 開始マスク値
30 左シフタ
32 シフトマスク
34 マルチビット・マルチプレクサ
36 宛先値
38 結果値
Claims (26)
- 使用されるデータ値を記憶する動作が可能な複数のレジスタと、
前記複数のレジスタに記憶された1つ以上のデータ値についてデータ処理動作を実行することが可能な処理ロジック手段と、
プログラム命令によって指定されたデータ処理動作を実行するために、前記処理ロジック手段を制御する前記プログラム命令に応答する命令デコーダと、を有し、
前記命令デコーダは、
所定の結果値を持つ結果を生成するシフトおよび挿入データ処理動作を実行するために、前記処理ロジック手段を制御するシフトおよび挿入命令に応答し、
前記所定の結果値は、
Nシフトされたビットを有するシフト値を形成するために、Nビット位置(positions)のシフト量で、第1レジスタに記憶された第1データ値をシフトするとともに、
前記Nシフトされたビットに対応する第2レジスタ内の第2データ値内のビットは変更せずに、前記第2レジスタ内の第2データ値における対応するビット位置に、前記シフト値の各ビットにおける前記Nシフトされたビット以外を挿入することによって形成されるものであり、
前記Nは、複数の異なるゼロでない値の一つであることを特徴とするデータ処理装置。 - 前記シフトおよび挿入命令は、Nビット位置の前記シフト量を指定する即値を有する請求項1に記載の装置。
- 前記シフトおよび挿入命令は、前記第1レジスタとして使用するために、レジスタ・バンクのなかからレジスタを指定するレジスタ指定領域を有する請求項1および2のいずれか一項に記載の装置。
- 前記シフトおよび挿入命令は、前記第2レジスタとして使用するために、レジスタ・バンクのなかからレジスタを指定するレジスタ指定領域を有する請求項1、2および3のいずれか一項に記載の装置。
- 前記シフトおよび挿入命令は、宛先(destination)レジスタとして使用するために、レジスタ・バンクのなかからレジスタを指定するレジスタ指定領域を有する請求項1から4のいずれか一項に記載の装置。
- 前記宛先レジスタについての前記レジスタ指定領域は、前記第1レジスタおよび第2レジスタのいずれか一つに割り当てられる請求項5に記載の装置。
- 前記第1データ値は、右シフトされる請求項1から6のいずれか一項に記載の装置。
- 前記第1データ値は、左シフトされる請求項1から6のいずれか一項に記載の装置。
- 前記第1データ値および前記第2データ値は、同一のビット数をもっている請求項1から8のいずれか一項に記載の装置。
- 前記処理ロジック手段は、前記シフトおよび挿入命令に対応して、前記第1データ値をシフトする動作が可能である請求項1から9のいずれか一項に記載の装置。
- 前記処理ロジック手段は、前記シフトおよび挿入命令に対応して、前記シフトデータ値の中の対応するビットに置換された前記第2データ値の中のいずれかのビットと、変更されていない前記第2データ値の中のいずれかのビットと、を選択するためのマスク値を形成する動作が可能である請求項1から10のいずれか一項に記載の装置。
- 前記処理ロジック手段は、単一命令多重データ処理をするロジック手段であるとともに、前記第1レジスタおよび第2レジスタは、それぞれ第1単一命令多重データ・レジスタおよび第2単一命令多重データ・レジスタの一部分であり、
前記シフトおよび挿入命令は、各処理列における複数のシフトおよび挿入動作の並列な実行を制御する動作が可能である請求項1から11のいずれか一項に記載の装置。 - 前記処理ロジック手段は、スカラ処理ロジック手段である請求項1から11のいずれか一項に記載の装置。
- 複数のレジスタに使用されるデータ値を記憶するステップと、
前記複数のレジスタに記憶された1つ以上のデータ値について処理ロジック手段を使用してデータ処理動作を実行するステップと、
プログラム命令に対応して、前記プログラム命令で指定されたデータ処理動作を実行するために前記処理ロジック手段を制御する命令デコーダを使用するステップとを有し、
前記命令デコーダは、
所定の結果値を持つ結果を生成するシフトおよび挿入データ処理動作を実行するために、前記処理ロジック手段を制御するシフトおよび挿入命令に応答し、
前記所定の結果値は、
Nシフトされたビットを有するシフト値を形成するために、Nビット位置(positions)のシフト量で、第1レジスタに記憶された第1データ値をシフトするとともに、
前記Nシフトされたビットに対応する第2レジスタ内の第2データ値内のビットは変更せずに、前記第2レジスタ内の第2データ値における対応するビット位置に、前記シフト値の各ビットにおける前記Nシフトされたビット以外を挿入することによって形成されるものであり、
前記Nは、複数の異なるゼロでない値の一つであることを特徴とするデータを処理する方法。 - 前記シフトおよび挿入命令は、Nビット位置の前記シフト量を指定する即値を有する請求項14に記載の方法。
- 前記シフトおよび挿入命令は、前記第1レジスタとして使用するために、レジスタ・バンクのなかからレジスタを指定するレジスタ指定領域を有する請求項14および15のいずれか一項に記載の方法。
- 前記シフトおよび挿入命令は、前記第2レジスタとして使用するために、レジスタ・バンクのなかからレジスタを指定するレジスタ指定領域を有する請求項14、15および16のいずれか一項に記載の方法。
- 前記シフトおよび挿入命令は、宛先レジスタとして使用するために、レジスタ・バンクのなかからレジスタを指定するレジスタ指定領域を有する請求項14から17のいずれか一項に記載の方法。
- 前記宛先レジスタについての前記レジスタ指定領域は、前記第1レジスタおよび第2レジスタのいずれか一つに割り当てられる請求項18に記載の方法。
- 前記第1データ値は、右シフトされる請求項13から17のいずれか一項に記載の方法。
- 前記第1データ値は、左シフトされる請求項14から17のいずれか一項に記載の方法。
- 前記第1データ値および前記第2データ値は、同一のビット数をもっている請求項14から19のいずれか一項に記載の方法。
- 前記処理ロジック手段は、前記シフトおよび挿入命令に対応して、前記第1データ値をシフトする動作が可能である請求項14から20のいずれか一項に記載の方法。
- 前記処理ロジック手段は、前記シフトおよび挿入命令に対応して、前記シフトデータ値の中の対応するビットに置換された前記第2データ値の中のいずれかのビットと、変更されていない前記第2データ値の中のいずれかのビットと、を選択するためのマスク値を形成する動作が可能である請求項14から21のいずれか一項に記載の方法。
- 前記処理ロジック手段は、単一命令多重データ処理をするロジック手段であるとともに、前記第1レジスタおよび第2レジスタは、それぞれ第1単一命令多重データ・レジスタおよび第2単一命令多重データ・レジスタの一部分であり、前記シフトおよび挿入命令は、各処理列における複数のシフトおよび挿入動作の並列な実行を制御する動作が可能である請求項14から22のいずれか一項に記載の方法。
- 前記処理ロジック手段は、スカラ処理ロジック手段である請求項14から22のいずれか一項に記載の方法。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB0405407A GB2411978B (en) | 2004-03-10 | 2004-03-10 | Inserting bits within a data word |
PCT/GB2004/003343 WO2005088441A2 (en) | 2004-03-10 | 2004-08-03 | Inserting bits within a data word |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2007528545A true JP2007528545A (ja) | 2007-10-11 |
Family
ID=32117417
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007502375A Pending JP2007528545A (ja) | 2004-03-10 | 2004-08-03 | データ・ワードの中へビットを挿入する装置および方法 |
Country Status (11)
Country | Link |
---|---|
US (1) | US7350058B2 (ja) |
EP (1) | EP1723512A2 (ja) |
JP (1) | JP2007528545A (ja) |
KR (1) | KR100981998B1 (ja) |
CN (1) | CN100538624C (ja) |
GB (1) | GB2411978B (ja) |
IL (1) | IL177507A (ja) |
MY (1) | MY137200A (ja) |
RU (1) | RU2006135629A (ja) |
TW (1) | TWI322947B (ja) |
WO (1) | WO2005088441A2 (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2018521426A (ja) * | 2015-07-31 | 2018-08-02 | エイアールエム リミテッド | スプライス演算を行うための装置および方法 |
Families Citing this family (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7529918B2 (en) * | 2006-07-21 | 2009-05-05 | Broadcom Corporation | System and method for efficiently performing bit-field extraction and bit-field combination operations in a processor |
JP4374363B2 (ja) * | 2006-09-26 | 2009-12-02 | Okiセミコンダクタ株式会社 | ビットフィールド操作回路 |
GB2475653B (en) * | 2007-03-12 | 2011-07-13 | Advanced Risc Mach Ltd | Select and insert instructions within data processing systems |
EP2232361A1 (en) * | 2007-12-05 | 2010-09-29 | Sandbridge Technologies, Inc. | Method and instruction set including register shifts and rotates for data processing |
CN102348111A (zh) * | 2010-07-30 | 2012-02-08 | 国家卫星气象中心 | 用于静止气象卫星数据广播的数据压缩结构识别码 |
US20120117360A1 (en) * | 2010-11-09 | 2012-05-10 | Texas Instruments Incorporated | Dedicated instructions for variable length code insertion by a digital signal processor (dsp) |
GB2485774A (en) | 2010-11-23 | 2012-05-30 | Advanced Risc Mach Ltd | Processor instruction to extract a bit field from one operand and insert it into another with an option to sign or zero extend the field |
US9823928B2 (en) * | 2011-09-30 | 2017-11-21 | Qualcomm Incorporated | FIFO load instruction |
CN111831335A (zh) * | 2011-12-23 | 2020-10-27 | 英特尔公司 | 经改进的插入指令的装置和方法 |
US9411593B2 (en) * | 2013-03-15 | 2016-08-09 | Intel Corporation | Processors, methods, systems, and instructions to consolidate unmasked elements of operation masks |
WO2014203034A1 (en) * | 2013-06-18 | 2014-12-24 | Freescale Semiconductor, Inc. | Signal processing device and method of performing a pack-insert operation |
CN104899522B (zh) * | 2015-06-09 | 2018-01-30 | 网易(杭州)网络有限公司 | 一种数据处理方法及装置 |
US20170177350A1 (en) * | 2015-12-18 | 2017-06-22 | Intel Corporation | Instructions and Logic for Set-Multiple-Vector-Elements Operations |
US20170185402A1 (en) * | 2015-12-23 | 2017-06-29 | Intel Corporation | Instructions and logic for bit field address and insertion |
CN105892993B (zh) * | 2016-03-28 | 2019-02-15 | 龙芯中科技术有限公司 | 基于提取插入操作的重组方法、装置及微处理器 |
CN110912562A (zh) * | 2018-09-18 | 2020-03-24 | 深圳市茁壮网络股份有限公司 | 一种浮点数据处理方法、装置及存储介质 |
CN109891756B (zh) * | 2019-01-31 | 2023-03-28 | 香港应用科技研究院有限公司 | 可重置分段可缩放移位器 |
US10831479B2 (en) * | 2019-02-20 | 2020-11-10 | International Business Machines Corporation | Instruction to move data in a right-to-left direction |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4023023A (en) * | 1973-12-04 | 1977-05-10 | Compagnie Internationale Pour L'informatique | Field selection data operating device |
JPS6014336A (ja) * | 1983-06-30 | 1985-01-24 | インタ−ナショナル ビジネス マシ−ンズ コ−ポレ−ション | 命令処理装置 |
JPH113226A (ja) * | 1996-10-10 | 1999-01-06 | Sun Microsyst Inc | 統合グラフィックス機能を有するcpu用のビジュアル命令セット |
JP2001134436A (ja) * | 1999-10-29 | 2001-05-18 | Texas Instr Inc <Ti> | 効率的な粒度のシフトとマージの一方または両方の命令をそなえたプロセッサの回路、システム及び方法 |
WO2003038601A1 (en) * | 2001-10-29 | 2003-05-08 | Intel Corporation | Method and apparatus for parallel shift right merge of data |
Family Cites Families (53)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US131030A (en) * | 1872-09-03 | Improvement in portable furnaces | ||
US133682A (en) * | 1872-12-03 | Improvement in gates | ||
US4876660A (en) | 1987-03-20 | 1989-10-24 | Bipolar Integrated Technology, Inc. | Fixed-point multiplier-accumulator architecture |
JPH0778735B2 (ja) | 1988-12-05 | 1995-08-23 | 松下電器産業株式会社 | キャッシュ装置と命令読出し装置 |
JPH05233281A (ja) | 1992-02-21 | 1993-09-10 | Toshiba Corp | 電子計算機 |
US5408670A (en) | 1992-12-18 | 1995-04-18 | Xerox Corporation | Performing arithmetic in parallel on composite operands with packed multi-bit components |
US5481743A (en) | 1993-09-30 | 1996-01-02 | Apple Computer, Inc. | Minimal instruction set computer architecture and multiple instruction issue method |
US5881302A (en) | 1994-05-31 | 1999-03-09 | Nec Corporation | Vector processing unit with reconfigurable data buffer |
US6009508A (en) | 1994-06-21 | 1999-12-28 | Sgs-Thomson Microelectronics Limited | System and method for addressing plurality of data values with a single address in a multi-value store on FIFO basis |
GB9412434D0 (en) | 1994-06-21 | 1994-08-10 | Inmos Ltd | Computer instruction compression |
GB9412487D0 (en) | 1994-06-22 | 1994-08-10 | Inmos Ltd | A computer system for executing branch instructions |
US5761103A (en) | 1995-03-08 | 1998-06-02 | Texas Instruments Incorporated | Left and right justification of single precision mantissa in a double precision rounding unit |
GB9509983D0 (en) | 1995-05-17 | 1995-07-12 | Sgs Thomson Microelectronics | Replication of data |
GB9509987D0 (en) | 1995-05-17 | 1995-07-12 | Sgs Thomson Microelectronics | Manipulation of data |
GB9509988D0 (en) | 1995-05-17 | 1995-07-12 | Sgs Thomson Microelectronics | Matrix transposition |
GB9509989D0 (en) | 1995-05-17 | 1995-07-12 | Sgs Thomson Microelectronics | Manipulation of data |
GB9513515D0 (en) | 1995-07-03 | 1995-09-06 | Sgs Thomson Microelectronics | Expansion of data |
GB9514695D0 (en) | 1995-07-18 | 1995-09-13 | Sgs Thomson Microelectronics | Combining data values |
GB9514684D0 (en) | 1995-07-18 | 1995-09-13 | Sgs Thomson Microelectronics | An arithmetic unit |
JP3526976B2 (ja) | 1995-08-03 | 2004-05-17 | 株式会社日立製作所 | プロセッサおよびデータ処理装置 |
US6295599B1 (en) | 1995-08-16 | 2001-09-25 | Microunity Systems Engineering | System and method for providing a wide operand architecture |
US5907865A (en) | 1995-08-28 | 1999-05-25 | Motorola, Inc. | Method and data processing system for dynamically accessing both big-endian and little-endian storage schemes |
AU6905496A (en) | 1995-09-01 | 1997-03-27 | Philips Electronics North America Corporation | Method and apparatus for custom operations of a processor |
US6088783A (en) | 1996-02-16 | 2000-07-11 | Morton; Steven G | DPS having a plurality of like processors controlled in parallel by an instruction word, and a control processor also controlled by the instruction word |
US5937178A (en) | 1996-02-13 | 1999-08-10 | National Semiconductor Corporation | Register file for registers with multiple addressable sizes using read-modify-write for register file update |
US6009191A (en) * | 1996-02-15 | 1999-12-28 | Intel Corporation | Computer implemented method for compressing 48-bit pixels to 16-bit pixels |
US5808875A (en) | 1996-03-29 | 1998-09-15 | Intel Corporation | Integrated circuit solder-rack interconnect module |
US6058465A (en) | 1996-08-19 | 2000-05-02 | Nguyen; Le Trong | Single-instruction-multiple-data processing in a multimedia signal processor |
US5838984A (en) | 1996-08-19 | 1998-11-17 | Samsung Electronics Co., Ltd. | Single-instruction-multiple-data processing using multiple banks of vector registers |
US6173366B1 (en) | 1996-12-02 | 2001-01-09 | Compaq Computer Corp. | Load and store instructions which perform unpacking and packing of data bits in separate vector and integer cache storage |
US5893145A (en) | 1996-12-02 | 1999-04-06 | Compaq Computer Corp. | System and method for routing operands within partitions of a source register to partitions within a destination register |
US5909572A (en) | 1996-12-02 | 1999-06-01 | Compaq Computer Corp. | System and method for conditionally moving an operand from a source register to a destination register |
US5898896A (en) | 1997-04-10 | 1999-04-27 | International Business Machines Corporation | Method and apparatus for data ordering of I/O transfers in Bi-modal Endian PowerPC systems |
US5973705A (en) | 1997-04-24 | 1999-10-26 | International Business Machines Corporation | Geometry pipeline implemented on a SIMD machine |
US6047304A (en) | 1997-07-29 | 2000-04-04 | Nortel Networks Corporation | Method and apparatus for performing lane arithmetic to perform network processing |
US6209017B1 (en) | 1997-08-30 | 2001-03-27 | Lg Electronics Inc. | High speed digital signal processor |
GB2329810B (en) | 1997-09-29 | 2002-02-27 | Science Res Foundation | Generation and use of compressed image data |
US5864703A (en) | 1997-10-09 | 1999-01-26 | Mips Technologies, Inc. | Method for providing extended precision in SIMD vector arithmetic operations |
US5933650A (en) | 1997-10-09 | 1999-08-03 | Mips Technologies, Inc. | Alignment and ordering of vector elements for single instruction multiple data processing |
US6223198B1 (en) | 1998-08-14 | 2001-04-24 | Advanced Micro Devices, Inc. | Method and apparatus for multi-function arithmetic |
US6085213A (en) | 1997-10-23 | 2000-07-04 | Advanced Micro Devices, Inc. | Method and apparatus for simultaneously multiplying two or more independent pairs of operands and summing the products |
US6144980A (en) | 1998-01-28 | 2000-11-07 | Advanced Micro Devices, Inc. | Method and apparatus for performing multiple types of multiplication including signed and unsigned multiplication |
US6038583A (en) | 1997-10-23 | 2000-03-14 | Advanced Micro Devices, Inc. | Method and apparatus for simultaneously multiplying two or more independent pairs of operands and calculating a rounded products |
US6269384B1 (en) | 1998-03-27 | 2001-07-31 | Advanced Micro Devices, Inc. | Method and apparatus for rounding and normalizing results within a multiplier |
US6223277B1 (en) | 1997-11-21 | 2001-04-24 | Texas Instruments Incorporated | Data processing circuit with packed data structure capability |
US6223320B1 (en) | 1998-02-10 | 2001-04-24 | International Business Machines Corporation | Efficient CRC generation utilizing parallel table lookup operations |
US6334176B1 (en) | 1998-04-17 | 2001-12-25 | Motorola, Inc. | Method and apparatus for generating an alignment control vector |
US6292888B1 (en) | 1999-01-27 | 2001-09-18 | Clearwater Networks, Inc. | Register transfer unit for electronic processor |
GB2352065B (en) | 1999-07-14 | 2004-03-03 | Element 14 Ltd | A memory access system |
US6408345B1 (en) | 1999-07-15 | 2002-06-18 | Texas Instruments Incorporated | Superscalar memory transfer controller in multilevel memory organization |
US6546480B1 (en) | 1999-10-01 | 2003-04-08 | Hitachi, Ltd. | Instructions for arithmetic operations on vectored data |
US6748521B1 (en) | 2000-02-18 | 2004-06-08 | Texas Instruments Incorporated | Microprocessor with instruction for saturating and packing data |
US7272622B2 (en) * | 2001-10-29 | 2007-09-18 | Intel Corporation | Method and apparatus for parallel shift right merge of data |
-
2004
- 2004-03-10 GB GB0405407A patent/GB2411978B/en not_active Expired - Lifetime
- 2004-08-03 KR KR1020067018123A patent/KR100981998B1/ko active IP Right Grant
- 2004-08-03 WO PCT/GB2004/003343 patent/WO2005088441A2/en active Application Filing
- 2004-08-03 RU RU2006135629/09A patent/RU2006135629A/ru not_active Application Discontinuation
- 2004-08-03 EP EP04743646A patent/EP1723512A2/en not_active Withdrawn
- 2004-08-03 JP JP2007502375A patent/JP2007528545A/ja active Pending
- 2004-08-03 CN CNB2004800423443A patent/CN100538624C/zh not_active Expired - Lifetime
- 2004-08-11 TW TW093124095A patent/TWI322947B/zh not_active IP Right Cessation
- 2004-08-12 MY MYPI20043293A patent/MY137200A/en unknown
- 2004-08-30 US US10/928,748 patent/US7350058B2/en active Active
-
2006
- 2006-08-15 IL IL177507A patent/IL177507A/en active IP Right Grant
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4023023A (en) * | 1973-12-04 | 1977-05-10 | Compagnie Internationale Pour L'informatique | Field selection data operating device |
JPS6014336A (ja) * | 1983-06-30 | 1985-01-24 | インタ−ナショナル ビジネス マシ−ンズ コ−ポレ−ション | 命令処理装置 |
US4569016A (en) * | 1983-06-30 | 1986-02-04 | International Business Machines Corporation | Mechanism for implementing one machine cycle executable mask and rotate instructions in a primitive instruction set computing system |
JPH113226A (ja) * | 1996-10-10 | 1999-01-06 | Sun Microsyst Inc | 統合グラフィックス機能を有するcpu用のビジュアル命令セット |
JP2001134436A (ja) * | 1999-10-29 | 2001-05-18 | Texas Instr Inc <Ti> | 効率的な粒度のシフトとマージの一方または両方の命令をそなえたプロセッサの回路、システム及び方法 |
US6430684B1 (en) * | 1999-10-29 | 2002-08-06 | Texas Instruments Incorporated | Processor circuits, systems, and methods with efficient granularity shift and/or merge instruction(s) |
WO2003038601A1 (en) * | 2001-10-29 | 2003-05-08 | Intel Corporation | Method and apparatus for parallel shift right merge of data |
JP2005508043A (ja) * | 2001-10-29 | 2005-03-24 | インテル コーポレイション | データの右方向平行シフトマージ方法及び装置 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2018521426A (ja) * | 2015-07-31 | 2018-08-02 | エイアールエム リミテッド | スプライス演算を行うための装置および方法 |
US12061906B2 (en) | 2015-07-31 | 2024-08-13 | Arm Limited | Apparatus and method for performing a splice of vectors based on location and length data |
Also Published As
Publication number | Publication date |
---|---|
GB2411978B (en) | 2007-04-04 |
MY137200A (en) | 2009-01-30 |
EP1723512A2 (en) | 2006-11-22 |
WO2005088441A2 (en) | 2005-09-22 |
CN1926511A (zh) | 2007-03-07 |
KR100981998B1 (ko) | 2010-09-13 |
US7350058B2 (en) | 2008-03-25 |
GB0405407D0 (en) | 2004-04-21 |
GB2411978A (en) | 2005-09-14 |
IL177507A0 (en) | 2006-12-10 |
WO2005088441A3 (en) | 2006-06-22 |
US20050204117A1 (en) | 2005-09-15 |
KR20070028322A (ko) | 2007-03-12 |
RU2006135629A (ru) | 2008-04-20 |
TW200530838A (en) | 2005-09-16 |
IL177507A (en) | 2010-12-30 |
CN100538624C (zh) | 2009-09-09 |
TWI322947B (en) | 2010-04-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP2007528545A (ja) | データ・ワードの中へビットを挿入する装置および方法 | |
JP5047944B2 (ja) | データアクセス及び置換ユニット | |
JP4708761B2 (ja) | Simd処理における定数の生成 | |
US9292298B2 (en) | Data processing apparatus having SIMD processing circuitry | |
US6098087A (en) | Method and apparatus for performing shift operations on packed data | |
US6438676B1 (en) | Distance controlled concatenation of selected portions of elements of packed data | |
JP4374363B2 (ja) | ビットフィールド操作回路 | |
JP2008071130A (ja) | Simd型マイクロプロセッサ | |
JP2005174295A (ja) | Simdデータ処理における算術演算の実行のためのデータ処理装置及び方法 | |
JP2007531133A (ja) | 二重経路プロセッサの処理制御のための装置および方法 | |
EP3329363B1 (en) | Vector arithmethic instruction | |
JP2005332361A (ja) | プログラム命令圧縮装置および方法 | |
US20230325189A1 (en) | Forming Constant Extensions in the Same Execute Packet in a VLIW Processor | |
JP2008513878A (ja) | 機能単位が読み出しポートを共有するデータ処理回路 | |
JP2004511039A5 (ja) | ||
JP4686435B2 (ja) | 演算装置 | |
CN107851022B (zh) | 向量长度查询指令 | |
CN112182496A (zh) | 用于矩阵乘法的数据处理方法及装置 | |
KR102591988B1 (ko) | 데이터 처리장치에서의 벡터 인터리빙 | |
WO2012137428A1 (ja) | データ処理装置、及びデータ処理方法 | |
JP3837386B2 (ja) | 情報処理装置 | |
JP2006285721A (ja) | 演算処理装置および演算処理方法 | |
JP2002091929A (ja) | Simd型並列処理装置 | |
JP2007279983A (ja) | 命令処理装置 | |
JP5263497B2 (ja) | 信号処理プロセッサ及び半導体装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20091124 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20100205 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20100330 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20100726 |
|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20100816 |
|
A912 | Re-examination (zenchi) completed and case transferred to appeal board |
Free format text: JAPANESE INTERMEDIATE CODE: A912 Effective date: 20100910 |