JP4228241B2 - 演算処理装置 - Google Patents
演算処理装置 Download PDFInfo
- Publication number
- JP4228241B2 JP4228241B2 JP2006335583A JP2006335583A JP4228241B2 JP 4228241 B2 JP4228241 B2 JP 4228241B2 JP 2006335583 A JP2006335583 A JP 2006335583A JP 2006335583 A JP2006335583 A JP 2006335583A JP 4228241 B2 JP4228241 B2 JP 4228241B2
- Authority
- JP
- Japan
- Prior art keywords
- register
- condition code
- condition
- value
- code set
- 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.)
- Expired - Fee Related
Links
- 238000006243 chemical reaction Methods 0.000 claims description 77
- 230000006870 function Effects 0.000 description 29
- 238000010586 diagram Methods 0.000 description 18
- 238000000034 method Methods 0.000 description 18
- 230000000694 effects Effects 0.000 description 1
- 230000001771 impaired effect Effects 0.000 description 1
- 230000009191 jumping Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000003672 processing method Methods 0.000 description 1
- 238000004904 shortening 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/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
-
- 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/3001—Arithmetic 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/3005—Arrangements for executing specific machine instructions to perform operations for flow control
- G06F9/30058—Conditional branch 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/30094—Condition code generation, e.g. Carry, Zero flag
-
- 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/34—Addressing or accessing the instruction operand or the result ; Formation of operand address; Addressing modes
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Executing Machine-Instructions (AREA)
- Advance Control (AREA)
Description
200 命令フェッチ/デコーダ
300 レジスタユニット
310 レジスタファイル
320 設定レジスタ
321 書込みモードレジスタ(Reg_WRMODE)
322 マスクレジスタ(Reg_MASK[3:0])
323 反転レジスタ(Reg_XOR[3:0])
324 比較パターンレジスタ(Reg_MATCH[3:0])
325 機能レジスタ(Reg_FUNC[1:0])
330 フラグ書込み部
340 フラグ変換部
342 論理積演算器
343 排他的論理和演算器
344 比較器
345 フラグ変換テーブル
346 選択器
400 オペランドセレクタ
411、412、421、422 選択器
500 実行ユニット群
501、511、521、531 演算ユニット
541 ロード/ストアユニット
551 分岐ユニット
600 データメモリ
Claims (2)
- それぞれ異なる演算を行ってその演算による演算結果および条件コードを生成する複数の演算器と、
前記複数の演算器によって生成された条件コードを条件コードセットとして保持する条件コードセットレジスタと、
前記条件コードセットレジスタに保持された前記条件コードセットの一部と前記複数の演算器によって同時に生成された前記条件コードの一部とを新たな条件コードセットとして前記条件コードセットレジスタに保持させる条件コード書込み手段と、
前記条件コードセットに対して所定の変換を施して変換条件コードセットとして出力する条件コード変換手段と、
前記変換条件コードセットに基づいて前記複数の演算器における前記演算のためのオペランドを供給するオペランド供給手段と
を具備する演算処理装置。 - それぞれ異なる演算を行ってその演算による演算結果および条件コードを生成する複数の演算器と、
前記条件コードの各々についてマスク演算を行うか否かを示すマスクビットを保持するマスクレジスタと、
前記条件コードの各々について前記マスクレジスタに従ってマスク演算を行うマスク演算器と、
前記マスク演算器により処理された前記条件コードの各々について反転処理を行うか否かを示す反転ビットを保持する反転レジスタと、
前記マスク演算器により処理された前記条件コードの各々について前記反転レジスタに従って反転処理を行う反転処理器と、
前記反転処理器により処理された前記条件コードの各々について比較対象となるパターンを保持する比較パターンレジスタと、
前記反転処理器により処理された前記条件コードと前記比較パターンレジスタに保持されたパターンを比較する比較器と、
前記反転処理器により処理された前記条件コードの組合せに対応した変換条件コードセットを保持する変換テーブルと、
前記比較器の比較結果、前記反転処理器により処理された前記条件コード、または、前記反転処理器により処理された前記条件コードの組合せに対応して前記変換テーブルから読み出された前記変換条件コードセットの何れか1つを選択する選択器と、
前記選択器の出力に基づいて前記複数の演算器における前記演算のためのオペランドを供給するオペランド供給手段と
を具備する演算処理装置。
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2006335583A JP4228241B2 (ja) | 2006-12-13 | 2006-12-13 | 演算処理装置 |
US11/987,700 US8635434B2 (en) | 2006-12-13 | 2007-12-04 | Mathematical operation processing apparatus for performing high speed mathematical operations |
CN2007101994391A CN101201736B (zh) | 2006-12-13 | 2007-12-13 | 数学运算处理装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2006335583A JP4228241B2 (ja) | 2006-12-13 | 2006-12-13 | 演算処理装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2008146544A JP2008146544A (ja) | 2008-06-26 |
JP4228241B2 true JP4228241B2 (ja) | 2009-02-25 |
Family
ID=39516911
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2006335583A Expired - Fee Related JP4228241B2 (ja) | 2006-12-13 | 2006-12-13 | 演算処理装置 |
Country Status (3)
Country | Link |
---|---|
US (1) | US8635434B2 (ja) |
JP (1) | JP4228241B2 (ja) |
CN (1) | CN101201736B (ja) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8850166B2 (en) | 2010-02-18 | 2014-09-30 | International Business Machines Corporation | Load pair disjoint facility and instruction therefore |
JP5813484B2 (ja) | 2011-11-30 | 2015-11-17 | ルネサスエレクトロニクス株式会社 | Vliwプロセッサと命令構造と命令実行方法 |
US9645820B2 (en) | 2013-06-27 | 2017-05-09 | Intel Corporation | Apparatus and method to reserve and permute bits in a mask register |
CN104966026A (zh) * | 2015-06-03 | 2015-10-07 | 西安科技大学 | 数学运算系统 |
US20160378480A1 (en) * | 2015-06-27 | 2016-12-29 | Pavel G. Matveyev | Systems, Methods, and Apparatuses for Improving Performance of Status Dependent Computations |
JP6616608B2 (ja) * | 2015-07-16 | 2019-12-04 | ルネサスエレクトロニクス株式会社 | 半導体装置 |
CN107229722A (zh) * | 2017-06-05 | 2017-10-03 | 商丘医学高等专科学校 | 一种智能数学运算处理系统 |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
USH1970H1 (en) * | 1971-07-19 | 2001-06-05 | Texas Instruments Incorporated | Variable function programmed system |
JPS6043751A (ja) | 1983-08-18 | 1985-03-08 | Hitachi Ltd | 情報処理装置 |
GB2228597A (en) * | 1989-02-27 | 1990-08-29 | Ibm | Data processor with conditional instructions |
JP2793357B2 (ja) | 1990-11-20 | 1998-09-03 | 株式会社東芝 | 並列演算装置 |
JP2928680B2 (ja) | 1992-03-30 | 1999-08-03 | 株式会社東芝 | 複合条件処理方式 |
JPH0991141A (ja) | 1995-09-26 | 1997-04-04 | Toshiba Corp | Vliw方式プロセッサ及び並列処理方法 |
TW325552B (en) * | 1996-09-23 | 1998-01-21 | Advanced Risc Mach Ltd | Data processing condition code flags |
CN1206145A (zh) * | 1997-06-30 | 1999-01-27 | 索尼公司 | 带有流水线处理电路的信号处理器及其方法 |
JPH1153189A (ja) | 1997-07-31 | 1999-02-26 | Toshiba Corp | 演算装置、演算方法及びコンピュータ読み取り可能な記録媒体 |
JP3830683B2 (ja) * | 1998-12-28 | 2006-10-04 | 富士通株式会社 | Vliwプロセッサ |
US6697276B1 (en) * | 2002-02-01 | 2004-02-24 | Netlogic Microsystems, Inc. | Content addressable memory device |
KR100628573B1 (ko) * | 2004-09-08 | 2006-09-26 | 삼성전자주식회사 | 조건부실행명령어의 비순차적 수행이 가능한 하드웨어장치 및 그 수행방법 |
EP1870803A4 (en) * | 2005-03-31 | 2008-04-30 | Matsushita Electric Ind Co Ltd | PROCESSOR |
JP3899114B2 (ja) | 2006-04-28 | 2007-03-28 | 松下電器産業株式会社 | プロセッサ |
-
2006
- 2006-12-13 JP JP2006335583A patent/JP4228241B2/ja not_active Expired - Fee Related
-
2007
- 2007-12-04 US US11/987,700 patent/US8635434B2/en not_active Expired - Fee Related
- 2007-12-13 CN CN2007101994391A patent/CN101201736B/zh not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
CN101201736B (zh) | 2011-08-10 |
JP2008146544A (ja) | 2008-06-26 |
US8635434B2 (en) | 2014-01-21 |
US20080148012A1 (en) | 2008-06-19 |
CN101201736A (zh) | 2008-06-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5233694A (en) | Pipelined data processor capable of performing instruction fetch stages of a plurality of instructions simultaneously | |
KR101581177B1 (ko) | 단일 명령 다중 데이터(simd)데이터 처리기에서 확장된 어드레싱 모드들의 제공 | |
JP6849274B2 (ja) | 融合された単一のサイクルのインクリメント−比較−ジャンプを実施するための命令及びロジック | |
JP4228241B2 (ja) | 演算処理装置 | |
JP2816248B2 (ja) | データプロセッサ | |
JPH04109336A (ja) | データ処理装置 | |
KR20100125331A (ko) | X86 가상머신을 지원하는 risc 프로세서 장치 및 방법 | |
JP2834292B2 (ja) | データ・プロセッサ | |
JP3449186B2 (ja) | パイプラインバイパス機能を有するデータ処理装置 | |
JP2011138308A (ja) | プロセッサ、コプロセッサ、情報処理システムおよびそれらにおける制御方法 | |
US6687808B2 (en) | Data processor using indirect register addressing | |
JP6073392B2 (ja) | 命令としてデータ値を評価するシステムおよび方法 | |
JP5326314B2 (ja) | プロセサおよび情報処理装置 | |
JP2008165589A (ja) | 情報処理装置 | |
JP3983482B2 (ja) | 高速ディスプレースメント付きpc相対分岐方式 | |
KR100974401B1 (ko) | 주소 레지스터의 내용을 스와핑하기 위한 방법 및 장치 | |
WO2010067522A1 (ja) | 演算ユニット、プロセッサ及び並列演算方法 | |
JP2556182B2 (ja) | デ−タ処理装置 | |
JP2020502669A (ja) | ベクトル生成命令 | |
JP2504312B2 (ja) | プライオリティエンコ―ダ及びそれを備えたデ―タ処理装置 | |
JP2002024008A (ja) | データ処理装置およびプログラム変換装置 | |
JP4533432B2 (ja) | Tlb相関型分岐予測器及びその使用方法 | |
JP3019818B2 (ja) | データ処理方法 | |
JP3147884B2 (ja) | 記憶装置及び情報処理装置 | |
JP3102399B2 (ja) | データ処理装置及び方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20080314 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20080314 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20080902 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20081014 |
|
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: 20081105 |
|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20081118 |
|
R151 | Written notification of patent or utility model registration |
Ref document number: 4228241 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R151 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20111212 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20121212 Year of fee payment: 4 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20131212 Year of fee payment: 5 |
|
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 |
|
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 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
LAPS | Cancellation because of no payment of annual fees |