IBUF和BUFG

在代码中,DATA_INCLK_IN 都通过IBUF实例进行缓冲。IBUF负责将外部信号转换到FPGA内部标准并驱动内部信号线。这不仅在物理上是必要的一步(没有IBUF就无法直接驱动内部逻辑),而且还允许我们指定引脚的约束(如电平标准等)。

BUFG 全局时钟缓冲bufg_clk 实例将时钟连接到了全局时钟网络。这样做的直接好处是降低时钟的偏斜(skew)抖动(jitter)。时钟偏斜指FPGA内不同触发器接收到同一时钟沿的时间差。如果不使用BUFG,时钟可能走一般的可编程布线,导致不同区域时钟延迟不同,偏斜增大。

参考代码:

复制代码
// 顶层模块:演示 IBUF 和 BUFG 的使用
module top_example (
    input  wire CLK_IN,   // 外部时钟输入,引脚上提供
    input  wire RST_N,    // 外部复位输入,低电平有效
    input  wire DATA_IN,  // 外部数据输入信号
    output reg  DATA_OUT  // 输出寄存后的数据
);

// 中间信号定义
wire clk_ibuf;   // 时钟经IBUF后的内部信号
wire clk_bufg;   // 时钟经BUFG后的全局时钟信号
wire data_buf;   // 数据经IBUF缓冲后的内部信号

// 1) 输入数据的缓冲:将外部DATA_IN通过IBUF转换为内部信号data_buf
IBUF ibuf_data (
    .I(DATA_IN),   // 外部引脚信号
    .O(data_buf)   // 缓冲后的内部信号
);

// 2) 外部时钟的缓冲:先通过IBUF,再送入BUFG实现全局分布
IBUF ibuf_clk (
    .I(CLK_IN),    // 外部时钟引脚
    .O(clk_ibuf)   // IBUF输出的内部时钟
);
BUFG bufg_clk (
    .I(clk_ibuf),  // BUFG输入连接IBUF的输出
    .O(clk_bufg)   // BUFG输出作为全局时钟
);

// 3) 使用全局时钟(clk_bufg)对数据进行寄存,同步输出
always @(posedge clk_bufg or negedge RST_N) begin
    if (!RST_N)
        DATA_OUT <= 1'b0;       // 异步复位:复位时输出清零
    else
        DATA_OUT <= data_buf;   // 时钟上升沿,将缓冲后的数据锁存到输出寄存器
end

endmodule
相关推荐
坏孩子的诺亚方舟11 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐11 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐11 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH12 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡12 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安12 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐13 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯13 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客13 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA13 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发