[FPGA]-时序分析工具使用

FPGA时序分析工具使用

将以下代码为例:

verilog 复制代码
module counter(
			Clk50M,
			Rst_n,
			led
		);

	input Clk50M;	
	input Rst_n;	
	
	output reg led;	
	
	reg [24:0]cnt;	


	always@(posedge Clk50M or negedge Rst_n)
	if(Rst_n == 1'b0)
		cnt <= 25'd0;
	else if(cnt == 25'd24_999_999)
		cnt <= 25'd0;
	else
		cnt <= cnt + 1'b1;


	always@(posedge Clk50M or negedge Rst_n)
	if(Rst_n == 1'b0)
		led <= 1'b1;
	else if(cnt == 25'd24_999_999)
		led <= ~led;
	else
		led <= led;

endmodule
  • 这段代码能够运行在多高的时钟频率?

这个代码所描述的逻辑电路能最高运行在多少频率的时钟?
这个代码所描述的CycloneIV E(65nm)这个器件上能最高运行在多少频率的时钟?
这个代码描述的逻辑电路在CycloneIVE的EP4CE10F17C8这个器件上最高能运行在多少频率的时钟?

需要时序分析软件高速我们时钟频率---TimeQuest,通过TimeQuest这个软件对EP4CE10F17C8进行分析,并给出报告。

时序分析一定时基于特定器件(该器件需要具体到一个特定型号的特定速度等级 )。

时序分析一定是基于某个逻辑设计在该特定器件上经过布局布线之后的网表(该网表包含了设计中每一个逻辑具体在该器件的什么资源上实现,而且还包括该资源在器件内的具体位置;该网表还包括信号从每一个节点传输到下一个节点的具体延迟时间 )。

时序分析不是在对代码进行分析,而是在对真实的门极传输路径进行分析。

使用Quartus进行全编译:

右侧报告Clocks:1000MHz,即1GHz。

这是软件报告汇中的时钟信号的约束频率,如果用户没有对时钟信号加约束,软件就会对分析出的时钟信号加入约束,这个约束会按照最大的可能来约束,也就是最大设置时钟频率为1000MHz。

框中表示的是时序分析出的三个模型,分别为;

  1. Slow 1200mV 85C Model:芯片内核供电电压 1200mV,工作温度 85摄氏度情况下慢速传输模型。
  2. Slow 1200mV 0C Model:芯片内核供电电压 1200mV,工作温度 0摄氏度情况下慢速传输模型。
  3. Fast 1200mV 0C Model:芯片内核供电电压 1200mV,工作温度 0摄氏度情况下快速传输模型。

参考Slow 1200mV 85C Model,Fmax=250.13MHz,满足50M需求。

软件之所以标红,是由于目前没有添加时序约束,虽然变量名称带有50M,但EDA软件不会了解;软件默认按最高频率来约束,即1000MHz,但实际最高250.13MHz,认为没有满足需求,所以报错。

分析设计的时序路径,分析的是寄存器到寄存器,一般不跨寄存器分析。

软件计算最高时钟频率的时候,是根据最坏路径的建立时间余量来计算的。

  • 如何告知时序分析软件时钟频率是多少?

约束:时钟约束。

操作步骤:

  1. 打开TTA软件;
  2. 创建时序网表;
  3. 读取SDC文件;
  4. 看报告/加入约束;
  5. 写SDC文件。

约束的作用:

  1. 指导EDA软件对设计的布局布线进行合理优化以尽量满足约束需求;
  2. 给时序分析工具提供一个分析时序的参考;
相关推荐
碎碎思2 小时前
开源雷达做到20km?一个PLFM雷达项目的FPGA实现拆解
fpga开发
Saniffer_SH3 小时前
【市场洞察】一叶知秋 - 从2026年开年Quarch公司PCIe 6.0测试工具销售状况说起
服务器·人工智能·嵌入式硬件·测试工具·fpga开发·自动化·压力测试
何如呢6 小时前
FIFO的IP核学习
学习·fpga开发
我爱C编程6 小时前
【3.3】FFT变换的FPGA实现整体概述以及模块划分
fpga开发·fft·多级fft·二维分治fft
星华云6 小时前
[FPGA] Spartan6 单总线协议 (One-Wire) 读取DS18B20温度传感器
fpga开发·温度传感器·ds18b20·单总线协议·one-wire bus
s09071367 小时前
ZYNQ 软硬件协同踩坑日记:PS写BRAM后,PL端连续4个地址读出相同数据的原因与解决办法
fpga开发·zynq·硬件设计
tiger1191 天前
FPGA独立实现LLM推理方案——FlighLLM
fpga开发·llm·fpga·ai推理
fei_sun1 天前
Systemverilog和Verilog区别
fpga开发
史蒂芬_丁1 天前
TI F28P65 使用 ePWM 模块模拟 SPI 时钟的详细方法
单片机·嵌入式硬件·fpga开发
fei_sun1 天前
HDLBits-Verilog Practice
fpga开发