在对compxlib命令有了初步的认识后,我们来详细介绍compxlib命令的语法。
compxlib命令的语法如下:
compxlib -s <simulator> -arch <arch>
[-l <language>] [-lib <library>] [-dir <output_dir>]
[-w] [-log <log_file>] [-p <dir_path>]
[-smartmodel_setup] [-verbose]
compxlib -cfg
compxlib -info <dir_path>
compxlib -f <cmd_file>
compxlib -help
compxlib -help <value>
l -s <simulator>
-s <simulator> 选项用于指明为哪一种仿真器编译仿真库,用户必须为compxlib命令指定该选项。-s选项的有效值如下:
-s mti_se // 为ModelSim? SE编译仿真库;
-s mti_pe // 为ModelSim? PE编译仿真库;
-s ncsim // 为NCSIM? 编译仿真库;
-s vcs_mx // 为VCS-MX? 编译仿真库;
-s vcs_mxi // 为VCS-MXi? 编译仿真库;
对ModelSim仿真器来说,我们可以使用-s mti_se或-s mti_pe,例如在上面的例子中我们使用了-s mti_se选项。
l -arch <arch>
-arch <arch>选项用于指明为哪一个器件族编译仿真库,用户必须为compxlib命令指定该选项。-arch选项的有效值如下:
-arch all // 为所有支持的器件族编译仿真库;
-arch virtex // 为Virtex器件族编译仿真库;
-arch virtexe // 为VirtexE器件族编译仿真库;
-arch virtex2 // 为Virtex-II器件族编译仿真库;
-arch virtex2p // 为Virtex-II Pro器件族编译仿真库;
-arch virtex4 // 为Virtex-4器件族编译仿真库;
-arch spartan2 // 为Spartan-II器件族编译仿真库;
-arch spartan3 // 为Spartan-3器件族编译仿真库;
-arch spartan2e // 为Spartan-II E器件族编译仿真库;
-arch spartan3e // 为Spartan-3 E器件族编译仿真库;
-arch fpgacore // 为Xilinx提供的IP Core编译仿真库;
-arch cpld // 为Xilinx的CPLD编译仿真库;
-arch cr2s // 为Xilinx的CoolRunner-II CPLD编译仿真库;
-arch xpla3 // 为Xilinx的CoolRunner XPLA3 CPLD编译仿真库;
-arch xc9500 // 为Xilinx的XC9500 CPLD编译仿真库;
-arch xc9500xl // 为Xilinx的XC9500XL CPLD编译仿真库;
-arch xc9500xv // 为Xilinx的XC9500XV CPLD编译仿真库;
l -l <language>
-l <language>选项用于指明为哪一种HDL语言编译仿真库。
-l <language>选项是可选的,在缺省情况下,compxlib命令根据-s <simulator> 选项检测语言类型。如果目标仿真器既支持Verilog也支持VHDL,则compxlib命令将-l选项设置成all,也就是说为两种语言产生仿真库。否则,compxlib命令根据目标仿真器支持的语言类型选择相应的-l选项。如果使用了-l <language>选项,则compxlib命令根据-l选项来选择为哪种语言编译仿真库。-l选项的有效值如下:
-l verilog // 为Verilog语言编译仿真库;
-l vhdl // 为 VHDL语言编译仿真库;
-l all // 为Verilog和VHDL两种语言编译仿真库;
l -lib <library>
-lib <library>选项用于选择编译哪一个HDL仿真库。-lib <library>选项是可选的,如果未指定该选项,则compxlib命令自动编译所有的仿真库。另外,如果指定多个仿真库,则“-lib”的各个有效值之间以空格分割。-lib选项的有效值如下:
-lib unisim // 该仿真库用于Xilinx器件的功能仿真;
-lib simprim // 该仿真库用于Xilinx器件的时序仿真;
-lib uni9000 // 该仿真库用于Xilinx CPLD器件的功能仿真;
-lib xilinxcorelib // 该仿真库用于Xilinx IP Core的功能仿真;
-lib smartmodel // 该仿真库用于SmartModel Library?的功能仿真和时序仿真;
-lib coolrunner // 该仿真库用于Xilinx CoolRunner?器件的功能仿真;
-lib abel // 该仿真库用于功能仿真;
在上面的例子中,我们没有使用该选项,也就是说自动编译所有的仿真库。
l -dir <output_dir>
该选项指明编译后的仿真库存储的目录路径。缺省情况下,compxlib命令将仿真库编译到$XILINX/language/target_simulator目录下。在上面的例子中,我们将仿真库编译到了D:\EDASoft\Modeltech_6.1a\xilinx_lib目录下,用户需要根据实际情况修改。当然也可以不使用该选项,而是编译到缺省目录下。
l -w
可以使用这个选项覆盖预编译的仿真库,缺省情况下不会覆盖预编译的仿真库。
l -log <log_file>
可以使用这个选项来产生自己的编译日志文件。如果不使用该选项,则compxlib命令会自动产生一个日志文件,这个文件存放于运行compxlib命令的目录,文件名为compxlib.log。
l -p <dir_path>
该选项用来指定仿真器可执行文件存在的路径。缺省情况下,compxlib命令自动从$PATH或%PATH%环境变量中搜索仿真器可执行文件存在的路径。如果$PATH或%PATH%环境变量中没有指定仿真器可执行文件存在的路径,则需要使用此选项指定。
l -smartmodel_setup
该选项为SWIFT接口更新设置文件。
l -verbose
该选项使compxlib命令执行的时候能够打印更多的消息。
l -cfg
使用该选项可以产生具有缺省设置的配置文件。缺省情况下,如果在当前的目录中没有compxlib.cfg文件,则compxlib命令会产生一个。
l -info <dir_path>
该选项用于打印预编译库的信息,<dir_path>用于指定预编译库存在的路径。例如:如果执行compxlib –info D:\EDASoft\Modeltech_6.1a\xilinx_lib命令,则在屏幕上显示如下的信息:
Release 7.1.02i - COMPXLIB H.40
Copyright (c) 1995-2005 Xilinx, Inc. All rights reserved.
Pre-Compiled Library Info :-
---------------------------------------------------------------
Library =: unisim
Mapped Name =: unisim
Language Name =: vhdl
Version =: 7.1i
Library Path =: D:\EDASoft\Modeltech_6.1a\xilinx_lib
Compiled By =: mti_se
Simulator Used =: Model Technology ModelSim SE vlog 6.1a Compiler 2005.07 Jul 19 2005
Compiled On =: Wed Aug 03 19:22:51 2005
Errors =: 0
Warnings =: 0
Library Log =: D:\EDASoft\Modeltech_6.1a\xilinx_lib\unisim\cxl_XilinxCoreLib.log
---------------------------------------------------------------
…
l -f <cmd_file>
使用该选项可以使compxlib命令从文件中读取compxlib命令的选项和参数。
l -help
使用该选项可以将compxlib命令的帮助打印到标准输出设备上。
l -help <value>
该选项可以打印扩展帮助信息。我们可以使用compxlib -help list命令来获得<value>的可用值。
至此,compxlib命令的用法便介绍完了,读者在使用该命令的时候,应充分利用compxlib -help命令和compxlib -help <value>命令来获得帮助信息。另外需要注意的是,本文的介绍是基于Xilinx ISE 7.1i所作的介绍,如果您正在使用其它版本,该命令的具体参数可能会有所不同,此时您可以使用compxlib -help命令获得特定版本的使用帮助。