FPGA开发全攻略—— 调试

原文链接:

FPGA开发全攻略连载之十三:FPGA实战开发技巧(12)

FPGA开发全攻略连载之十三:FPGA实战开发技巧(12)

5.6 大规模设计的调试经验

在大规模设计的调试应该按照和设计理念相反的顺序,从底层测试,主要依靠ChipScope Pro 工具。下面主要介绍ChipScope Pro、FPGA Editor 组件的使用方法。

5.6.1 ChipScope Pro组件应用实例

在赛灵思软件设计工具中,ISE 可集成赛灵思公司的所有工具和程序。ChipScope Pro 也不例外,在ISE 中将其作为一类源文件,和HDL 源文件、IP Core 以及嵌入式系统的地位是等同的。本节在Xilinx Spartan3E-D开发板上实现一个计数器模块,基于该模块详细介绍如何在ISE 中新建ChipScope 应用以及观察、分析数据的详细操作。

例5.6.1 :在ISE 中实现一个8 比特计数器,利用ChipScope 分析其逻辑输出。

(1) 新建用户工程,添加mycounter.v 的源文件,其内容如下所列:
module mycounter(clk, reset, dout);
  input clk;
  input reset;
  output [7:0] dout;
  reg [7:0] dout;
  always @(posedge clk) begin
    if (reset == 0)
      dout <= 0;
    else
      dout <= dout + 1;
  end
endmodule

然后根据电路连接,添加相应的管脚约束。

(2) 综合工程,然后在ISE 工程管理区,单击右键,选择“Add New Source”命令,在弹出的对话框中选择“ChipScope Definition and Connection File” 类型, 并在“File Name” 栏输入ChipScope 设计名称mychipscope,如图5-41所示。

图5-41 添加ChipScope设计示意图

图5-42 测试模块选择界面

单击“Next”按键,进入分析文件选择界面,这里会将该文件夹里所有的HDL 设计、原理图设计都罗列出来( 包括顶层模块和全部底层模块),供用户挑选,用鼠标单击即可选中,本例选择mycounter,如图5-42 所示。单击“Next”按键进入小结页面,单击“Finish”按键完成添加。

(3) 双击工程区mycounter.v 下的子模块mychipscope.cdc,可自动打开Chipscope Pro Core Insterser软件,添加触发单元和触发位宽。其中触发类型选为Basic,位宽为8比特;设置采样深度为4096,各步骤如图5-43到图5-46所示。

图5-43 调试工程配置界面

图5-44 ICON核配置界面

图5-45 触发信号配置界面

图5-46 采集深度配置界面

(4) 点击“Next”进入网表连接显示页面,如图5-47 所示。其中如果用户定义的触发和时钟信号线有未连接的情况,则图中“UNIT”、“CLOCKPORT”以及“TRIGGERPORTS”等字样以红色显示;正确完成连接后则变成黑色。

图5-47网表连接提示界面

点击图5-47 中“Modify Connection”的按键,进入连接页面,时钟和数据的连接如图5-48、图5-49所示。需要注意的是,ChipScope Pro 只能分析FPGA 设计的内部信号,因此不能直接连接输入信号的网表,所以输入信号网表全部以灰色显示。如果要采样输入信号,可通过连接其输入缓冲信号来实现,时钟信号选择相应的BUFGP,普通信号选择相应的IBUF。如图5-48 中所示,选择采样时钟时,选择了CLK_BUFGP。

图5-48 时钟网表连接界面

图5-49 触发网表连接界面

连接完成后,单击“OK”按键返回连接显示界面,发现所有提示字符“UNIT”、“CLOCKPORT”以及“TRIGGERPORTS”没有红色,则单击“Return Project Navigator”,退出Chipscope,返回到ISE 中。否则需要再次点击“Modify Connection”按键重新连接。

(5) 在工程中加入UCF 文件,约束时钟、数据管脚位置。为了简化也可以只添加clk 和reset 这两个控制信号的管脚约束,其内容如下:

NET "clk" LOC = "C9" | IOSTANDARD = LVCMOS33 ;
# Define clock period for 50 MHz oscillator (40%/60% duty-cycle)
NET " clk " PERIOD = 20.0ns HIGH 40%;
NET "reset" LOC = "H13" | IOSTANDARD = LVTTL | PULLDOWN ;

(6) 在ISE 过程控制区中双击“Implement Design”和“Generate Programming File”, 可以完成实现以及生成可编程文件,并将设计人员插入的各类核也将被包含在比特文件中。生成配置文件后,双击图5-50所示的“Analyze Design Using Chipscope”图标,可自动打开Chipscope Pro Analyzer 软件。

图5-50 Chipscope Pro Analyzer启动操作示意图

(7) 在Chipscope Analyzer 用户界面上点击工具栏上图标“ ”,初始化边界扫描链。等扫描完成后,单击“Device”菜单下“DEV: 0 My Device0(XC3S500E) → Configure”命令选择.bit 文件配置FPGA。
(8) 芯片配置完成后,选择“File”菜单的“Import”命令,可弹出CDC 文件加载页面,选择相应的CDC 文件,将会把所有以“Dataport”的名称修改为综合后的线网名称。
(9) 组合cnt 总线信号。可按住“Ctrl”键,选择多个总线信号,单击右键,选择“Add to Bus”命令,将其组合成相应的总线信号,如图5-51 所示。

图5-51 添加总线操作示意图

(10) 不设定触发条件采集数据。点击工具栏的“ ”图标,开始采集数据。整体结果如图5-52 所示,单击工具栏的“ ”按键,可放大信号,局部结果如图5-53 所示。从分析结果可以看出,本设计在FPGA中成功地完成了8 比特计数器的功能。

图5-52 Analyzer分析结果整体示意图

图5-53 Analyzer分析结果局部示意图

(11) 设定触发条件采集数据。在“Trigger Setup”栏Match 区域的“M0: Trigger Port0”行的Value 列输入触发条件“0000_0000”,如图5-54 所示。

图5-54 触发条件设置界面

点击工具栏的“ ”图标,开始采集数据,可以看到,采集结果的第一个数为0,如图5-55 所示。当然,
用户可以根据需要设置更复杂的触发条件。

图5-55 触发条件设置界面

(12) 利用Bus Plot 功能绘制输出信号波形。在工程区双击“Bus Plot”命令,然后在弹出窗口的“Bus Selection”区域选中“dout”,则会将采集数据以图形方式显示出来,如图5-56 所示。由于本设计是8 比特加1 计数器,因此其波形就是幅度为0 到255 的锯齿波。

图5-56 8计数器的波形示意图

时间: 2024-10-05 17:17:11

FPGA开发全攻略—— 调试的相关文章

FPGA开发全攻略——配置电路

原文链接: FPGA开发全攻略连载之十二:FPGA实战开发技巧(9) FPGA开发全攻略连载之十二:FPGA实战开发技巧(10) FPGA开发全攻略连载之十三:FPGA实战开发技巧(11) 5.5 FPGA相关电路设计知识 FPGA的相关电路主要就是FPGA的配置电路,其余的应用电路只要将外围芯片连接到FPGA的通用I/O管脚上即可. 5.5.1 配置电路 FPGA配置方式灵活多样,根据芯片是否能够自己主动加载配置数据分为主模式.从模式以及JTAG模式.典型的主模式都是加载片外非易失( 断电不丢

FPGA开发全攻略连载之十:FPGA开发基本流程(1)

原文链接: FPGA开发全攻略连载之十:FPGA开发基本流程(1) FPGA开发基本流程(2) FPGA是可编程芯片,因此FPGA的设计方法包括硬件设计和软件设计两部分.硬件包括FPGA芯片电路. 存储器.输入输出接口电路以及其他设备,软件即是相应的HDL程序以及最新才流行的嵌入式C程序. 目前微电子技术已经发展到SOC阶段,即集成系统(Integrated System)阶段,相对于集成电路(IC)的设计思想有着革命性的变化.SOC是一个复杂的系统,它将一个完整产品的功能集成在一个芯片上,包括

FPGA开发全攻略——综合

原文链接: FPGA开发全攻略连载之十二:FPGA实战开发技巧(7) FPGA开发全攻略连载之十二:FPGA实战开发技巧(8)(原文缺失,转自:FPGA开发全攻略—工程师创新设计宝典) 5.3.4 综合高手揭秘XST的11个技巧 作者:Ricky Su(www.rickysu.com) 技巧1.XST 主要参考资料:XST User Guide (ISE 安装目录doc 中的xst.pdf)技巧2. 辅助参考资料:WP231 - HDL Coding Practices to Accelerat

FPGA开发全攻略——时序约束

原文链接: FPGA开发全攻略连载之十二:FPGA实战开发技巧(5) FPGA开发全攻略连载之十二:FPGA实战开发技巧(6)(原文缺失,转自:FPGA开发全攻略—工程师创新设计宝典) 5.3.3 和FPGA接口相关的设置以及时序分析5.3.3.1 使用约束文件添加时序约束 一般来讲,添加约束的原则为先附加全局约束,再补充局部约束,而且局部约束比较宽松.其目的是在可能的地方尽量放松约束,提高布线成功概率,减少ISE 布局布线时间.典型的全局约束包括周期约束和偏移约束.在添加全局时序约束时,需要根

FPGA开发全攻略——ISE基本操作

原文链接: FPGA实战开发技巧(2) FPGA开发全攻略连载之十二:FPGA实战开发技巧(3) FPGA开发全攻略连载之十二:FPGA实战开发技巧(4) 5.2 如何进行FPGA设计早期系统规划 作者:Ricky Su (www.rickysu.com) 这篇文章讲述了如何用工具提高效率的方法,适用程度因人而异. Situation: 在对FPGA 设计进行最初步的系统规划的时候,需要进行模块划分,模块接口定义等工作.通常,我们起初会在纸上进行设计,到了一定阶段的定稿可能会输入Visio 等工

FPGA开发全攻略——FPGA发展以及赛灵思系列产品

原文链接: FPGA开发全攻略连载之八:从可编程器件发展看FPGA未来趋势 FPGA开发全攻略连载之九:FPGA主要供应商与产品(1) FPGA开发全攻略连载之九:FPGA主要供应商与产品(2) FPGA开发全攻略连载之九:FPGA主要供应商与产品(3) 可编程逻辑器件的发展历史可编程逻辑器件的发展可以划分为4个阶段,即从20世纪70年代初到70年代中为第1段,20世纪70年代中到80年代中为第2阶段,20世纪80年代到90年代末为第3阶段,20世纪90年代末到目前为第4阶段. 第1阶段的可编程

FPGA开发全攻略——FPGA内部结构

原文链接: FPGA开发全攻略连载之五:FPGA主要功能模块介绍(1) FPGA开发全攻略连载之六:数字时钟管理模块与嵌入式块RAM FPGA开发全攻略连载之七:底层内嵌功能单元与软核.硬核以及固核 1. 可编程输入输出单元(IOB) 可编程输入/ 输出单元简称I/O 单元,是芯片与外界电路的接口部分,完成不同电气特性下对输入/ 输出信号的驱动与匹配要求,其示意结构如图2-4 所示.FPGA 内的I/O 按组分类,每组都能够独立地支持不同的I/O标准.通过软件的灵活配置,可适配不同的电气标准与I

FPGA开发全攻略——概念篇

原文链接: FPGA开发全攻略连载之一:FPGA为什么这么热? FPGA开发全攻略连载之二:为什么工程师要掌握FPGA开发知识? FPGA开发全攻略连载之三:FPGA基本知识与发展趋势(part1) FPGA开发全攻略连载之四:FPGA基本知识与发展趋势(part2) 写在前面 2008年,我参加了几次可编程器件供应商举办的技术研讨会,让我留下深刻印象的是参加这些研讨会的工程师人数之多,简直可以用爆满来形容,很多工程师聚精会神地全天听讲,很少出现吃完午饭就闪人的现象,而且工程师们对研讨会上展出的

FPGA开发全攻略——FPGA选型

原文链接: FPGA实战开发技巧(1) 第五章.FPGA实战开发技巧 5.1 FPGA 器件选型常识 作者: 童 鹏.胡以华/中科院上海技术物理研究所 FPGA 器件的选型非常重要,不合理的选型会导致一系列的后续设计问题,有时甚至会使设计失败:合理的选型不光可以避免设计问题,而且可以提高系统的性价比,延长产品的生命周期,获得预想不到的经济效果.FPGA 器件选型有以下7 个原则:器件的供货渠道和开发工具的支持.器件的硬件资源.器件的电气接口标准.器件的速度等级.器件的温度等级.器件的封装和器件的