Debussy 仿真快速上手教程 Debussy介绍         Debussy 是NOVAS Software, Inc(思源科技)发展的HDL Debug & Analysis tool,这套软体主要不是用来跑模拟或看波形,它最强大的功能是:能够在HDL source code、schematic diagram、waveform、state bubble diagram之间,即时做trace,协助工程师debug。       可能您会觉的:只要有simulator如ModelSim就可以做debug了,我何必再学这套软体呢? 其实Debussy v5.0以后的新版本,还提供了nLint -- check coding style & synthesizable,这蛮有用的,可以协助工程师了解如何写好coding style,并养成习惯。        下图所示为整个Debussy 的原理架构,可归纳几个结论:                Debussy有四个主要单元(component),nTrace、nWave、nSchema、nState   * nTrace ~ Hypertext source code analysis and browse tool (为 %Debussy & 所开启的主画面)    * nWave -- Waveform analysis tool (可由nTrace内开启,或直接 %nWave & 开启)    * nSchema -- Hierarchy schematic generator    * nState -- Finite State Machine Extraction and analysis tool     Debussy本身不含模拟器(simulator),必须呼叫外部模拟器(如Verilog-XL or ModelSim)产生FSDB file,其显示波形的单元\"nWave\"透过读取FSDB file,才能显示波形或讯号值的变化。
快速上手五部曲: (Debussy v.5.2)
1. Import Files and generate FSDB file
2. Trace between hierarchy browser and source code
3. Trace between hierarchy browser、source code and schematic      4. Trace between hierarchy browser、source code、schematic and
waveform
5. nLint
(nState本文没介绍,有兴趣的读者,请依文后的连结,自行下载CIC所提
供的NOVAS原厂编写教材参考)
1. Import Files and generate FSDB file
1.1 启动Debussy:% Debussy &(此处的D大小写都可以,但其它指令的大小写
可能就有差别)               开启nTrace window如下,此时工作目录下会新建一个\"DebussyLog\"目录
1.2 Import Files:File \\ Import Design
结果如下图所示:nTrace视窗中,含有三个区域,Hierarchical Brower、
Source code window、Message window。             (如果不想看波形,只想查看source code与schematic的关係,您可以直
接跳到step 2.1)
此时DebussyLog目录内会有Debussy.cmd、turbo.log、compiler.log三个档案。Debussy.cmd纪录所有import的档案与之后所有的执行程序。我们可以直接
引用这个档案来执行上一次我们做过的一连串程序(refer to 1.5)。
1.3 设定外部模拟器,藉其產生FSDB file: Tools \\ Options \\ Preferences
1.4 切换到Interactive Mode:Tools \\ Interactive Mode  (此时ToolBar上会
出现Simulation选单)             开始执行模拟:Simulation \\ Run/Continue (模拟结束工作目录下就会產
生dump_i.fsdb )
Source code目录下,要有先前ModelSim所建立的此project的work library,不然会有错误讯息:Failed to access library 'work' at \"work\"。
另外,你不能只是开一个work资料夹,而是要真的用ModelSim產生work library,并且把design compile to the work library后,step 1.4才会正确
动作。
1.5 结束程式:File \\ Exit
1.6 快速启动执行序
把DebussyLog目录下的指令记录档Debussy.cmd复制到目前工作目录下,重新编辑此档 (删掉最后一行的\"debExit\
重复之前同样的动作程序。           % Debussy -play Debussy.cmd &        (结果相当於从步骤1.1做到
1.4)
1.7 其他启动Debussy的方法
% Debussy -f xxx.f    (类似开启一个事先编写的批次档,可以同时一次
载入多个.v)           % Debussy -vhdl -f xxx.f    (类似开启一个事先编写的批次档,可以同
时一次载入多个.vhd)
^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^
\".f\"文件可由顶层项目文件 \".prj\"生成。
\".prj\"项目文件格式如下:
\".f\"文件格式如下:
导入\".f\"文件时,Language选择Verilog-2001。
记得加入库文件“unisim.v”。
^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^ ^
以上都是属於Import design from file的方法,另外还有一种方法是Import design from library。两者的差异在於:Import design from file是将design compile to RAM,而Import design from library则是将design compile to
library (default lib. is \"work\")。
对於比较大的project,為了避免每次使用Debussy都要花时间compile,建议採用Import design from library的方法,而且mixed-language design一定
要用Import design from library的方法。
Ex. for Verilog files:%vericom -inc -f run.f     
%Debussy -lib work -top xxx &
Ex. for VHDL files:%vhdlcom -93 -f run.f                    %Debussy -lib work -top xxx &
2. Trace between hierarchy browser and source code
2.1 在Hierarchy browser点击A1(FourBitAdder)左侧的符号\"+\",可以展开四
个full adder (fa0, fa1, fa2, fa3)
2.2 试著双击Hierarchy browser内的testbed or A1 or fa0 ...右边的source
code window会立即切换到相对的module
2.3 双击上图source code window内的\"fulladder\"(in line 8),软体会自动帮你追踪出引用fa0的地方,结果示於下图 -- A1(FourBitAdder)的fa0 (in
line 32);若再双击fa0(in line 32),则又回到上图。             --> 你可以藉由这个方法,轻易的追踪出project内的所有design彼此之
间的关连性
2.4 除了追踪designs之间的关连性,也可以用同样的方法追踪出signal's
drivers and loads。
若双击上图的讯号c_in (in line 24),将显示该讯号的所有的drive loads, 结果如下图 -- message window显示,有4处drive c_in,分别在add4test line
69, 71, 73, 75
3.Trace between hierarchy browser、source code and schematic
3.1 开启nSchema有三种方法
下图是把A1(FourBitAdder)丢进New Schematic icon的结果:
如果想直接看symbol \"fulladder\"的source code,先以左键选定(highlight)该元件,然后按右键,从快速选单选择\"Display Source Code\"
选择(highlight)第一个full adder的第二条输出讯号,然后按Tools \\ New
Schematic \\Fan-In Cone试试
3.2 双击上图内的元件符号(如第一个fulladder)可进一步看到其内容/ 细部
电路组成(fa0)
3.3 请自行尝试,在hierarchy browser、source code与schematic window
之间,用滑鼠中键互相拖曳designs/signals的效果
4. Trace between hierarchy browser、source code、schematic and
waveform
4.1 接下来的操作,需要利用模拟器所产生的资料(.fsdb),以\"nWave\"显示讯号
波形,有两种可能作法
4.1.1 如果是从1.2接著打开nWave window,一开始nWave内容是空的,要执行
(nWave) File \\ Open...以载入dump_i.fsdb。
4.1.2 接著按 Get Signals icon,此时就会看到有讯号可以让你选择
了
如果你看不到讯号,把想观察的design(A1),直接从(nTrace) Hierarchy
browser拖进nWave就可以
4.1.3 (nWave) View \\ Zoom \\ Zoom All
如果你看不到波形,请再执行一次 (nTrace) Simulation \\ Run/Continue
就会看到
4.2 启动Active Annotation功能:(nTrace) Source \\ Active
Annotation
能够在nWave选择讯号触发缘,同时在nTrace的source code的所有讯号符号
下方,直接看到数值的变换
4.3 在nWave双击想观察其触发状况的讯号 (如c_out)
5. nLint
5.1 开启图形介面的nLint
% nLint -gui &   (大小写不能改,n一定要小写,L一定要大写)              开启nLint window如下,此时工作目录下会新建一个\"nLintLog\"目录
5.2 Import Files:File \\ Import Design... (与step 1-2一模一样的操作
后,结果如下所示)
5.3 执行Run \\ Compile
5.4 执行Tools \\ Rule Organizer,或按选择check哪些rules
不想检查的项目,就把E/D那一栏的核选框框取消
5.5 执行Run \\ Lint   会自动跳出ReportViwer显示检查结果
5.6 展开report,选择第一个黄色警示标示,其出错的原因与原始码部份,会
即时显示在下方的栏框中。             如果要修改source code,在该错误选项上,按滑鼠右键,选择Show violation
\\ to default editor