FPGA进阶开发与实践
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人

1.6 命令行与Tcl脚本

1.6.1 命令行

采用命令行方式来控制设计的编译流程,设置设计的各种约束,可以加快开发进程。因为命令行方式占用的内存较少,可以执行自动化流程。

Quartus软件中可以独立以命令行方式执行的模块程序有以下几个。

(1)quartus_map:分析综合工具。

(2)quartus_fit:布局布线工具。

(3)quartus_tan:时序分析工具。

(4)quartus_sim:仿真工具。

(5)quartus_asm:配置映射工具。

(6)quartus_pgm:程序下载工具。

(7)quartus_sh:Tcl解释器。

用户可以在操作系统的命令窗口中直接输入命令,也可以把需要执行的命令写到一个脚本文件中,通过执行脚本文件来执行所有的命令。

命令行示例如图1-59和图1-60所示。

图1-59 命令行示例(一)

图1-60 命令行示例(二)

1.6.2 Tcl基础知识

Tcl是EDA工具行业标准脚本语言,它允许用户自定义命令,并且可以在大多数平台间转换。

Quartus软件自带Tcl命令包和解释器,命令包有以下几个。

(1)::quartus::project:建立和设置工程。

(2)::quartus::device:器件设置。

(3)::quartus::advanced_device:高级器件设置。

(4)::quartus::flow:简单设计流程。

(5)::quartus::timing:时序分析。

(6)::quartus::advanced_timing:高级时序分析。

(7)::quartus::simulation:仿真。

(8)::quartus::report:数据报告。

(9)::quartus::timing_report:时序报告。

(10)::quartus::backannotate:反标注。

(11)::quartus::logiclock:逻辑锁定。

执行Tcl命令有以下两种方式。

(1)直接执行Tcl脚本(批处理方式)。

可以直接在Tcl Shell中执行source命令:

也可以在命令窗口中执行以下命令:

(2)在Quartus软件的Tcl解释器中执行命令。

如图1-61所示,先进入Tcl解释器,再输入Tcl命令。

Tcl解释器中还提供了帮助信息,如图1-62所示。

Tcl是工具命令语言,由加州大学伯克利分校的约翰·奥斯特豪特开发。他最初的目的是控制IC设计过程中使用的不同软件,以便轻松地完成设计。Tcl在EDA工具行业得到了广泛应用,包括Synopsys、Mentor Graphics、英特尔等在内的主要供应商的产品都支持Tcl。

Tcl是一种基于字符串的语言。Tcl中的基本结构和规则很少,基本语法结构是命令后面跟随相关参数,用空格分隔命令和参数,用换行符或分号结束命令。

图1-61 Tcl解释器

图1-62 帮助信息

Tcl解释器是执行Tcl脚本的程序,可以通过tclsh命令启动Tcl解释器。

图1-63中显示了一个“Hello World”示例。在该示例中,利用puts命令来打印字符串“Hello World”。

图1-63 “Hello World”示例

1.6.3 创建和执行Tcl脚本

Tcl脚本是包含一系列Tcl命令的文件,文件扩展名为.tcl。

下面创建Tcl脚本以打印字符串“Hello World”。

(1)创建myscript.tcl文件,如图1-64所示。

图1-64 创建myscript.tcl文件

(2)执行Tcl脚本,如图1-65所示。

图1-65 执行Tcl脚本

1.6.4 Tcl脚本实验

1.实验目的

学习Tcl脚本在FPGA开发中的应用。

2.实验环境

(1)硬件:PC、FPGA实验开发平台。

(2)软件:Quartus Prime 17.1。

3.实验内容

首先在Quartus软件中使用Tcl建立工程,添加设计源文件和时序约束文件,然后进行编译,最后烧写到目标器件上进行验证。

4.实验设计

新建设计源文件test.v和时序约束文件test.sdc,代码如下。

将Tcl命令统一放入文件test.tcl中。

首先加入Quartus软件支持的Tcl命令包,本实验中需要用到::quartus::project(提供建立工程、管理工程、引脚分配及时序约束等功能)和::quartus::flow(提供工程编译功能)两个Tcl命令包。

然后建立设计工程,本实验中设计工程名为test。

接下来设置工程属性,如使用的器件型号、Quartus软件版本、编译和仿真工具等;添加设计源文件test.v和时序约束文件test.sdc,对设计中使用的I/O进行引脚分配。

最后通过“execute_flow-compile”命令对工程进行编译。

Quartus软件支持的详细Tcl命令可参考Quartus Handbook文档中的相关内容。

5.实验步骤

(1)将实验所需文件放入本地文件夹包括设计源文件test.v、时序约束文件test.sdc和Tcl脚本文件test.tcl,如图1-66所示。

图1-66 准备实验所需文件

(2)打开Quartus软件,调出Tcl控制台,如图1-67所示。

图1-67 调出Tcl控制台

(3)如图1-68所示,在Tcl控制台中输入命令,执行Tcl脚本文件test.tcl。

图1-68 执行Tcl脚本文件

(4)在Tcl控制台中输入“execute_flow-compile”命令对工程进行编译。编译时间随计算机配置不同而不同。编译成功后即可查看综合、布局布线及时序报告,以检查设计的正确性。

(5)根据实验实际使用的硬件连接情况,在Tcl脚本文件test.tcl中修改工程I/O引脚分配后再次运行。

(6)用下载线将实验使用的开发板和计算机相连并正常供电。如图1-69所示,在Quartus软件中单击“Program Device(Open Programmer)”,打开硬件编程界面。

图1-69 单击“Program Device(Open Programmer)”

(7)在“Currently selected hardware”下拉列表框中找到实验所用的下载线,如图1-70所示。

图1-70 选择下载线

(8)在图1-71所示的界面中,“Mode”选择“JTAG”,单击“Auto Detect”按钮,然后选择需要下载的文件。

图1-71 选择需要下载的文件

(9)如图1-72所示,单击“Start”按钮,开始下载文件。下载过程中遇到错误时,Quartus软件会显示具体的错误。若下载成功,“Progress”栏会显示“100%(Successful)”。

图1-72 下载文件

6.实验现象

用示波器测试test_ot引脚,可以观察到周期性的正脉冲信号,如图1-73所示。

图1-73 观察实验现象