JP2004326748A - 例外条件を解消するために同時マルチスレッド・プロセッサでディスパッチ・フラッシュを使用する方法 - Google Patents
例外条件を解消するために同時マルチスレッド・プロセッサでディスパッチ・フラッシュを使用する方法 Download PDFInfo
- Publication number
- JP2004326748A JP2004326748A JP2004105227A JP2004105227A JP2004326748A JP 2004326748 A JP2004326748 A JP 2004326748A JP 2004105227 A JP2004105227 A JP 2004105227A JP 2004105227 A JP2004105227 A JP 2004105227A JP 2004326748 A JP2004326748 A JP 2004326748A
- Authority
- JP
- Japan
- Prior art keywords
- instruction
- thread
- dispatch
- instructions
- shared
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 35
- 238000012545 processing Methods 0.000 claims abstract description 25
- 230000000903 blocking effect Effects 0.000 claims description 16
- 238000004891 communication Methods 0.000 claims description 6
- 230000004044 response Effects 0.000 claims description 6
- 238000013519 translation Methods 0.000 claims description 5
- 230000008878 coupling Effects 0.000 claims description 2
- 238000010168 coupling process Methods 0.000 claims description 2
- 238000005859 coupling reaction Methods 0.000 claims description 2
- 238000012360 testing method Methods 0.000 description 28
- 230000008901 benefit Effects 0.000 description 9
- 239000002699 waste material Substances 0.000 description 7
- 238000010586 diagram Methods 0.000 description 4
- 230000008569 process Effects 0.000 description 4
- 238000011010 flushing procedure Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 238000003491 array Methods 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000007423 decrease Effects 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000000605 extraction Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 1
- 230000001351 cycling effect Effects 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000008030 elimination Effects 0.000 description 1
- 238000003379 elimination reaction Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3836—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
- G06F9/3851—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution from multiple instruction streams, e.g. multistreaming
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3861—Recovery, e.g. branch miss-prediction, exception handling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3867—Concurrent instruction execution, e.g. pipeline or look ahead using instruction pipelines
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Multimedia (AREA)
- Advance Control (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
【解決手段】共用ディスパッチ・パイプラインを使用する複数スレッドからの命令の処理は、ディスパッチ・フラッシュ・オペレーションを呼び出すことによって制御され、選択されスレッドの命令が、フラッシュされる。検出された例外条件は、次の命令を発行することにより解消する。例外条件が解消されるまで、第2のスレッドをディスパッチ可能にするリソースは解放されず、例外条件を解消する第1のスレッドのディスパッチを妨げる。第1のスレッドのフラッシュは機能停止を解消せず、第2のスレッドのディスパッチ・フラッシュが発行される。第2のスレッド命令が、例外を解消するために第1のスレッドがディスパッチするのを妨げる長い待ち時間のリソース要件を有する場合、第2のスレッド命令が再フェッチの制御するホールドが発行される。
【選択図】図1
Description
第1のスレッドの第1の命令において例外条件を検出するステップを含み、前記第1の命令は、前記第1の命令に続く前記第1のスレッドの第2の命令のディスパッチを必要とするものであって、
さらに前記方法は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドの命令に関してディスパッチ・フラッシュ・オペレーションを発行するステップを含み、前記第2の命令は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドのブロック命令によってディスパッチをブロックされる方法。
(2)前記ブロック命令は、前記第1の命令が完了するまで解放されない前記第1の命令によって使用されるリソース要件を有することを理由に、前記第2の命令をブロックしている、請求項1に記載の方法。
(3)前記ブロック命令が、いずれかの命令が前記共用ディスパッチ・パイプラインからディスパッチされる前に合致しなければならない長い待ち時間の共用リソース要件を有するかどうかを判定するステップと、
前記第2のスレッドのフラッシュ済み命令が再フェッチされる時点、および前記フラッシュ済み命令中で選択された命令に応答して共用ディスパッチ・パイプラインに再入する時点を制御する、選択済みホールドを設定するホールド・コマンドを発行するステップとを含む、請求項1に記載の方法。
(4)前記選択済みホールドは、前記第2のスレッドの命令が、前記ディスパッチ・パイプライン内のディスパッチ待ち行列からフラッシュし、前記ディスパッチ待ち行列に入るが、前記CLBホールドが除去されるまでディスパッチされないことを可能にする、キャッシュ・ライン・バッファ(CLB)ホールドである、請求項3に記載の方法。
(5)前記ブロック命令は、変換索引バッファ例外無効化(Translation Look Aside Buffer Invalidate Exception)命令またはSync命令を含む、請求項3に記載の方法。
(6)共用ディスパッチ・パイプラインを有する同時マルチスレッド(SMT)プロセッサであって、前記プロセッサは、
第1のスレッドの第1の命令において例外条件を検出するための回路を含み、前記第1の命令は、前記第1の命令に続く前記第1のスレッドの第2の命令のディスパッチを必要とするものであって、
さらに前記プロセッサは、前記共用ディスパッチ・パイプライン内の前記第2のスレッドの命令に関してディスパッチ・フラッシュ・オペレーションを発行する回路を含み、前記第2の命令は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドのブロック命令によってディスパッチをブロックされるプロセッサ。
(7)前記ブロック命令は、前記第1の命令が完了するまで解放されない前記第1の命令によって使用されるリソース要件を有することを理由に、前記第2の命令をブロックしている、請求項6に記載のプロセッサ。
(8)前記ブロック命令が、いずれかの命令が前記共用ディスパッチ・パイプラインからディスパッチされる前に合致しなければならない長い待ち時間の共用リソース要件を有するかどうかを判定するための回路と、
前記第2のスレッドのフラッシュ済み命令が再フェッチされる時点、および前記フラッシュ済み命令中で選択された命令に応答して共用ディスパッチ・パイプラインに再入する時点を制御する、選択済みホールドを設定するホールド・コマンドを発行するための回路とを含む、請求項6に記載のプロセッサ。
(9)前記選択済みホールドは、前記第2のスレッドの命令が、前記ディスパッチ・パイプライン内のディスパッチ待ち行列からフラッシュし、前記ディスパッチ待ち行列に入るが、前記CLBホールドが除去されるまでディスパッチされないことを可能にする、キャッシュ・ライン・バッファ(CLB)ホールドである、請求項8に記載のプロセッサ。
(10)前記ブロック命令は、変換索引バッファ例外無効化命令またはSync命令を含む、請求項8に記載のプロセッサ。
(11)1つまたは複数の同時マルチスレッド(SMT)プロセッサを有する中央処理ユニット(CPU)と、
ランダム・アクセス・メモリ(RAM)と、
入力出力(I/O)アダプタと、
通信アダプタと、
前記CPU、RAM、I/Oアダプタ、および前記通信アダプタを結合するバスと、
第1のスレッドの第1の命令において例外条件を検出するための回路とを含む、データ処理システムであって、前記第1の命令は、前記第1の命令に続く前記第1のスレッドの第2の命令のディスパッチを必要とするものであって、
さらに前記データ処理システムは、前記共用ディスパッチ・パイプライン内の前記第2のスレッドの命令に関してディスパッチ・フラッシュ・オペレーションを発行する回路を含み、前記第2の命令は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドのブロック命令によってディスパッチをブロックされるデータ処理システム。
(12)前記ブロック命令は、前記第1の命令が完了するまで解放されない前記第1の命令によって使用されるリソース要件を有することを理由に、前記第2の命令をブロックしている、請求項11に記載のデータ処理システム。
(13)前記ブロック命令が、いずれかの命令が前記共用ディスパッチ・パイプラインからディスパッチされる前に合致しなければならない長い待ち時間の共用リソース要件を有するかどうかを判定するための回路と、
前記第2のスレッドのフラッシュ済み命令が再フェッチされる時点、および前記フラッシュ済み命令中で選択された命令に応答して共用ディスパッチ・パイプラインに再入する時点を制御する、選択済みホールドを設定するホールド・コマンドを発行するための回路とを含む、請求項11に記載のデータ処理システム。
(14)前記選択済みホールドは、前記第2のスレッドの命令が、前記ディスパッチ・パイプライン内のディスパッチ待ち行列からフラッシュし、前記ディスパッチ待ち行列に入るが、前記CLBホールドが除去されるまでディスパッチされないことを可能にする、キャッシュ・ライン・バッファ(CLB)ホールドである、請求項13に記載のデータ処理システム。
(15)前記ブロック命令は、変換索引バッファ例外無効化命令またはSync命令を含む、請求項13に記載のデータ処理システム。
102 D−Cache
103 IFAR
104 I−Cache
108 IFU
113 命令シーケンサ
114 FXU
115 GPRファイル
GP名前変更バッファ
116 LSU
117 FPRファイル
FP名前変更バッファ
118 FPU
119 完了ユニット
131 命令発行待ち行列
132 IDU
133 スレッド・セレクタ
134 プログラム・カウンタ
135 待ち行列T0
136 待ち行列T1
137 スレッド優先順位セレクタ
139 メモリ
140 ディスパッチ段階
150 レジスタ名前変更
410 CPU(SMTプロセッサ)
412 バス
Claims (15)
- 共用ディスパッチ・パイプラインを有するSMTプロセッサにおいて命令流れを管理するための方法であって、前記方法は
第1のスレッドの第1の命令において例外条件を検出するステップを含み、前記第1の命令は、前記第1の命令に続く前記第1のスレッドの第2の命令のディスパッチを必要とするものであって、
さらに前記方法は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドの命令に関してディスパッチ・フラッシュ・オペレーションを発行するステップを含み、前記第2の命令は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドのブロック命令によってディスパッチをブロックされる方法。 - 前記ブロック命令は、前記第1の命令が完了するまで解放されない前記第1の命令によって使用されるリソース要件を有することを理由に、前記第2の命令をブロックしている、請求項1に記載の方法。
- 前記ブロック命令が、いずれかの命令が前記共用ディスパッチ・パイプラインからディスパッチされる前に合致しなければならない長い待ち時間の共用リソース要件を有するかどうかを判定するステップと、
前記第2のスレッドのフラッシュ済み命令が再フェッチされる時点、および前記フラッシュ済み命令中で選択された命令に応答して共用ディスパッチ・パイプラインに再入する時点を制御する、選択済みホールドを設定するホールド・コマンドを発行するステップとを含む、請求項1に記載の方法。 - 前記選択済みホールドは、前記第2のスレッドの命令が、前記ディスパッチ・パイプライン内のディスパッチ待ち行列からフラッシュし、前記ディスパッチ待ち行列に入るが、前記CLBホールドが除去されるまでディスパッチされないことを可能にする、キャッシュ・ライン・バッファ(CLB)ホールドである、請求項3に記載の方法。
- 前記ブロック命令は、変換索引バッファ例外無効化(Translation Look Aside Buffer Invalidate Exception)命令またはSync命令を含む、請求項3に記載の方法。
- 共用ディスパッチ・パイプラインを有する同時マルチスレッド(SMT)プロセッサであって、前記プロセッサは、
第1のスレッドの第1の命令において例外条件を検出するための回路を含み、前記第1の命令は、前記第1の命令に続く前記第1のスレッドの第2の命令のディスパッチを必要とするものであって、
さらに前記プロセッサは、前記共用ディスパッチ・パイプライン内の前記第2のスレッドの命令に関してディスパッチ・フラッシュ・オペレーションを発行する回路を含み、前記第2の命令は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドのブロック命令によってディスパッチをブロックされるプロセッサ。 - 前記ブロック命令は、前記第1の命令が完了するまで解放されない前記第1の命令によって使用されるリソース要件を有することを理由に、前記第2の命令をブロックしている、請求項6に記載のプロセッサ。
- 前記ブロック命令が、いずれかの命令が前記共用ディスパッチ・パイプラインからディスパッチされる前に合致しなければならない長い待ち時間の共用リソース要件を有するかどうかを判定するための回路と、
前記第2のスレッドのフラッシュ済み命令が再フェッチされる時点、および前記フラッシュ済み命令中で選択された命令に応答して共用ディスパッチ・パイプラインに再入する時点を制御する、選択済みホールドを設定するホールド・コマンドを発行するための回路とを含む、請求項6に記載のプロセッサ。 - 前記選択済みホールドは、前記第2のスレッドの命令が、前記ディスパッチ・パイプライン内のディスパッチ待ち行列からフラッシュし、前記ディスパッチ待ち行列に入るが、前記CLBホールドが除去されるまでディスパッチされないことを可能にする、キャッシュ・ライン・バッファ(CLB)ホールドである、請求項8に記載のプロセッサ。
- 前記ブロック命令は、変換索引バッファ例外無効化命令またはSync命令を含む、請求項8に記載のプロセッサ。
- 1つまたは複数の同時マルチスレッド(SMT)プロセッサを有する中央処理ユニット(CPU)と、
ランダム・アクセス・メモリ(RAM)と、
入力出力(I/O)アダプタと、
通信アダプタと、
前記CPU、RAM、I/Oアダプタ、および前記通信アダプタを結合するバスと、
第1のスレッドの第1の命令において例外条件を検出するための回路とを含む、データ処理システムであって、前記第1の命令は、前記第1の命令に続く前記第1のスレッドの第2の命令のディスパッチを必要とするものであって、
さらに前記データ処理システムは、前記共用ディスパッチ・パイプライン内の前記第2のスレッドの命令に関してディスパッチ・フラッシュ・オペレーションを発行する回路を含み、前記第2の命令は、前記共用ディスパッチ・パイプライン内の前記第2のスレッドのブロック命令によってディスパッチをブロックされるデータ処理システム。 - 前記ブロック命令は、前記第1の命令が完了するまで解放されない前記第1の命令によって使用されるリソース要件を有することを理由に、前記第2の命令をブロックしている、請求項11に記載のデータ処理システム。
- 前記ブロック命令が、いずれかの命令が前記共用ディスパッチ・パイプラインからディスパッチされる前に合致しなければならない長い待ち時間の共用リソース要件を有するかどうかを判定するための回路と、
前記第2のスレッドのフラッシュ済み命令が再フェッチされる時点、および前記フラッシュ済み命令中で選択された命令に応答して共用ディスパッチ・パイプラインに再入する時点を制御する、選択済みホールドを設定するホールド・コマンドを発行するための回路とを含む、請求項11に記載のデータ処理システム。 - 前記選択済みホールドは、前記第2のスレッドの命令が、前記ディスパッチ・パイプライン内のディスパッチ待ち行列からフラッシュし、前記ディスパッチ待ち行列に入るが、前記CLBホールドが除去されるまでディスパッチされないことを可能にする、キャッシュ・ライン・バッファ(CLB)ホールドである、請求項13に記載のデータ処理システム。
- 前記ブロック命令は、変換索引バッファ例外無効化命令またはSync命令を含む、請求項13に記載のデータ処理システム。
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/422,676 US7213135B2 (en) | 2003-04-24 | 2003-04-24 | Method using a dispatch flush in a simultaneous multithread processor to resolve exception conditions |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2004326748A true JP2004326748A (ja) | 2004-11-18 |
JP3919764B2 JP3919764B2 (ja) | 2007-05-30 |
Family
ID=33298952
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2004105227A Expired - Fee Related JP3919764B2 (ja) | 2003-04-24 | 2004-03-31 | 例外条件を解消するために同時マルチスレッド・プロセッサでディスパッチ・フラッシュを使用する方法 |
Country Status (2)
Country | Link |
---|---|
US (1) | US7213135B2 (ja) |
JP (1) | JP3919764B2 (ja) |
Families Citing this family (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7653906B2 (en) * | 2002-10-23 | 2010-01-26 | Intel Corporation | Apparatus and method for reducing power consumption on simultaneous multi-threading systems |
US9323571B2 (en) * | 2004-02-06 | 2016-04-26 | Intel Corporation | Methods for reducing energy consumption of buffered applications using simultaneous multi-threading processor |
US7941642B1 (en) * | 2004-06-30 | 2011-05-10 | Oracle America, Inc. | Method for selecting between divide instructions associated with respective threads in a multi-threaded processor |
US7370243B1 (en) * | 2004-06-30 | 2008-05-06 | Sun Microsystems, Inc. | Precise error handling in a fine grain multithreaded multicore processor |
US7603544B2 (en) | 2004-12-23 | 2009-10-13 | Intel Corporation | Dynamic allocation of a buffer across multiple clients in multi-threaded processor without performing a complete flush of data associated with allocation |
US7664936B2 (en) * | 2005-02-04 | 2010-02-16 | Mips Technologies, Inc. | Prioritizing thread selection partly based on stall likelihood providing status information of instruction operand register usage at pipeline stages |
US7657883B2 (en) * | 2005-02-04 | 2010-02-02 | Mips Technologies, Inc. | Instruction dispatch scheduler employing round-robin apparatus supporting multiple thread priorities for use in multithreading microprocessor |
US7681014B2 (en) * | 2005-02-04 | 2010-03-16 | Mips Technologies, Inc. | Multithreading instruction scheduler employing thread group priorities |
US7613904B2 (en) * | 2005-02-04 | 2009-11-03 | Mips Technologies, Inc. | Interfacing external thread prioritizing policy enforcing logic with customer modifiable register to processor internal scheduler |
US7631130B2 (en) * | 2005-02-04 | 2009-12-08 | Mips Technologies, Inc | Barrel-incrementer-based round-robin apparatus and instruction dispatch scheduler employing same for use in multithreading microprocessor |
US7657891B2 (en) * | 2005-02-04 | 2010-02-02 | Mips Technologies, Inc. | Multithreading microprocessor with optimized thread scheduler for increasing pipeline utilization efficiency |
US7490230B2 (en) | 2005-02-04 | 2009-02-10 | Mips Technologies, Inc. | Fetch director employing barrel-incrementer-based round-robin apparatus for use in multithreading microprocessor |
US7752627B2 (en) * | 2005-02-04 | 2010-07-06 | Mips Technologies, Inc. | Leaky-bucket thread scheduler in a multithreading microprocessor |
US7506140B2 (en) * | 2005-02-04 | 2009-03-17 | Mips Technologies, Inc. | Return data selector employing barrel-incrementer-based round-robin apparatus |
US7853777B2 (en) * | 2005-02-04 | 2010-12-14 | Mips Technologies, Inc. | Instruction/skid buffers in a multithreading microprocessor that store dispatched instructions to avoid re-fetching flushed instructions |
US7478276B2 (en) * | 2005-02-10 | 2009-01-13 | International Business Machines Corporation | Method for checkpointing instruction groups with out-of-order floating point instructions in a multi-threaded processor |
US7266674B2 (en) * | 2005-02-24 | 2007-09-04 | Microsoft Corporation | Programmable delayed dispatch in a multi-threaded pipeline |
US7409589B2 (en) | 2005-05-27 | 2008-08-05 | International Business Machines Corporation | Method and apparatus for reducing number of cycles required to checkpoint instructions in a multi-threaded processor |
US20070038981A1 (en) * | 2005-07-29 | 2007-02-15 | Timothy Hanson | System and method for multi-threaded resolver with deadlock detection |
US7805712B2 (en) * | 2005-07-29 | 2010-09-28 | Bea Systems, Inc. | System and method for multi-threaded resolver with versioning |
US7523264B1 (en) * | 2005-12-15 | 2009-04-21 | Nvidia Corporation | Apparatus, system, and method for dependent computations of streaming multiprocessors |
US7492368B1 (en) | 2006-01-24 | 2009-02-17 | Nvidia Corporation | Apparatus, system, and method for coalescing parallel memory requests |
US9606800B1 (en) * | 2012-03-15 | 2017-03-28 | Marvell International Ltd. | Method and apparatus for sharing instruction scheduling resources among a plurality of execution threads in a multi-threaded processor architecture |
US9621633B2 (en) | 2013-03-15 | 2017-04-11 | Intel Corporation | Flow director-based low latency networking |
US10599431B2 (en) | 2017-07-17 | 2020-03-24 | International Business Machines Corporation | Managing backend resources via frontend steering or stalls |
US10365928B2 (en) | 2017-11-01 | 2019-07-30 | International Business Machines Corporation | Suppress unnecessary mapping for scratch register |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4200912A (en) * | 1978-07-31 | 1980-04-29 | Motorola, Inc. | Processor interrupt system |
DE4434895C2 (de) | 1993-12-23 | 1998-12-24 | Hewlett Packard Co | Verfahren und Vorrichtung zur Behandlung von Ausnahmebedingungen |
US6055650A (en) * | 1998-04-06 | 2000-04-25 | Advanced Micro Devices, Inc. | Processor configured to detect program phase changes and to adapt thereto |
US6493741B1 (en) * | 1999-10-01 | 2002-12-10 | Compaq Information Technologies Group, L.P. | Method and apparatus to quiesce a portion of a simultaneous multithreaded central processing unit |
US6694425B1 (en) | 2000-05-04 | 2004-02-17 | International Business Machines Corporation | Selective flush of shared and other pipeline stages in a multithread processor |
US7401211B2 (en) * | 2000-12-29 | 2008-07-15 | Intel Corporation | Method for converting pipeline stalls caused by instructions with long latency memory accesses to pipeline flushes in a multithreaded processor |
-
2003
- 2003-04-24 US US10/422,676 patent/US7213135B2/en not_active Expired - Fee Related
-
2004
- 2004-03-31 JP JP2004105227A patent/JP3919764B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
JP3919764B2 (ja) | 2007-05-30 |
US7213135B2 (en) | 2007-05-01 |
US20040215944A1 (en) | 2004-10-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7469407B2 (en) | Method for resource balancing using dispatch flush in a simultaneous multithread processor | |
JP3919764B2 (ja) | 例外条件を解消するために同時マルチスレッド・プロセッサでディスパッチ・フラッシュを使用する方法 | |
JP3927546B2 (ja) | 同時マルチスレッド化プロセッサ | |
KR100745904B1 (ko) | 동시적 멀티스레드 프로세서에서 파이프라인 길이를변경하기 위한 방법 및 회로 | |
US10061588B2 (en) | Tracking operand liveness information in a computer system and performing function based on the liveness information | |
US7363625B2 (en) | Method for changing a thread priority in a simultaneous multithread processor | |
US8335911B2 (en) | Dynamic allocation of resources in a threaded, heterogeneous processor | |
US7093106B2 (en) | Register rename array with individual thread bits set upon allocation and cleared upon instruction completion | |
US20080126771A1 (en) | Branch Target Extension for an Instruction Cache | |
US20140047219A1 (en) | Managing A Register Cache Based on an Architected Computer Instruction Set having Operand Last-User Information | |
US6981128B2 (en) | Atomic quad word storage in a simultaneous multithreaded system | |
EP0649085A1 (en) | Microprocessor pipe control and register translation | |
US7194603B2 (en) | SMT flush arbitration | |
US9870226B2 (en) | Control of switching between executed mechanisms | |
US7013400B2 (en) | Method for managing power in a simultaneous multithread processor by loading instructions into pipeline circuit during select times based on clock signal frequency and selected power mode | |
US11829767B2 (en) | Register scoreboard for a microprocessor with a time counter for statically dispatching instructions | |
US20230342153A1 (en) | Microprocessor with a time counter for statically dispatching extended instructions |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20051004 |
|
RD12 | Notification of acceptance of power of sub attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7432 Effective date: 20051031 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A821 Effective date: 20051031 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20051221 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20060516 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20060811 |
|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20060920 |
|
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: 20070206 |
|
RD14 | Notification of resignation of power of sub attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7434 Effective date: 20070206 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20070213 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110223 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110223 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120223 Year of fee payment: 5 |
|
LAPS | Cancellation because of no payment of annual fees |