FPGA基于计数器的分频器时序违例的解决方法

现象:约束分频出来的时钟编译后:建立时间或保持时间违例。

原因:分频器关键路径过长。

解决方案:使用流水线优化。

XML 复制代码
// 流水线化分频器
module pipelined_divider (
    input wire clk_in,
    input wire rst_n,
    output reg clk_out
);

    reg [7:0] counter_pipe1, counter_pipe2;
    reg clk_out_pipe;

    // 第一级流水线
    always @(posedge clk_in or negedge rst_n) begin
        if (!rst_n) begin
            counter_pipe1 <= 0;
        end else begin
            counter_pipe1 <= counter_pipe1 + 1;
        end
    end

    // 第二级流水线
    always @(posedge clk_in or negedge rst_n) begin
        if (!rst_n) begin
            counter_pipe2 <= 0;
            clk_out_pipe <= 0;
        end else begin
            counter_pipe2 <= counter_pipe1;
            clk_out_pipe <= (counter_pipe2 == 255);
        end
    end

    // 输出寄存器
    always @(posedge clk_in or negedge rst_n) begin
        if (!rst_n) begin
            clk_out <= 0;
        end else begin
            clk_out <= clk_out_pipe;
        end
    end

endmodule
相关推荐
崇山峻岭之间10 小时前
单片机步进电机实验
单片机·嵌入式硬件
xiangw@GZ12 小时前
802.11全系列标准调制编码与速率档对应关系
网络·单片机·嵌入式硬件·架构
希希之光12 小时前
Aurix Tc3xx Port&Dio模块总结
单片机·嵌入式硬件
日拱一卒的小田12 小时前
ZYNQ学习笔记2-ZYNQ的UART控制器1
单片机·嵌入式硬件
我想走路带风13 小时前
OPENWRT-Day01
stm32·单片机·嵌入式硬件
ACP广源盛1392462567313 小时前
GSV2221@ACP#DP 1.4 MST 多屏转换芯片,物理 AI 多模态交互的视觉中枢
大数据·人工智能·嵌入式硬件·gpt·spark
云栖梦泽14 小时前
Linux内核与驱动:pinctl子系统和GPIO子系统
linux·单片机·嵌入式硬件
电气_空空14 小时前
基于 LabVIEW 的单片机串口通信设计
单片机·嵌入式硬件·毕业设计·labview
FPGA小徐16 小时前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
caimouse16 小时前
Reactos 第 9 章 设备驱动 — 9.10 磁盘的Miniport驱动模块
windows·嵌入式硬件