aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/io_cap_gen/catcap_ddr_cmos.v
blob: bb4c77f0deec9215d93783b455d371c3173dc0f3 (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
91
92
93
94
95
//
// Copyright 2014 Ettus Research LLC
// Copyright 2018 Ettus Research, a National Instruments Company
//
// SPDX-License-Identifier: LGPL-3.0-or-later
//

module catcap_ddr_cmos
#(
  parameter DEVICE = "7SERIES" // "7SERIES" or "SPARTAN6"
)
(
  input             data_clk,
  input             mimo,
  input             rx_frame,
  input [11:0]      rx_d,
  output            rx_clk, output rx_strobe,
  output reg [11:0] i0, output reg [11:0] q0,
  output reg [11:0] i1, output reg [11:0] q1
);

  wire [11:0]       i,q;
  wire              frame_0, frame_1;

  genvar            z;

  generate
    for(z = 0; z < 12; z = z + 1)
      begin : gen_pins
        if (DEVICE == "SPARTAN6") begin
          // i[] & q[] swapped
          IDDR2 #(
            .DDR_ALIGNMENT("C0"))
          iddr2 (
            .Q0(q[z]), .Q1(i[z]), .C0(data_clk), .C1(~data_clk),
            .CE(1'b1), .D(rx_d[z]), .R(1'b0), .S(1'b0));
        end
        else if (DEVICE == "7SERIES") begin
          IDDR #(
            .DDR_CLK_EDGE("SAME_EDGE"))
          iddr (
            .Q1(q[z]), .Q2(i[z]), .C(data_clk),
            .CE(1'b1), .D(rx_d[z]), .R(1'b0), .S(1'b0));
        end
      end
  endgenerate

  generate
    if (DEVICE == "SPARTAN6") begin
      IDDR2 #(
        .DDR_ALIGNMENT("C0"))
      iddr2_frame (
        .Q0(frame_0), .Q1(frame_1), .C0(data_clk), .C1(~data_clk),
        .CE(1'b1), .D(rx_frame), .R(1'b0), .S(1'b0));
    end
    else if (DEVICE == "7SERIES") begin
      IDDR #(
        .DDR_CLK_EDGE("SAME_EDGE"))
      iddr_frame (
        .Q1(frame_0), .Q2(frame_1), .C(data_clk),
        .CE(1'b1), .D(rx_frame), .R(1'b0), .S(1'b0));
    end
  endgenerate

  reg frame_d1, frame_d2;
  always @(posedge data_clk)
    if(~mimo)
      { frame_d2, frame_d1 } <= { frame_1, 1'b0 };
    else
      { frame_d2, frame_d1 } <= { frame_d1, frame_1 };

  assign rx_strobe = frame_d2;

  reg [11:0] i_del, q_del;
  always @(posedge data_clk)
    if(mimo)
      if(frame_0) begin
        i_del <= i;
        q_del <= q;
      end
      else begin
        i1 <= i;
        q1 <= q;
        i0 <= i_del;
        q0 <= q_del;
    end
    else begin
      i0 <= i;
      q0 <= q;
      i1 <= i;
      q1 <= q;
    end
  assign rx_clk = data_clk;

endmodule // catcap_ddr_cmos