FPGA原语之IDDR/ODDR

IDDR/ODDR

1. IDDR

IDDR的VHDL例化如下。

IDDR_inst : IDDR
   generic map (
      DDR_CLK_EDGE => "OPPOSITE_EDGE", -- "OPPOSITE_EDGE", "SAME_EDGE"
                                       -- or "SAME_EDGE_PIPELINED"
      INIT_Q1 => '0', -- Initial value of Q1: '0' or '1'
      INIT_Q2 => '0', -- Initial value of Q2: '0' or '1'
      SRTYPE => "SYNC") -- Set/Reset type: "SYNC" or "ASYNC"
   port map (
      Q1 => Q1, -- 1-bit output for positive edge of clock
      Q2 => Q2, -- 1-bit output for negative edge of clock
      C => C,   -- 1-bit clock input
      CE => CE, -- 1-bit clock enable input
      D => D,   -- 1-bit DDR data input
      R => R,   -- 1-bit reset
      S => S    -- 1-bit set
      );

对于DDR_CLK_EDGE主要有三种模式,分别是OPPOSITE_EDGESAME_EDGE以及SAME_EDGE_PIPELINED。这三种模式的时序图如下。

image

image

image

根据上面时序关系可以看出,在OPPOSITE模式下,Q1与Q2没有对齐,两者的时序关系是异步的;在SAME_EDGE模式下,Q1与Q2时序对齐,但是并不是同时出现,Q2上的数据落后Q1一个时钟周期;在SAME_EDGE_PIPELINED模式下,Q1与Q2时序对齐,并且同时出现在数据口上。相比于前两种模式,SAME_EDGE_PIPELINED消耗的资源更多一些。

2. ODDR

ODDR的VHDL例化如下。

ODDR_inst : ODDR
   generic map(
      DDR_CLK_EDGE => "OPPOSITE_EDGE", -- "OPPOSITE_EDGE" or "SAME_EDGE"
      INIT => '0',   -- Initial value for Q port ('1' or '0')
      SRTYPE => "SYNC") -- Reset Type ("ASYNC" or "SYNC")
   port map (
      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 (positive edge)
      D2 => D2,  -- 1-bit data input (negative edge)
      R => R,    -- 1-bit reset input
      S => S     -- 1-bit set input
   );

对于DDR_CLK_EDGE主要有两种模式,分别是OPPOSITE_EDGESAME_EDGE,时序图如下。

image

image

image

根据上面时序关系可以看出,在OPPOSITE模式下,D1与D2没有对齐,两者的时序关系是异步的,时钟分别在上升沿和下降沿对D1和D2进行采样;在SAME_EDGE模式下,D1与D2时序对齐,在时钟的上升沿对D1与D2同时采样,采用这种模式可以获得更好的性能。

  • 4
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值