JP4493739B2 - 集積回路装置の診断手順 - Google Patents
集積回路装置の診断手順 Download PDFInfo
- Publication number
- JP4493739B2 JP4493739B2 JP34988597A JP34988597A JP4493739B2 JP 4493739 B2 JP4493739 B2 JP 4493739B2 JP 34988597 A JP34988597 A JP 34988597A JP 34988597 A JP34988597 A JP 34988597A JP 4493739 B2 JP4493739 B2 JP 4493739B2
- Authority
- JP
- Japan
- Prior art keywords
- cpu
- breakpoint
- chip
- signal
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/362—Software debugging
- G06F11/3648—Software debugging using additional hardware
Landscapes
- Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Theoretical Computer Science (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Test And Diagnosis Of Digital Computers (AREA)
- Debugging And Monitoring (AREA)
Description
【発明の属する技術分野】
本発明は集積回路装置の診断手順に関し、特に、診断手順を実行可能にするための、メモリ内のCPUのアドレスによって識別された特定命令のCPUによる実行の検出と、CPUの通常作動の中断に関する。
【0002】
【従来の技術及び発明が解決しようとする課題】
シリコンチップ上に統合されるCPUについての設計及び構造が数多くあり、この場合、CPUはシリコン領域の大部分またはわずかな部分を意味し、また、オン−チップメモリまたはオフ−チップメモリに記憶された命令を実行する。一般的には、このようなCPUは、命令ポインタ(Iptr)、プログラムカウンタ(PC)等として様々に知られている実行用命令へのポインタまたはこれらの実行用命令のメモリアドレスとして作動するレジスタを有する。現在実行される命令へのポインタ、次に実行される命令へのポインタ、メモリから次に取出される命令へのポインタ等の命令ポインタの種々のバージョンを有する複数のレジスタがある。
【0003】
種々の予測される構造によれば、メモリからの命令取出しタスクは識別可能な命令取出しユニットにより実施される。別の変更例は、このような命令取出しユニットに通常のCPUデータアクセスとは別のメモリにアクセスさせ、CPUと主メモリとの間にキャッシュ或いは別の命令及びデータキャッシュを挿入することを含む。
【0004】
命令ポインタレジスタの値を知ることは、CPU上で実行するソフトウエア上の診断機能を実行する際に特に重要である。最も簡単な場合、命令ポインタの値は外部メモリバス上のメモリアドレス値を観察することによって推測できる。しかしながら、より複雑な例では、Iptrの値はCPUの奥に隠れている。
ソフトウエア診断のための他の重要な特色は、特定の命令に到達した時にCPUを停止するか、又は、何らかの別の作動をとる能力である。Iptrが外部ピンから推測できる場合、ブレークポインティングは外部ハードウエアによってアシストされ得る。これが不可能の場合、ブレークポインティングを達成するのに共通に使用される2つの方法がある。
【0005】
1つの方法では、ブレークポイントされる命令の位置でメモリを修正して、CPUがブレークポイントされた命令の代わりに実行し、停止のような所望の結果を達成する命令と取り替えることによって「ソフトウエアブレークポインティング」を実行する。しかしながら、この解決方法は割り込みであり、命令が読み出し専用メモリに記憶される場合には作動せず、使用者がブレークポイント後に処理しようとする場合には正しい命令と取り替えるための著しいオーバヘッドが必要となる。
【0006】
第2の方法では、1つ以上のレジスタ及び比較ロジックが付加され、各レジスタはブレークポイント値を有する。Iptrがブレークポイントレジスタ値の1つと一致すると、CPUが停止する。この解決方法は、CPU内に又は非常に近接して存在するハードウエアを必要とするので、製作変更のために容易に取り外すことができない。また、この方法は、CPU自体によって行われる場合には割り込みであるか、または、付加外部ピン等の他のハードウエアサポートを必要とする何らかのブレークポイントレジスタをロードするための機構を必要とする。CPUがブレークポイントされた命令を実行使用とするのと同時に命令が取り出されるが割り込みのために実行されない場合には状況は複雑である。また、このような機構は、CPUがブレークポイントされた命令で安全に停止した場合にのみ満足に作動する。
【0007】
【課題を解決するための手段】
改良されたブレークポインティングシステムを提供することが本発明の目的である。
本発明によれば、
メモリから命令を取出して実行する取出し及び実行回路と、次に実行される命令のメモリ内のアドレスを保持する命令ポインタレジスタと、を含んで構成されるオン−チップCPUと、
CPUを前記メモリにアクセスさせる、CPUに接続されたバスと、
アドレス通信パスを介して命令ポインタレジスタの内容を受信するように接続されるとともに、CPUの通常作動が診断目的のために中断されるブレークポイントアドレスを保持するブレークポイントレジスタを有し、更に、ブレークポイントアドレスを命令ポインタレジスタの内容と比較して、マッチした時にブレークポイント信号パス上のブレークポイント信号を出力する比較回路を有するオン−チップブレークポイントユニットと、
ブレークポイント信号パスに接続され、ブレークポイント信号を受信した時にCPUの通常作動を中断するように配置されたオン−チップ制御ロジックと、を含んで構成され、
前記オン−チップブレークポイントユニットが、中断した後のCPUの通常作動の再開に関する前記次の命令のためのブレークポイント信号の発生を禁止する回路を含んで構成される
ことを特徴とする単一チップ集積回路装置が提供される。
【0008】
ブレークポイント信号は、CPUが通常に実行する次の命令の代わりに、一連の命令(いわゆる「トラップ命令」)をCPUに取出させて実行させることができる。或いは、ブレークポイント信号は、診断手順が行われている間にCPUが何らかの別の命令(STALL AT INTERRUPT POINT)を実行することを防止できる。
【0009】
このように、ブレークポイントユニットがチップ上に設けられ、このブレークポイントユニットは、、1つ以上のブレークポイントレジスタを有し、CPUからの命令ポインタを観察し、CPUがブレークポイントレジスタによって示された命令を実行しようとする場合に、CPUを停止するかまたはCPUに何か特定の作動をさせることができる。オン−チップ制御ロジックはCPU自体内に、または、CPUの近くに接続して設けてもよく、CPUがブレークポイントアドレスにより定義された命令を実行した時に、他の何らかの特別な作動を停止或いは行う機能を実行する。特別な作動としての1つの特定形態は、CPUがトラップを取ることである。他のインプリメンテーションでは、ストール、ホルト、ストップ、非マスカブル割込みまたは他の適宜な作動を実行できる。
【0010】
中断した後のCPUの通常作動の再開についての次の命令のためのブレークポイント信号の発生の禁止は、CPUがブレークポイントに必要な特別の作動を終了した後に毎回ブレークポイント作動をとり続ける無限ループを防止するのに重要である。
上記ブレークポイントユニットは、通信パスを介してオン−チップブレークポイントユニットに接続され、オン−チップCPUを必要とせずにブレークポイントレジスタにブレークポイントアドレスをロードさせるメッセージコンバータを含んで構成される集積回路のコンテキストに特に使用できる。メッセージコンバータはオン−チップバスに接続されてブレークポイントレジスタにブレークポイントアドレスをロードするメッセージを受信できる。また、メッセージコンバータはオフ−チップ通信パスに接続されてブレークポイントレジスタをロードするためにオフ−チップCPUからメッセージを受信することができる。
【0011】
上記形態において、アドレス通信パスは命令ポインタレジスタをオン−チップブレークポイントユニットに接続する専用並列バスである。これにより、ブレークポイントユニットを自立性にして、CPUの通常作動に影響を与えずに取り除いたり変更したりできる。
CPUがメモリにアクセスできるように、アドレス通信パスを前記バスにより設けることができ、オン−チップブレークポイントユニットは命令を取り出すためのバス上のメモリアクセスを監視するための監視回路を有する。
【0012】
オン−チップブレークポイントユニットは、命令ポインタレジスタ内のアクセスが有効であることを表示するためのアドレス有効信号を受信するように接続される。
オン−チップCPUが複数の異なる手順を実行するための命令を取出して実行できる状況において、ブレークポイント信号の発生の禁止は、これらの手順のうち他の手順ではなく、CPUの通常作動を中断させるいずれか1つの手順に関してのみ作動するように設定できる。このように、多条ブレークポインティングが可能である。
【0013】
ブレークポイントユニットはカウンタを有して、ブレークポイント信号が、ブレークポイントアドレスでの命令が所定回数実行された後にのみ発生するようにできる。
ブレークポイントユニットは、複数のブレークポイントアドレスのそれぞれを保持する前記複数のブレークポイントレジスタを有することができる。
【0014】
更に、1つ以上のブレークポイントユニットを単一チップ集積回路装置上に設けることができる。
本発明の他の態様によれば、CPUによって実行される命令アドレスが監視されるとともに、各アドレスがCPUの通常作動が診断目的のために中断されるブレークポイントアドレスとそれぞれ比較され、監視アドレスとブレークポイントアドレスとの間にマッチがある時にブレークポイント信号が出力され、CPUによるブレークポイント信号の受信によりCPUの通常作動が中断し、更に、中断した後のCPUの通常作動の再開に関する次の命令のためのブレークポイント信号の発生を禁止することを特徴とする、特に診断手順を実行するための、オン−チップCPUの通常作動を中断する方法が提供される。
【0015】
【発明の実施の形態】
本発明を更に理解し、どのように実施するかを添付の図面を参照して説明する。
図1は、テストアクセスポート(TAP)コントローラ4とチップ境界スキャンチェイン10とを有する集積回路2を概略的に示す。TAPコントローラ4は、ライン14上のテストクロック信号TCKと、ライン16上のテストモード選択信号TMSと、ライン18上のテストデータ入力信号TDIと、ライン22上のテストリセット入力信号TRST*と、をオフ−チップから受信する。TAPコントローラ4は、ライン20上のテストデータ出力信号TDOをオフ−チップに出力する。TAPコントローラ4はまた、ライン12上の装置識別子信号DEVICEIDを受信する。図1において、装置識別子信号DEVICEIDは、集積回路内でアースに接続された信号ライン12として示される。信号ライン12はマルチビットワイヤでよく、また、装置識別子信号DEVICEIDは集積回路上またはオフ−チップ上のいずれかから発生できる。信号ライン12がマルチビットワイヤの場合には、各ビットがチップ上の低レベルロジックまたは高レベルロジックのいずれかに接続される。TAPコントローラ4は、ライン28上のスキャンデータ入力信号SCANINと、ライン38上のテストクロック信号TESTCLKと、ライン24上のスキャンテストモードSCANMODEの選択を示す信号と、をライン26上の診断モードDIAGMODEの選択を示す信号と、をオン−チップ回路に出力する。チップ境界スキャンチェイン10は、ライン28上のスキャンデータ入力信号SCANINと、ライン24上のスキャンテストモード信号SCANMODEと、を入力として受信し、ライン34上のスキャンデータ出力信号SCANOUTをTAPコントローラ4に出力する。本発明では、ライン28上のスキャンデータ入力信号SCANINはまた、後述するように、診断のためにオン−チップソース/宛先ロジックに接続される。本発明では、ソース/宛先ロジックは、入力信号DIAGSCANOUTをライン36上でTAPコントローラ4に供給する。
【0016】
以下に詳細に説明する図5は、ソース/宛先ロジックを構成する構成要素を示す。ソース/宛先ロジックは、少なくともオン−チップバスシステムに接続されるプロセッサであり、オン−チップバスシステムはこれに接続されたオン−チップメモリを有する。オフ−チップメモリもまたこのようなバスシステムに直接接続できる。オン−チップソース/宛先ロジックはまた、DMAエンジン又はEMIインタフェースを備えた他の機能回路を持つ。
【0017】
TAPコントローラ4は、標準演算に必要であり且つ本発明で要求される回路ブロックを備えて図2に概略的に示される。図2を参照すると、TAPコントローラ4はその基本形式において、ステートマシン50と、IDレジスタ42と、命令レジスタ44と、命令デコーダ46と、バイパスラッチ48と、データマルチプレクサ52と、命令/データマルチプレクサ54と、ラッチ56と、インバータ60と、を含んで構成される。命令レジスタ44は、ライン18上のテストデータ入力信号TDIを受信し、バス62への並列命令とライン76上への直列出力とを発生し、また、ライン82上の命令制御入力信号を受信する。命令デコーダ46は、バス62上の並列命令とライン84上のデコーダ制御入力信号とを受信して、信号SCANMODE及び信号DIAGMODEをライン24及び26それぞれに、また、ライン70上に並列データマルチプレクサ選択信号を発生する。バイパスラッチ48は、ライン18上のテストデータ入力信号TDIを受信し、ライン72上に出力信号を発生する。IDレジスタ42は、ライン12上の並列の信号DEVICEIDを受信し、ライン68上に直列の装置識別子出力信号を発生する。データマルチプレクサ52は、ライン68上のIDレジスタ42の出力信号と、ライン72上のバイパスラッチ48の出力信号と、ライン34上の信号SCANOUTと、ライン36上の信号DIAGSCANOUTと、ライン70上のデータマルチプレクサ選択信号と、を受信する。データマルチプレクサ52は、ライン74上に出力を発生する。命令/データマルチプレクサ54は、ライン76上の直列出力と、ライン74上のデータマルチプレクサの出力と、ライン78上の命令/データマルチプレクサ選択信号と、を受信する。命令/データマルチプレクサ54は、ライン80上に出力を発生する。ラッチ56は、ライン80上の命令/データマルチプレクサ54の出力を受信し、ライン20上にテストデータ出力信号TDOを発生する。ステートマシン50は、ライン16上の信号TMSと、ライン22上の信号TRST*と、を受信する。ステートマシン50は、ライン78への命令/データマルチプレクサ選択信号と、ライン82への命令制御入力信号と、ライン84へのデコーダ制御入力信号と、を発生する。IDレジスタ42、命令レジスタ44、命令デコーダ46、バイパスラッチ48、ステートマシン50、及びデータコンバータ57は、それぞれライン14上のテストクロック信号TCKを受信する。ラッチ56は、ライン64上のインバータ60を介して反転されたテストクロック信号TCKを受信する。テストクロック信号TCKとテストデータ入力信号TDIは、ライン38の出力TESTCLK及びライン28の出力SCANINとしてそれぞれ直接接続される。
【0018】
集積回路2のテストを実行する際のTAPコントローラ4の作動は、IEEE1149.1−1990に詳細に説明されている。本質的に、有限長さのスキャンチェインは、チップ境界スキャンチェイン10によって形成されるチェインのように集積回路上で形成される。
TAPコントローラ4は、IEEE基準1149.1−1990によって定義される同期有限ステートマシンである。IEEE基準1149.1−1990は、集積回路に含むことのできるテストロジックを定義して、集積回路間の相互接続のテスト、集積回路自体のテスト、集積回路の通常作動中における回路動作の監視又は修正の標準的な方法を提供する。
【0019】
集積回路2の通常作動中、TAPコントローラ4は、リセット状態にあり、その入力と出力は全て非作動である。IEEE基準1149.1−1990によるテストアクセスポートを使用したテストを実行する場合、TAPコントローラは前記基準の定義に従って作動する。このようなテストモードでは、TAPコントローラ4は少なくとも1つの作動のテストモードを選択できる。1つの可能なテストモードはスキャンテストモードであり、これはライン24上の信号SCANMODEを設定することにより選択される。スキャンテストモードでは、集積回路2上のスキャンチェインがテストのために選択される。本実施形態において、チップ境界スキャンチェイン10が信号SCANMODEによって選択される。このようなスキャンテストは、単にスキャンチェインの一端にデータを入力し、同一データがスキャンチェインの他端で出力されることを確認するためにチェックをすることを含む。或いは、オン−チップの機能ロジックに入力されるデータをスキャンし、1以上のクロックサイクルでチップを機能的にクロックして、機能ロジックの出力をスキャンするような、より複雑なスキャン操作を実行できる。オン−チップの任意の接続点または回路をテスト用に接続してスキャンチェインを形成できる。チップ境界スキャンチェイン10は、テストモードで制御されて集積回路2の全ての入力/出力ポートを接続する一連のフリップフロップである。このようなスキャンテスティングの完全な理解はIEEE基準1149.1−1990を参照することから求められる。スキャンテスティングをどのように実行するかの特定の例として、ヨーロッパ特許出願公開第0698890号、第0702239号、第0702240号、第0702241号、第0702242号、第0702243号、第0709688号が挙げられる。
【0020】
IEEE基準1149.1−1990のテストアクセスポートを使用する公知のテストモードの特徴は、スキャンチェインが有限の長さか又は閉ループであること、また、テストデータ出力信号TDOがテストデータ入力信号TDIに依存するとともに、テストデータ入力信号との時間関係を持つことである。
本実施形態では、作動の診断モードは、IEEE基準1149.1−1990と一致するオン−チップのソース/宛先ロジックの診断手順を実行するために提供される。このような診断テストモードでは、テストデータ出力信号TDOはテストデータ入力信号TDIに依存しないので、このテストデータ入力信号との時間関係を持たない。テストデータ入力信号TDIとテストデータ出力信号TDOとの間のチェインは、無限の長さまたは開ループであると考えられる。診断モードでは、TAPコントローラ4は、全ての正常な機能を提供しながら、付加的に全二重の、フロー制御された、束縛されない直列データを、これがデータの形式であるとは気づかずに伝える転送エージェントとして作動する。逆に、TAPコントローラ4は、通常はどんなフロー制御もせずに選択されたテストチェインを通過する単一のデータストリームを処理する。
【0021】
テストモードにおけるTAPコントローラ4の作動の大要を、図1及び図2を参照して説明する。図2においては、信号SCANINはテストデータ入力信号TDIに直接接続しているが、一定の状況では、信号SCANINは信号TDIの修正バージョンであってもよい。同様に、テストクロック信号TESTCLKはテストクロック信号TCKに直接接続しているが、一定の状況では、信号TCKの修正バージョンであることが要求される。
【0022】
作動のテストモードでは、テストデータ入力信号TDIとテストモード選択信号TMSは、テストクロック信号TCKの制御下でTAPコントローラ4に直列形式で供給される。ステートマシン50は、テストクロック信号TCKの各作動エッジでテストモード選択信号TMSの値に作用して、IEEE基準1149.1−1990によって定義されるようにその状態を反復させる。テストリセット信号TRST*は、IEEE基準1149.1−1990に応じた低ロジック状態にある時、TAPコントローラ4の非同期初期化を提供する。
【0023】
命令レジスタ44は、テストクロック信号TCKによってクロックされて、ステートマシン50からのライン82上の命令制御入力信号の制御下でテストデータ入力信号TDIから直列形式で命令をロードする。命令が、命令レジスタ44内に直列にロードされると、この命令は、ステートマシン50からのライン84上のデコーダ制御入力信号の制御下で、命令バス62を経由して命令デコーダ46に並列に転送される。ここで記憶された命令に従って、命令デコーダ46は、実行されるのがスキャンテストか或いは診断テストかに応じて信号SCANMODEまたは信号DIAGMODEのいずれか一方を設定する。命令レジスタ44及び命令デコーダ46のローディングは、IEEE基準1149.1−1990に従ってステートマシン50により制御される。命令デコーダ46によってデコードされた命令に応じて、また、以下に更に説明するように、命令デコーダ46のライン70上の並列出力は、データマルチプレクサ52を制御して、その入力の1つを出力ライン74に接続する。同様に、ステートマシン50のライン78上の出力は、命令/データマルチプレクサ52を制御して、その入力の1つをライン80上の出力に接続する。
【0024】
IDレジスタ42は、ライン12上の並列の信号DEVICEIDを受信する。IDレジスタ42は、チップ識別子を記憶し、そのチップ識別子は、IDレジスタ42からライン68を介してテストデータ出力信号TDOにスキャンされる。チップ識別子は集積回路2を識別する。
一つの作動モードにおいて、命令デコーダ46によってデコードされた命令は、マルチプレクサ52が制御されてライン68上のその入力をライン74上のその出力に接続し、また、命令/データマルチプレクサ54が制御されてライン74上のその入力をライン80上のその出力に接続する場合に、装置の一致を単に出力するものでよい。そして、装置の一致は信号TDOとして直列に出力される。
【0025】
作動の別のモードでは、ライン76上の直列出力が命令/データマルチプレクサ54によりライン80に接続される場合に、テストデータ出力信号TDOに現行命令を出力することが要求される。
テスト作動の一つのモードでは、特定の集積回路2のTAPコントローラ4がテストデータ入力信号TDIをテストデータ出力信号TDOに接続することだけが要求される。この作動モードでは、データマルチプレクサ52が制御されてライン72上のバイパスラッチ48の出力をライン74上の出力に接続し、命令/データマルチプレクサ54が制御されてライン74をライン80上の出力に接続する。このように、テストデータ入力信号TDIは、ラッチ56を介してテストデータ出力信号TDOに接続される。
【0026】
ラッチ56は単に、テストデータ出力信号TDOの時間制御をして、この信号がテストクロック信号TCKの立ち下がりエッジに同期できるようにするためにだけ設けられたフリップフロップである。
実行されるテストモードがスキャンテストモードの場合、命令デコーダ46が信号SCANMODEを設定する。データマルチプレクサ52が命令デコーダ46により制御されて、信号SCANOUTを出力ライン74に接続する。命令/データマルチプレクサ54もまた制御されてライン74をライン80に接続して、信号SCANOUTをテストデータ出力信号TDOとして出力する。このようなスキャンテストモード中では、テストデータは、テストデータ入力信号TDIと直接接続する信号SCANIN上の選択されたスキャンチェイン内にスキャンされる。スキャンテスティング、特に境界スキャンテスティングは、IEEE基準1149.1−1990に十分に説明されている。実行されるテストに応じた付加制御信号が選択スキャンチェインに供給されて必要なテスト作動を実行する必要がある。
【0027】
本実施形態では、命令デコーダ46がライン26上の信号DIAGMODEを設定する場合に診断モードに入る。更に、データマルチプレクサ52が制御されてライン36上の信号DIAGSCANOUTをライン74上の出力に接続する。これは、命令/データマルチプレクサ54を介してライン80に、またラッチ56を介してテストデータ出力信号TDOに順次接続される。
【0028】
診断モードにおいて、テストデータ入力信号TDIとテストデータ出力信号TDOとの間の直列データフローは、スキャンテストモードに対抗するものとしての無限の長さのシフトレジスタを通ると考えられる。このモードにおいて直列データフローは有限の長さのシフトレジスタ(シフトレジスタチェイン)を通る。診断モードでは、テストデータ入力信号TDIとしてテストアクセスポート内にシフトされた一連のビットパターンは、テストデータ出力信号としてテストアクセスポートの外にシフトされた一連のビットパターンに反映されない。診断データの通信は、ホストからターゲットへ及びターゲットからホストへ(読み出し及び書き込み)のメモリアクセス要求、CPUレジスタの状態情報、メモリアクセス要求に応答してホストメモリまたはターゲットメモリから読み出されたデータ、CPUレジスタ内にロードするための状態データ、及びターゲットCPUによってアクセスされるメモリアドレスに関する情報を含む。このように、診断モードは、データの非割り込みモニタリングまたはデータの割り込みローディングを含む。
【0029】
診断モードにおいて、テストアクセスポート内にシフトされた直列データは、任意の所望の手段、例えば、データチャンクを表す開始ビット及び停止ビットでエンコードできる単一方向直列データストリームである。同様に、テストアクセスポートを介してシフトアウトされたデータは、任意の所望の手段、例えば、データチャンクを表す開始ビット及び停止ビットでエンコードできる1方向直列データストリームである。通常、シフトインされたデータ及びシフトアウトされたデータは、同様の方法でエンコードされる。1方向入力及び出力データストリームは、全二重の2方向直列通信を可能にするために同時に使用される。一連の直列データビットは情報バイトを構成できる。
【0030】
本実施形態において、通常テストモードに加えて作動の診断モードが提供されると、集積回路2には、図3に示すように、TAPコントローラ4とオン−チップソース/宛先ロジックとの間をインタフェースするデータアダプタ90が備えられる。データアダプタ90は、TAPコントローラ4からの入力として、ライン28上のスキャンデータ入力信号SCANINと、ライン38上のテストクロック信号TESTCLKと、ライン26上の診断モードDIAGMODEの選択を示す信号と、を受信する。データアダプタ90は、TAPコントローラ4にライン36上の信号DIAGSCANOUTを出力する。データアダプタ90は、ライン92上の送信データバスTXDATAのオン−チップソース/宛先ロジックからデータを受信し、ライン94上の受信データバスRXDATAのオン−チップソース/宛先ロジックにデータを出力する。データアダプタ90は、ライン96上の送信有効信号TXVALIDを入力し、ライン98上の送信肯定応答信号TXACKを出力する。両信号は、送信データバスTXDATAに関連する制御信号である。データアダプタ90は、ライン100上の受信有効信号RXVALIDを出力し、ライン102上の受信肯定応答信号RXACKを入力する。両信号は、受信データバスRXDATAに関連する制御信号である。
【0031】
データアダプタ90は、受信シフトレジスタ114と、受信バッファ116と、受信制御ロジック110と、受信フロー制御状態フリップフロップ120と、送信フロー制御状態フリップフロップ124と、送信シフトレジスタ118と、送信制御ロジック112と、を含んで構成される。受信シフトレジスタ114は、ライン28上の信号SCANINと受信制御ロジック110からのライン126上の制御信号とを受信し、バス130上に並列データを出力して受信バッファ116への入力を形成する。受信バッファ116は、更に受信制御ロジック110からのライン128上の制御信号を受信し、ライン94上に受信データバス信号RXDATAを発生する。受信制御ロジック110は、更にライン100上に信号RXVALIDを発生し、ライン102上の信号RXACKを受信し、ライン26上の信号DIAGMODEを受信し、ライン134及び132上に信号STARTDATA及びACKRXをそれぞれ発生する。受信フロー制御状態フリップフロップ120は、信号STARTDATAとライン136上の信号TXSENDACKとを受信し、送信制御ロジック112への信号RXSENDACKをライン142上に出力する。送信フロー制御状態フリップフロップ124は、信号ACKRXとライン138上の信号TXSENDBYTEとを受信し、送信制御ロジック112への信号TXWAITACKをライン140上に出力する。送信制御ロジック112は、更にライン26上の信号DIAGMODEとライン96上の信号TXVALIDとを受信し、信号TXACKをライン98上に、送信シフトレジスタ118への制御信号をライン144上に、並列信号SERCONTを送信シフトレジスタ118に出力する。送信シフトレジスタ118は、更にライン92上の並列データバスTXDATAを受信し、ライン36上に信号DIAGSCANOUTを出力する。
【0032】
図にはその接続は示されてはいないが、データアダプタ90には任意にオン−チップシステムクロックからの入力が供給される。データアダプタとオン−チップソース/宛先ロジックとの間のデータ及び制御信号が、オン−チップソース/宛先ロジックのクロックと同期する必要がある場合には、システムクロックは同期実行のために使用できる。データアダプタ90は、信号TESTCLK(信号TCKから引き出された)によってクロックされたTAPコントローラからソース/宛先ロジックの内部機能のクロック環境まで、また、ソース/宛先ロジックのクロック環境から信号TESTCLKによってクロックされたTAPコントローラまでの直列データの同期を実行する。図には示されていないが、TAPコントローラ4は任意にスキャンイネーブル信号をデータアダプタ90に供給してもよい。このようなスキャンイネーブル信号は、TAPコントローラがテストデータ出力信号TDOへのデータ出力用スキャンパスを選択したことを示す。
【0033】
データアダプタ90は、TAPコントローラ4を介したオフ−チップからの1方向直列データをオン−チップソース/宛先ロジックで使用するのにより適したフォーマットに変換する。逆に、データアダプタ90は、オン−チップソース/宛先ロジックにより供給されるデータフォーマットを1方向直列データに変換する。好ましい実施形態においては、並列8ビット又はバイトの形式でデータをオン−チップソース/宛先ロジックに供給するのが望ましい。しかしながら、特に受信データバスRXDATA及び送信データバスTXBUSは、1バイト幅よりも1ビット幅のみでもよい。また、受信及び送信データバスRXBUSとTXBUSは、複数バイト幅のバスであってもよい。
【0034】
データアダプタ90は、受信及び送信の両データの「フロー制御」の機能を実行する。直列データは、受信端部がこのデータを受信できる容量を有してデータ損失または低下を防止する時は、TAPコントローラ4を(どちらの方向でも)単に通過するだけである。受信端部がより多くのデータを受信する用意があることの通信は、そのような情報を反対方向に送信することにより実行される。これはフロー制御プロトコルを構成する。本実施形態におけるデータアダプタ90は、オン−チップソース/宛先ロジックとの通信のために1方向直列データの並列フォーマットへの変換を提供する。このように、フロー制御プロトコルはまた、データアダプタ90とオン−チップソース/宛先ロジックとの間で必要である。
【0035】
このように、このフロー制御は2つの境界、TAPコントローラ4とデータアダプタ90との間の境界、及びデータアダプタ90とこのデータアダプタ90がインタフェースするオン−チップソース/宛先ロジックとの間の境界、を越えて実行される。
TAPコントローラ4とデータアダプタ90との間のフロー制御を提供するには、テストデータ入力信号TDIライン及びテストデータ出力信号ライン上の1方向データが、図4(a) に示されるような開始及び停止ビットでエンコードされる。ビットフロー制御プロトコルは、2つの開始ビットS1及びS2、1つの停止ビットE1で信号を送るゼロ復帰方式(RTZ)である。開始ビットと停止ビットとの間にはデータのバイトが含まれる。このフォーマットの直列データは、TAPコントローラ4のテストデータ入力信号TDIからライン28上の信号SCANINまで通過してデータアダプタ90に入力される。データアダプタ90の受信制御ロジック110は、直列データ信号SCANINを受信する。受信制御信号が2つの連続した直列ビットを開始ビットS1及びS2として認識すると、受信シフトレジスタ114がライン126上で制御されて、データバイトを内部で形成する次の連続した8ビットを直列にロードする。
【0036】
2つの連続した開始ビットS1及びS2に応答して、受信制御ロジック110はまた、受信フロー制御状態フリップフロップ120を設定するライン134上の信号STARTDATAを設定する。設定されると、受信フロー制御状態フリップフロップ120は、順次、ライン142上の信号RXSENDACKを設定し、この信号により、送信制御ロジック112は、図4(b) に示される形式でテストデータ出力信号TDOに肯定応答信号を送る。この肯定応答信号は、開始肯定応答ビットACKと停止ビットE1のみを含んで構成される。これらのビットは、ライン144上の信号の制御下でライン150上の信号SERCONTとして送信シフトレジスタ118に並列に直接ロードされ、信号DIAGSCANOUTとして、図4(b) の直列形式で送信シフトレジスタ118から出力される。肯定応答信号が送られると、送信制御ロジック112は、ライン136上に信号TXSENDACKを設定して、受信フロー制御状態フリップフロップをリセットし、信号RXSENDACKをリセットする。
【0037】
本実施形態で使用されるフロー制御プロトコルによれば、信号SERCONTは、開始ビットS1とS2及び停止ビットE1とを送信シフトレジスタ118内に直接ロードするのを許可する3ビット信号である。TAPコントローラ4を介して出力され、オン−チップソース/宛先ロジックによって示されるデータバイトが送信データバスTXDATA上に現れると、このデータバイトは送信制御ロジック112の制御下で送信シフトレジスタ118内に並列にロードされ、送信制御ロジック112は、図4(a) に示されるフォーマットの信号を直列にシフトする前に、信号SERCONTを形成する開始ビットS1、S2及び停止ビットE1を送信シフトレジスタ内の適宜なビット位置に直接ロードする。肯定応答信号を送ると、送信制御ロジック112は単一の開始ビットと停止ビットを送信シフトレジスタ118内に直接ロードしてから、それらを全て直列にシフトする。
【0038】
受信制御ロジック110が信号SCANINの停止ビットE1を受信すると、データバイトは受信シフトレジスタ114内にロードされ、受信制御ロジック110の制御下でデータバイトはバス130上を受信シフトレジスタ114から受信バッファ116まで転送される。データバイトが受信バッファ116内にロードされると、このデータバイトは、ライン100上の信号RXVALIDも設定する受信制御ロジック110の制御下でバスRXDATA上に出力される。信号RXVALIDに応答して、オン−チップソース/宛先ロジックはRXBUS上のデータバイトを受け入れ、この受信をライン102上の信号RXACKを設定することによって示す。信号RXACKに応答して、受信制御ロジック110は、信号RXVALIDをリセットし、受信シフトレジスタ114内に別のデータバイトがある場合は、信号RAVALIDを再度設定する前にこれを受信バッファ116に転送する。
【0039】
受信バッファ116が好ましい実施形態において提供される。これは、データの受信をオーバーラップする公知のトークンを2つの開始ビットが受信されるとすぐに送信させ、また、連続したバイトを、各バイトの間にどんな隙間もなしに転送させることによって、効果的なデータ転送速度を維持する。データバッファリングもまた送信側に設けることができる。
【0040】
オン−チップソース/宛先ロジックは、データバイトをTXDATAバス92上のデータアダプタ90に並列に転送する。オン−チップソース/宛先ロジックが、転送されるデータバイトを有している時は、ライン96上の信号TXVALIDが設定される。信号TXVALIDが設定されるのに応答して、送信制御ロジック112が、ライン144を介して送信シフトレジスタ118を制御してTXDATAバス上のデータバイトを並列にロードする。更に、ライン150を使用して、送信制御ロジック112は、適宜な開始ビットS1とS2及び停止ビットE1を送信シフトレジスタ118内にロードする。そして、再びライン144を介した送信制御ロジック112の制御下で、2つの開始ビットと1つの停止ビットを含むデータバイトが信号DIAGSCANOUTとして送信シフトレジスタ118から外に直列にシフトされ、これはTAPコントローラ4を介して信号TDOに接続される。バスTXDATA上のデータバイトがシフトレジスタ内にロードされると、送信制御ロジック112は、ライン98上に信号TXACKを設定してオン−チップソース/宛先ロジックへのデータバイトの受信の肯定応答をする。そして、オン−チップソース/宛先ロジックは別のデータバイトを送信できる。データバッファリングが、必要に応じて送信シフトレジスタ118と関連して提供される。
【0041】
送信シフトレジスタ118が送信制御ロジック112に制御されて、図4(a) に示される形式の直列データを出力すると、送信制御ロジック112はまた、ライン138上に信号TXSENDBYTEを設定し、この信号は送信フロー制御状態フリップフロップ124を設定する。この信号に応答して、送信フロー制御状態フリップフロップ124はライン140上に信号TXWAITACKを設定する。信号TXWAITACKが設定されると、データバイトが受信されたことをオン−チップソース/宛先ロジックが肯定応答するのを送信制御ロジック112は待つ。オン−チップソース/宛先ロジックは送信データバイトをうまく受信すると、図4(b) に示されるタイプの肯定応答信号をテストデータ入力信号TDIに送る。ライン28上の信号SCANINのような肯定応答信号を受信すると、受信制御ロジック110は、ライン132上に信号ACKRXを設定して、送信フロー制御状態フリップフロップ124をリセットさせ、結果として信号TXWAITACKをリセットさせる。そして、送信制御ロジック112は、オン−チップソース/宛先ロジックからの次の並列データバイトの受信及び送信のための準備をする。
【0042】
図5は、ホストメモリとターゲットメモリとの間の接続を確立するのにどのようにデータアダプタ90を使用するかを系統図形式で示す。集積回路2は、相互の間をオフ−チップで通信し、また、上記信号を使用してオン−チップで回路と通信する、TAPコントローラ4とデータアダプタ90とを含んで構成される。図5において、上述の信号に相当する信号には同様の参照符号を使用する。図5から明らかなように、集積回路2はまた、メモリバスアダプタ160と、ターゲットCPU162と、オン−チップメモリ164と、を含んで構成される。集積回路2には、ターゲットCPU162及びオン−チップメモリ164とインタフェースするメモリバス166が備えられる。メモリバス166はまた、オフ−チップメモリ174に接続する。オフ−チップのテストアクセスポート信号TCK、TMS、TDI、TDO及びTRST*が、TAPコントローライニシャライザ176に接続しており、このTAPコントローライニシャライザ176は、それ自体別のデータアダプタ180からライン178上の直列データ入力信号SERINを受信し、データアダプタ180へライン179上の直列データ出力信号SEROUTを出力する。この別のデータアダプタ180は、ライン190、188及び186上の信号EXTRXDATA、EXTRXVALID及びEXTTXACKを、別のメモリバスアダプタ194に出力し、ライン184、182及び192上の信号EXTTXDATA、EXTTXVALID及びEXTRXACKをメモリバスアダプタ194から受信する。メモリバスアダプタ194は外部メモリバス198に接続される。ホストCPU200は、外部メモリバス198に接続され、別のオフ−チップメモリ202も外部メモリバス198に接続される。
【0043】
TAPコントローライニシャライザ176は、テストモードか診断モードのいずれかの作動用のTAPコントローラ4を構成する。メモリバスアダプタ160,194は、バスRXDATA上の並列データをオン−チップソース/宛先ロジックと通信するのにより適宜なメッセージフォーマットに調整する。このため、メモリバスアダプタはメッセージコンバータであって、本出願人による特許出願に開示されるタイプのメッセージコンバータである。メモリバスアダプタはまた、オン−チップソース/宛先ソースのメッセージフォーマットをバスTXDATAの送信用の並列データバイトに変換する。
【0044】
図5の構成は種々の診断手順に使用できる。オン−チップ及びオフ−チップ直列リンクが集積回路2とホストCPU200との間の種々の異なるタイプの診断データの通信を可能にする。
ホストCPU200は、オン−チップバスシステム166を使用してオン−チップメモリ164またはオフ−チップメモリ174にアクセスできるが、これにはターゲットCPU162を必要としない。このためには、ホストCPUによりなされたメモリアクセス要求が、オフ−チップメモリバスアダプタ194と、データアダプタ180と、TAPコントローライニシャライザ176と、オン−チップTAPコントローラ4と、データアダプタ90と、メモリバスアダプタ160と、を含んで構成されるインタフェース回路を介して、ここに述べられる種々の変換を行って送信できる。同様に、オン−チップメモリ164またはオフ−チップメモリ174から読み出されたデータは、オン−チップバスシステム166とインタフェース回路とを介してホストCPUに戻ることができる。逆に、ターゲットCPUが、ホストCPUに関連したオフ−チップメモリ202とアクセスできる。ホストCPU200に関連したオフ−チップメモリ202から読み出されたデータも、同様にインタフェース回路を介して戻ることができる。
【0045】
また、ターゲットCPUが診断目的のために監視される。例えば、それ自体のメモリへのそのアクセスがオン−チップ回路によって監視され、アクセスされたメモリアドレスに関する情報がインタフェース回路を使用してホストCPUに送信される。更に、ターゲットCPUは、その状態を示す構成レジスタを含むか又はアクセスできる。これらのレジスタの内容に関する情報はオフ−チップでインタフェース回路を使用してホストCPUに送信される。逆に、特定状態情報がこれらのレジスタ内にロードされてホストCPUの命令下でターゲットCPUの状況に影響を与える。
【0046】
このように、ここで述べられるインタフェース回路は、ホストからターゲットへのまたターゲットからホストへの(読み出し及び書き込み)メモリアクセス要求、CPUレジスタの状態情報、メモリアクセス要求に応答したホストメモリまたはターゲットメモリからの読み出しデータ、CPUレジスタ内へロードするための状況データ及びターゲットCPUによりアクセスされるメモリアドレスに関する情報を含む診断データの通信を可能にする。
【0047】
このように、インタフェース回路は、以下の診断上の機能を回路内に提供できる。
リアルタイムの診断手順の実行機能、即ち、ターゲットCPUがリアルタイムで作動すると同時に、その作動に割り込まずに診断手順を行う。特に、メモリバスの監視とターゲットメモリへのアクセスが、ターゲットCPUを必要とせずにホストCPUにより行える。
【0048】
ホストCPUからターゲットメモリ及び構成レジスタへのアクセス。
ターゲットCPUからホストメモリへのアクセス。
ホストプロセッサからCPUのブーティング操作を実行する機能を含む、ターゲットCPU及びサブシステムの制御。
本実施形態では、テストデータ入力信号TDIとテストデータ出力信号TDO上の作動の診断モードにおけるテストアクセスポート内及び外へシフトされる1方向直列データストリームは、メッセージ形式の情報である。このようなメッセージは、ホストCPUまたはターゲットCPUによって開始される。デバッギング環境において、ホストCPUは、オン−チップソース/宛先ロジックの割り込み又は非割り込み診断を実行できる。或いは、診断モードにおいて、このようなメッセージは、ターゲットCPUによって開始できる。
【0049】
図5のメモリバスアダプタ160は、チップに入力されるメッセージを、オン−チップソース/宛先ロジックによって使用するための制御情報、アドレス及びデータに変換する。本実施形態では、各メッセージは複数のバイトで構成されるパケットである。前述のように、データアダプタ90は入力する直列データを並列バイトに変換し、出力するバイトを直列データに変換する。メモリバスアダプタ160は、入力するメッセージをデコードして、オン−チップソース/宛先ロジックに制御情報、アドレス情報及びデータ情報を供給する。同様に、メモリバスアダプタ160は、オン−チップソース/宛先ロジックからの制御情報、アドレス情報及びデータ情報を、データアダプタに並列で送信されたメッセージにエンコードする。
【0050】
本実施形態において、開始される2つのタイプのメッセージと、応答として発生する2つのタイプのメッセージがある。開始される2つのタイプのメッセージは、特定メモリ位置に特定データを書き込むためのメモリ書き込み要求「poke」と、特定メモリ位置からデータを読み出すためのメモリ読み出し要求「peek」とである。レスポンスとして発生する2つのタイプのメッセージは、メモリ読み出し要求に応答して読み出しデータを戻す「peeked」メッセージと、後述の「triggered」メッセージとである。各メッセージの第1のバイトは、ヘッダバイトであり、4つのメッセージの各々の構成は図6に示される。ヘッダバイトは、パケットの性質を識別するパケット識別子を構成する。
【0051】
第1の2ビットのヘッダバイトは、メッセージのタイプ、即ち、メッセージが「poke」、「peek」、「peeked」又は「triggered」メッセージかどうか、を識別するタイプ識別子である。以下の6ビットのヘッダバイトは、ヘッダバイトに続き前記メッセージに関連するワード数を識別して、パケットの長さを識別する長さ識別子として機能する。或いは、以下に詳細に説明するように、これらの6ビットは理由識別子として機能できる。図7は本実施形態による4つのタイプのメッセージの各々の構成を示す。図7(a) は「poke」ヘッダバイト00+WORDCOUNTを含んで構成される「poke」メッセージを示し、アドレスワードが続き、更に少なくとも1つのデータワードが続く。図7(b) は「peek」ヘッダバイト01+WORDCOUNTを含んで構成される「peek」メッセージであり、アドレスワードが続く。図7(C) は「peeked」ヘッダバイト10+WORDCOUNTを含んで構成される「peeked」メッセージであり、少なくとも1つのデータワードが続く。図7(d) は「triggered」ヘッダバイト11+REASONのみを含む「triggered」メッセージである。4つのタイプのメッセージの各々の操作は以下に詳細に説明する。
【0052】
上記のように、メモリバスアダプタ160は、メッセージコンバータとして機能し、以下に説明される。図8は、本実施形態によるメッセージコンバータ160のブロック図である。既に詳細に説明したように、メッセージコンバータ160は、データアダプタ90からライン94上の受信データバスRXDATAの情報バイトを受信し、ライン92上の送信データバスTXDATAの情報バイトをデータアダプタ90に送信する。更に、上述のように、メッセージコンバータ160は、データアダプタからのライン100及び98上の信号RXVALID及びTXACKのそれぞれを受信し、ライン102及び96上に信号RXACK及びTXVALIDのそれぞれをデータアダプタに発生する。また、メッセージコンバータ160は、3つのメモリバスポート、即ち、メモリスレーブバス220、メモリマスタバス222及びメモリモニタバス226を介してオン−チップソース/宛先ロジックとインタフェースする。メッセージコンバータ160はさらに、診断バス234を介してオン−チップソース/宛先ロジックとインタフェースする。更に、メッセージコンバータ160は、ライン236上のシステム信号SYSTEMを受信する。
【0053】
メモリスレーブバス220、メモリマスタバス222、メモリモニタバス226及び診断バス234は、それぞれ1方向バスとして図8に示される。しかしながら、各バスは、図8の矢印で示されるのとは反対の方向の信号を含む。図8において使用される規則は、バスの矢印方向が要求がなされる方向を反映することである。図9は、特に各バスに含まれる信号を示す。
【0054】
図9を参照すると、各バスは、複数のADDRESS信号350と、複数のWRITE_DATA信号352と、複数のREAD_DATA信号354と、1つのREQUEST信号356と、1つのGRANT信号358と、1つのVALID信号360と、を含む。各バスは、図示されない関連する他の制御信号、即ち、読み出し書き込み制御信号を有する。図9から明らかなように、ADDRESS信号350とWRITE_DATA信号352とREQUEST信号356とは、全て1方向に伝達され、READ_DATA信号354とGRANT信号358とVALID信号360とは、反対方向に伝達される。しかしながら、メモリモニタバス226において、READ_DATA信号354とGRANT信号358もまた、ADDRESS信号350、WRITE_DATA信号352、REQUEST信号356と同じ方向に伝達できることは言うまでもない。VALID信号360は、メモリモニタバス226には接続されない。
【0055】
メモリマスタバス222は、オフ−チップホストCPUによって駆動されてメモリアクセス要求をターゲットCPUメモリ領域につくり、また、診断機能によっても駆動できる。メモリスレーブバス220は、ターゲットCPUによって駆動されてオフ−チップメモリまたは診断機能にメモリアクセス要求をつくる。メモリモニタバス226は、メモリスレーブバス220と同じオン−チップ信号に接続され、診断機能により使用されてどのターゲットCPUがスレーブバスを使用するかを確認(非割り込み)する固定通路バスである。診断バス234は、メモリバスというよりはレジスタアドレスバスであり、診断機能により発生する「triggered」事象を伝達すると同時に、オン−チップ診断機能からの読み出し及びオン−チップ診断機能への書き込みを実行できる。診断バスはまた、診断機能からのメモリアクセス(メモリマスタバスを介したローカルオン−チップ/オフ−チップメモリへのまたはデータアダプタを介したリモートホストメモリへの)を開始するのに使用される。
【0056】
状態信号が、ターゲットCPUから診断機能を介してメッセージコンバータに供給される。これらの信号は、命令ポインタが有効である時を示す制御信号を備えた命令ポインタ等のターゲットCPU進行情報を含む。ホストCPUは、命令ポインタを監視してターゲットCPUが何をしているかを判定する。状態信号はまた、CPUの作動状態に関する付加的な情報を提供する多面的な個別の制御信号を含む他のターゲットCPU状態信号を含む。状態は、診断バスの「register」読み出しによりアクセスされる。命令ポインタもまた異なるレジスタアドレスからではあるが、「register」読み出しによりアクセスできる。
【0057】
オン−チップソース/宛先ロジックのステータスに関連する他の情報は、オン−チップレジスタに関連する情報等のステータス信号として含まれるが、このような情報は、一般的には診断目的のためのオン−チップ機能のいくつかの抽出を含むレジスタから引き出されるだけである。機能信号は任意の非割り込みオン−チップ診断機能、例えば、診断情報及び制御の抽出を容易にする任意のレジスタ、に接続できる。
【0058】
メモリマスタバスは、オン−チップのアドレスバスと、書き込みバスと、読み出しバスと、関連する制御信号とに接続される。メモリマスタバスは、オン−チップメモリ164、オフ−チップメモリ174及び構成レジスタ等のメモリバスを介してアクセス可能な任意の他のリソースを含むターゲットメモリスペース内の範囲に、ホストCPU及び診断機能がアクセスできるように使用される。
【0059】
個別のバスポートにオン−チップソース/宛先ロジックとの種々の接続点を設けるよりも、それらの間を識別する適宜な制御信号を使用して、いくつかのバスを組合せることができる。例えば、メモリバス書き込みデータと読み出しデータとは、共通のメモリデータバスに組合される。メモリアドレスはメモリデータに組合される。メモリスレーブバスはメモリマスタバスに組合される。このような選択肢は、実行、領域及び他の要素間の実行トレードオフを表す。
【0060】
ライン236上のシステム信号は、システムサービスに接続点を提供する。このようなシステムサービスは、例えば、クロッキング、電源、リセット、テストである。
メッセージコンバータ160は、データアダプタによって直列ビットフォーマットから直列バイトフォーマットに変換された連続した情報バイトを受信し、ヘッダバイトを読み出してその内部に伝えられるメッセージを決定する。このようにメッセージコンバータ160は、入力するメッセージを解釈して必要な動作を実行する。この必要な動作には、ホストに戻される情報を選択すること、又は、メッセージコンバータに接続されるバスのうちの適宜な1つを介してメモリアクセスを開始してデータを読み出すか書き込むことが含まれる。メッセージコンバータ160はまた、メッセージプロトコルに従ってオン−チップバスから受信した並列データをオフ−チップ送信用のメッセージに編集する。これには、ヘッダバイトを並列データとアドレスバイトとに配分して、入力するデータ、アドレス及び制御信号に応じてメッセージの性質を定義することが含まれる。図8のメッセージコンバータ160の作動と図6及び7のメッセージプロトコルとを図10を参照して詳細に説明する。
【0061】
図10は、本実施形態によるメッセージコンバータ160を示す。メッセージコンバータ160は、ヘッダレジスタ240と、アドレスレジスタ242と、データレジスタ244と、減分制御246と、増分制御248と、シフト制御250と、ステートマシン252と、バス選択及び指定ロジック254と、を含んで構成される。メッセージコンバータ160には、全ての制御信号を伝達するための内部制御バス258と、内部情報バス256と、が備えられる。内部制御バス258は、ステートマシン252に接続し、ステートマシン252への及びステートマシン252からのフロー制御信号RXVALID、RXACK、TXVALID及びTXACKを伝達する。内部制御バス258は更に、ライン260上の減分制御信号を減分制御246に、ライン262上の増分制御信号を増分制御248に、ライン264上のシフト制御信号をシフト制御250に、ライン266上のヘッダ制御信号をヘッダレジスタ240に、ライン268上のアドレス制御信号をアドレスレジスタ242に、ライン270上のデータ制御信号をデータレジスタ244に、また、ライン272上の選択及び指定制御信号をバス選択及び指定ロジック254に伝達する。ヘッダレジスタ240は、減分制御246からライン241上の制御信号を受信し、アドレスレジスタ242は、増分制御248からライン243上の制御信号を受信し、また、データレジスタ244は、シフト制御250からライン245上の制御信号を受信する。情報バス256は、受信データバイトRXDATAをヘッダレジスタ240、アドレスレジスタ242、データレジスタ244及びバス選択及び指定ロジック254に伝達する。また、情報バス256は、バス選択及び指定ロジック254、データレジスタ244、アドレスレジスタ242及びヘッダレジスタ240からの出力を送信データ信号TXDATAに伝達する。バス選択及び指定ロジック254は、メモリスレーブバス220、メモリマスタバス222、メモリモニタバス226及び診断バス234の1つへの或いはこれらの1つからの情報バス256上の情報を指定し、その情報は、本実施形態ではバイト幅のものである。
【0062】
図10の実施形態において、システム信号236は、ヘッダレジスタ240と、アドレスレジスタ242と、データレジスタ244と、ステートマシン252とをクロックするのに使用されるライン280上のクロック信号を提供するだけである。メッセージコンバータ160の作動を、予測される種々のメッセージタイプについて以下に説明する。
【0063】
ホストCPUが「poke」を開始すると、図7(a) に示される形式の直列メッセージが、集積回路2 のテストアクセスポートで受信され、続いて、受信データバスRXDATA上でデータアダプタ90によって並列の情報バイトの形式で出力される。受信データバスRXDATA上の各並列情報バイトを出力すると、データアダプタ90は、ライン100上で信号RXVALIDを設定する。ライン100上の信号RXVALIDに応答して、メッセージコンバータ160のステートマシン252は、受信データバスRXDATAの情報バイトをメッセージコンバータ160内にロードし、ライン102上に信号RXACKを設定して情報バイトの受信を肯定応答する。信号RXVALIDを設定してメッセージの第1の情報バイトを示すデータアダプタ90に応答して、ステートマシン252は、ライン266を介してヘッダレジスタ240を制御し、受信データバスRXDATAの情報バイトを内部情報バス256を介してヘッダレジスタ240内にロードする。そして、ステートマシン252は、ヘッダレジスタ240内にロードされたバイトのうちの少なくとも2つの重要なビットを検索して、どのタイプのメッセージが入力するのかを決定する。この場合、ステートマシン252は、受信したバイトの少なくとも2つの重要なビットを00として識別し、「poke」メッセージに対応するとして入力メッセージを識別する。ホストCPUによって開始された「poke」メッセージは、ホストCPUがターゲットCPUメモリ領域内に特定アドレスで挿入しようとするデータを含む。ヘッダレジスタ240に記憶されたヘッダバイトと関連するワードカウントは、メッセージ内のデータワード数のカウントである。ステートマシン252は、ライン268を介してアドレスレジスタ242を制御して、受信データバスRXDATA上で受信される次の4バイトを、情報バス256を介してアドレスレジスタ242内にロードする。この4バイトはアドレスワードを形成する。アドレスワードがアドレスレジスタ242内にロードされると、受信データバスRXDATAで受信される第1のデータワードを形成する次の4バイトが、制御ライン270を介してステートマシン252の制御下でデータレジスタ244内にロードされる。そして、ステートマシン252は、ライン272を介してバス選択及び指定ロジック254を制御してアドレスレジスタ242とデータレジスタ244の内容をメモリマスタバス222に出力する。
【0064】
アドレスレジスタとデータレジスタの内容をメモリマスタバス222に出力すると、ステートマシン252は、前記バスに関連する書き込み制御信号と、メモリマスタバスに関連するライン356上の要求信号とを設定する。アクセスされるターゲットCPUのメモリスペースに関連するメモリアービタは、要求されたメモリアクセスが進行できることを判定すると、メモリマスタバスに関連するライン358上の許可(GRANT)信号を宣言する。より高い優先順位の要求者(例えばCPU)が要求を出さずに前回アクセスを完了した場合、メッセージコンバータ160は低優先順位を持ってもよい。要求及び許可の信号セットは、各データワード転送毎に要求される。
【0065】
メモリアクセス後、ヘッダレジスタ240に含まれるワードカウントが1ではない場合(本実施形態では、1はゼロのワードカウントを示す)、アドレスレジスタ242は、制御ライン243を介して増分制御248によって増分され、別のワード情報がデータレジスタ244内にロードされる。更に、レジスタ244へのデータワードのローディング後、アドレスレジスタ242内に記憶されたアドレス及びデータレジスタ244内に記憶されたデータは、書き込み制御信号及び要求信号が設定されるのとともにメモリマスタバス上に出力され、また、データレジスタ244内に含まれるデータワードがアドレスレジスタ242内に含まれるアドレスに書き込まれる。その肯定応答は、メモリマスタバス上に許可信号を設定するメモリアービタによって確認される。この一連のアドレスレジスタ242の増分とデータレジスタ244内への4バイト情報のローディングは、ヘッダレジスタ240に含まれるワードカウントが1と同じ、即ち、データワードが残らない、状態になるまで継続する。
【0066】
ホストCPUが「peek」を開始すると、図7(b) に示される形式の直列メッセージが集積回路2のテストアクセスポートで受信され、続いて受信データバスRXDATA上のデータアダプタ90によって並列情報バイト形式で出力される。信号RAVALIDを設定して第1の情報バイトを示すデータアダプタ90に応答して、ステートマシン252はヘッダレジスタ240を制御してその内部に情報バイトをロードする。そして、ステートマシン252はその内部にロードされたバイトのうち少なくとも2つの重要なビットを検索して、どのメッセージが入力するかを判定するが、この場合、受信したバイトのうち少なくとも2つの重要なビットを01として識別し、入力するメッセージを「peek」メッセージに対応するものとして識別する。ホストCPUによって開始される「peek」メッセージはターゲットCPUメモリ領域内にアドレスを含み、その内容はホストCPUが検索する。
【0067】
ステートマシン252が、その内部に含まれる第1の2ビットのヘッダバイトを01として識別することにより、ヘッダレジスタ240内にロードされた「peek」メッセージを識別すると、ステートマシン252は、ヘッダバイトの第1の2ビットを「peeked」ヘッダ用の適宜なビット、即ち、10に対応するように変化させて、この変化させたヘッダバイトを送信データバスに送信してヘッダレジスタ内に記憶されたワードカウントをそのまま含むホストCPUに戻し、図7(c)に示される形式の戻された「peeked」メッセージのヘッダバイトを形成する。言い換えれば、「peek」ヘッダバイトは「peeked」ヘッダバイトとして、そのままのワードカウントと01から10に変化した少なくとも2つの重要なビットとともに戻される。受信データバスRXDATA上で受信された次の4バイト情報がアドレスレジスタ242内にロードされてアドレスワードを形成する。ステートマシン252は、ライン272を介して選択及び指定ロジック254を制御し、メモリマスタバスに関連する読み出し制御信号の設定と、メモリマスタバスに関連する要求信号が設定されるのと、を連係して、アドレスレジスタ242に含まれるアドレスワードをメモリマスタバス222上に出力する。
【0068】
設定される要求信号に応答して、アクセスされるターゲットCPUのメモリスペースに連絡するメモリアービタが、要求されたアクセスが進行できることを判定すると、アービタはメモリマスタバスに関連する許可信号を設定する。メモリマスタバス上のアドレス出力に関連する実際のメモリ位置がアクセスされ、その内部に記憶されたデータがメモリマスタバスの読み出しデータバス上に出力されると、アービタはメモリマスタバスに関連する信号VALIDを設定してデータがホストCPUに返送される用意ができていることを示す。設定される信号VALIDに応答して、ステートマシン252は、ライン272を介してバス選択及び指定制御ロジックを制御してメモリマスタバスの読み出しデータバス上のデータをデータレジスタ244内にロードする。データレジスタ244内にロードされたデータワードは、内部情報バス256を介して送信データバスTXDATA上に一度に1バイトずつシフトアウトされて、ホストCPUに返送される。要求、許可及び有効の信号のセットが転送される各データワード毎に必要である。
【0069】
データレジスタ244内にロードされたデータワードがホストCPUにシフトバックされた後、ステートマシン252はライン260を介して減分制御246を制御し、制御ライン241を介してヘッダレジスタ240に含まれるワードカウントを1だけ減少させる。ワードカウントが1ではない場合、増分制御248がライン262を介してステートマシン252によって制御されて、制御ライン243を介してアドレスレジスタ242に含まれるアドレスを増加し、このアドレスが再びバス選択及び指定ロジック254によって設定された要求信号及び読み出し制御信号とともにメモリマスタバス222上に出力される。このように、ターゲットCPUメモリ領域内の次の連続したメモリ位置が読み出され、その内容がメッセージコンバータ160のデータレジスタ244内に書き込まれる。また、このデータワードは1バイトずつ送信データバスTXDATA上でホストCPUにシフトアウトされ、ヘッダレジスタ内のワードカウントが再び1だけ減少される。ヘッダレジスタ240に含まれるワードカウントが0と同じ、即ちデータワードが残らない状態になるまで、このサイクルが繰り返される。
【0070】
ターゲットCPUは、「poke」又は「peek」メッセージを開始してホストCPU200のメモリスペースからデータを書き込むかまたは読み出す。ターゲットCPU領域のメモリスレーブバス220とその関連制御信号を監視し、読み出しまたは書き込み制御信号に関連して、ターゲットCPUによるアドレスバス上のアドレス出力がターゲットCPUではなくホストCPUのアドレス範囲内であることを識別するステートマシン252によって、ターゲットCPUによる「poke」メッセージまたは「peek」メッセージの開始が認識される。複数ワードの「peek」メッセージ及び「poke」メッセージを実行する上記のようなターゲットCPUにより開始される「poke」メッセージ及び「peek」メッセージに対して、ターゲットCPUは単一ワードの「peek」メッセージ及び「poke」メッセージのみを実行できる。
【0071】
ターゲットCPUが「poke」メッセージを開始すると、これは、メモリスレーブバスの書き込みデータバスに関連する書き込み信号と、設定されるメモリスレーブバスに関連する要求信号とを識別するステートマシン252によって認識される。また、ステートマシン252は、メモリスレーブバスによって要求される書き込みデータと関連するアドレスがターゲットCPU領域のメモリ範囲の外側であることを認識する。この状況に応じて、ステートマシン252は、図6(a) に示されるような予め記憶された「poke」ヘッダバイトを制御ライン266を介してヘッダレジスタ240内に直接ロードする。このような「poke」ヘッダバイトは1つのデータワードを示すワードカウントを持つ。そして、メモリスレーブバスのアドレスデータバス上のアドレスワードはバス選択及び指定ロジック254を介して、ステートマシン252の制御下でアドレスレジスタ242内にロードされ、メモリスレーブバスの書き込みデータバス上の書き込みデータも同様にデータアダプタ160のデータレジスタ244内にロードされる。そして、ステートマシン252の制御下で、ヘッダレジスタ240内の「poke」バイトは、送信データバスTXDATA上を通ってホストCPUに出力され、アドレスレジスタ242に含まれる4バイトアドレスとデータレジスタ244に含まれる4バイトデータが続く。
【0072】
同様に、要求信号とターゲットCPU領域のアドレス範囲の外側のメモリスレーブバスのアドレスバス上のアドレスとに関連して読み出し信号をメモリスレーブバス上で識別するステートマシン252に応答して、ステートマシン252は、「peek」ヘッダバイトに相当する図6(b) に示されるヘッダバイトをヘッダレジスタ240内にロードする。この場合、ヘッダバイトは1つのワードカウントを含む、即ち、データワードがないことを示す。同様に、上述のように、ステートマシン252はまた、データアダプタ160を制御してメモリスレーブバスのアドレスバス上のアドレスをアドレスレジスタ242内にロードする。そして、ヘッダレジスタ240に含まれるヘッダバイトは、送信データバスTXDATA上に出力され、アドレスレジスタ242に記憶された4つの連続したバイトが続く。
【0073】
この段階で、メッセージコンバータ160は、開始されたターゲット「peek」メッセージで終了するが、ターゲットCPUはメモリスレーブバス220上の信号VALIDを受信していない。結果として、ターゲットCPUは「stuck」(即ち、固定されたかまたは継続して待機中)であり、何もしていない(停止または他の中断ではない)。しかしながら、メッセージコンバータ160は「stuck」ではなく、その他の活動(CPUが「stuck」なので開始されたターゲット「peek」メッセージまたは「poke」メッセージを受信しないが)を進行する位置にいる。
【0074】
このように、メッセージコンバータがメモリアクセスメッセージをオフ−チップホストプロセッサに送信すると、後続のメッセージまたは要求を自由に処理できる。
ターゲットCPUにより開始された「poke」メッセージまたは「peek」メッセージに応答して、ホストCPUは「peeked」メッセージで応答する。ホストCPUからの「peeked」メッセージの受信は、図6(c) の構成に対応するヘッダレジスタ内のヘッダバイトを認識するステートマシン252によって識別される。受信データバスRXDATAからの次の4バイトの情報がデータレジスタ244内にシフトされ、その内部にロードされたデータワードが、設定されるメモリスレーブバスと連絡する信号VALIDと関連して、ステートマシン252の制御下で、ターゲットCPU領域のメモリスレーブバス220のデータバスに、バス選択及び指定制御ロジック254によって転送されるので、ターゲットCPUのメモリスペースと連絡するメモリアービタに、「peek」要求によって要求されたデータが利用可能であることを表示する。ターゲットCPUは単一ワード「peek」を開始するだけなので、ホストCPUからの「peeked」メッセージは単一データワードのみを含む。ターゲットCPUが信号VALIDを受信すると、「stuck」ではなくなる。
【0075】
メモリスレーブバス220は、ターゲットCPUによって使用されて、メッセージコンバータ160を介してホストCPUによってアクセスされるオン−チップ診断機能にアクセスする。これは開始されたターゲット「peek」/「poke」に使用するのと同じバスであり、アドレス範囲は、これがオン−チップ診断機能へのアクセスかどうか判定する。ターゲットCPUによってメモリスレーブバス220上で開始される任意の作動に応答して、ステートマシン252はライン272を介してバス選択及び指定ロジック254を制御しメモリスレーブバス220上の任意の情報または制御信号を診断バス234に転送する。
【0076】
図11を参照すると、図8及び図10のメッセージコンバータ160と、オン−チップソース/宛先ロジックまたはターゲット領域とホストCPUと、の間の相互接続が概略的に示される。図5を参照して前述したように、集積回路2は、TAPコントローラ4と、データアダプタ90と、CPUレジスタ163を有するターゲットCPU162と、オン−チップメモリ164と、を含んで構成される。加えて、図11の集積回路2は、診断レジスタ301を有する診断機能回路300と、メモリキャッシュ302と、外部メモリインタフェースコントローラ304と、図10で詳細に説明したメッセージコンバータ160と、を含んで構成される。図11において、ホストCPU200がホスト通信アダプタ308を介して集積回路2のTAPコントローラ4とインタフェースすることが示されている。本実施形態において、ホスト通信アダプタ308は、TAPコントローライニシャライザ176と、データアダプタ180と、図5において説明したメモリバスアダプタ194と、を含んで構成される。また、ホスト通信アダプタ308は、ホストCPU200からまたはホストCPU200へのメッセージを変換するための集積回路2に設けられたメッセージコンバータ160と同等のメッセージコンバータを有する。更に、図11を参照すると、メッセージコンバータ160が診断バス234を介して診断機能回路300と通信するのがわかる。診断機能回路300とターゲットCPU162とは、バス310を介して相互に通信する。メッセージコンバータ160のメモリモニタバス226とメモリスレーブバス220は、ターゲットCPUとメモリキャッシュ302との間の共通バス312と接続する。また、ターゲットCPUとメモリキャッシュ302とは、CPU命令−取出しバス314を介して相互接続する。メッセージコンバータ160上のメモリマスタバス222は、オン−チップソース/宛先ロジックのメモリバス166に順次接続するメモリキャッシュ302に接続する。図5を参照して前述したように、メモリバス166はオン−チップメモリ164に接続する。また、メモリバス166は、外部メモリインタフェースコントローラ304と接続し、その外部メモリインターフェースコントローラ304は、オフ−チップメモリ174とインタフェースするオフ−チップメモリバス316にオン−チップソース/宛先ロジックメモリバス166をインタフェースする。
【0077】
図11の構成は、オン−チップソース/宛先ロジックとホストCPUとの間でメッセージを送信することによって種々の診断手順を実行するのに使用できる。診断バス234は、診断機能回路300の診断レジスタ301への又は診断レジスタ301からの読み出し及び書き込みを可能にするとともに、トリガ事象を発生させる。ターゲットCPUに関連する制御情報は、診断機能回路300から読み出される。ターゲットCPUに関連する命令ポインタと他の制御信号は、診断機能回路300の診断レジスタ301に記憶される。命令ポインタは、診断レジスタ301の一つに連続して複写され、診断バス234上の要求によってアクセスされる。ターゲットCPUの状態を検索するには、診断機能回路300の診断レジスタ301の一つを検索する必要がある。診断レジスタ301は、例えば、STALL AT INTERRUPT POINT、TRAP AT INTERRUPT POINT等の、ターゲットCPUの種々の制御信号を記憶できる。これらの信号は特定のワイヤを介してCPUに伝達される。
【0078】
前述のように、ホストCPUがメモリマスタバス222を介してターゲットCPUメモリスペース内のメモリ位置に書き込みができるのと同様の方法で、ホストCPUは、診断バス234を介して診断機能回路300内のレジスタに書き込みができる。診断機能回路300のレジスタに書き込みをするホストCPUに応答して、トリガされた事象が発生する。このトリガ事象は、トリガ事象を識別する理由コードに関連する要求信号を識別するステートマシン252によってメッセージコンバータ160内で検出される。要求信号に応答して、ステートマシン252は、トリガ事象に関連する理由コードを、トリガヘッダバイトを識別する2ビット11とともに、ヘッダレジスタ240内にロードする。そして、ヘッダレジスタ240に記憶されたトリガヘッダバイトが送信データバスTXDATA上をターゲットCPUに出力される。
【0079】
上記のように、ターゲットCPU自体が、メモリモニタバス226と診断バス234とを介して診断機能回路300にアクセスできる。同様に、ターゲットCPUが診断機能回路に書き込みをすると、この書き込みに応答してトリガ事象が発生して、ステートマシン252がヘッダレジスタ240に含まれるトリガヘッダバイトを出力してターゲットCPUに戻す。ステートマシン252は、診断バス234上の書き込みがターゲットCPUによって行われたかまたはホストCPUによって行われたかを記憶し、トリガ事象を正しい宛先に返送する。
【0080】
図11に示された環境で実行される本実施形態によるメッセージコンバータは、テストアクセスポートからのブート、ホットプラグ挿入及びホストとターゲットの同期化等の種々の高レベルの診断特徴を維持できる。
このように、本実施形態によれば、集積回路に挿入され、限定されたピンカウントを介してホストCPUとオン−チップソース/宛先ロジックとの間の通信を提供するメッセージコンバータが設けられる。このコンバータは、種々のオン−チップリソースへのアクセスを有する。これらのリソースのうちのいくつかは単に監視されるだけであり、他は制御されるかまたは監視及び制御される。任意のリソースの監視は非割り込みであり、チップ機能の実行または待機に何の影響も与えない。これは診断目的には理想的である。メッセージコンバータは、受信メッセージの解釈と、送信メッセージの編集と、オン−チップソース/宛先ロジックへのまたはオン−チップソース/宛先ロジックからの情報の選択または指示との機能を実行する。メッセージコンバータは、オン−チップ機能のいずれからも独立して作動するので、何らかの割り込み作動の実行が指示されるまで或いは指示されなければ非割り込みである。
【0081】
図11を参照すると、その構成は、メモリキャッシュ302を取り除き、共通バス312とCPU命令取出しバス314とをメモリバス166に直接接続することによって応用されてもよい。更に、この構成は、付加的なマスタまたはメモリバス166に接続されたオン−チップの自律機能を有するようにも応用できる。さらにまた、ターゲットCPU162は取り除くことができ、メモリスレーブバス220とメモリマスタバス222とメモリモニタバス226とをメモリバス166に直接接続できる。
【0082】
上記本発明の実施の形態によれば、診断機能回路300はブレークポイントユニット400を有し、1つ以上の診断レジスタがブレークポイントレジスタとして使用される。図12を参照して説明する。ブレークポイントレジスタは符号402、404で示される。ターゲットCPU162の命令ポインタは、ターゲットCPUの命令ポインタ(Iptr)レジスタ406内に保持され、バス310を介してブレークポイントユニット400に供給される。命令ポインタは、CPUが中断されず、或いは逸脱しない場合に、CPUが次に実行することが予測される命令へのポインタである。CPUが逸脱した場合、命令ポインタが有効な時を表示する制御信号とともに命令ポインタがバス310上を供給されるのは明らかである。
【0083】
上記の制御信号、即ち、STALL AT INTERRUPT POINT、TRAP AT INTERRUPT POINT、に加えて、新しい制御信号TRAP AT NEXT INTRUCTIONがブレークポイントユニット400により発生する。ブレークポイントユニット400は、制御信号STALL AT INTERRUPT POINTをライン408上に、制御信号TRAP AT NEXT INSTRUCTIONをライン407上に発生し、両制御信号はターゲットCPU162の命令実行回路411に接続される。実行回路411が制御信号TRAP AT NEXT INTRUCTION及びSTALL AT INTERRUPT POINTに応答して、ターゲットCPU162の通常作動を中断させる。信号TRAP AT NEXT INSTRUCTIONが宣言されて、ターゲットCPUにトラップを取らせる、即ち、CPUが通常実行する次の命令の代わりに予め定義された一連のトラップ命令を取出して実行させる。これらのトラップ命令は、CPUの作動を検査するために診断できる一定のタスクをCPUに実行させるように選択される。このために、CPUの実行回路411の実行制御ロジック454は、バス456上のアドレスとともにライン401上の制御信号をCPU162の命令取出しユニット410に送る。命令取出しユニット410及びCPUのトラップ機構の正常特性により、命令が命令バス409上に発生する。信号STALL AT INTERRUPT POINTが宣言されて、診断手順が行われている間は、CPUが別のどんな命令も実行することを防止する。
【0084】
ブレークポイントユニットの主要な機能は、上記のようにトラップを生じさせるかまたはCPUを停止させることであるが、診断コントローラもまた他の相互作用が可能である。ブレークポイントアドレスの検出に応答して可能な他の作動は、CPUを必要とせずに或いはCPUを妨害せずにTAPコントローラを介して「triggered」メッセージをオフ−チップで送信し、また、CPUを必要とせずに外部接続部を介して信号「trigger−out」を送信し、或いは、ブレークポイントされた命令のn番目の実行が上記可能な応答の1つを生じるようカウンタを減少させる、ことである。ここで、nは応答をトリガするのに必要なブレークポイント命令の所望の数である。
【0085】
TRAP AT NEXT INSTRUCTIONが、CPUが次の命令を実際に実行しようとする場合にのみ、CPUに次の命令の実行の代わりにトラップを取るかまたは停止するように合図することは言うまでもない。CPUが中断するか、(何らかの他の原因でトラップを取るか、またはプログラム飛越しをとると、次の命令が実行されないのでブレークポイントトラップがとられない。
【0086】
図13はブレークポイントユニットの構成部品をより詳細に示す。各ブレークポイントレジスタ402、404には比較回路412、414が接続される。両比較回路はバス310上の命令ポインタを受信する。また、各比較回路412、414は接続されたブレークポイントレジスタ402、404からそれぞれアドレスを受信する。ブレークポイントレジスタに保持されるアドレスは、ここではブレークポイントアドレスと考えられる。論理回路416は比較回路412、414からの出力と、命令ポインタと、を受信し、命令ポインタが有効な時期を決定して、比較回路の1つが、命令ポインタと接続されたブレークポイントレジスタ内に記憶されたブレークポイントアドレスとの間のマッチを表示すると、信号TRAP AT NEXT INSTRUCTIONまたは信号STALL AT INTERRUPT POINTのどちらかを宣言する。論理回路416はまた、信号TRAP AT NEXT INSTRUCTION及びSTALL AT INTERRUPT POINTが前回ブレークポイントから戻った後すぐに宣言されることを防止する状態ビットを記憶する状態ビットストア418に接続される。状態ビットは、次の命令が何らかの前回ブレークポイント作動に続く復帰または再開であることをブレークポイントユニット400に伝達するライン420上のCPUからの信号によって設定される。
【0087】
ブレークポイントユニット400には、論理回路416が信号TRAP AT NEXT INTRUCTIONまたはSTALL AT INTERRRUPT POINTのどちらを宣言するかを決定する、ブレークポイントユニット固有のレジスタ内のビット等の構成手段が設けられる。図13の実施の形態では、構成手段の構成ビットストア450は論理回路416にライン452上の信号を供給して、どの制御信号が宣言されるかを決定する。構成ビットストアは診断バス234を介してロードされる。
【0088】
ブレークポイントアドレスは、ブレークポイントレジスタ内に診断バス234を介してロードされる。これらは、これを実行するための回路接続はここでは示されていないが、代わりにメモリバス312によってロードされてもよい。
ブレークポイントユニット400は以下のように作動する。CPUからの命令ポインタは比較回路412、414内の各ブレークポイントアドレスと比較される。マッチが生じると、命令ポインタが有効であって、状態ビットが設定されていないとして、信号TRAP AT NEXT INSTRUCTIONまたはSTALL AT INTERRUPT POINTのうちの1つが、CPUが通常実行するはずの次の命令を実行するのを防止するのに十分な短い時間でライン407または408上で宣言される。実行回路411の実行制御ロジック454は、CPUが宣言された信号TRAP AT NEXT INSTRUCTIONまたはSTALL AT INTERRUPT POINTのうちの1つに正しく応答できるようにする。状態ビット418は、一方ではRETURN FROM TRAPに続く命令のための、他方では通常のCPU作動の再開のためのブレークポイント機能を禁止する。これは、CPUがブレークポイントによって要求される特定作動を終了した後に毎回ブレークポイント作動をとり続ける無限ループを防止するのに重要である。
【0089】
多条ブレークポインティングを可能にする状態ビット418の代わりにより洗練された状態機構を有することができる。即ち、状態ビットは同一ブレークポイントでのRETURN FROM TRAPの再トラッピングを防止するが、ブレークポイント機構を他のブレークポイントアドレス用に作動させるように設定できる。
【0090】
上記のように、ブレークポイントユニットはカウンタを有して、ブレークポイントされた命令が一定時間実行された後に、ブレークポイント作動が生じるようにする。この場合に特に重要な点は、中断が完了した時に再開されるCPUの実行の間のある中間点で命令を中断させるCPUの実行である。これを達成するために、カウンタは命令の開始ではなく命令の完了をカウントする必要がある。このようなカウンタは図13に符号422で示されており、バス310上の命令ポインタを受信し、適宜なカウントに到達した時に論理回路416に教えるように接続される。
【0091】
上記実施の形態において、命令ポインタはブレークポイントユニットに直接供給される。或いは、命令は実行のためにメモリから取出される必要があるので、命令取出しバス314が監視されてもよい。この変更例は、単純な命令取出しスキーマが使用される状況において実行可能である。ブレークポイント命令が次の命令の実行前に生じることが重要である場合に、命令取出しが命令実行よりどの程度進んでいるかの情報が要求されるのは言うまでもない。
【0092】
ここでのブレークポイントユニットは、ブレークポイントマッチが生じるまでは非割込み作動ができる。即ち、CPUのまたは他のオン−チップ機能の実行を妨害せず或いは実行に影響を与えずに、ブレークポイントレジスタをロードでき、命令ポインタを継続して監視できる。また、ブレークポイントユニットは、自立性ユニットなので、CPUに何らの変更も必要とせずに、例えばソフトウエア診断特性を必要としない場合の製造変更のために、チップから取り外すことができる。この結果、CPU内の実行制御ロジック454は単に冗長である。
【図面の簡単な説明】
【図1】本実施形態による接続点を有するテストアクセスポートコントローラを備えた集積回路を示す。
【図2】図1のテストアクセスポートコントローラを示す。
【図3】図2のテストアクセスポートコントローラに接続するための本実施形態によるデータアダプタを示す。
【図4】診断モードにおける図2のテストアクセスポートコントローラを介してオフ−チップ通信されたデータのデータフォーマットを示す。
【図5】図3のデータアダプタの実行を階層形状ブロック図で示す。
【図6】本実施形態によるメッセージのヘッダバイトのフォーマットを示す。
【図7】本実施形態によるメッセージのフォーマットを示す。
【図8】本実施形態によるメッセージコンバータを概略的に示す。
【図9】本実施形態におけるメッセージコンバータに接続されるバスのフォーマットを示す。
【図10】本実施形態のメッセージコンバータの実行を示す。
【図11】本実施形態のメッセージコンバータの実行を階層形状ブロック図で示す。
【図12】ブレークポイントユニットのCPUへの使用を示すブロック図を示す。
【図13】ブレークポイントユニットのブロック図を示す。
Claims (19)
- メモリから命令を取出して実行する取出し及び実行回路と、次に実行される命令のメモリ内のアドレスを保持する命令ポインタレジスタと、を含んで構成されるオン−チップCPUと、
CPUを前記メモリにアクセスさせる、CPUに接続されたバスと、
アドレス通信パスを介して命令ポインタレジスタの内容を受信するように接続されるとともに、CPUの通常作動が診断目的のために中断されるブレークポイントアドレスを保持するブレークポイントレジスタを有し、更に、ブレークポイントアドレスを命令ポインタレジスタの内容と比較して、マッチした時にブレークポイント信号パス上のブレークポイント信号を出力する比較回路を有するオン−チップブレークポイントユニットと、
ブレークポイント信号パスに接続され、ブレークポイント信号を受信したときに、診断手順を実行するためにCPUの通常作動を中断するように配置されたオン−チップ制御ロジックと、を含んで構成され、
前記オン−チップブレークポイントユニットが、前記診断手順を終了した後のCPUの通常作動の再開に関する前記次の命令のためのブレークポイント信号の発生を禁止する回路を含んで構成される、
ことを特徴とする単一チップ集積回路装置。 - 前記オン−チップ制御ロジックはブレークポイント信号に応答して、CPUが通常実行しようとする次の命令の代わりに、CPUに一連の命令を取り出させて実行させるように作動する請求項1記載の単一チップ集積回路装置。
- 前記オン−チップ制御ロジックはブレークポイント信号に応答して、診断手順が行われている間にCPUが何か別の命令を実行することを防止するように作動する請求項1記載の単一チップ集積回路装置。
- 通信パスを介してオン−チップブレークポイントユニットに接続され、オン−チップCPUを必要とせずにブレークポイントレジスタにブレークポイントアドレスをロードできるメッセージコンバータを含んで構成される請求項1から3のいずれか1つに記載の単一チップ集積回路装置。
- 前記メッセージコンバータがオン−チップバスに接続されてメッセージを受信し、ブレークポイントレジスタにブレークポイントアドレスをロードする請求項4記載の単一チップ集積回路装置。
- 前記メッセージコンバータがオフ−チップ通信パスに接続されてオフ−チップCPUからのメッセージを受信し、ブレークポイントレジスタをロードする請求項4または5記載の単一チップ集積回路装置。
- アドレス通信パスが、命令ポインタレジスタをオン−チップブレークポイントユニットに接続する専用並列バスである請求項1から6のいずれか1つに記載の単一チップ集積回路装置。
- アドレス通信パスが、CPUがメモリにアクセスできるように前記バスにより設けられ、オン−チップブレークポイントユニットが、バス上のメモリアクセスを監視するための監視回路を有して命令を取り出す請求項1から6のいずれか1つに記載の単一チップ集積回路装置。
- オン−チップブレークポイントユニットが、命令ポインタレジスタ内のアドレスが有効であることを示すアドレス有効信号を受信するように接続される請求項1から8のいずれか1つに記載の単一チップ集積回路装置。
- オン−チップCPUが複数の異なる手順を実行するための命令を取り出して実行でき、ブレークポイント信号の発生の禁止は、他の手順ではなく、通常作動を中断する手順のうちのいずれか1つに関してのみ作動する請求項1から9のいずれか1つに記載の単一チップ集積回路装置。
- ブレークポイント信号が、ブレークポイントアドレスにおける命令が所定回数実行された後にのみ発生する請求項1から10のいずれか1つに記載の単一チップ集積回路装置。
- オン−チップブレークポイントユニットが、それぞれ複数のブレークポイントアドレスを保持する複数の前記ブレークポイントレジスタを有する請求項1から11のいずれか1つに記載の単一チップ集積回路装置。
- 1つ以上のブレークポイントレジスタを含んで構成される複数の前記ブレークポイントユニットを含んで構成される請求項1から12のいずれか1つに記載の単一チップ集積回路装置。
- CPUによって実行される命令アドレスが監視されるとともに、各アドレスがCPUの通常作動が診断目的のために中断されるブレークポイントアドレスとそれぞれ比較され、監視アドレスとブレークポイントアドレスとの間にマッチがある時にブレークポイント信号が出力され、CPUによるブレークポイント信号の受信により、診断手順を実行するためにCPUの通常作動が中断し、更に、該診断手順を終了した後のCPUの通常作動の再開に関する次の命令のためのブレークポイント信号の発生を禁止することを特徴とする、特に診断手順を実行するための、オン−チップCPUの通常作動を中断する方法。
- ブレークポイント信号が、CPUが通常実行しようとする次の命令の代わりに、CPUに一連の命令を取り出させて実行させる請求項14記載のオン−チップCPUの通常作動を中断する方法。
- ブレークポイント信号が、診断手順が行われている間、CPUが何か別の命令を実行することを防止する請求項14記載のオン−チップCPUの通常作動を中断する方法。
- ブレークポイントアドレスが、オン−チップCPUを必要とせずにロードできるブレークポイントレジスタ内に保持される請求項14から16のいずれか1つに記載のオン−チップCPUの通常作動を中断する方法。
- オン−チップCPUが複数の異なる手順を実行するための命令を取り出して実行でき、ブレークポイント信号の発生の禁止は、他の手順ではなく通常作動を中断する手順のうちのいずれか1つに関してのみ作動する請求項14から17のいずれか1つに記載のオン−チップCPUの通常作動を中断する方法。
- ブレークポイントアドレスにおける命令が所定回数実行された後にのみブレークポイント信号が発生する請求項14から18のいずれか1つに記載のオン−チップCPUの通常作動を中断する方法。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB9626401-5 | 1996-12-19 | ||
GBGB9626401.5A GB9626401D0 (en) | 1996-12-19 | 1996-12-19 | Diagnostic procedures in an integrated circuit device |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH10222393A JPH10222393A (ja) | 1998-08-21 |
JP4493739B2 true JP4493739B2 (ja) | 2010-06-30 |
Family
ID=10804703
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP34988597A Expired - Fee Related JP4493739B2 (ja) | 1996-12-19 | 1997-12-19 | 集積回路装置の診断手順 |
Country Status (5)
Country | Link |
---|---|
US (1) | US6134652A (ja) |
EP (1) | EP0849668B1 (ja) |
JP (1) | JP4493739B2 (ja) |
DE (1) | DE69705813T2 (ja) |
GB (1) | GB9626401D0 (ja) |
Families Citing this family (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB9626412D0 (en) * | 1996-12-19 | 1997-02-05 | Sgs Thomson Microelectronics | Diagnostic procedures in an integrated circuit device |
US6192427B1 (en) * | 1997-05-02 | 2001-02-20 | Texas Instruments Incorporated | Input/output buffer managed by sorted breakpoint hardware/software |
US6446221B1 (en) * | 1999-05-19 | 2002-09-03 | Arm Limited | Debug mechanism for data processing systems |
JP2001051863A (ja) * | 1999-08-09 | 2001-02-23 | Fujitsu Ltd | マイクロプロセッサ |
US6892347B1 (en) * | 1999-09-16 | 2005-05-10 | Customersat.Com, Inc. | Techniques for monitoring user activities at a web site and for initiating an action when the user exits from the web site |
US6601189B1 (en) | 1999-10-01 | 2003-07-29 | Stmicroelectronics Limited | System and method for communicating with an integrated circuit |
US6449736B1 (en) * | 1999-10-20 | 2002-09-10 | Texas Instruments Incorporated | Method and apparatus for providing chained breakpoints in a microprocessor |
JP2001166009A (ja) * | 1999-12-14 | 2001-06-22 | Matsushita Electric Ind Co Ltd | 診断機能を有する半導体集積回路 |
KR100337149B1 (ko) * | 2000-07-05 | 2002-05-18 | 권 기 홍 | 프로그램 테스트 및 디버깅이 용이한 중앙처리장치 |
US6985980B1 (en) | 2000-11-03 | 2006-01-10 | Xilinx, Inc. | Diagnostic scheme for programmable logic in a system on a chip |
US6751751B1 (en) * | 2000-11-06 | 2004-06-15 | Xilinx, Inc. | Universal multi-bus breakpoint unit for a configurable system-on-chip |
US6757846B1 (en) | 2000-11-06 | 2004-06-29 | Xilinx, Inc. | Method and apparatus for multi-bus breakpoint stepping |
US6708326B1 (en) * | 2000-11-10 | 2004-03-16 | International Business Machines Corporation | Method, system and program product comprising breakpoint handling mechanism for debugging and/or monitoring a computer instruction sequence |
JP2002202900A (ja) * | 2000-12-28 | 2002-07-19 | Seiko Epson Corp | デバッグ装置 |
US7093236B2 (en) * | 2001-02-01 | 2006-08-15 | Arm Limited | Tracing out-of-order data |
US7093108B2 (en) * | 2001-02-01 | 2006-08-15 | Arm Limited | Apparatus and method for efficiently incorporating instruction set information with instruction addresses |
US9003376B2 (en) * | 2002-08-09 | 2015-04-07 | Texas Instruments Incorporated | Software breakpoints with tailoring for multiple processor shared memory or multiple thread systems |
JP4409349B2 (ja) * | 2004-04-27 | 2010-02-03 | Okiセミコンダクタ株式会社 | デバッグ回路およびデバッグ制御方法 |
US7334161B2 (en) * | 2004-04-30 | 2008-02-19 | Arm Limited | Breakpoint logic unit, debug logic and breakpoint method for a data processing apparatus |
US7395454B1 (en) * | 2005-01-04 | 2008-07-01 | Marvell Israel (Misl) Ltd. | Integrated circuit with integrated debugging mechanism for standard interface |
US8510596B1 (en) * | 2006-02-09 | 2013-08-13 | Virsec Systems, Inc. | System and methods for run time detection and correction of memory corruption |
GB2443507A (en) * | 2006-10-24 | 2008-05-07 | Advanced Risc Mach Ltd | Debugging parallel programs |
US8407457B2 (en) * | 2007-09-28 | 2013-03-26 | Freescale Semiconductor, Inc. | System and method for monitoring debug events |
TWI557746B (zh) * | 2011-05-10 | 2016-11-11 | 電子戰協會公司 | 實施微電腦為基的電路之內容驗證的系統及方法 |
JP2016534479A (ja) | 2013-09-12 | 2016-11-04 | ヴァーセック・システムズ・インコーポレーテッドVirsec Systems,Inc. | マルウェアのランタイム中の自動検出 |
CN103743604A (zh) * | 2013-11-28 | 2014-04-23 | 苏州长风航空电子有限公司 | 一种线圈断点的检测方法 |
WO2015200511A1 (en) | 2014-06-24 | 2015-12-30 | Virsec Systems, Inc. | System and methods for automated detection of input and output validation and resource management vulnerability |
CA3027728A1 (en) | 2016-06-16 | 2017-12-21 | Virsec Systems, Inc. | Systems and methods for remediating memory corruption in a computer application |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2197506A (en) * | 1986-10-27 | 1988-05-18 | Burr Brown Ltd | Providing and handling break points in a software monitor |
JPS63155336A (ja) * | 1986-12-19 | 1988-06-28 | Hitachi Ltd | デ−タ処理装置 |
JP2513417B2 (ja) * | 1993-07-05 | 1996-07-03 | 日本電気株式会社 | 情報処理装置 |
EP0636976B1 (en) * | 1993-07-28 | 1998-12-30 | Koninklijke Philips Electronics N.V. | Microcontroller provided with hardware for supporting debugging as based on boundary scan standard-type extensions |
US5664159A (en) * | 1994-03-08 | 1997-09-02 | Exponential Technology, Inc. | Method for emulating multiple debug breakpoints by page partitioning using a single breakpoint register |
JP2752592B2 (ja) * | 1994-12-28 | 1998-05-18 | 日本ヒューレット・パッカード株式会社 | マイクロプロセッサ、マイクロプロセッサ−デバッグツール間信号伝送方法及びトレース方法 |
US5717909A (en) * | 1995-05-26 | 1998-02-10 | National Semiconductor Corporation | Code breakpoint decoder |
US5740413A (en) * | 1995-06-19 | 1998-04-14 | Intel Corporation | Method and apparatus for providing address breakpoints, branch breakpoints, and single stepping |
US5964893A (en) * | 1995-08-30 | 1999-10-12 | Motorola, Inc. | Data processing system for performing a trace function and method therefor |
US5889981A (en) * | 1996-05-07 | 1999-03-30 | Lucent Technologies Inc. | Apparatus and method for decoding instructions marked with breakpoint codes to select breakpoint action from plurality of breakpoint actions |
-
1996
- 1996-12-19 GB GBGB9626401.5A patent/GB9626401D0/en active Pending
-
1997
- 1997-12-12 EP EP97310061A patent/EP0849668B1/en not_active Expired - Lifetime
- 1997-12-12 DE DE69705813T patent/DE69705813T2/de not_active Expired - Lifetime
- 1997-12-19 US US08/995,255 patent/US6134652A/en not_active Expired - Lifetime
- 1997-12-19 JP JP34988597A patent/JP4493739B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
DE69705813D1 (de) | 2001-08-30 |
EP0849668B1 (en) | 2001-07-25 |
GB9626401D0 (en) | 1997-02-05 |
DE69705813T2 (de) | 2002-10-24 |
JPH10222393A (ja) | 1998-08-21 |
EP0849668A1 (en) | 1998-06-24 |
US6134652A (en) | 2000-10-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4493739B2 (ja) | 集積回路装置の診断手順 | |
JP3929574B2 (ja) | 集積回路装置及びその通信方法 | |
JP3929573B2 (ja) | 集積回路装置及びその通信方法 | |
EP0849669B1 (en) | Diagnostic system and procedure in an integrated circuit device | |
JP4426655B2 (ja) | トリガシーケンシングコントローラ | |
US6279103B1 (en) | Method and device for providing an instruction trace from an on-chip CPU using control signals from the CPU | |
JP4037494B2 (ja) | テストアクセスポート制御器及びそれを用いた有効な通信方法 | |
US6675284B1 (en) | Integrated circuit with multiple processing cores | |
JP3998303B2 (ja) | Tapコントローラを有する集積回路 | |
JP3929572B2 (ja) | 集積回路装置及びその通信方法 | |
JP4504466B2 (ja) | コンピュータシステム内の通信を実行する方法 | |
JP2004094451A (ja) | オンチップjtagインタフェース回路およびシステムlsi | |
EP0943994A2 (en) | Method of initializing CPU for emulation |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20041217 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20060829 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20061129 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20061204 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20070206 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20100210 |
|
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: 20100407 |
|
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: 20130416 Year of fee payment: 3 |
|
LAPS | Cancellation because of no payment of annual fees |