FPGA设计时序分析三、恢复/去除时间

目录

一、背景说明

二、工程设计

[2.1 工程代码](#2.1 工程代码)

[2.2 综合结果](#2.2 综合结果)


一、背景说明

​恢复时间recovery和去除时间removal和setup、holdup类型,不同点是数据信号为控制信号,如复位,清零,使能信号,更多的是异步的复位信号,并且是针对复位信号取消时的上升沿。

​recovery: 复位取消信号需在时钟信号到达之前的recovery时间内稳定下来,保证复位完全释放

​removal: 复位消信号需在时钟信号到达后保持至少removal时间,保证复位信号有效

二、工程设计

​目前寄存器都采用异步复位,同步释放,复位可以不依靠时钟,实现简单,同时可以稳定释放复位信号,不出现亚稳态问题

2.1 工程代码

复制代码
module RST (clk,rst,d,out);
input      clk;
input      rst;
input      d;
output reg out;
reg rst_s1,rst_s2;
always @(posedge clk or negedge rst) begin
   if(!rst) begin
       rst_s1<= 1'b0;         //异步复位操作
       rst_s2<= 1'b0;
   end
   else begin
       rst_s1<= 1'b1;         //同步释放
       rst_s2 <= rst_s1;      //对同步释放后的复位信号延迟一拍,即最终复位信号为rst_s2
   end
end

always@(posedge clk,negedge rst_s2)
begin
 if (!rst_s2) 
    out <= 1'b0; 
 else 
    out <= d;
end

endmodule

2.2 综合结果

​在3个FDCE的CLR端口前面都插入了LUT1,作用是作为反相器,因为FDCE的CLR是高电平有效,源码设计中为低电平进行有效复位。复位信号rst是经过两拍之后在out_reg中使用。

相关推荐
Turing_kun2 小时前
基于FPGA的实时图像处理系统(1)——SDRAM回环测试
fpga开发
I'm a winner1 天前
新手入门Makefile:FPGA项目实战教程(二)
笔记·fpga开发
我爱C编程1 天前
基于FPGA的8PSK+卷积编码Viterbi译码通信系统,包含帧同步,信道,误码统计,可设置SNR
fpga开发·通信·8psk·帧同步·snr·卷积编码·维特比译码
I'm a winner1 天前
新手入门 Makefile:FPGA 项目实战教程(三)
fpga开发
范纹杉想快点毕业1 天前
嵌入式 C 语言编程规范个人学习笔记,参考华为《C 语言编程规范》
linux·服务器·数据库·笔记·单片机·嵌入式硬件·fpga开发
lazyduck2 天前
从半年到一年的 bug 往事:TCP modbus的卡死与补救
fpga开发·modbus
范纹杉想快点毕业2 天前
《嵌入式 C 语言编码规范与工程实践个人笔记》参考华为C语言规范标准
服务器·c语言·stm32·单片机·华为·fpga开发·51单片机
Chipi Chipi3 天前
FPGA即插即用Verilog驱动系列——串口数据、命令解析
fpga开发
FPGA_ADDA3 天前
基于 AMDXCVU47P HBM2 FPGA 的 2 路 100G 光纤 PCIe 高性能计算加速卡
fpga开发·vu47p·100g光纤pcie·高性能计算加速卡
霖003 天前
高级项目——基于FPGA的串行FIR滤波器
人工智能·经验分享·matlab·fpga开发·信息与通信·信号处理