FPGA基础知识(1)原语

原语,即primitive。不同的厂商,原语不同;同一家的FPGA,不同型号的芯片,可以也不一样;原语类似最底层的描述方法。使用原语的好处,可以直接例化使用,不用定制IP;即可通过复制原语的语句,然后例化IP,就可使用;Xilinx是通过直接修改原语中的参数再例化IP来使用;Xilinx公司的原语分为10类,包括:计算组件,IO端口组件,寄存器/锁存器,时钟组件,处理器组件,移位寄存器,配置和检测组件,RAM/ROM组件,Slice/CLB组件,G-tranceiver。 项目中主要用到的原语与IO端口有关,下面着重介绍实际中所用到的几个原语,芯片V7系列。

1. IBUF和IBUFDS

IBUF是输入缓存,IBUFDS是IBUF的差分形式,支持低压差分信号(如LVCMOS、LVDS等)。 举例说明: LVDS_25的差分输入的ADC数据。
IBUFDS #(                           // 差分输入原语,用于LVDS_25端口
            .DIFF_TERM("TRUE"),
            .IOSTANDARD("LVDS_25")
        ) IBUFDS_ADC01 (
            .O(ADC01_D[i]),
            .I(ADC01_P_D[i]),
            .IB(ADC01_N_D[i])
        );

2. IDDR

被设计用来接收DDR数据,避免额外的时序复杂性。

3. IBUFG和IBUFGDS

IBUFG即输入全局缓冲,是与专用全局时钟输入管脚相连接的首级全局缓冲。所有从全局时钟管脚输入的信号必须经过IBUF元,否则在布局布线时会报错。 IBUFGDS是IBUFG的差分形式,当信号从一对差分全局时钟管脚输入时,必须使用IBUFGDS作为全局时钟输入缓冲。
posted @ 2021-09-10 15:45  27岁的太阳  阅读(862)  评论(0编辑  收藏  举报