JP4609540B2 - マルチプロセサシステム - Google Patents

マルチプロセサシステム Download PDF

Info

Publication number
JP4609540B2
JP4609540B2 JP2008186812A JP2008186812A JP4609540B2 JP 4609540 B2 JP4609540 B2 JP 4609540B2 JP 2008186812 A JP2008186812 A JP 2008186812A JP 2008186812 A JP2008186812 A JP 2008186812A JP 4609540 B2 JP4609540 B2 JP 4609540B2
Authority
JP
Japan
Prior art keywords
bus
signal
transfer
data
shared bus
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2008186812A
Other languages
English (en)
Other versions
JP2008293524A (ja
Inventor
俊樹 竹内
裕之 井倉
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
NEC Corp
Original Assignee
NEC Corp
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 NEC Corp filed Critical NEC Corp
Priority to JP2008186812A priority Critical patent/JP4609540B2/ja
Publication of JP2008293524A publication Critical patent/JP2008293524A/ja
Application granted granted Critical
Publication of JP4609540B2 publication Critical patent/JP4609540B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Landscapes

  • Bus Control (AREA)
  • Information Transfer Systems (AREA)

Description

本発明は、マルチプロセサシステムに関し、特に、複数の共有バスを介してデータ転送を
行うマルチプロセサシステムに関する。
従来、この種のマルチプロセサシステムとして、各プロセサ要素の役割がマスタもしくは
スレーブとして固定されているマルチプロセサシステム以外に、各プロセサ要素がマスタ
もしくはスレーブとして動的に動作可能なマルチプロセサシステムがあり、プロセサ要素
間のデータ転送を効率化するため、複数の共有バスを用いて、プロセサ要素間のメッセー
ジ転送と、プロセサ要素および入出力装置の間の入出力転送とが、それぞれ行われてきた
たとえば、図18は、この従来のマルチプロセサシステムの構成例を示すブロック図であ
る(特許文献1参照)。
この従来のマルチプロセサシステムは、プロセサ要素をそれぞれ構成する複数のプロセサ
12−1,2および複数のバスコントローラ13−1,2と、複数の入出力装置16−1
,2,3および複数のアダプタ15−1,2とを備え、複数のプロセサ12−1,2を複
数のバスコントローラ13−1,2を介して複数の共有バス14−1,2にそれぞれ接続
し、また、複数の入出力装置16−1,2,3を複数のアダプタ15−1,2を介して複
数の共有バス14−1,2にそれぞれ接続する。
さらに、複数のプロセサ12−1,2は、オペレーティングシステムのカーネル処理手段
として入出力処理部およびメッセージ通信処理部をそれぞれ備える。
入出力処理部は、入出力装置16−1,2,3への入出力要求に対して、入出力装置のア
ドレス情報や転送データ情報をバスコントローラ13−1,13−2にそれぞれ渡し、入
出力を起動する。そして、入出力が完了したときに、バスコントローラ13−1,2から
割込み通知を受けて、入出力要求を出したプログラムに完了通知を行う。
メッセージ通信処理部は、プロセサ間のデータ通信要求を受けると、バスコントローラ1
3−1,2に対して、相手プロセサのアドレス,転送データ情報などを渡して、データの
送信要求を行う。また、受信処理では、他プロセサからのデータ送信があった場合に、バ
スコントローラ13−1,2から割込み通知を受けて、データを受け取り、そのデータを
要求元のプログラムに渡す。
この従来のマルチプロセサシステムにおいては、各プロセサ要素がマスタまたはスレーブ
となり、複数の共有バス14−1,2を用いて、入出力装置との入出力転送と、プロセサ
要素間のメッセージ転送とが行われる。また、1本のバスを入出力転送およびメッセージ
転送に共通に用いることができるため、プロセサ要素間で転送されるデータ転送量および
転送トラフィックに応じて、複数の共有バスを用いて複数のメッセージ転送と複数の入出
力転送とを同時に行うことができる。このため、メッセージ転送および入出力転送を合わ
せたデータ転送の同時要求数が共有バスの本数以下であれば、バスのビジーによって処理
が待たされることはない。
特開平5−6333号公報(段落0007〜0013,図1)
一般に、マルチプロセサシステムにおいて複数のプロセサ要素間のデータ転送を行う共有
バスに対して、次に示すような要求が列挙される。
(1) 性能の観点から、高速データ転送を小さな回路面積および低消費電力で実現する
こと
(2) 拡張容易性・資源再利用性の観点から、プロセサ要素の物理的な追加・変更・削
除が行われても、他のプロセサ要素および共有バスの設計変更点を最小にできること
(3) 検証容易性の観点から、プロセサ要素間におけるデータ転送の状況およびプロセ
サ要素ごとのデバグ情報を選択してモニタリングできること
上述した、従来のマルチプロセサシステムでは、プロセサ要素間のメッセージ転送が、入
出力装置の入出力転送から分離され、入出力転送の終了まで待たされことが無く高速に行
われる。しかしながら、プロセサ要素間のメッセージ転送の転送データ数が大きい場合は
、共有バスの占有時間が長くなり、他のプロセサ要素間のメッセージ転送が待たされ、シ
ステム全体として、プロセサ要素間の高速データ転送が難しいという問題がある。
また、この対策として、共有バスの本数を多くした場合は、回路規模オーバヘッドが膨大
になるという問題が発生する。
また、プロセサ要素間のメッセージ転送の転送データ数が小さい場合も、メッセージ転送
ごとに、プロセサ要素の内部プロセッサの処理に対して割込みを発生して割込み処理する
必要があり、プロセサ要素の内部プロセッサによるデータ処理の効率が相対的に低下する
という問題がある。
また、システム全体またはプロセサ要素のプログラムのデバグ時に、プロセサ要素間にお
けるデータ転送の状況およびプロセサ要素ごとのデバグ情報を選択してモニタリングでき
ず、デバグ効率が低いという問題がある。
また、この対策として、例えば、特開2000−330877号公報または特開平4−1
95552号公報に開示されているように、共有バスまたはプロセサ要素ごとにバスモニ
タ回路またはアドレストレース機能を実装した場合は、回路規模オーバヘッドが膨大にな
るという問題が発生する。
従って、本発明の目的は、マルチプロセサシステムにおいて、回路規模の増加を最小限に
抑えながら、プロセサ要素間のデータ転送を高速化し、プロセサ要素の内部プロセッサの
データ処理効率を向上させ、また、デバグ効率を向上させることにある。
そのため、本発明は、それぞれデータ処理し制御系データまたは入出力データの転送要求
に対応して第1または第2の共有バスのバス使用権を獲得しマスタとしてマルチプレクス
転送またはバースト転送する複数のプロセサ要素を備えるマルチプロセサシステムにおい
て、
前記プロセサ要素が、前記制御系データの転送要求に対応して第1の共有バスのバス要求
信号を出力しバス許可信号の入力に応じてマスタとして転送先の選択信号,制御信号,ア
ドレス信号および前記制御系データを1サイクルで転送出力し、第1の共有バスを介して
前記選択信号に基づき選択されスレーブとして前記制御系データを入力し前記制御信号お
よび前記アドレス信号に基づき処理している。
また、前期複数のプロセサ要素から前記選択信号,前記制御信号,前記アドレス信号およ
び前記制御系データをそれぞれ入力し第1の共有バスのバス使用権に対応して第1の共有
バスへ選択的に切り替え出力し第1の共有バスを介して前記選択信号に基づき前記複数の
プロセサ要素の1つをスレーブとして選択し前記制御信号,前記アドレス信号および前記
制御系データを出力する第1の共有バス回路と、
前記複数のプロセサ要素からバス要求信号をサイクルごとにそれぞれ受け付け最も優先度
の高いプロセサ要素に対し第1の共有バスのバス許可信号を発行して次のサイクルのバス
使用権を調停する第1のバスアービタとを備えている。
また、第1の共有バス回路が、前記複数のプロセサ要素から前記選択信号,前記制御信号
,前記アドレス信号および前記制御系データをそれぞれ入力し第1の共有バスのバス使用
権に対応して第1の共有バスへ選択的に切り替え出力するマルチプレクサと、
第1の共有バス上の前記選択信号をデコードし前記複数のプロセサ要素の1つを転送先の
スレーブとして選択するデコーダと、
第1の共有バス上の前記制御信号,前記アドレス信号および前記制御系データをそれぞれ
入力し前記デコーダの出力に対応して転送先のスレーブへそれぞれ切り替え分配するデマ
ルチプレクサとを備えている。
また、前記プロセサ要素が、前記制御系データの転送要求に対応して第1の共有バスのバ
ス要求信号を出力しバス許可信号の入力に応じてマスタとして前記制御系データを転送出
力し第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記制御系デ
ータを入力し前記制御信号および前記アドレス信号に基づきメモリ書込みを行う書込み転
送と、
返送先コードを含む制御系データの転送要求に対応して第1の共有バスのバス要求信号を
出力しバス許可信号の入力に応じてマスタとして前記返送先コードを転送出力し第1の共
有バスを介して前記選択信号に基づき選択されスレーブとして前記返送先コードを入力し
前記制御信号および前記アドレス信号に基づきメモリデータを読み出して制御系データと
し返送要求を行う読出し返送要求転送と、
前記返送要求に対応して第1の共有バスのバス要求信号を出力しバス許可信号の入力に応
じてマスタとして前記返送先コード対応の選択信号を転送出力し第1の共有バスを介して
前記選択信号に基づき選択されスレーブとして前記制御系データを入力し前記制御信号お
よび前記アドレス信号に基づきメモリ書込みを行う返送書込み転送とをそれぞれ行ってい
る。
また、前記プロセサ要素が、第1の共有バスを介して前記選択信号に基づき選択されスレ
ーブとして、内部割込み処理でなく専用のメモリ制御部により、前記制御信号および前記
アドレス信号に基づきメモリ書込みまたはメモリ読出し返送要求を行っている。
また、前記プロセサ要素が、割込み要求を含む制御系データの転送要求に対応して第1の
共有バスのバス要求信号を出力しバス許可信号の入力に応じてマスタとして前記割込み要
求を転送出力し、第1の共有バスを介して前記選択信号に基づき選択されスレーブとして
前記割込み要求を入力し前記制御信号および前記アドレス信号に基づき前記割込み要求に
対応した内部割込み処理を行う割込み要求転送を行っている。
また、前記割込み要求が、割込み要因および転送元コードを含んでいる。
また、第1および第2の共有バス上の前記制御系データおよび前記入出力データを転送経
路およびアドレス範囲の一致に応じてスヌーピングしデバグ用メモリに記憶するデバグ用
処理要素を備えている。
また、前記プロセサ要素が、内部プロセッサの実行命令のアドレスをトレースしトレース
データを作成して制御系データとし、その転送要求に対応して第1の共有バスのバス要求
信号を出力しバス許可信号の入力に応じてマスタとして前記トレースデータを転送出力し
ている。
また、前記デバグ用処理要素が、第1の共有バスを介して前記選択信号に基づき選択され
スレーブとして前記トレースデータを入力し前記制御信号および前記アドレス信号に基づ
きデバグ用メモリに記憶している。
また、前記プロセサ要素の基本クロック信号に同期し且つ第1の共有バスの転送トラフィ
ックに応じて前記基本クロック信号の整数倍周波数のバスクロック信号を生成するクロッ
ク生成回路と、
前記プロセサ要素から第1の共有バスのバス要求信号を入力し第1のバスアービタへ前記
バスクロック信号に同期して出力し第1のバスアービタから第1の共有バスのバス許可信
号を入力し前記プロセサ要素へ前記基本クロック信号に同期して出力するアービタ同期回
路と、
第1の共有バスを介して前記選択信号,前記制御信号,前記アドレス信号および前記制御
系データを入力し前記プロセサ要素へ前記基本クロック信号に同期して出力するスレーブ
同期回路とを備え、
第1のバスアービタが、前記アービタ同期回路を介して前記複数のプロセサ要素から第1
の共有バスのバス要求信号を前記基本クロック信号のサイクルごとにそれぞれ1度だけ受
け付け前記バスクロック信号の各バスサイクルで最も優先度の高いプロセサ要素に対し前
記アービタ同期回路を介して第1の共有バスのバス許可信号を発行して次のサイクルの各
バスサイクルのバス使用権を調停している。
また、前記複数のプロセサ要素の1つとして動作し且つ前記入出力データの転送要求に対
応して第2の共有バスのバス要求信号を出力しバス許可信号の入力に応じてマスタとして
前記入出力データをバースト転送するプロセサ要素と、
前記複数のプロセサ要素の1つとして動作し且つ第2の共有バスを介して接続されたスレ
ーブとして前記入出力データをバースト転送するプロセサ要素とを備えている。
また、第2の共有バスのマスタまたはスレーブとして動作するプロセサ要素を第2の共有
バスのバス使用権に対応して第2の共有バスに選択的に切り替え接続し第2の共有バスを
介してマスタおよびスレーブ間で前記入出力データをバースト転送する第2の共有バス回
路と、
前記複数のプロセサ要素から第2の共有バスのバス要求信号をサイクルごとにそれぞれ受
付け最も優先度の高いプロセサ要素に対し第2の共有バスのバス許可信号を発行してバス
使用権を調停する第2のバスアービタとを備えている。
以上のように、この発明によれば、以下のような効果が期待できる。
第1の効果は、回路規模の増加を抑えたままで、全てのプロセッサ要素間における転送お
よび高速データ転送の両方が効率的に行えることである。
その理由は、従来のプロセサ要素と異なり、プロセサ要素による全データ転送の転送デー
タを制御系データおよび入出力データの2種類に分割して、制御系データまたは入出力デ
ータの転送要求に対応して第1または第2の共有バスのバス使用権を獲得しマスタとして
マルチプレクス転送またはバースト転送し、第1の共有バスでは、全てのプロセッサ要素
間で転送可能とし、必要最小限の書込み転送のみの機能に限定し、読み出し返送要求が書
込み転送された時点でバスの使用権は解放され、返送データが準備できるまでの期間中は
、他の転送を行いたいプロセサ要素にバスを割り当てることができ、第2の共有バスでは
、接続されるプロセッサ要素と転送方向とを限定しているためである。
第2の効果は、全てのプロセッサ要素間の制御系データの転送と、各プロセッサ要素内の
データ処理とが、高速化および低消費電力化され、マルチプロセサシステム全体が高速化
および低消費電力化されることである。
その理由は、第1の共有バスを介した制御系データの転送そのものに対しては、特定マス
タのプロセッサ要素の起動が不要になり、各プロセッサ要素のバスインタフェース間で第
1の共有バスを介したデータ転送ができ、各プロセッサ要素内の内部プロセサによる処理
が不要になり、また、転送トラフィックに応じてプロセッサ要素の基本クロック信号のサ
イクルより整数倍速いバスサイクルで第1の共有バス回路を動作させることができるため
である。
第3の効果は、拡張容易性および資源再利用性に優れ、マルチプロセサシステムの開発期
間が短縮され、さらには、開発コストが削減されることである。
その理由は、システム仕様の変更に伴ってのプロセサ要素の追加・変更などにより、プロ
セサ要素間に想定していなかった転送経路が発生した場合でも、全てのプロセサ要素間で
転送可能な第1の共有バスを介して、割込み要求を含む制御系データも転送でき、全体の
バス仕様および接続構成の変更をほとんど必要とせずに柔軟に対応でき、プロセサ要素間
に想定していなかった大量のデータ転送が追加・変更された場合でも、第2の共有バスの
接続構成を追加・変更することで対応できるためである。
第4の効果は、テスト容易性およびデバグ容易性が向上することである。
その理由は、プロセサ要素ごとのアドレストレース機能によって生成されたトレースデー
タが、通常動作中の第1の共有バスの不使用期間を利用して、全てのプロセサ要素共通の
デバグ用記憶装置に転送され、また、バスモニタ機能と組み合わせることにより、通常動
作におけるプロセサ要素間の転送データと、1つまたは複数のプロセサ要素のアドレスト
レースデータを同時にモニタリングでき、また、転送トラフィックに応じてプロセッサ要
素の基本クロック信号のサイクルより整数倍速いバスサイクルで第1の共有バス回路を動
作させることができるためである。
次に、本発明について、図面を参照して説明する。図1は、本発明によるマルチプロセサ
システムの実施形態1を示す全体ブロック図である。図1を参照すると、本実施形態のマ
ルチプロセサシステムは、複数のプロセサ要素01〜0nと、第1,第2の共有バス回路
100,200と、第1,第2のバスアービタ105,205と、デバグ用処理要素10
とを備える。
複数のプロセサ要素01〜0nは、それぞれデータ処理し、また、図10で示した従来の
マルチプロセサシステムにおけるプロセサ要素と異なり、プロセサ要素による全データ転
送の転送データを制御系データおよび入出力データの2種類に分割して、制御系データま
たは入出力データの転送要求に対応して第1または第2の共有バスのバス使用権を獲得し
マスタとしてマルチプレクス転送またはバースト転送する。
各プロセッサ要素内の構成例としては、種々の演算およびプロセッサ要素内の制御を行う
MPUやDSPなどの内部プロセッサ、メモリやレジスタなどの記憶装置、データ処理を
行う専用ハードウェアアクセラレータ、データ入出力装置(DMAコントローラ)などか
ら構成されると考えられるが、本発明の実施の形態としては、特にこれの限りではない。
また、これら複数のプロセサ要素01〜0nの少なくとも1つが、従来と同じく、入出力
データの転送要求に対応して、第2の共有バスのバス要求信号を出力し、バス許可信号の
入力に応じてマスタとして入出力データをバースト転送し、また、これら複数のプロセサ
要素01〜0nの少なくとも1つが、従来と同じく、第2の共有バスを介して接続された
スレーブとして、入出力データをバースト転送する。
第1,第2の共有バス回路100,200は、第1,第2の共有バスを介して、プロセッ
サ要素01〜0n間の制御系データ,入出力データを互い異なる仕様でデータ転送する。
第1の共有バス回路100は、必要最小限の書込み転送機能だけを有して一部あるいは全
てのプロセッサ要素間で双方向に1サイクルごとにマルチプレクス転送し、第2の共有バ
ス回路200は、転送されるプロセッサ要素および転送方向を限定し、マスタからスレー
ブへ、または、スレーブからマスタへバースト転送する。これら第1,第2の共有バスは
、それぞれ、1つのマルチプロセッサ内に物理的に1本または複数本存在可能である。ま
た、第2の共有バスが複数本存在する場合には、それらのバスに接続されるプロセッサ要
素およびバス仕様が同一である必要はない。
第1,第2のバスアービタ105,205は、複数のプロセサ要素01〜0nから第1,
第2の共有バスのバス要求をサイクルごとにそれぞれ受け付け最も優先度の高いプロセサ
要素に対し第1,第2の共有バスのバス許可信号を発行して第1,第2のバス使用権を調
停する。
デバグ用処理要素10は、第1および第2の共有バス上の制御系データおよび入出力デー
タを転送経路およびアドレス範囲の一致に応じてスヌーピングしデバグ用メモリに記憶し
、モニタ出力できる。
上述したように、本実施形態のマルチプロセサシステムにおいて、主に、動作タイミング
信号やパラメータ設定信号などの、一度に転送される転送データ数は少ないが全てのプロ
セサ要素間で転送される可能性のあるデータは、制御系データとして、第1の共有バスを
用いて複数のプロセサ要素01〜0n間で相互にマスタからスレーブへマルチプレクス転
送される。一方、主に、ストリームデータなどの、一度に転送される転送データ数が多く
且つ転送経路が予め決まっているデータは、入出力データとして、第2の共有バスを用い
て複数のプロセサ要素01〜0nの限定されたマスタおよびスレーブ間でバースト転送さ
れる。
すなわち、転送トラフィックが大きく、第1の共有バスを用いて転送すると他の転送およ
び全体のシステム性能に影響が出るような転送を、第2の共有バスを用いて転送する。こ
れにより、接続先が多く複雑になりがちな第1の共有バス100の仕様を、最大限簡単化
することが可能となる。
また、デバグ用処理要素10により、第1,第2の共有バス上の転送データまたは信号の
転送経路およびアドレスが所望の範囲と一致した場合にだけ、その転送データをスヌーピ
ングし内部のデバグ用メモリに記憶させ、モニタすることができる。このとき、デバグ用
処理要素10が、第1,第2の共有バス上の転送データを同時にモニタするために、動作
クロックを速くしてマルチプレクサなどを用いて切り替えながらモニタする機能を有して
いても何ら問題はない。
次に、本実施形態のマルチプロセサシステムにおける第1,第2の共有バスを介したデー
タ転送についてそれぞれ詳細説明する。
図2は、本実施形態のマルチプロセサシステムにおける第1の共有バスを介したデータ転
送を説明するための説明図である。第1の共有バスを介したデータ転送では、図2に示す
ように、転送を行うプロセッサ要素のマスタもしくはスレーブとしての役割が動的に変化
し、全てのプロセッサ要素間で第1の共有バスを介したデータ転送が許容されている。こ
のような構成をとることにより、第1の共有バスを介したデータ転送そのものに対しては
、特定マスタのプロセッサ要素の起動が不要になり、各プロセッサ要素のバスインタフェ
ース間で第1の共有バスを介したデータ転送ができ、転送の効率化および低消費電力化を
図ることができる。
図3は、第1の共有バス回路100の内部構成例および周辺接続例を示すブロック図であ
り、図4は、プロセサ要素内の第1の共有バスのマスタ側およびスレーブ側インタフェー
スの1部を示す部分ブロック図である。
図3を参照すると、第1の共有バス回路100は、マルチプレクサ,デコーダおよびデマ
ルチプレクサを備えて構成される。ここで、マルチプレクサは、第1の共有バスのマスタ
として動作するプロセサ要素から選択信号MSEL,制御信号MWE,MRES,アドレ
ス信号MADDRおよび制御系データMDBOをそれぞれ入力し、第1のアービタ105
からの第1の共有バスのバス使用権に対応した信号により第1の共有バスへ選択的に切り
替え出力し、デコーダは、第1の共有バス上の選択信号をデコードし複数のプロセサ要素
01〜0nの1つを転送先のスレーブとして選択し、デマルチプレクサは、第1の共有バ
ス上の制御信号,アドレス信号および制御系データをそれぞれ入力し、デコーダの出力に
対応して、第1の共有バスのスレーブとして動作する転送先のプロセサ要素へそれぞれ切
り替え分配する。
上述のように、本実施形態の第1の共有バス回路100は、従来バスでは書込み転送(マ
スタからスレーブへ)および読み出し転送(スレーブからマスタへ)の両方を考慮して回
路を構成しなければならないのに対して、書込み転送のみを可能にするだけの回路構成と
する。このような回路構成にしても、全てのプロセッサ要素がマスタになれるために双方
向のデータ転送が実現でき、回路規模が削減される。また、図3では、第1の共有バス回
路100が、論理合成等のインプリメント容易性を考慮して、MUX型のバス構成となっ
ているが、インプリメント容易性および動作遅延の見積りが許せば、3ステート型などの
バス構成でも何ら問題はない。
各プロセサ要素01〜0nは、制御系データの転送要求に対応して第1の共有バスのバス
要求信号MREQを出力し、バス許可信号MGRANTの入力に応じてマスタとして転送
先の選択信号MSELと、制御信号MWE,MRESと、アドレス信号MADDRおよび
制御系データMDBOを各出力端子から1サイクルで転送出力し、また、第1の共有バス
を介して選択信号に基づき選択されスレーブとして、制御系データを入力し制御信号およ
びアドレス信号に基づき処理する。また、図4に示すように、各プロセサ要素01〜0n
内の第1の共有バスのインタフェースは、割込み要求信号をエンコードし制御系データと
して転送出力するマスタ出力部と、転送入力した制御系データを1時保持およびデコード
し割込み要求信号を生成するスレーブ入力部とを備える。
第1のアービタ105は、複数のプロセサ要素01〜0nからバス要求信号MREQおよ
び優先度信号MPRIをサイクルごとにそれぞれ受け付け、最も優先度の高いプロセサ要
素に対し第1の共有バスのバス許可信号MGRANTを発行して、次のサイクルの第1の
共有バスのバス使用権を調停し第1の共有バス回路100へ信号出力する。
図5は、第1の共有バスによる制御系データの転送例を示すタイミング図である。図5に
示すように、第1の共有バスによるデータ転送は、Request phaseとTra
nsfer phaseの2種類のフェーズにより実現される。Request pha
seは、1または複数サイクルを必要とし、転送を行いたいプロセサ要素がバス要求信号
を発行してから、バスの使用権付与を示すバス許可信号がアクティブになるまでの期間で
ある。また、Transfer phaseは、バス許可信号をクロック信号でラッチし
た信号がアクティブな期間がそのプロセサ要素にバスが割り当てられている期間であり、
そのプロセサ要素がマスタとなれる期間であり、基本的に1サイクルでの転送となる。
つまり、Request phaseにてマスタに対してバス許可信号が発行された次の
1サイクルで、アドレス信号などのコントロール信号およびデータ信号全てを出力し、転
送を完了する。データの転送が終了したらバス要求信号を立ち下げる。すると、バスアー
ビタは他のバス割り当てを要求しているプロセサ要素にバスの使用権を割り当てることが
できる。また、マスタ側選択信号MSELによって選択され、スレーブ側選択信号SSE
Lがアクティブとなったプロセサ要素はスレーブとなり、コントロール信号およびデータ
信号などの全ての転送データをTransfer phaseの末尾のクロックタイミン
グでラッチする。
上述のように、第1の共有バスで制御系データの転送するため、バスアービタ105は、
サイクルごとにバス使用権の切り替えを行い、バス許可信号がアクティブになった次のサ
イクルが、そのマスタにバスの使用権がある期間である。したがって、各プロセサ要素は
、制御系データの転送要求の発生ごとにバスアービタに対してバス要求する必要があり、
また、バス許可に基づき、制御系データの種類に対応して、次に示す書込み転送,読出し
返送要求転送,返送書込み転送または割込み要求転送を1サイクルごとのマルチプレクス
モードでそれぞれ行う。
書込み転送において、プロセサ要素は、制御系データの転送要求に対応して第1の共有バ
スのバス要求信号を出力しバス許可信号の入力に応じてマスタとして制御系データを転送
出力し第1の共有バスを介して選択信号に基づき選択されスレーブとして制御系データを
入力し制御信号およびアドレス信号に基づきメモリ書込みを行う。
読出し返送要求転送において、プロセサ要素は、返送先コードを含む制御系データの転送
要求に対応して第1の共有バスのバス要求信号を出力しバス許可信号の入力に応じてマス
タとして返送先コードを転送出力し、第1の共有バスを介して選択信号に基づき選択され
スレーブとして返送先コードを入力し制御信号およびアドレス信号に基づきメモリデータ
を読み出して制御系データとし返送要求を行う。
返送書込み転送において、プロセサ要素は、読出し返送要求転送の返送要求に対応して第
1の共有バスのバス要求信号を出力しバス許可信号の入力に応じてマスタとして返送先コ
ード対応の選択信号を転送出力し、第1の共有バスを介して選択信号に基づき選択されス
レーブとして制御系データを入力し制御信号およびアドレス信号に基づきメモリ書込みを
行う。
図6は、これら読出し返送要求転送および返送書込み転送のリンク動作のシーケンスを説
明するための説明図である。ここで、分図(a),(b),(c)は、ステップ1,2,
3の動作をそれぞれ示す。図6に示すように、まず、図6(a)のステップ1において、
プロセサ要素01が、返送先コードを含む制御系データの転送要求に対応してマスタとな
り、読み出したいメモリのアドレスRADDRおよび返送先コードを転送する。このとき
、制御信号の1つであるライトイネーブル信号MWEをインアクティブにすることで読出
し返送要求であることをスレーブのプロセサ要素02へ伝える。データ出力信号(MDB
O)には、要求元がプロセサ要素01であることがわかる情報を転送する。
次に、図6(b)のステップ2において、プロセサ要素02が内部メモリからデータを読
み出し返送要求を行う。この期間、同時にバスの使用権は解放され、バスアービタは他の
データ転送をバスに割り当てることができる。
次に、図6(c)ステップ3において、今度はプロセサ要素02がマスタとなり、読出し
データを返送先コード対応の転送先へ返送する。このとき、制御信号の1つであるレスポ
ンス信号MRESをアクティブにすることで転送データが読み出しデータであることを伝
えることができる。または、アドレス信号を読み出しデータ返送用の専用アドレスにする
ことで伝えてもよい。
これら書込み転送,読出し返送要求転送または返送書込み転送において、プロセサ要素は
、第1の共有バスを介して選択信号に基づき選択されスレーブとして、内部プロセッサの
内部割込み処理でなく専用のメモリ制御部により、制御信号およびアドレス信号に基づき
メモリ書込みまたはメモリ読出し返送要求を行う。これにより、プロセサ要素間のデータ
転送が高速化し、プロセサ要素の内部プロセッサのデータ処理効率が向上する。
また、割込み要求転送において、プロセサ要素が、図4に示した第1の共有バスのインタ
フェースのマスタ出力手段およびスレーブ入力手段により、割込み要求を含む制御系デー
タの転送要求に対応して第1の共有バスのバス要求信号を出力しバス許可信号の入力に応
じてマスタとして割込み要求を転送出力し、第1の共有バスを介して選択信号に基づき選
択されスレーブとして割込み要求を入力し制御信号およびアドレス信号に基づき割込み要
求内部割込み処理を行う。このとき、必要に応じて、マスタにおいて、割込み要求として
割込み要因および転送元コードを転送し、スレーブにおいて、割込み要因に対応した内部
割込み処理を行い、その終了時に、処理結果をマスタとして転送元コードに応じて書込み
転送することもできる。
この割込み要求転送により、割込み要求信号の専用線を用いず、データ生成終了タイミン
グなどをCPUに知らせることができ、割込み要求信号の追加・変更・削除、または、プ
ロセサ要素の物理的な追加・変更・削除が行われても、他のプロセサ要素および共有バス
の設計変更点を最小にできる。
図7は、本実施形態のマルチプロセサシステムにおける第2の共有バスを介したデータ転
送を説明するための説明図である。第2の共有バスを介したデータ転送は、予め転送方向
が決まっている入出力データの転送を想定している。このため、転送を行うプロセサ要素
は限定され、マスタまたはスレーブの一方は、そのマルチプロセサシステムのホストプロ
セサ,DMAコントローラまたはメインメモリとなる可能性が高い。また、転送方向も書
込み転送に限定され、マスタからスレーブへの一方向の転送とする。また、第2の共有バ
スを介したデータ転送では、転送方向および転送トラフィックに応じて、図7(a)に示
すような1対1の転送に限定する個別バスの形態と、図7(b)に示すような複数の転送
間で共有する共有バスの形態とが考えられる。これにより、読み出し転送を考慮した場合
の回路構成に比べて、回路規模を削減できる。しかしながら、図7(c)に示すようなマ
スタおよびスレーブ間の両方向の転送を考慮した構成でも何ら問題はない。
図8は、第2の共有バス回路200の内部構成例および周辺接続例を示すブロック図であ
る。図8を参照すると、第2の共有バス回路200は、マルチプレクサ,デマルチプレク
サを備え、従来と同じく、マルチプレクサは、第2の共有バスのマスタとして動作するプ
ロセサ要素から選択信号MSEL,制御信号MWE,アドレス信号MADDRおよび制御
系データMDATAをそれぞれ入力し、第2のアービタ105からの第2の共有バスのバ
ス使用権に対応した信号により第2の共有バスへ選択的に切り替え出力し、第2の共有バ
スを介して、第2の共有バスのスレーブとして動作するプロセサ要素へ出力し、デマルチ
プレクサは、スレーブとして動作するプロセサ要素から第2の共有バスを介して制御信号
SREADYを入力し、マスタとして動作する転送先のプロセサ要素へそれぞれ切り替え
分配する。
上述のように、図8では、第2の共有バス回路200が、論理合成等のインプリメント容
易性を考慮して、MUX型のバス構成となっているが、第1の共有バスと同様に、インプ
リメント容易性および動作遅延の見積りが許せば、3−state型のバス構成でも何ら
問題はない。
複数のプロセサ要素01〜0nの少なくとも1つが、従来と同じく、入出力データの転送
要求に対応して、第2の共有バスのバス要求信号MREQを出力し、バス許可信号MGR
ANTの入力に応じてマスタとして制御信号MWE,アドレス信号MADDRを出力し制
御信号MREADYに応じて入出力データMDATAをバースト転送し、また、複数のプ
ロセサ要素01〜0nの少なくとも1つが、従来と同じく、第2の共有バスを介して接続
されたスレーブとして、制御信号SWE,アドレス信号SADDRを入力し制御信号SR
EADYを出力して入出力データSDATAをバースト転送する。
第2のバスアービタ205は、従来と同じく、複数のプロセサ要素01〜0nから第2の
共有バスのバス要求信号をサイクルごとにそれぞれ受付け、最も優先度の高いプロセサ要
素に対し第2の共有バスのバス許可信号を発行してバス使用権を調停する。
なお、第2の共有バスを共有化しない場合は、従来と同じく、第2の共有バス回路200
および第2のバスアービタ205は不要であり、個別バスにより、マスタおよびスレーブ
間が接続される。 図9は、第2の共有バスによる入出力データの転送例を示すタイミン
グ図である。図9に示すように、第2の共有バスによるデータ転送は、例えば、アドレス
信号MADDRおよび制御信号MWEが発行された次のサイクルに、そのアドレスに対応
するデータ信号MDATAが出力される。まず、転送を行いたいプロセサ要素はバス要求
信号MREQを発行し、タイミングT2でバスの使用権を要求する。次に、タイミングT
4で、マスタがアクティブであるバス許可信号MGRANTをラッチしたら、アドレス信
号MADDRを出力し、制御信号MWEをアクティブにする。スレーブは、制御信号MW
Eがアクティブであることを認識し、次のタイミングT5で、アドレス信号MADDRを
ラッチする。同時に、マスタはアドレス信号MADDRに対応するデータ信号MDATA
を出力する。スレーブは、ラッチしたアドレスに対して書き込めるかどうかのレスポンス
を、制御信号SREADYとして返送する。マスタがアクティブである制御信号SREA
DYをラッチしたタイミングT6で転送は完了し、スレーブ側で転送データの書込み処理
が行われる。また、読み出し転送を考慮したバスの場合には、スレーブは、アクティブな
制御信号SREADYの発行と同時に読み出しデータの返送を行う。
図10は、上述した本実施形態のマルチプロセサシステムを具体的なW−CDMAディジ
タルベースバンドLSIに適用した実施例を示すブロック図である。この実施例のマルチ
プロセサシステムは、W−CDMAディジタルベースバンドLSIのシステム全体を制御
するプロセサ要素のCCPU300,制御系データ用メモリ301,入出力データ用メモ
リ302,入出力データ転送用DMAコントローラ303と、ディジタルベースバンドL
SIの各処理を行うプロセサ要素01〜08,デバグ用処理要素10と、主に制御系デー
タを転送し全てのプロセサ要素間で双方向に転送可能な第1の共有バス回路100と、主
に転送経路の決まっている受信データ,送信データ用の入出力データを転送する第2の共
有バス回路200,201と、それぞれの共有バスの使用権を調停する第1,第2のバス
アービタ105、205と、それぞれの共有バスおよびCCPUバスの間のブリッジ回路
110,210とから構成される。ここで、プロセサ要素07,08は、HSDPA処理
,GSM処理の拡張プロセサ要素として存在する。
この実施例のマルチプロセサシステムにおいては、基本的には、プロセサ要素CCPU3
00がマスタとなって、第1の共有バスを介して各プロセサ要素01〜08を制御するこ
とでシステムを実現している。しかしながら、CCPU300以外の各プロセサ要素01
〜08も第1の共有バスのマスタになることができ、従来バスであればスレーブ同士とな
るプロセサ要素01〜08間の転送もCCPU300を介さずに直接行うことができる。
具体的には、プロセサ要素01〜08間における動作タイミング信号,パラメータ信号,
ステータス信号および割込み信号など制御系データの転送を、第1の共有バスを用いて直
接行う。
各々のプロセサ要素で処理される入出力データの転送は、第2の共有バスを介して行われ
る。図10に示した例では、第2の共有バスはその転送データの転送方向から2本に分離
されており、主に受信データ,送信データ用の入出力データを転送する第2の共有バス回
路200,201が存在する。受信データ用の第2の共有バス回路200では、マスタと
して接続されているプロセサ要素05,07,08であるFEC,HSDPA,GSMか
ら、スレーブとして接続されているプロセサ要素である入出力データ用メモリ302に対
して受信データの転送が行われる。また、送信データ用の第2の共有バス回路201では
、マスタとして接続されているプロセサ要素04であるDEMおよびブリッジ回路210
経由のDMAコントローラ303から、スレーブとして接続されているプロセサ要素05
,06,08であるFEC,MOD,GSMに対して、復調データおよび送信データの転
送が行われる。
効果としては、転送トラフィックの大きい入出力データ転送中に、複雑な制御系データの
転送が発生した場合でも、制御系データおよび入出力データの転送を異なるバスを用いて
行うことにより、柔軟なシステムが実現できる。例えば、CPU300による制御系デー
タの転送と、DMAコントローラ303による入出力データの転送を同時に行うことが可
能になる。また、他のプロセサ要素間においても同様に、転送データ数の多い入出力デー
タの転送中に制御系データを転送することが可能になる。
また、プロセサ要素07,08がHSDPA処理,GSM処理の拡張プロセサ要素として
接続されるように、本実施形態における第1,第2の共有バスを用いて全体のマルチプロ
セサシステムを構成することによって、第1,第2の共有バスの仕様をほとんど変更する
ことなく、このような拡張プロセサ要素の追加・変更・削除にも柔軟に対応可能である。
図11,図12は、本発明のマルチプロセサシステムの実施形態2における各プロセサ要
素,デバグ用処理要素の構成の一部をそれぞれ示す部分ブロック図である。
本実施形態のマルチプロセサシステムの全体の構成は、図1に示した実施形態1のマルチ
プロセサシステムと同構成であり、各プロセサ要素およびデバグ用処理要素以外の各ブロ
ックも同構成であり、各プロセサ要素およびデバグ用処理要素の内部構成が異なる。
図11を参照すると、本実施形態のマルチプロセサシステムにおける各プロセサ要素01
〜0nは、第1の共有バスに接続するためのインタフェース回路21と、種々の演算およ
びプロセサ要素内のコントロールを行うDSPおよびMPUなどの内部プロセサ22と、
内部プロセサ22の命令コードを格納している命令コード記憶装置23と、命令アドレス
のトレース機能をもつアドレストレーサ24とを備える。もちろん、各プロセサ要素内に
は、これらの他にもデータ処理を行う専用ハードウェアアクセラレータ、各種レジスタお
よびメモリなどの記憶装置などを備えていても何ら問題はない。
これら各プロセサ要素01〜0nの動作について説明すると、まず、本実施形態のマルチ
プロセサシステム全体およびプロセサ要素単体の仕様により、その処理がデバグルーチン
に入った場合、DSPおよびMPUなどの内部プロセサ22は、アドレストレーサ24に
対する制御信号Control signalsを用いて、アドレストレーサ24に対し
て命令アドレストレース開始を指示する。
次に、アドレストレーサ24は、命令コード記憶装置23に対する命令アドレスを監視す
ることでトレースデータTrace Dataを作成し、バスインタフェース回路21に
トレースデータを転送する。このとき、トレースデータの生成法としては、読み出された
命令アドレス全てをそのまま転送する方法を用いても良いし、または、トレースデータの
転送データ数を削減するために、通常の動作シーケンスは単調増加のインクリメント方式
で行われることに着目し、それ以外の分岐またはウェイトなどのアドレスジャンプが発生
した場合にだけトレースデータを生成し、転送する方法を用いても何ら問題はない。
最後に、バスインタフェース回路21は、通常動作における転送データOutput D
ataが存在する場合には通常転送データを優先的にバス転送し、存在しなくなった場合
にだけ、すなわち、通常データ転送の合間に、生成されたトレースデータを転送先である
デバグ処理要素10のDBGIFに向けて第1の共有バス回路100へ転送する。具体的
には、バスインタフェース回路21は、第1の共有バス回路100へデータ転送出力のた
めにFIFOバッファを持ち、通常データ転送用のFIFOバッファ内にデータが存在し
なくなってから、トレースデータ用のFIFOバッファ内のトレースデータを読み出して
転送する。
図12(a)を参照すると、本実施形態のマルチプロセサシステムにおけるデバグ用処理
要素10は、共有バス上の転送データをラッチするレシーブユニットと、デバグ用に共有
バス上の転送経路が所望の条件を満たしているかを判断するスヌーピングユニットと、第
1および第2の共有バスに対してラッチしたデータを格納する2つの記憶装置とを備える
。また、これら2つの記憶装置を1つにして、第1,第2の共有バスに対して共通とし、
マルチプレクサで切り替えながらデータを書き込む構成が図12(b)に示されている。
このデバグ用処理要素10の動作について説明すると、レシーブユニットがデータをラッ
チする動作として2つある。1つは、第1,第2の共有バスのスレーブとして動作する場
合である。転送先がデバグ用処理要素10であった場合にデータを取り込む。もう1つは
、デバグ用にバスモニタを行うときである。この場合には、スヌーピングユニットにおい
て、第1,第2の共有バス上を転送されるデータの転送経路の条件BSEL,BDECお
よび書込みアドレスSADDRが所望の範囲を満たしていた場合に、レシーブユニットは
データを取り込みデバグ用記憶装置に書き込む。このとき、その書込みアドレスSADD
Rは、通常のスレーブ動作の場合は、そのまま転送されてきたアドレスになり、バスモニ
タ動作の場合には、スヌーピングユニットが指定したアドレスとなる。
なお、図12においては、デバグ用処理要素10で取得したデータを専用の記憶装置に書
き込む場合について示したが、実際には、記憶装置に書き込まず、直接外部に出力してモ
ニタできる構成でも何ら問題はない。
この実施形態2において、プロセサ要素ごとのアドレストレース機能によって生成された
トレースデータを、第1の共有バスを用いて全てのプロセサ要素共通のデバグ用記憶装置
に転送することにより、従来プロセサ要素ごとに実装されていたトレースメモリの削減に
つながる。これは、全てのプロセサ要素がマスタになれるという第1の共有バスの特徴に
よって実現される。従来、プロセサ要素ごとに必要とされていたトレースメモリを削減で
き、デバグ用の共通記憶装置としてまとめることにより、マルチプロセサシステムとして
効率的に利用可能となる。
また、通常動作中の共有バスを使用していない期間を利用してトレースデータが転送され
るため、バスモニタ機能と組み合わせることにより、通常動作におけるプロセサ要素間の
転送データと、1つまたは複数のプロセサ要素のアドレストレースデータを、同時にモニ
タリングできるという利点もある。すなわち、一度動作を停止してから読み出す必要はな
く、通常動作中にアドレストレース情報を取得できる。特に、トレースデータを分岐時な
どに限定して作成することで削減することにより、アドレストレーサのリアルタイム性を
より高く実現できる。
また、実施形態2と同様の原理を利用して、アドレストレースデータだけではなく、デバ
グ時におけるプロセサ要素内の任意のデバグ用データ信号も、第1の共有バスを用いてデ
バグ用処理要素10に対して転送可能であることを付記しておく。
図13は、本発明によるマルチプロセサシステムの実施形態3を示す全体ブロック図であ
る。図13を参照すると、本実施形態のマルチプロセサシステムの全体の構成は、図1に
示した実施形態1のマルチプロセサシステムに対し各プロセサ要素01〜0nと第1のバ
スアービタ105および第1の共有バス回路100との間にそれぞれ同期回路30を挿入
追加した構成である。また、第1のバスアービタ105以外の各ブロックは、実施形態1
の各ブロックと同構成であり、第1のバスアービタ105の内部構成が異なる。また、図
示してないが、プロセサ要素01〜0nの基本クロック信号に同期し且つ第1の共有バス
の転送トラフィックに応じて基本クロック信号の整数倍周波数のバスクロック信号を生成
するクロック生成回路を備える。
図14は、本実施形態のマルチプロセサシステムにおいて挿入追加された同期回路30の
挿入箇所を説明するための説明図である。各プロセサ要素01〜0nと第1のバスアービ
タ105との間に、アービタ同期回路30aがそれぞれ挿入され、各プロセサ要素01〜
0nのスレーブ入力と第1の共有バス回路100との間に、スレーブ同期回路30bがそ
れぞれ挿入される。また、図15は、図14に示したアービタ同期回路30a,スレーブ
同期回路30bの構成例をそれぞれ示すブロック図であり、図16は、図15のアービタ
同期回路30a,スレーブ同期回路30bに供給されるバスクロック信号および基本クロ
ック信号の動作を示すタイミング図である。
アービタ同期回路30aは、各プロセサ要素から基本クロック信号に同期して発行される
バス要求信号MREQをバスクロック信号に同期させ信号BREQとしてバスアービタに
転送するための追加回路と、可変であるバスクロック信号に同期して第1のバスアービタ
105から発行されるバス許可信号BGRANTを、基本クロック信号に同期させ、信号
MGRANTとして各プロセサ要素のバスインタフェース回路21に転送する追加回路と
を備える。
これら追加回路により、バス要求信号MREQが基本クロック信号に同期して発行されて
も、バス許可信号BGRANTがアクティブになった場合は、その基本クロック信号のサ
イクル中の残りのバスサイクルにおいてはバスアービタに対するバス要求信号BREQを
インアクティブにする。また、バス許可信号BGRANTはバスクロック信号に同期して
発行されるが、次の基本クロック信号の立ち上がりタイミングまで、そのバス許可信号を
保持してプロセサ要素のバスインタフェース回路に転送できる。
スレーブ同期回路30bは、第1の共有バス回路100からバスクロック信号に同期して
入力される転送データ信号BSSEL,BADDR,BDBIなどを、基本クロック信号
に同期させ信号SSEL,SADDR,SDBIなどとして転送するための追加回路を備
える。
この追加回路により、第1の共有バスからバスクロック信号に同期して1つのスレーブに
対して転送が行われた場合には、同一のスレーブに対しては基本クロックの1サイクル中
に多くても一回の転送しか発生しないが、プロセサ要素のバスインタフェース回路がデー
タをラッチする次の基本クロックの立ち上がりタイミングまでその転送データを保持でき
る。
これらアービタ同期回路30aおよびスレーブ同期回路30bは、基本的には可変である
バスクロック信号に同期して動作するが、バスクロック信号の周波数が最も低い周波数、
すなわち基本クロック信号の周波数である場合には、内部のレジスタへのクロックを停止
できるという特徴をもつ。
図17は、本実施形態のマルチプロセサシステムにおける第1のバスアービタの構成例を
示すブロック図である。図17を参照すると、本実施形態のマルチプロセサシステムにお
ける第1のバスアービタは、図1の第1のバスアービタに対して、アービタ同期回路を介
して複数のプロセサ要素から第1の共有バスのバス要求信号を基本クロック信号のサイク
ルごとにそれぞれ1度だけ受け付けマスクするためのマスク機能と、各バスサイクルでの
第1の共有バスのバス許可信号の発行から次のサイクルの各バスサイクルのバス使用権を
調停し信号出力するための遅延機能とを追加している。
これらマスク機能および遅延機能により、例えば、図17に示すように、バスクロック信
号の周波数が基本クロック信号の周波数(30MHz)の1倍,2倍,4倍の場合には、
1バスサイクル前,2サイクル前,4サイクル前のバス調停結果に対応したバス選択信号
BSELにより第1の共有バス回路100を動作させる。また、基本クロックの同一サイ
クル内においては、同一プロセサ要素をスレーブとする転送は多くても1回だけ行うこと
ができ、各プロセサ要素は、バスクロック信号に依存せずに常に基本クロックで動作でき
る。
上述のように、本実施形態のマルチプロセサシステムにおける第1のバスアービタは、第
1の共有バス回路100の転送トラフィックを保証するため、および、物理的にバス本数
を増やすことによる回路規模増加を防ぐために、第1の共有バス回路100を、基本クロ
ック信号の周波数を定数倍したバスクロック信号の周波数で動作させる。
このとき、常に定数倍したクロックで動作させると、回路のスイッチング回数が増加し、
消費電力が大きくなってしまうという問題があるため、バスクロックを可変にできるよう
にする。例えば、転送トラフィックが多い処理ルーチン、および、実施形態2に示したデ
バグ時のアドレストレースを基本クロック信号より速いバスクロック信号を用いて第1の
共有バス回路100を動作させる。
すなわち、本実施形態である可変クロックの第1の共有バス回路100では、専用ハード
ウェアを用いて何か信号を常に監視して、完全に動的なクロック切り替えを行わず、実際
には、システム全体の処理ルーチンが転送トラフィックの大きいルーチンに入る場合、も
しくは、他のある条件を満たした場合にのみ、CPUなどから切り替え信号が発行され、
バスクロックが切り替わる仕組みとする。
これら同期回路30および第1のバスアービタに対して、例えば、図16に示したスター
ト位置信号staが必要になるだけである。このスタート位置信号staは、基本クロッ
ク信号を30MHzとし、可変であるバスクロック信号を30MHz,60MHz,12
0MHzとした場合、基本クロック信号の立ち上がりタイミング時に、可変であるバスク
ロック信号に同期して1サイクルだけアクティブになる。また、第1の共有バスに対する
プロセサ要素のデータ出力側には、追加回路は不要である。
本実施形態のマルチプロセサシステムにおいて、バスの動作クロックを可変(定数倍)に
することによって、物理的にバス本数を増やす場合に比べて回路規模オーバヘッドを抑え
たままで、転送トラフィックを広い範囲で保証できることである。これにより、新たな転
送トラフィックの発生にも柔軟に対応できる可能性が増加するため、拡張容易性も向上す
る。また、バスの動作クロックを常に速くしておく高速転送バスに比べて、必要なときに
だけ速くする可変にすることで低消費電力化が実現できる。
また、バスの動作クロックの切り替えを、例えば、転送の多い処理ルーチンおよびデバグ
時などは高速なバス動作クロックを用いるなど、マクロ的なシステムレベルで制御するこ
とで、回路規模および消費電力など効率の良いシステムを実現できる。最後に、共有バス
が基本クロックに同期して動作する場合には、同期回路30内の全てのレジスタにおける
入力クロックを停止でき、低消費電力化が実現できる。
本発明によるマルチプロセサシステムの実施形態1を示す全体ブロック図である。 図1における第1の共有バスを介したデータ転送を説明するための説明図である。 図1における第1の共有バス回路100の内部構成例および周辺接続例を示すブロック図である。 図1における各プロセサ要素内の第1の共有バスのマスタ側およびスレーブ側インタフェースの1部を示す部分ブロック図である。 図3における第1の共有バスによる制御系データの転送例を示すタイミング図である。 図3における第1の共有バスによる読出し返送要求転送および返送書込み転送のリンク動作のシーケンスを説明するための説明図である。 図1における第2の共有バスを介したデータ転送を説明するための説明図である。 図1における第2の共有バス回路200の内部構成例および周辺接続例を示すブロック図である。 図8における第2の共有バスによる入出力データの転送例を示すタイミング図である。 図1のマルチプロセサシステムを具体的なW−CDMAディジタルベースバンドLSIに適用した実施例を示すブロック図である。 本発明のマルチプロセサシステムの実施形態2における各プロセサ要素の構成の一部を示す部分ブロック図である。 本発明のマルチプロセサシステムの実施形態2におけるデバグ用処理要素の構成の一部を示す部分ブロック図である。 本発明によるマルチプロセサシステムの実施形態3を示す全体ブロック図である。 図13のマルチプロセサシステムにおいて挿入追加された同期回路30の挿入箇所を説明するための説明図である。 図14に示したアービタ同期回路30a,スレーブ同期回路30bの構成例をそれぞれ示すブロック図である。 図15のアービタ同期回路30a,スレーブ同期回路30bに供給されるバスクロック信号および基本クロック信号の動作を示すタイミング図である。 図13のマルチプロセサシステムにおける第1のバスアービタの構成例を示すブロック図である。 従来のマルチプロセサシステムの構成例を示すブロック図である。
符号の説明
01〜0n プロセサ要素
10 デバグ用処理要素
12−1,12−2 プロセサ
13−1,13−2 バスコントローラ
15−1,15−2 アダプタ
16−1,16−2,16−3 入出力装置
21 バスインタフェース回路
22 内部プロセサ
23 命令コード記憶装置
24 アドレストレーサ
30,30a,30b 同期回路
100 第1の共有バス回路
105 第1のバスアービタ
110,210 ブリッジ回路
200,201 第2の共有バス
205 第2のバスアービタ
300 CCPU
301 制御系データ用メモリ
302 入出力データ用メモリ
303 DMAコントロー

Claims (15)

  1. それぞれデータ処理し、制御系データまたは入出力データの転送要求
    に対応して第1または第2の共有バスのバス使用権を獲得し、マスタとして1サイクルごとにバス使用権を切り替え可能な転送方法であるマルチプレクス転送またはバースト転送する複数のプロセサ要素を備えるマルチプロセサシステムであって、
    前記複数のプロセサ要素を構成する第1のプロセサ要素と第2のプロセサ要素は、
    前記制御系データの転送要求に対応して第1の共有バスのバス要求信号を出力し、バス
    許可信号の入力に応じてマスタとして転送先の選択信号,制御信号,アドレス信号および
    前記制御系データを1サイクルで転送出力するマスタ機能と、
    前記第1の共有バスを介して前記選択信号に基づき選択され、スレーブとして前記制御
    系データを入力し、前記制御信号および前記アドレス信号に基づき処理するスレーブ機能
    との両方の機能を備え、

    さらに前記第1のプロセサ要素と前記第2のプロセサ要素は、
    返送先コードを含む制御系データの転送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記返送先コードを転送出力する第1の機能と、
    第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記返送先コードを入力し、前記制御信号および前記アドレス信号に基づきメモリデータを読み出して制御系データとし返送要求を行う第2の機能と、を有し、
    前記プロセサ要素間の読出し返送要求転送を行い、
    前記返送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記返送先コード対応の選択信号を転送出力する第3の機能と、
    第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記制御系データを入力し、前記制御信号および前記アドレス信号に基づきメモリ書込みを行う第4の機能と、を有し、
    前記プロセサ要素間の返送書込み転送と、
    を行うことを特徴とするマルチプロセサシステム。
  2. 前記第1のプロセサ要素は、返送先コードを含む制御系データの転送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記返送先コードを転送出力し、
    前記第2のプロセサ要素は、第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記返送先コードを入力し、前記制御信号および前記アドレス信号に基づきメモリデータを読み出して制御系データとし返送要求を行い、前記プロセサ要素間の読出し返送要求転送を行い、
    前記第2のプロセサ要素は、前記返送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記返送先コード対応の選択信号を転送出力し、
    前記第1のプロセサ要素は、第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記制御系データを入力し、前記制御信号および前記アドレス信号に基づきメモリ書込みを行い、前記プロセサ要素間の返送書込み転送を行うことを特徴とする請求項1に記載のマルチプロセサシステム。
  3. 前記第1のプロセサ要素と前記第2のプロセサ要素は、
    前記制御系データの転送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記制御系データを転送出力する第5の機能と、
    第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記制御系データを入力し、前記制御信号および前記アドレス信号に基づきメモリ書込みを行う第6の機能と、を有し、前記プロセサ要素間の書込み転送とを行うことを特徴とする請求項1または2に記載のマルチプロセサシステム。
  4. 前記第1のプロセサ要素は、
    前記制御系データの転送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記制御系データを転送出力し、
    前記第2のプロセサ要素は、
    第1の共有バスを介して前記選択信号に基づき選択されスレーブとして前記制御系データを入力し、前記制御信号および前記アドレス信号に基づきメモリ書込みを行い、前記プロセサ要素間の書込み転送とを行うことを特徴とする請求項3に記載のマルチプロセサシステム。
  5. 前記複数のプロセサ要素から、前記選択信号,前記制御信号,前記ア
    ドレス信号および前記制御系データをそれぞれ入力し、第1の共有バスのバス使用権に対
    応して第1の共有バスへ選択的に切り替え出力し、第1の共有バスを介して前記選択信号
    に基づき前記複数のプロセサ要素の1つをスレーブとして選択し、前記制御信号,前記ア
    ドレス信号および前記制御系データを出力する第1の共有バス回路と、
    前記複数のプロセサ要素からバス要求信号をサイクルごとにそれぞれ受け付け、最も優
    先度の高いプロセサ要素に対し第1の共有バスのバス許可信号を発行して次のサイクルの
    バス使用権を調停する第1のバスアービタ
    とを備える、請求項1から4のいずれか1項に記載のマルチプロセサシステム。
  6. 第1の共有バス回路が、
    前記複数のプロセサ要素から前記選択信号,前記制御信号,前記アドレス信号および前
    記制御系データをそれぞれ入力し、第1の共有バスのバス使用権に対応して第1の共有バ
    スへ選択的に切り替え出力するマルチプレクサと、
    第1の共有バス上の前記選択信号をデコードし前記複数のプロセサ要素の1つを転送先
    のスレーブとして選択するデコーダと、
    第1の共有バス上の前記制御信号,前記アドレス信号および前記制御系データをそれぞ
    れ入力し、前記デコーダの出力に対応して転送先のスレーブへそれぞれ切り替え分配する
    デマルチプレクサ
    とを備える、請求項5記載のマルチプロセサシステム。
  7. 前記プロセサ要素が、第1の共有バスを介して前記選択信号に基づき
    選択され、スレーブとして内部割込み処理でなく専用のメモリ制御部により、前記制御信
    号および前記アドレス信号に基づきメモリ書込みまたはメモリ読出し返送要求を行う、請
    求項1から6のいずれか一項に記載のマルチプロセサシステム。
  8. 前記プロセサ要素が、割込み要求を含む制御系データの転送要求に対
    応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとし
    て前記割込み要求を転送出力し、第1の共有バスを介して前記選択信号に基づき選択され
    スレーブとして前記割込み要求を入力し、前記制御信号および前記アドレス信号に基づき
    前記割込み要求に対応した内部割込み処理を行う割込み要求転送を行う、請求項1から7
    のいずれか一項に記載のマルチプロセサシステム。
  9. 前記割込み要求が、割込み要因および転送元コードを含む、請求項8
    記載のマルチプロセサシステム。
  10. 第1および第2の共有バス上の前記制御系データおよび前記入出力データを転送経路およびアドレス範囲の一致に応じてスヌーピングし、デバグ用メモリに記憶するデバグ用処理要素を備える、請求項1から9のいずれか一項に記載のマルチ
    プロセサシステム。
  11. 前記プロセサ要素が、内部プロセッサの実行命令のアドレスをトレースしトレースデータを作成して制御系データとし、その転送要求に対応して第1の共有バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記トレースデー
    タを転送出力する、請求項1から10のいずれか一項に記載のマルチプロセサシ
    ステム。
  12. 前記プロセサ要素が、内部プロセッサの実行命令のアドレスをトレ
    ースしトレースデータを作成して制御系データとし、その転送要求に対応して第1の共有
    バスのバス要求信号を出力し、バス許可信号の入力に応じてマスタとして前記トレースデ
    ータを転送出力し、
    前記デバグ用処理要素が、第1の共有バスを介して前記選択信号に基づき選択され、ス
    レーブとして前記トレースデータを入力し前記制御信号および前記アドレス信号に基づき
    デバグ用メモリに記憶する、請求項10記載のマルチプロセサシステム。
  13. 前記プロセサ要素の基本クロック信号に同期し且つ第1の共有バス
    の転送トラフィックに応じて前記基本クロック信号の整数倍周波数のバスクロック信号を
    生成するクロック生成回路と、
    前記プロセサ要素から第1の共有バスのバス要求信号を入力し第1のバスアービタへ前
    記バスクロック信号に同期して出力し、第1のバスアービタから第1の共有バスのバス許
    可信号を入力し前記プロセサ要素へ前記基本クロック信号に同期して出力するアービタ同
    期回路と、
    第1の共有バスを介して前記選択信号,前記制御信号,前記アドレス信号および前記制
    御系データを入力し前記プロセサ要素へ前記基本クロック信号に同期して出力するスレー
    ブ同期回路とを備え、
    第1のバスアービタが、前記アービタ同期回路を介して前記複数のプロセサ要素から第
    1の共有バスのバス要求信号を前記基本クロック信号のサイクルごとにそれぞれ1度だけ
    受け付け、前記バスクロック信号の各バスサイクルで最も優先度の高いプロセサ要素に対
    し前記アービタ同期回路を介して第1の共有バスのバス許可信号を発行して次のサイクル
    の各バスサイクルのバス使用権を調停する、請求項5から12のいずれか一項に記載のマルチプロセサシステム。
  14. 前記複数のプロセサ要素の1つとして動作し、且つ前記入出力デー
    タの転送要求に対応して第2の共有バスのバス要求信号を出力し、バス許可信号の入力に
    応じてマスタとして前記入出力データをバースト転送するプロセサ要素と、
    前記複数のプロセサ要素の1つとして動作し、且つ第2の共有バスを介して接続された
    スレーブとして前記入出力データをバースト転送するプロセサ要素
    とを備える、請求項1から13のいずれか一項に記載のマルチプロセサシステム。
  15. 第2の共有バスのマスタまたはスレーブとして動作するプロセサ要
    素を第2の共有バスのバス使用権に対応して第2の共有バスに選択的に切り替え接続し、
    第2の共有バスを介してマスタおよびスレーブ間で前記入出力データをバースト転送する
    第2の共有バス回路と、
    前記複数のプロセサ要素から第2の共有バスのバス要求信号をサイクルごとにそれぞれ
    受付け、最も優先度の高いプロセサ要素に対し第2の共有バスのバス許可信号を発行して
    バス使用権を調停する第2のバスアービタ
    とを備える、請求項14記載のマルチプロセサシステム。
JP2008186812A 2008-07-18 2008-07-18 マルチプロセサシステム Expired - Fee Related JP4609540B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2008186812A JP4609540B2 (ja) 2008-07-18 2008-07-18 マルチプロセサシステム

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2008186812A JP4609540B2 (ja) 2008-07-18 2008-07-18 マルチプロセサシステム

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2003120591A Division JP4182801B2 (ja) 2003-04-24 2003-04-24 マルチプロセサシステム

Publications (2)

Publication Number Publication Date
JP2008293524A JP2008293524A (ja) 2008-12-04
JP4609540B2 true JP4609540B2 (ja) 2011-01-12

Family

ID=40168116

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2008186812A Expired - Fee Related JP4609540B2 (ja) 2008-07-18 2008-07-18 マルチプロセサシステム

Country Status (1)

Country Link
JP (1) JP4609540B2 (ja)

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH056333A (ja) * 1991-06-28 1993-01-14 Fujitsu Ltd マルチプロセサシステム
CA2129882A1 (en) * 1993-08-12 1995-02-13 Soheil Shams Dynamically reconfigurable interprocessor communication network for simd multiprocessors and apparatus implementing same
JPH11265342A (ja) * 1998-03-17 1999-09-28 Nec Saitama Ltd データ転送装置およびデータ転送方法

Also Published As

Publication number Publication date
JP2008293524A (ja) 2008-12-04

Similar Documents

Publication Publication Date Title
JP4182801B2 (ja) マルチプロセサシステム
JP4895183B2 (ja) メモリコントローラ
EP1239374A1 (en) Shared program memory for use in multicore DSP devices
JP5102789B2 (ja) 半導体装置及びデータプロセッサ
JP2004171209A (ja) 共有メモリデータ転送装置
WO2011148920A1 (ja) マルチプロセッサシステム、実行制御方法、実行制御プログラム
JP2013106166A (ja) クロックゲーティング回路およびバスシステム
JP5360061B2 (ja) マルチプロセッサシステム及びその制御方法
JP2007219816A (ja) マルチプロセッサシステム
US20070156937A1 (en) Data transfer in multiprocessor system
CN116028413A (zh) 一种总线仲裁器、总线仲裁的方法、装置及介质
JP2001117858A (ja) データ処理装置
JP2006040276A (ja) 選択的なクロック制御に基づいて消費電力を節減させるバス仲裁システム及びその方法
US6954869B2 (en) Methods and apparatus for clock domain conversion in digital processing systems
US8244994B1 (en) Cooperating memory controllers that share data bus terminals for accessing wide external devices
US8799699B2 (en) Data processing system
JP4609540B2 (ja) マルチプロセサシステム
US20040054843A1 (en) Configuration and method having a first device and a second device connected to the first device through a cross bar
JP2020046876A (ja) バス制御回路
JP4928683B2 (ja) データ処理装置
JP6978670B2 (ja) 演算処理装置および演算処理装置の制御方法
JP2009163531A (ja) 割り込み管理機構およびマイクロコンピュータ
JP4124579B2 (ja) バス制御システム
US20040064662A1 (en) Methods and apparatus for bus control in digital signal processors
JPH1185673A (ja) 共有バスの制御方法とその装置

Legal Events

Date Code Title Description
RD01 Notification of change of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7421

Effective date: 20090512

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

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20100927

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

Free format text: PAYMENT UNTIL: 20131022

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4609540

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

LAPS Cancellation because of no payment of annual fees