xilinx的oddr原语是否可以直接使用verilog实现?

一、是否可以

1.就我个人而言,虽然知道内部怎么实现的,但是目前我不知道怎么用verilog来实现

2.就目前了解,ODDR底层不是纯verilog来实现的,而是通过硬核来实现的

3.其本质是一个专用的选择器(Multiplexer) 和触发器(Flip-Flop) 的组合。

二、为啥不能用普通verilog来直接实现等效

1.时序性能

IOB这些电路是物理上最靠近IOB引脚的位置,其路径是经过精细该设计和优化的,

从而保证在极低的时钟到输出的延迟,非常潇的skew。通过普通的verilog代码在

FPGA fabric可编程逻辑区中实现的逻辑,其延迟和skew不确定性都会很大,不能

完全满足DDR时序要求。

2.时钟处理

普通逻辑无法直接使用一个时钟的正负边沿区驱动两个触发器,然后完美的去控制

MUX的切换时间,这个通过模拟电路或者数字集成电路就很好实现。

3.可靠性

专用硬件电路的行为是确定和可靠的。而用通用逻辑实现DDR功能,在高速率下很容易出现毛刺和时序违例。

三、功能模型

module oddr_model #(

parameter DDR_CLK_EDGE = "OPPOSITE_EDGE", // 模拟模式参数

parameter INIT = 1'b0, // 初始值

parameter SRTYPE = "SYNC" // 复位类型,本例只做简单同步

)(

output reg Q,

input C,

input CE,

input D1,

input D2,

input R,

input S

);

reg d1_reg, d2_reg;

// 上升沿触发的触发器,捕获D1

always @(posedge C) begin

if (R) begin

d1_reg <= 1'b0;

end else if (S) begin

d1_reg <= 1'b1;

end else if (CE) begin

d1_reg <= D1;

end

end

// 下降沿触发的触发器,捕获D2

always @(negedge C) begin

if (R) begin

d2_reg <= 1'b0;

end else if (S) begin

d2_reg <= 1'b1;

end else if (CE) begin

d2_reg <= D2;

end

end

// 用时钟选择要输出的数据

// 注意:实际硬件中这个MUX的切换速度极快,这里只是行为模拟

always @(*) begin

if (C) begin

Q = d1_reg; // 时钟高电平时,输出上升沿采样的D1

end else begin

Q = d2_reg; // 时钟低电平时,输出下降沿采样的D2

end

end

endmodule

四、接口

// 首先需要包含Xilinx的原语库,但通常Vivado会自动识别,无需手动include

// 直接实例化即可

ODDR #(

.DDR_CLK_EDGE("OPPOSITE_EDGE"), // "OPPOSITE_EDGE" or "SAME_EDGE"

.INIT(1'b0), // Initial value of Q

.SRTYPE("SYNC") // Reset type: "SYNC" or "ASYNC"

) ODDR_inst (

.Q(Q), // 1-bit DDR output

.C(C), // 1-bit clock input

.CE(CE), // 1-bit clock enable input

.D1(D1), // 1-bit data input (for positive edge)

.D2(D2), // 1-bit data input (for negative edge)

.R(R), // 1-bit reset

.S(S) // 1-bit set

);

相关推荐
szxinmai主板定制专家18 小时前
RK3568 + CODESYS+实时系统运动控制器PLC,支持 AI 视觉目标检测,预测性维护,混合多系统部署,多路模拟量采集
arm开发·人工智能·嵌入式硬件·fpga开发
GateWorld20 小时前
LCD显示技术完全指南:原理·制造·驱动·FPGA实现之驱动二
fpga开发·lcd显示·fpga点亮屏幕·minilvds
GateWorld1 天前
LCD显示技术完全指南:原理·制造·驱动·FPGA实现之驱动一
fpga开发·lcd显示·minilvds·fpga点屏
XMAIPC_Robot1 天前
深度无人机自动驾驶仪,中小型无人机硬件在环仿真飞行
运维·arm开发·人工智能·fpga开发·无人机·边缘计算
小眼睛FPGA2 天前
【紫光HiYou开源入门轻量级PCIE开发板PG2L25G】实验例程1-基于紫光FPGA 的LED 流水灯
fpga开发
不会武功的火柴2 天前
SystemVerilog语法(8)-有限状态机(FSM)
嵌入式硬件·fpga开发·自动化·ic验证·rtl·uvm方法学
Kent Gu2 天前
Lattice FPGA选型
fpga开发
Terasic友晶科技2 天前
答疑解惑|为DE25-Nano开发板配置Linux kernel时.config文件没有起作用是什么原因?
linux·服务器·fpga开发·linux kernel·de25-nano
8K超高清2 天前
CCBN展会多图回顾
人工智能·算法·fpga开发·接口隔离原则·智能硬件
小眼睛FPGA2 天前
【紫光HiYou开源入门轻量级PCIE开发板PG2L25G】实验例程5-DDR3 读写实验例程
fpga开发