aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/io_cap_gen/catgen_ddr_cmos.v
blob: 017a2f43233b219def0045facc02383011bf3228 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
//
// Copyright 2014 Ettus Research LLC
// Copyright 2018 Ettus Research, a National Instruments Company
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//

module catgen_ddr_cmos
#(
  parameter DEVICE = "7SERIES" // "7SERIES" or "SPARTAN6"
)
(
  output        data_clk,
  input         mimo,
  output        tx_frame,
  output [11:0] tx_d,
  input         tx_clk,
  output reg    tx_strobe,
  input [11:0]  i0,
  input [11:0]  q0,
  input [11:0]  i1,
  input [11:0]  q1
);

  reg [11:0]      i,q;
  genvar          z;
  reg             tx_strobe_d;

  generate
    for(z = 0; z < 12; z = z + 1)
    begin : gen_pins
      if (DEVICE == "SPARTAN6") begin
        ODDR2 #(
          .DDR_ALIGNMENT("C0"), .SRTYPE("ASYNC"))
        oddr2 (
          .Q(tx_d[z]), .C0(tx_clk), .C1(~tx_clk),
          .CE(1'b1), .D0(i[z]), .D1(q[z]), .R(1'b0), .S(1'b0));
      end
      else if (DEVICE == "7SERIES") begin
        ODDR #(
          .DDR_CLK_EDGE("SAME_EDGE"), .SRTYPE("ASYNC"))
        oddr (
          .Q(tx_d[z]), .C(tx_clk),
          .CE(1'b1), .D1(i[z]), .D2(q[z]), .R(1'b0), .S(1'b0));
      end
    end
  endgenerate

  generate
    if (DEVICE == "SPARTAN6") begin
      ODDR2 #(
        .DDR_ALIGNMENT("C0"), .SRTYPE("ASYNC"))
      oddr2_frame (
        .Q(tx_frame), .C0(tx_clk), .C1(~tx_clk),
        .CE(1'b1), .D0(tx_strobe_d), .D1(mimo&tx_strobe_d), .R(1'b0), .S(1'b0));

      ODDR2 #(
        .DDR_ALIGNMENT("C0"), .SRTYPE("ASYNC"))
      oddr2_clk (
        .Q(data_clk), .C0(tx_clk), .C1(~tx_clk),
        .CE(1'b1), .D0(1'b1), .D1(1'b0), .R(1'b0), .S(1'b0));
    end
    else if (DEVICE == "7SERIES") begin
      ODDR #(
        .DDR_CLK_EDGE("SAME_EDGE"), .SRTYPE("ASYNC"))
      oddr_frame (
        .Q(tx_frame), .C(tx_clk),
        .CE(1'b1), .D1(tx_strobe_d), .D2(mimo&tx_strobe_d), .R(1'b0), .S(1'b0));

      ODDR #(
        .DDR_CLK_EDGE("SAME_EDGE"), .SRTYPE("ASYNC"))
      oddr_clk (
        .Q(data_clk), .C(tx_clk),
        .CE(1'b1), .D1(1'b1), .D2(1'b0), .R(1'b0), .S(1'b0));
    end
  endgenerate

  always @(posedge tx_clk)
    tx_strobe <= (mimo)? ~tx_strobe : 1'b1;

  always @(posedge tx_clk)
    tx_strobe_d <= tx_strobe;

  always @(posedge tx_clk)
    if(tx_strobe)
      {i,q} <= {i0,q0};
    else
      {i,q} <= {i1,q1};

endmodule // catgen_ddr_cmos