JP2014149868A - マルチスレッドプロセッサ - Google Patents
マルチスレッドプロセッサ Download PDFInfo
- Publication number
- JP2014149868A JP2014149868A JP2014090595A JP2014090595A JP2014149868A JP 2014149868 A JP2014149868 A JP 2014149868A JP 2014090595 A JP2014090595 A JP 2014090595A JP 2014090595 A JP2014090595 A JP 2014090595A JP 2014149868 A JP2014149868 A JP 2014149868A
- Authority
- JP
- Japan
- Prior art keywords
- thread
- instruction
- hardware
- processor
- slot
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Landscapes
- Advance Control (AREA)
Abstract
【解決手段】複数のハードウェアスレッドと、ハードウェアスレッドを選択するスレッド選択信号TSELを出力するスレッドスケジューラ19と、スレッド選択信号TSELに応じて選択したハードウェアスレッドにより生成された命令を出力する第1のセレクタと、命令を実行する演算回路とを有するマルチスレッドプロセッサにおいて、スレッドスケジューラ19は、第1の実行期間において固定的にハードウェアスレッドを選択し、第2の実行期間において任意のハードウェアスレッドを選択し、第1の実行期間と第2の実行期間の比率、及び第1の実行期間に実行されるハードウェアスレッドの比率は、演算回路で実行される管理プログラムにより任意に設定される。
【選択図】図2
Description
以下、図面を参照して本発明の実施の形態について説明する。図1に本実施の形態にかかるマルチスレッドプロセッサ1を含むプロセッサシステムのブロック図を示す。本実施の形態にかかるプロセッサシステムでは、システムバスを介してマルチスレッドプロセッサ1とメモリ2が接続される。なお、図示はしていないが、システムバスには、入出力インタフェースなどの他の回路も接続されるものとする。
2 メモリ
10 演算回路
11 割り込みコントローラ
12 PC生成回路
13、18、30、37 セレクタ
14 命令メモリ
15 命令バッファ
16 パイプライン制御回路
17 命令フェッチコントローラ
19 スレッドスケジューラ
21 命令デコーダ
22 実行ユニット
23 データレジスタ
31 第1のスケジューラ
32 第2のスケジューラ
33 スレッド制御レジスタ
34 カウンタ
35 カウント最大値格納部
36 一致比較回路
a、b データ
BUF0〜BUF0 命令バッファ領域
IMadd 命令フェッチアドレス
Radd データレジスタアドレス
SC 演算制御信号
TSEL スレッド選択信号
CNT カウント値
CNTM カウント最大値
RST リセット信号
SLT0〜SLT7 スロット
TPC0〜TCP3 スレッドプログラムカウンタ
Claims (6)
- それぞれが独立した命令流を生成する複数のハードウェアスレッドと、
前記複数のハードウェアスレッドのうち次実行サイクルにおいて使用するハードウェアスレッドを選択するスレッド選択信号を出力するスレッドスケジューラと、
前記スレッド選択信号に応じて前記複数のハードウェアスレッドのいずれか1つを選択して、選択したハードウェアスレッドにより生成された命令を出力するセレクタと、
前記セレクタから出力される命令を実行する演算回路と、
を有し、
前記スレッドスケジューラは、
各スロットが第1の情報を保持し、この第1の情報を書き換え可能とする複数のスロットを含むスレッド制御レジスタと、
前記複数のスロットのうち1つを指定する第2の情報を格納し、この第2の情報を書き換え可能とする格納部と、を有し、
前記スレッド制御レジスタの前記複数のスロットの第1のスロットからスロットを順々に選択し、
前記第2の情報により指定されたスロットを選択したときには、前記第1のスロットに戻ってスロットを再び順次選択し、
順次選択されたスロットが保持する前記第1の情報に基づき、ハードウェアスレッドを前記セレクタに選択させるマルチスレッドプロセッサ。 - 前記第1の情報、及び前記第2の情報は、前記演算回路で実行される管理プログラムにより前記スロット及び前記格納部に設定される請求項1に記載のマルチスレッドプロセッサ。
- 前記スレッドスケジューラは、前記スロットの番号を示すカウント値を所定の周期でカウントアップし、前記カウント値が前記第2の情報で示される値に達したことに応じて前記カウント値がリセットされるカウンタを有する請求項1又は2に記載のマルチスレッドプロセッサ。
- 前記第1の情報が、ハードウェアスレッド番号を含む請求項1乃至3のいずれか1項に記載のマルチスレッドプロセッサ。
- 前記管理プログラムは、前記マルチスレッドプロセッサの起動後に実行される請求項2に記載のマルチスレッドプロセッサ。
- 命令メモリと、
命令バッファと、
命令フェッチコントローラと、をさらに有し、
前記命令バッファには、
前記命令フェッチコントローラにより指定された前記ハードウェアスレッドが生成する命令が前記命令メモリよりフェッチされ、
当該フェッチされた命令が格納され、
前記命令フェッチコントローラは、
前記命令バッファに格納された命令の個数に応じていずれの前記ハードウェアスレッドが生成する命令をフェッチすべきかを判断し、
当該判断結果に基づき前記命令バッファに格納する命令を生成する前記ハードウェアスレッドを決定する請求項1乃至5のいずれか1項に記載のマルチスレッドプロセッサ。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2014090595A JP5770333B2 (ja) | 2014-04-24 | 2014-04-24 | マルチスレッドプロセッサ |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2014090595A JP5770333B2 (ja) | 2014-04-24 | 2014-04-24 | マルチスレッドプロセッサ |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2012284004A Division JP5536863B2 (ja) | 2012-12-27 | 2012-12-27 | マルチスレッドプロセッサ |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2015126242A Division JP5946566B2 (ja) | 2015-06-24 | 2015-06-24 | マルチスレッドプロセッサにおけるハードウェアスレッドのスケジュール方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2014149868A true JP2014149868A (ja) | 2014-08-21 |
JP5770333B2 JP5770333B2 (ja) | 2015-08-26 |
Family
ID=51572718
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2014090595A Active JP5770333B2 (ja) | 2014-04-24 | 2014-04-24 | マルチスレッドプロセッサ |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP5770333B2 (ja) |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007317171A (ja) * | 2006-04-27 | 2007-12-06 | Matsushita Electric Ind Co Ltd | マルチスレッド計算機システム、マルチスレッド実行制御方法 |
JP2008123045A (ja) * | 2006-11-08 | 2008-05-29 | Matsushita Electric Ind Co Ltd | プロセッサ |
-
2014
- 2014-04-24 JP JP2014090595A patent/JP5770333B2/ja active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007317171A (ja) * | 2006-04-27 | 2007-12-06 | Matsushita Electric Ind Co Ltd | マルチスレッド計算機システム、マルチスレッド実行制御方法 |
JP2008123045A (ja) * | 2006-11-08 | 2008-05-29 | Matsushita Electric Ind Co Ltd | プロセッサ |
Also Published As
Publication number | Publication date |
---|---|
JP5770333B2 (ja) | 2015-08-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5173711B2 (ja) | マルチスレッドプロセッサ及びそのハードウェアスレッドのスケジュール方法 | |
JP5173712B2 (ja) | マルチスレッドプロセッサ | |
JP5173713B2 (ja) | マルチスレッドプロセッサ及びそのハードウェアスレッドのスケジュール方法 | |
US10467053B2 (en) | Multi-thread processor with rescheduling when threads are nondispatchable | |
JP5173714B2 (ja) | マルチスレッドプロセッサ及びその割り込み処理方法 | |
JP5946566B2 (ja) | マルチスレッドプロセッサにおけるハードウェアスレッドのスケジュール方法 | |
JP5770333B2 (ja) | マルチスレッドプロセッサ | |
JP5536863B2 (ja) | マルチスレッドプロセッサ | |
JP5536862B2 (ja) | マルチスレッドプロセッサ | |
JP5838237B2 (ja) | マルチスレッドプロセッサ | |
JP5536864B2 (ja) | マルチスレッドプロセッサ | |
JP5770334B2 (ja) | マルチスレッドプロセッサ | |
JP2014067248A (ja) | プロセッサ、割り込み処理方法及び割り込み制御装置 | |
JP2015064861A (ja) | マルチスレッドプロセッサ | |
JP2014211890A (ja) | マルチスレッドプロセッサ及びその割り込み処理方法 | |
JP2013058265A (ja) | マルチスレッドプロセッサ及びその割り込み処理方法 | |
JP2006146641A (ja) | マルチスレッドプロセッサ及びマルチスレッドプロセッサの割込み方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20150109 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20150120 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20150320 |
|
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: 20150526 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20150624 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 5770333 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
R360 | Written notification for declining of transfer of rights |
Free format text: JAPANESE INTERMEDIATE CODE: R360 |
|
R370 | Written measure of declining of transfer procedure |
Free format text: JAPANESE INTERMEDIATE CODE: R370 |