[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

JP4082568B2 - Integrated circuit design support apparatus and method, and program thereof - Google Patents

Integrated circuit design support apparatus and method, and program thereof Download PDF

Info

Publication number
JP4082568B2
JP4082568B2 JP2002082446A JP2002082446A JP4082568B2 JP 4082568 B2 JP4082568 B2 JP 4082568B2 JP 2002082446 A JP2002082446 A JP 2002082446A JP 2002082446 A JP2002082446 A JP 2002082446A JP 4082568 B2 JP4082568 B2 JP 4082568B2
Authority
JP
Japan
Prior art keywords
logic
condition
api
signal
circuit
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2002082446A
Other languages
Japanese (ja)
Other versions
JP2003281216A (en
Inventor
泰隆 塚本
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Ricoh Co Ltd
Original Assignee
Ricoh Co Ltd
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 Ricoh Co Ltd filed Critical Ricoh Co Ltd
Priority to JP2002082446A priority Critical patent/JP4082568B2/en
Publication of JP2003281216A publication Critical patent/JP2003281216A/en
Application granted granted Critical
Publication of JP4082568B2 publication Critical patent/JP4082568B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Landscapes

  • Design And Manufacture Of Integrated Circuits (AREA)

Description

【0001】
【発明の属する技術分野】
本発明は、コンピュータを利用したLSI等の集積回路の設計を支援する技術に関し、特に集積回路に対応する回路記述データに基づき、集積回路の動作検証以外の項目を検証する技術に関する。
【0002】
【従来の技術】
現在、LSIをはじめとする半導体デバイスの回路設計の主流は、回路の動作を、HDL(Hardware Description Language:ハードウエア記述言語)によりRTL(Register Transfer Level:レジスタ転送レベル)で記述し、それを論理合成技術によりゲートレベルのネットリストに変換する方法を採っている。図6にRTL記述例を示す。これは、図5の論理回路に対応するRTL記述例である。論理合成実施後、ゲートレベルのネットリストに対して各種設計ルールを満足しているか否かを検証する。
【0003】
設計ルールの例としてはテスト容易化設計ルールがある。このルールは例えば、「外部入力クロック信号を使って、各フリップ・フロップのクロック端子を制御できる必要がある」などである。このクロック制御に関するルールについて図5を使って説明する。図5において、a、b、ckは外部信号であり、このうち、ckがクロックである。図5の回路の場合、フリップフロップ(FF)のクロック信号はcknetであるが、このcknetは外部入力クロックckにより制御することはできない。ここでいう制御とは、ckの論理値が1の場合は、cknetは必ず1になり、ckの論理値が0の場合は、cknetは必ず0になることをいう。しかし、図5では、外部入力bが0の場合、ckの論理値に関係なく、cknetは0となる。したがって、図5の回路は上述のクロック制御ルールを満足していない。一方、外部入力bを1に固定した状況ではこのルールを満たす。
【0004】
ゲートレベルにおいて各種設計ルールをチェックする場合、ルール違反が発見されると、RTLデータを修正し、再び論理合成を実施することになる。これではLSI設計にかかる期間を増大させるため、できればRTLデータに対して直接各種設計ルールをチェックしたいところである。しかし、RTLデータに対して設計ルールチェックを実施する装置を一から開発するのは非常に手間がかかり、その実現が困難な状況にある。
【0005】
【発明が解決しようとする課題】
本発明は、上述の事情に鑑みなされたもので、その目的は、既存の論理シミュレータおよび論理シミュレータにあらかじめ用意されているAPI(Application Procedure Interface)を利用し、RTLデータに基づき、集積回路の動作検証以外の項目を検証する装置及び方法を実現することにある。詳しくは、既存の論理シュミレータおよび論理シュミレータにあらかじめ用意されているAPIを利用し、RTLデータに対して、条件漏れチェックを実施する装置及び方法を実現することにある。
【0006】
【課題を解決するための手段】
本発明は、論理シミュレーション機能と、該論理シミュレーション機能に対する論理値の設定や参照、回路記述データの構文解析木情報の参照を可能とするAPIを含む論理シミュレータを利用して、集積回路に対応する回路記述データに基づき、該集積回路の動作検証以外の項目を検証することを特徴とする。
【0007】
具体的には、を回路記述データから条件記述部前記APIを使って抽出する手段と前記抽出された条件記述部の各条件信号に対して、すべての論理値の組み合わせを前記APIにより設定し、該論理値の組み合わせに対して、シミュレーション機能により論理シミュレーションを実施せしめる手段、前記条件記述部において代入先となっている信号の論理値を前記APIにより読み出し、該読み出された論理値から、条件記述部に条件漏れがあるか否か判定する手段等により、条件漏れチェックを実施する。
【0008】
【発明の実施の形態】
以下、本発明の実施の形態について図面を用いて説明する。
図1は本発明にかかる集積回路設計支援装置の第1の実施例を示す構成図で、論理シミュレータ及びそれにあらかじめ用意されているAPIを利用して、HDL記述のRTLデータに対し、テスト容易化設計ルールチェックを実施する場合の構成例を示したものである。図1において、110は回路記述データファイル、120は信号制約ファイル、130は信号制約ファイル読込み部、140は論理シミュレータ、150はフリップ・フロップ情報ファイル、160はテスト容易化設計ルール判定部を示している。
【0009】
回路記述データファイル110には、設計対象の集積回路に対応する回路記述データであるHDL記述のRTLデータが保持されている。HDLのフォーマットとしては、例えば、IEEE標準1304−1995であるVerilog−HDLなどが挙げられる。信号制約ファイル120には、チェック対象ルールとともに、設計ルールチェックを行う際に固定すべき信号とその論理等が記述されている。また、外部入部クロック信号名も記述されている。
【0010】
論理シミュレータ140は、論理シミュレーション部141とAPI部142で構成される。ここで、API部142はC言語等のプログラミング言語で記述された関数として論理シミュレータ140の中に通常組み込まれているものである。この組み込まれた関数を使って、次のようなことが可能となっている。
(1) 論理シミュレーション部中で任意の信号に論理値を設定する。
(2) 論理シミュレーション部から任意の信号の論理値を参照する。
(3) HDL記述データの構文解析木情報を参照する。
【0011】
APIの例としては、Verilog−HDLのAPIであるVPI(Verilog Procedure Interface)などが挙げられる。
【0012】
本来、論理シミュレータ140は、回路が正しく動作するかどうかを検証するために用いられてきた。本実施例は、この論理シミュレータ140及びそれにあらかじめ組み込まれているAPI部142を利用して、HDL記述のRTLデータに対し、テスト容易化設計ルールチェックを実施するものである。図2に、クロック・ルール・チェックの処理手順を示す。以下、図2にもとづいて、図1の実施例の動作を具体的に説明する。
【0013】
まず、論理シミュレーション部141では、回路記述データファイル110から回路記述データとしてHDL記述のRTLデータを読み込む(S201)。次に、信号制約ファイル読込み部130では、信号制約ファイル120の信号制約情報を読み、論理シミュレータ140のAPI部142に渡す(S202)。先にも述べたように、信号制約ファイル120には、設計ルールチェックを行う際に固定すべき信号とその論理値等が記述されている。また、外部入力クロック信号名も記述されている。ここでは、図5の回路において、外部信号bが固定信号で、固定値は1であり、また、外部クロック信号はckであるとする。
【0014】
論理シミュレータ140のAPI部142では、論理シミュレーション部141に読み込まれたRTLデータに対し、信号制約ファイル120の信号制約情報中の信号に論理値を設定する(S203)。さらに、外部クロック信号に、まず、論理値0を設定する(S204)。このステップS203、S204により、図5の回路では、外部信号bの論理値は0に固定され、外部クロック信号ckは、論理値1に設定される。
【0015】
論理シミュレーション部141では、回路記述データファイル110から読み込まれたRTLデータにより、API部142によって設定された条件のもとに、論理シミュレーションを実行する(S205)。論理シミュレーションの実行後、API部142では、フリップ・フロップ情報を読み出し、フリップ・フロップ情報ファイル150に出力する(S206)。フリップフロップ名はRTLデータから抽出することができる。フリップフロップ情報には、各フリップフロップの名前、そのクロック端子の論理値等が含まれる。ここでは、それに外部クロック信号の論理値も付加する。これにより、図5の回路では、フリップ・フロップFFのクロック信号cknetと人力クロック信号の論理値がともに0の情報がフリップ・フロップ情報ファイル150に出力される。
【0016】
テスト容易化設計ルール判定部160では、フリップフロップ情報ファイル150を参照して、API部142により検出されたフリップ・フロップのクロック端子が論理シミュレーション後にどのような論理になっているか調べる(S207)。ここで、外部入力クロック信号の論理値と、フリップ・フロップのクロック端子の論理値が同じであれば設計ルールを満たしていると判定する。図5の回路では、ck=0、cknet=0が判定される。
【0017】
次に、API部142では、外部クロックを論理値1に設定する(S208)。これにより、図5の回路では、外部クロック信号ckの論理値が0から1に変更される。外部入力信号bは1に固定のままである。
【0018】
論理シミュレーション部141では、API部142によって設定された条件のもとに、再び論理シミュレーションを実行し(S209)、論理シミュレーション実行後、SPI部142では、再びフリップ・フロップの情報をフリップ・フロップ情報ファイル150に読み出す(S210)。そして、テスト容易化設計ルール判定部160では、再びフリップロップ情報ファイル150を参照して、フリップフロップのクロツク端子の論理値をチェックする(S211)。この結果、図5の回路では、ck=1、cknet=1が判定される。
【0019】
なお、図2の処理手順において、ステップ206の後、ステップS208〜210を実行し、外部クロックの論理値が0と1の場合のそれぞれの論理シミュレーション実行後、テスト容易化設計ルール設定部160において、ステップS207とS211のルール判定チェックをまとめて実施することでもよい。
【0020】
図3は本発明にかかる集積回路設計支援装置の第2の実施例を示す構成図で、論理シミュレータ及びそれにあらかじめ用意されているAPIを利用して、HDL記述のRTLデータについて、条件漏れチェックを実施する場合の構成例を示したものである。図3において、310は回路記述データファイル、320は論理シミュレータ、330は条件記述情報ファイル、340は論理値設定部、350は代入先信号チェック部を示している。
【0021】
回路記述データファイル310には、図1の回路記述データファイル110と同様に、設計対象の集積回路に対応する回路記述データであるHDL記述のRTLデータが保持されている。先にも述べたように、HDLのフォーマットとしては、例えば、IEEE標準1364−1995であるVerilog−HDLなどが挙げられる。
【0022】
論理回路シミュレータ320は、論理シミュレーション部321とAPI部322で構成される。API部322は、先にも述べたように、C言語等のプログラミング言語で記述された関数として論理シミュレータ320の中に通常組み込まれているものであり、この関数を使って、論理シミュレーション部中の任意の信号に対する論理値の設定や参照、さらには、HDL記述データの構文解析木情報の参照などを可能にするものである。
本実施例は、この論理シミュレータ320及びそれにあらかじめ組み込まれているAPI部322を利用して、回路記述データに対し、条件漏れチェックを実施するものである。図4に、条件漏れチェックの処理手順を示す。以下、図4にもとづいて、図3の実施例の動作を具体的に説明する。
【0023】
ます、論理シミュレーション部321では、回路記述データファイル310から回路記述データとしてHDL記述のRTLデータを読み込む(S401)。API部322では、このHDL記述のRTLデータ中におけるif文などの条件記述部分から条件記述情報を抽出し、条件記述情報ファイル330に出力する(S402)。
【0024】
図7にif文の例を示す。以降、この図7のif文を例にとり説明する。ここで、条件記述情報とは、以下のような情報である。
(1) 条件記述信号はa,bである。
(2) 代入先信号はq1である。
【0025】
論理値設定部340では、条件記述情報ファイル330を参照して、まず、信号c,d,eを選択し、API部322を使って、論理シミュレーション部321中の当該信号c,d,eを論理値0あるいは1で初期化する(S403)。次に、論理値設定部340では、同様にAPI部322を使って、論理シミュレーション部321の代入先信号q1を論理値Xで初期化した後(S404)、条件記述信号a,bについて、そのすべての論理値の組み合わせを一つずつ選択し、API部322により、論理シミュレーション部321中の該当信号a,bに該論理値を設定し(S405)、シミュレーション部321で論理シミュレーションを実施する(S406)。
【0026】
ここで、条件記述信号a,bの取り得る論理値の組み合わせは、(a,b)=(0,0),(0,1),(1,0),(1,1)の4通りである。論理値設定部340では、4つの組み合わせのうちの1つ、例えば(0,0)を選択し、API部322を使って論理シミュレーション部321の該当信号に論理値を設定する。そして、シミュレーション部321において、論理シミュレーションを実施する。ただし論理値設定部340では該当信号に論理値を代入する前に、代入先信号q1を論理値Xで、その他の信号c、d、eは0あるいは1で必ず初期化する。
【0027】
論理シミュレーション後、代入先信号チェック部350では、API部320を使って信号q1の論理値を取り込み、条件記述情報ファイル330の信号q1を参照して、該信号q1の論理値がXから他の値に変化しているかどうかを調べ(S407)、Xのまま(初期値のまま)であれば、条件漏れがありと判定する(S410)。
【0028】
上記ステップS404〜S405の処理を、(a,b)=(0,0),(0,1),(1,0),(1,1)の4通りすべてに対して繰り返し(S408)、いずれも信号q1の論理値がXから変化していれば、代入先信号チェック部350では、条件漏れなしと判定する(S409)。
【0029】
図7のif文の例では、(a,b)=(0,0)の場合は、700の文が実行され、q1の論理値は1または0になる。また(a,b)=(1,0)の場合は、図7中のどの文も実行されることはなく、q1の値はXのままとなる。代入先信号チェック部350にて、q1の論理値がXであることが確認されると、条件漏れを検出したことになる。
【0030】
なお、図1及び図3で示した装置における各部の一部もしくは全部の処理機能をコンピュータのプログラムで構成し、そのプログラムをコンピュータを用いて実行して本発明を実現することができること、あるいは、図2及び図4で示した処理手順をコンピュータのプログラムで構成し、そのプログラムをコンピュータに実行させることができることは言うまでもない。また、コンピュータでその処理機能を実現するためのプログラム、あるいは、コンピュータにその処理手順を実行させるためのプログラムを、そのコンピュータが読み取り可能な記録媒体、例えば、FDや、MO、ROM、メモリカード、CD、DVD、リムーバブルディスクなどに記録して、保存したり、提供したりすることができるとともに、インターネット等のネットワークを通してそのプログラムを配布したりすることが可能である。
【0031】
【発明の効果】
本発明によれば、HDL記述のRTLデータの構文解析および論理値の伝播を論理シミュレータに実施させ、RTLデータの構文解析情報の取得や論理値の設定および観測を、論理シミュレータに組み込まれているAPIにより行い、if文中の条件漏れを検出するので、一から開発する場合に比べ容易に条件漏れチェック・システムを構築することができる。
【図面の簡単な説明】
【図1】 本発明の第1の実施例の構成図である。
【図2】 図1の第1の実施例の動作を説明するための処理フロー図である。
【図3】 本発明の第2の実施例の構成図である。
【図4】 図3の第2の実施例の動作を説明するための処理フロー図である。
【図5】 論理回路の一例を示す図である。
【図6】 図5に対するRTL記述例を示す図である。
【図7】 RTLデータのif文の例を示す図である。
【符号の説明】
110 回路記述データファイル
120 信号制約ファイル
130 信号制約ファイル読み込み部
140 論理シミュレータ
150 フリップ・フロップ情報ファイル
160 テスト容易化設計ルール判定部
310 回路記述データファイル
320 論理シミュレータ
330 条件記述情報ファイル
340 論理値設定部
350 代入先信号チェック部
[0001]
BACKGROUND OF THE INVENTION
The present invention relates to a technology for supporting the design of an integrated circuit such as an LSI using a computer, and more particularly to a technology for verifying items other than the operation verification of an integrated circuit based on circuit description data corresponding to the integrated circuit.
[0002]
[Prior art]
Currently, the mainstream of circuit design for LSI and other semiconductor devices is to describe the operation of the circuit in RTL (Register Transfer Level) using HDL (Hardware Description Language) and logically describe it. A method of converting to a net list at the gate level by a synthesis technique is adopted. FIG. 6 shows an RTL description example. This is an RTL description example corresponding to the logic circuit of FIG. After performing the logic synthesis, it is verified whether various design rules are satisfied for the gate level netlist.
[0003]
An example of a design rule is a testability design rule. This rule is, for example, “It is necessary to be able to control the clock terminal of each flip-flop using an external input clock signal”. The rules regarding the clock control will be described with reference to FIG. In FIG. 5, a, b, and ck are external signals, and of these, ck is a clock. In the case of the circuit of FIG. 5, the clock signal of the flip-flop (FF) is cknet, but this cknet cannot be controlled by the external input clock ck. Control here means that cknet is always 1 when the logical value of ck is 1, and cknet is always 0 when the logical value of ck is 0. However, in FIG. 5, when the external input b is 0, cknet is 0 regardless of the logical value of ck. Therefore, the circuit of FIG. 5 does not satisfy the above clock control rule. On the other hand, this rule is satisfied when the external input b is fixed to 1.
[0004]
When checking various design rules at the gate level, if a rule violation is found, the RTL data is corrected and logic synthesis is performed again. Since this increases the period of LSI design, it is desirable to check various design rules directly against RTL data if possible. However, developing a device for performing design rule check on RTL data from scratch is very laborious and difficult to implement.
[0005]
[Problems to be solved by the invention]
The present invention has been made in view of the above circumstances, and its purpose is to use an existing logic simulator and an API (Application Procedure Interface) prepared in advance in the logic simulator, and to operate an integrated circuit based on RTL data. An object is to realize an apparatus and a method for verifying items other than verification. More specifically, an existing logic simulator and an API prepared in advance for the logic simulator are used to realize an apparatus and method for performing a condition leak check on RTL data.
[0006]
[Means for Solving the Problems]
The present invention supports an integrated circuit by using a logic simulator including a logic simulation function and an API that enables setting and referencing of a logic value for the logic simulation function and referencing of parse tree information of circuit description data. Items other than the operation verification of the integrated circuit are verified based on the circuit description data.
[0007]
Against Specifically, each condition signal means and the extracted condition description section for extracting with a condition description section the API from the circuit description data, all the combinations of logic values set by the API, for the combination of the logic values, means allowed to implement the logic simulation by a simulation function, the logic value of the signal that is the assignment target in the condition description section reads, from the read logical values by the API, condition A condition leak check is performed by means for determining whether there is a condition leak in the description part.
[0008]
DETAILED DESCRIPTION OF THE INVENTION
Hereinafter, embodiments of the present invention will be described with reference to the drawings.
FIG. 1 is a block diagram showing a first embodiment of an integrated circuit design support apparatus according to the present invention, which makes it easy to test RTL data in HDL description using a logic simulator and an API prepared beforehand. The example of a structure in the case of implementing a design rule check is shown. In FIG. 1, 110 is a circuit description data file, 120 is a signal constraint file, 130 is a signal constraint file reading unit, 140 is a logic simulator, 150 is a flip-flop information file, and 160 is a testability design rule determination unit. Yes.
[0009]
The circuit description data file 110 holds HDL description RTL data that is circuit description data corresponding to the integrated circuit to be designed. Examples of the HDL format include Verilog-HDL, which is an IEEE standard 1304-1995. In the signal constraint file 120, a signal to be fixed when performing a design rule check, its logic, and the like are described together with a rule to be checked. The external input clock signal name is also described.
[0010]
The logic simulator 140 includes a logic simulation unit 141 and an API unit 142. Here, the API unit 142 is normally incorporated in the logic simulator 140 as a function described in a programming language such as C language. Using this built-in function, you can:
(1) A logic value is set for an arbitrary signal in the logic simulation section.
(2) Refer to the logic value of an arbitrary signal from the logic simulation unit.
(3) Refer to the parse tree information of the HDL description data.
[0011]
Examples of APIs include VPI (Verilog Procedure Interface) which is an API of Verilog-HDL.
[0012]
Originally, the logic simulator 140 has been used to verify whether a circuit operates correctly. In this embodiment, a testability design rule check is performed on RTL data in an HDL description using the logic simulator 140 and an API unit 142 incorporated in advance. FIG. 2 shows a processing procedure of the clock rule check. The operation of the embodiment shown in FIG. 1 will be specifically described below with reference to FIG.
[0013]
First, the logic simulation unit 141 reads RTL data in HDL description as circuit description data from the circuit description data file 110 (S201). Next, the signal constraint file reading unit 130 reads the signal constraint information of the signal constraint file 120 and passes it to the API unit 142 of the logic simulator 140 (S202). As described above, the signal constraint file 120 describes a signal to be fixed when performing a design rule check, its logical value, and the like. The external input clock signal name is also described. Here, in the circuit of FIG. 5, it is assumed that the external signal b is a fixed signal, the fixed value is 1, and the external clock signal is ck.
[0014]
The API unit 142 of the logic simulator 140 sets a logical value for the signal in the signal constraint information of the signal constraint file 120 for the RTL data read by the logic simulation unit 141 (S203). Further, first, a logical value 0 is set in the external clock signal (S204). Through the steps S203 and S204, in the circuit of FIG. 5, the logical value of the external signal b is fixed to 0, and the external clock signal ck is set to the logical value 1 .
[0015]
The logic simulation unit 141 executes logic simulation based on the RTL data read from the circuit description data file 110 under the conditions set by the API unit 142 (S205). After executing the logic simulation, the API unit 142 reads the flip-flop information and outputs it to the flip-flop information file 150 (S206). The flip-flop name can be extracted from the RTL data. The flip-flop information includes the name of each flip-flop, the logical value of the clock terminal, and the like. Here, the logical value of the external clock signal is also added thereto. As a result, in the circuit of FIG. 5, information in which the logic values of the clock signal cknet of the flip-flop FF and the human-powered clock signal are both 0 is output to the flip-flop information file 150.
[0016]
The testability design rule determination unit 160 refers to the flip-flop information file 150 and checks what kind of logic the clock terminal of the flip-flop detected by the API unit 142 is after logic simulation (S207). Here, if the logical value of the external input clock signal is the same as the logical value of the clock terminal of the flip-flop, it is determined that the design rule is satisfied. In the circuit of FIG. 5, ck = 0 and cknet = 0 are determined.
[0017]
Next, the API unit 142 sets the external clock to a logical value 1 (S208). Thereby, in the circuit of FIG. 5, the logical value of the external clock signal ck is changed from 0 to 1. The external input signal b remains fixed at 1.
[0018]
The logic simulation unit 141 executes the logic simulation again under the conditions set by the API unit 142 (S209). After executing the logic simulation, the SPI unit 142 again converts the flip-flop information into the flip-flop information. Read to file 150 (S210). Then, the testability design rule determination unit 160 refers to the flip-flop information file 150 again and checks the logical value of the clock terminal of the flip-flop (S211). As a result, in the circuit of FIG. 5, ck = 1 and cknet = 1 are determined.
[0019]
In the processing procedure of FIG. 2, after step 206, steps S208 to S210 are executed, and after each logical simulation is executed when the logical value of the external clock is 0 and 1, in the testability design rule setting unit 160 The rule determination checks in steps S207 and S211 may be performed together.
[0020]
FIG. 3 is a block diagram showing a second embodiment of the integrated circuit design support apparatus according to the present invention. Using a logic simulator and an API prepared in advance, a condition leak check is performed on RTL data in HDL description. The example of a structure in the case of implementing is shown. 3, 310 is a circuit description data file, 320 is a logic simulator, 330 is a condition description information file, 340 is a logic value setting unit, and 350 is an assignment destination signal check unit.
[0021]
Similar to the circuit description data file 110 of FIG. 1, the circuit description data file 310 holds RTL data of HDL description that is circuit description data corresponding to the integrated circuit to be designed. As described above, as an HDL format, for example, Verilog-HDL, which is an IEEE standard 1364-1995, can be cited.
[0022]
The logic circuit simulator 320 includes a logic simulation unit 321 and an API unit 322. As described above, the API unit 322 is normally incorporated in the logic simulator 320 as a function described in a programming language such as C language, and is used in the logic simulation unit. It is possible to set and refer to a logical value for an arbitrary signal, and to reference parse tree information of HDL description data.
In this embodiment, a condition omission check is performed on circuit description data by using the logic simulator 320 and an API unit 322 incorporated in advance. FIG. 4 shows a procedure for condition leak check. The operation of the embodiment of FIG. 3 will be specifically described below with reference to FIG.
[0023]
First, the logic simulation unit 321 reads RTL data in HDL description as circuit description data from the circuit description data file 310 (S401). The API unit 322 extracts condition description information from a condition description portion such as an if statement in the RTL data of the HDL description, and outputs it to the condition description information file 330 (S402).
[0024]
FIG. 7 shows an example of an if statement. Hereinafter, description will be made by taking the if sentence of FIG. 7 as an example. Here, the condition description information is the following information.
(1) The condition description signals are a and b.
(2) The substitution destination signal is q1.
[0025]
In the logical value setting unit 340, referring to the condition description information file 330, first, signals c, d, e are selected, and the API unit 322 is used to select the signals c, d, e in the logic simulation unit 321. It is initialized with a logical value 0 or 1 (S403). Next, the logical value setting unit 340 similarly uses the API unit 322 to initialize the substitution destination signal q1 of the logical simulation unit 321 with the logical value X (S404), A combination of all logical values is selected one by one, and the logical value is set to the corresponding signals a and b in the logical simulation unit 321 by the API unit 322 (S405), and the logical simulation is performed by the simulation unit 321 ( S406).
[0026]
Here, there are four possible combinations of logical values of the condition description signals a and b: (a, b) = (0, 0), (0, 1), (1, 0), (1, 1). It is. The logic value setting unit 340 selects one of the four combinations, for example, (0, 0), and sets a logic value for the corresponding signal of the logic simulation unit 321 using the API unit 322. Then, the simulation unit 321 performs logic simulation. However, before assigning a logical value to the corresponding signal, the logical value setting unit 340 always initializes the assignment destination signal q1 with the logical value X and the other signals c, d, and e with 0 or 1.
[0027]
After the logic simulation, the substitution destination signal check unit 350 uses the API unit 320 to capture the logic value of the signal q1, and refers to the signal q1 of the condition description information file 330, so that the logic value of the signal q1 is changed from X to other values. It is determined whether or not the value has changed (S407). If X remains as it is (initial value), it is determined that there is a condition omission (S410).
[0028]
The processes in steps S404 to S405 are repeated for all four patterns (a, b) = (0, 0), (0, 1), (1, 0), (1, 1) (S408), In any case, if the logical value of the signal q1 has changed from X, the assignment destination signal check unit 350 determines that there is no condition omission (S409).
[0029]
In the example of the if statement in FIG. 7, when (a, b) = (0, 0), 700 statements are executed, and the logical value of q1 becomes 1 or 0. When (a, b) = (1, 0), no statement in FIG. 7 is executed and the value of q1 remains X. When the substitution destination signal check unit 350 confirms that the logical value of q1 is X, it means that a condition omission has been detected.
[0030]
The processing functions of some or all of the units in the apparatus shown in FIGS. 1 and 3 can be configured by a computer program, and the program can be executed using the computer to realize the present invention, or It goes without saying that the processing procedure shown in FIGS. 2 and 4 can be configured by a computer program and the program can be executed by the computer. In addition, a computer-readable recording medium such as an FD, an MO, a ROM, a memory card, a program for realizing the processing function by the computer or a program for causing the computer to execute the processing procedure, It can be recorded on a CD, DVD, removable disk, etc., stored, provided, and the program can be distributed through a network such as the Internet.
[0031]
【The invention's effect】
According to the present invention, syntax analysis of RTL data in HDL description and propagation of logic values are performed by a logic simulator, and acquisition of syntax analysis information of RTL data and setting and observation of logic values are incorporated in the logic simulator. Since it is performed by API and a condition omission in an if statement is detected, a condition omission check system can be constructed more easily than in the case of developing from scratch.
[Brief description of the drawings]
FIG. 1 is a configuration diagram of a first embodiment of the present invention.
FIG. 2 is a processing flowchart for explaining the operation of the first exemplary embodiment of FIG. 1;
FIG. 3 is a configuration diagram of a second embodiment of the present invention.
4 is a process flow diagram for explaining the operation of the second embodiment of FIG. 3; FIG.
FIG. 5 is a diagram illustrating an example of a logic circuit.
6 is a diagram illustrating an RTL description example for FIG. 5; FIG.
FIG. 7 is a diagram illustrating an example of an if sentence of RTL data;
[Explanation of symbols]
DESCRIPTION OF SYMBOLS 110 Circuit description data file 120 Signal constraint file 130 Signal constraint file reading part 140 Logic simulator 150 Flip flop information file 160 Testability design rule determination part 310 Circuit description data file 320 Logic simulator 330 Condition description information file 340 Logic value setting part 350 Substitution destination signal check part

Claims (3)

論理シミュレーション機能と、該論理シミュレーション機能の論理値の設定や参照、回路記述データの構文解析木情報の参照を可能とするAPIを含む論理シミュレータと、A logic simulator including a logic simulation function and an API that enables setting and referencing of logic values of the logic simulation function and referencing of parse tree information of circuit description data;
集積回路に対応する回路記述データを入力する手段と、Means for inputting circuit description data corresponding to the integrated circuit;
前記回路記述データから条件記述部を前記APIを使って抽出する手段と、Means for extracting a condition description part from the circuit description data using the API;
前記抽出された条件記述部の各条件信号に対して、すべての論理値の組み合わせを前記APIにより設定し、該論理値の組み合わせに対して、前記論理しュミレーション機能により論理シミュレーションを実施せしめる手段と、Means for setting all combinations of logic values for each condition signal in the extracted condition description section by the API, and performing a logic simulation for the combinations of the logic values by the logic simulation function; ,
前記条件記述部において代入先となっている信号の論理値を前記APIにより読み出し、該読み出された論理値から、条件記述部に条件漏れがあるか否か判定する手段と、Means for reading a logical value of a signal which is a substitution destination in the condition description part by the API, and determining from the read logical value whether there is a condition omission in the condition description part;
を有することを特徴とする集積回路設計支援装置。An integrated circuit design support apparatus characterized by comprising:
論理シミュレーション機能と、該論理シミュレーション機能の任意の信号に対する論理値の設定や参照、回路記述データの構文解析木情報の参照を可能とするAPIを含む論理シミュレータを備えたコンピュータが、A computer having a logic simulation function and a logic simulator including an API that enables setting and referencing of a logic value for an arbitrary signal of the logic simulation function and referencing of parse tree information of circuit description data,
集積回路に対応する回路記述データを入力するステップと、Inputting circuit description data corresponding to the integrated circuit;
前記回路記述データから条件記述部を前記APIを使って抽出するステップと、Extracting a condition description part from the circuit description data using the API;
前記抽出された条件記述部の各条件信号に対して、すべての論理値の組み合わせを前記APIにより設定し、該論理値の組み合わせに対して、論理シミュレーションを実施せしめるステップと、Setting all combinations of logic values for each condition signal in the extracted condition description section by the API, and executing a logic simulation for the combinations of the logic values;
前記条件記述部において代入先となっている信号の論理値を前記APIにより読み出し、該読み出された論理値から、条件記述部に条件漏れがあるか否か判定するステップと、A step of reading a logical value of a signal which is a substitution destination in the condition description part by the API, and determining from the read logical value whether there is a condition omission in the condition description part;
を実行することを特徴とする集積回路設計支援方法。An integrated circuit design support method comprising:
請求項2記載の集積回路設計支援方法の各ステップをコンピュータで実行するためのプログラム。A program for executing each step of the integrated circuit design support method according to claim 2 by a computer.
JP2002082446A 2002-03-25 2002-03-25 Integrated circuit design support apparatus and method, and program thereof Expired - Fee Related JP4082568B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2002082446A JP4082568B2 (en) 2002-03-25 2002-03-25 Integrated circuit design support apparatus and method, and program thereof

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2002082446A JP4082568B2 (en) 2002-03-25 2002-03-25 Integrated circuit design support apparatus and method, and program thereof

Publications (2)

Publication Number Publication Date
JP2003281216A JP2003281216A (en) 2003-10-03
JP4082568B2 true JP4082568B2 (en) 2008-04-30

Family

ID=29230627

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2002082446A Expired - Fee Related JP4082568B2 (en) 2002-03-25 2002-03-25 Integrated circuit design support apparatus and method, and program thereof

Country Status (1)

Country Link
JP (1) JP4082568B2 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2011180841A (en) 2010-03-01 2011-09-15 Ricoh Co Ltd Semiconductor design support apparatus

Also Published As

Publication number Publication date
JP2003281216A (en) 2003-10-03

Similar Documents

Publication Publication Date Title
JP4994393B2 (en) System and method for generating multiple models at different levels of abstraction from a single master model
US20070294647A1 (en) Transferring software assertions to hardware design language code
US20030208730A1 (en) Method for verifying properties of a circuit model
US8146034B2 (en) Efficient Redundancy Identification, Redundancy Removal, and Sequential Equivalence Checking within Designs Including Memory Arrays.
US20050097484A1 (en) Method for clock synchronization validation in integrated circuit design
US8336016B2 (en) Eliminating, coalescing, or bypassing ports in memory array representations
US9600398B2 (en) Method and apparatus for debugging HDL design code and test program code
US8291359B2 (en) Array concatenation in an integrated circuit design
US8307313B2 (en) Minimizing memory array representations for enhanced synthesis and verification
US10437946B1 (en) Using implemented core sources for simulation
US10437949B1 (en) Scheduling events in hardware design language simulation
US10372858B2 (en) Design-for-testability (DFT) insertion at register-transfer-level (RTL)
US7231627B2 (en) Merging a hardware design language source file with a separate assertion file
US8448113B2 (en) Efficiently applying a single timing assertion to multiple timing points in a circuit using creating a deffinition
JP2008511894A (en) Method and system for designing a structure level description of an electronic circuit
JP4082568B2 (en) Integrated circuit design support apparatus and method, and program thereof
US7260792B2 (en) Modeling a mixed-language mixed-signal design
US10599802B2 (en) Methods for automatic engineering change order (ECO) bug fixing in integrated circuit design
US8949766B2 (en) Detecting corresponding paths in combinationally equivalent circuit designs
US8910097B2 (en) Netlist abstraction
US7496869B1 (en) Method and apparatus for implementing a program language description of a circuit design for an integrated circuit
JP4881769B2 (en) Semiconductor integrated circuit design support apparatus, semiconductor integrated circuit design support method, semiconductor integrated circuit design support program
US7493580B2 (en) Critical path estimating program, estimating apparatus, estimating method, and integrated circuit designing program
US6442738B1 (en) RTL back annotator
US20060190882A1 (en) System and method for generating assertions using waveforms

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20050202

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20071001

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20071010

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20071210

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20080207

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

Free format text: PAYMENT UNTIL: 20110222

Year of fee payment: 3

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

Free format text: PAYMENT UNTIL: 20120222

Year of fee payment: 4

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

Free format text: PAYMENT UNTIL: 20130222

Year of fee payment: 5

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

Free format text: PAYMENT UNTIL: 20130222

Year of fee payment: 5

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

Free format text: PAYMENT UNTIL: 20140222

Year of fee payment: 6

LAPS Cancellation because of no payment of annual fees