JPH07505968A - Cisc型からrisc型命令への変換のためのアライメント並びにデコーディング - Google Patents

Cisc型からrisc型命令への変換のためのアライメント並びにデコーディング

Info

Publication number
JPH07505968A
JPH07505968A JP5517306A JP51730693A JPH07505968A JP H07505968 A JPH07505968 A JP H07505968A JP 5517306 A JP5517306 A JP 5517306A JP 51730693 A JP51730693 A JP 51730693A JP H07505968 A JPH07505968 A JP H07505968A
Authority
JP
Japan
Prior art keywords
instruction
bytes
alignment
byte
instructions
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
Application number
JP5517306A
Other languages
English (en)
Other versions
JP3547052B2 (ja
Inventor
クーン ブレット
芳幸 宮山
ニューエン リートロン
ジョハネス ワン
Original Assignee
トランスメタ コーポレイション
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by トランスメタ コーポレイション filed Critical トランスメタ コーポレイション
Publication of JPH07505968A publication Critical patent/JPH07505968A/ja
Application granted granted Critical
Publication of JP3547052B2 publication Critical patent/JP3547052B2/ja
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30098Register arrangements
    • G06F9/30101Special purpose registers
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30145Instruction analysis, e.g. decoding, instruction word fields
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30145Instruction analysis, e.g. decoding, instruction word fields
    • G06F9/30149Instruction analysis, e.g. decoding, instruction word fields of variable length instructions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30145Instruction analysis, e.g. decoding, instruction word fields
    • G06F9/30149Instruction analysis, e.g. decoding, instruction word fields of variable length instructions
    • G06F9/30152Determining start or end of instruction; determining instruction length
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30145Instruction analysis, e.g. decoding, instruction word fields
    • G06F9/3016Decoding the operand specifier, e.g. specifier format
    • G06F9/30163Decoding the operand specifier, e.g. specifier format with implied specifier, e.g. top of stack
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30145Instruction analysis, e.g. decoding, instruction word fields
    • G06F9/3016Decoding the operand specifier, e.g. specifier format
    • G06F9/30167Decoding the operand specifier, e.g. specifier format of immediate specifier, e.g. constants
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/3017Runtime instruction translation, e.g. macros
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/3017Runtime instruction translation, e.g. macros
    • G06F9/30174Runtime instruction translation, e.g. macros for non-native instruction set, e.g. Javabyte, legacy code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30181Instruction operation extension or modification
    • G06F9/30185Instruction operation extension or modification according to one or more bits in the instruction, e.g. prefix, sub-opcode
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3802Instruction prefetching
    • G06F9/3816Instruction alignment, e.g. cache line crossing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3818Decoding for concurrent execution
    • G06F9/382Pipelined decoding, e.g. using predecoding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3836Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
    • G06F9/3853Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution of compound instructions
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B82NANOTECHNOLOGY
    • B82YSPECIFIC USES OR APPLICATIONS OF NANOSTRUCTURES; MEASUREMENT OR ANALYSIS OF NANOSTRUCTURES; MANUFACTURE OR TREATMENT OF NANOSTRUCTURES
    • B82Y10/00Nanotechnology for information processing, storage or transmission, e.g. quantum computing or single electron logic

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Advance Control (AREA)
  • Executing Machine-Instructions (AREA)

Abstract

(57)【要約】本公報は電子出願前の出願データであるため要約のデータは記録されません。

Description

【発明の詳細な説明】 Cl5C型カらRISC型命令への変換のためのアライメント並びにデコーディ ング ICl5Cto RISCIn5tructionTranslation A lignment and Decoding)阻連■区α弘肛 以下は同−承継人の出願に係る同時係属中の出願である。
米国出願番号07/802.816.1992年12月6日出願(代理人整理番 号5PO24) 、発明の名称r RAMセル及び巡回冗長検査回路搭載ROM (A ROMwith RAM Ce l l and Cycl ic Re dundancy check Ci rcui tl J s米国出願番号0 77817.810.1992年1月8日出願(代理人整理番号5POI5)  、発明の名称「高性能RISC梨マイクロプロセッサ・アーキテクチャ(Hig h Performance RISCMicroprocessorArch  i tecturel 、米国出願番号07/817.809.1992年1 月8日出願(代理人整理番号Sρ02+) 、発明の名称「拡張可能RISC型 マイクロプロセッサ1アーキテクチw (Extensible RISCMi croprocessorArchitecture)J 。
上記の出願の開示は参照することにより本明細書に組み込まれているものとする 。
発旦眩m 1 産】」二J打り1比 本発明は一般的にはスーパースカラ方式のRISC型マイクロプロセブロニ関し 、より具体的には複合命令をRISCベースのハードウェアで実行できるように するためのCl5C型からRISC型へのマイクロプロセッサ命令のアライメン ト・ユニットとデコード・ユニットに関スる。
2、 関Δ目支術− 可変長命令を使用する複合命令上ノド・コンビュータ(CISC型コンピュータ )は全て、命令ストリームの中で発生する各命令の長さを確定するという問題に 直面している。命令は連続するバイトからなるデータとしてメモリの中に詰め込 まれる。従って、命令のアドレスが与えられれば、第1命令の長さがわかってい る場合次の命令の開始アドレスを確定することは可能である。
従来のプロセッサでは、この長さの確定が、実際の各命令実行のような、命令ス トリームの処理における他のステージに比べて、性能に大きく影響することはな い。その結果、かなり111純な回路が典型的に使用されている。一方、スーパ ースカラ型の縮小命令上ノド・コノピユータ(RISCIははるかに高速で命令 をプロセスできるが、複数の命令を並列で実行するためにはるかに高速でメモリ から命令が抽出されなければならない。命令がメモリから抽出される速度によっ て課せられるこの制限要因はフラビン・ボトルネック(Flynn Bottl enecklと呼ばれる。
各命令の長さを確定し、さらにその命令を命令ストリームから引き出すタスクは 命令整列装置(IAulと呼ばれる機能ユニットによって実行される。このプロ 、りには命令の長さを確定するためのデコーダ・ロジックと、命令データをその デコーダ・ロジックに合わせてアライメントするためのシックが含まれなければ ならない。
インテル社(Intel)の80386マイクロプロセソサでは、命令の第1バ イトが命令長全体に関して多くのことを暗示しており、最終の長さを知る前に追 加バイトのチェックが必要になることがある。さらに、追加バイトから他の追加 バイトを特定できることがある。従って、プロセスが本質的に/−ケン/ヤシで あるため、X86系の命令の長さを即時に確定するのは極めて困難である。
1486のプログラマ・リファレンス・ガイド(i486 Programme r’5ReferenceGuidelに112供されている情報に基づき、1 486に採用されているアライメント・ユニットに関して幾つかの結論を引き出 すことができる。1486のIAUは命令の最初の数バイトだけを見るように設 計されている。これらのバイトがその長さを十分には特定していない場合、これ らの初期バイトが抽出されさらにそのプロセスが残りのバイトに対して繰り返さ れる。このプロセスの繰り返しは毎回フル・サイクルを要する。従って、最悪の 場合、命令が完全にアライメントされるには数サイクルかかることがある。
1486のIAUが追加サイクルを要するのはプレフィックス形や拡張型(2バ イト)の演算フードが使われている場合などである。これらの演算コードは共に 1486のプログラムでは共通のものである。その上、複合命令はまたディスブ レースメツ!−及びイミディエト・データから成り立っていることもある。14 86ではこのデータを抽出するのに追加の時間が必要になる。
Cl5C型プロセツサ命令のフォーマット例は第1図に示す通りである。この例 は可変長の1486cIsc皇命令の可能バイトを表している。命令はバイト境 界上のメモリに格納されている。命令の長さは最短で1バイト、最長はプレフィ ックスを入れて15バイトである。命令の全長はPrefixesOpcode 、 ModR/M及びSIBのバイトによって確定される。
元旦B曙1要工 本発明は、Intel 80x86マイクロブロセノサのような複合命令セット ・コノピユータCCI SCI、またはその他のCl5C型プロセツサをエミユ レートするように設計されたスーパースカラ型の縮小命令セット・コンビコータ (RISC)・プロセッサを有するマイクロフード、すのサブンステム並びに方 法である。
本発明におけるCl5C型からRISC型への変換(translationl 処理には2つの基本的なステップがある。Cl5C型命令は先ず命令ストリーム から抽出され、そして次にRISC型プロセッサによって処理され得るナノ命令 を生成するためにデコードされなければならない。これらのステップはそれぞれ 命令アライメント・ユニット[IAU)と命令デコード・ユニット(IDUIに よって実行される。
IAuは命令データ上の古い方から23番目までのバイトを調べることによって 命令ストリームから個々のCl5C型命令を抽出する働きをする。IAUは命令 FIFOのボトム・ラインにあるバイトのいずれから始まって継続する8バイト を抽出する。各クロック・フェーズの間に、IAuは現在の命令の長さを確定し 、この情報を使って2個の/フタを制御してその現在の命令をソフトアウトする のであるが、そのストリームには次に来る続きの命令が残っている。IAUは、 その結果、サイクル当たり2命令というピーク・レートで、各クロック・フェー ズの間にアライメントされた命令を出力する。このベスト・ケースの性能の例外 については以下の項2.0と2.1で説明する。
Cl5C型命令がメモリから抽出された後、ICUがこれらのアライメントされ た命令をナノ命令と呼ばれるRISC型命令と同じノーケノスに変換する働きを する。IDUはアライメントされた各命令はIALJからの出力であるとみなし て、必要なナノ命令の数やタイプ、データ・オペランドのサイズ、さらにアライ メントされた命令を完了するのにメモリ・アクセスが必要か否かなどといった様 々な要因を確定するためにその命令をデコードする。単純な命令は直接デコーダ ・I\−ドウエアによってナノ命令に変換されるのに対し、より複雑なCl5C 型命令はマイクロフード・ルーチンと呼ばれる特殊命令セットのサブルーチンに よってエミュレートされ、そのサブルーチンは次にナノ命令にデコードされる。
この情報は、2つの命令につき完全な1サイクルで収集され、その次に命令バケ ットを形成すべく一つにまとめられるが、その中には両方のソース命令に対応す るナノ命令が含まれている。このバケットは次にRISC型プロセッサによる実 行のため命令実行ユニ、 l−(IELIIに転送される。ナノ命令バケットの 実行は本発明の適用範囲外である。
本発明の前記、ならびにそれ以外の特徴並びに利点については、添付の図面に示 すように、以下の本発明の好適な実施例のより詳細な説明から明らかになるであ ろう。
LH!! 本発明は添付の図面を参考にすることにより、より良く理解されることであろう 。
第1図は従来のCl5C型命令のデータ構造フォーマットを示す。
第2図は本発明の命令ブリフェッチ・バッファのブロック図を示す。
第3図は本発明の命令アライメント・ユニットのブロック図を示す。
第4図は本発明のIAUの命令抽出並びにアライメント方法を表す代表的なフロ ーチャートを示す。
第5図は第3図のブロック図並びに第4図のフローチャートに関連する簡略24 577図を示す。
第6図は本発明の5TAC;にのプロIり図である。
第7A図は本発明の次命令検出器(NIDIのブロック図である。
第7B図は本発明の残存次命令検出器(RNIDIのブロック図である。
第8図は本発明のイミディエト・データ及びディスプレースソフト検出器(ID DD)のブロック図である。
第9図は本発明のプレフィックス検出器(po)のブロック図である。
第10図は本発明のプレフィックス数(PRFX N(]デコーダのプロ/り図 である。
第11図は本発明のナノ命令バケットのブロック図である。
第12図は本発明の命令デコード・ユニット(IOU)の代表的なブロック図で ある。
第13A〜13C,図は本発明の命令ビット・マツプを示す。
第14図は本発明のIDDDの命令デコーダのセク/lIンの一例を示すブロッ ク図である。
第15図は第14図に示した命令デコーダのデコーダ一式の代表的なブロック並 びにロジック図を表わす。
第16A〜16C図は本発明のデコードFIFOの概念的なプロ・ツタ図を示す 。
第17図は本発明のナノ命令のフィールド・フォーマツトの例を示す。
且」笈 好適な実施例の詳細な説明 7 +、o+jlフェッチ・ユニット 8 2.0命令アライメノト・ユニットの概略 92.1命令アライメント・ユニッ トのブロック図 1130命令デコード・ユニットの概説 323.1 マイク ロコード・ディスバッチ・ロジック 3432メールボ!クス 37 3.3ナノ命令フオーマツト 38 3.4特殊命令 39 3.5命令デコード・ユニットのブロック図 414、 Oテコ−Fサレタ命令 PIFO52?−、=、 ! ?−!ロ 本項で説明する基本的な概念については以下の参考文献により詳細に記述されて いる:r 、Mike Johnson著、ニューシャーシー州、イングルウッドクリフ所在のPren tice−HgI2社より1991年出版。「 −1John L、 Henn essy他著、カリフォルニア州、サンマチオ所在のMorganKaufma nnPublishers社より1990年出版リニア州、サンマチオ所在のI ntel Corporationより1990年発行でオーダ番号はそれぞれ 240486及び240552゜これらの出版物の開示は参考することにより本 明細書に組み込まれているものとする。
10IA ・ユニ 本発明の命令フェッチ・ユニット(IFUIは命令メモリや、命令キャノ/二等 の中に格納された命令ストリームから命令バイトをフェッチし、さらにその命令 バイトを実行のためにデコーダ部に供給するために使用される。命令アライメン ト・ユニットによってアライメントされるべき命令は従ってIFLJから供給さ れる。第2図に示すのはそのIFU内の3個の命令ブリフェッチ・バッファ20 0のブロック図であり、それは主命令バッファ(MBuFl 204.エミュレ ーシヨン命令バッファFEBUFI 202、及び目標命令バッファ(TBUF I 206から成っている。
そのブリフェッチ命令バッファは命令キャyンユから128ビ1ト(16バイト )の命令ストリームを単一サイクルでロードすることができる。このデータはI AUによって使用されるべく3個のバッファのうちの1個に保持される。
通常のプログラム実行中、MBUF 202は命令バイトをIALIに供給する ために使用される。条件付きの制御フロー(即ち、条件付き分岐命令)に遭遇す ると、MBLJF202からの実行が続行している間、そのブランチのターゲッ ト・アドレスに対応する命令はTBUF206に格納される。一度ブランチの決 定が下されると、分岐しない場合はTBUF 206の廃棄、分岐する場合には TBLJF 206のMBLJFへの転送、のいずれかが行なわれる。いずれの 場合も、MBUFからの実行は続行する。
EBLIF 204の動作は多少異なる。エミュレーション・モードに入ると、 エミコレーノコン命令かもしくは例外によって、命令のフェノチングと実行がE BUF204に転送される。(エミュレーション・モード及び例外処理について は共に以下に詳細に説明する。)プロセッサがエミュレーシヨン・モードになっ ている限り、実行はEBUF204から続行する。エミュレー71Iン・ルーチ ンが終わると、実行はMBLJF204に残っている命令データから続けられる 。これにより、エミニレー/11ノ・ルーチン実行後、主命令データを再度フェ ッチする必要がな(な2・0 − ゛ ・ユニ 本発明との組み合わせで命令アライメント・ユニットは、スーパースカラ型プロ セッサの卓越したサイクル当たりの命令スループットを用いることによって、普 通のケースを高速処理にするRISC戦略を用いる。
本発明において、「アライメントする」ζいう用語は、後でデコードするために 成る命令のバイトを命令ストリームで隣接するバイトと区別できるように位置付 けることを意味する。IAuは、現在の命令のバイト数を確定することによって 、現在の命令の終わりを次の命令の始まりと区別する。IALJは次に、IDU に入れられる最下位のバイトが現在の命令の第1バイトとなるように、現在の命 令をアライメントする。バイトはいろいろ異なる順序でIDLIに供給すること もできる。
本発明のTAUのサブ/ステムはあらゆるクロック・レートにおいてサイクル当 たり2命令の速度でほとんどの一般的な命令をアライメントすることができ、縮 小クロック速度でこれと同じレートでその他のほとんどの命令をアライメントす ることができる。プレフィックスを含む命令にアライメントに半サイクル余計に 必要である。イミディエト・データ及びディスプレースソフトのフィールドは並 列で抽出されるために余分な時間は不要である。
さらに、TAUのアライメント・タイムは最悪のケースで1命令当たりわずか2 0サイクルであり、従来のCl5C型プロセツサの一般的な命令の多くをアライ メントするのに要する時間より短い。命令が一つ以上のプレフィックス(アライ メントに要するサイクル合34の半分)を有し、その命令が長さの確定に完全に 1サイクルを要する七ノドからのもので、且つその命令(プレフィックスを含ま ない)の長さが8バイトより長い場合(半サイクル余計に必要だから、結果とし て合計で完全な2サイクルになる)には最悪のケースが起こる。
幾つかの構造上の特徴によってこうした性能が実現される。第一に、IAUは、 アライメント回路中のフェーズ・ラッチとマルチプレクサを交互に使用すること によりクロックのフェーズ毎に完全なアライメント操作を実行するように設計さ れている。第二に、デコード・ロジックは各命令の長さを確定するために考慮に 入れなければならないビット数に基づいてCl5C型命令を2つのカテゴリーに 分ける。即ち、少数ピットで指定された長さの命令は単一フェーズ(半サイクル )でアライメントされるのに対し、他の命令は典型的に、さらに1クロツク・サ イクルが必要である。最後に、IAuは命令ストリームから一回だけのソフトで 8バイトまでを抽出できる。これにより、長い命令(1486では15バイトま で)を数少ないシフト命令でアライメントすることが可能になり、且つほとんど の命令が一回だけの/フトでアライメントできるようになる。
高速且つ正確にCtSC型命令をデコードするために以下のタスクがIALJに よって実行される。
プレフィックス・バイトの存在とその長さを検出する。
演算コード、ModR/M及び5IB(scale、 1ndex、 base )のバイトを分離する。
命令の長さく次の命令の記憶位置を示す)を検出する。
以下の情報を命令デコード・ユニ、 ) (IDLJIに送るニー 演算コード 、即ち8ビツトに任意の拡張3ビツトを足したもの。2バイトの演算では、第1 バイトは常にOF hexだから、2番目のバイトが演算フードとして送られる 。
ModR/Mバイト、SIBバイト、ディスプレースソフト及びイミディエト・ データ。
−プレフィックス数及びタイプに関する情報。
演算コード・バイトはその命令によって実行された演算を指定する。
ModR/Mバイトは、命令がメモリのオペランドを参照する場合に用いられる アドレス形式を指定する。ModR/Mバイトはまた2番目のアドレソンング・ バイト、即ち、5IB(scale、 1ndex、 baselバイトを参照 することもでき、そのSIBバイトはアドレノ/フグ形式を十分に指定すること が必要とすることがある。
21 八 −/ −ユニ 一口 IAUのブロック図は第3図に示す通りである。この図は2つの部分、即ち、メ インデータバス302(破線で囲んだ部分)とプレデコーダ304 (M線で囲 んだ部分)とに分れる。命令の7フテイングや抽出はメインデータバス302で 起こるのに′i1シ、長さの確定やデータバスの制御はプレデコーダ304によ って処理される。
メインデータバス302は幾つかの7フタ、ラッチ及びマルチプレクサから成り 立っている。抽出/フタ306はバイトで構成された命令データをIFUから受 け取る。IFlob−バス1127:OlとIFIlb−バス(ss : 01 の2本のバス(概ね303で示した)はIFUの命令データ出力を表している。
IFLJはIAUからの要求に答えてアドバンス・バッファ・リクエスト(AD VBUFREQIライン308上でこの9 令情Nを更新する。ADVBLIF REQ信号の生成については以下に説明する。現在の命令に9当する8バイトの データは抽出/フタから出力され且つバス307上の整列シフタ310に送られ る。整列/フタは合計で16バイトの命令データを保持し且つ)S−ズ毎に8バ イトまで/フ卜することができる。/フトアウトによってプレフィックスが検出 される場合、命令からプレフィックスを切り離すために整列7フタが使用される 。整列シフタはまた、命令をより低位のバイトにアライメントし、さらにアライ メント後にその命令全体をシフトアウトするために使用される。
その8バイトはバス309を介してイミディエト・データ/ツク(IMMンフタ 312)とディスプレースソフト・/フタ(DISP/フタ3+4)にも送られ る。IMMンフタ312は現在の命令からイミディエト・データを抽出し、DI SP/フタ314はディスプレースソフト・データを抽出する。これら2個のシ フタへのデータはアライメントされた命令との同期を維持するためにΩサイクル 遅延素子316によって遅延させられる。
整列/フタ310はバス311上のアライメントされた次の命令を2個の整列I Rクラッチ18または320へ出力する。これらのラッチはシステム・クロック の対向フェーズ上で動作する。それによってサイクル毎に2つの命令がラッチさ れることになる。整列−IRクラッチ18及び320はアライメントされた命令 を2本の出力バス321−ヒに出力する。そのラッチの1個が新規の値を受け取 るフェーズ期間中に、他のラッチの出力(アライメントされた現在の命令)はマ ルチプレクサiMUX 322]によって選択される。MUX 322はそのア ライメントされた現在の命令をアライメントされた命令バス323に出力する。
出力323は[AUの一次出力である。この出力は、現在の命令の長さを確定す るためにプレデコーダ304によって使用され、且つ次の命令が抽出されるデー タとして整列シフタ310にフィードバックされる。アライメントされた現在の 命令はバス325、スタック334、さらに先のバス336を介して整列/フタ 310にフィードバックされる。バス336はアライメントされた現在の命令に 関する情報をΩサイクル・データ遅延316にも送る。
IMM/フタ312とDISP/フタ314はそれぞれイミディエト・データと ディスプレースソフト・データをシフトすることができる。何故ならば、それら は/フトするのに合計16バイトが必要だがらである。Ωサイクル・データ遅延 316は/フタへの命令バイトを1本のバス上に出力する。IMM/フタ312 は現在の命令にχj応するイミディエト・データをイミディエト・データバス3 40上に出力する。DISP/フタ314は現在の命令に対応するディスプレー スソフト・データをディスプレースソフト・データバス342上に出力する。
プレデコーダ304は、次命令検出器[NID) 324、イミディエト・デー タ及びディスプレースソフト検出器(IDDD) 326、及びプレフィックス 検出器CPDI 328の3つのデコーダ・ブロックから成り立っている。NI DとPDは整列/フタ及び抽出/フタを制御し、IDDD旧MM/フタ312と DISP/フタ314を制御する。
PD 328は1つの命令中のプレフィックスの存在を検出するように設工1さ れている。PD32Bは存在するプレフィックス数を確定し、且つ次の半サイク ルで命令ストリームからプレフィックスを抽出するために、ライン331、MU X330、及びライン333を介して整列/フタ310とカウンタシフタ308 に/フト制御信号を供給する。さらに、PD 328はプレフィックス自体をデ コードしてこのプレフィックス情報をIDLJへの出力ライン329上に供給す る。
ρD328の基本アーキテクチャは4個の同一の検出装置(プレフィックスを4 つまで検出するため)と、プレフィックス自体をデコードするための第2ブロツ クのロノノクとで構成されている。Cl5C型フオーマツトはプレフィックス発 生の順序を定義するが、本発明では初めの4バイト位置のそれぞれにおける全て のプレフィックスの(j在を検査する。さらに、デコーダの減速要求を利用すべ く、プレフィックスの存在を検出する機能とプレフィックスをデコードする機能 は別々になっている。PD 328のアーキテクチャについては以下にさらに詳 細に述べる。
IDDD 326は各命令からイミディエト・データとディスプレースソフト・ データを抽出するように設計されている。IDDDはそれらの存在に係わりなく 常にこの2つのフィールドの抽出を試みる。IDDD 326はIMM/フタ3 12とDIS/フタ314を1χIのライン344と346上でそれぞれ制御す る。IDuはアライメントされた命令をプロセスするのに半サイクルを要するが 、イミディエト・データ及びディスプレースソフト・データには無用のものであ る。従って、イミディエト・データ及びディスプレースメ/ト・データは、ID DD326がノット量の計算にもっと時間をかけられるようにするために、Ωサ イクル・データ遅延316によって遅延させられる。何故ならば、同じフェーズ でデコードと/フトを実行するNID 324と異なり、/フトはその次にくる フェーズで起こるからである。
NID324はプレデコーダの心臓部である。一度プレフィノクスが取り除かれ ると、NID324は各命令の長さを確定する。NID324は制御ライン 3 25、MUX330、さらにライン333を介して整列/フタ310とカウンタ /フタ308を制御する。NIDは2つのサブプロ、り、サブセット次命令検出 器+5NID7021と、さらに残存次命令検出器(RNID 7041とから 成り立っており、RNID 704については第7A・78図との関連において 説明する。
その名が示すように、5NID702はCl5C型命令セ、トのサブセットの長 さを確定する。サブセット内の命令は5NIDによってサイクル当たり2命令の 割合でアライメントされる。
RNID 704は残る全ての命令の長さを確定し、さらにあと半サイクルを必 要とし、それによってデコード時間合計は完全な1サイクルになる。サブセット に命令が入っているかどうかの確定は5NIDによってなされ、さらにこの信号 は5NIDかRNIDかいずれかの出力を選択するためにNID内で使用される 。
新規の命令がアライメントされている場合、初めはサブセットの中に存在してい ると仮定され、それによって5NIDの出方が選択される。5NIDがその命令 はRNIDによって処理されるべきものであると(この同じ半サイクル中に)判 定した場合、信号がアサートされ、IAuが現在の命令をループし、それをさら に半サイクルの間保持する。この2番目の半サイクルの間に、RNIDの出力が 選択され、且つ命令が適正にアライメントされる。
NIDのこのアーキテクチャには幾つかの利点がある。その一つは先に既に述べ たが、サイクル時間が十分に長ければ、5NID −RNID間の選択が1回の 半サイクルの間に実行でき、それによって全ての命令が単一フェーズ(プレフィ ックスや8バイトより長い命令を抽出する時間は含まない)内にアライメントさ れるようになることである。これにより、ハードウェアを追加せずに低サイクル ・レートでサイクル当たりの性能を向上させることができる。
第2の利点は、選択信号をアライメント取消(3号として使用できることである 。何故ならば、選択信号はIALIが5NID/フト出力を無視し、そして、さ らに半サイクルの間現在の命令を保持するからである。特定命令の組み合わせま たは長さを予測し、続いてその予測が正しくなければ取消信号を生成するように 5NIDを設計することができる。例えば、この方法は一回の半サイクルで複数 の命令をアライメントするために使用することができ、これによって性能がさら に向上する。
IAUもカウンタ/フタ332から成り立っている。カウンタ/フタ332はラ イ/335を介して抽出/フタ306の/フトmを確定し、さらにADVBUF REQライノ308を用いてIFUに追加のCl5C型命令バイトを要求するた めに使用される。
カウンタ/フタ332の機能については次のIALIの動作フローチャートとタ イミング図の例を検討することにより良く理解されるであろう。
第4図は本発明のIALIによって実行される命令バイト抽出とアライメントの 概略フローチャートである。ステップ402に示すように、新規のデータがIF LJのMBuF204 (BUCKET #Oと呼ばれる)の最低ライン205 に入力されると、抽出/フタ306は第1命令から始まる8バイトを抽出する。
ステップ404に示すように、その8命令バイトは整列/フタ310をバイパス して整列−IRクラッチ18及び320に渡される。ステップ406に示すよう に、IAtJは次に整列−IRラッチ中にアライメントされた命令を保持しなが ら次のクロック・フェーズがくるのを待つ。
次のクロック・フェーズの間に、IAUはIDLI、 5TACK 334、I DDD326、NID324、PD 328及びΩサイクル・データ遅延316 にアライメントされた命令を出力する。イミディエト・データとディスプレース ソフトに関する情報は次にバス340と342上のそれぞれのICUへ出力され る。このデータは、もし存在していたら、その前のフェーズでアライメントされ た命令に対応する。これらのオベレー/gノは概ね第4図のステップ408に示 す通りである。
プレフィックスが存在しているかを確定するために、次にIAUによって条件文 409が入力される。この確定はPD(プレフィックスデコーダ)328によっ て行なわれる。条件文409を出る矢印rYesjで示すように、PDによって 1つ以上のプレフィックスが検出されれば、そのプロセスはステップ410へと 進み、そこてIAUはMIJX 330でPDの出力を選択する。ステップ41 2に示すように、そのデコードされたプレフィックス情報は次に対応するアライ メントされた命令とともに次のフェーズてIDUに送られるべくラッチされる。
条件文409を出る矢印1N01で示すように、プレフィックス命令バイトが検 出されなければ、ステ、ブ414に示すようにMUX 330でNID 324 の出力が選択される。
一度ステップ412または414が完了すれば、ブロック416に示すように、 抽出/フタ306を制御して、整列/フタ310とΩサイクル・データ遅延31 6に次の8バイトの命令データを供給するためにカウンタ/フタ332の現在の 出力が使用される。次に、IAuはMIJX330の出力をソフトーAと呼ばれ る変数として用いる。この変数は整列/フタ310を制御して次の命令をアライ メントするために用いられる。/フトーAは、次のフェーズの間に用いるシフト 量を計算するために、現在の抽出/フタの/フトffi (BUF−カウントと 呼ばれる)にも加えられる。この加算は、ステップ408に示すように、カウン タ/フタ308において行なわれる。
IAUによって行なわれる次の操作のステップは、ステップ420に示すように 、整列−IRラッチ内の整列シフタの出力をラッチすることである。ステップ4 22に示すように、IDDD326内のイミディエト・データとディスプレース ソフト・データの位置が計算され、さらにこのシフト量がΩサイクルだけ遅延さ せられる。次に、ステップ424に示すように、IAuはその前の半サイクルの 間に計算されたノット量を用い、現在IMMンフタ322とDISP/フタ31 4に入力中のデータをシフトする。最後に、このプロセスをステップ1106か ら始めて繰り返して行ない、次のクロック・フェーズを待つ。408から424 までのステップが命令ストリーム中に残存する命令バイトに対して繰り返される 。
第5図に示すのは第3図のIAUに関連するタイミング図である。第5図の上部 に2つの命令パケットが表示されている。バケット−#0及びバケット−#1と ラベルの付いたこれら2つの命令バケットはそれぞれ第3図に示したIFU ( 図示していない命令メモリから)によってIAuに供給される16命令バイトか ら成り立っている。命令のアライメントはいつもバケット−#0の右(即ち、一 番下のバケット)から行なわれる。本実施例においては、バケット−#0及びバ ケット−#1がIFUのM8UF 204の一番下の2つのバケットである。他 の配列も可能である。
本実施例において、IAUに送られた最初の3命令はOPO,OPI、OR3で 、長さはそれぞれ5バイト、3バイト、11バイトである。命令OP2の最初の 8バイトだけがバケット−#1に収まることに注意すること。残る3バイトはバ ケット−#1の始まりにラップされる。この実施例を簡素化するために、これら の3命令にはプレフィックス・バイトがないものと仮定する。プレフィックスが 検出されれば、1命令のアライメントのために1フエーズの追加が必要になる。
命令はバケットのどの位置からでも開始できる。命令は一番下のパケットのいず れかの位置から始まって一度に8バイトまで抽出される。IAuは本実施例にお けるOR3のような、2番目のバケットに入り込んでいる命令に対処するため、 2つのバケットを調べる。
このタイミング図におけるトレース「1」は2つのシステム・クロックの一つ、 CLKOである。本実施例において、この/ステム・クロックは半サイクルが6 ナノ秒になっている。別の/ステム・クロックC,LKIと対比して逆のフェー ズをaするCLKOはTOで上がりToで下がる。その場合、TOはCLに1の 立ち上がりエツジであり、TOがCLにOの立ち上がり二ノシである。説明をわ かりやすくするために第5図において主な3つのクロック・フェーズには−L  j、jのラベルを付けである。
このタイミング図におけるトレースのr2Jと「3」は入力バスIFIIBとI  F I OB−1=の命令データを表している。502に示すように、新規の バケット−#0はコが始まるところのIFIOB上で使用可能になる。少し後に 、OPO(B10 、7−0)で始まる最初の8バイトが504のところで抽出 シフタ306によって抽出される。
バケット−#0バイト7−0は有効であることが示されている。抽出7フタのタ イミングはトレース「4」に示す通りである。
命令ストリームのCl5C梨からRISC型へのデコーディングが始まると、カ ウンタ/フタ332はバケyト、−#Oから最初の8バイトを抽出するために抽 出/フタ306を制御する。カウンタ/フタは命令のアライメントの進行につれ てバケットからさらにバイトをシフトし且つ抽出するように抽出/フタに信号を 送る。バケット−#0から命令バイトが空になると、パケノトノ1の内容がバケ ット−#0の中にシフトされ、バケyト−nは命令ストリームから補充される。
最初の8バイト抽出後、抽出シフタは、命令長、プレフィックス長並びに先のシ フトの情報に基づいて、ライン335上のカラ/り/フタの制御のもとバイトを 抽出してソフトする。
しかしながら、本実施例では、カウンタ/フタは第1命令をアライメントすべく ゼロにシフトするように抽出/フタに信号を送る。よって、抽出シフタは第1命 令の最初の8バイトを整列/フタ310にシフトアウトする。整列シフタの信号 のタイミングはタイミング図のトレース「5」に示す通りである。これらの8バ イトは参照番号506で示した−1の時間帯の間整列ンフタで有効になる。
バケット−#Oの最初の8バイトは整列シフタをバイパスして2個の整列−IR クラッチ18または320(第3図のトレース「6」と「7」に示すように)の 中に格納される。クロック信号CLに0とCLに1のタイミングに基づいて、こ れらの整列IRラッチは交互に命令バイトを受け取る。整列−IRO318はク ロック信号CLKOのラッチで、即ちクロック信号CLKOがハイの時ラッチさ れる。整列−IRI320はクロック信号CLKIのラッチで、クロック信号C LKOがハイの時ラッチする。−1の終わり寄りの参照番号508で示すように 、最初の8バイトは第1クロツク信号0LKOのフェーズ終了前に整列−IRQ にて有効になる。
MUX 322はその前のフェーズでラッチを実行したラッチを選択する。本実 施例では、従って、MUX322が2番目の完全フェーズ、−2の間にOPOの 最初の8バイトを出力する。
その次に、oPOの最初の8バイトはNID 324とスタック334に流れる 。NID324は、第1命令が5バイト長であることを検出してこの情報をライ /325、MUX330、さらにライフ333経由で整列/フタ及びカウンタ/ フタに送り返す。上述したように、同時にM?71の8バイトはスタックを通っ て流れ、整列7フタにフィードバックされる。その結果、整列/フタは命令バイ トを抽出/フタからと、そして間接的に自分自身から受け取ることになる。これ はサイクル毎に最大8バイトをソフトするためには整列/フタには16バイトの 入力が必要だからである。整列/フタがXバイトを右にシフトすると、最下位の Xバイトを廃棄して次の8バイトのデータをう、チの318と320に渡す。こ の場合、スタック334は整列/フタ310にバイト0〜7を供給する。
整列/フタを取り囲むバイパス336は抽出/フタが命令ストリームから第1命 令を抽出する初期のケースで使われる。プレフィックス・バイトを除いて、第1 命令かアライメントされるため、整列/フタが初期のケースでソフトを行なう必 要はない。
タイミング図の−2の期間中、抽出/フタはバケット−#0のバイト15〜8の 計・イトをソフトアウトする。第5図の510を参照。これらのバイトは整列シ フタに送られるが、その整列/フタは今や合計で16の処理対象の続きバイトを 有している。整列/フタは抽出/フタの出力並びに−2期間中のラッチ318と 320の有効出力を調べる。
−2の終わり近くで、整列/フタはNIDからの信号に基づき、パケット#0の バイト12〜5を出力にシフトする。そのNIDからの信号は整列/フタに5バ イト右にソフトするように指示するものである。それによって命令OPOに対応 する最下位の5バイトが廃棄される。タイミング図のトレース「8」のソフト− 5−バイト信号512を参照。残る命令データの8バイト、即ちバイト12〜5 はその後整列/フタを通って流れる。バイト5は次の命令OPIの第1バイトで あることに注意すること。
カウンタ/フタ332は次に抽出/フタ306の8バイトをシフトする。何故な らば、最初の8バイトは今や整列−IRクラッチら入手でき、よって次のバイト が必要だからである。フェーズ3が始まると、カウンタ/フタは先のフェーズで 整列/フタ310によってソフトアウトされたバイト数だけソフト量を増やすよ うに抽出/フタに信号を送る。従ってカウンタ/フタは先の抽出/フタの771 mを格納し、さらにこの値に整列シフタのソフト量を加算するためのロジックが ら成り立っていなければならない。
整列/フタ用に新規の値がでてくる毎に、カウンタ/フタはその量を旧シフト量 に加算する。本実施例においては、−2の期間中カウンタ/フタは8バイトをシ フトしたことになる。従って、−3の期間中、カウンタ/フタは抽出シックに8 +5または13バイトをソフトするように指示しなければならない。抽出シック によるバイト出力はバイト20〜13である。整列−IRクラッチ−3の期間中 バイト12−5を出力し、よってバイト20〜5が整列/フタで使用可能になる ことに注意のこと。
−3の期間中、抽出シフタはバイト20〜13を出力する。しかしながら、パケ ット−#0はバイト15〜0しか含有していないため、バイト20〜16はバケ ット−#1から取ってこなければならない。タイミング図の514に示すように 、バケ・ノド−#1は−3の始まりで有効になる。516に示すように、抽出シ フタは続いてパケット−#1のバイト4〜Oをソフトし、さらにバケット−#O のバイト15〜13をシフトする。この時点でパケット−s+が有効でなければ 、IAIJは有効になるまで待たなければならない。
上記のごとく、ソフト−5−バイト信号が−2の期間中NIDによって生成され た。518に示すように、この信号に従い、パケット−noのバイト12〜5は 整列/フタによってシフトアウトされ、さらに520に示すように、その後まも なく整列JRIの中にラッチされる。
バイト12〜5は−3の始まりにMUX322によってスタック334とNID 324に送られる。スタックは336に示すようにバイト12−5を整列シフタ にフィードバックし、さらに522のトレース「9」に示すように、NIDはO Plの長さが3バイトであると確定して、−3の期間中の後半に/スト−3−バ イト信号を出力する。
整列/フタは3バイトf15−81をシフトし、さらにこの量がカランタンフタ に加算される。
」−述のプロセスがさらに繰り返される。一つの命令がバヶy)−#Qを越える (即ち、バケ、ト−noが全部使われている)と、バケット−#1がバヶノトノ 0になり、そして新規のバヶy)、j+Iがその後有効になる。
タイミング図のトレース「1o」は命令ストリームからのバイト抽出のタイミン グを示している。Buf−カウ/ト#0ブロックは格納された抽出/フト量を表 している。フJ−ズ毎にアライメントされたソフト量がBuf−カウント#0に 加算され、その結果が次のフェーズで抽出/フトmになる(カラ/ターシフトと ラベルのついたブロックを参照)。
タイミング図のトレース「11」は命令アライメントのタイミングを示す。
IRツノチー#0とIRツノチー#1のラベルのついたブロックは対応する整列 −IRラッチ内の命令が有効になる期間を表す。MtJXlのラベルが付いた小 さなブロックはMLIX 322がその佇効アライソフト・ラッチを選択し始め る時を表している。
MUX 2のラベルが付いた小さなブロックはMUX 330がN+0324が 確定した/フト徹を選択し始める時を表す。最後に、整列−/フトのラベルが付 いたブロックは整列/フタが命令を出方し始める時を表している。
プレフィックスは命令が7ライメントされるのと同じ技法を使って抽出され71  f)<、MUX 330i1NID 32417)出力”C’liなく PD  32877)出力を選ぶ。
スタック334の一部分のブロック図は第6図に示す通りである。このスタック は並列に配置された、64個の1ビツト・スタックから成り立っている。1ビツ ト・スタノ′り600はそれぞれ2個のう、チロ02及び604、さらに3人力 のMLIX606とから成っている。アライメントされた命令はラッチ並びにI Nのラベルが付いたバスら07上のMUXへ人力される。この2個のう、チのロ ーディングはいずれかのクロック・フェーズで個別に行なわれる。さらに、MU X 606はいずれのラッチの出力を選択するが、またはINデータをバイパス して直接OUTのラベルが付いた出力610に送るがするために3本のMuX制 御ライン608を有している。
IAUは定期的に別々の命令ストリームに転送することができる。スタックによ ってIAUがMUX 322がらの8バイトの命令データ・セット2組を格納で きるようになる。この特徴は一般的にCl5C型命令エミユレー勾ンで使われる ものである。IAuが複雑なCl5C型命令のエミュレーション用のマイクロコ ード・ルーチノを処理するために分岐しなければならない時、crsc型命令の エミュレーンヨノが文子すればIAUの状朝が格納され、再開始される。
Ωサイクル・データ遅延316はイミディエト・データとディスプレースノット の情報を遅らせるために使用される。同じ半サイクル期間中に命令長とシフトを 確定するのではなく、/フタの前にIALIに遅延を入れることによって次のフ ェーズでノットを行なうためにイミディエト・データとディスプレースノット・ ロジックが送られる。これらの動作がそのサイクルに渡って広げられるがら、タ イミング要件をそのロジックに合せるのが容易になる。ICCDブロック326 は[MMノフフタ12とDISPンフタ314を制御して命令がらイミディエト ・データ並びにディスプレースメ/ト・データを抽出する。例えば、最初の3バ イトの命令が演算フードでそれに4バイトのディスプレースノット並びに4バイ トのイミディエト・データが続いていれば、シフタは適切なバイトをシフトアウ トすることができるようになる。
/フタの312ど314は、実際のデータ・サイズが8.16、或いは32ビツ トであろうが関係なく常に32ビツトを出力し、それには32ビツト出カの低位 ビットの順に適正アライメントされたイミディエト・データ及びディスプレース ノット・データが含まれている。lDuはそのイミディエト・データ及びディス プレースメ/ト・データが有効であるか確定し、もし有効ならば、どれだけ有効 データがあるかを確定する。
プレフィックス、イミディエト・データ、ディスプレースノット・データの長さ の確定並びに命令の実際の長さの確定はアライメントされ、さらにデコードされ ている実際の(、ISO!!!’命令セットの機能の一つである。当業者はCl 5C型命令七ノド自体、メーカーのユーザ・マニュアル、もしくはその他一般的 な参考資料を調査することによってこうした情報を得ることができる。当業者は これをどのように行なうか、また上述のIAUサブ/ステムを実現するために情 報をランダム・ロジ/りにどのように転換するか、以下に述べるICUサブ7ス テムをどのように実現するか、さらにデータの流れ(月owlを制御するために 使われる制御ロジック並びに制御信号をどのように生成するかについて容易に理 解するだろう。
さらに、一度そうしたランダム・ロジックが生成されたら、市販のエンジニアリ ング・ノットウェア・アプリケ−/IIン(例えば、カリフォルニア州すンノセ 市所在のCadenceDesignSystems社製のVer百〇Q)を使 ってロジックを検証することができるし、そうしたアプリケーンコンは制御信号 や関連するランダム・ロジックのタイミングや生成を定義するのに役に立つ。ゲ ートやセルのレイアウトを生成して、そうした機能ブロックや制御ロジックの実 現を最適化するために(也の市販のエンジニアリング・ノットウェア・アプリケ −INンを用いることができる。
1486の命令セットは、一つの命令の中で一緒に使われるとき順序が定義され ている11個のプレフィックスをサポートしている。そのフォーマットはプレフ ィックスを単一命令に4個まで含めるように定義する。従って、本発明のプレフ ィックス検出器328は同一のプレフィックス検出回路4個を備えている。各々 の回路がその11個のプレフィックス・コードのどれかを探索する。プレフィッ クス検出器に渡される最初の4バイトが評価され、さらに存在するプレフィック ス数の合計を確定するために4個のプレフィックス検出回路の出力が一つにまと められる。その結果はMLIX 330に渡される/フト量として使用される。
NIDのブロック図を第7図に示す。NIDについての以下の説明は1486命 令のアライメント特有のものである。他のCl5C型命令のアライメントは異な るNIDアー手テタテクチャいるのが適切である。以下に述べる技法は従って当 業者にとって一つのガイドとはなるが、それによって本発明の適用範囲を限定す るものと考えられるべきではない。
一つの命令の長さを確定するには4バイトだけあればよい。(上記のごとく、そ の4バイトは2つの演算コードバイトと、1つの任意のModR/Mバイト並び に1つのSIRバイトから成り立っている。)第7A図に示すのはMUX 32 2から受け取った命令の最初の4バイトを表す4バイト(32ビツト)・バス7 01である。その最初の2バイトはバス703上のSNr[)702に送られる 。5NIDは、定義上、その最初の2バイトに基づいて識別される命令の最初の サブセットの長さを確定する。5NIDは半サイクルで命令のこのサブセットの 長さを確定できる。サブセット命令の長さはバス705上の5NIDによって出 力される。バスの幅は5NIDによって検出された命令バイトの最大数に相当す る。5NIDはまたModR/Mバイトがその命令の中にあるかどうかを知らせ るために1ビツトのMOD検出 (MOD−DETI出カライン707を有して いる。さらに、5NIDは命令がサブセット形式でない制御ロジ・ツクを合図す るために1ビツトのNID−待ちライン709を有している(即ち、代わりにR NIDの出力を用いる)。
従ってfALIは、NID−待ちが真の場合、命令をデコードするためにRNI Dを半サイクル待たなければならない。
5NIDによってデコードされた命令のサブセットは最低1.2及び3人力のゲ ート(否定論理積、否定論理和及びインペンタ)を使って半サイクルでデコニド することができるCl5C型命令であり、そのゲート遅延は256命令の16x 16のカルノー図に基づいて最大で5である。はとんどが1バイトの演算コード 命令を含むカルノー図のブロックはこのようにして実現できる。残りの命令はゲ ート遅延がもっと長いロジック・アレイを使ってRNIDによってデコードされ る。
RNID 704はバス701上の最初の4バイトを受け取る。RNIDはデコ ードするのに1フ工−ズ以上を要する残りの命令の長さを確定するためにデコー ドを実行する。RNIDは5NIDの出力に類似した出力を有する。
RNIDは命令長を検出してその結果をバス711上に出力する。1ビツトのオ ーバー8出カフ12はその命令は長さが8バイト以上であることを示している。
RNIDはまた、命令にModR/Mバイトを含んでいるかどうかを示す1ビツ トのMOD CET出カフ14をイfする。
5NIDまたはRNIDかのどぢらかによってデコードされた長さはMUX70 6によって選択される。現在の命令のための選択−デコーダ[5ELDECIR )と呼ばれる、MUX 706用の制御ライン708は1から11バイトである 実際の長さを測定するためにMLIX 706を2個のデフーダ間で切り替える 。例えば、11バイト長の命令は、RNIDがオーバ−8信号と3をバス711 上に出力するようにする。その命令1(lnlはバス716」二のMUX 33 0に送られ、整列/フタ310とカウンタ/フタ332によって使用される。ト ップのMLJX706によって出力された8ビツトは整列/フタ及びカウンタ/ フタ用の/フト制御(イネーブル)として使われる。
ModR/Mバイトも同様に選択される。5ELDECIR信号708は適切な MODライ/を選んで、ModR/Mバイトが存在しているか否かを示すために 第2MUX710を制御する。MODライライカフ18はIDDDによって使用 される。
5ELDECIR信号708はNID−待ち信号709に基づいて生成される。
5NIDの出力は、その結果が完全なものであるから、第1クロツク・フェーズ 期間中に選択される。NID−侍ち信号709がその命令がデコードされていな いことを示している場合、MUX706と710はRNIDの出力相1を選択す るために切り替えられ、その次のクロック・フェーズの始まりで使用可能になる 。
RNID 704は基本的に2個のffli列デコーダを備えており、その1個 は命令を1バイトの演算フードがあるかのようにデコードし、もう1個は2バイ トの演算コードがあるかのようにデコードする。エスケープ検出 (ESC−D ETI入力信号は演算コードの長さが1バイトか2バイトかを示す。例えば、+ 486の命令セットでは、全2バイトの演算コード(エスケープバイトと呼ばれ る)の第1バイトはその命令が2バイトの演算コードを有することを示す値OF  hexを有している。
RNIDはESCDET信号に基づいて有効命令長を出力する。この信号は第1 演算フードがエスケープ(OFhexiであることを示し、それは即ち2バイト の演算コードであることを示しており、それによって第2バイト・デコーダをイ ネーブルにする。ESI、DET信号を生成するためのロジックのデコーディン グについては当業者には明らかなはずである。
RNIDのブロック図は第7B図に示す通りである。RNIDは、第1演算コー ドバイトをデコードするRNID IOPデコーダ752、第2演算コードバイ トをデコードするRNIDjOPデコーダ754、存在する演算バイト数によっ て確定された2ケ所の位置のいずれかにModR/Mバイトをデコードする2個 の同一のRNID−MODデコーダ756と758、及びRNID SUM加算 器760とを備えている。4個のRNIDデコーダ752〜758)出力に基づ イテ、RNID SUM加算器76oはバス762上に命令の全長を出力する。
RNID SLJM加算器760は、命令の長さが8バイト以上であるかどうか を示すために、0VER8とラベルが付いた別の出力ライン764を有している 。
命令の第1演算コードのバイト及びModR/Mバイトの3ビツト(拡張ビット と呼ばれるビットj5+3])はバス766上のRNID l0P752へ入力 される。データーSzと呼ばれるRNIDJOPへのさらに別の入力ライン76 8は命令のオペランド・サイズが16ビ/トか32ビツトかを示す。データ・サ イズは使用されるメモリ保護構成と、さらに、デフォルトのデータ・サイズを無 効にするプレフィックスが存在しているか否かに基づいて確定される。RN I  D、、−10Pは、命令が1バイトの演算コードを有していると仮定し、さら にその情報と拡張3ビツトに基づいて命令の長さを確定しようとする。
RNID−MODデコーダ754はバス770上のModR/Mバイトの命令入 ツノをデコードする。RNID MODデコーグはアドレス・サイズが16ビ、 トか32ビ、トかを示1−ADD SZのラベルが付いた別の入カバスフ72を 有している。アドレス・サイズはデータ・サイズとは無関係である。
ESCDET信号774はブロック760へも入力される。例えば、ESC−D ET信号がロジックのHIGHであれば、RNID−3UMブロックは演算コー ドが実際に第2バイトになっていることを知る。
RNIDjOPデコータ754は演算フードが2バイトであると仮定し、それゆ え演算コードの第2バイト(バス776参超)をデコードする。RNID 20 Pデコーダはデータ・サイズを認識する人カフ68も有している。
デコーダ自体は演算コードの長さ、即ち1バイトなのか2バイトなのかを知らな いし、HつModR/Mバイトは必ずb1算コードの後に続くから、ここでも2 バイトであるど仮定して2バイトの演算コードに続くバイト(バス778参超) をデコードするために第2RN]D MODデコーダ758が使用される。2個 のRNID MODデコーダは同一であるが、命令ストリーム中の異なるバイト をデコードする。
さらにまた、ESCJET信号774に基づいて、RNID−SUM 760は 適切な演算フード及びModR/Mバイト・デコーダの出力並びにバス762上 の命令の長さを選択する。オーバー8のラベルが付いた化カフ64は命令が8バ イト以上か否かを示す。命令の長さが8バイト以上の場合、IJNO[7:01 バス762が8を越える命令バイト数を示す。
RNID−10Pデコーダ752は9ビツト幅の出カバスフ80を有する。1本 のラインは命令が1バイト長であるか否かを示す。2本目のラインは命令が1バ イト長で且つModR/Mバイトが存在していることを示しており、従って命令 の長さをfす定するにはModR/Mデコーダからの情報も含まれるべきもので ある。同様に、バス780の残りの出力ライ/は次のバイト数を示す:2.2/ MOD、 3.3/MOD、 4.5、及び5/MOD0命令が4バイト長であ れば、ModR/Mバイトは存在しているはずがない。これは1486命令セツ ト特有のことである。しかしながら、本発明はいかなる点においても特定のCl 5C型命令七ノドに限定されるものではない。当業者はどんな引SC型命令セッ トに対してもアライメント並びにデコードするために本発明の特徴を適用するこ とができる。
RNID 20Pデコーダ754は6ビ、ト幅の出カバスフ82を有する。1本 のライ/は命令が1バイト長であるか否かを示す。2本目のラインは命令が1バ イト長であるか盃かを示し、且っModR/Mバイトを含有しており、命令の長 さを確定するには含まれるべきものである。同様に、バス782の残りの出力ラ インは2.2/MOD、3、及び5/MODが存在することを示す。演算コード が2バイト長の場合、1486の命令セットがサポートする命令長は他に考えら れない。
2個のデコーダRNIJMOD756及び758の化カフ84及び786によっ てRNID SUM760はModR/Mバイトによりt旨定される5つの考え られる追加の長さを知る。各RNIJMODデコーダは5ビツト幅の出力バスを 有している。その考えられる5つの追加の長さは1.2.3.5及び6バイトで ある。全長を確定するのにModR/Mバイト自体が含まれている。残りのバイ トはいずれもイミディエト・データまたはディスプレースソフト・データから成 り立っている。
第8図に示すのはIDDD326のブロック図である。IDDDはIMM/フタ 312及びDISP/フタ314の/フト量を確定する。ソフトlllは、命令 のModR/Mバイトによって確定される。
1486命令セツトは2つの特殊命令、即ちenter detect命令とj ump call detect命令を含む。従って、IDDDはこれらの命令 のデコーディング処理をするためにイミディエト特殊検出器[l5Dl 802 と呼ばれるブロックを有する。ISDへの人力803は、命令の第1バイトであ る。2本の出力ラインEN DETとJMjCL DET (820と822) は該当する命令の一つが検H5されていることを示す。
MOD−DECデコーダ804と806は同一物でイミディエト・データとディ スプレースノット・データをデコードする。ADD、−5Z772に基づいて、 デコーダ804は1バイトの演算コードと仮定してMOdR/%lz<イトを調 べ、デコーダ806は2バイトと仮定してModR/Mバイトを調べる。MOJ DEC804及び805への命令バイト入力はそれぞれ805及び807である 。これらのデコーダは命令ストリームのディスプレースノットの位置とイミディ エト・データの位置を確定する。2つの7ライン出力824と826はディスプ レースノット及びイミディエト・データの開始位置を示す。即ち、ディスプレー スノットは位置2か位置3から始まり、イミディエト・データは位置2.3.4 .6或いは7から始まる。
MOD、、−DETライン707と714もまた選択ブロック812へ入力され る。
選択ブロック812はEN DET信号とJMP−CL−DET信号、MOCD ET結果とMOD−DEC結果、及びADD SZとを組み合わせて、4個のハ ス832〜838上にその結果を出力する。ディスプレースノットl (DIS PJIバス832は1バイトcD演算コードと仮定してディスプレースノット・ /フトの結果を出力する。ディスプレースノット2 (DISPjlバス834 は2バイトの演算フードと仮定してディスプレースノット・/フト結果を出力す る。イミディエト1及び2(IMMJとIMM−21バス836及び838はそ れぞれ1バイトと2バイトの演算コードと仮定してイミディエト・データ・/フ トの情報を出力する。
MOD SEL/DLYとラベルが付いた最後のブロック814は実際に適切な シフト1を選択してその結果を半サイクル遅延させる。MOD SEL/DLY  816によって実行された半サイクルの遅延は第3図に示した遅延316を表 す。上述のESC−DET信号774はノットの選択を行なうためにMOD S EL/DLYブロックによって使用される。その結果は半サイクル遅れてクロッ ク信号CLに0とCLに1とによってMOD SEL/DLY814からクロッ クされる。イミディエト・データの/フト制御信号並びにディスプレースノット の/フト制御信号は/フトーD13:01バス840とノット−+1フ:01バ ス842をそれぞれ介してDISP/フタとIMMンフタに送られる。Cl5C 型命令内でのイミディエト・データとディスプレースノット・データの可能な位 置数は/フト量を指定するのに必要なビット数を定義する。
プレフィックス検出器328のプロ1り図は第9図に示す通りである。プレフィ ックス検出器328はプレフィックス−数デコーダfPRFX−NO) 902 .4個のプレフィックス−検出器デコーダ(PRF)jDEc904〜910) とプレフィックス−デコーダ(PRFX 5EL) 912を備えている。
例えば、1486命令セIトは11の考えられるプレフィックスを含む。幾つか の無効なプレフィックスの組み合わせがあるから、1命令につき合計で4つのプ レフィックスを含むことができる。その4つのプレフィックスの順序もまた命令 セットによって定義される。しかしながら、正しいプレフィックス順列のみを検 出するためではなく、むしろ命令の最初の4バイトをそれぞれデコードするため にプレフィックス検出器は4個のプレフィックス検出器904〜910を使う。
命令の最初の4バイトはバス9引上のプレフィックス検出器へ入力される。検出 器904から910はそれぞれ12ビット幅の出力バス(905,907,90 9及び911)を有する。
プレフィックスが実際にデコードされていれば、12の出力からどのプレフィッ クスが存在しているかわかる。12番目のプレフィックスはロック解除と呼ばれ 、これは1486のロックプレフィックスの機能上の補数であるが、エミュレー シヨン・モード時のマイクロフード・ルーチンにのみ使用可能である。
整列−RUN制御信号920はプレフィックス・デコーダをイネーブル/ディス エーブルにするために組み込まれていることがあり、プレフィックスを全てマス ク・アウトするために使用される。HOLJPRFX制御信号922はプレフィ ックス情報をラッチし且つ保持するために使用される。一般的に、プレフィック ス検出器328がプレフィックスの存在を示している場合の命令のアライメント では、制御ロジックがプレフィックス情報をラッチしなければならない。プレフ ィックス情報はその後プレフィックスを/フト・アウトするために整列シフタ3 10によって使用される。その次のサイクルで、IAUは命令の長さを確定して アライメントし、さらにIDuに引き渡す。
PRFX Noデコーダ902は演算フードの最初の4バイトをデコードするこ とによりプレフィックスがどこにどれだけ存在しているかを示す。PRFx−N oデコーダ902の論理図は第10図に示す通りである。PRFX Noデコー ダは4個の同一のデコーダ1002〜1008並びに論理ゲー) +010一式 を備えている。4個のデコーダ1002〜1008は各々最初の4バイト(10 10〜+013)の一つを調べてプレフィックスが存在しているかどうかを確定 する。プレフィックス・/<イトは演算コード・バイトに続くことができるから 、論理ゲート1o10は最初の演算コード・バイトの前にプレフィックス総数を 示している結果を出力するために使用される。何故なら、演算フードに続(プレ フィックスは次の命令の演算コードにのみ適用できるからである。
第1バイト(位置)がプレフィックスで第2位置にプレフィックスがなければ、 プレフィックス総数は1である。また別の実施例として、ブレフイ・ノクスが最 初の3位置になければ、第4位置のプレフィックスはどうでもよい。−格下のN ANDゲート1014から出力されたロジックHIGH(11は4個のプレフィ ックスが存在することを示し、下から2番目のNANDゲー) 1015から出 力されたHIGHは3個のプレフィックスの存在を示すといった具合である。4 個のNANDゲートの出力はPREFIJNOバス1018を形成するために結 合され、1<ス1018は第1演算コードに先行する有効プレフィックス総数、 即ちプレフィックス検出器328のシフト量出力を表す。
PRFJNOデフーダ902はρrefix Present (PRFX−P l出力)(ス1020(これも4ビット幅)も含んでいる。4本のPRFX P 出力ライン1020〜1o23は、他の位置の出力が何であるかに係わらず、特 定の位置にプレフィックスがあるか否かを示す。PRFJP出力は4個のデコー ダ+1002〜+o081の出力から直接採られる。
PRFJNOデコーダの結果(第10図との関連で説明する)及びPRFX−D EC検出器904〜910からの情報はPRFX SELデコーダ912によっ て結合される。プレフィックス情報は1個の13ビツト出力バス924を形成す るために結合され、バス924はプレフィックス信号があるか、及びどのプレフ ィックスが存在するかを示す。
3.0/′−′ツー5・ユニ 命令は全てIAUから命令デコード・ユニット(IDU)に引き渡され、直接R 2Se型の命令に変換される。IELJによって実行される命令は先ずIDLJ によって処理される。IDLIは各命令がエミュレートされた命令なのか基本命 令なのかを判定する。エミュレートされていれば、全て基本命令からなるマイク ロコード・エミュレーフMン・ルーチンが処理される。基本命令であれば、直接 I\−ドウエアによって1個から4個のナノ命令に変換されてIEUに送られる 。IEUが実際に実行するのは、元々のCl5C型かマイクロコードの命令では なくて、これらのナノ命令である。
命令の分割には2つの主要な利点がある。その1は、簡単なオペレーンタンに対 応しているだけでいいから、ハードウェアが小型ですむ。その2は変更が容易な 複合マイクロフード・ルーチンでバグが発生しやすいため、バグはそれほど厄介 な問題ではなくなる。
本発明に関連するIDLJのマイクロコード・ルーチン対応の/\−ドウエアに は固有の特徴が幾つかある。マイクロコード命令はブロセ・ノサ内に存在する様 々な・ データバス用の制御ビットから成り、はとんど符号化されていないか全 く符号化されていないというのが典型的である。これと対比して、本発明のマイ クロコードは特定の複合命令上ノドをエミュレートするために設計された比較的 高レベルの機械言語である。典型的なマイクロコードは直接プロセッサの機能ユ ニットへ送られるのに対し、本発明のマイクロフードは目欅のCl5C型(例え ば、!30x86)命令に使用されるのと同じデコーダ論理によって処理される 。これによって、本発明のマイクロコードのコード密度が典型的なマイクロフー ドによって達成される場合よりはるかに優れたものになり、そして目標のCl5 C型命令セツトと類似しているからマイクロコードの開発が容易になる。さらに 、本発明はマイクロフードの改訂用にハードウェアで対応できるようになる。即 ち、オフチップROMベースのマイクロコードはソフトウェア制御によって部分 的もしくは全体的に外部RAMベースのマイクロコードに置き換えることができ る。(1991年12月6[1に出願された、同−承継人の出願に係る・同時係 属出願中の、米国出願番号07/802.8+6、発明の名称r RAMセル及 び巡回冗長検査回路搭載ROMJ 、代理人整理番号5PO24を参照。なお、 当該出願の開示はV照することによって本明細書に組み込まれているものとする 。) マイクロコード・ルーチン言語は、あらゆるエミユレートされた複合命令に必要 な機能に加え、例外処理に関連する様々な制御並びに保守機能を実行するために 、RISC型コアによって実行される命令セットになるように設計されている。
エミユレートされた命令は典型的にはエミュレートされていない(基本)命令は どには性能に影響しないし、さらに例外くマイクロコード・ルーチンによって処 理される)はめったに起こらないけれど、それでもなお両方を効率的に処理する ことが総体的な/ステムのスループットにとって非常に重要なことである。この 目標は様々な形式のマイクロコード・ルーチン対応のハードウェアを使用するこ とによって達成される。本発明はマイクロコード対応のハードウェアの4つの領 域、即ち、ディスバッチ論理、メイルボックス、ナノ命令フォーマット、及び特 殊命令を備えている。
マイクロコード・ディスバッチ論理は目標Cl5C型命令ストリームからマイク ロコード・ルーチアへ、そしてまた目標命令ストリームに戻るプログラム制御の 効率的な転送を制御する。それはわずかなハードウェアを使用し、且つRISC 型コアの命令実行ユニット[IEIJlには見えない方法で、処理される。(I EUはRI SC型命令を実行する。上述のrRIscコア」はIELJと同義 語である。IEUについての詳細は当業者が本発明を実施するのに必要ではない 。本発明の特徴はRISC型プロセッサ全般に適用できる。)メールホックスは 情報を体系的な方法で命令デコード・ハードウェアからマイクロコード・ルーチ ンに転送するために使用されるレジスタの7ステムを備えている。これによって このハードウェアが命令オペランドや同様のデータをマイクロコード・ルーチン に引き渡せるようになり、その結果、命令からこのデータを抽出するタスクを省 くことになる。
ナノ命令フォーマットはICUから[EUに引き渡す情報を記述する。ソースの Cl5C梨命令から効率的に抽出されるようにするためにこのフォーマットが選 択されているが、依存性の検査や機能ユニット制御には十分な情報をIELIに 提供する。
最後に、特殊命令はRISC型ハードウェアを完全に制御できるようにし、ハー ドウェア固有のエミュレーンプノ・タスクに対応するために備えられた追加の命 令セットであり、且つCl5C型命令セツト専用である。
317 ロコー゛・−′ パ 慎 マイクロコードにディスパッチする第1のステップはマイクロコード・ルーチン のアドレスを確定することである。このステップには2つの重要要件がある。
即ち、各マイクロフード・ルーチン毎に固有の開始アドレスがあることと、それ らのアドレスは高速で生成されなければならないことである。取り扱い件数が少 なければハードウェアがアドレスを定数として格納できるし且つそれらの間で選 択することもほとんどないから、このやり方でかなり容易に例外処理のルーチン を実現できる。しかしながら、実行可能なアドレス全部を格納させるにはあまり にも数が多いため、エミュレートされた命令のアドレス確定はもっと難しい。
マイクロコード・ディスバッチ論理は直接その演算コードを各命令のディスバッ チ・アドレスに基づかせることによって要件を満たしている。例えば、1バイト の演算コードがOHからIFFFHのアドレス空間にマツプされる。その場合、 16ビノトのディスバッチ・アドレスの上位3ビツトはゼロでなければならない 。
これらのマイクロフードのエントリ・ポイントは64バイト隔てられており、各 エントリ・ポイント・アドレスの最下位の6ピノトはゼロでなければならない。
これによって7ビ、トが未定のまま残ることになるが、演算フードの7ビノトか ら直接取り込むことができる。当業者には明確になるように、この方法によるア ドレス生成はほどんどロノノクを必要としない。例えば、演算コードから適正ビ ットを選択するためにマルチプレクサだけが使用される。
一度マイクロフード・ルーチ/のディスパッチ・アドレスが確定されれば、マイ クロコードはメモリからフェッチされなければならない。典型的には、マイクロ コードはオノチノブROM内に存在するが、必ずしもそうとは限らない。上記に 引用した米国出願番号07/802.816に詳述されているように、各エント リ・1′イツトはROMのルーチ/が正しいか否かを表すROM無効ビットに対 応している。このビットはROMへのアクセスと並行してフェッチされ、従来の キヤノンユ・ヒツト・インディケータと同様の働きをする。このビットがROM のエントリが(■効であることを示していれば、マイクロコード・ルーチンはR OMから継続して〕Il、 7チされ、u通に実行される。しかしながら、ビッ トがROMが無効であるごとを示していれば、マイクロコードはRAM等の外部 メモリからフェッチされる。
オフチップ・マイクロコード・ルーチンのアドレス指定はIDU自身によって行 なわれる。lDuはマイクロコードROMにアクセスするための16ビノトのア ドレスを生成する。アドレス指定されているROM二/トリに対応するROM無 効ヒ゛ノドがそのマイクロコードは無効であることを示していれば、主メモリ内 にオフチップで存在する外部マイクロコードのアドレスが計算される。U−ベー スレジスタ1i主メモリ内に存在する外部マイクロコードの上位16のアドレス ・ビット(開始アドレスと呼ばれる)を保持する。ICUによってデコードされ た16ビノトのアドレスは、主メモリ内に11在する外部マイクロコードにアク セスするために、U Ba5e I/’;スタの上位16ビノトと連結される。
主メモリ内に存在する外部マイクロコードの記憶場所が変更されれば、新規の主 メモリの記憶場所を反映するためにU Ba5eレジスタの内容を修正すること ができる。
この特徴によって、全てのマイクロコードに外部メモリ・アクセスの性能低下を 強いることなく、あるルーチンを外部メモリ内の別のものと置き換えることによ りマイクロコードの更新を行なえるようになる。RISC型チップの面積要件を 減らしたり、マイクロフード開発援助のために、RISC型チップからROMを 全て削除して外部RAMにマイクロフード全体を入れることもできるようになる 。
タスクが終了するとマイクロコード・ルーチンが命令の主ストリームに戻るため の手段を提供するのもこのディスバッチ論理である。この処理のために、個別の プログラム・カウンタ(pc’s)及び命令バッファを維持する。通常動作中、 土ρCが外部メモリ内の各Cl5C型命令のアドレスを確定する。これらの命令 を含むメモリのセフ/ランはIFUによってフェッチされ、MBLJFに格納さ れる。
エミュレートされた命令または例外が検出されると、現在の命令のPC値と長さ が一時バッファに格納される。一方、マイクロコード・ディスパッチ・アドレス は上述のように計算され、さらに命令がこのアドレスからEBuFにフェッチさ れる。マイクロコードの「リターン命令が検出されるまでマイクロコードがEB UFから実行される。リターン命令検出時に予備のPC値が再ロードされ、MB UFから実行が継続される。MBuFやその地金ての関連レジスタはマイクロコ ード・ルーチンへの制御の転送中は保存されているから、Cl5C型プログラム への戻りの転送は非常に高速で起こる。
命令エミュレー/コノ・ルーチンと例外処理ルーチンの相違に対応するためにマ イクロコード・ルーチンによって使用される2つのリターン命令がある。例外処 理のためにマイクロコード・ルーチンが入力されると、そのルーチン終了後にプ ロセッサは割り込みが入ったまさにその状態に戻ることが重要である。しかしな がら、命令をエミュレートするためにマイクロコード・ルーチンが入力されるど 、ルーチンはエミュレートされた命令に続く命令に戻りたがる。さもなければ、 エミュレーノヨノ・ルーチンは2回目を実行する。これらの2つの機能は2つの リターン命令、即ち、aret及びeretsを使用して処理される。aret 命令は、マイクロコードが入力されていれば、プロセッサをその状態に戻し、一 方、@ret命令は主PCを更新し且つ制御して目的ストリームの次の命令に戻 るようにする。
3.2.L:Jkニー乙111 エミュレーンヲン・ルーチンがうまく複合Cl5C型命令の機能を行なうために は、マイクロフードが、エミュレートされた命令によって参照されるオペランド にアクセスしやすいことが必要である。本発明において、このことは4個のメー ルボックス・レジスタを使用することによって行なわれる。これらのレジスタは その使われ方が特有である。即ち、マイクロコードに使用可能な、整数レジスタ ・ファイル内の16個の一時レジスタ・セットの最初の4個であると定義されて いる。オリジナル命令からのオペラッドか他の情報を要する各エミュレーン曹ン ・ルーチンは、ルーチンに入る際に、1個以上のメールボックス・レジスタに格 納されたこれらの値を見つけるはずである。IDLJはエミュレートされた命令 を検出すると、マイクロコード・ルーチン自体の実行開始前に、マイクロフード が予期する値を有するレジスタをロードするためにIEUによって使用される命 令を生成する。
例えば、オペラッドとして汎用レジスタのどれかを指定するLoadMach  ine 5tatus Word Hmswl命令のエミュレーンgンを考察し てみよう。
エミュレート対象の特定命令が1m5w axであると仮定し、それはraxJ レジスタから16ビノトの状態ワードをロードするとする。命令で実際に指定さ れたレジスタいかんにかかわわらず同じマイクロコード・ルーチンが使用され、 従ってこの命令のためにメイルボックス#0には状態ワードがマイクロフード・ エントリの前にロードされる。ICUはこの命令を検出すると、IEuがrax jレノスタから「uO」レジスタに状態ワードを移動するようにmovuO,a x命令を生成するのであるが、それはメイルボックス#0と定義されている。こ のmov命令がIEUに送らられた後に、マイクロコード・ルーチンがフェッチ されて送られる。従って、マイクロフードはエミュレートされた命令が1m5w  uoであるかのように書き込まれ、オリジナルのCl5C型命令で1旨定され る全ての考えられるオペランドを正確に処理する。
3.3 −マ 上述したように、Cl5C型命令はIDLJによってナノ命令にデコードされる のであるが、その処理はIEUと呼ばれるRISC型プロセッサ・コアによって 行なわれる。ナノ命令は「バケット」と呼ばれる4つのグループに分けてIDu がらIEUに渡される。バケットの1つを竿11図に示す。各バケットは2個の バケットとそのパケット全体に関する一般的な情報とで構成されている。バケッ ト#oには常に順序通りに実行される3つのナノ命令が入っている。その3つの ナノ命令はロード命令1102、ALUタイプ命令1104、格納命令1106 である。バケット#1は単一のALIJタイプ命令1108から成る。
IEUはサイクル当たり1個のピーク・レートでICUからバケットを受け入れ ることができる。IDLJはサイクル当たり2個のピーク・レートで基本命令を 処理する。はとんどの基本命令は単一のバケットに変換されているため、通常2 つの基本命令は1個のバケットに入れられて一緒にrEUに渡される。このレー トの一番大きな制約は基本命令がパケットの要件に適合していなければならない ということである。その要件とは以下の通りである。
2つの基本命令のうち1つしかメモリ・オペランドを参照することはできない( バケ、ト毎にロード/格納動作は1つしかない)、さらに両命令ともに単一のA LLJタイプ演算(2つのALLIタイプ演算を要する1つの命令と対照して) から成っていなければならない。
この制約の片方か両方かが満たされなければ、基本命令の1つだけに該当するナ ノ命令の入ったバケットが[EUに送られ、残る命令は後から別のバケットで送 られる。これらの制約はIEUの能力を正確に反映するものである。即ち、IE Uは2個のALUと1個のロード/格納ユニットを備えているから、実際にはこ れらの要件によって性能が限定されるわけではない。このタイプのIEUの例に ついては、同−承継人の出願に係る同時係属中の、米国特許出願番号07/81 7.81、発明の名称「高性能RISC型マイクロプロセッサ・アーキテクチャ (H4ghPerformance RISCMicroprocessor  Architecture) J 、1992年1月8[]出願く代理人整狸番 号SP0+5/1397.0280001) 、並びに米国特許出願番号07/ 817.809、発明の名称1拡張可能R15C型マイクロプロセツサ・アーキ テクチw (ExtensibleRISCMicroprocessorAr chitecturel J 、1992年1月8日出願(代理人整理番号5P O2+/1397.0300001)に開示している。なお、これらの開示は参 照することにより本明細書に組み込まれているものとする。
34持lJ「包 汎用命令を用いて実行するのが困難であったり不十分であるマイクロコード・ル ーチンによって実行されなければならない機能は数多くある。さらに、従来のC l5C型ブロセ、−1に比べ当RISC型プロセッサのアーキテクチャは拡張さ れているため、特定の機能が有効である。かといって、そうした機能はCl5C 型ブロセ、すには何の意味もないし、従ってCl5C型命令のどんな組み合わせ を用いても実行できない。合わせて、こうした状況から「特殊命令」が生まれた 。
特殊命令の第1カテゴリーの例はextractJesc−base命令である 。この命令によって2個のマイクロフードの汎用レジスタから様々なピット・フ ィールドが抽出され、それらは連結され、さらにその結果がマイクロコードによ る使用のために第3の汎用レジスタに入れられる。この命令を利用しないで同じ 動作を実行するには、マイクロコードが幾つかのマスキングと/フトの動作を実 行しなければならない上、一時的値を保持するために追加のレジスタの使用が必 要となる。特殊命令によって、単一サイクルで1命令によってしかもスクラッチ ・レジスタを使わずに、実行されるの七同じ機能が果たせるようになる。
特殊命令の第2カテゴリーの2つの例については既に述べた。即ち、マイクロコ ード・ルーチンを終了させるために用いられる2つのリターン命令、aretと eretである。これらの命令はマイクロコード環境でのみ意味があり、従って Cl5C型のアーキテクチャには同等の命令とか命令順序といったものはない。
本件において、特殊命令は性能上の理由だけでなく、機能NIi正の点からも必 要だった。
特殊命令はマイクロフード・ルーチンにのみ使用可能であり、さらにエミュレー トされた命令は目標のCl5C型命令ストリームにしか発生しないから、エミュ レートされた命令の演算コードは特殊命令のマイクロコード・モード時に再使用 される。従って、目標のCl5C型命令ストリームにこれらの演算コードの一つ が発生する時、それはその命令のマイクロコード・エミュレーション・ルーチン が実行されるべきであるということを表しているにすぎない。しかしながら、そ の同じ演算コードがマイクロコード命令ストリームに発生する時、それは特殊命 令の一つとして全く異なった機能を有している。この演算コードの再使用に対応 するために、ICUは現在のプロセッサの状態を記録し、さらに命令を適正にデ コードする。この演算コード再使用はIE(Jには見えない。
ICUは各Cl5C型命令(例えば、1486命令セツトの)をデコードして各 命令を幾つかのRISC型プロセッサ・ナノ命令に変換する。上述したように、 複雑性や機能性いかんによって、各命令は0から4つのナノ命令に変換される。
IDLIは最高で1サイクルの割合で2個のCl5C壓命令をデコードして変換 する。ICUの基本機能を要約すると以下の通りである。
傘 半サイクルにつき1個のCl5C型命令をデコードする。
傘 第1フエーズで第1CISC型命令をデコードする。
傘 第1CISC型命令のデコードされた結果を有効なものであるとして第2フ エーズ終了まで保持する。
傘 第2フj−ズで第2CISC型命令をデコードする。
傘 第37エーズで可能ならば、2つの命令の出力を結合する。
傘 サイクル毎に4つのナノ命令がら成るパケットを1個出力する。
35命八−コー′eユニ ″口 ICUのブロック図は第12図に示す通りである。IAuがらのアライメントさ れた命令は32ビツト幅(]31・olが4バイト〉のバス12o1上のIDL Iに到達する。
そのアライメントされた命令は命令デコーダ12o2によって受け取られる。I DL11202はCl5C型からRISC型への変換を行なうためにアライメン トされた命令の最初の4バイトを調べるだけである。
命令デコーダ12o2は1クロツク・フェーズ(半サイクル)で作動する。アラ イメントされた命令はそのデコーダを通り、そしてそこを出るデコードされた情 報は多重化され、バス1203を介して半サイクル遅延ラッチ12o4にフェッ チされる。従って、そのデコードされた情報は1フエーズ・パイプライン遅延と 同じことを経験することになる。
半サイクルの遅延後、そのデコードされた情報は使用された実際のレジスタラー ドを確定するためにバス1205を介してMLIXI206に送られる。デコー ディングのこの段階で、そのデコードされた情報はナノ命令にフォーマットされ る。
そのナノ命令は次にラエノチされる。2個の完全なナノ命令パケットがサイクル 毎にラッチされる。2個のナノ命令バケットのラッチをそれぞれ第11Rバケツ ト1208、第21Rバケツト1210で図式的に示す。
ICUはパケット12o8と1210を1個のパケット1212にまとめようと する。
制御ゲート一式1214がまとめ作業を行なう。IDUは先ず各ナノ命令のタイ プを調べ、結合可能なタイプがどぅがを確定する。2つのラッチされた命令のロ ード(LDI動作のどちらが単一パケット1212のLD記憶場所1216に入 っていいし、ラッチされた命令の格納(ST)動作のどちらが単一パケットのS 前記憶場所に入っていいし、AO動作のどちらがAO記憶場所122oに入って もいい、さらにAOがA1の動作のいずれでもA1記憶場所1222に入ってい いことに注意すること。
ICUは命令を全体的に扱う。ICUは2つの命令を1つのパケットに詰め込め なければ、一つの完全な命令を後に残す。例えば、第+1RラツチにはAO動作 しかなく、第21Rラツチに4つの動作全てが入っている場合、IFUは第21 RラツチからA1を取り込まずAO動作に合併する。AO動作が単独で送られ、 第21Rラツチの動作の果合は第11Rラツチに転送され次のフェーズ上に送ら れる。その期間中に第21Rラツチは再ロードされる。言い換えれば、第1IR ラツチに格納された動作は常に送られ、第21RうIチに格納された動作は可能 ならば第11Rラツチの動作と一つにまとめられるということである。万−第+ 1Rと第21Rがまとめられない場合には先のIDLJ並びにIAUのバイブラ イン・ステージは待機しなければならない。IDLJが第1と第2のIRクラッ チ作を合併できるのは下記の状況においてである。
1、 共にAOLか使用しない、もしくは2、 片方はAOLか使用せず、他方 は八〇、 LD及びSTのみを使用する。
先に説明した機能性及び基本論理の設計実務に基づいて、当業者は、第1と第2 のIRラッチの内容を合併すべく、制御ゲートに必要な制御信号を生成するため に組み合わせ論理を容易に設計できる。
IDIJがエミュレーンヲンを要する命令のサブセットに属する命令を識別する とエミュレーンヲン・モードになる。エミュレート嘗/・モードになると、エミ ュレーンヲン・モード制御信号(EMUjMODEl力(ICUのデコーダに送 られる。
Cl5C型命令の直接デコーディングは中断し、識別された命令に対応するマイ クロコード・ルーチンがデコーディングのためICUに送られる。マイクロコー ド・ルーチンがサブセット命令のエミユレーションを終えると、ICUデコーダ はCl5C!1’!命令のデコーディングを続1ブるため基本モードに戻る。基 本的に、IDLIは基本Cl5C型命令及びマイクロコード命令を同様に取り扱 う。演算コードの解釈だけが変わる。
1バイト!lfトびに2バイトの演算フード命令のデフォルト(基本)モードの カルノー図を第13A〜13C図に示す。カル7−図の左側と上部に示す数字は 演算コード・ビットである。例えば、hex OFのコードのついた1バイトの 演算コードは第1行第11列に相当し、それは「2バイト・エスケープ」命令で ある。
第13A〜+3c図のカルノー図で影をつけたグレーの命令ボックスは基本命令 で、白のボックスはエミュレートされなければならない命令である。
ICUの命令デコーダ1202のブロック図を第14図に示す。命令デコーダ1 2o2はCl5C型命令とマイクロコード・ルーチンをデコードするために用い られる慢数のデコーダを含んでいる。
タイプジェネレータ(TYPE GENIデコーダ1402は整列−IRババス 上完全にアライメントされた最ン刀の命令を受取り、命令のタイプフィールドを 識別するために命令を一つずつデコードする。
識別されたタイプフィールドはICUとの関連で先に説明したナノ命令の動作に 対応する。タイプはパケット内の各動作(ロード、ALLJO1格納、ALLJ I)を表す4ビ、トのフィールドで表わされる。TYPjGENデコーダ140 2は命令実行にはこれら4つの動作のどれが必要かを指定する。受は取った命令 いかんで、Cl5C型命令を満たすには命令の1から4までのいずれかの番号が 必要である。
例えば、1個のレジスタの内容をもう1個のレジスタの内容と合計する、加算演 算はALUナノ命令を1口実行するだけでいい。一方、レジスタの内容と記憶場 所の内容を足さなければならない命令では、ロード、ALUの動作と、続いて格 納動作との合わせて3つのナノ命令の動作が必要となる。(データはメモリから 読み出され、レジスタに加算され、さらにメモリに格納されなければならない。
)より複雑なCl5C型命令では4つのナノ命令全てが必要になる。
TYPEJENデコーダ14o2は3個のタイプデコーダを備えている。第1デ コーダタイプ1は命令はModR/Mバイトの前に1バイトの演算フードを有し ていると仮定し、その仮定に基づいてタイプを計算する。第2デコーダタイプ2 はその命令には2バイトの演算コードがあると仮定する。第1バイトはエスケー プバイトであるが、それは演算コードである第2バイトとModR/Mバイトで ある第3バイトとの前にくる。第3デコーダタイプFはその命令は浮動小数点命 令であると仮定し、その仮定に基づき命令をデコードする。
TYPEJENデコーダは4ビツト幅のタイプ命令出力バス(タイプ1、タイプ 2、タイプF)を3個有する。各ビットはバケット内の4つのナノ命令動作の一 つに対応する。特定のタイプフィールドによってcrsc型命令を実行するのに どのナノ命令が必要か指定される。例えば、4ビ2)が全てロジックのHIGH の場合、Cl5C型命令にはロード、格納の動作がそれぞれ1回と、ALU動作 が2回必要である。
1.2、Fのラベルが付いたセクンWノを含む第14図の残りのデコーダはそれ らがそれぞれ1バイトの演算コード、2バイトの演算フード、浮動小数点命令で あると仮定してデコードする。無効結果が選択されることはめったにない。マル チプレクサは正しいデコーダの出力を選択する。
2つのALU動作fALUoとALUllには各々11ビIト長の演算コード・ フィールドがある。その11ビツトは演算コードの8ビツトと、隣接するMod R/Mハイドからの3演算コード拡張ビツトとから成る。ICUが処理するcr sc型命令ではほとんどの場合、演算コード・ビットはナノ命令動作に直接コピ ーされる。しかしながら、Cl5C型命令のなかには演算コードの置き換えを必 要とするものもある。
この場合、ICU装置はCl5C型演算コードを命令実行ユニット(IEtJl にフィルタすることはめったにない。IFU内の機能ユニットのタイプ及び数が ICU内での演算コードの置き換えが特定のCl5C型命令にとって必要か否か を左右するから、このことは当業者には明確になるであろう。
IEUがALU動作を処理するためには、措定されたALLJ動作を処理するの にどの機能ユニットが必要であるかという情報を受け取らなければならない。従 って、IDLJllFJUNITI、F−OUNIT2、及びF−OuNITF (’)3個のデコーダから成る機能ゼロユニットfF−OLINITIデコーダ 1410を含んでいる。デコーダの出力はAOのALU動作を処理するのにどの 機能ユニットが必要かを表す複数バイトのフィールドである。A1のALLI動 作のためのデコーディングをする機能ユニットは同一ではあるが、別個のデコー ダFJユニット1412によって取り扱われる。
crsc型命令は演算コードによって暗示されるレジスタを用いてオペレー/ヲ ノを実行することが多い。例えば、多くの命令がア牛ユムレー夕としてAXレジ スタを用いるべきであると暗示している。従って、そのCl5C型命令の演算フ ードに基づいたレジスタ・インデックスを生成するために定数ジェネレータ(C ST GENIデコーダ1414が含まれている。C3T GENデコーダは特 定の演算コードに基づいて、どのレジスタが暗示されているがを明らかにする。
ナノ命令の正しいノースやデスティネーンヨノ・レジスタ・インデックスを生成 するための多重化については第15図との関連において以下に説明する。
追加の2ビツトの制御信号である、TempCount (TCIは、CST  GENデコーダへ入力される。TC制御信号は ダミー・レジスタとしてIEL Iが使うために、循環する4個の一時レジスタを表す2ビツトのカウンタである 。一時(もしくはダミー)レジスタは、暗示されたレジスタに加えて、CST  GENデコーダから受け継ぐレジスタのもう一つの値を示す。動作毎のレジスタ を2個有するALU動作が2つあるため、定数ジェネレータ・デコーダは4つの 定数フィールドを引き渡す。
定数レジスタ・バスはそれぞれが20ビノト幅で、各定数は計5ビットだから、 IEIJ内の32個のレジスタの1個を選択することができる。
次に、概ねブロック1416で示した選択ジェネレータfsELJEN)デコー ダについて説明する。SEL GENデコーダはフラグ要求変更(FG NMI デコーダ1418を含む。FG NMデコーダは1バイトの演算コード、2バイ トの演算コード、及び浮動小数点命令用にデコードする。例えば、1486命令 セツトには計6個のフラグがある。フラグは命令によって変更してもいいが、こ れらのフラグは命令の実行が開始される前に有効になっていなければならない。
FG−NMデコーダはフラグ毎に2つの信号を出方する。一方のビットはこの命 令実行のためにフラグが必要か否かを示し、別のビットはこの命令が実際にフラ グを変更するが否かを示す。
ALUOとALLIIの動作に関するレジスタの無効情報はそれぞれ142oと 1422で表したINVDTとINVD2のデコーダによってデコードされる。
I NVD +及びINVD2fニア−’ll5ELJENテ:l−タ1416 CD一部t’モアル。INVD +及ヒINVD2のデコーダはIEU用の制御 信号を生成する。これらの信号はALUレジスタを使用すべきか否かを示す。3 個の考えられるレジスタ・インデックスは各ALU動作により指定される。その 1つはソース及び/またはデスティネーンヨノ・レジスタとして使用し、残りの 2つはソース・レジスタ指定だけに限定される。動作にはどのレジスタが必要か を指定するために4ビ)+)のフィールドが使われる。
SEL GENデコーダ1416はさらにCl5C命令にはレジス?・フィール ドのどれが必要かを示すFLJCNTデコーダ1424を含んでいる。FLD− CNTデコーダは2つのフィールドのどちらがソース・レジスタでどちらがデス ティネーション・レジスタであるかを指定する。
ナノ命令ジェネレータ (NIR,−GENIデコーダは概ねブロック1426 として示す通りである。データ・サイズ(DATA SZI及びアドレス・サイ ズ(ADDRSZ)の入力制御信号はシステムが動作しているデフォルトの状朝 に対応している。最終のアドレス並びにオペランドのサイズをデコードするため には、デフォルト・モードが分かっていなければならないし、プレフィックス( IALIとの関連において先に説明した)の存在も分がっていなければならない 。EMUjMODE制御信号はNIRJENデコーダへ入力されるが、他のデコ ーダによっても使用される。
エスケープ検出(ESCJETI入カ制御信号は、命令が2バイトの演算フード をfTしているかを表すために、NIR−GENデコーダに送り込まれる。さら に、エミコレー/ヨノ命令が検出されるとメールボックス・レジスタのローディ ングを起こすために、選択演算コード拡張(SELJPjXTl入力制御信号が 使われる。
浮動小数点レジスタ[FjREG1人力制御信号は変換された浮動小数点レジス タ・インデックスをIDUに渡す。例えば、1486のγ77動小数フォーマッ トは17動小数点数用の8個のレジスタを有しているが、それらのレジスタはス タックと同様にアクセスされる。スタック・アクセス方式、即ち、レジスタ0が スタ。
りの一番」二で、レジスタ1が上から2番目といった具合、を使ってこれらのレ ジスタをアクセスできる。このレジスタ・スタックは固定インデックスを有する 8個の線形レジスタを使用することによってエミュレートされり、入力命令がレ ジスタOを指定すれば、変換ブロック(図示せず)は周知の方法でスタック関連 レジスタ・インデックスを線形レジスタ用のレジスタ・インデックスに変換する 。これによりIDLIがどのレジスタがスタックの一番上にあるかを記録するこ とができるようになる。
/ステムがエミュレーフgノ・モードに分岐すると、ICUはエミュートされて いる命令についての情報を保存する。IDLIは、デスティネーションのレジス タインデックスtEM RDESTI、ソース(EM−RDEST2+ 、ペー スインデックス情報[EIJBSIDXl 1m加えて、命令ノテータサイズ( EM DSIZEI及びアドレ’Xサイズ(EM ASIZEIも保存する。こ の保存された情報は命令を適切にエミュレートするためにマイクロフード・ルー チンによって使用される。例えば、加算命令のエミュレー/−J/を考えてみよ う。マイクロコード・ルーチンは、どのアドレス・サイズをエミュレートするか を知るために、加算命令のアドレス・サイズを確定するのにEM ASIZEを チェックすることがある。
NIRGENデフーダ1426はサイズデコーダ1428を含む。5IZEデコ ーダ(即チ、5IZEI、5IZE2.5IZEF)によって生成されたフィー ルドは命令のアドレス・サイズ、オペランド・サイズ、さらにイミディエト・デ ータ・サイズを表す。16ビノトか32ビツトのアドレス・サイズ、8ピlトが 16ビノトが32ビツトかのオペランド・サイズ、8ピツトか16ビノトか32 ビツトがのイミディエト・データ・フィールド・サイズが各命令用に抽出される 。
もう一つのNIR−GENデコーダはロート情報(LD−INF) デコーダ1 43oと呼ばれる。LDjNFデコーダはロード及び格納の動作に対応する情報 をデコードする。ロード情報は効果的なアドレス計算を行なうために使用される 。Cl5C命令セツトは通常多くの様々に異なるアドレス指定モードを支援する から、ロード情報ノフィールド(LD−INFI、LD lNF2、LD−IN FF)はCl5C命令によッテどのアドレス措定モードが使われているかを指定 するために使用される。
1486の基本アドレス指定モードは、アドレスを確定するために足して一つに まとめられるセグメント・フィールドとオフセットを含んでいる。インデックス ・レジスタのスケールに加えて(例えば、インデックス・レジスタがアレイ内の 素子である場合)、インデックス・レジスタを指定できるし、素子を長さで1. 2.4、または8バイトとして指定できる。従って、インデックス・レジスタが アドレスを確定するために加算される前に1.2.4、または8でインデックス ・レジスタを基準化することができる。ベース並びにインデックスもLD IN Fフィールドで指定できる。
ナノ命令演算コード(NIR0PC)デコーダ1432はA1オペレーンコン( パケット1)用の演算コードを転送する。デコードされたフィールド(NIR− OPCI、NIROρC2、NIR−OPCF)は第1命令バイト(8ビツト) と第2バイトからの3つの拡張ビットから成る。
雑演算コード fMIsc 0PC)デコーダ1434は、命令が浮動小数点で あるか、及びロード命令が実際に存在しているかどうかを表す。MISCJPC デコーダによって生成されたフィールドは、浮動データの変換が必要かを示すこ とになる。この情報は命令のフォーマットに係わらず簡単に抽出されるから、こ のデコーダは多重化する必要がない。
バケットOのAO動作用の演算コードは演算コードデコーダ1436により指定 される。AO演算コードは通常1486の入力演算コードから直接コピーされる が、命令によっては演算コードが別の演算コードで置き換えられることがある。
(上記のように、NIRJENデフーダにより生成された信号の機能性はデコー ドされているCl5C型命令七ノドに特有であり、よってCl5C型命令セツト 並びに本発明のナノ命令フォーマットを検討すると当業者には明確になるはずで ある。)EXT C0DEデコーダ1440はModR/Mバイトから3ビツト の演算コード拡張子を抽出する◇ lN−0RDERデコーダ1442は命令が「順序正しく」実行されなければな らないかを確定するために命令をデコードする。これによって、全ての先行命令 の実行終了までこの命令に対して何もしないようにIEIJに(指示が出される 。一度命令の実行が完了すると、それに続く命令の実行が開始される。
制御フロージャノブサイズデコーダ1444はアドレスを指定するジャンプのデ ィスプレースソフト・サイズを表す。CjJVjIZEとラベルをつけた、この フィールドはツヤノブのアドレス・サイズを指定する。これはCl5C!12命 令七ノドに使用されるアドレス指定方式のタイプに特有のものである。
DECMDEST1446とラベルをつけた1ビツトのデコーダは命令のデステ イネー/−J)がメモリ・アドレスであるか否かを表す。
最後に、命令デコーダはレジスタ・コード(インデックス)選択のために3個の レジスタコードデコーダ1438を含んでいる。蔦486の命令フォーマットは 命令内の様々な場所にあるレジスタ・フィールドのインデックスを符号化する。
これらのフィールドのインデックスはRCデコーダにより抽出される。ModR /Mバイトは2個のレジスタ・インデックスも有しており、それらは演算コード 自体により指定されたデスティネー7:+ノ/ソースとして使用される。レジス タコードデコーダ1438は3つのRCフィールド、RCI、RC,及びRC3 を生成する。プロセッサがエミコレー7ツノ・モードでない場合、RCl及びR C2は以下のようにModR/Mバイトから抽出され、その命令は浮動小数点命 令ではない。即ち、PCI= ModR/Mバイトのビット12:01で、 R C2= MOdR/Mバイトのビット15 : 31で、そしてRC3=演算コ ードのビット12・01゜基本(エミ二し−ンッンでない)モードの浮動小数点 命令では、RCI、RC2、RC3は以下のように割り当てられる。
RCl:5T(o)ニスタックの1層上RC2: 5T(1)= スタックの2 番目のアイテムニスタックの上から2番目RC3: 5T(il = スタック からi番目のアイテムで、そこにおいて、1は演算コードの中に1旨定されてい る。
エミュレ−7ヨン・モードでは、RCI、RC2、RC3は以下のように割り当 てられる。
RCI: バイト3のビット[4:0IRC2・バイト2のビット11:01及 びバイト3のビット[7: 51RC3: バイト2のビット16:11第15 図はC5T−GEN、、NIRJEN、 5ELJENの各デコーダ(+414 .1438、+424)の代表的なブロック並びに論理ゲート図を表すものであ る。この第15図は、ナノ命令オペレーンコンAO及びA1のソース並びにデス ティネー7W1ン・レジスタ・インデックス、さらにロード命令のデスティネー ンラン・レジスタ・インデックスを生成するために、1バイトの演算コード、2 バイトの演算コード及び浮動小数点のデコードされた結果がどのように選択され 、遅延させられ、さらに結合されるかを示す実施例であると理解されるべきもの である。選択、遅延、さらに多重化の技法は、1バイトの演算コード、2バイト の演算コード及び浮動小数点の結果を個別に生成しない信号を除く、命令デコー ダ1202により生成される全ての信号に適用される。さらに、言い換えれば、 この実施例により生成された結果はアプリケ−/ラン専用であり、+486命令 を本発明のナノ命令フォーマットにデコードすることに適用される。しかしなが ら、これらの実施例を通じてこれまでに説明してきた原理はCl5C型からR1 5C型への命令のアライメント及びデコーディングに概ね適用可能である。
先に説明したように、CST GENデフーダ1414はC5Tl、C5T2及 びC5TFの3つの出力を生成し、その各々は4つの定数5ビツトレジスタ・フ ィールド(計20ピット)から成り立っている。SEL GENはもっと先の部 分MuX I 512でのマルチプレクサの選択のためにレジスタ・フィールド 制御信号(FLDI、FLD2、FLD3)を生成する。CST l、C5T2 かC5TFの結果並びにFLDI、FLD2、及びFLDFの結果の選択につい てはマルチプレクサ・ブロック1502に概ね示す通りである。3ビツトのML JXセレクトIQ + 504は、命令が1バイトの演算コード、2バイトの演 算フード、或いはi1動小数点命令を有しているかどうかで結果を選択するため に使用される。
Ωサイクル・パイプライン遅延ラッチ1504はマルチプレクサ1502によっ て選択された結果と、3つのレジスタ制御フィールドのRCI、RC2、RC3 を遅延させるために使用される。Ωパイプライン遅延ラッチ1504への各入力 は対向してクロックされた一対のラッチ1508に送られる。このラッチの内容 はマルチプレクサ1510により選択される。この配列はIAUとの関連で先に 説明したΩサイクル遅延316に類似している。
さらにその先の多重化のステージはブロック1512に示す通りである。マルチ プレクサ1502によって選択された定数レジスタ・フィールドは、+514に 概ね示すように、regclからregc4まで個々にラベルをつけた4つの個 別のフィールドとしてマルチプレクサ1512へ入力される。ブロック1512 への人力としても示したのは、演算フード及びModR/Mバイトからの抽出レ ジスタフィールド、RCI、RC2及びRC3である。概ね1518に示した動 作A1用のソース及びデステイネーン−17のレジスタ・インデックスat−r d及びal−rsだ1すでなく、概ね1516に表わした動作Ao用のソース及 びデステイネーンヨンのレジスタ・インデックスa(jrd及びao−rsを生 成するためにFLD制御信号1520の制御の下プロ、り1512の論理により 、regcフィールド並びにRCフィールドが結合される。
ロード命令のデスティネー7−Iン・レジスタ・インデックスである、インデッ クスld rdもブロック1512で選択される。
4、OZコ一 2 本発明におけるデコードFIFOfDFIFOlのブロック図は第16A図に示 す通りである。DFIFOは4個の完全なバケットを保持し、その各々には4つ のナノ命令、2つのイミディエト・データ・フィールド、及び1つのディスプレ ースソフト・フィールドが入っている。各バケットはDFIFOのルベルのパイ プライン・レジスタに対応している。これらのバケットはIDIJで生成されて IEuが新規のバケットを要求する各サイクル期間中に[)F IFOに押し出 される。バケット内のナノ命令はバケット0及びバケット1と呼ばれる2つのグ ループに分けられる。バケットOはロード、ALU、及び/または格納の動作で 構成され、その動作は1.2、もしくは3ナノ命令に対応している。バケット1 は1ナノ命令に相当するALU動作のみである。この分割の結果、1個のバケッ トは2つのALLJ動作のみを含み、その1つだけがメモリを参照できる。その 後に続く命令が共にメモリ・オペランドを要求する場合、それらの命令は別々の バケットに入れられなければならない。
第168図から分かるように、各バケット及びパケット全体に関する、相当量の 一般的な情報があるだけである。この情報は一般情報FIFOに格納される。デ フォルトでは、1個のバケ)l)内に入った4っのナノ命令がNIROからNl R3への順序で実行される。NlR3はNIRO〜NlR2の前に実行されなけ ればならないことを示すようにバケットの一般情報ビ/トの一つを設定すること ができる。この特徴により連続する命令を単一のバケットにまとめることが容易 になる。何故なら、その順序はもはやパケット要件を満たす能力に影響しないか らである。
第16C図はパケット0〜バケツト4のイミディエト・データ及びディスプレー スメ/トFIFOを示す。IMMOはパケット0に対応するイミディエト・デー タを表し、IMMIはバケット1にt4応するイミディエト・データを表してい る。DISPはバケットOに対応するディスプレースソフトを表わしている。D ISPフィールドはアドレス計算の一部としてしか使用されないから、パケット 1はDISP情報を使用しない。
上述の3タイプのナノ命令の具体例を第17図に示す。フィールドの記述並びに 定義については添付A、ペー、;1〜10に述べる。これらの表は各バケットの 内容についての情報を提供するものである。
本発明に基づく様々な実施例を先に記述してきたが、あくまで例として提示した ものであり、それにより限定されるものではないことが理解されるはずである。
従って、本発明の広さ並びに範囲については上記の例としての実施例によって制 限されるべきものではなく、以下に記載の特許請求の範囲及びそれに相当するも のに従ってのみ定められるべきことである。
区 第5図 第7B図 区 区 く く 恢 区 m 派 区 ○ 昧 第16A図 第16C図 区 恢 フロントページの続き (72)発明者 ニューエン リートロンアメリカ合衆国 95030 カリフ ォルニア州 モンテセレノ、ダニエル プレース(72)発明者 ワシ ジョハ ネス アメリカ合衆1m 94062 カリフォルニア州 レッド ウッド シティ  キングストリート25

Claims (1)

  1. 【特許請求の範囲】 1.複合命令のストリームから複合の可変長コンピュータ命令を抽出してアライ メントするためのシステムで、各複合命令が不定数の命令バイトに細分されてお り、そのシステムが、 (a)複合命令のストリームを受け取るための第1手段と、(b)前記第1手段 に応答して、複合命令のストリームから命令バイト・セットを抽出するための第 2手段と、 (c)前記第2手段に応答して、複合命令の第1命令に対応する命令バイト数を 確定するための第3手段と、 (d)前記第3手段に応答して、前記の該当する命令バイト数に基づいて複合命 令の前記第1命令をアライメントするための第4手段と、(e)前記第4手段に 応答して、複合命令の前記第1命令を出力するための第5手段と、 を備えていることを特徴とするシステム。 2.前記第2手段が抽出シフト制御信号に基づいて複合命令ストリームから命令 バイトを抽出するための抽出シフタを備えていることを特徴とする請求項1記載 のシステム。 3.前記システムが、 少なくとも一つの整列ラッチをさらに備えており、前記第4手段が整列シフト制 御信号に基づいて複合命令をアレイメントすろための整列シフタをさらに備えて おり、前記整列シフタが少なくとも一つの整列ラッチに対してアライメントされ た複合命令バイトを出力することを特徴とする請求項1記載のシステム。 4.前記第3手段が前記整列ラッチから前記のアライメントされた複合命令を受 け取り、さらに前記のアライメントされた複合命令バイトに基づいて複合命令中 の命令バイト数を確定し、出力するための次命令検出器を備えていることを特徴 とすろ請求項3記載のシステム。 5.前記整列シフト制御信号が前記次命令検出器により確定された先行複合命令 の命令バイト数から成り、さらに前記整列シフタが次の複合命令に対応するさら なる命令バイトをアライメントするために前記命令バイト数をシフトし、前記整 列シフタがそれから前記の次の複合命令に対応する前記さらなる命令バイトを前 記の少なくとも1つの整列ラッチに出力することを特徴とする請求項4記載のシ ステム。 6.前記システムが前記の少なくとも一つの整列ラッチから前記のアライメント された複合命令バイトを受け取り、且つ前記のアライメントされた複合命令バイ トの始めに含まれたブレフィックス・バイト数を確定するためのプレフィックス 検出器をさらに備えていることを特徴とする請求項3記載のシステム。 7.前記システムが前記の少なくとも一つの整列ラッチから前記のアライメント された複合命令バイトを受け取るためのプレフィックス検出器をさらに備えてお り、且つ前記のアライメントされた複合命令バイトの始めに含まれたプレフィッ クス・バイト数を確定することを特徴とする請求項5記載のシステム。 8.前記整列シフト制御信号が前記プレフィックス検出器により確定された前記 のプレフィックス・バイト数から成り、且つ対応するプレフィックス・バイト数 をシフトアウトするために、前記整列シフト制御信号が前記整列シフタに受け取 られることを特徴とする請求項6記載のシステム。 9.前記整列シフト制御信号が前記プレフィックス検出器により確定された前記 のプレフィックス・バイト数から成り、且つ対応するプレフィックス・バイト数 をシフトアウトするために前記整列シフタに受け取られることを特徴とする請求 項7記載のシステム。 10.前記の少なくとも一つの整列ラッチからアライメントされた複合命令バイ トを受け取り、且つ前記の抽出された命令バイト中のイミディエト・データ及び ディスプレースメント・データの位置を確定するための第6手段をさらに備えて いる請求項3記載のシステム。 11.前記第6手段が、 (a)前記のアライメントされた複合命令バイトに対応するイミディエト・デー タをアライメントするためのイミディエト・データ・シフタと、(b)前記のア ライメントされた複合命令バイトに対応するディスプレースメント・データをア ライメントするためのディスプレースメント・データ・シフタと、 をさらに備えていることを特徴とする請求項10記載のシステム。 12.前記イミディエト・データ・シフタ及び前記ディスプレースメント・デー タ・ンフタが前記のアライメントされたイミディエト・データ及び前記のアライ メントされたディスプレースメント・データを命令デコーダ・ユニットに直接出 力することを特徴とする請求項11のシステム。 13.前記の第1手段がバスを有することを特徴とする請求項1のシステム。 14.前記バスがバッファ装置から複合命令ストリームを受け取ることを特徴と する請求項13記載のシステム。 15.不定数の命令バイトに各々細分された、複合命令ストリームからの複合の 可変長コンピュータ命令を抽出し、さらに複合命令の個々の命令の命令バイトを アライメントするための方法で、その方法が、(1)複合命令ストリームの一部 を受け取るステップと、(2)抽出シフタを使って、第1命令バイトで始まる命 令バイトの第1セットを抽出するステップと、 (3)前記の命令バイト・セットを整列ラッチに渡すステップと、(4)前記ラ ッチから次命令検出器にアライメントされた命令バイトを出力するステップと、 (5)前記の次命令検出器を使って前記の命令バイト・セットに基づき第1命令 の終わりを確定するステップと、 (6)命令バイトの次のセットを抽出し、且つ整列シフタに供給するために前記 抽出シフタを制御するステップと、(7)次の命令をアライメントして出力する ために前記整列シフタを制御するステップと、 (8)前記整列シフタの前記出力を前記整列ラッチにラッチするステップと、( 9)複合命令ストリーム中の残りの命令バイトに関して4〜8のステップを繰り 返すステップと、 を備えていることを特徴とする方法。 16.前記ラッチからのアライメントされた命令バイトを命令デコード・ユニッ トに出力するステップと、 アライメントされた命令バイトをロード、格納及び算術・論理の動作グループか ら成る1つ以上のナノ命令動作にデコードするステップと、をさらに備えている ことを特徴とする請求項15記載の方法。 17.前記1つ以上のナノ命令動作を事前に定められたロード、格納及び算術論 理の動作フィールドから成る命令バケットに入れるステップと、前記命令パケッ トを第1命令ラッチににそして当該第1命令ラッチが空でない場合は第2命令ラ ッチに格納するステップと、前記命令バケット・フィールドの組み合わせを支配 する所定のルール・セットに基づいて、前記の第1及び第2の命令ラッチの内容 を最終命令バケットに統合するステップと、 をさらに備えていることを特徴とする請求項15記載の方法。 18.前記ラッチからプレフィックス検出器にアライメントされた命令バイトを 出力するステップと、 プレフィックス情報を提供するために、1個以上のプレフィックス・バイトが存 在するか否かを確定するステップとを備えており、プレフィックス・バイトが存 在する場合、(i)前記プレフィックス情報をラッチし、プレフィックス・バイ トが存在しない場合、(ii)前記の次命令検出器の出力を選択することを特徴 とする請求項15記載の方法。 19.サブステツプ(i)が、対応するアライメントされた命令を有する前記ラ ッチ・プレフィックス情報を出力するステップをさらに備えていることを特徴と する請求項18記載の方法。 20.前記最終命令バケットをナノ命令デコーダに出力するステップをさらに備 えていることを特徴とする請求項17記載の方法。 21.不定数の命令バイトを有する複合コンピュータ命令を、縮小命令セット・ コンピュータで処理するためのナノ命令動作にデコードするためのシステムで、 そのシステムが (a)アライメントされた複合命令を受け取るための第1手段と、(b)前記第 1手段から前記のアライメントされた複合命令を受け取り、且つ前記アライメン トされた複合命令をロード、格納及び算術・論理の動作グループから成る1個以 上のナノ命令にデコードするための第2手段と、(c)前記第2手段に応答して 、前記の1個以上のナノ命令動作を事前に定められたロード、格納及び算術・論 理の動作フィールドから成る命令バケットに入れるための第3手段と、 (d)前記第3手段に応答して、前記命令バケットを第1命令ラッチに、そして 当該第1命令ラッチが空でない場合、第2命令ラッチに格納するための第4手段 と、 (e)前記第4手段に応答して、前記命令バケット・フィールドの組み合わせを 支配する所定のルール・セットに基づき、前記第1及び第2命令ラッチの内容を 最終命令バケットに統合するための第5手段と、を備えていることを特徴とする システム。 22.前記命令バケット及び最終バケットが各々第1及び第2命令バケットから 成ることを特徴とする請求項21記載のシステム。 23.前記第1命令パケットが3個ののナノ命令動作フィールドから成ることを 特徴とする請求項22記載のシステム。 24.前記第2命令バケットが1個のナノ命令動作フィールドから成ることを特 徴とする請求項22記載のシステム。 25.前記第1命令バケットの前記3個のナノ命令動作フィールドがロード・ナ ノ命令動作フィールド、格納ナノ命令動作フィールド及び算術論理ナノ命令演算 フィールドから成ることを特徴とする請求項23記載のシステム。 26.前記第2命令バケットの前記の1個のナノ命令動作フィールドが算術論理 ナノ命令演算フィールドから成ることを特徴とする請求項24記載のシステム。 27.以下の条件、 (i)第1及び第2命令ラッチのみが共に1個の算術論理演算を格納する、(i i)第1及び第2命令ラッチのうちの1個のみが1個の算術論理演算を格納し、 もう1個が1つのロード動作、1つの格納動作、及び1つの算術論理演算のみを 格納する、 のうちの1つが存在する場合、前記第1及び第2バケットの前記組み合わせが発 生することを特徴とする請求項21記載のシステム。 28.前記第3手段がマルチプレクサを備えていることを特徴とする請求項21 記載のシステム。 29.前記第4手段が制御ゲートー式を備えていることを特徴とする請求項21 記載のシステム。 30.不定数の命令バイトを有する複合コンピュータ命令を、縮小命令セット・ コンピュータで処理するためのナノ命令動作にデコードするための方法で、その 方法が、 (1)アライメントされた複合命令を受け取るステップと、(2)前記アライメ ントされた複合命令をロード、格納及び算術論理の動作グループから成る1個以 上のナノ命令動作にデコードするステップと、(3)前記の1個以上のナノ命令 動作を事前に定められたロード、格納及び算術論理の動作フィールドから成る命 令バケットの中に入れるステップと、(4)前記命令バケットを第1命令ラッチ に、そして当該第1命令ラッチが空でない場合は、第2命令ラッチに格納するス テップと、(5)前記命令バケット・フィールドの組み合わせを支配する所定の ルールセットに基づいて、前記第1及び第2命令ラッチの内容を最終命令バケッ トに統合するステップと、 を備えていることを特徴とする方法。 31.前記統合するステップが、前記第1及び第2命令ラッチの前記内容を前記 最終命令バケット内の第1及び第2命令バケットに格納するステップをさらに備 えていることを特徴とする請求項30記載の方法。 32.前記統合するステップが、前記第1及び第2命令ラッチの前記内容を前記 第1命令バケット内の3個のナノ命令動作フィールドの中に格納するステップを さらにまた備えていることを特徴とする請求項31記載の方法。 33.前記のさらに格納するステップが、前記第1及び第2命令ラッチの前記内 容を前記第2命令バケット内の1個のナノ命令動作フィールドの中に格納するス テップを備えていることを特徴とする請求項32記載の方法。 34.前記統合するステップが、 (i)前記第1及び第2命令ラッチが共に1つの算術論理演算のみを格納するか 、或いは (ii)前記の第1及び第2命令ラッチのうちの1個のみが1つの算術論理演算 のみを格納し、もう1個が1つのロード動作、1つの格納動作、及び1つの算術 論理演算のみを格約するか、 を確定することによって前記第1及び第2バケットの前記組み合わせを実行する ことを特徴とする請求項30記載の方法。
JP51730693A 1992-03-31 1993-03-30 Cisc型からrisc型命令への変換のためのアライメント並びにデコーディング Expired - Lifetime JP3547052B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US07/857,599 US5438668A (en) 1992-03-31 1992-03-31 System and method for extraction, alignment and decoding of CISC instructions into a nano-instruction bucket for execution by a RISC computer
US857,599 1992-03-31
PCT/JP1993/000417 WO1993020507A2 (en) 1992-03-31 1993-03-30 Cisc to risc instruction translation alignment and decoding

Related Child Applications (8)

Application Number Title Priority Date Filing Date
JP2000007262A Division JP2000215051A (ja) 1992-03-31 2000-01-17 命令ストリ―ムの変換システム
JP2000007264A Division JP3544334B2 (ja) 1992-03-31 2000-01-17 命令ストリームの変換方法
JP2000007259A Division JP3544331B2 (ja) 1992-03-31 2000-01-17 命令ストリームの変換方法
JP2000007263A Division JP3544333B2 (ja) 1992-03-31 2000-01-17 コンピュータシステム
JP2000007260A Division JP3544332B2 (ja) 1992-03-31 2000-01-17 コンピュータシステム
JP2000007265A Division JP3544335B2 (ja) 1992-03-31 2000-01-17 複合命令ストリームのアライメントシステム
JP2000007261A Division JP2000215050A (ja) 1992-03-31 2000-01-17 プロセッサ
JP2000007258A Division JP3544330B2 (ja) 1992-03-31 2000-01-17 命令ストリームの変換システム

Publications (2)

Publication Number Publication Date
JPH07505968A true JPH07505968A (ja) 1995-06-29
JP3547052B2 JP3547052B2 (ja) 2004-07-28

Family

ID=25326342

Family Applications (3)

Application Number Title Priority Date Filing Date
JP51730693A Expired - Lifetime JP3547052B2 (ja) 1992-03-31 1993-03-30 Cisc型からrisc型命令への変換のためのアライメント並びにデコーディング
JP2000007262A Withdrawn JP2000215051A (ja) 1992-03-31 2000-01-17 命令ストリ―ムの変換システム
JP2000007261A Withdrawn JP2000215050A (ja) 1992-03-31 2000-01-17 プロセッサ

Family Applications After (2)

Application Number Title Priority Date Filing Date
JP2000007262A Withdrawn JP2000215051A (ja) 1992-03-31 2000-01-17 命令ストリ―ムの変換システム
JP2000007261A Withdrawn JP2000215050A (ja) 1992-03-31 2000-01-17 プロセッサ

Country Status (6)

Country Link
US (8) US5438668A (ja)
EP (2) EP0636257B1 (ja)
JP (3) JP3547052B2 (ja)
KR (2) KR100343530B1 (ja)
DE (2) DE69329644T2 (ja)
WO (1) WO1993020507A2 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001504957A (ja) * 1996-09-26 2001-04-10 トランスメタ・コーポレーション 先進のプロセッサにおけるメモリ・データ・エリアシング方法および装置

Families Citing this family (244)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5226126A (en) * 1989-02-24 1993-07-06 Nexgen Microsystems Processor having plurality of functional units for orderly retiring outstanding operations based upon its associated tags
US5768575A (en) * 1989-02-24 1998-06-16 Advanced Micro Devices, Inc. Semi-Autonomous RISC pipelines for overlapped execution of RISC-like instructions within the multiple superscalar execution units of a processor having distributed pipeline control for sepculative and out-of-order execution of complex instructions
US5781753A (en) 1989-02-24 1998-07-14 Advanced Micro Devices, Inc. Semi-autonomous RISC pipelines for overlapped execution of RISC-like instructions within the multiple superscalar execution units of a processor having distributed pipeline control for speculative and out-of-order execution of complex instructions
US5438668A (en) * 1992-03-31 1995-08-01 Seiko Epson Corporation System and method for extraction, alignment and decoding of CISC instructions into a nano-instruction bucket for execution by a RISC computer
US5628021A (en) * 1992-12-31 1997-05-06 Seiko Epson Corporation System and method for assigning tags to control instruction processing in a superscalar processor
US5463748A (en) 1993-06-30 1995-10-31 Intel Corporation Instruction buffer for aligning instruction sets using boundary detection
JP3248992B2 (ja) * 1993-07-13 2002-01-21 富士通株式会社 マルチプロセッサ
EP0651320B1 (en) * 1993-10-29 2001-05-23 Advanced Micro Devices, Inc. Superscalar instruction decoder
DE69429061T2 (de) * 1993-10-29 2002-07-18 Advanced Micro Devices, Inc. Superskalarmikroprozessoren
US5903772A (en) * 1993-10-29 1999-05-11 Advanced Micro Devices, Inc. Plural operand buses of intermediate widths coupling to narrower width integer and wider width floating point superscalar processing core
DE69434669T2 (de) * 1993-10-29 2006-10-12 Advanced Micro Devices, Inc., Sunnyvale Spekulative Befehlswarteschlange für Befehle mit variabler Byteslänge
US5689672A (en) * 1993-10-29 1997-11-18 Advanced Micro Devices, Inc. Pre-decoded instruction cache and method therefor particularly suitable for variable byte-length instructions
US5630082A (en) * 1993-10-29 1997-05-13 Advanced Micro Devices, Inc. Apparatus and method for instruction queue scanning
JPH07239780A (ja) * 1994-01-06 1995-09-12 Motohiro Kurisu 1クロック可変長命令実行処理型命令読み込み電子計 算機
US5884057A (en) * 1994-01-11 1999-03-16 Exponential Technology, Inc. Temporal re-alignment of a floating point pipeline to an integer pipeline for emulation of a load-operate architecture on a load/store processor
US5600806A (en) * 1994-03-01 1997-02-04 Intel Corporation Method and apparatus for aligning an instruction boundary in variable length macroinstructions with an instruction buffer
JP3212213B2 (ja) * 1994-03-16 2001-09-25 株式会社日立製作所 データ処理装置
US5574927A (en) * 1994-03-25 1996-11-12 International Meta Systems, Inc. RISC architecture computer configured for emulation of the instruction set of a target computer
EP0679990B1 (en) * 1994-04-28 2000-03-01 Hewlett-Packard Company A computer apparatus having a means to force sequential instruction execution
US5559975A (en) 1994-06-01 1996-09-24 Advanced Micro Devices, Inc. Program counter update mechanism
JP2982618B2 (ja) * 1994-06-28 1999-11-29 日本電気株式会社 メモリ選択回路
US5598546A (en) * 1994-08-31 1997-01-28 Exponential Technology, Inc. Dual-architecture super-scalar pipeline
US5619663A (en) * 1994-09-16 1997-04-08 Philips Electronics North America Corp. Computer instruction prefetch system
US6496922B1 (en) * 1994-10-31 2002-12-17 Sun Microsystems, Inc. Method and apparatus for multiplatform stateless instruction set architecture (ISA) using ISA tags on-the-fly instruction translation
US5640526A (en) * 1994-12-21 1997-06-17 International Business Machines Corporation Superscaler instruction pipeline having boundary indentification logic for variable length instructions
US5832249A (en) * 1995-01-25 1998-11-03 Advanced Micro Devices, Inc. High performance superscalar alignment unit
US6006324A (en) 1995-01-25 1999-12-21 Advanced Micro Devices, Inc. High performance superscalar alignment unit
US5737550A (en) * 1995-03-28 1998-04-07 Advanced Micro Devices, Inc. Cache memory to processor bus interface and method thereof
US5751982A (en) * 1995-03-31 1998-05-12 Apple Computer, Inc. Software emulation system with dynamic translation of emulated instructions for increased processing speed
US5991869A (en) * 1995-04-12 1999-11-23 Advanced Micro Devices, Inc. Superscalar microprocessor including a high speed instruction alignment unit
US5758114A (en) * 1995-04-12 1998-05-26 Advanced Micro Devices, Inc. High speed instruction alignment unit for aligning variable byte-length instructions according to predecode information in a superscalar microprocessor
US5822558A (en) * 1995-04-12 1998-10-13 Advanced Micro Devices, Inc. Method and apparatus for predecoding variable byte-length instructions within a superscalar microprocessor
US5815736A (en) * 1995-05-26 1998-09-29 National Semiconductor Corporation Area and time efficient extraction circuit
US6237074B1 (en) * 1995-05-26 2001-05-22 National Semiconductor Corp. Tagged prefetch and instruction decoder for variable length instruction set and method of operation
US5680578A (en) * 1995-06-07 1997-10-21 Advanced Micro Devices, Inc. Microprocessor using an instruction field to specify expanded functionality and a computer system employing same
US5822778A (en) * 1995-06-07 1998-10-13 Advanced Micro Devices, Inc. Microprocessor and method of using a segment override prefix instruction field to expand the register file
US5768574A (en) * 1995-06-07 1998-06-16 Advanced Micro Devices, Inc. Microprocessor using an instruction field to expand the condition flags and a computer system employing the microprocessor
JP3451595B2 (ja) * 1995-06-07 2003-09-29 インターナショナル・ビジネス・マシーンズ・コーポレーション 二つの別個の命令セット・アーキテクチャへの拡張をサポートすることができるアーキテクチャ・モード制御を備えたマイクロプロセッサ
US5875315A (en) * 1995-06-07 1999-02-23 Advanced Micro Devices, Inc. Parallel and scalable instruction scanning unit
US5867701A (en) * 1995-06-12 1999-02-02 Intel Corporation System for inserting a supplemental micro-operation flow into a macroinstruction-generated micro-operation flow
DE69638241D1 (de) * 1995-08-01 2010-09-30 Bull Hn Information Syst Verfahren für die emulation von programmbefehlen
US5678032A (en) * 1995-09-06 1997-10-14 Bull Hn Information Systems Inc. Method of optimizing the execution of program instuctions by an emulator using a plurality of execution units
US5781789A (en) * 1995-08-31 1998-07-14 Advanced Micro Devices, Inc. Superscaler microprocessor employing a parallel mask decoder
US5809273A (en) * 1996-01-26 1998-09-15 Advanced Micro Devices, Inc. Instruction predecode and multiple instruction decode
US6093213A (en) * 1995-10-06 2000-07-25 Advanced Micro Devices, Inc. Flexible implementation of a system management mode (SMM) in a processor
US5920713A (en) * 1995-10-06 1999-07-06 Advanced Micro Devices, Inc. Instruction decoder including two-way emulation code branching
US5794063A (en) * 1996-01-26 1998-08-11 Advanced Micro Devices, Inc. Instruction decoder including emulation using indirect specifiers
DE69629484D1 (de) * 1995-10-06 2003-09-18 Advanced Micro Devices Inc Befehlsvordekodierung und dekodierung mehrerer befehle
US5819056A (en) * 1995-10-06 1998-10-06 Advanced Micro Devices, Inc. Instruction buffer organization method and system
US5926642A (en) * 1995-10-06 1999-07-20 Advanced Micro Devices, Inc. RISC86 instruction set
US5872947A (en) * 1995-10-24 1999-02-16 Advanced Micro Devices, Inc. Instruction classification circuit configured to classify instructions into a plurality of instruction types prior to decoding said instructions
US5768553A (en) * 1995-10-30 1998-06-16 Advanced Micro Devices, Inc. Microprocessor using an instruction field to define DSP instructions
US5796974A (en) * 1995-11-07 1998-08-18 Advanced Micro Devices, Inc. Microcode patching apparatus and method
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
US5809272A (en) * 1995-11-29 1998-09-15 Exponential Technology Inc. Early instruction-length pre-decode of variable-length instructions in a superscalar processor
US5740392A (en) * 1995-12-27 1998-04-14 Intel Corporation Method and apparatus for fast decoding of 00H and OFH mapped instructions
US5778246A (en) * 1995-12-27 1998-07-07 Intel Corporation Method and apparatus for efficient propagation of attribute bits in an instruction decode pipeline
US5710914A (en) * 1995-12-29 1998-01-20 Atmel Corporation Digital signal processing method and system implementing pipelined read and write operations
US5819080A (en) * 1996-01-02 1998-10-06 Advanced Micro Devices, Inc. Microprocessor using an instruction field to specify condition flags for use with branch instructions and a computer system employing the microprocessor
US5826089A (en) * 1996-01-04 1998-10-20 Advanced Micro Devices, Inc. Instruction translation unit configured to translate from a first instruction set to a second instruction set
JP3634379B2 (ja) * 1996-01-24 2005-03-30 サン・マイクロシステムズ・インコーポレイテッド スタックキャッシングのための方法及び装置
WO1997027537A2 (en) * 1996-01-24 1997-07-31 Sun Microsystems, Inc. A processor for executing instruction sets received from a network or from a local memory
US6105124A (en) * 1996-01-26 2000-08-15 Intel Corporation Method and apparatus for merging binary translated basic blocks of instructions
US5790821A (en) * 1996-03-08 1998-08-04 Advanced Micro Devices, Inc. Control bit vector storage for storing control vectors corresponding to instruction operations in a microprocessor
US5867681A (en) * 1996-05-23 1999-02-02 Lsi Logic Corporation Microprocessor having register dependent immediate decompression
US5822560A (en) * 1996-05-23 1998-10-13 Advanced Micro Devices, Inc. Apparatus for efficient instruction execution via variable issue and variable control vectors per issue
US5896519A (en) * 1996-06-10 1999-04-20 Lsi Logic Corporation Apparatus for detecting instructions from a variable-length compressed instruction set having extended and non-extended instructions
US5905893A (en) * 1996-06-10 1999-05-18 Lsi Logic Corporation Microprocessor adapted for executing both a non-compressed fixed length instruction set and a compressed variable length instruction set
JP2000515275A (ja) * 1996-07-16 2000-11-14 アドバンスト・マイクロ・ディバイシズ・インコーポレイテッド 高速命令整列ユニットを含むスーパースカラマイクロプロセッサ
US6049863A (en) * 1996-07-24 2000-04-11 Advanced Micro Devices, Inc. Predecoding technique for indicating locations of opcode bytes in variable byte-length instructions within a superscalar microprocessor
US5958061A (en) * 1996-07-24 1999-09-28 Transmeta Corporation Host microprocessor with apparatus for temporarily holding target processor state
US5867680A (en) * 1996-07-24 1999-02-02 Advanced Micro Devices, Inc. Microprocessor configured to simultaneously dispatch microcode and directly-decoded instructions
US6199152B1 (en) 1996-08-22 2001-03-06 Transmeta Corporation Translated memory protection apparatus for an advanced microprocessor
US5890009A (en) * 1996-12-12 1999-03-30 International Business Machines Corporation VLIW architecture and method for expanding a parcel
US5870576A (en) * 1996-12-16 1999-02-09 Hewlett-Packard Company Method and apparatus for storing and expanding variable-length program instructions upon detection of a miss condition within an instruction cache containing pointers to compressed instructions for wide instruction word processor architectures
US5918031A (en) * 1996-12-18 1999-06-29 Intel Corporation Computer utilizing special micro-operations for encoding of multiple variant code flows
US5923862A (en) * 1997-01-28 1999-07-13 Samsung Electronics Co., Ltd. Processor that decodes a multi-cycle instruction into single-cycle micro-instructions and schedules execution of the micro-instructions
US5909567A (en) * 1997-02-28 1999-06-01 Advanced Micro Devices, Inc. Apparatus and method for native mode processing in a RISC-based CISC processor
US5852727A (en) * 1997-03-10 1998-12-22 Advanced Micro Devices, Inc. Instruction scanning unit for locating instructions via parallel scanning of start and end byte information
US5875336A (en) * 1997-03-31 1999-02-23 International Business Machines Corporation Method and system for translating a non-native bytecode to a set of codes native to a processor within a computer system
US6047368A (en) * 1997-03-31 2000-04-04 Sun Microsystems, Inc. Processor architecture including grouping circuit
US5940602A (en) * 1997-06-11 1999-08-17 Advanced Micro Devices, Inc. Method and apparatus for predecoding variable byte length instructions for scanning of a number of RISC operations
US6009511A (en) * 1997-06-11 1999-12-28 Advanced Micro Devices, Inc. Apparatus and method for tagging floating point operands and results for rapid detection of special floating point numbers
US5933626A (en) * 1997-06-12 1999-08-03 Advanced Micro Devices, Inc. Apparatus and method for tracing microprocessor instructions
US5930491A (en) * 1997-06-18 1999-07-27 International Business Machines Corporation Identification of related instructions resulting from external to internal translation by use of common ID field for each group
US5978901A (en) * 1997-08-21 1999-11-02 Advanced Micro Devices, Inc. Floating point and multimedia unit with data type reclassification capability
US6230259B1 (en) 1997-10-31 2001-05-08 Advanced Micro Devices, Inc. Transparent extended state save
US6216218B1 (en) 1997-11-03 2001-04-10 Donald L. Sollars Processor having a datapath and control logic constituted with basis execution blocks
US6016539A (en) 1997-11-03 2000-01-18 Teragen Corporation Datapath control logic for processors having instruction set architectures implemented with hierarchically organized primitive operations
US6438679B1 (en) 1997-11-03 2002-08-20 Brecis Communications Multiple ISA support by a processor using primitive operations
US5923894A (en) * 1997-11-03 1999-07-13 Teragen Corporation Adaptable input/output pin control
US5940626A (en) * 1997-11-03 1999-08-17 Teragen Corporation Processor having an instruction set architecture implemented with hierarchically organized primitive operations
US6067601A (en) * 1997-11-03 2000-05-23 Brecis Communications Cache memory based instruction execution
US6178482B1 (en) 1997-11-03 2001-01-23 Brecis Communications Virtual register sets
US6157996A (en) * 1997-11-13 2000-12-05 Advanced Micro Devices, Inc. Processor programably configurable to execute enhanced variable byte length instructions including predicated execution, three operand addressing, and increased register space
US6021484A (en) * 1997-11-14 2000-02-01 Samsung Electronics Co., Ltd. Dual instruction set architecture
US6167506A (en) 1997-11-17 2000-12-26 Advanced Micro Devices, Inc. Replacing displacement in control transfer instruction with encoding indicative of target address, including offset and target cache line location
US6134649A (en) * 1997-11-17 2000-10-17 Advanced Micro Devices, Inc. Control transfer indication in predecode which identifies control transfer instruction and an alternate feature of an instruction
US6134650A (en) * 1997-12-12 2000-10-17 Advanced Micro Devices, Inc. Apparatus and method for predicting a first scanned instruction as microcode instruction prior to scanning predecode data
US6061775A (en) * 1997-12-12 2000-05-09 Advanced Micro Devices, Inc. Apparatus and method for predicting a first microcode instruction of a cache line and using predecode instruction data to identify instruction boundaries and types
US6039765A (en) * 1997-12-15 2000-03-21 Motorola, Inc. Computer instruction which generates multiple results of different data types to improve software emulation
US6012138A (en) * 1997-12-19 2000-01-04 Lsi Logic Corporation Dynamically variable length CPU pipeline for efficiently executing two instruction sets
US6044460A (en) * 1998-01-16 2000-03-28 Lsi Logic Corporation System and method for PC-relative address generation in a microprocessor with a pipeline architecture
US5881260A (en) * 1998-02-09 1999-03-09 Hewlett-Packard Company Method and apparatus for sequencing and decoding variable length instructions with an instruction boundary marker within each instruction
EP1457876B1 (en) * 1998-03-18 2017-10-04 Qualcomm Incorporated Systems for and method of controlling a digital signal processor using a variable length instruction set, method of generating and storing said instructions and memory comprising said instructions
US6425070B1 (en) * 1998-03-18 2002-07-23 Qualcomm, Inc. Variable length instruction decoder
US6014735A (en) * 1998-03-31 2000-01-11 Intel Corporation Instruction set extension using prefixes
US6061786A (en) * 1998-04-23 2000-05-09 Advanced Micro Devices, Inc. Processor configured to select a next fetch address by partially decoding a byte of a control transfer instruction
US6141745A (en) * 1998-04-30 2000-10-31 Advanced Micro Devices, Inc. Functional bit identifying a prefix byte via a particular state regardless of type of instruction
US6175908B1 (en) 1998-04-30 2001-01-16 Advanced Micro Devices, Inc. Variable byte-length instructions using state of function bit of second byte of plurality of instructions bytes as indicative of whether first byte is a prefix byte
US6275927B2 (en) * 1998-09-21 2001-08-14 Advanced Micro Devices. Compressing variable-length instruction prefix bytes
US6253309B1 (en) 1998-09-21 2001-06-26 Advanced Micro Devices, Inc. Forcing regularity into a CISC instruction set by padding instructions
US6460116B1 (en) 1998-09-21 2002-10-01 Advanced Micro Devices, Inc. Using separate caches for variable and generated fixed-length instructions
US6240506B1 (en) 1998-10-02 2001-05-29 Advanced Micro Devices, Inc. Expanding instructions with variable-length operands to a fixed length
US6339822B1 (en) 1998-10-02 2002-01-15 Advanced Micro Devices, Inc. Using padded instructions in a block-oriented cache
US6260134B1 (en) * 1998-11-02 2001-07-10 Advanced Micro Devices, Inc. Fixed shift amount variable length instruction stream pre-decoding for start byte determination based on prefix indicating length vector presuming potential start byte
US6826749B2 (en) 1998-12-08 2004-11-30 Nazomi Communications, Inc. Java hardware accelerator using thread manager
US6332215B1 (en) 1998-12-08 2001-12-18 Nazomi Communications, Inc. Java virtual machine hardware for RISC and CISC processors
US20050149694A1 (en) * 1998-12-08 2005-07-07 Mukesh Patel Java hardware accelerator using microcode engine
US7225436B1 (en) 1998-12-08 2007-05-29 Nazomi Communications Inc. Java hardware accelerator using microcode engine
US7013456B1 (en) 1999-01-28 2006-03-14 Ati International Srl Profiling execution of computer programs
US6954923B1 (en) 1999-01-28 2005-10-11 Ati International Srl Recording classification of instructions executed by a computer
US8074055B1 (en) 1999-01-28 2011-12-06 Ati Technologies Ulc Altering data storage conventions of a processor when execution flows from first architecture code to second architecture code
US8065504B2 (en) * 1999-01-28 2011-11-22 Ati International Srl Using on-chip and off-chip look-up tables indexed by instruction address to control instruction execution in a processor
US7111290B1 (en) 1999-01-28 2006-09-19 Ati International Srl Profiling program execution to identify frequently-executed portions and to assist binary translation
US7065633B1 (en) 1999-01-28 2006-06-20 Ati International Srl System for delivering exception raised in first architecture to operating system coded in second architecture in dual architecture CPU
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
US7275246B1 (en) 1999-01-28 2007-09-25 Ati International Srl Executing programs for a first computer architecture on a computer of a second architecture
US6763452B1 (en) 1999-01-28 2004-07-13 Ati International Srl Modifying program execution based on profiling
US6978462B1 (en) 1999-01-28 2005-12-20 Ati International Srl Profiling execution of a sequence of events occuring during a profiled execution interval that matches time-independent selection criteria of events to be profiled
US7941647B2 (en) 1999-01-28 2011-05-10 Ati Technologies Ulc Computer for executing two instruction sets and adds a macroinstruction end marker for performing iterations after loop termination
US6453407B1 (en) * 1999-02-10 2002-09-17 Infineon Technologies Ag Configurable long instruction word architecture and instruction set
US6581154B1 (en) * 1999-02-17 2003-06-17 Intel Corporation Expanding microcode associated with full and partial width macroinstructions
EP1050799A1 (en) 1999-05-03 2000-11-08 STMicroelectronics S.A. Execution of a computer program
US6779107B1 (en) 1999-05-28 2004-08-17 Ati International Srl Computer execution by opportunistic adaptation
EP1216287B1 (en) 1999-08-19 2005-11-23 Manufacturing And Technology Conversion International, Inc. System integration of a steam reformer and fuel cell
US7213129B1 (en) * 1999-08-30 2007-05-01 Intel Corporation Method and system for a two stage pipelined instruction decode and alignment using previous instruction length
US7254806B1 (en) 1999-08-30 2007-08-07 Ati International Srl Detecting reordered side-effects
US6460132B1 (en) 1999-08-31 2002-10-01 Advanced Micro Devices, Inc. Massively parallel instruction predecoding
US6405303B1 (en) 1999-08-31 2002-06-11 Advanced Micro Devices, Inc. Massively parallel decoding and execution of variable-length instructions
US6438664B1 (en) 1999-10-27 2002-08-20 Advanced Micro Devices, Inc. Microcode patch device and method for patching microcode using match registers and patch routines
AU2745001A (en) * 1999-12-31 2001-07-16 Intel Corporation External microcode
US6934832B1 (en) 2000-01-18 2005-08-23 Ati International Srl Exception mechanism for a computer
US6654872B1 (en) * 2000-01-27 2003-11-25 Ati International Srl Variable length instruction alignment device and method
US6542862B1 (en) * 2000-02-18 2003-04-01 Hewlett-Packard Development Company, L.P. Determining register dependency in multiple architecture systems
US7584234B2 (en) * 2002-05-23 2009-09-01 Qsigma, Inc. Method and apparatus for narrow to very wide instruction generation for arithmetic circuitry
US6968469B1 (en) 2000-06-16 2005-11-22 Transmeta Corporation System and method for preserving internal processor context when the processor is powered down and restoring the internal processor context when processor is restored
US6877084B1 (en) 2000-08-09 2005-04-05 Advanced Micro Devices, Inc. Central processing unit (CPU) accessing an extended register set in an extended register mode
US6981132B2 (en) 2000-08-09 2005-12-27 Advanced Micro Devices, Inc. Uniform register addressing using prefix byte
US6633969B1 (en) 2000-08-11 2003-10-14 Lsi Logic Corporation Instruction translation system and method achieving single-cycle translation of variable-length MIPS16 instructions
SE0003398D0 (sv) * 2000-09-22 2000-09-22 Ericsson Telefon Ab L M Optimization of a pipelined processor system
EP1197847A3 (en) * 2000-10-10 2003-05-21 Nazomi Communications Inc. Java hardware accelerator using microcode engine
US7149878B1 (en) 2000-10-30 2006-12-12 Mips Technologies, Inc. Changing instruction set architecture mode by comparison of current instruction execution address with boundary address register values
US6738792B1 (en) 2001-03-09 2004-05-18 Advanced Micro Devices, Inc. Parallel mask generator
JP4542722B2 (ja) * 2001-04-25 2010-09-15 富士通株式会社 命令処理方法
US7107439B2 (en) * 2001-08-10 2006-09-12 Mips Technologies, Inc. System and method of controlling software decompression through exceptions
US8769508B2 (en) 2001-08-24 2014-07-01 Nazomi Communications Inc. Virtual machine hardware for RISC and CISC processors
US7107584B2 (en) * 2001-10-23 2006-09-12 Microsoft Corporation Data alignment between native and non-native shared data structures
US20030093775A1 (en) * 2001-11-14 2003-05-15 Ronald Hilton Processing of self-modifying code under emulation
US7092869B2 (en) * 2001-11-14 2006-08-15 Ronald Hilton Memory address prediction under emulation
US7493470B1 (en) 2001-12-07 2009-02-17 Arc International, Plc Processor apparatus and methods optimized for control applications
US7278137B1 (en) 2001-12-26 2007-10-02 Arc International Methods and apparatus for compiling instructions for a data processor
EP1470476A4 (en) * 2002-01-31 2007-05-30 Arc Int CONFIGURABLE DATA PROCESSOR WITH MULTI-LENGTH INSTRUCTION KIT ARCHITECTURE
US7785340B2 (en) * 2002-02-04 2010-08-31 Boston Scientific Scimed, Inc. Bonding sleeve for medical device
US6977162B2 (en) * 2002-03-01 2005-12-20 Ravgen, Inc. Rapid analysis of variations in a genome
US6957321B2 (en) 2002-06-19 2005-10-18 Intel Corporation Instruction set extension using operand bearing NOP instructions
EP1387252B1 (en) * 2002-07-31 2019-02-13 Texas Instruments Incorporated Instruction prefix to indicate system commands
EP1387256B1 (en) * 2002-07-31 2018-11-21 Texas Instruments Incorporated Program counter adjustment based on the detection of an instruction prefix
US7349934B2 (en) * 2002-12-20 2008-03-25 Texas Instruments Incorporated Processor system and method with combined data left and right shift operation
US7444471B1 (en) 2002-12-30 2008-10-28 Transmeta Corporation Method and system for using external storage to amortize CPU cycle utilization
EP1447742A1 (en) 2003-02-11 2004-08-18 STMicroelectronics S.r.l. Method and apparatus for translating instructions of an ARM-type processor into instructions for a LX-type processor
US20040193845A1 (en) * 2003-03-24 2004-09-30 Sun Microsystems, Inc. Stall technique to facilitate atomicity in processor execution of helper set
US7219218B2 (en) * 2003-03-31 2007-05-15 Sun Microsystems, Inc. Vector technique for addressing helper instruction groups associated with complex instructions
US7917734B2 (en) * 2003-06-30 2011-03-29 Intel Corporation Determining length of instruction with multiple byte escape code based on information from other than opcode byte
US7707389B2 (en) * 2003-10-31 2010-04-27 Mips Technologies, Inc. Multi-ISA instruction fetch unit for a processor, and applications thereof
US7404178B2 (en) * 2004-02-18 2008-07-22 Hewlett-Packard Development Company, L.P. ROM-embedded debugging of computer
US7873815B2 (en) * 2004-03-04 2011-01-18 Qualcomm Incorporated Digital signal processors with configurable dual-MAC and dual-ALU
US20060101504A1 (en) * 2004-11-09 2006-05-11 Veveo.Tv, Inc. Method and system for performing searches for television content and channels using a non-intrusive television interface and with reduced text input
US20070266406A1 (en) * 2004-11-09 2007-11-15 Murali Aravamudan Method and system for performing actions using a non-intrusive television with reduced text input
US7895218B2 (en) * 2004-11-09 2011-02-22 Veveo, Inc. Method and system for performing searches for television content using reduced text input
US20060155961A1 (en) * 2005-01-06 2006-07-13 International Business Machines Corporation Apparatus and method for reformatting instructions before reaching a dispatch point in a superscalar processor
US7646886B2 (en) * 2005-05-11 2010-01-12 Lockheed Martin Corporation Closely-spaced multiple targets detection using a regional window as a discriminant function
US7543287B2 (en) * 2005-06-30 2009-06-02 Intel Corporation Using a block device interface to invoke device controller functionality
US7454492B2 (en) * 2005-08-26 2008-11-18 International Business Machines Corporation Method and apparatus for configuring and modeling server information in an enterprise tooling environment
US7779011B2 (en) 2005-08-26 2010-08-17 Veveo, Inc. Method and system for dynamically processing ambiguous, reduced text search queries and highlighting results thereof
US7788266B2 (en) 2005-08-26 2010-08-31 Veveo, Inc. Method and system for processing ambiguous, multi-term search queries
US20070074199A1 (en) * 2005-09-27 2007-03-29 Sebastian Schoenberg Method and apparatus for delivering microcode updates through virtual machine operations
US20070083736A1 (en) * 2005-10-06 2007-04-12 Aravindh Baktha Instruction packer for digital signal processor
US7644054B2 (en) * 2005-11-23 2010-01-05 Veveo, Inc. System and method for finding desired results by incremental search using an ambiguous keypad with the input containing orthographic and typographic errors
US7792666B2 (en) * 2006-05-03 2010-09-07 Sony Computer Entertainment Inc. Translation block invalidation prehints in emulation of a target system on a host system
US7739280B2 (en) 2006-03-06 2010-06-15 Veveo, Inc. Methods and systems for selecting and presenting content based on user preference information extracted from an aggregate preference signature
US8073860B2 (en) * 2006-03-30 2011-12-06 Veveo, Inc. Method and system for incrementally selecting and providing relevant search engines in response to a user query
EP4209927A1 (en) 2006-04-20 2023-07-12 Veveo, Inc. User interface methods and systems for selecting and presenting content based on user navigation and selection actions associated with the content
CA2989780C (en) 2006-09-14 2022-08-09 Veveo, Inc. Methods and systems for dynamically rearranging search results into hierarchically organized concept clusters
US7925986B2 (en) 2006-10-06 2011-04-12 Veveo, Inc. Methods and systems for a linear character selection display interface for ambiguous text input
US8078884B2 (en) 2006-11-13 2011-12-13 Veveo, Inc. Method of and system for selecting and presenting content based on user identification
US9177111B1 (en) 2006-11-14 2015-11-03 Hitachi Global Storage Technologies Netherlands B.V. Systems and methods for protecting software
WO2008148012A1 (en) 2007-05-25 2008-12-04 Veveo, Inc. System and method for text disambiguation and context designation in incremental search
US8943539B2 (en) 2007-11-21 2015-01-27 Rovi Guides, Inc. Enabling a friend to remotely modify user data
US8060356B2 (en) 2007-12-19 2011-11-15 Sony Computer Entertainment Inc. Processor emulation using fragment level translation
US8281109B2 (en) 2007-12-27 2012-10-02 Intel Corporation Compressed instruction format
US8028153B2 (en) * 2008-08-14 2011-09-27 International Business Machines Corporation Data dependent instruction decode
CN101853148B (zh) * 2009-05-19 2014-04-23 威盛电子股份有限公司 适用于微处理器的装置及方法
CN101819517B (zh) * 2009-05-19 2013-05-22 威盛电子股份有限公司 适用于微处理器的装置及方法
US9166714B2 (en) 2009-09-11 2015-10-20 Veveo, Inc. Method of and system for presenting enriched video viewing analytics
TWI424445B (zh) 2009-12-29 2014-01-21 Macronix Int Co Ltd 指令解碼電路及其方法
US20110191332A1 (en) 2010-02-04 2011-08-04 Veveo, Inc. Method of and System for Updating Locally Cached Content Descriptor Information
WO2012103359A2 (en) 2011-01-27 2012-08-02 Soft Machines, Inc. Hardware acceleration components for translating guest instructions to native instructions
WO2012103253A2 (en) 2011-01-27 2012-08-02 Soft Machines, Inc. Multilevel conversion table cache for translating guest instructions to native instructions
WO2012103245A2 (en) 2011-01-27 2012-08-02 Soft Machines Inc. Guest instruction block with near branching and far branching sequence construction to native instruction block
WO2012103373A2 (en) 2011-01-27 2012-08-02 Soft Machines, Inc. Variable caching structure for managing physical storage
KR101612594B1 (ko) 2011-01-27 2016-04-14 소프트 머신즈, 인크. 프로세서의 변환 룩 어사이드 버퍼를 이용하는 게스트 명령-네이티브 명령 레인지 기반 매핑
WO2012103367A2 (en) 2011-01-27 2012-08-02 Soft Machines, Inc. Guest to native block address mappings and management of native code storage
US9141389B2 (en) 2011-04-07 2015-09-22 Via Technologies, Inc. Heterogeneous ISA microprocessor with shared hardware ISA registers
US9244686B2 (en) 2011-04-07 2016-01-26 Via Technologies, Inc. Microprocessor that translates conditional load/store instructions into variable number of microinstructions
US9043580B2 (en) 2011-04-07 2015-05-26 Via Technologies, Inc. Accessing model specific registers (MSR) with different sets of distinct microinstructions for instructions of different instruction set architecture (ISA)
US9645822B2 (en) 2011-04-07 2017-05-09 Via Technologies, Inc Conditional store instructions in an out-of-order execution microprocessor
US9274795B2 (en) 2011-04-07 2016-03-01 Via Technologies, Inc. Conditional non-branch instruction prediction
US9378019B2 (en) 2011-04-07 2016-06-28 Via Technologies, Inc. Conditional load instructions in an out-of-order execution microprocessor
US8880851B2 (en) 2011-04-07 2014-11-04 Via Technologies, Inc. Microprocessor that performs X86 ISA and arm ISA machine language program instructions by hardware translation into microinstructions executed by common execution pipeline
US8880857B2 (en) * 2011-04-07 2014-11-04 Via Technologies, Inc. Conditional ALU instruction pre-shift-generated carry flag propagation between microinstructions in read-port limited register file microprocessor
US9317288B2 (en) 2011-04-07 2016-04-19 Via Technologies, Inc. Multi-core microprocessor that performs x86 ISA and ARM ISA machine language program instructions by hardware translation into microinstructions executed by common execution pipeline
US9176733B2 (en) 2011-04-07 2015-11-03 Via Technologies, Inc. Load multiple and store multiple instructions in a microprocessor that emulates banked registers
US9146742B2 (en) 2011-04-07 2015-09-29 Via Technologies, Inc. Heterogeneous ISA microprocessor that preserves non-ISA-specific configuration state when reset to different ISA
US9292470B2 (en) 2011-04-07 2016-03-22 Via Technologies, Inc. Microprocessor that enables ARM ISA program to access 64-bit general purpose registers written by x86 ISA program
US8924695B2 (en) 2011-04-07 2014-12-30 Via Technologies, Inc. Conditional ALU instruction condition satisfaction propagation between microinstructions in read-port limited register file microprocessor
US9128701B2 (en) * 2011-04-07 2015-09-08 Via Technologies, Inc. Generating constant for microinstructions from modified immediate field during instruction translation
US9898291B2 (en) 2011-04-07 2018-02-20 Via Technologies, Inc. Microprocessor with arm and X86 instruction length decoders
US9336180B2 (en) 2011-04-07 2016-05-10 Via Technologies, Inc. Microprocessor that makes 64-bit general purpose registers available in MSR address space while operating in non-64-bit mode
US9032189B2 (en) 2011-04-07 2015-05-12 Via Technologies, Inc. Efficient conditional ALU instruction in read-port limited register file microprocessor
US8645618B2 (en) 2011-07-14 2014-02-04 Lsi Corporation Flexible flash commands
US8806112B2 (en) 2011-07-14 2014-08-12 Lsi Corporation Meta data handling within a flash media controller
JP5932347B2 (ja) * 2012-01-18 2016-06-08 ピーエスフォー ルクスコ エスエイアールエルPS4 Luxco S.a.r.l. 半導体装置
CN103279325B (zh) * 2013-03-11 2015-12-09 浙江大学 加密文本数据时可提高SoC处理器指令运算效率的方法
WO2014151652A1 (en) 2013-03-15 2014-09-25 Soft Machines Inc Method and apparatus to allow early dependency resolution and data forwarding in a microprocessor
CN105122206B (zh) 2013-03-15 2018-11-09 英特尔公司 用于支持推测的访客返回地址栈仿真的方法和装置
US20140281398A1 (en) * 2013-03-16 2014-09-18 William C. Rash Instruction emulation processors, methods, and systems
US9792112B2 (en) 2013-08-28 2017-10-17 Via Technologies, Inc. Propagation of microcode patches to multiple cores in multicore microprocessor
US9465432B2 (en) 2013-08-28 2016-10-11 Via Technologies, Inc. Multi-core synchronization mechanism
US9891927B2 (en) 2013-08-28 2018-02-13 Via Technologies, Inc. Inter-core communication via uncore RAM
US10157164B2 (en) * 2016-09-20 2018-12-18 Qualcomm Incorporated Hierarchical synthesis of computer machine instructions
US11204768B2 (en) 2019-11-06 2021-12-21 Onnivation Llc Instruction length based parallel instruction demarcator
FR3106422B1 (fr) 2020-01-20 2021-12-10 Continental Automotive Passerelle de communication de trames de données pour véhicule automobile
JP2024056266A (ja) * 2022-10-11 2024-04-23 富士通株式会社 プロセッサ

Family Cites Families (114)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US510341A (en) * 1893-12-05 Composition and process of producing same for commutator-brushes
US3346851A (en) * 1964-07-08 1967-10-10 Control Data Corp Simultaneous multiprocessing computer system
US3789365A (en) * 1971-06-03 1974-01-29 Bunker Ramo Processor interrupt system
US3771138A (en) * 1971-08-31 1973-11-06 Ibm Apparatus and method for serializing instructions from two independent instruction streams
US3916388A (en) * 1974-05-30 1975-10-28 Ibm Shifting apparatus for automatic data alignment
US4084235A (en) * 1975-04-14 1978-04-11 Honeywell Information Systems Inc. Emulation apparatus
US4034349A (en) * 1976-01-29 1977-07-05 Sperry Rand Corporation Apparatus for processing interrupts in microprocessing systems
AU529675B2 (en) * 1977-12-07 1983-06-16 Honeywell Information Systems Incorp. Cache memory unit
US4315314A (en) * 1977-12-30 1982-02-09 Rca Corporation Priority vectored interrupt having means to supply branch address directly
US4200927A (en) * 1978-01-03 1980-04-29 International Business Machines Corporation Multi-instruction stream branch processing mechanism
US4189768A (en) * 1978-03-16 1980-02-19 International Business Machines Corporation Operand fetch control improvement
US4189772A (en) * 1978-03-16 1980-02-19 International Business Machines Corporation Operand alignment controls for VFL instructions
US4236206A (en) * 1978-10-25 1980-11-25 Digital Equipment Corporation Central processor unit for executing instructions of variable length
US4228495A (en) * 1978-12-19 1980-10-14 Allen-Bradley Company Multiprocessor numerical control system
JPS6041768B2 (ja) * 1979-01-19 1985-09-18 株式会社日立製作所 デ−タ処理装置
US4296470A (en) * 1979-06-21 1981-10-20 International Business Machines Corp. Link register storage and restore system for use in an instruction pre-fetch micro-processor interrupt system
JPS5616248A (en) * 1979-07-17 1981-02-17 Matsushita Electric Ind Co Ltd Processing system for interruption
CA1174370A (en) * 1980-05-19 1984-09-11 Hidekazu Matsumoto Data processing unit with pipelined operands
JPS5743239A (en) * 1980-08-27 1982-03-11 Hitachi Ltd Data processor
JPS6028015B2 (ja) * 1980-08-28 1985-07-02 日本電気株式会社 情報処理装置
US4434461A (en) * 1980-09-15 1984-02-28 Motorola, Inc. Microprocessor with duplicate registers for processing interrupts
JPS5757345A (en) * 1980-09-24 1982-04-06 Toshiba Corp Data controller
US4654781A (en) * 1981-10-02 1987-03-31 Raytheon Company Byte addressable memory for variable length instructions and data
JPS58151655A (ja) * 1982-03-03 1983-09-08 Fujitsu Ltd 情報処理装置
US4514803A (en) * 1982-04-26 1985-04-30 International Business Machines Corporation Methods for partitioning mainframe instruction sets to implement microprocessor based emulation thereof
JPS5932045A (ja) 1982-08-16 1984-02-21 Hitachi Ltd 情報処理装置
US4587612A (en) * 1982-10-22 1986-05-06 International Business Machines Corporation Accelerated instruction mapping external to source and target instruction streams for near realtime injection into the latter
JPS59154546A (ja) * 1983-02-24 1984-09-03 Toshiba Corp 情報処理装置
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
US4800486A (en) * 1983-09-29 1989-01-24 Tandem Computers Incorporated Multiple data patch CPU architecture
US4807115A (en) * 1983-10-07 1989-02-21 Cornell Research Foundation, Inc. Instruction issuing mechanism for processors with multiple functional units
GB8329509D0 (en) * 1983-11-04 1983-12-07 Inmos Ltd Computer
US4629989A (en) * 1983-11-10 1986-12-16 General Electric Company Patient alignment system for NMR studies
US4720779A (en) * 1984-06-28 1988-01-19 Burroughs Corporation Stored logic program scanner for a data processor having internal plural data and instruction streams
US4766564A (en) * 1984-08-13 1988-08-23 International Business Machines Corporation Dual putaway/bypass busses for multiple arithmetic units
US5025368A (en) * 1984-12-27 1991-06-18 Sony Corporation Microprocessor with option area adjacent CPU core facilitating interfacing with peripheral devices
US4714994A (en) * 1985-04-30 1987-12-22 International Business Machines Corp. Instruction prefetch buffer control
JPH0762823B2 (ja) * 1985-05-22 1995-07-05 株式会社日立製作所 デ−タ処理装置
US4739471A (en) * 1985-06-28 1988-04-19 Hewlett-Packard Company Method and means for moving bytes in a reduced instruction set computer
US4722049A (en) * 1985-10-11 1988-01-26 Unisys Corporation Apparatus for out-of-order program execution
JPS62152043A (ja) * 1985-12-26 1987-07-07 Nec Corp 命令コ−ドアクセス制御方式
JPS62165242A (ja) * 1986-01-17 1987-07-21 Toshiba Corp プロセツサ
DE3751503T2 (de) * 1986-03-26 1996-05-09 Hitachi Ltd Datenprozessor in Pipelinestruktur mit der Fähigkeit mehrere Befehle parallel zu dekodieren und auszuführen.
US4903196A (en) * 1986-05-02 1990-02-20 International Business Machines Corporation Method and apparatus for guaranteeing the logical integrity of data in the general purpose registers of a complex multi-execution unit uniprocessor
JPS6324428A (ja) * 1986-07-17 1988-02-01 Mitsubishi Electric Corp キヤツシユメモリ
US4766566A (en) * 1986-08-18 1988-08-23 International Business Machines Corp. Performance enhancement scheme for a RISC type VLSI processor using dual execution units for parallel instruction processing
US4841476A (en) * 1986-10-06 1989-06-20 International Business Machines Corporation Extended floating point operations supporting emulation of source instruction execution
US5133072A (en) * 1986-11-13 1992-07-21 Hewlett-Packard Company Method for improved code generation in reduced instruction set computers
JPS63131230A (ja) * 1986-11-21 1988-06-03 Hitachi Ltd 情報処理装置
US4992934A (en) * 1986-12-15 1991-02-12 United Technologies Corporation Reduced instruction set computing apparatus and methods
CA1278382C (en) * 1986-12-15 1990-12-27 Brian J. Sprague Reduced instruction set computing apparatus and methods
US4814976C1 (en) * 1986-12-23 2002-06-04 Mips Tech Inc Risc computer with unaligned reference handling and method for the same
JPS63163930A (ja) * 1986-12-26 1988-07-07 Toshiba Corp アライメント補正方式
US5226170A (en) * 1987-02-24 1993-07-06 Digital Equipment Corporation Interface between processor and special instruction processor in digital data processing system
US4992938A (en) * 1987-07-01 1991-02-12 International Business Machines Corporation Instruction control mechanism for a computing system with register renaming, map table and queues indicating available registers
US4926323A (en) * 1988-03-03 1990-05-15 Advanced Micro Devices, Inc. Streamlined instruction processor
US4992930A (en) * 1988-05-09 1991-02-12 Bull Hn Information Systems Inc. Synchronous cache memory system incorporating tie-breaker apparatus for maintaining cache coherency using a duplicate directory
US5003462A (en) * 1988-05-31 1991-03-26 International Business Machines Corporation Apparatus and method for implementing precise interrupts on a pipelined processor with multiple functional units with separate address translation interrupt means
US4897810A (en) * 1988-06-13 1990-01-30 Advanced Micro Devices, Inc. Asynchronous interrupt status bit circuit
JP3034257B2 (ja) * 1988-06-22 2000-04-17 大日本印刷株式会社 シャドウマスク製版用パターン及び製造方法
US5006980A (en) * 1988-07-20 1991-04-09 Digital Equipment Corporation Pipelined digital CPU with deadlock resolution
US5019967A (en) * 1988-07-20 1991-05-28 Digital Equipment Corporation Pipeline bubble compression in a computer system
JPH0673105B2 (ja) * 1988-08-11 1994-09-14 株式会社東芝 命令パイプライン方式のマイクロプロセッサ
US5101341A (en) * 1988-08-25 1992-03-31 Edgcore Technology, Inc. Pipelined system for reducing instruction access time by accumulating predecoded instruction bits a FIFO
JPH0638676B2 (ja) * 1988-09-19 1994-05-18 松下電工株式会社 ワイヤレス送信制御システム
JP2810068B2 (ja) * 1988-11-11 1998-10-15 株式会社日立製作所 プロセッサシステム、コンピュータシステム及び命令処理方法
GB8828817D0 (en) * 1988-12-09 1989-01-18 Int Computers Ltd Data processing apparatus
US5127091A (en) * 1989-01-13 1992-06-30 International Business Machines Corporation System for reducing delay in instruction execution by executing branch instructions in separate processor while dispatching subsequent instructions to primary processor
US5075840A (en) * 1989-01-13 1991-12-24 International Business Machines Corporation Tightly coupled multiprocessor instruction synchronization
US5249273A (en) * 1989-01-17 1993-09-28 Fujitsu Limited Microprocessor having a variable length instruction format
US5148528A (en) * 1989-02-03 1992-09-15 Digital Equipment Corporation Method and apparatus for simultaneously decoding three operands in a variable length instruction when one of the operands is also of variable length
US4985825A (en) * 1989-02-03 1991-01-15 Digital Equipment Corporation System for delaying processing of memory access exceptions until the execution stage of an instruction pipeline of a virtual memory system based digital computer
US5113515A (en) * 1989-02-03 1992-05-12 Digital Equipment Corporation Virtual instruction cache system using length responsive decoded instruction shifting and merging with prefetch buffer outputs to fill instruction buffer
US5768575A (en) * 1989-02-24 1998-06-16 Advanced Micro Devices, Inc. Semi-Autonomous RISC pipelines for overlapped execution of RISC-like instructions within the multiple superscalar execution units of a processor having distributed pipeline control for sepculative and out-of-order execution of complex instructions
US5226126A (en) * 1989-02-24 1993-07-06 Nexgen Microsystems Processor having plurality of functional units for orderly retiring outstanding operations based upon its associated tags
GB2230116B (en) * 1989-04-07 1993-02-17 Intel Corp An improvement for pipelined decoding of instructions in a pipelined processor
CA2016068C (en) * 1989-05-24 2000-04-04 Robert W. Horst Multiple instruction issue computer architecture
JPH0314025A (ja) * 1989-06-13 1991-01-22 Nec Corp 命令実行制御方式
EP0419105B1 (en) * 1989-09-21 1997-08-13 Texas Instruments Incorporated Integrated circuit formed on a surface of a semiconductor substrate and method for constructing such an integrated circuit
US5019937A (en) * 1989-10-30 1991-05-28 A. B. Chance Company Circuit improvement apparatus having combination current limiting fuse and resettable vacuum switch to prevent single-phasing of three-phase loads
JP2835103B2 (ja) * 1989-11-01 1998-12-14 富士通株式会社 命令指定方法及び命令実行方式
US5487156A (en) * 1989-12-15 1996-01-23 Popescu; Valeri Processor architecture having independently fetching issuing and updating operations of instructions which are sequentially assigned and stored in order fetched
US5193206A (en) * 1989-12-27 1993-03-09 Motorola, Inc. Reduce instruction set microprocessor
US5168571A (en) * 1990-01-24 1992-12-01 International Business Machines Corporation System for aligning bytes of variable multi-bytes length operand based on alu byte length and a number of unprocessed byte data
US5230068A (en) * 1990-02-26 1993-07-20 Nexgen Microsystems Cache memory system for dynamically altering single cache memory line as either branch target entry or pre-fetch instruction queue based upon instruction sequence
DE69130588T2 (de) * 1990-05-29 1999-05-27 National Semiconductor Corp., Santa Clara, Calif. Cache-Speicher von partiell decodierten Befehlen und Verfahren hierfür
CA2038264C (en) 1990-06-26 1995-06-27 Richard James Eickemeyer In-memory preprocessor for a scalable compound instruction set machine processor
US5778423A (en) * 1990-06-29 1998-07-07 Digital Equipment Corporation Prefetch instruction for improving performance in reduced instruction set processor
US5155843A (en) * 1990-06-29 1992-10-13 Digital Equipment Corporation Error transition mode for multi-processor system
US5430862A (en) * 1990-06-29 1995-07-04 Bull Hn Information Systems Inc. Emulation of CISC instructions by RISC instructions using two pipelined stages for overlapped CISC decoding and RISC execution
US5163139A (en) * 1990-08-29 1992-11-10 Hitachi America, Ltd. Instruction preprocessor for conditionally combining short memory instructions into virtual long instructions
DE69130723T2 (de) * 1990-10-05 1999-07-22 Koninklijke Philips Electronics N.V., Eindhoven Verarbeitungsgerät mit Speicherschaltung und eine Gruppe von Funktionseinheiten
US5507030A (en) * 1991-03-07 1996-04-09 Digitial Equipment Corporation Successive translation, execution and interpretation of computer program having code at unknown locations due to execution transfer instructions having computed destination addresses
US5450575A (en) * 1991-03-07 1995-09-12 Digital Equipment Corporation Use of stack depth to identify machine code mistakes
US5307492A (en) * 1991-03-07 1994-04-26 Digital Equipment Corporation Mapping assembly language argument list references in translating code for different machine architectures
US5307504A (en) * 1991-03-07 1994-04-26 Digital Equipment Corporation System and method for preserving instruction granularity when translating program code from a computer having a first architecture to a computer having a second reduced architecture during the occurrence of interrupts due to asynchronous events
US5539911A (en) * 1991-07-08 1996-07-23 Seiko Epson Corporation High-performance, superscalar-based computer system with out-of-order instruction execution
KR100299691B1 (ko) 1991-07-08 2001-11-22 구사마 사부로 확장가능알아이에스씨마이크로프로세서구조
US5438668A (en) * 1992-03-31 1995-08-01 Seiko Epson Corporation System and method for extraction, alignment and decoding of CISC instructions into a nano-instruction bucket for execution by a RISC computer
US5335460A (en) * 1992-04-27 1994-08-09 Smith Jr Joseph H Tilt to clean gutter system
DE69429061T2 (de) * 1993-10-29 2002-07-18 Advanced Micro Devices, Inc. Superskalarmikroprozessoren
US5574927A (en) * 1994-03-25 1996-11-12 International Meta Systems, Inc. RISC architecture computer configured for emulation of the instruction set of a target computer
US5819056A (en) * 1995-10-06 1998-10-06 Advanced Micro Devices, Inc. Instruction buffer organization method and system
US5778210A (en) * 1996-01-11 1998-07-07 Intel Corporation Method and apparatus for recovering the state of a speculatively scheduled operation in a processor which cannot be executed at the speculated time
US6138271A (en) * 1996-06-26 2000-10-24 Rockwell Technologies, Llc Operating system for embedded computers
JP3274608B2 (ja) * 1996-07-12 2002-04-15 日本電気株式会社 携帯端末装置
US5832205A (en) * 1996-08-20 1998-11-03 Transmeta Corporation Memory controller for a microprocessor for detecting a failure of speculation on the physical nature of a component being addressed
US6442570B1 (en) * 1997-10-27 2002-08-27 Microsoft Corporation Object identification and data communication during an object synchronization process
US6671745B1 (en) * 1998-03-23 2003-12-30 Microsoft Corporation Application program interfaces and structures in a resource limited operating system
US6253309B1 (en) * 1998-09-21 2001-06-26 Advanced Micro Devices, Inc. Forcing regularity into a CISC instruction set by padding instructions
US6862617B1 (en) * 1998-10-12 2005-03-01 Microsoft Corp. System and method for synchronizing objects between two devices
US7032213B1 (en) * 1999-09-01 2006-04-18 Microsoft Corporation Fixing incompatible applications using a light debugger
US6959330B1 (en) * 2000-05-16 2005-10-25 Palmsource, Inc. Sync-time read only memory image binding for limited resource devices
WO2005107929A2 (en) * 2004-04-22 2005-11-17 Siemens Water Technologies Corp. Filtration apparatus comprising a membrane bioreactor and a treatment vessel for digesting organic materials

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001504957A (ja) * 1996-09-26 2001-04-10 トランスメタ・コーポレーション 先進のプロセッサにおけるメモリ・データ・エリアシング方法および装置

Also Published As

Publication number Publication date
DE69329644D1 (de) 2000-12-14
US7343473B2 (en) 2008-03-11
US5546552A (en) 1996-08-13
EP0636257B1 (en) 2000-11-08
KR100343530B1 (ko) 2002-11-27
US5983334A (en) 1999-11-09
EP1028370A2 (en) 2000-08-16
US7664935B2 (en) 2010-02-16
US6263423B1 (en) 2001-07-17
EP1028370A3 (en) 2002-02-20
KR100371929B1 (ko) 2003-02-12
US5438668A (en) 1995-08-01
KR950701100A (ko) 1995-02-20
US6954847B2 (en) 2005-10-11
DE69329644T2 (de) 2001-03-01
US20030084270A1 (en) 2003-05-01
EP0636257A1 (en) 1995-02-01
WO1993020507A3 (en) 1994-01-06
JP2000215050A (ja) 2000-08-04
WO1993020507A2 (en) 1993-10-14
JP2000215051A (ja) 2000-08-04
EP1028370B1 (en) 2004-09-15
US20080162880A1 (en) 2008-07-03
US5619666A (en) 1997-04-08
DE69333630D1 (de) 2004-10-21
JP3547052B2 (ja) 2004-07-28
DE69333630T2 (de) 2005-09-22
US20050251653A1 (en) 2005-11-10

Similar Documents

Publication Publication Date Title
JPH07505968A (ja) Cisc型からrisc型命令への変換のためのアライメント並びにデコーディング
KR100327777B1 (ko) 다중명령 세트를 이용한 데이터 프로세싱 장치
JPH07334361A (ja) 命令を処理するためのパイプラインを有するマイクロプロセッサ装置およびそれにおいて用いるためのプログラムカウンタ値を発生する装置
JPH03174626A (ja) データ処理装置
JPH01214932A (ja) データ処理装置
JPH0391029A (ja) データ処理装置
JPS6160459B2 (ja)
JP3544330B2 (ja) 命令ストリームの変換システム
JP3732233B2 (ja) スーパースカラマイクロプロセッサ内で可変バイト長命令をプリデコードするための方法および装置
TWI223773B (en) Suppression of store checking
TWI222015B (en) Mechanism for extending the number of registers in a microprocessor
TW200417926A (en) Selective interrupt suppression
JPH1021071A (ja) 複数の命令を処理するプロセッサ動作方法

Legal Events

Date Code Title Description
A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20040105

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20040220

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20040409

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20090423

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100423

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110423

Year of fee payment: 7

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110423

Year of fee payment: 7

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120423

Year of fee payment: 8

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120423

Year of fee payment: 8

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130423

Year of fee payment: 9