JP2007328622A - Method for verifying circuit operation - Google Patents

Method for verifying circuit operation Download PDF

Info

Publication number
JP2007328622A
JP2007328622A JP2006160093A JP2006160093A JP2007328622A JP 2007328622 A JP2007328622 A JP 2007328622A JP 2006160093 A JP2006160093 A JP 2006160093A JP 2006160093 A JP2006160093 A JP 2006160093A JP 2007328622 A JP2007328622 A JP 2007328622A
Authority
JP
Japan
Prior art keywords
circuit
verified
clock
divided
communication
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2006160093A
Other languages
Japanese (ja)
Other versions
JP4743427B2 (en
Inventor
Souji Mori
創司 森
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 JP2006160093A priority Critical patent/JP4743427B2/en
Publication of JP2007328622A publication Critical patent/JP2007328622A/en
Application granted granted Critical
Publication of JP4743427B2 publication Critical patent/JP4743427B2/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Abstract

<P>PROBLEM TO BE SOLVED: To provide a method for verifying circuit operation that is capable of increasing the speed of verifying operation by further reducing the number of times of communication of split circuits to be verified when the operation of a circuit to be verified is verified. <P>SOLUTION: The method for verifying circuit operation includes an investigation step for investigating a method of synchronizing synchronization elements in the circuit to be verified; a splitting step for splitting the circuit to be verified into a plurality of split circuits to be verified 103.1, 103.2 in such a manner as to minimize the number of times that the synchronization element addressed by a path between the split circuits 103.1, 103.2 latches the signal values of the path; and a verification step for verifying the operation of the circuit to be verified, by causing the plurality of split circuits 103.1, 103.2 to communicate with each other via a bus 10. <P>COPYRIGHT: (C)2008,JPO&INPIT

Description

本発明は、複数の被検証分割回路に分割され、複数の被検証分割回路間で相互通信を行うことで動作するような被検証回路の動作検証を実行する回路動作検証方法に関し、特に、大規模な被検証回路の動作検証を実行する回路動作検証方法に関する。   The present invention relates to a circuit operation verification method for performing operation verification of a circuit to be verified which is divided into a plurality of divided circuits to be verified and operates by performing mutual communication between the plurality of divided circuits to be verified. The present invention relates to a circuit operation verification method for performing operation verification of a circuit to be verified on a scale.

ディジタルLSI(Large Scale Integration)に実装できる回路規模が年々大きくなっていることに伴って、ディジタルLSIの動作検証の高速化を図ることが重要な課題となっている。   As the circuit scale that can be mounted on a digital LSI (Large Scale Integration) has increased year by year, it has become an important issue to speed up the operation verification of the digital LSI.

近年、ディジタルLSIのような大規模回路を被検証回路とし、その動作検証の高速化を図るための回路動作検証方法として、回路を実装できるFPGA(Field Programmable Gate Array),CPLD(Complex Programmable Logic Device)などの検証用デバイスを用いる構成が研究されている。   In recent years, a large-scale circuit such as a digital LSI is used as a circuit to be verified, and as a circuit operation verification method for speeding up the operation verification, an FPGA (Field Programmable Gate Array), CPLD (Complex Programmable Logic Device) capable of mounting the circuit is used. A configuration using a verification device such as) has been studied.

例えば、特許文献1には、被検証回路を分割して得られた複数の被検証分割回路をそれぞれ実装した複数の検証用デバイスと、被検証分割回路のそれぞれの機能的動作をシミュレーションにより実現するための複数のシミュレーション手段と、複数のシミュレーション手段を接続して複数のシミュレーション手段間の相互通信を可能にするバスと、バスを制御するバス制御手段と、バス制御手段を制御して複数のシミュレーション手段間で相互通信を行わせることにより被検証回路の機能的動作の検証を実行する上位制御手段とを有する回路動作検証装置を使用した回路動作検証方法が提案されている。   For example, in Patent Document 1, a plurality of verification devices each mounted with a plurality of verified divided circuits obtained by dividing a circuit to be verified, and a functional operation of each of the verified divided circuits are realized by simulation. A plurality of simulation means, a bus connecting the plurality of simulation means to enable mutual communication between the plurality of simulation means, a bus control means for controlling the bus, and a plurality of simulations by controlling the bus control means There has been proposed a circuit operation verification method using a circuit operation verification device having higher-level control means for performing verification of functional operation of a circuit to be verified by performing mutual communication between the means.

この回路動作検証方法によれば、被検証回路を分割して得られた複数の被検証分割回路のそれぞれを複数の検証用デバイスに実装しているため、大規模な被検証回路の動作検証を実行することが可能である。また、この回路動作検証方法によれば、その検証の際には、バスを介して被検証分割回路間で相互通信を行わせ、上位制御手段からクロック信号等の制御信号を入力することによって動作検証を実行する。   According to this circuit operation verification method, each of a plurality of divided circuit to be verified obtained by dividing a circuit to be verified is mounted on a plurality of verification devices. It is possible to execute. Further, according to this circuit operation verification method, in the verification, the communication is performed between the divided circuits to be verified through the bus, and the operation is performed by inputting a control signal such as a clock signal from the upper control means. Perform verification.

特許文献1には、被検証回路の動作検証の高速化を図るために、次のような回路分割方法が提案されている。
・被検証分割回路間で貫通パス(被検証分割回路の入力信号と出力信号との間に、クロックで同期するメモリ等の同期素子が1つもないパス)の本数が最も少なくなるように被検証回路を分割する回路分割方法。貫通パスが少ないと通信回数は少なくなる。
・被検証分割回路間をまたぐパスの信号変化率を基に通信発生回数が最も少なくなるように被検証回路を分割する回路分割方法。
Patent Document 1 proposes the following circuit division method for speeding up the operation verification of the circuit to be verified.
-Tested so that the number of through paths (paths where there is no synchronization element such as a memory synchronized with the clock between the input signal and output signal of the circuit to be verified) between the circuit to be verified is minimized. A circuit dividing method for dividing a circuit. If the number of through paths is small, the number of times of communication decreases.
A circuit division method that divides a circuit to be verified so that the number of communication occurrences is minimized based on a signal change rate of a path across the circuit to be verified.

上記の2つの回路分割方法はいずれも、検証用デバイス間で必要な通信回数が減るように被検証回路を分割することによって、被検証回路の動作検証を高速化する方法である。
特開2005−84957号公報
Both of the above two circuit division methods are methods for speeding up the operation verification of the circuit to be verified by dividing the circuit to be verified so that the required number of communications between the verification devices is reduced.
JP 2005-84957 A

ところで、被検証分割回路間をまたぐパスを介した通信が必要となるタイミングは、以下の2つの条件を満たしている時である。   By the way, the timing at which communication via a path crossing between the divided circuits to be verified is required is when the following two conditions are satisfied.

条件1)被検証分割回路間をまたぐパスの信号値が変化した後
条件2)被検証分割回路間をまたぐパスの通信先の同期素子がパスの信号値をラッチする前
例えば、パスの信号値が変化していないのなら、通信を行う必要はない。また、パスの信号値が変化したとても通信先の同期素子がその信号値をラッチしないのなら、通信を行う必要はない。
Condition 1) After the signal value of the path that crosses between the divided circuits to be verified changes. Condition 2) Before the synchronization element of the communication destination of the path that crosses between the divided circuits to be verified latches the signal value of the path. If is not changing, there is no need to communicate. If the signal value of the path has changed and the synchronization element at the communication destination does not latch the signal value, communication is not necessary.

条件1は、通信元の同期素子による条件であり、条件2は、通信先の同期素子による条件である。   Condition 1 is a condition based on a synchronization element at a communication source, and condition 2 is a condition based on a synchronization element at a communication destination.

特許文献1で提案されている回路分割方法のうち、被検証分割回路間をまたぐパスの信号変化率を基に通信発生回数が最も少なくなるような回路分割方法は、条件1の方に注目した手法である。   Of the circuit division methods proposed in Patent Document 1, the circuit division method that minimizes the number of communication occurrences based on the signal change rate of the path that crosses between the divided circuits to be verified is focused on condition 1. It is a technique.

しかし、特許文献1では、条件2については注目していないため、十分に通信回数を減らせるような回路分割ができてはいない。また、クロック入力とデバイス間通信のスケジュールを決定する時にも、不必要な通信を行っている。   However, since Patent Document 1 does not pay attention to Condition 2, circuit division that can sufficiently reduce the number of communications has not been achieved. Also, unnecessary communication is performed when a schedule for clock input and communication between devices is determined.

本発明の目的は、被検証回路の動作検証時に被検証分割回路の通信回数をさらに減らし、動作検証の高速化を図ることができる回路動作検証方法を提供することにある。   An object of the present invention is to provide a circuit operation verification method capable of further reducing the number of times of communication of a verification target divided circuit at the time of verifying the operation of the circuit to be verified and increasing the speed of the operation verification.

上記目的を達成するために本発明は、
複数の被検証分割回路に分割され、当該複数の被検証分割回路間でバスを介して相互通信を行うような被検証回路の動作検証を実行する回路動作検証方法であって、
前記被検証回路内の、クロックで同期する同期素子の同期方法を調査する調査ステップと、
前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信先の同期素子が当該パスの信号値をラッチする回数が最小となるように、前記被検証回路を複数の被検証分割回路に分割する分割ステップと、
前記複数の被検証分割回路間でバスを介して相互通信を行わせて前記被検証回路の動作検証を実行する検証ステップとを有する。
In order to achieve the above object, the present invention provides:
A circuit operation verification method for performing operation verification of a circuit to be verified that is divided into a plurality of divided circuits to be verified and performs mutual communication via a bus between the plurality of divided circuits to be verified.
An investigation step for investigating a synchronization method of a synchronization element synchronized with a clock in the circuit to be verified;
Based on the result of the investigation in the investigation step, the circuit to be verified is divided into a plurality of circuits to be verified so that the number of times that the synchronization element of the communication destination of the path across the circuit to be verified latches the signal value of the path is minimized. A dividing step of dividing into verification dividing circuits;
A verification step of performing operation verification of the circuit to be verified by performing mutual communication between the plurality of circuit to be verified via a bus.

この構成によれば、特許文献1では注目されていないパスの通信先の同期素子に注目し、通信先の同期素子がパスの信号値をラッチする回数が最小となるように回路分割を行うため、特許文献1に開示された発明よりも、被検証回路の動作検証時の被検証分割回路の通信回数を効果的に減らし、動作検証の高速化を図ることができる。   According to this configuration, attention is paid to a synchronization element at a communication destination of a path that is not focused on in Patent Document 1, and circuit division is performed so that the number of times that the synchronization element at the communication destination latches a signal value of the path is minimized. Compared to the invention disclosed in Patent Document 1, it is possible to effectively reduce the number of communications of the circuit to be verified at the time of verifying the operation of the circuit to be verified, thereby speeding up the operation verification.

具体的には、本発明の第1の実施態様は、前記調査ステップでは、前記同期素子の同期方法として、前記被検証回路が周波数の異なる複数のクロックを使用する場合に前記同期素子がどの周波数のクロックで同期するかを調査し、
前記分割ステップでは、前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信先の全ての同期素子が、当該パスの通信元の全ての同期素子に比べて周波数の小さいクロックで同期するように、前記被検証回路を複数の被検証分割回路に分割する。
Specifically, according to the first embodiment of the present invention, in the investigating step, as the synchronization method of the synchronization element, when the circuit to be verified uses a plurality of clocks having different frequencies, the frequency of the synchronization element Investigate whether to synchronize with other clocks,
In the division step, based on the investigation result in the investigation step, all the synchronization elements of the communication destination of the path crossing between the division circuits to be verified have a lower frequency than all of the synchronization elements of the communication source of the path. The circuit to be verified is divided into a plurality of divided circuits to be verified so as to be synchronized with a clock.

この構成によれば、被検証分割回路間をまたぐパスの通信先の同期素子が、周波数の小さいクロックで同期しているため、通信先の同期素子が同期する周波数の小さいクロックのタイミングのみ通信を行えばよいので、動作検証時の被検証分割回路の通信回数を減らすことができる。   According to this configuration, since the synchronization element of the communication destination of the path crossing between the divided circuits to be verified is synchronized with the clock having a low frequency, communication can be performed only at the timing of the clock with the low frequency to which the synchronization element of the communication destination is synchronized. Therefore, it is possible to reduce the number of times of communication of the divided circuit to be verified at the time of operation verification.

また、本発明の第2の実施態様は、前記調査ステップでは、前記同期素子の同期方法として、前記同期素子がクロックの立ち上がりまたは立ち下がりのどちらで同期するのかを調査し、
前記分割ステップでは、前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信元の全ての同期素子がクロックの立ち上がりもしくは立ち下がりでのみ同期するか、または、当該パスの通信先の全ての同期素子がクロックの立ち上がりもしくは立ち下がりでのみ同期するように、前記被検証回路を複数の被検証分割回路に分割する。
Further, in the second embodiment of the present invention, in the investigating step, as the synchronizing method of the synchronizing element, investigating whether the synchronizing element synchronizes at the rising edge or falling edge of the clock,
In the division step, based on the investigation result in the investigation step, all the synchronization elements of the communication sources of the paths crossing the division circuits to be verified are synchronized only at the rising edge or falling edge of the clock, or The circuit to be verified is divided into a plurality of divided circuits to be verified so that all the synchronization elements at the communication destination are synchronized only at the rise or fall of the clock.

この構成によれば、クロックの立ち上がり後と立ち下り後の両方で通信を行うことを回避することができるため、動作検証時の被検証分割回路の通信回数を減らすことができる。   According to this configuration, it is possible to avoid performing communication both at the rising edge and the falling edge of the clock, so that the number of times of communication of the division circuit to be verified at the time of operation verification can be reduced.

また、本発明の第3の実施態様は、前記調査ステップでは、前記同期素子の同期方法として、前記同期素子がクロックの立ち上がりまたは立ち下がりのどちらで同期するのかを調査し、
前記分割ステップでは、前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信元の全ての同期素子がクロックの立ち下がりでのみ同期するか、または、当該パスの通信先の全ての同期素子がクロックの立ち上がりでのみ同期するように、前記被検証回路を複数の被検証分割回路に分割する。
In the third embodiment of the present invention, in the investigating step, as the synchronizing method of the synchronizing element, investigating whether the synchronizing element is synchronized at the rising edge or falling edge of the clock,
In the division step, based on the investigation result in the investigation step, all the synchronization elements of the communication source of the path crossing between the divided circuits to be verified are synchronized only at the falling edge of the clock, or the communication destination of the path The to-be-verified circuit is divided into a plurality of to-be-verified divided circuits so that all of the synchronization elements are synchronized only at the rise of the clock.

また、前記検証ステップでは、クロックの立ち上がり後に、前記被検証分割回路でクロックを自動的に立ち下げる。   In the verification step, the clock is automatically lowered by the divided circuit to be verified after the clock rises.

この構成によれば、クロックの立ち上がり後と立ち下り後の両方で通信を行うことを回避することができるため、動作検証時の被検証分割回路の通信回数を減らすことができる。さらに、クロックの立ち上がり後に、被検証分割回路間をまたぐパスの通信を行っていないため、被検証分割回路でクロックを自動的に立ち下げることができる。よって、上位コンピュータから被検証分割回路に対するクロックの入力回数を減らすことができるため、動作検証時の被検証分割回路の通信回数をさらに減らすことができる。   According to this configuration, it is possible to avoid performing communication both at the rising edge and the falling edge of the clock, so that the number of times of communication of the division circuit to be verified at the time of operation verification can be reduced. Furthermore, after the clock rise, since the communication of the path across the divided circuit to be verified is not performed, the clock can be automatically lowered by the divided circuit to be verified. Therefore, since the number of clock inputs from the host computer to the verified divided circuit can be reduced, the number of communications of the verified divided circuit during operation verification can be further reduced.

上記のように構成された本発明によれば、特許文献1では注目されていないパスの通信先の同期素子に注目し、通信先の同期素子がパスの信号値をラッチする回数が最小となるように回路分割を行うため、特許文献1に開示された発明よりも、被検証回路の動作検証時の被検証分割回路の通信回数をさらに減らし、動作検証の高速化を図ることができるという効果が得られる。   According to the present invention configured as described above, attention is paid to the synchronization element of the communication destination of the path not paid attention in Patent Document 1, and the number of times the synchronization element of the communication destination latches the signal value of the path is minimized. Since the circuit division is performed as described above, it is possible to further reduce the number of times of communication of the circuit to be verified at the time of verifying the operation of the circuit to be verified and to speed up the operation verification than the invention disclosed in Patent Document 1. Is obtained.

以下に、本発明を実施するための最良の形態について図面を参照して説明する。このうち、第1から第3実施形態は、基本的なシステム構成は特許文献1の構成と等しいが、後述する回路分割工程、被検証分割回路間のパスの通信とクロック入力の順序を決定するスケジューリング工程、アドレス配置工程において特許文献1とは相違点がある。
(第1実施形態)
1.1)システム構成
図1は、本発明の第1実施形態による回路動作検証方法に使用する回路動作検証装置の概略構成を示すブロック図である。
The best mode for carrying out the present invention will be described below with reference to the drawings. Among these, in the first to third embodiments, the basic system configuration is the same as the configuration of Patent Document 1, but the circuit division process, which will be described later, the path communication between the verified divided circuits and the order of clock input are determined. There is a difference from Patent Document 1 in the scheduling process and the address arrangement process.
(First embodiment)
1.1) System Configuration FIG. 1 is a block diagram showing a schematic configuration of a circuit operation verification apparatus used in the circuit operation verification method according to the first embodiment of the present invention.

図1を参照すると、本実施形態においては、複数の回路素子あるいは複数の回路モジュールからなる被検証回路を、複数の被検証分割回路103.1,103.2に分割し、分割した複数の被検証分割回路103.1,103.2を複数の検証用デバイス(以下、デバイスと称す)1,2にそれぞれ実装している。   Referring to FIG. 1, in this embodiment, a circuit to be verified including a plurality of circuit elements or a plurality of circuit modules is divided into a plurality of divided circuits 103.1 and 103.2 to be verified, Verification division circuits 103.1 and 103.2 are mounted on a plurality of verification devices (hereinafter referred to as devices) 1 and 2, respectively.

デバイス1,2は、バス10に接続され、バス10はさらにバスコントローラ11に接続されている。バスコントローラ11は常にバスマスタとして動作し、デバイス1,2は常にバスのスレーブデバイスとして動作する。   The devices 1 and 2 are connected to the bus 10, and the bus 10 is further connected to the bus controller 11. The bus controller 11 always operates as a bus master, and the devices 1 and 2 always operate as slave devices of the bus.

上位コンピュータシステム12は、バスコントローラ11、ユーザインタフェース13および表示装置14に接続されている。ユーザは、ユーザインタフェース13を用いてバスコントローラ11の動作を制御することができる。また、バスコントローラ11を通して得た情報は表示装置14によりユーザに提示される。バスコントローラ11は、上位コンピュータシステム12からの命令によって動作が規定され、各デバイス1,2に対して信号の入力および出力を行う。   The host computer system 12 is connected to the bus controller 11, user interface 13 and display device 14. The user can control the operation of the bus controller 11 using the user interface 13. Information obtained through the bus controller 11 is presented to the user by the display device 14. The bus controller 11 is regulated in operation by a command from the host computer system 12 and inputs and outputs signals to the devices 1 and 2.

また、バスコントローラ11は、被検証回路内部の指定された信号の値を順次保存するためのメモリ15に接続されている。被検証回路内部のどの信号を指定するかは、ユーザがユーザインタフェース13を通してバスコントローラ11に予め指示しておく。例えば、ブレーク条件を設定した信号を指定しておく。   The bus controller 11 is connected to a memory 15 for sequentially storing designated signal values inside the circuit to be verified. The user specifies in advance to the bus controller 11 through the user interface 13 which signal in the circuit to be verified is to be specified. For example, a signal for which a break condition is set is specified.

各デバイス1,2は、バス10に接続して信号の入出力を可能にするバスインタフェース101、被検証回路を分割して得られた被検証分割回路103、および、被検証分割回路103をバスインタフェース101と接続して他デバイスの被検証分割回路103との相互通信を可能にする通信回路102を有する。   Each of the devices 1 and 2 is connected to the bus 10 through a bus interface 101 that enables input / output of signals, a divided circuit 103 to be verified obtained by dividing the circuit to be verified, and a divided circuit 103 to be verified. The communication circuit 102 is connected to the interface 101 to enable mutual communication with the divided circuit 103 to be verified of another device.

以下、デバイス1,2の構成をさらに詳細に説明する。   Hereinafter, the configuration of the devices 1 and 2 will be described in more detail.

図2は、図1に示したデバイス1,2の詳細な構成を示すブロック図である。   FIG. 2 is a block diagram showing a detailed configuration of the devices 1 and 2 shown in FIG.

各デバイス1,2の基本構成はいずれも、上述したように、バスインタフェース101、通信回路102、および被検証分割回路103を有する構成となっている。   As described above, the basic configuration of each of the devices 1 and 2 includes the bus interface 101, the communication circuit 102, and the divided circuit 103 to be verified.

通信回路102は、バスインタフェース101からの書き込みデータWDATAなどを入力信号inputとして被検証分割回路103へ与え、また、被検証分割回路103からの出力信号outputをバスインタフェース101からのアドレス信号ADに従って選択し、バスインタフェース101に転送する。   The communication circuit 102 supplies the write data WDATA from the bus interface 101 as an input signal input to the verified divided circuit 103, and selects the output signal output from the verified divided circuit 103 according to the address signal AD from the bus interface 101. The data is transferred to the bus interface 101.

より詳しくは、通信回路102は、クロック制御回路201、レジスタ202、アドレスデコーダ203、およびセレクタ204を有する。   More specifically, the communication circuit 102 includes a clock control circuit 201, a register 202, an address decoder 203, and a selector 204.

クロック制御回路201は、書き込みデータWDATAを書き込み、書き込みイネーブル信号WEおよびセレクタ信号SELを入力してクロック信号を生成し、被検証分割回路103およびセレクタ204へ供給する。図2の例では、2つのクロック信号CLK,2f_CLKを生成している。なお、図2では、セレクタ204へ供給されるクロック信号の図示は、簡略化のために省略されている。   The clock control circuit 201 writes the write data WDATA, receives the write enable signal WE and the selector signal SEL, generates a clock signal, and supplies the clock signal to the divided circuit 103 to be verified and the selector 204. In the example of FIG. 2, two clock signals CLK and 2f_CLK are generated. In FIG. 2, the clock signal supplied to the selector 204 is not shown for the sake of simplicity.

レジスタ202は、書き込みデータWDATA、書き込みイネーブル信号WEおよびセレクタ信号SELを入力し、入力信号input、入出力信号IN/OUT、およびリセット信号RSTを生成して被検証分割回路103へ出力する。   The register 202 receives the write data WDATA, the write enable signal WE, and the selector signal SEL, generates an input signal input, an input / output signal IN / OUT, and a reset signal RST and outputs them to the divided circuit 103 to be verified.

アドレスデコーダ203は、バスインタフェース101から入力したアドレス信号ADをデコードしてセレクタ信号SEL,SELTxを生成し、セレクタ信号SELをクロック制御回路201およびレジスタ202に供給し、セレクタ信号SELTxをセレクタ204に供給する。   The address decoder 203 decodes the address signal AD input from the bus interface 101 to generate selector signals SEL and SELTx, supplies the selector signal SEL to the clock control circuit 201 and the register 202, and supplies the selector signal SELTx to the selector 204. To do.

セレクタ204は、セレクタ信号SELTxに従って、被検証分割回路103の出力信号outputおよび入出力信号IN/OUTのいずれかを送信データTxDとして選択してバスインタフェース101へ出力する。   The selector 204 selects one of the output signal output and the input / output signal IN / OUT of the verified divided circuit 103 as the transmission data TxD according to the selector signal SELTx, and outputs it to the bus interface 101.

なお、被検証分割回路103の入力信号inputおよび入出力信号IN/OUTの入力信号、出力信号outputおよび入出力信号IN/OUTの出力信号には、それぞれ1つずつアドレスが割り振られている。1アドレスで特定されるデータの最大ビット数は、書き込みデータWDATAおよび送信データTxDのビット幅に等しい。アドレス信号ADによるアドレスは、バス10のアドレス空間の一部でもよいし、また別空間のアドレスでもよい。このアドレスは、バス10から被検証分割回路103のデータの位置が一意に決定できればよい。このアドレスがバス10のアドレス空間の一部でない時はバスインタフェース101が必要なアドレス変換を行う。ただし、各データのアドレスの割り振りにおいて、1アドレスに接続先の異なるデバイスのデータを割り振ることはできない。   Note that one address is assigned to each of the input signal input and input / output signal IN / OUT input signal, the output signal output and the input / output signal IN / OUT output signal of the divided circuit 103 to be verified. The maximum number of bits of data specified by one address is equal to the bit width of write data WDATA and transmission data TxD. The address by the address signal AD may be a part of the address space of the bus 10 or an address in another space. This address only needs to be able to uniquely determine the data position of the verification target divided circuit 103 from the bus 10. When this address is not part of the address space of the bus 10, the bus interface 101 performs necessary address conversion. However, in the allocation of each data address, data of devices with different connection destinations cannot be allocated to one address.

図3は、図2に示したクロック制御回路201の詳細な構成を示すブロック図である。   FIG. 3 is a block diagram showing a detailed configuration of the clock control circuit 201 shown in FIG.

図3を参照すると、クロック制御回路201は、同期素子301,302およびAND回路303,304を有する。なお、図3において、書き込みWDATA[0]〜WDATA[1]およびセレクタ信号SEL[0]〜SEL[1]における[X]は、その信号のビット番号を表している。   Referring to FIG. 3, the clock control circuit 201 includes synchronization elements 301 and 302 and AND circuits 303 and 304. In FIG. 3, [X] in writing WDATA [0] to WDATA [1] and selector signals SEL [0] to SEL [1] represents the bit number of the signal.

同期素子301は、セレクタ信号SEL[0]と書き込みイネーブル信号WEとが共にアクティブになった時に、書き込みデータWDATA[0]の値をラッチし、その値をクロック信号CLKとして被検証分割回路103に入力する。   When both the selector signal SEL [0] and the write enable signal WE become active, the synchronization element 301 latches the value of the write data WDATA [0], and uses the value as the clock signal CLK to the verified divided circuit 103. input.

同様に、同期素子302は、セレクタ信号SEL[1]と書き込みイネーブル信号WEとが共にアクティブになった時に、書き込みデータWDATA[1]の値をラッチし、その値をクロック信号2f_CLKとして被検証分割回路103に入力する。   Similarly, when both the selector signal SEL [1] and the write enable signal WE become active, the synchronization element 302 latches the value of the write data WDATA [1] and uses the value as the clock signal 2f_CLK to be verified. Input to the circuit 103.

上位コンピュータシステム12は、クロック信号CLKを立ち上げる時は、バスコントローラ11からアドレス信号ADとしてクロック信号CLKに割り当てたアドレス値を入力し、WDATA[0]に1を入力する。立ち下げる時には、アドレス信号ADとしてクロック信号CLKに割り当てたアドレス値を入力し、WDATA[0]に0を入力する。また、図3では、WDATA[0]とWDATA[1]を、それぞれCLK、2f_CLKの入力に割り当てているが、この割り当てはWDATのビット幅内で自由に変更可能である。なお、同期素子301,302は、バスインタフェース101からのクロック信号で動作するが、簡略化のためにクロック信号の図示は省略されている。   When the host computer system 12 raises the clock signal CLK, it inputs the address value assigned to the clock signal CLK from the bus controller 11 as the address signal AD, and inputs 1 to WDATA [0]. When falling, the address value assigned to the clock signal CLK is input as the address signal AD, and 0 is input to WDATA [0]. In FIG. 3, WDATA [0] and WDATA [1] are assigned to inputs of CLK and 2f_CLK, respectively, but this assignment can be freely changed within the bit width of WDAT. Although the synchronization elements 301 and 302 operate with the clock signal from the bus interface 101, the clock signal is not shown for simplicity.

図4は、図2に示したレジスタ202の詳細な構成を示すブロック図である。   4 is a block diagram showing a detailed configuration of the register 202 shown in FIG.

図4を参照すると、レジスタ202は、被検証分割回路103の入力信号inputおよび入出力信号IN/OUTの入力信号の和の合計と同じ個数の同期素子401〜407を有する。図4では、書き込みデータWDATAのビット幅が3、被検証分割回路103の入力信号inputおよび入出力信号IN/OUTの入力信号の数の合計が7の場合を一例として示している。また、図4のA,B,C,D,E,F,Gは7個の入力信号inputおよび入出力信号IN/OUTの入力信号をそれぞれに示す。   Referring to FIG. 4, the register 202 has the same number of synchronization elements 401 to 407 as the sum of the sum of the input signals input and input / output signals IN / OUT of the circuit to be verified 103. FIG. 4 shows an example where the write data WDATA has a bit width of 3 and the total number of input signals input and input / output signals IN / OUT of the divided circuit 103 to be verified is 7. Further, A, B, C, D, E, F, and G in FIG. 4 respectively indicate seven input signals input and input signals of the input / output signal IN / OUT.

同期素子401は、セレクタ信号SEL[0]と書き込みイネーブル信号WEとが共にアクティブになった時に、書き込みデータWDATA[0]の値をラッチする。他の同期素子402〜407も、同期素子401と略同様の動作を行う。   The synchronization element 401 latches the value of the write data WDATA [0] when both the selector signal SEL [0] and the write enable signal WE become active. The other synchronization elements 402 to 407 perform substantially the same operation as the synchronization element 401.

図4のようにレジスタ202を構成することで、バス10から各同期素子401〜407を一意に特定することができ、被検証分割回路103の入力信号inputおよび入出力信号IN/OUTの入力信号A,B,C,D,E,F,Gの全ての値をバス10に接続されたデバイスすべてから変更可能である。   By configuring the register 202 as shown in FIG. 4, each of the synchronization elements 401 to 407 can be uniquely specified from the bus 10, and the input signal input and the input / output signal IN / OUT input signals of the divided circuit 103 to be verified. All values of A, B, C, D, E, F, and G can be changed from all devices connected to the bus 10.

例えば、書き込みデータWDATA[0]〜WDATA[2]=(1,0,0)、アドレス信号ADをデコードしたセレクタ信号SEL[0]〜SEL[2]=(1,0,0)とすれば、書き込みイネーブル信号WEがアクティブなり、図示されていないクロックが立ち上がった時点で、同期素子401〜403には、それぞれデータ“1”、“0”、“0”が保持される。   For example, if write data WDATA [0] to WDATA [2] = (1, 0, 0) and selector signals SEL [0] to SEL [2] obtained by decoding the address signal AD are set to (1, 0, 0). When the write enable signal WE becomes active and a clock (not shown) rises, data “1”, “0”, and “0” are held in the synchronization elements 401 to 403, respectively.

図5は、図2に示したセレクタ204の詳細な構成を示すブロック図である。図5では、送信データTxDのビット幅が3、被検証分割回路103の出力信号outputおよび入出力信号IN/OUTの出力信号の数の合計が8の場合を一例として示している。また、図5のOA,OB,OC,OD,OE,OF,OG,OHは、被検証分割回路103の出力信号outputを表す。   FIG. 5 is a block diagram showing a detailed configuration of the selector 204 shown in FIG. FIG. 5 shows an example in which the transmission data TxD has a bit width of 3, and the total number of output signals output and output signals of the divided circuit 103 to be verified is eight. In addition, OA, OB, OC, OD, OE, OF, OG, and OH in FIG. 5 represent output signals output of the divided circuit 103 to be verified.

セレクタ204は、3個のセレクタ回路501〜503を有する。なお、セレクタ回路501〜503は、クロック制御回路201からのクロック信号で動作するが、簡略化のためにクロック信号の図示は省略されている。   The selector 204 has three selector circuits 501 to 503. The selector circuits 501 to 503 operate with the clock signal from the clock control circuit 201, but the clock signal is not shown for the sake of simplicity.

セレクタ回路501は、被検証分割回路103からの出力信号OA,OD,OGを入力とし、セレクタ信号SELTxによって出力信号OA,OD,OGのいずれかを選択し送信データTxD[0]として出力する。   The selector circuit 501 receives the output signals OA, OD, OG from the divided circuit 103 to be verified, selects one of the output signals OA, OD, OG by the selector signal SELTx, and outputs it as transmission data TxD [0].

セレクタ回路502は、被検証分割回路103からの出力信号OB,OE,OHを入力とし、セレクタ信号SELTxによって出力信号OB,OE,OHのいずれかを選択し送信データTxD[1]として出力する。   The selector circuit 502 receives the output signals OB, OE, and OH from the divided circuit 103 to be verified, selects one of the output signals OB, OE, and OH by the selector signal SELTx and outputs it as transmission data TxD [1].

セレクタ回路503は、被検証分割回路103からの出力信号OC,OF,“0”を入力とし、セレクタ信号SELTxによって出力信号OC,OF,“0”のいずれかを選択し送信データTxD[2]として出力する。   The selector circuit 503 receives the output signals OC, OF, “0” from the divided circuit 103 to be verified, selects one of the output signals OC, OF, “0” by the selector signal SELTx, and transmits the transmission data TxD [2]. Output as.

図6は、被検証回路を2つの被検証分割回路103.1,103.2に分割して、2つのデバイス1,2にそれぞれ実装するまでの概略的な流れを説明するフローチャートである。   FIG. 6 is a flowchart for explaining a schematic flow from dividing the circuit to be verified into two divided circuits 103.1 and 103.2 to be verified and mounting them on the two devices 1 and 2, respectively.

図6を参照すると、被検証回路を2つのデバイス1,2に実装するため、最初に、被検証回路を2つの被検証分割回路103.1,103.2に分割する回路分割を行う。まず、分割候補解のそれぞれについて、回路分割面をまたぐパスの通信元・通信先の同期素子の調査を行う(ステップS101)。この調査結果に基づいて、被検証分割回路間をまたぐパスの通信先の同期素子が当該パスの信号値をラッチする回数が最小となるように、被検証回路を被検証分割回路103.1,103.2に分割する(ステップS102)。   Referring to FIG. 6, in order to mount the circuit to be verified on the two devices 1 and 2, first, circuit division is performed to divide the circuit to be verified into two circuit to be verified 103.1 and 103.2. First, for each of the division candidate solutions, the communication source / communication destination synchronization element of the path crossing the circuit division plane is investigated (step S101). Based on this investigation result, the circuit to be verified is divided into the circuit to be verified 103.1 so that the number of times that the synchronization element of the communication destination of the path across the circuit to be verified latches the signal value of the path is minimized. Divide into 103.2 (step S102).

続いて、被検証分割回路103.1,103.2間をまたぐ各パスについて、通信を行う順番やクロックを与えるタイミングを決定するスケジューリングを行う(ステップS103)。このスケジューリングに基づいてデバイス1,2に実装する被検証分割回路103.1,103.2の入力信号input、入出力信号IN/OUT、および出力信号outputのバスアドレス空間におけるアドレス配置を決定する(ステップS104)。なお、ステップS101〜S104についての詳細は後述する。この決定されたアドレス配置から通信回路102を生成する(ステップS105)。   Subsequently, scheduling is performed to determine the order of communication and the timing for providing the clock for each path crossing between the divided circuits to be verified 103.1 and 103.2 (step S103). Based on this scheduling, the address arrangement in the bus address space of the input signal input, the input / output signal IN / OUT, and the output signal output of the divided circuit to be verified 103.1, 103.2 mounted on the devices 1 and 2 is determined ( Step S104). Details of steps S101 to S104 will be described later. The communication circuit 102 is generated from the determined address arrangement (step S105).

このとき、ステップS101,S102では、デバイス1,2ごとに被検証分割回路103を生成し、また、ステップS105では、デバイス1,2ごとに通信回路102を生成する。その後、各デバイス1,2に被検証分割回路103および通信回路102を実装する(ステップS106)。実装する手法は、デバイス1,2の構成によって異なる。例えば、デバイス1,2の1つがプログラマブル素子から構成される場合、あらかじめバスインタフェース101および通信回路102を用意するほかに、被検証分割回路103、通信回路102およびバスインタフェース101をインスタンスした最上位回路を合成ツールを用いて合成し、その結果を配置配線しプログラマブル素子をコンフィグレーションしてもよい。   At this time, in steps S101 and S102, the verification divided circuit 103 is generated for each of the devices 1 and 2, and in step S105, the communication circuit 102 is generated for each of the devices 1 and 2. Thereafter, the divided circuit 103 to be verified and the communication circuit 102 are mounted on the devices 1 and 2 (step S106). The mounting method varies depending on the configuration of the devices 1 and 2. For example, when one of the devices 1 and 2 is composed of programmable elements, in addition to preparing the bus interface 101 and the communication circuit 102 in advance, the highest circuit in which the divided circuit 103 to be verified, the communication circuit 102 and the bus interface 101 are instantiated May be synthesized using a synthesis tool, and the result may be placed and routed to configure a programmable element.

なお、ステップS101〜S104の工程は、図1には図示していないシミュレーション手段により実行することができる。   In addition, the process of step S101-S104 can be performed by the simulation means which is not illustrated in FIG.

1.2)回路分割
次に、図6に示したステップS101,S102における被検証回路の回路分割工程についてさらに詳細に説明する。
1.2) Circuit Division Next, the circuit division process of the circuit to be verified in steps S101 and S102 shown in FIG. 6 will be described in more detail.

被検証回路の回路分割に際しては、上述したように、被検証分割回路間をまたぐパスの通信先の同期素子が当該パスの信号値をラッチする回数が最小となるように回路分割を行う。ここでは、被検証回路は複数の回路ユニットからなるものとし、各回路ユニットは1個または複数個の回路素子からなるものとする。回路分割方法の基本的な手順を次に示す。   In circuit division of the circuit to be verified, as described above, circuit division is performed so that the number of times that the synchronization element of the communication destination of the path across the divided circuit to be verified latches the signal value of the path is minimized. Here, it is assumed that the circuit to be verified is composed of a plurality of circuit units, and each circuit unit is composed of one or a plurality of circuit elements. The basic procedure of the circuit division method is as follows.

A1)複数の回路ユニットから構成される被検証回路のハードウェア記述言語を読み込み、各回路ユニットの入力および出力の各々がどこの回路ユニットに接続しているかを解析する。   A1) Read a hardware description language of a circuit to be verified including a plurality of circuit units, and analyze which circuit unit each input and output of each circuit unit is connected to.

A2)デバイスの数、各デバイスの回路規模、および各回路ユニットの回路規模を算出する。デバイスの数および各デバイスの回路規模はユーザが手動で与え、各回路ユニットの回路規模は当該回路ユニットに対するハードウェア記述言語を読み込んで推定する。   A2) The number of devices, the circuit scale of each device, and the circuit scale of each circuit unit are calculated. The number of devices and the circuit scale of each device are manually given by the user, and the circuit scale of each circuit unit is estimated by reading the hardware description language for the circuit unit.

A3)被検証回路全体のハードウェア記述言語を読み込み、各回路ユニット間をまたぐパスの通信元・通信先の同期素子の情報を記憶する。この同期素子の情報とは具体的には次の2つである。
(1)被検証回路が異なる周波数を持つ複数のクロックを使用している場合、通信元・通信先の同期素子がどの周波数のクロックで同期するのかの情報。
(2)通信元・通信先の同期素子がクロックの立ち上がりで同期しているのか、立ち下がりで同期しているかの情報。
A3) The hardware description language of the entire circuit to be verified is read, and information on the synchronization element of the communication source / destination of the path crossing between the circuit units is stored. Specifically, the information of the synchronization element is the following two.
(1) Information on which frequency clock the communication source / destination synchronization element synchronizes with when the circuit to be verified uses a plurality of clocks having different frequencies.
(2) Information on whether the communication source / destination synchronization elements are synchronized at the rising edge of the clock or at the falling edge.

A4)上記ステップA1〜A3により得られた情報に基づき、被検証分割回路間をまたぐパスの信号値に対して通信先の同期素子が同期する回数が可能な限り少なくなるように被検証回路の回路分割を行う。これにより、動作検証時の必要な通信回数を減少させる。さらにクロックの入力回数を減らすように回路分割を行う。具体的には以下のように回路分割を行う。
(a)被検証分割回路間をまたぐパスの数が少なくなるように回路分割を行う。
(b)被検証回路が周波数の異なる複数のクロックを使用している場合、被検証分割回路間をまたぐパスの通信先の全ての同期素子が、通信元の全ての同期素子に比べて周波数の小さいクロックで同期するように回路分割を行う。
(c)被検証分割回路間をまたぐ全てのパスについて、パスの通信元の被検証分割回路の同期素子と通信先の被検証分割回路の同期素子が以下の条件iまたは条件iiを満たすように回路分割を行う。以下では、クロックの立ち上がりによって同期する同期素子をPM、クロックの立ち下がりによって同期する同期素子をNMと呼ぶ。
(条件i)通信元の同期素子の集合がPMかNMのどちらかである。あるいは、通信先の同期素子の集合がPMかNMのどちらかである。
(条件ii)通信元の同期素子の集合がNMのみである。あるいは、通信先の同期素子の集合がPMのみである。
A4) Based on the information obtained in steps A1 to A3, the number of times that the synchronization element of the communication destination synchronizes with the signal value of the path across the divided circuit to be verified is minimized. Perform circuit division. As a result, the necessary number of communications during operation verification is reduced. Further, circuit division is performed so as to reduce the number of clock inputs. Specifically, circuit division is performed as follows.
(A) Circuit division is performed so that the number of paths crossing between the divided circuits to be verified is reduced.
(B) When the circuit to be verified uses a plurality of clocks having different frequencies, all the synchronization elements in the communication destination of the path crossing between the divided circuits to be verified have a frequency higher than that of all the synchronization elements of the communication source. Circuit division is performed so as to synchronize with a small clock.
(C) For all paths straddling between the divided circuit to be verified, the synchronization element of the divided circuit to be verified of the communication source of the path and the synchronous element of the divided circuit to be verified of the communication destination satisfy the following condition i or condition ii: Perform circuit division. Hereinafter, a synchronization element that synchronizes with the rising edge of the clock is referred to as PM, and a synchronization element that synchronizes with the falling edge of the clock is referred to as NM.
(Condition i) The set of synchronization elements of the communication source is either PM or NM. Alternatively, the set of communication synchronous elements is either PM or NM.
(Condition ii) The set of synchronization elements of the communication source is only NM. Alternatively, the PM is the only set of communication-destination synchronization elements.

条件iiの方が条件iよりも厳しい条件である。   Condition ii is more severe than condition i.

この回路分割方法のうち、(b)と(c)の回路分割方法は特許文献1にない本発明独自のものである。   Among these circuit dividing methods, the circuit dividing methods (b) and (c) are unique to the present invention which is not disclosed in Patent Document 1.

この回路分割方法の理解を助けるために、簡単な例を用いて説明する。   In order to help understanding of this circuit dividing method, a simple example will be described.

被検証回路の検証は、詳しくは後述するが、大まかには、各デバイス1,2に実装された被検証分割回路103.1,103.2同士で通信を行うデバイス間通信と、上位コンピュータシステム12から各被検証分割回路103.1,103.2へのクロック信号入力とを交互に繰り返すことによって実行される。   The verification of the circuit to be verified will be described in detail later. Roughly speaking, the device-to-device communication for performing communication between the circuit to be verified 103.1 and 103.2 mounted on each device 1 and 2 and the host computer system This is executed by alternately repeating the clock signal input from 12 to each of the divided circuit to be verified 103.1 and 103.2.

デバイス間通信は、被検証回路内のある同期素子を通信元とし、回路分割面をまたいで別の被検証回路内の同期素子を通信先とするような全てのパスに対して行う。   The inter-device communication is performed for all paths in which a certain synchronization element in the circuit to be verified is a communication source and a synchronization element in another circuit to be verified is a communication destination across the circuit division plane.

例えば、図7の場合、被検証分割回路103.1内の同期素子Xを通信元とし、被検証分割回路103.2内の同期素子Zを通信先とするようなパスPと、被検証分割回路103.1内の同期素子Xを通信元とし、被検証分割回路103.2内を貫通して被検証分割回路103.1内の同期素子Yを通信先とするようなパスQのデバイス間通信を行う。なお、被検証分割回路103.1,103.2内の同期素子は、FF(flip-flop)やレジスタ、メモリ等により実現される。   For example, in the case of FIG. 7, a path P in which the synchronization element X in the divided circuit to be verified 103.1 is a communication source and the synchronization element Z in the divided circuit to be verified 103.2 is a communication destination, and the division to be verified Between the devices of the path Q such that the synchronous element X in the circuit 103.1 is a communication source and the synchronous element Y in the verified divided circuit 103.1 is the communication destination through the verified divided circuit 103.2. Communicate. Note that the synchronization elements in the divided circuits 103.1 and 103.2 to be verified are realized by FFs (flip-flops), registers, memories, and the like.

図7の場合、(a)の回路分割方法を用いて回路分割を行うと、デバイス間通信の通信回数が減少することは自明である。   In the case of FIG. 7, when circuit division is performed using the circuit division method of (a), it is obvious that the number of communication between devices decreases.

また、(b)の回路分割方法を用いて回路分割を行っても、デバイス間通信の通信回数が減少する。その理由を図8および図9の回路分割例を用いて説明する。   In addition, even if circuit division is performed using the circuit division method (b), the number of communication between devices is reduced. The reason will be described with reference to the circuit division examples of FIGS.

図8および図9において、(A)は、3つの同期素子X,Y,Zを2つの被検証分割回路に分割した回路分割例を示す図、(B)は、デバイスへのクロック入力およびデバイス間通信のタイミングを説明するフローチャート、(C)は、クロック、パスの信号値、および通信先の同期素子の信号値の波形を示す図である。   8 and 9, (A) is a diagram showing an example of circuit division in which three synchronization elements X, Y, and Z are divided into two to-be-verified divided circuits, and (B) is a clock input to the device and the device The flowchart explaining the timing of intercommunication, (C) is a figure which shows the waveform of a clock, the signal value of a path | pass, and the signal value of the synchronous element of a communication destination.

ここで、(A)において、同期素子Zは、クロック信号f_Clockで同期され、同期素子X,Yは、f_Clockの2倍の周波数を持つ2f_Clockで同期されている。なお、クロック信号f_Clock,2f_Clockの波形は、図8および図9で同じとしている。また、(B)において、クロック入力とは、クロック信号の立ち上げおよび立ち下げの両方を入力することである。また、(C)において、図中の縦の太い点線はデバイス間通信のタイミングを示している。また、パスの信号値[X]に対応する通信先の同期素子の信号値を([X])としている。   Here, in (A), the synchronization element Z is synchronized with the clock signal f_Clock, and the synchronization elements X and Y are synchronized with 2f_Clock having a frequency twice that of f_Clock. Note that the waveforms of the clock signals f_Clock and 2f_Clock are the same in FIGS. In (B), the clock input is to input both rising and falling of the clock signal. Further, in (C), a vertical thick dotted line in the figure indicates the timing of communication between devices. Further, the signal value of the synchronous element of the communication destination corresponding to the signal value [X] of the path is ([X]).

例えば、図8(A)に示す回路分割例では、被検証分割回路間をまたぐパスの通信先に同期素子Zが配置されるように回路分割を行っている。この場合、図8(B)および(C)に示すように、デバイス間通信はクロック信号f_Clock入力の直前だけ行えば、回路は正常動作する。これは、被検証分割回路間のパスの信号はクロック信号2f_Clockに同期して変化するが、このパスの信号はクロック信号f_Clockでのみ同期してラッチされるからである。   For example, in the circuit division example shown in FIG. 8A, the circuit division is performed so that the synchronization element Z is arranged at a communication destination of a path that crosses between the divided circuits to be verified. In this case, as shown in FIGS. 8B and 8C, if the inter-device communication is performed just before the clock signal f_Clock is input, the circuit operates normally. This is because the signal of the path between the divided circuits to be verified changes in synchronization with the clock signal 2f_Clock, but the signal of this path is latched only in synchronization with the clock signal f_Clock.

これに対して、図9(A)に示す回路分割例では、同期素子Yが被検証分割回路間をまたぐパスの通信先に配置されるように回路分割を行っている。すなわち、(b)の回路分割方法を用いている。この場合、図9(B)に示すように、クロック信号2f_Clockの入力ごとにデバイス間通信を行う必要がある。これは、図9(C)に示すように、被検証分割回路間のパスの信号はクロック信号2f_Clockに同期して変化し、その変化はクロック信号2f_Clockに同期してラッチされるからである。   On the other hand, in the circuit division example shown in FIG. 9A, circuit division is performed so that the synchronization element Y is arranged at a communication destination of a path that crosses between the divided circuits to be verified. That is, the circuit dividing method (b) is used. In this case, as illustrated in FIG. 9B, it is necessary to perform inter-device communication for each input of the clock signal 2f_Clock. This is because, as shown in FIG. 9C, the signal of the path between the division circuits to be verified changes in synchronization with the clock signal 2f_Clock, and the change is latched in synchronization with the clock signal 2f_Clock.

よって、図9に示す回路分割例は、図8に示す回路分割例に比べて、必要な通信回数が2倍になる。   Therefore, the circuit division example shown in FIG. 9 requires twice as many communication operations as the circuit division example shown in FIG.

このように(b)の回路分割方法を用いて回路分割を行った場合、周波数の異なる複数のクロックを使用する被検証回路に対して、動作検証時の被検証分割回路の通信回数を減少させて動作検証速度を向上させる効果がある。   In this way, when circuit division is performed using the circuit division method of (b), the number of communications of the verification target divided circuit during operation verification is reduced with respect to the verification target circuit using a plurality of clocks having different frequencies. This has the effect of improving the operation verification speed.

また、(c)の回路分割方法を用いて回路分割を行っても、デバイス間の通信回数が減少する。その理由を図10〜図13の回路分割例を用いて説明する。なお、(c)の回路分割方法では、条件iまたは条件iiを満たすように回路分割を行う。   Further, even when circuit division is performed using the circuit division method of (c), the number of communication between devices is reduced. The reason will be described with reference to the circuit division examples of FIGS. In the circuit division method (c), circuit division is performed so as to satisfy the condition i or the condition ii.

図10〜図13において、(A)は、4つの同期素子を2つの被検証分割回路に分割した回路分割例を示す図、(B)は、デバイスへのクロック入力およびデバイス間通信のタイミングを説明するフローチャート、(C)は、クロック、パスの信号値、および通信先の同期素子の信号値の波形を示す図である。   10 to 13, (A) is a diagram showing an example of circuit division in which four synchronization elements are divided into two to-be-verified divided circuits, and (B) shows the timing of clock input to the device and communication between devices. The flowchart to be described, (C) is a diagram showing waveforms of the clock, the signal value of the path, and the signal value of the synchronization element of the communication destination.

ここで、(A)において、4つの同期素子は同じクロック信号で同期されている。また、図中のPと記された同期素子はPMであり、Nと記された同期素子はNMである。なお、クロック信号の波形は、図10〜図13で同じとしている。また、(C)において、図中の縦の太い点線はデバイス間通信のタイミングを示している。また、パスの信号値[X]に対応する通信先の同期素子の信号値を([X])としている。   Here, in (A), the four synchronization elements are synchronized with the same clock signal. In the figure, the synchronizing element marked P is PM, and the synchronizing element marked N is NM. The waveform of the clock signal is the same in FIGS. Further, in (C), a vertical thick dotted line in the figure indicates the timing of communication between devices. Further, the signal value of the synchronous element of the communication destination corresponding to the signal value [X] of the path is ([X]).

図10(A)に示す回路分割例では、被検証分割回路間をまたぐパスの通信元にはPMとNMの両方の同期素子があり、通信先にもPMとNMの両方の同期素子があるため、条件iを満たしていない。この場合、図10(B)に示すように、クロック信号の立ち上げ後と立ち下げ後の両方でデバイス間通信を行っている。これは、図10(C)に示すように、パスの通信元にPMとNMの両方の同期素子があることから、クロック信号の立ち上げと立ち下げの両方で同期してパスの信号値が変化するためと、通信先にもPMとNMの両方の同期素子があることから、クロック信号の立ち上げと立ち下げの両方で同期してパスの信号値をラッチするからである。   In the circuit division example shown in FIG. 10A, there are both PM and NM synchronization elements at the communication source of the path crossing between the divided circuits to be verified, and both PM and NM synchronization elements at the communication destination. Therefore, the condition i is not satisfied. In this case, as shown in FIG. 10B, inter-device communication is performed both after the rising and falling of the clock signal. As shown in FIG. 10C, since there are both PM and NM synchronization elements at the path communication source, the signal value of the path is synchronized with both rising and falling of the clock signal. This is because the signal value of the path is latched in synchronism with both rising and falling of the clock signal because there are both PM and NM synchronizing elements at the communication destination.

図11(A)に示す回路分割例では、被検証分割回路間をまたぐパスの通信先にはPMとNMの両方の同期素子があるが、通信元にはPMしかない。このため、条件iを満たしている。この場合、図11(B)に示すように、クロック信号の立ち上げ後にしかデバイス間通信を行う必要がない。これは、図11(C)に示すように、被検証分割回路間をまたぐパスの通信元にはPMしかないことから、クロック立ち上げでしかパスの信号値が変化しないためである。   In the circuit division example shown in FIG. 11A, there are both PM and NM synchronization elements in the communication destination of the path that crosses between the divided circuits to be verified, but only the communication source is PM. For this reason, the condition i is satisfied. In this case, as shown in FIG. 11B, it is necessary to perform inter-device communication only after the rising of the clock signal. This is because, as shown in FIG. 11 (C), since the PM is the only communication source of the path that crosses between the divided circuits to be verified, the signal value of the path changes only at the rising edge of the clock.

同様に、図12(A)に示す回路分割例では、被検証分割回路間をまたぐパスの通信元にはNMしかない。このため、条件iを満たしている。この場合、図12(B)および(C)に示すように、クロック信号の立ち下げ後でしかデバイス間通信を行う必要がない。   Similarly, in the circuit division example shown in FIG. 12A, there is only NM as a communication source of a path that crosses between the divided circuits to be verified. For this reason, the condition i is satisfied. In this case, as shown in FIGS. 12B and 12C, it is only necessary to perform inter-device communication after the clock signal falls.

また、図13(A)に示す回路分割例では、被検証分割回路間をまたぐパスの通信元にはPMとNMの両方の同期素子があるが、通信先にはPMしかない。このため、条件iを満たしている。この場合、図13(B)に示すように、クロック信号の立ち下げ後でしかデバイス通信は必要ない。これは、図13(C)に示すように、通信先にはPMしかないことから、クロック信号の立ち上げでのみ同期してパスの信号値をラッチするためである。このため、クロック信号の立ち上げ前にのみデバイス通信を行えば、回路は正常動作する。   Further, in the circuit division example shown in FIG. 13A, there are both PM and NM synchronization elements at the communication source of the path crossing between the divided circuits to be verified, but only the communication destination is PM. For this reason, the condition i is satisfied. In this case, as shown in FIG. 13B, device communication is necessary only after the clock signal falls. This is because, as shown in FIG. 13C, since the communication destination has only PM, the signal value of the path is latched in synchronism only with the rise of the clock signal. For this reason, if device communication is performed only before the rise of the clock signal, the circuit operates normally.

また、図12および図13に示す回路分割例は条件iiも満たしている。これらの場合は、クロック信号の立ち上げ後にデバイス間通信を行っていないために、クロック信号の回路内での自動立ち下りの手法を使用できる。自動立ち下りとは、上位コンピュータシステム12からクロック信号の立ち上がり入力を行った後、被検証回路内でクロック信号を自動的に立ち下がらせることで、上位コンピュータシステム12からの入力回数を減らす手法である。この詳細については後述する。   The circuit division examples shown in FIGS. 12 and 13 also satisfy the condition ii. In these cases, since no inter-device communication is performed after the rising of the clock signal, a method of automatically falling the clock signal in the circuit can be used. The automatic falling is a method of reducing the number of inputs from the host computer system 12 by causing the clock signal to fall automatically in the circuit to be verified after the rising signal of the clock signal is input from the host computer system 12. is there. Details of this will be described later.

1.3)デバイス間通信のスケジューリング
次に、図6に示したステップS103におけるスケジューリング工程について詳細に説明する。
1.3) Scheduling of communication between devices Next, the scheduling process in step S103 shown in FIG. 6 will be described in detail.

スケジューリング工程では、被検証分割回路間をまたぐパスの通信とクロック入力を行う順番を、もっとも周波数の小さいクロックの1周期分だけ決定する。また、スケジューリング工程では、被検証分割回路内の貫通パスの探索を行う。貫通パスとは、被検証分割回路の入力信号と出力信号との間に同期素子が1つもないパスのことを言う。   In the scheduling step, the order of performing the communication and the clock input of the path across the divided circuit to be verified is determined for one cycle of the clock having the lowest frequency. In the scheduling step, a search is made for a through path in the divided circuit to be verified. The through path refers to a path having no synchronization element between the input signal and the output signal of the divided circuit to be verified.

図14は、デバイス間での貫通パスの一例を示す模式図である。   FIG. 14 is a schematic diagram illustrating an example of a through path between devices.

図14に示す例では、被検証分割回路103.1の入力信号S2と出力信号S3との間に同期素子を含まない貫通パスが存在し、被検証分割回路103.2の入力信号S4と出力信号S5との間に同期素子を含まない貫通パスが存在する。同期素子601と同期素子602との間には、被検証分割回路間をまたぐパスと貫通パスとを含むパスがある。このような場合は、クロック1周期のデバイス間通信において、被検証分割回路103.1,103.2間をまたぐパスのうち貫通パスに接続されているパスの優先順序が必然的に定まる。この例では、パスPはパスQよりも先に通信しなくてはならず、パスQはパスRよりも先に通信しなくてはならない。   In the example shown in FIG. 14, there is a through path that does not include a synchronizing element between the input signal S2 and the output signal S3 of the divided circuit to be verified 103.1, and the input signal S4 and the output of the divided circuit to be verified 103.2 are output. There is a through path that does not include a synchronization element between the signal S5 and the signal S5. Between the synchronization element 601 and the synchronization element 602, there is a path including a path and a through path that cross between the divided circuits to be verified. In such a case, in the communication between devices in one clock cycle, the priority order of the paths connected to the through path among the paths crossing between the divided circuits to be verified 103.1 and 103.2 is inevitably determined. In this example, path P must communicate before path Q, and path Q must communicate before path R.

デバイス間通信のスケジューリング工程は、貫通パスの優先順位を守るように行う必要がある。スケジューリング工程の理解を助けるために、図15の回路分割例を用いて説明する。   The scheduling process for inter-device communication needs to be performed so as to maintain the priority order of the through paths. In order to help understanding of the scheduling process, description will be made using the circuit division example of FIG.

図15に示す回路分割例では、クロック信号CLKと、この2倍の周波数を持つクロック信号2f_CLKを被検証分割回路内の同期素子に与えている。被検証分割回路間をまたぐパスはパスA,B,C,D,Eの5本ある。また、分割回路103.2内には、パスAとパスB間の貫通パスと、パスDとパスE間の貫通パスとがある。このため、パスAはパスBよりも先に通信する必要があり、パスDはパスEよりも先に通信する必要がある。また、被検証分割回路間をまたぐ各パスの通信元の同期素子と、通信先の同期素子の集合は、表1のようになる。   In the circuit division example shown in FIG. 15, the clock signal CLK and the clock signal 2f_CLK having twice the frequency are given to the synchronizing elements in the divided circuit to be verified. There are five paths A, B, C, D, and E that cross between the divided circuits to be verified. Further, in the dividing circuit 103.2, there are a through path between the path A and the path B and a through path between the path D and the path E. For this reason, the path A needs to communicate before the path B, and the path D needs to communicate before the path E. Table 1 shows a set of communication source synchronization elements and communication destination synchronization elements of each path that crosses the divided circuit to be verified.

Figure 2007328622
Figure 2007328622

例えば、パスAの場合は、分割回路103.1内のPMが通信元の同期素子であり、分割回路内の103.2内のNMとパスBを通過した分割回路103.1内のNMとが通信先の同期素子になる。また、パスBの場合は、パスAの通信元である分割回路103.1内のPMと分割回路103.2内のNMとが通信元の同期素子であり、分割回路103.1内のNMが通信先の同期素子になる。   For example, in the case of path A, PM in the dividing circuit 103.1 is a synchronization element of the communication source, and NM in 103.2 in the dividing circuit and NM in the dividing circuit 103.1 that has passed the path B Becomes the synchronous element of the communication destination. In the case of path B, the PM in the dividing circuit 103.1 that is the communication source of the path A and the NM in the dividing circuit 103.2 are the synchronization elements of the communication source, and the NM in the dividing circuit 103.1. Becomes the synchronous element of the communication destination.

このとき、パスAは、CLKの立ち上げに同期して信号値が変化するため、CLKの立ち上げ後にのみ通信を行う。   At this time, since the signal value of the path A changes in synchronization with the rise of CLK, communication is performed only after the rise of CLK.

パスBは、CLKの立ち下げに同期してパスBの信号値をラッチするため、やはりCLKの立ち下げ前にのみ通信を行う。   Since the path B latches the signal value of the path B in synchronization with the fall of CLK, the communication is performed only before the fall of CLK.

パスCは、CLKの立ち上げにのみ同期してパスの信号値をラッチするため、CLKの立ち上げ前にのみ通信を行う。   Since the path C latches the signal value of the path only in synchronization with the rise of CLK, communication is performed only before the rise of CLK.

パスDは、クロック信号2f_CLKに同期してパスDの信号値をラッチする通信先の同期素子があるため、クロック信号2f_CLKの立ち上げ後に通信を行うが、パスEは、CLKで同期してパスEの信号値をラッチする同期素子しかないために、CLKの立ち上げ後のみ通信を行う。   Since the path D has a communication destination synchronization element that latches the signal value of the path D in synchronization with the clock signal 2f_CLK, communication is performed after the rising of the clock signal 2f_CLK. However, the path E is synchronized with the clock CLK. Since there is only a synchronizing element that latches the signal value of E, communication is performed only after the rise of CLK.

これらの結果と貫通パスの優先順位に基づく、CLK1周期内のデバイス間通信とクロック入力のスケジュール結果は、図16のようになる。   FIG. 16 shows a schedule result of inter-device communication and clock input within the CLK1 period based on these results and the priority order of the through paths.

1.4)アドレス配置
次に、図6のステップS104におけるアドレス配置工程について詳細に説明する。
1.4) Address Placement Next, the address placement step in step S104 in FIG. 6 will be described in detail.

アドレス配置工程では、ステップS103のスケジューリング結果に基づいて、各デバイス1,2に実装する被検証分割回路103.1,103.2の入力信号input、入出力信号IN/OUT、および出力信号outputのアドレス配置を決定する。   In the address arrangement process, based on the scheduling result of step S103, the input signal input, input / output signal IN / OUT, and output signal output of the divided circuit to be verified 103.1, 103.2 mounted on each device 1, 2 are output. Determine the address arrangement.

アドレス配置を決定する際には、ステップS103のスケジューリング結果に基づき同じタイミングで通信できるパスを判定し、これらのパスを構成する、input同士やIN/OUT同士、output同士は同じアドレスに配置する。このように同じアドレスを配置することで、通信回数を減少し通信速度の高速化が可能になる。   When determining the address arrangement, paths that can be communicated at the same timing are determined based on the scheduling result in step S103, and inputs, IN / OUTs, and outputs constituting these paths are arranged at the same address. By arranging the same address in this way, the number of communications can be reduced and the communication speed can be increased.

例えば、図16に示すようなスケジュールで図17の分割回路103.1のアドレス配置を行う場合、出力信号outputAとoutputD同士や、入力信号inputBとinputE同士を同じアドレスに配置すれば、同時に通信を行うことによって、通信回数を減少できる。   For example, when the address arrangement of the dividing circuit 103.1 in FIG. 17 is performed according to the schedule shown in FIG. 16, if the output signals outputA and outputD or the input signals inputB and inputE are arranged at the same address, communication can be performed simultaneously. By doing so, the number of communications can be reduced.

1.5)クロックの自動立ち下り
上述したように、被検証分割回路間をまたぐ全てのパスに対して、通信元の同期素子がNMのみである場合、もしくは通信先の同期素子がPMのみである場合は、クロックの自動立ち下がりの手法を使用できる。
1.5) Automatic falling of clock As described above, for all paths crossing between the divided circuits to be verified, the communication source synchronization element is only NM, or the communication destination synchronization element is only PM. In some cases, an automatic clock fall technique can be used.

クロックの自動立ち下りは、バスコントローラ11からクロックを立ち上げた後、クロック制御回路201内でクロックを自動的に立ち下げることによって、クロックの立ち下げのためにバスコントローラ11から信号入力することを避ける手法である。この手法によって、信号の入力回数が減少するため、動作検証の高速化が可能になる。   In the automatic falling of the clock, after the clock is raised from the bus controller 11, the clock is automatically lowered in the clock control circuit 201 to thereby input a signal from the bus controller 11 for the clock falling. It is a technique to avoid. With this method, the number of signal inputs is reduced, so that the speed of operation verification can be increased.

クロックの自動立ち下げは、クロック制御回路201を図18に示すように構成することで可能になる。   The clock can be automatically lowered by configuring the clock control circuit 201 as shown in FIG.

図18に示すクロック制御回路201は、図3に示すクロック制御回路201に比べて、AND回路303の代わりに、WDATAも入力されるAND回路701が設けられており、また、AND回路701と同期素子301との間に、同期素子702、インバータ回路703、およびOR回路704が追加されている。   Compared with the clock control circuit 201 shown in FIG. 3, the clock control circuit 201 shown in FIG. 18 is provided with an AND circuit 701 to which WDATA is input instead of the AND circuit 303, and is synchronized with the AND circuit 701. A synchronous element 702, an inverter circuit 703, and an OR circuit 704 are added between the element 301 and the element 301.

1.6)動作検証
図19は、本発明の第1の実施形態による被検証回路の動作検証の概略的な流れを説明するフローチャートである。被検証回路は、異なる周波数を持つクロック信号として、クロック信号CLKと、CLKの2倍の周波数を持つクロック信号2f_CLKとを使用している。上述したように、第1実施形態ではバスコントローラ11だけがバスマスタになるために、各デバイス1,2の入力信号の設定や信号の読み取りなどはすべてバスコントローラ11が行う。また、ユーザによって予め指定された信号の履歴は、メモリ15に順次格納される。
1.6) Operation Verification FIG. 19 is a flowchart illustrating a schematic flow of operation verification of the circuit to be verified according to the first embodiment of the present invention. The circuit to be verified uses a clock signal CLK and a clock signal 2f_CLK having a frequency twice that of CLK as clock signals having different frequencies. As described above, since only the bus controller 11 becomes the bus master in the first embodiment, the setting of input signals and reading of signals of the devices 1 and 2 are all performed by the bus controller 11. Further, a history of signals designated in advance by the user is sequentially stored in the memory 15.

最初に、各デバイス1,2に対して電源が投入される(ステップS201)。   First, the devices 1 and 2 are powered on (step S201).

続いて、バスコントローラ11は、上位コンピュータシステム12の指令により、各デバイス1,2の通信回路102.1、102.2を通して、被検証分割回路103.1,103.2のリセット信号RSTをアクティブにすることで、リセット処理を行う(ステップS202)。さらに、初期処理としてクロックを入力する前に全てのデバイス1,2間の通信を行う(ステップS203)。   Subsequently, the bus controller 11 activates the reset signal RST of the divided circuit to be verified 103.1 and 103.2 through the communication circuits 102.1 and 102.2 of the devices 1 and 2 according to the command of the host computer system 12. By doing so, reset processing is performed (step S202). Further, communication between all the devices 1 and 2 is performed before inputting a clock as an initial process (step S203).

その後、図6に示したステップS103のスケジューリング結果に従って、クロック入力とデバイス間通信を行う(ステップS204)。クロックCLKの立ち上げは、上位コンピュータシステム12の指令により、各デバイス1,2の通信回路102.1,102.2を通して、被検証分割回路103.1,103.2のCLKをアクティブにすることで行う。クロックCLKの立ち下げは、上位コンピュータシステム12の指令により、各デバイス1,2の通信回路102.1,102.2を通して、被検証分割回路103.1,103.2のクロック信号CLKをローにすることで行う。クロック信号2f_CLKの立ち上げ、立ち下げも同様である。このクロック入力の合間にスケジュールに従ってデバイス間通信を行う。デバイス間通信は、バスコントローラ11が通信元のデバイスの出力信号を読み取り、通信先のデバイスの入力信号を設定することで行う。   Thereafter, clock input and inter-device communication are performed according to the scheduling result of step S103 shown in FIG. 6 (step S204). The clock CLK is activated by activating the CLK of the divided circuits 103.1 and 103.2 to be verified through the communication circuits 102.1 and 102.2 of the devices 1 and 2 according to a command from the host computer system 12. To do. In response to the command of the host computer system 12, the clock CLK is lowered through the communication circuits 102.1 and 102.2 of the devices 1 and 2 and the clock signal CLK of the divided circuits 103.1 and 103.2 to be verified is set to low. To do. The same applies to the rise and fall of the clock signal 2f_CLK. Inter-device communication is performed according to a schedule between these clock inputs. The inter-device communication is performed by the bus controller 11 reading the output signal of the communication source device and setting the input signal of the communication destination device.

CLK1周期分のクロック入力およびデバイス間通信を終えた後は、バスコントローラ11は、メモリ15に格納したブレーク条件に一致したか否かを判定し(ステップS205)、一致している場合は(ステップS205のYes)、状態を停止し、ユーザに次にどのような操作を行うかユーザインタフェース13を通じて指定されるまで待機する(ステップS206)。ブレーク条件に一致しない場合は(ステップS205のNo)、ステップS204へ進み、クロック入力とデバイス間通信を繰り返す。   After completing the clock input for one cycle of CLK and the inter-device communication, the bus controller 11 determines whether or not the break condition stored in the memory 15 is matched (step S205). The state is stopped, and the process waits until the user specifies what operation is to be performed next through the user interface 13 (step S206). If the break condition is not met (No in step S205), the process proceeds to step S204, and the clock input and the inter-device communication are repeated.

ステップS206において、ユーザは、ブレークの設定、ステップ命令、何サイクルまでユーザに意見を求めず動作させるか等を設定することができる。その際、メモリ15には、指定された信号の履歴が格納されているから、ユーザは表示装置14を通して指定した信号の過去の値を参照することができ、回路のデバッグ等に役立つ。   In step S206, the user can set a break, a step command, and how many cycles the user can operate without asking for opinions. At this time, since the history of the designated signal is stored in the memory 15, the user can refer to the past value of the designated signal through the display device 14, which is useful for debugging the circuit.

(第2実施形態)
第1実施形態では、2つの被検証分割回路103.1,103.2をそれぞれデバイス1,2に実装したが、本発明は2分割構成に限定されるものではない。すなわち、被検証回路は、被検証分割回路間で通信回数が最も少なくなるように、所望の数に分割することが可能である。どのような数に分割しても、各デバイスは上述した基本構成を有し、バス10により相互に接続され、全体として被検証回路の動作検証が実行される。
(Second Embodiment)
In the first embodiment, the two verified divided circuits 103.1 and 103.2 are mounted on the devices 1 and 2, respectively, but the present invention is not limited to the two-divided configuration. That is, the circuit to be verified can be divided into a desired number so that the number of times of communication is minimized between the divided circuits to be verified. Regardless of the number, each device has the above-described basic configuration and is connected to each other via the bus 10, and the operation verification of the circuit to be verified is executed as a whole.

また、第1実施形態では、2つの被検証分割回路103.1,103.2をそれぞれデバイス1,2に分割したが、本発明はこれに限定されるものではない。すなわち、複数の被検証分割回路103.1,103.2をデバイスおよび/またはシミュレータに分割し、それらをバス10によって相互接続することも可能である。以下、本発明の第2実施形態として、2つのデバイスと1つのシミュレータとをバス10で接続した回路動作検証装置について説明する。   Further, in the first embodiment, the two verification divided circuits 103.1 and 103.2 are divided into devices 1 and 2, respectively, but the present invention is not limited to this. That is, it is also possible to divide a plurality of divided circuit to be verified 103.1 and 103.2 into devices and / or simulators and interconnect them by the bus 10. Hereinafter, a circuit operation verification apparatus in which two devices and one simulator are connected by a bus 10 will be described as a second embodiment of the present invention.

図20は、本発明の第2実施形態による回路動作検証方法に使用する回路動作検証装置の概略構成を示すブロック図である。   FIG. 20 is a block diagram showing a schematic configuration of a circuit operation verification apparatus used in the circuit operation verification method according to the second embodiment of the present invention.

図20を参照すると、本実施形態においては、第1実施形態と同様に、被検証分割回路103.1,103.2がそれぞれデバイス1,2に実装され、さらに被検証回路のロジック部を実際に動作させるシミュレータ3がバス10に追加で接続されている。   Referring to FIG. 20, in this embodiment, as in the first embodiment, divided circuits 103.1 and 103.2 to be verified are mounted on devices 1 and 2, respectively, and the logic unit of the circuit to be verified is actually implemented. An additional simulator 3 is connected to the bus 10.

シミュレータ3は、バス10と通信をするためのバスインタフェース801、メモリ802、および、被検証回路のロジック部分を実際に動作させるシミュレーションエンジン803を有する。   The simulator 3 includes a bus interface 801 for communicating with the bus 10, a memory 802, and a simulation engine 803 that actually operates the logic portion of the circuit to be verified.

メモリ802は、シミュレーションエンジン803でシミュレーションされる被検証分割回路の入力信号および出力信号を一時的に保持する。   The memory 802 temporarily holds an input signal and an output signal of the verification target divided circuit simulated by the simulation engine 803.

シミュレーションエンジン803は、イベントドリブン形式であるため、入力信号が変動することによって計算が実行され、その計算結果である出力信号がメモリ802に書き込まれる。なお、本実施形態でも、バスコントローラ11が常にバスマスタとなる。   Since the simulation engine 803 is in an event driven format, the calculation is executed when the input signal fluctuates, and the output signal as the calculation result is written in the memory 802. In this embodiment as well, the bus controller 11 is always the bus master.

本実施形態でも、第1実施形態のように被検証分割回路間をまたぐパスの通信元と通信先の同期素子と貫通パスの調査を行い、この調査結果からクロック入力とデバイス間通信のスケジュールを決定する。   Also in this embodiment, as in the first embodiment, the source and destination synchronization elements of the path crossing the divided circuit to be verified and the through path are investigated, and the clock input and the inter-device communication schedule are determined based on the investigation result. decide.

また、被検証回路が複数の異なる周波数を持つクロックを使用している場合は、シミュレータ3がどのクロックに同期して動作しているかに応じて回路動作検証装置の動作が異なる。   When the circuit to be verified uses clocks having a plurality of different frequencies, the operation of the circuit operation verification device differs depending on which clock the simulator 3 is operating in synchronization with.

図21は、本発明の第2の実施形態による被検証回路の動作検証の概略的な流れを説明するフローチャートである。なお、図21では、シミュレータ3がもっとも周波数の低いクロックで同期して動作しているものとする。   FIG. 21 is a flowchart illustrating a schematic flow of operation verification of a circuit to be verified according to the second embodiment of the present invention. In FIG. 21, it is assumed that the simulator 3 operates in synchronization with the clock having the lowest frequency.

図21を参照すると、最初に、各デバイス1,2に電源が投入され(ステップS301)、図19で説明したように、被検証分割回路103.1,103.2のリセット処理を行い(ステップS302)、初期処理として全てのデバイス1,2間で通信を行う(ステップS303)。   Referring to FIG. 21, first, the devices 1 and 2 are powered on (step S301), and as described with reference to FIG. 19, reset processing is performed on the verified divided circuits 103.1 and 103.2 (steps). S302) As an initial process, communication is performed between all the devices 1 and 2 (step S303).

次に、各デバイス1,2へクロックを入力する前に、シミュレータ3からデバイス1,2への通信を行う(ステップS304)。次いで、デバイス1,2からシミュレータ3への通信を行う(ステップS305)。その後、スケジューリングしたクロック入力とデバイス間通信を、最も小さい周波数を持つクロックの1周期分行う(ステップS306)。   Next, before inputting the clock to each of the devices 1 and 2, communication from the simulator 3 to the devices 1 and 2 is performed (step S304). Next, communication from the devices 1 and 2 to the simulator 3 is performed (step S305). Thereafter, the scheduled clock input and inter-device communication are performed for one cycle of the clock having the smallest frequency (step S306).

次いで、上位コンピュータシステム12が起動時に設定したブレーク条件に一致しているか否かを判定する(ステップS307)。一致している場合は(ステップS307のYes)、状態を停止して、すでに説明したようにユーザ設定を行い(ステップS308)ステップS309へ進み、一致しない場合は(ステップS307のNo)、そのままステップS309へ進む。   Next, it is determined whether or not the host computer system 12 matches the break condition set at the time of activation (step S307). If they match (Yes in step S307), the state is stopped, the user setting is performed as described above (step S308), and the process proceeds to step S309. If they do not match (No in step S307), the process proceeds as it is. The process proceeds to S309.

次に、バスコントローラ11は、シミュレータ3のバスインタフェース801に対して1サイクル進む要求を送信し、これによって、シミュレータエンジン803におけるクロック信号を変更する(ステップS309)。シミュレータエンジン803で動作させている被検証回路のロジック部分の入力信号が変更された場合、バスインタフェース801はメモリ802に値を書き込むだけでなく、どの信号がどのように変更されたのかシミュレータエンジン803に知らせる。この入力信号変更通知に応じて、シミュレータエンジン803はその変更を反映するように計算し、回路シミュレーションを実行する。このシミュレーションの結果はメモリ802に書き込まれる。こうして、制御はステップS304へ戻り、以下、上記ステップS304〜S309を繰り返す。   Next, the bus controller 11 transmits a request to advance one cycle to the bus interface 801 of the simulator 3, thereby changing the clock signal in the simulator engine 803 (step S309). When the input signal of the logic part of the circuit to be verified that is operated by the simulator engine 803 is changed, the bus interface 801 not only writes a value to the memory 802 but also which signal is changed and how the simulator engine 803 changes. To inform. In response to this input signal change notification, the simulator engine 803 performs calculation so as to reflect the change, and executes circuit simulation. The result of this simulation is written in the memory 802. Thus, the control returns to step S304, and the above steps S304 to S309 are repeated thereafter.

(第3実施形態)
図22は、本発明の第3実施形態による回路動作検証方法に使用する回路動作検証装置の概略構成を示すブロック図である。
(Third embodiment)
FIG. 22 is a block diagram showing a schematic configuration of a circuit operation verification apparatus used in the circuit operation verification method according to the third embodiment of the present invention.

図22を参照すると、本実施形態においては、バス10にプログラム制御プロセッサ901を接続し、プログラム制御プロセッサ901がROMに格納された動作検証プログラム902を実行することで、上述したバスコントローラ11および上位コンピュータシステム12の機能を実現している。プログラム制御プロセッサ901には入力部13および出力部14が接続されている。プログラム制御プロセッサ901により実行される動作は第1および第2実施形態で説明した動作と同じであるため説明は省略する。   Referring to FIG. 22, in the present embodiment, the program control processor 901 is connected to the bus 10, and the program control processor 901 executes the operation verification program 902 stored in the ROM. The functions of the computer system 12 are realized. An input unit 13 and an output unit 14 are connected to the program control processor 901. Since the operation executed by the program control processor 901 is the same as that described in the first and second embodiments, description thereof is omitted.

(第4実施形態)
本実施形態においては、上述した第3実施形態において、検証用デバイスの代わりに、ASIC(Application Specific Integrated Circuit)等の回路を実装できるデバイスを使用し、動作検証プログラム902の代わりにファームウェアを使用する。
(Fourth embodiment)
In the present embodiment, in the third embodiment described above, a device capable of mounting a circuit such as an ASIC (Application Specific Integrated Circuit) is used instead of the verification device, and firmware is used instead of the operation verification program 902. .

(第5実施形態)
本実施形態においては、1枚の基板内で複数の回路モジュールがバスによって相互に接続され、また同基板内でバスに接続された制御プロセッサがモジュール間の通信を実行し、また各モジュールに同期クロック信号等の制御信号を入力する。
(Fifth embodiment)
In this embodiment, a plurality of circuit modules are connected to each other by a bus in a single board, and a control processor connected to the bus in the same board executes communication between the modules and is synchronized with each module. A control signal such as a clock signal is input.

本発明によれば、大規模なLSIの動作検証の高速化を図ることが可能である。また、LSIを動作させるファームウェアの動作検証の高速化にも有用である。さらに、SoC(System On a Chip)のように1枚の基板やチップ内で、回路を複数のモジュールに分割して相互通信を行う場合でも、本発明による検証の高速化は有用である。   According to the present invention, it is possible to speed up the operation verification of a large-scale LSI. It is also useful for speeding up the operation verification of firmware that operates LSI. Furthermore, even when a circuit is divided into a plurality of modules for mutual communication within a single substrate or chip as in SoC (System On a Chip), the speeding up of verification according to the present invention is useful.

本発明の第1実施形態による回路動作検証方法に使用する回路動作検証装置の概略構成を示すブロック図である。It is a block diagram which shows schematic structure of the circuit operation verification apparatus used for the circuit operation verification method by 1st Embodiment of this invention. 図1に示した検証用デバイスの構成を示すブロック図である。FIG. 2 is a block diagram illustrating a configuration of a verification device illustrated in FIG. 1. 図2に示したクロック制御回路の構成を示すブロック図である。FIG. 3 is a block diagram illustrating a configuration of a clock control circuit illustrated in FIG. 2. 図2に示したレジスタの構成を示すブロック図である。FIG. 3 is a block diagram illustrating a configuration of a register illustrated in FIG. 2. 図2に示したセレクタの構成を示すブロック図である。FIG. 3 is a block diagram illustrating a configuration of a selector illustrated in FIG. 2. 本発明の第1実施形態において、被検証回路を分割して各検証用デバイスに実装するまでの概略的な流れを説明するフローチャートである。5 is a flowchart illustrating a schematic flow from dividing a circuit to be verified to mounting on each verification device in the first embodiment of the present invention. 本発明の第1実施形態に係る、被検証分割回路間をまたぐパスの通信元・通信先の同期素子を説明する図である。It is a figure explaining the synchronous element of the communication origin and communication destination of the path | pass straddling between to-be-verified division circuits based on 1st Embodiment of this invention. 本発明の第1実施形態による回路分割方法(b)の一例を示す図であり、(A)は回路分割後の構成を示すブロック図、(B)は(A)の分割を行った場合の動作検証時の流れを説明するフローチャート、(C)は(A)の分割を行った場合の動作検証時の各部の波形を示す図である。It is a figure which shows an example of the circuit division method (b) by 1st Embodiment of this invention, (A) is a block diagram which shows the structure after circuit division, (B) is the case at the time of performing the division of (A) The flowchart explaining the flow at the time of operation | movement verification, (C) is a figure which shows the waveform of each part at the time of the operation | movement verification at the time of dividing (A). 従来の回路分割方法の一例を示す図であり、(A)は回路分割後の構成を示すブロック図、(B)は(A)の分割を行った場合の動作検証時の流れを説明するフローチャート、(C)は(A)の分割を行った場合の動作検証時の各部の波形を示す図である。It is a figure which shows an example of the conventional circuit division | segmentation method, (A) is a block diagram which shows the structure after circuit division, (B) is a flowchart explaining the flow at the time of the operation verification at the time of performing the division of (A). (C) is a figure which shows the waveform of each part at the time of the operation | movement verification at the time of dividing (A). 従来の回路分割方法の他の例を示す図であり、(A)は回路分割後の構成を示すブロック図、(B)は(A)の分割を行った場合の動作検証時の流れを説明するフローチャート、(C)は(A)の分割を行った場合の動作検証時の各部の波形を示す図である。It is a figure which shows the other example of the conventional circuit division | segmentation method, (A) is a block diagram which shows the structure after circuit division, (B) demonstrates the flow at the time of the operation | movement verification at the time of dividing (A). The flowchart which performs (C) is a figure which shows the waveform of each part at the time of operation verification at the time of performing the division | segmentation of (A). 本発明の第1実施形態による回路分割方法(c)の一例を示す図であり、(A)は回路分割後の構成を示すブロック図、(B)は(A)の分割を行った場合の動作検証時の流れを説明するフローチャート、(C)は(A)の分割を行った場合の動作検証時の各部の波形を示す図である。It is a figure which shows an example of the circuit division method (c) by 1st Embodiment of this invention, (A) is a block diagram which shows the structure after circuit division, (B) is the case at the time of performing the division of (A) The flowchart explaining the flow at the time of operation | movement verification, (C) is a figure which shows the waveform of each part at the time of the operation | movement verification at the time of dividing (A). 本発明の第1実施形態による回路分割方法(c)の他の例を示す図であり、(A)は回路分割後の構成を示すブロック図、(B)は(A)の分割を行った場合の動作検証時の流れを説明するフローチャート、(C)は(A)の分割を行った場合の動作検証時の各部の波形を示す図である。It is a figure which shows the other example of the circuit division | segmentation method (c) by 1st Embodiment of this invention, (A) is a block diagram which shows the structure after circuit division, (B) performed the division of (A) The flowchart explaining the flow at the time of the operation | movement verification in a case, (C) is a figure which shows the waveform of each part at the time of the operation verification at the time of performing the division | segmentation of (A). 本発明の第1実施形態による回路分割方法(c)のさらに他の例を示す図であり、(A)は回路分割後の構成を示すブロック図、(B)は(A)の分割を行った場合の動作検証時の流れを説明するフローチャート、(C)は(A)の分割を行った場合の動作検証時の各部の波形を示す図である。It is a figure which shows the further another example of the circuit division | segmentation method (c) by 1st Embodiment of this invention, (A) is a block diagram which shows the structure after circuit division, (B) performs the division of (A) FIG. 8C is a flowchart illustrating the flow of operation verification in the case of the operation verification, and FIG. 10C is a diagram illustrating waveforms of respective units during operation verification when the division of (A) is performed. 本発明の第1実施形態に係る貫通パスを説明する図である。It is a figure explaining the penetration path concerning a 1st embodiment of the present invention. 本発明の第1実施形態による回路分割後の回路動作検証装置の構成を示すブロック図である。It is a block diagram which shows the structure of the circuit operation verification apparatus after the circuit division by 1st Embodiment of this invention. 図15に示した回路分割後の回路動作検証装置に対して生成された、クロック入力とデバイス間通信のタイミングのスケジュールを示す図である。FIG. 16 is a diagram showing a schedule of clock input and inter-device communication timing generated for the circuit operation verification apparatus after circuit division shown in FIG. 15. 図15に示した回路分割後の回路動作検証装置の左側の被検証分割回路の入力信号inputと出力信号outputを示す図である。FIG. 16 is a diagram illustrating an input signal input and an output signal output of a divided circuit to be verified on the left side of the circuit operation verification device after circuit division shown in FIG. 15. 図3に示したクロック制御回路にクロックの自動立ち下がり機能を付加した構成を示すブロック図である。FIG. 4 is a block diagram showing a configuration in which a clock automatic falling function is added to the clock control circuit shown in FIG. 3. 本発明の第1の実施形態による被検証回路の動作検証の概略的な流れを説明するフローチャートである。3 is a flowchart illustrating a schematic flow of operation verification of a circuit to be verified according to the first embodiment of the present invention. 本発明の第2実施形態による回路動作検証方法に使用する回路動作検証装置の概略構成を示すブロック図である。It is a block diagram which shows schematic structure of the circuit operation verification apparatus used for the circuit operation verification method by 2nd Embodiment of this invention. 本発明の第2の実施形態による被検証回路の動作検証の概略的な流れを説明するフローチャートである。6 is a flowchart illustrating a schematic flow of operation verification of a circuit to be verified according to the second embodiment of the present invention. 本発明の第3実施形態による回路動作検証方法に使用する回路動作検証装置の概略構成を示すブロック図である。It is a block diagram which shows schematic structure of the circuit operation verification apparatus used for the circuit operation verification method by 3rd Embodiment of this invention.

符号の説明Explanation of symbols

1,2 検証用デバイス
3 シミュレータ
10 バス
11 バスコントローラ
12 上位コンピュータシステム
13 ユーザインタフェース
14 表示装置
15 メモリ
101 バスインタフェース
102 通信回路
103 被検証分割回路
201 クロック制御回路
202 レジスタ
203 アドレスデコーダ
204 セレクタ
301,302 同期素子
303,304 AND回路
401〜407 同期素子
501〜503 セレクタ回路
601,602 同期素子
701 AND回路
702 同期素子
703 インバータ回路
704 OR回路
801 バスインタフェース
802 メモリ
803 シミュレーションエンジン
901 プログラム制御プロセッサ
902 動作検証プログラム
DESCRIPTION OF SYMBOLS 1, 2 Device for verification 3 Simulator 10 Bus 11 Bus controller 12 Host computer system 13 User interface 14 Display device 15 Memory 101 Bus interface 102 Communication circuit 103 Verification division circuit 201 Clock control circuit 202 Register 203 Address decoder 204 Selector 301, 302 Synchronous elements 303 and 304 AND circuits 401 to 407 Synchronous elements 501 to 503 Selector circuits 601 and 602 Synchronous elements 701 AND circuit 702 Synchronous elements 703 Inverter circuit 704 OR circuit 801 Bus interface 802 Memory 803 Simulation engine 901 Program control processor 902 Operation verification program

Claims (9)

複数の被検証分割回路に分割され、当該複数の被検証分割回路間でバスを介して相互通信を行うような被検証回路の動作検証を実行する回路動作検証方法であって、
前記被検証回路内の、クロックで同期する同期素子の同期方法を調査する調査ステップと、
前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信先の同期素子が当該パスの信号値をラッチする回数が最小となるように、前記被検証回路を複数の被検証分割回路に分割する分割ステップと、
前記複数の被検証分割回路間でバスを介して相互通信を行わせて前記被検証回路の動作検証を実行する検証ステップとを有する回路動作検証方法。
A circuit operation verification method for performing operation verification of a circuit to be verified that is divided into a plurality of divided circuits to be verified and performs mutual communication via a bus between the plurality of divided circuits to be verified.
An investigation step for investigating a synchronization method of a synchronization element synchronized with a clock in the circuit to be verified;
Based on the result of the investigation in the investigation step, the circuit to be verified is divided into a plurality of circuits to be verified so that the number of times that the synchronization element of the communication destination of the path across the circuit to be verified latches the signal value of the path is minimized. A dividing step of dividing into verification dividing circuits;
A circuit operation verification method comprising: a verification step of performing an operation verification of the circuit to be verified by performing mutual communication between the plurality of circuit to be verified via a bus.
前記分割ステップの実行後で前記検証ステップの実行前に行われ、前記複数の被検証分割回路のそれぞれを分離して、FPGA、CPLD、またはASICに実装する実装ステップをさらに有する、請求項1に記載の回路動作検証方法。   2. The method according to claim 1, further comprising an implementation step that is performed after the division step and before the verification step, and each of the plurality of division circuits to be verified is separated and mounted on an FPGA, CPLD, or ASIC. The circuit operation verification method described. 前記調査ステップでは、前記被検証分割回路間をまたぐパスの通信元および通信先の同期素子のみ同期方法を調査する、請求項1または2に記載の回路動作検証方法。   3. The circuit operation verification method according to claim 1, wherein, in the checking step, a synchronization method is checked only for a communication source and a communication destination synchronization element of a path straddling the verification target divided circuits. 前記調査ステップでは、前記同期素子の同期方法として、前記被検証回路が周波数の異なる複数のクロックを使用する場合に前記同期素子がどの周波数のクロックで同期するかを調査し、
前記分割ステップでは、前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信先の全ての同期素子が、当該パスの通信元の全ての同期素子に比べて周波数の小さいクロックで同期するように、前記被検証回路を複数の被検証分割回路に分割する、請求項1から3のいずれか1項に記載の回路動作検証方法。
In the investigating step, as a synchronizing method of the synchronizing element, when the circuit to be verified uses a plurality of clocks having different frequencies, it is investigated which frequency clock the synchronizing element synchronizes with,
In the division step, based on the investigation result in the investigation step, all the synchronization elements of the communication destination of the path crossing between the division circuits to be verified have a lower frequency than all of the synchronization elements of the communication source of the path. The circuit operation verification method according to any one of claims 1 to 3, wherein the circuit to be verified is divided into a plurality of divided circuits to be verified so as to be synchronized with a clock.
前記調査ステップでは、前記同期素子の同期方法として、前記同期素子がクロックの立ち上がりまたは立ち下がりのどちらで同期するのかを調査し、
前記分割ステップでは、前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信元の全ての同期素子がクロックの立ち上がりもしくは立ち下がりでのみ同期するか、または、当該パスの通信先の全ての同期素子がクロックの立ち上がりもしくは立ち下がりでのみ同期するように、前記被検証回路を複数の被検証分割回路に分割する、請求項1から3のいずれか1項に記載の回路動作検証方法。
In the investigation step, as a synchronization method of the synchronization element, investigate whether the synchronization element is synchronized at the rising edge or falling edge of the clock,
In the division step, based on the investigation result in the investigation step, all the synchronization elements of the communication sources of the paths crossing the division circuits to be verified are synchronized only at the rising edge or falling edge of the clock, or The circuit according to any one of claims 1 to 3, wherein the circuit to be verified is divided into a plurality of divided circuits to be verified so that all the synchronization elements at the communication destination are synchronized only at the rising or falling edge of the clock. Operation verification method.
前記調査ステップでは、前記同期素子の同期方法として、前記同期素子がクロックの立ち上がりまたは立ち下がりのどちらで同期するのかを調査し、
前記分割ステップでは、前記調査ステップによる調査結果に基づいて、前記被検証分割回路間をまたぐパスの通信元の全ての同期素子がクロックの立ち下がりでのみ同期するか、または、当該パスの通信先の全ての同期素子がクロックの立ち上がりでのみ同期するように、前記被検証回路を複数の被検証分割回路に分割する、請求項1から3のいずれか1項に記載の回路動作検証方法。
In the investigation step, as a synchronization method of the synchronization element, investigate whether the synchronization element is synchronized at the rising edge or falling edge of the clock,
In the division step, based on the investigation result in the investigation step, all the synchronization elements of the communication source of the path crossing between the divided circuits to be verified are synchronized only at the falling edge of the clock, or the communication destination of the path 4. The circuit operation verification method according to claim 1, wherein the circuit to be verified is divided into a plurality of divided circuits to be verified so that all of the synchronization elements are synchronized only at the rising edge of the clock. 5.
前記検証ステップでは、クロックの立ち上がり後に、前記被検証分割回路でクロックを自動的に立ち下げる、請求項6に記載の回路動作検証方法。   The circuit operation verification method according to claim 6, wherein, in the verification step, the clock is automatically decreased by the divided circuit to be verified after the clock rises. 前記調査ステップでは、前記同期素子の同期方法として、前記被検証回路が周波数の異なる複数のクロックを使用する場合は前記同期素子がどの周波数のクロックで同期するかを調査するとともに、前記同期素子がクロックの立ち上がりまたは立ち下がりのどちらで同期するのかを調査し、
前記分割ステップの実行後で前記検証ステップの実行前に行われる、
前記被検証分割回路の入力信号と出力信号との間に同期素子が1つもない貫通パスを探索する探索ステップと、
前記探索ステップによる探索結果に基づいて、前記被検証分割回路間をまたぐパスのうち前記貫通パスに接続するパスの通信の優先順序を決定する優先順位決定ステップと、
前記調査ステップによる調査結果および前記優先順位決定ステップによる優先順位に基づいて、前記被検証分割回路をまたぐ各パスの通信を、どのクロックの立ち上がり後または立ち下がり後に行うかを決定するスケジューリングステップとをさらに有する、請求項1から3のいずれか1項に記載の回路動作検証方法。
In the investigating step, as a synchronizing method of the synchronizing element, when the circuit to be verified uses a plurality of clocks having different frequencies, the synchronizing element investigates which frequency clock the synchronizing element synchronizes with. Investigate whether to synchronize at the rising edge or falling edge of the clock,
Performed after execution of the splitting step and before execution of the verification step;
A search step of searching for a through path having no synchronization element between an input signal and an output signal of the division circuit to be verified;
A priority order determining step for determining a communication priority order of a path connected to the through-passage among paths crossing between the divided circuit to be verified based on a search result by the search step;
A scheduling step for determining which clock is to be communicated after the rising edge or the falling edge thereof, based on the investigation result of the investigation step and the priority order of the priority order determination step; The circuit operation verification method according to claim 1, further comprising:
前記スケジューリングステップの実行後で前記検証ステップの実行前に行われ、前記スケジューリングステップによるスケジューリング結果に基づいて、各被検証分割回路で同じタイミングで入力・出力できるパスを構成する信号を、バスアドレス空間の同じアドレスに配置するアドレス配置ステップをさらに有する、請求項8に記載の回路動作検証方法。   A signal that forms a path that can be input and output at the same timing in each divided circuit to be verified, based on the scheduling result of the scheduling step, after the scheduling step and before the verification step is executed. The circuit operation verification method according to claim 8, further comprising an address arrangement step of arranging at the same address.
JP2006160093A 2006-06-08 2006-06-08 Circuit operation verification method Expired - Fee Related JP4743427B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2006160093A JP4743427B2 (en) 2006-06-08 2006-06-08 Circuit operation verification method

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2006160093A JP4743427B2 (en) 2006-06-08 2006-06-08 Circuit operation verification method

Publications (2)

Publication Number Publication Date
JP2007328622A true JP2007328622A (en) 2007-12-20
JP4743427B2 JP4743427B2 (en) 2011-08-10

Family

ID=38929038

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2006160093A Expired - Fee Related JP4743427B2 (en) 2006-06-08 2006-06-08 Circuit operation verification method

Country Status (1)

Country Link
JP (1) JP4743427B2 (en)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005063002A (en) * 2003-08-08 2005-03-10 Matsushita Electric Ind Co Ltd Parallel simulation device and method
JP2005084957A (en) * 2003-09-09 2005-03-31 Nec Corp Circuit operation verification device and method
JP2005332162A (en) * 2004-05-19 2005-12-02 Nec Corp Hardware/software cooperation simulation system, and its method

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005063002A (en) * 2003-08-08 2005-03-10 Matsushita Electric Ind Co Ltd Parallel simulation device and method
JP2005084957A (en) * 2003-09-09 2005-03-31 Nec Corp Circuit operation verification device and method
JP2005332162A (en) * 2004-05-19 2005-12-02 Nec Corp Hardware/software cooperation simulation system, and its method

Also Published As

Publication number Publication date
JP4743427B2 (en) 2011-08-10

Similar Documents

Publication Publication Date Title
JP3131177B2 (en) Method and apparatus for design verification using emulation and simulation
JP4599266B2 (en) Simulation apparatus and simulation method
US10635843B2 (en) Simulation modeling frameworks for controller designs
JP2009517764A (en) Merge timing constraints in hierarchical SOC design
EP2098969A1 (en) Logic circuit designing device for asynchronous logic circuit, logic circuit designing method, and logic circuit designing program
US7966590B2 (en) Circuit design data conversion apparatus, circuit design data conversion method, and computer product
US7228513B2 (en) Circuit operation verification device and method
US8074192B2 (en) Verification support apparatus, verification support method, and computer product
JP4743427B2 (en) Circuit operation verification method
US7676685B2 (en) Method for improving the data transfer in semi synchronous clock domains integrated circuits at any possible m/n clock ratio
JP2005084956A (en) Verification method and system for logic circuit
US7797653B2 (en) Circuit verification apparatus, circuit verification method, and signal distribution method for the same
JP2010140255A (en) Reconfigurable logic circuit, verification method and verification program
JPH1126591A (en) Function block, semiconductor integrated circuit device, and simulation method of integrated circuit
JP5057509B2 (en) Behavioral synthesis apparatus, behavioral synthesis method, semiconductor integrated circuit manufacturing method, behavioral synthesis program, and readable storage medium
US9355198B1 (en) Method and apparatus for performing late binding of control status registers in a design compilation flow
US20240134718A1 (en) Apparatus and method for synchronizing participants of a simulation
JP2006079369A (en) Simulation apparatus, and method for generating history of the same
JP5492704B2 (en) Hardware-software co-verification system, method, and program
JP4645843B2 (en) Data processing apparatus, data processing method and program
JP6761182B2 (en) Information processing equipment, information processing methods and programs
JP2007179172A (en) Logic circuit verification system and its control method
JP2000208632A (en) Design method for semiconductor integrated circuit
JP2007026030A (en) Logic synthesis method and apparatus
JP2006018429A (en) Functional verification system, test bench, simulator program and storage medium

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20090519

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20101224

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20110112

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20110216

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

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

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

Free format text: PAYMENT UNTIL: 20140520

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4743427

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