eth/example/HTG_ZRF8: Add example design for HTG-ZRF8-EM and HTG-ZRF8-R2
Signed-off-by: Alex Forencich <alex@alexforencich.com>
This commit is contained in:
610
src/eth/example/HTG_ZRF8/fpga/rtl/fpga_core.sv
Normal file
610
src/eth/example/HTG_ZRF8/fpga/rtl/fpga_core.sv
Normal file
@@ -0,0 +1,610 @@
|
||||
// SPDX-License-Identifier: MIT
|
||||
/*
|
||||
|
||||
Copyright (c) 2021-2025 FPGA Ninja, LLC
|
||||
|
||||
Authors:
|
||||
- Alex Forencich
|
||||
|
||||
*/
|
||||
|
||||
`resetall
|
||||
`timescale 1ns / 1ps
|
||||
`default_nettype none
|
||||
|
||||
/*
|
||||
* FPGA core logic
|
||||
*/
|
||||
module fpga_core #
|
||||
(
|
||||
parameter logic SIM = 1'b0,
|
||||
parameter string VENDOR = "XILINX",
|
||||
parameter string FAMILY = "zynquplusRFSOC",
|
||||
parameter PORT_CNT = 2,
|
||||
parameter GTY_QUAD_CNT = PORT_CNT,
|
||||
parameter GTY_CNT = GTY_QUAD_CNT*4,
|
||||
parameter GTY_CLK_CNT = GTY_QUAD_CNT,
|
||||
parameter ADC_CNT = 8,
|
||||
parameter DAC_CNT = ADC_CNT
|
||||
)
|
||||
(
|
||||
/*
|
||||
* Clock: 125MHz
|
||||
* Synchronous reset
|
||||
*/
|
||||
input wire logic clk_125mhz,
|
||||
input wire logic rst_125mhz,
|
||||
input wire logic fpga_refclk,
|
||||
input wire logic fpga_sysref,
|
||||
|
||||
/*
|
||||
* GPIO
|
||||
*/
|
||||
input wire logic [3:0] sw,
|
||||
output wire logic [3:0] led,
|
||||
output wire logic [7:0] gpio,
|
||||
|
||||
/*
|
||||
* I2C for board management
|
||||
*/
|
||||
input wire logic i2c_scl_i,
|
||||
output wire logic i2c_scl_o,
|
||||
input wire logic i2c_sda_i,
|
||||
output wire logic i2c_sda_o,
|
||||
|
||||
/*
|
||||
* UART: 921600 bps, 8N1
|
||||
*/
|
||||
output wire logic uart_rxd,
|
||||
input wire logic uart_txd,
|
||||
input wire logic uart_rts,
|
||||
output wire logic uart_cts,
|
||||
output wire logic uart_rst_n,
|
||||
input wire logic uart_suspend_n,
|
||||
|
||||
/*
|
||||
* Ethernet: QSFP28
|
||||
*/
|
||||
output wire logic [GTY_CNT-1:0] eth_gty_tx_p,
|
||||
output wire logic [GTY_CNT-1:0] eth_gty_tx_n,
|
||||
input wire logic [GTY_CNT-1:0] eth_gty_rx_p,
|
||||
input wire logic [GTY_CNT-1:0] eth_gty_rx_n,
|
||||
input wire logic [GTY_CLK_CNT-1:0] eth_gty_mgt_refclk_p,
|
||||
input wire logic [GTY_CLK_CNT-1:0] eth_gty_mgt_refclk_n,
|
||||
output wire logic [GTY_CLK_CNT-1:0] eth_gty_mgt_refclk_out,
|
||||
|
||||
output wire logic [PORT_CNT-1:0] eth_port_resetl,
|
||||
input wire logic [PORT_CNT-1:0] eth_port_modprsl,
|
||||
input wire logic [PORT_CNT-1:0] eth_port_intl,
|
||||
|
||||
/*
|
||||
* RFDC
|
||||
*/
|
||||
input wire logic axil_rfdc_clk,
|
||||
input wire logic axil_rfdc_rst,
|
||||
taxi_axil_if.wr_mst m_axil_rfdc_wr,
|
||||
taxi_axil_if.rd_mst m_axil_rfdc_rd,
|
||||
|
||||
input wire logic axis_rfdc_clk,
|
||||
input wire logic axis_rfdc_rst,
|
||||
taxi_axis_if.snk s_axis_adc[ADC_CNT],
|
||||
taxi_axis_if.src m_axis_dac[DAC_CNT]
|
||||
);
|
||||
|
||||
// XFCP
|
||||
taxi_axis_if #(.DATA_W(8), .USER_EN(1), .USER_W(1)) xfcp_ds(), xfcp_us();
|
||||
|
||||
assign uart_cts = 1'b1;
|
||||
assign uart_rst_n = 1'b1;
|
||||
|
||||
taxi_xfcp_if_uart #(
|
||||
.TX_FIFO_DEPTH(512),
|
||||
.RX_FIFO_DEPTH(512)
|
||||
)
|
||||
xfcp_if_uart_inst (
|
||||
.clk(clk_125mhz),
|
||||
.rst(rst_125mhz),
|
||||
|
||||
/*
|
||||
* UART interface
|
||||
*/
|
||||
.uart_rxd(uart_txd),
|
||||
.uart_txd(uart_rxd),
|
||||
|
||||
/*
|
||||
* XFCP downstream interface
|
||||
*/
|
||||
.xfcp_dsp_ds(xfcp_ds),
|
||||
.xfcp_dsp_us(xfcp_us),
|
||||
|
||||
/*
|
||||
* Configuration
|
||||
*/
|
||||
.prescale(16'(125000000/921600))
|
||||
);
|
||||
|
||||
taxi_axis_if #(.DATA_W(8), .USER_EN(1), .USER_W(1)) xfcp_sw_ds[3](), xfcp_sw_us[3]();
|
||||
|
||||
taxi_xfcp_switch #(
|
||||
.XFCP_ID_STR("HTG-ZRF8"),
|
||||
.XFCP_EXT_ID(0),
|
||||
.XFCP_EXT_ID_STR("Taxi example"),
|
||||
.PORTS($size(xfcp_sw_us))
|
||||
)
|
||||
xfcp_sw_inst (
|
||||
.clk(clk_125mhz),
|
||||
.rst(rst_125mhz),
|
||||
|
||||
/*
|
||||
* XFCP upstream port
|
||||
*/
|
||||
.xfcp_usp_ds(xfcp_ds),
|
||||
.xfcp_usp_us(xfcp_us),
|
||||
|
||||
/*
|
||||
* XFCP downstream ports
|
||||
*/
|
||||
.xfcp_dsp_ds(xfcp_sw_ds),
|
||||
.xfcp_dsp_us(xfcp_sw_us)
|
||||
);
|
||||
|
||||
// Statistics
|
||||
taxi_axis_if #(.DATA_W(16), .KEEP_W(1), .KEEP_EN(0), .LAST_EN(0), .USER_EN(1), .USER_W(1), .ID_EN(1), .ID_W(10)) axis_stat();
|
||||
|
||||
taxi_xfcp_mod_stats #(
|
||||
.XFCP_ID_STR("Statistics"),
|
||||
.XFCP_EXT_ID(0),
|
||||
.XFCP_EXT_ID_STR(""),
|
||||
.STAT_COUNT_W(64),
|
||||
.STAT_PIPELINE(2)
|
||||
)
|
||||
xfcp_stats_inst (
|
||||
.clk(clk_125mhz),
|
||||
.rst(rst_125mhz),
|
||||
|
||||
/*
|
||||
* XFCP upstream port
|
||||
*/
|
||||
.xfcp_usp_ds(xfcp_sw_ds[0]),
|
||||
.xfcp_usp_us(xfcp_sw_us[0]),
|
||||
|
||||
/*
|
||||
* Statistics increment input
|
||||
*/
|
||||
.s_axis_stat(axis_stat)
|
||||
);
|
||||
|
||||
taxi_axis_if #(.DATA_W(16), .KEEP_W(1), .KEEP_EN(0), .LAST_EN(0), .USER_EN(1), .USER_W(1), .ID_EN(1), .ID_W(axis_stat.ID_W)) axis_eth_stat[GTY_QUAD_CNT]();
|
||||
|
||||
taxi_axis_arb_mux #(
|
||||
.S_COUNT($size(axis_eth_stat)),
|
||||
.UPDATE_TID(1'b0),
|
||||
.ARB_ROUND_ROBIN(1'b1),
|
||||
.ARB_LSB_HIGH_PRIO(1'b0)
|
||||
)
|
||||
stat_mux_inst (
|
||||
.clk(clk_125mhz),
|
||||
.rst(rst_125mhz),
|
||||
|
||||
/*
|
||||
* AXI4-Stream inputs (sink)
|
||||
*/
|
||||
.s_axis(axis_eth_stat),
|
||||
|
||||
/*
|
||||
* AXI4-Stream output (source)
|
||||
*/
|
||||
.m_axis(axis_stat)
|
||||
);
|
||||
|
||||
// I2C
|
||||
taxi_xfcp_mod_i2c_master #(
|
||||
.DEFAULT_PRESCALE(16'(125000000/400000/4))
|
||||
)
|
||||
xfcp_mod_i2c_inst (
|
||||
.clk(clk_125mhz),
|
||||
.rst(rst_125mhz),
|
||||
|
||||
/*
|
||||
* XFCP upstream port
|
||||
*/
|
||||
.xfcp_usp_ds(xfcp_sw_ds[1]),
|
||||
.xfcp_usp_us(xfcp_sw_us[1]),
|
||||
|
||||
/*
|
||||
* I2C interface
|
||||
*/
|
||||
.i2c_scl_i(i2c_scl_i),
|
||||
.i2c_scl_o(i2c_scl_o),
|
||||
.i2c_sda_i(i2c_sda_i),
|
||||
.i2c_sda_o(i2c_sda_o)
|
||||
);
|
||||
|
||||
// RFDC control
|
||||
taxi_xfcp_mod_axil #(
|
||||
.XFCP_ID_STR("RFDC"),
|
||||
.COUNT_SIZE(16)
|
||||
)
|
||||
xfcp_mod_axil_inst (
|
||||
.clk(clk_125mhz),
|
||||
.rst(rst_125mhz),
|
||||
|
||||
/*
|
||||
* XFCP upstream port
|
||||
*/
|
||||
.xfcp_usp_ds(xfcp_sw_ds[2]),
|
||||
.xfcp_usp_us(xfcp_sw_us[2]),
|
||||
|
||||
/*
|
||||
* AXI lite master interface
|
||||
*/
|
||||
.m_axil_wr(m_axil_rfdc_wr),
|
||||
.m_axil_rd(m_axil_rfdc_rd)
|
||||
);
|
||||
|
||||
// Ethernet
|
||||
wire eth_reset = SIM ? 1'b0 : rst_125mhz;
|
||||
assign eth_port_resetl = {PORT_CNT{~eth_reset}};
|
||||
|
||||
wire [GTY_CNT-1:0] eth_gty_tx_clk;
|
||||
wire [GTY_CNT-1:0] eth_gty_tx_rst;
|
||||
taxi_axis_if #(.DATA_W(64), .ID_W(8)) eth_gty_axis_tx[GTY_CNT]();
|
||||
taxi_axis_if #(.DATA_W(96), .KEEP_W(1), .ID_W(8)) eth_gty_axis_tx_cpl[GTY_CNT]();
|
||||
|
||||
wire [GTY_CNT-1:0] eth_gty_rx_clk;
|
||||
wire [GTY_CNT-1:0] eth_gty_rx_rst;
|
||||
taxi_axis_if #(.DATA_W(64), .ID_W(8)) eth_gty_axis_rx[GTY_CNT]();
|
||||
|
||||
wire [GTY_CNT-1:0] eth_gty_rx_status;
|
||||
|
||||
wire [GTY_QUAD_CNT-1:0] eth_gty_gtpowergood;
|
||||
|
||||
wire [GTY_CLK_CNT-1:0] eth_gty_mgt_refclk;
|
||||
wire [GTY_CLK_CNT-1:0] eth_gty_mgt_refclk_bufg;
|
||||
|
||||
wire [GTY_CLK_CNT-1:0] eth_gty_rst;
|
||||
|
||||
for (genvar n = 0; n < GTY_CLK_CNT; n = n + 1) begin : gty_clk
|
||||
|
||||
wire eth_gty_mgt_refclk_int;
|
||||
|
||||
if (SIM) begin
|
||||
|
||||
assign eth_gty_mgt_refclk[n] = eth_gty_mgt_refclk_p[n];
|
||||
assign eth_gty_mgt_refclk_int = eth_gty_mgt_refclk_p[n];
|
||||
assign eth_gty_mgt_refclk_bufg[n] = eth_gty_mgt_refclk_int;
|
||||
|
||||
end else begin
|
||||
|
||||
IBUFDS_GTE4 ibufds_gte4_eth_gty_mgt_refclk_inst (
|
||||
.I (eth_gty_mgt_refclk_p[n]),
|
||||
.IB (eth_gty_mgt_refclk_n[n]),
|
||||
.CEB (1'b0),
|
||||
.O (eth_gty_mgt_refclk[n]),
|
||||
.ODIV2 (eth_gty_mgt_refclk_int)
|
||||
);
|
||||
|
||||
BUFG_GT bufg_gt_eth_gty_mgt_refclk_inst (
|
||||
.CE (ð_gty_gtpowergood),
|
||||
.CEMASK (1'b1),
|
||||
.CLR (1'b0),
|
||||
.CLRMASK (1'b1),
|
||||
.DIV (3'd0),
|
||||
.I (eth_gty_mgt_refclk_int),
|
||||
.O (eth_gty_mgt_refclk_bufg[n])
|
||||
);
|
||||
|
||||
end
|
||||
|
||||
assign eth_gty_mgt_refclk_out[n] = eth_gty_mgt_refclk_bufg[n];
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
qsfp_sync_reset_inst (
|
||||
.clk(eth_gty_mgt_refclk_bufg[n]),
|
||||
.rst(rst_125mhz || eth_reset),
|
||||
.out(eth_gty_rst[n])
|
||||
);
|
||||
|
||||
end
|
||||
|
||||
localparam logic [8*8-1:0] STAT_PREFIX_STR_QSFP1[4] = '{"QSFP1.1", "QSFP1.2", "QSFP1.3", "QSFP1.4"};
|
||||
localparam logic [8*8-1:0] STAT_PREFIX_STR_QSFP2[4] = '{"QSFP2.1", "QSFP2.2", "QSFP2.3", "QSFP2.4"};
|
||||
|
||||
for (genvar n = 0; n < GTY_QUAD_CNT; n = n + 1) begin : gty_quad
|
||||
|
||||
localparam CLK = n;
|
||||
localparam CNT = 4;
|
||||
|
||||
taxi_eth_mac_25g_us #(
|
||||
.SIM(SIM),
|
||||
.VENDOR(VENDOR),
|
||||
.FAMILY(FAMILY),
|
||||
|
||||
.CNT(CNT),
|
||||
|
||||
// GT config
|
||||
.CFG_LOW_LATENCY(1),
|
||||
|
||||
// GT type
|
||||
.GT_TYPE("GTY"),
|
||||
|
||||
// PHY parameters
|
||||
.PADDING_EN(1'b1),
|
||||
.DIC_EN(1'b1),
|
||||
.MIN_FRAME_LEN(64),
|
||||
.PTP_TS_EN(1'b0),
|
||||
.PTP_TS_FMT_TOD(1'b1),
|
||||
.PTP_TS_W(96),
|
||||
.PRBS31_EN(1'b0),
|
||||
.TX_SERDES_PIPELINE(1),
|
||||
.RX_SERDES_PIPELINE(1),
|
||||
.COUNT_125US(125000/6.4),
|
||||
.STAT_EN(1),
|
||||
.STAT_TX_LEVEL(1),
|
||||
.STAT_RX_LEVEL(1),
|
||||
.STAT_ID_BASE(n*CNT*(16+16)),
|
||||
.STAT_UPDATE_PERIOD(1024),
|
||||
.STAT_STR_EN(1),
|
||||
.STAT_PREFIX_STR(
|
||||
n == 0 ? STAT_PREFIX_STR_QSFP1 :
|
||||
STAT_PREFIX_STR_QSFP2
|
||||
)
|
||||
)
|
||||
mac_inst (
|
||||
.xcvr_ctrl_clk(clk_125mhz),
|
||||
.xcvr_ctrl_rst(eth_gty_rst[CLK]),
|
||||
|
||||
/*
|
||||
* Common
|
||||
*/
|
||||
.xcvr_gtpowergood_out(eth_gty_gtpowergood[n]),
|
||||
.xcvr_gtrefclk00_in(eth_gty_mgt_refclk[CLK]),
|
||||
.xcvr_qpll0pd_in(1'b0),
|
||||
.xcvr_qpll0reset_in(1'b0),
|
||||
.xcvr_qpll0pcierate_in(3'd0),
|
||||
.xcvr_qpll0lock_out(),
|
||||
.xcvr_qpll0clk_out(),
|
||||
.xcvr_qpll0refclk_out(),
|
||||
.xcvr_gtrefclk01_in(eth_gty_mgt_refclk[CLK]),
|
||||
.xcvr_qpll1pd_in(1'b0),
|
||||
.xcvr_qpll1reset_in(1'b0),
|
||||
.xcvr_qpll1pcierate_in(3'd0),
|
||||
.xcvr_qpll1lock_out(),
|
||||
.xcvr_qpll1clk_out(),
|
||||
.xcvr_qpll1refclk_out(),
|
||||
|
||||
/*
|
||||
* Serial data
|
||||
*/
|
||||
.xcvr_txp(eth_gty_tx_p[n*CNT +: CNT]),
|
||||
.xcvr_txn(eth_gty_tx_n[n*CNT +: CNT]),
|
||||
.xcvr_rxp(eth_gty_rx_p[n*CNT +: CNT]),
|
||||
.xcvr_rxn(eth_gty_rx_n[n*CNT +: CNT]),
|
||||
|
||||
/*
|
||||
* MAC clocks
|
||||
*/
|
||||
.rx_clk(eth_gty_rx_clk[n*CNT +: CNT]),
|
||||
.rx_rst_in('0),
|
||||
.rx_rst_out(eth_gty_rx_rst[n*CNT +: CNT]),
|
||||
.tx_clk(eth_gty_tx_clk[n*CNT +: CNT]),
|
||||
.tx_rst_in('0),
|
||||
.tx_rst_out(eth_gty_tx_rst[n*CNT +: CNT]),
|
||||
.ptp_sample_clk('0),
|
||||
|
||||
/*
|
||||
* Transmit interface (AXI stream)
|
||||
*/
|
||||
.s_axis_tx(eth_gty_axis_tx[n*CNT +: CNT]),
|
||||
.m_axis_tx_cpl(eth_gty_axis_tx_cpl[n*CNT +: CNT]),
|
||||
|
||||
/*
|
||||
* Receive interface (AXI stream)
|
||||
*/
|
||||
.m_axis_rx(eth_gty_axis_rx[n*CNT +: CNT]),
|
||||
|
||||
/*
|
||||
* PTP clock
|
||||
*/
|
||||
.tx_ptp_ts('{CNT{'0}}),
|
||||
.tx_ptp_ts_step('0),
|
||||
.rx_ptp_ts('{CNT{'0}}),
|
||||
.rx_ptp_ts_step('0),
|
||||
|
||||
/*
|
||||
* Link-level Flow Control (LFC) (IEEE 802.3 annex 31B PAUSE)
|
||||
*/
|
||||
.tx_lfc_req('0),
|
||||
.tx_lfc_resend('0),
|
||||
.rx_lfc_en('0),
|
||||
.rx_lfc_req(),
|
||||
.rx_lfc_ack('0),
|
||||
|
||||
/*
|
||||
* Priority Flow Control (PFC) (IEEE 802.3 annex 31D PFC)
|
||||
*/
|
||||
.tx_pfc_req('{CNT{'0}}),
|
||||
.tx_pfc_resend('0),
|
||||
.rx_pfc_en('{CNT{'0}}),
|
||||
.rx_pfc_req(),
|
||||
.rx_pfc_ack('{CNT{'0}}),
|
||||
|
||||
/*
|
||||
* Pause interface
|
||||
*/
|
||||
.tx_lfc_pause_en('0),
|
||||
.tx_pause_req('0),
|
||||
.tx_pause_ack(),
|
||||
|
||||
/*
|
||||
* Statistics
|
||||
*/
|
||||
.stat_clk(clk_125mhz),
|
||||
.stat_rst(rst_125mhz),
|
||||
.m_axis_stat(axis_eth_stat[n]),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.tx_start_packet(),
|
||||
.stat_tx_byte(),
|
||||
.stat_tx_pkt_len(),
|
||||
.stat_tx_pkt_ucast(),
|
||||
.stat_tx_pkt_mcast(),
|
||||
.stat_tx_pkt_bcast(),
|
||||
.stat_tx_pkt_vlan(),
|
||||
.stat_tx_pkt_good(),
|
||||
.stat_tx_pkt_bad(),
|
||||
.stat_tx_err_oversize(),
|
||||
.stat_tx_err_user(),
|
||||
.stat_tx_err_underflow(),
|
||||
.rx_start_packet(),
|
||||
.rx_error_count(),
|
||||
.rx_block_lock(),
|
||||
.rx_high_ber(),
|
||||
.rx_status(eth_gty_rx_status[n*CNT +: CNT]),
|
||||
.stat_rx_byte(),
|
||||
.stat_rx_pkt_len(),
|
||||
.stat_rx_pkt_fragment(),
|
||||
.stat_rx_pkt_jabber(),
|
||||
.stat_rx_pkt_ucast(),
|
||||
.stat_rx_pkt_mcast(),
|
||||
.stat_rx_pkt_bcast(),
|
||||
.stat_rx_pkt_vlan(),
|
||||
.stat_rx_pkt_good(),
|
||||
.stat_rx_pkt_bad(),
|
||||
.stat_rx_err_oversize(),
|
||||
.stat_rx_err_bad_fcs(),
|
||||
.stat_rx_err_bad_block(),
|
||||
.stat_rx_err_framing(),
|
||||
.stat_rx_err_preamble(),
|
||||
.stat_rx_fifo_drop('0),
|
||||
.stat_tx_mcf(),
|
||||
.stat_rx_mcf(),
|
||||
.stat_tx_lfc_pkt(),
|
||||
.stat_tx_lfc_xon(),
|
||||
.stat_tx_lfc_xoff(),
|
||||
.stat_tx_lfc_paused(),
|
||||
.stat_tx_pfc_pkt(),
|
||||
.stat_tx_pfc_xon(),
|
||||
.stat_tx_pfc_xoff(),
|
||||
.stat_tx_pfc_paused(),
|
||||
.stat_rx_lfc_pkt(),
|
||||
.stat_rx_lfc_xon(),
|
||||
.stat_rx_lfc_xoff(),
|
||||
.stat_rx_lfc_paused(),
|
||||
.stat_rx_pfc_pkt(),
|
||||
.stat_rx_pfc_xon(),
|
||||
.stat_rx_pfc_xoff(),
|
||||
.stat_rx_pfc_paused(),
|
||||
|
||||
/*
|
||||
* Configuration
|
||||
*/
|
||||
.cfg_tx_max_pkt_len('{CNT{16'd9218}}),
|
||||
.cfg_tx_ifg('{CNT{8'd12}}),
|
||||
.cfg_tx_enable('1),
|
||||
.cfg_rx_max_pkt_len('{CNT{16'd9218}}),
|
||||
.cfg_rx_enable('1),
|
||||
.cfg_tx_prbs31_enable('0),
|
||||
.cfg_rx_prbs31_enable('0),
|
||||
.cfg_mcf_rx_eth_dst_mcast('{CNT{48'h01_80_C2_00_00_01}}),
|
||||
.cfg_mcf_rx_check_eth_dst_mcast('1),
|
||||
.cfg_mcf_rx_eth_dst_ucast('{CNT{48'd0}}),
|
||||
.cfg_mcf_rx_check_eth_dst_ucast('0),
|
||||
.cfg_mcf_rx_eth_src('{CNT{48'd0}}),
|
||||
.cfg_mcf_rx_check_eth_src('0),
|
||||
.cfg_mcf_rx_eth_type('{CNT{16'h8808}}),
|
||||
.cfg_mcf_rx_opcode_lfc('{CNT{16'h0001}}),
|
||||
.cfg_mcf_rx_check_opcode_lfc('1),
|
||||
.cfg_mcf_rx_opcode_pfc('{CNT{16'h0101}}),
|
||||
.cfg_mcf_rx_check_opcode_pfc('1),
|
||||
.cfg_mcf_rx_forward('0),
|
||||
.cfg_mcf_rx_enable('0),
|
||||
.cfg_tx_lfc_eth_dst('{CNT{48'h01_80_C2_00_00_01}}),
|
||||
.cfg_tx_lfc_eth_src('{CNT{48'h80_23_31_43_54_4C}}),
|
||||
.cfg_tx_lfc_eth_type('{CNT{16'h8808}}),
|
||||
.cfg_tx_lfc_opcode('{CNT{16'h0001}}),
|
||||
.cfg_tx_lfc_en('0),
|
||||
.cfg_tx_lfc_quanta('{CNT{16'hffff}}),
|
||||
.cfg_tx_lfc_refresh('{CNT{16'h7fff}}),
|
||||
.cfg_tx_pfc_eth_dst('{CNT{48'h01_80_C2_00_00_01}}),
|
||||
.cfg_tx_pfc_eth_src('{CNT{48'h80_23_31_43_54_4C}}),
|
||||
.cfg_tx_pfc_eth_type('{CNT{16'h8808}}),
|
||||
.cfg_tx_pfc_opcode('{CNT{16'h0101}}),
|
||||
.cfg_tx_pfc_en('0),
|
||||
.cfg_tx_pfc_quanta('{CNT{'{8{16'hffff}}}}),
|
||||
.cfg_tx_pfc_refresh('{CNT{'{8{16'h7fff}}}}),
|
||||
.cfg_rx_lfc_opcode('{CNT{16'h0001}}),
|
||||
.cfg_rx_lfc_en('0),
|
||||
.cfg_rx_pfc_opcode('{CNT{16'h0101}}),
|
||||
.cfg_rx_pfc_en('0)
|
||||
);
|
||||
|
||||
end
|
||||
|
||||
for (genvar n = 0; n < GTY_CNT; n = n + 1) begin : gty_ch
|
||||
|
||||
taxi_axis_async_fifo #(
|
||||
.DEPTH(16384),
|
||||
.RAM_PIPELINE(2),
|
||||
.FRAME_FIFO(1),
|
||||
.USER_BAD_FRAME_VALUE(1'b1),
|
||||
.USER_BAD_FRAME_MASK(1'b1),
|
||||
.DROP_OVERSIZE_FRAME(1),
|
||||
.DROP_BAD_FRAME(1),
|
||||
.DROP_WHEN_FULL(1)
|
||||
)
|
||||
ch_fifo (
|
||||
/*
|
||||
* AXI4-Stream input (sink)
|
||||
*/
|
||||
.s_clk(eth_gty_rx_clk[n]),
|
||||
.s_rst(eth_gty_rx_rst[n]),
|
||||
.s_axis(eth_gty_axis_rx[n]),
|
||||
|
||||
/*
|
||||
* AXI4-Stream output (source)
|
||||
*/
|
||||
.m_clk(eth_gty_tx_clk[n]),
|
||||
.m_rst(eth_gty_tx_rst[n]),
|
||||
.m_axis(eth_gty_axis_tx[n]),
|
||||
|
||||
/*
|
||||
* Pause
|
||||
*/
|
||||
.s_pause_req(1'b0),
|
||||
.s_pause_ack(),
|
||||
.m_pause_req(1'b0),
|
||||
.m_pause_ack(),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.s_status_depth(),
|
||||
.s_status_depth_commit(),
|
||||
.s_status_overflow(),
|
||||
.s_status_bad_frame(),
|
||||
.s_status_good_frame(),
|
||||
.m_status_depth(),
|
||||
.m_status_depth_commit(),
|
||||
.m_status_overflow(),
|
||||
.m_status_bad_frame(),
|
||||
.m_status_good_frame()
|
||||
);
|
||||
|
||||
end
|
||||
|
||||
for (genvar n = 0; n < ADC_CNT; n = n + 1) begin : rfdc_lpbk
|
||||
|
||||
assign m_axis_dac[n].tdata = s_axis_adc[n].tdata;
|
||||
assign m_axis_dac[n].tvalid = s_axis_adc[n].tvalid;
|
||||
assign s_axis_adc[n].tready = m_axis_dac[n].tready;
|
||||
|
||||
end
|
||||
|
||||
endmodule
|
||||
|
||||
`resetall
|
||||
897
src/eth/example/HTG_ZRF8/fpga/rtl/fpga_em.sv
Normal file
897
src/eth/example/HTG_ZRF8/fpga/rtl/fpga_em.sv
Normal file
@@ -0,0 +1,897 @@
|
||||
// SPDX-License-Identifier: MIT
|
||||
/*
|
||||
|
||||
Copyright (c) 2021-2025 FPGA Ninja, LLC
|
||||
|
||||
Authors:
|
||||
- Alex Forencich
|
||||
|
||||
*/
|
||||
|
||||
`resetall
|
||||
`timescale 1ns / 1ps
|
||||
`default_nettype none
|
||||
|
||||
/*
|
||||
* FPGA top-level module for HTG-ZRF8-EM
|
||||
*/
|
||||
module fpga #
|
||||
(
|
||||
parameter logic SIM = 1'b0,
|
||||
parameter string VENDOR = "XILINX",
|
||||
parameter string FAMILY = "zynquplusRFSOC"
|
||||
)
|
||||
(
|
||||
/*
|
||||
* Clock: 200 MHz LVDS
|
||||
*/
|
||||
input wire logic clk_pl_user_p,
|
||||
input wire logic clk_pl_user_n,
|
||||
input wire logic fpga_refclk_p,
|
||||
input wire logic fpga_refclk_n,
|
||||
input wire logic fpga_sysref_p,
|
||||
input wire logic fpga_sysref_n,
|
||||
|
||||
/*
|
||||
* GPIO
|
||||
*/
|
||||
input wire logic btn,
|
||||
input wire logic [3:0] sw,
|
||||
output wire logic [3:0] led,
|
||||
output wire logic [7:0] gpio,
|
||||
|
||||
/*
|
||||
* I2C for board management
|
||||
*/
|
||||
inout wire logic i2c_scl,
|
||||
inout wire logic i2c_sda,
|
||||
output wire logic i2c_rst_n,
|
||||
|
||||
/*
|
||||
* UART: 921600 bps, 8N1
|
||||
*/
|
||||
output wire logic uart_rxd,
|
||||
input wire logic uart_txd,
|
||||
input wire logic uart_rts,
|
||||
output wire logic uart_cts,
|
||||
output wire logic uart_rst_n,
|
||||
input wire logic uart_suspend_n,
|
||||
|
||||
/*
|
||||
* FMC+
|
||||
*/
|
||||
// output wire logic [9:0] fmc_la_p,
|
||||
// output wire logic [9:0] fmc_la_n,
|
||||
|
||||
output wire logic [7:0] fmc_dp_c2m_p,
|
||||
output wire logic [7:0] fmc_dp_c2m_n,
|
||||
input wire logic [7:0] fmc_dp_m2c_p,
|
||||
input wire logic [7:0] fmc_dp_m2c_n,
|
||||
input wire logic fmc_mgt_refclk_0_0_p,
|
||||
input wire logic fmc_mgt_refclk_0_0_n,
|
||||
input wire logic fmc_mgt_refclk_1_0_p,
|
||||
input wire logic fmc_mgt_refclk_1_0_n,
|
||||
|
||||
/*
|
||||
* RFDC
|
||||
*/
|
||||
input wire logic [7:0] adc_vin_p,
|
||||
input wire logic [7:0] adc_vin_n,
|
||||
|
||||
input wire logic adc_refclk_0_p,
|
||||
input wire logic adc_refclk_0_n,
|
||||
input wire logic adc_refclk_1_p,
|
||||
input wire logic adc_refclk_1_n,
|
||||
input wire logic adc_refclk_2_p,
|
||||
input wire logic adc_refclk_2_n,
|
||||
input wire logic adc_refclk_3_p,
|
||||
input wire logic adc_refclk_3_n,
|
||||
|
||||
output wire logic [7:0] dac_vout_p,
|
||||
output wire logic [7:0] dac_vout_n,
|
||||
|
||||
// input wire logic dac_refclk_0_p,
|
||||
// input wire logic dac_refclk_0_n,
|
||||
input wire logic dac_refclk_1_p,
|
||||
input wire logic dac_refclk_1_n,
|
||||
|
||||
input wire logic rfdc_sysref_p,
|
||||
input wire logic rfdc_sysref_n
|
||||
);
|
||||
|
||||
// PLL
|
||||
wire pll_i2c_busy;
|
||||
|
||||
// Clock and reset
|
||||
|
||||
wire clk_pl_user_ibufg;
|
||||
wire clk_pl_user_bufg;
|
||||
|
||||
// Internal 125 MHz clock
|
||||
wire clk_125mhz_mmcm_out;
|
||||
wire clk_125mhz_int;
|
||||
wire rst_125mhz_int;
|
||||
|
||||
wire mmcm_rst = pll_i2c_busy;
|
||||
wire mmcm_locked;
|
||||
wire mmcm_clkfb;
|
||||
|
||||
IBUFGDS #(
|
||||
.DIFF_TERM("FALSE"),
|
||||
.IBUF_LOW_PWR("FALSE")
|
||||
)
|
||||
clk_pl_user_ibufg_inst (
|
||||
.I (clk_pl_user_p),
|
||||
.IB(clk_pl_user_n),
|
||||
.O (clk_pl_user_ibufg)
|
||||
);
|
||||
|
||||
BUFG
|
||||
clk_pl_user_bufg_inst (
|
||||
.I(clk_pl_user_ibufg),
|
||||
.O(clk_pl_user_bufg)
|
||||
);
|
||||
|
||||
// MMCM instance
|
||||
MMCME4_BASE #(
|
||||
// 200 MHz input
|
||||
.CLKIN1_PERIOD(5.0),
|
||||
.REF_JITTER1(0.010),
|
||||
// 200 MHz input / 1 = 200 MHz PFD (range 10 MHz to 500 MHz)
|
||||
.DIVCLK_DIVIDE(1),
|
||||
// 200 MHz PFD * 5 = 1000 MHz VCO (range 800 MHz to 1600 MHz)
|
||||
.CLKFBOUT_MULT_F(5),
|
||||
.CLKFBOUT_PHASE(0),
|
||||
// 1000 MHz / 8 = 125 MHz, 0 degrees
|
||||
.CLKOUT0_DIVIDE_F(8),
|
||||
.CLKOUT0_DUTY_CYCLE(0.5),
|
||||
.CLKOUT0_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT1_DIVIDE(1),
|
||||
.CLKOUT1_DUTY_CYCLE(0.5),
|
||||
.CLKOUT1_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT2_DIVIDE(1),
|
||||
.CLKOUT2_DUTY_CYCLE(0.5),
|
||||
.CLKOUT2_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT3_DIVIDE(1),
|
||||
.CLKOUT3_DUTY_CYCLE(0.5),
|
||||
.CLKOUT3_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT4_DIVIDE(1),
|
||||
.CLKOUT4_DUTY_CYCLE(0.5),
|
||||
.CLKOUT4_PHASE(0),
|
||||
.CLKOUT4_CASCADE("FALSE"),
|
||||
// Not used
|
||||
.CLKOUT5_DIVIDE(1),
|
||||
.CLKOUT5_DUTY_CYCLE(0.5),
|
||||
.CLKOUT5_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT6_DIVIDE(1),
|
||||
.CLKOUT6_DUTY_CYCLE(0.5),
|
||||
.CLKOUT6_PHASE(0),
|
||||
|
||||
// optimized bandwidth
|
||||
.BANDWIDTH("OPTIMIZED"),
|
||||
// don't wait for lock during startup
|
||||
.STARTUP_WAIT("FALSE")
|
||||
)
|
||||
clk_mmcm_inst (
|
||||
// 200 MHz input
|
||||
.CLKIN1(clk_pl_user_bufg),
|
||||
// direct clkfb feeback
|
||||
.CLKFBIN(mmcm_clkfb),
|
||||
.CLKFBOUT(mmcm_clkfb),
|
||||
.CLKFBOUTB(),
|
||||
// 125 MHz, 0 degrees
|
||||
.CLKOUT0(clk_125mhz_mmcm_out),
|
||||
.CLKOUT0B(),
|
||||
// Not used
|
||||
.CLKOUT1(),
|
||||
.CLKOUT1B(),
|
||||
// Not used
|
||||
.CLKOUT2(),
|
||||
.CLKOUT2B(),
|
||||
// Not used
|
||||
.CLKOUT3(),
|
||||
.CLKOUT3B(),
|
||||
// Not used
|
||||
.CLKOUT4(),
|
||||
// Not used
|
||||
.CLKOUT5(),
|
||||
// Not used
|
||||
.CLKOUT6(),
|
||||
// reset input
|
||||
.RST(mmcm_rst),
|
||||
// don't power down
|
||||
.PWRDWN(1'b0),
|
||||
// locked output
|
||||
.LOCKED(mmcm_locked)
|
||||
);
|
||||
|
||||
BUFG
|
||||
clk_125mhz_bufg_inst (
|
||||
.I(clk_125mhz_mmcm_out),
|
||||
.O(clk_125mhz_int)
|
||||
);
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
sync_reset_125mhz_inst (
|
||||
.clk(clk_125mhz_int),
|
||||
.rst(~mmcm_locked),
|
||||
.out(rst_125mhz_int)
|
||||
);
|
||||
|
||||
wire fpga_refclk_ibufg;
|
||||
wire fpga_refclk_int;
|
||||
wire fpga_sysref_ibufg;
|
||||
wire fpga_sysref_int;
|
||||
|
||||
IBUFGDS #(
|
||||
.DIFF_TERM("FALSE"),
|
||||
.IBUF_LOW_PWR("FALSE")
|
||||
)
|
||||
fpga_refclk_ibufg_inst (
|
||||
.O (fpga_refclk_ibufg),
|
||||
.I (fpga_refclk_p),
|
||||
.IB (fpga_refclk_n)
|
||||
);
|
||||
|
||||
BUFG
|
||||
fpga_refclk_bufg_inst (
|
||||
.I(fpga_refclk_ibufg),
|
||||
.O(fpga_refclk_int)
|
||||
);
|
||||
|
||||
IBUFGDS #(
|
||||
.DIFF_TERM("FALSE"),
|
||||
.IBUF_LOW_PWR("FALSE")
|
||||
)
|
||||
fpga_sysref_ibufg_inst (
|
||||
.O (fpga_sysref_ibufg),
|
||||
.I (fpga_sysref_p),
|
||||
.IB (fpga_sysref_n)
|
||||
);
|
||||
|
||||
BUFG
|
||||
fpga_sysref_bufg_inst (
|
||||
.I(fpga_sysref_ibufg),
|
||||
.O(fpga_sysref_int)
|
||||
);
|
||||
|
||||
// STARTUP instance for cfgmclk
|
||||
wire cfgmclk;
|
||||
|
||||
STARTUPE3
|
||||
startupe3_inst (
|
||||
.CFGCLK(),
|
||||
.CFGMCLK(cfgmclk),
|
||||
.DI(),
|
||||
.DO(4'd0),
|
||||
.DTS(1'b1),
|
||||
.EOS(),
|
||||
.FCSBO(1'b1),
|
||||
.FCSBTS(1'b1),
|
||||
.GSR(1'b0),
|
||||
.GTS(1'b0),
|
||||
.KEYCLEARB(1'b1),
|
||||
.PACK(1'b0),
|
||||
.PREQ(),
|
||||
.USRCCLKO(1'b0),
|
||||
.USRCCLKTS(1'b1),
|
||||
.USRDONEO(1'b0),
|
||||
.USRDONETS(1'b1)
|
||||
);
|
||||
|
||||
wire cfgmclk_int;
|
||||
|
||||
BUFG
|
||||
cfgmclk_bufg_inst (
|
||||
.I(cfgmclk),
|
||||
.O(cfgmclk_int)
|
||||
);
|
||||
|
||||
wire cfgmclk_rst_int;
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
sync_reset_cfgmclk_inst (
|
||||
.clk(cfgmclk_int),
|
||||
.rst(~btn),
|
||||
.out(cfgmclk_rst_int)
|
||||
);
|
||||
|
||||
// GPIO
|
||||
wire [3:0] sw_int;
|
||||
|
||||
taxi_debounce_switch #(
|
||||
.WIDTH(4),
|
||||
.N(4),
|
||||
.RATE(125000)
|
||||
)
|
||||
debounce_switch_inst (
|
||||
.clk(clk_125mhz_int),
|
||||
.rst(rst_125mhz_int),
|
||||
.in({sw}),
|
||||
.out({sw_int})
|
||||
);
|
||||
|
||||
wire uart_txd_int;
|
||||
wire uart_rts_int;
|
||||
|
||||
taxi_sync_signal #(
|
||||
.WIDTH(2),
|
||||
.N(2)
|
||||
)
|
||||
sync_signal_inst (
|
||||
.clk(clk_125mhz_int),
|
||||
.in({uart_txd, uart_rts}),
|
||||
.out({uart_txd_int, uart_rts_int})
|
||||
);
|
||||
|
||||
wire i2c_scl_i;
|
||||
wire i2c_scl_o;
|
||||
wire i2c_sda_i;
|
||||
wire i2c_sda_o;
|
||||
|
||||
assign i2c_scl_i = i2c_scl;
|
||||
assign i2c_scl = i2c_scl_o ? 1'bz : 1'b0;
|
||||
assign i2c_sda_i = i2c_sda;
|
||||
assign i2c_sda = i2c_sda_o ? 1'bz : 1'b0;
|
||||
assign i2c_rst_n = 1'b1;
|
||||
|
||||
wire i2c_init_scl_i = i2c_scl_i;
|
||||
wire i2c_init_scl_o;
|
||||
wire i2c_init_sda_i = i2c_sda_i;
|
||||
wire i2c_init_sda_o;
|
||||
|
||||
wire i2c_int_scl_i = i2c_scl_i;
|
||||
wire i2c_int_scl_o;
|
||||
wire i2c_int_sda_i = i2c_sda_i;
|
||||
wire i2c_int_sda_o;
|
||||
|
||||
assign i2c_scl_o = i2c_init_scl_o & i2c_int_scl_o;
|
||||
assign i2c_sda_o = i2c_init_sda_o & i2c_int_sda_o;
|
||||
|
||||
// PLL init
|
||||
taxi_axis_if #(.DATA_W(12)) pll_i2c_cmd();
|
||||
taxi_axis_if #(.DATA_W(8)) pll_i2c_tx();
|
||||
taxi_axis_if #(.DATA_W(8)) pll_i2c_rx();
|
||||
|
||||
assign pll_i2c_rx.tready = 1'b1;
|
||||
|
||||
taxi_i2c_master
|
||||
pll_i2c_master_inst (
|
||||
.clk(cfgmclk_int),
|
||||
.rst(cfgmclk_rst_int),
|
||||
|
||||
/*
|
||||
* Host interface
|
||||
*/
|
||||
.s_axis_cmd(pll_i2c_cmd),
|
||||
.s_axis_tx(pll_i2c_tx),
|
||||
.m_axis_rx(pll_i2c_rx),
|
||||
|
||||
/*
|
||||
* I2C interface
|
||||
*/
|
||||
.scl_i(i2c_init_scl_i),
|
||||
.scl_o(i2c_init_scl_o),
|
||||
.sda_i(i2c_init_sda_i),
|
||||
.sda_o(i2c_init_sda_o),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.busy(),
|
||||
.bus_control(),
|
||||
.bus_active(),
|
||||
.missed_ack(),
|
||||
|
||||
/*
|
||||
* Configuration
|
||||
*/
|
||||
.prescale(SIM ? 15 : 150),
|
||||
.stop_on_idle(1)
|
||||
);
|
||||
|
||||
pll_i2c_init_em #(
|
||||
.SIM_SPEEDUP(SIM)
|
||||
)
|
||||
pll_i2c_init_inst (
|
||||
.clk(cfgmclk_int),
|
||||
.rst(cfgmclk_rst_int),
|
||||
|
||||
/*
|
||||
* I2C master interface
|
||||
*/
|
||||
.m_axis_cmd(pll_i2c_cmd),
|
||||
.m_axis_tx(pll_i2c_tx),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.busy(pll_i2c_busy),
|
||||
|
||||
/*
|
||||
* Configuration
|
||||
*/
|
||||
.start(1'b1)
|
||||
);
|
||||
|
||||
localparam PORT_CNT = 2;
|
||||
localparam GTY_QUAD_CNT = PORT_CNT;
|
||||
localparam GTY_CNT = GTY_QUAD_CNT*4;
|
||||
localparam GTY_CLK_CNT = GTY_QUAD_CNT;
|
||||
|
||||
// RF data converters
|
||||
localparam ADC_CNT = 8;
|
||||
localparam ADC_SAMPLE_W = 16;
|
||||
localparam ADC_SAMPLE_CNT = 4;
|
||||
localparam ADC_DATA_W = ADC_SAMPLE_W*ADC_SAMPLE_CNT;
|
||||
|
||||
localparam DAC_CNT = ADC_CNT;
|
||||
localparam DAC_SAMPLE_W = ADC_SAMPLE_W;
|
||||
localparam DAC_SAMPLE_CNT = ADC_SAMPLE_CNT;
|
||||
localparam DAC_DATA_W = DAC_SAMPLE_W*DAC_SAMPLE_CNT;
|
||||
|
||||
wire axil_rfdc_clk = clk_125mhz_int;
|
||||
wire axil_rfdc_rst = rst_125mhz_int;
|
||||
|
||||
taxi_axil_if #(
|
||||
.DATA_W(32),
|
||||
.ADDR_W(18)
|
||||
) axil_rfdc();
|
||||
|
||||
wire axis_rfdc_clk;
|
||||
wire axis_rfdc_rst;
|
||||
|
||||
wire [3:0] adc_clk_out;
|
||||
wire [3:0] dac_clk_out;
|
||||
|
||||
taxi_axis_if #(
|
||||
.DATA_W(ADC_DATA_W),
|
||||
.KEEP_EN(1),
|
||||
.KEEP_W(ADC_SAMPLE_CNT),
|
||||
.LAST_EN(0),
|
||||
.USER_EN(0),
|
||||
.ID_EN(0),
|
||||
.DEST_EN(0)
|
||||
) axis_adc[ADC_CNT]();
|
||||
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_0 = axis_adc[0].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_1 = axis_adc[1].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_2 = axis_adc[2].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_3 = axis_adc[3].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_4 = axis_adc[4].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_5 = axis_adc[5].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_6 = axis_adc[6].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_7 = axis_adc[7].tdata;
|
||||
|
||||
taxi_axis_if #(
|
||||
.DATA_W(DAC_DATA_W),
|
||||
.KEEP_EN(1),
|
||||
.KEEP_W(DAC_SAMPLE_CNT),
|
||||
.LAST_EN(0),
|
||||
.USER_EN(0),
|
||||
.ID_EN(0),
|
||||
.DEST_EN(0)
|
||||
) axis_dac[DAC_CNT]();
|
||||
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_0 = axis_dac[0].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_1 = axis_dac[1].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_2 = axis_dac[2].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_3 = axis_dac[3].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_4 = axis_dac[4].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_5 = axis_dac[5].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_6 = axis_dac[6].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_7 = axis_dac[7].tdata;
|
||||
|
||||
wire rfdc_mmcm_in = dac_clk_out[0];
|
||||
wire rfdc_mmcm_rst = rst_125mhz_int;
|
||||
wire rfdc_mmcm_clkfb;
|
||||
wire rfdc_mmcm_locked;
|
||||
wire rfdc_mmcm_out;
|
||||
|
||||
// MMCM instance
|
||||
MMCME4_BASE #(
|
||||
// 62.5 MHz input
|
||||
.CLKIN1_PERIOD(16.0),
|
||||
.REF_JITTER1(0.010),
|
||||
// 62.5 MHz input / 1 = 62.5 MHz PFD (range 10 MHz to 500 MHz)
|
||||
.DIVCLK_DIVIDE(1),
|
||||
// 62.5 MHz PFD * 20 = 1250 MHz VCO (range 800 MHz to 1600 MHz)
|
||||
.CLKFBOUT_MULT_F(20),
|
||||
.CLKFBOUT_PHASE(0),
|
||||
// 1250 MHz / 5 = 250 MHz, 0 degrees
|
||||
.CLKOUT0_DIVIDE_F(5),
|
||||
.CLKOUT0_DUTY_CYCLE(0.5),
|
||||
.CLKOUT0_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT1_DIVIDE(1),
|
||||
.CLKOUT1_DUTY_CYCLE(0.5),
|
||||
.CLKOUT1_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT2_DIVIDE(1),
|
||||
.CLKOUT2_DUTY_CYCLE(0.5),
|
||||
.CLKOUT2_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT3_DIVIDE(1),
|
||||
.CLKOUT3_DUTY_CYCLE(0.5),
|
||||
.CLKOUT3_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT4_DIVIDE(1),
|
||||
.CLKOUT4_DUTY_CYCLE(0.5),
|
||||
.CLKOUT4_PHASE(0),
|
||||
.CLKOUT4_CASCADE("FALSE"),
|
||||
// Not used
|
||||
.CLKOUT5_DIVIDE(1),
|
||||
.CLKOUT5_DUTY_CYCLE(0.5),
|
||||
.CLKOUT5_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT6_DIVIDE(1),
|
||||
.CLKOUT6_DUTY_CYCLE(0.5),
|
||||
.CLKOUT6_PHASE(0),
|
||||
|
||||
// optimized bandwidth
|
||||
.BANDWIDTH("OPTIMIZED"),
|
||||
// don't wait for lock during startup
|
||||
.STARTUP_WAIT("FALSE")
|
||||
)
|
||||
rfdc_mmcm_inst (
|
||||
// 62.5 MHz input
|
||||
.CLKIN1(rfdc_mmcm_in),
|
||||
// direct clkfb feeback
|
||||
.CLKFBIN(rfdc_mmcm_clkfb),
|
||||
.CLKFBOUT(rfdc_mmcm_clkfb),
|
||||
.CLKFBOUTB(),
|
||||
// 250 MHz, 0 degrees
|
||||
.CLKOUT0(rfdc_mmcm_out),
|
||||
.CLKOUT0B(),
|
||||
// Not used
|
||||
.CLKOUT1(),
|
||||
.CLKOUT1B(),
|
||||
// Not used
|
||||
.CLKOUT2(),
|
||||
.CLKOUT2B(),
|
||||
// Not used
|
||||
.CLKOUT3(),
|
||||
.CLKOUT3B(),
|
||||
// Not used
|
||||
.CLKOUT4(),
|
||||
// Not used
|
||||
.CLKOUT5(),
|
||||
// Not used
|
||||
.CLKOUT6(),
|
||||
// reset input
|
||||
.RST(rfdc_mmcm_rst),
|
||||
// don't power down
|
||||
.PWRDWN(1'b0),
|
||||
// locked output
|
||||
.LOCKED(rfdc_mmcm_locked)
|
||||
);
|
||||
|
||||
BUFG
|
||||
axis_rfdc_bufg_inst (
|
||||
.I(rfdc_mmcm_out),
|
||||
.O(axis_rfdc_clk)
|
||||
);
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
axis_rfdc_sync_reset_inst (
|
||||
.clk(axis_rfdc_clk),
|
||||
.rst(!rfdc_mmcm_locked || rfdc_mmcm_rst),
|
||||
.out(axis_rfdc_rst)
|
||||
);
|
||||
|
||||
usp_rfdc_0 rfdc_inst (
|
||||
// Common
|
||||
.sysref_in_p(rfdc_sysref_p),
|
||||
.sysref_in_n(rfdc_sysref_n),
|
||||
|
||||
.s_axi_aclk(axil_rfdc_clk),
|
||||
.s_axi_aresetn(!axil_rfdc_rst),
|
||||
.s_axi_awaddr(axil_rfdc.awaddr),
|
||||
.s_axi_awvalid(axil_rfdc.awvalid),
|
||||
.s_axi_awready(axil_rfdc.awready),
|
||||
.s_axi_wdata(axil_rfdc.wdata),
|
||||
.s_axi_wstrb(axil_rfdc.wstrb),
|
||||
.s_axi_wvalid(axil_rfdc.wvalid),
|
||||
.s_axi_wready(axil_rfdc.wready),
|
||||
.s_axi_bresp(axil_rfdc.bresp),
|
||||
.s_axi_bvalid(axil_rfdc.bvalid),
|
||||
.s_axi_bready(axil_rfdc.bready),
|
||||
.s_axi_araddr(axil_rfdc.araddr),
|
||||
.s_axi_arvalid(axil_rfdc.arvalid),
|
||||
.s_axi_arready(axil_rfdc.arready),
|
||||
.s_axi_rdata(axil_rfdc.rdata),
|
||||
.s_axi_rresp(axil_rfdc.rresp),
|
||||
.s_axi_rvalid(axil_rfdc.rvalid),
|
||||
.s_axi_rready(axil_rfdc.rready),
|
||||
|
||||
.irq(),
|
||||
|
||||
// ADC
|
||||
.adc0_clk_p(adc_refclk_0_p),
|
||||
.adc0_clk_n(adc_refclk_0_n),
|
||||
.clk_adc0(adc_clk_out[0]),
|
||||
|
||||
.adc1_clk_p(adc_refclk_1_p),
|
||||
.adc1_clk_n(adc_refclk_1_n),
|
||||
.clk_adc1(adc_clk_out[1]),
|
||||
|
||||
.adc2_clk_p(adc_refclk_2_p),
|
||||
.adc2_clk_n(adc_refclk_2_n),
|
||||
.clk_adc2(adc_clk_out[2]),
|
||||
|
||||
.adc3_clk_p(adc_refclk_3_p),
|
||||
.adc3_clk_n(adc_refclk_3_n),
|
||||
.clk_adc3(adc_clk_out[3]),
|
||||
|
||||
.vin0_01_p(adc_vin_p[7]),
|
||||
.vin0_01_n(adc_vin_n[7]),
|
||||
.vin0_23_p(adc_vin_p[6]),
|
||||
.vin0_23_n(adc_vin_n[6]),
|
||||
|
||||
.vin1_01_p(adc_vin_p[5]),
|
||||
.vin1_01_n(adc_vin_n[5]),
|
||||
.vin1_23_p(adc_vin_p[4]),
|
||||
.vin1_23_n(adc_vin_n[4]),
|
||||
|
||||
.vin2_01_p(adc_vin_p[3]),
|
||||
.vin2_01_n(adc_vin_n[3]),
|
||||
.vin2_23_p(adc_vin_p[2]),
|
||||
.vin2_23_n(adc_vin_n[2]),
|
||||
|
||||
.vin3_01_p(adc_vin_p[1]),
|
||||
.vin3_01_n(adc_vin_n[1]),
|
||||
.vin3_23_p(adc_vin_p[0]),
|
||||
.vin3_23_n(adc_vin_n[0]),
|
||||
|
||||
.m0_axis_aresetn(!axis_rfdc_rst),
|
||||
.m0_axis_aclk(axis_rfdc_clk),
|
||||
.m00_axis_tdata(axis_adc[7].tdata),
|
||||
.m00_axis_tvalid(axis_adc[7].tvalid),
|
||||
.m00_axis_tready(axis_adc[7].tready),
|
||||
.m02_axis_tdata(axis_adc[6].tdata),
|
||||
.m02_axis_tvalid(axis_adc[6].tvalid),
|
||||
.m02_axis_tready(axis_adc[6].tready),
|
||||
|
||||
.m1_axis_aresetn(!axis_rfdc_rst),
|
||||
.m1_axis_aclk(axis_rfdc_clk),
|
||||
.m10_axis_tdata(axis_adc[5].tdata),
|
||||
.m10_axis_tvalid(axis_adc[5].tvalid),
|
||||
.m10_axis_tready(axis_adc[5].tready),
|
||||
.m12_axis_tdata(axis_adc[4].tdata),
|
||||
.m12_axis_tvalid(axis_adc[4].tvalid),
|
||||
.m12_axis_tready(axis_adc[4].tready),
|
||||
|
||||
.m2_axis_aresetn(!axis_rfdc_rst),
|
||||
.m2_axis_aclk(axis_rfdc_clk),
|
||||
.m20_axis_tdata(axis_adc[3].tdata),
|
||||
.m20_axis_tvalid(axis_adc[3].tvalid),
|
||||
.m20_axis_tready(axis_adc[3].tready),
|
||||
.m22_axis_tdata(axis_adc[2].tdata),
|
||||
.m22_axis_tvalid(axis_adc[2].tvalid),
|
||||
.m22_axis_tready(axis_adc[2].tready),
|
||||
|
||||
.m3_axis_aresetn(!axis_rfdc_rst),
|
||||
.m3_axis_aclk(axis_rfdc_clk),
|
||||
.m30_axis_tdata(axis_adc[1].tdata),
|
||||
.m30_axis_tvalid(axis_adc[1].tvalid),
|
||||
.m30_axis_tready(axis_adc[1].tready),
|
||||
.m32_axis_tdata(axis_adc[0].tdata),
|
||||
.m32_axis_tvalid(axis_adc[0].tvalid),
|
||||
.m32_axis_tready(axis_adc[0].tready),
|
||||
|
||||
.adc0_01_dsa_code(5'd27),
|
||||
.adc0_23_dsa_code(5'd27),
|
||||
.adc0_dsa_update(1'b0),
|
||||
.adc1_01_dsa_code(5'd27),
|
||||
.adc1_23_dsa_code(5'd27),
|
||||
.adc1_dsa_update(1'b0),
|
||||
.adc2_01_dsa_code(5'd27),
|
||||
.adc2_23_dsa_code(5'd27),
|
||||
.adc2_dsa_update(1'b0),
|
||||
.adc3_01_dsa_code(5'd27),
|
||||
.adc3_23_dsa_code(5'd27),
|
||||
.adc3_dsa_update(1'b0),
|
||||
|
||||
// DAC
|
||||
.dac2_clk_p(dac_refclk_1_p),
|
||||
.dac2_clk_n(dac_refclk_1_n),
|
||||
|
||||
.clk_dac0(dac_clk_out[0]),
|
||||
.clk_dac1(dac_clk_out[1]),
|
||||
.clk_dac2(dac_clk_out[2]),
|
||||
.clk_dac3(dac_clk_out[3]),
|
||||
|
||||
.vout00_p(dac_vout_p[7]),
|
||||
.vout00_n(dac_vout_n[7]),
|
||||
.vout02_p(dac_vout_p[6]),
|
||||
.vout02_n(dac_vout_n[6]),
|
||||
|
||||
.vout10_p(dac_vout_p[5]),
|
||||
.vout10_n(dac_vout_n[5]),
|
||||
.vout12_p(dac_vout_p[4]),
|
||||
.vout12_n(dac_vout_n[4]),
|
||||
|
||||
.vout20_p(dac_vout_p[3]),
|
||||
.vout20_n(dac_vout_n[3]),
|
||||
.vout22_p(dac_vout_p[2]),
|
||||
.vout22_n(dac_vout_n[2]),
|
||||
|
||||
.vout30_p(dac_vout_p[1]),
|
||||
.vout30_n(dac_vout_n[1]),
|
||||
.vout32_p(dac_vout_p[0]),
|
||||
.vout32_n(dac_vout_n[0]),
|
||||
|
||||
.s0_axis_aresetn(!axis_rfdc_rst),
|
||||
.s0_axis_aclk(axis_rfdc_clk),
|
||||
.s00_axis_tdata(axis_dac[7].tdata),
|
||||
.s00_axis_tvalid(axis_dac[7].tvalid),
|
||||
.s00_axis_tready(axis_dac[7].tready),
|
||||
.s02_axis_tdata(axis_dac[6].tdata),
|
||||
.s02_axis_tvalid(axis_dac[6].tvalid),
|
||||
.s02_axis_tready(axis_dac[6].tready),
|
||||
|
||||
.s1_axis_aresetn(!axis_rfdc_rst),
|
||||
.s1_axis_aclk(axis_rfdc_clk),
|
||||
.s10_axis_tdata(axis_dac[5].tdata),
|
||||
.s10_axis_tvalid(axis_dac[5].tvalid),
|
||||
.s10_axis_tready(axis_dac[5].tready),
|
||||
.s12_axis_tdata(axis_dac[4].tdata),
|
||||
.s12_axis_tvalid(axis_dac[4].tvalid),
|
||||
.s12_axis_tready(axis_dac[4].tready),
|
||||
|
||||
.s2_axis_aresetn(!axis_rfdc_rst),
|
||||
.s2_axis_aclk(axis_rfdc_clk),
|
||||
.s20_axis_tdata(axis_dac[3].tdata),
|
||||
.s20_axis_tvalid(axis_dac[3].tvalid),
|
||||
.s20_axis_tready(axis_dac[3].tready),
|
||||
.s22_axis_tdata(axis_dac[2].tdata),
|
||||
.s22_axis_tvalid(axis_dac[2].tvalid),
|
||||
.s22_axis_tready(axis_dac[2].tready),
|
||||
|
||||
.s3_axis_aresetn(!axis_rfdc_rst),
|
||||
.s3_axis_aclk(axis_rfdc_clk),
|
||||
.s30_axis_tdata(axis_dac[1].tdata),
|
||||
.s30_axis_tvalid(axis_dac[1].tvalid),
|
||||
.s30_axis_tready(axis_dac[1].tready),
|
||||
.s32_axis_tdata(axis_dac[0].tdata),
|
||||
.s32_axis_tvalid(axis_dac[0].tvalid),
|
||||
.s32_axis_tready(axis_dac[0].tready),
|
||||
|
||||
.dac00_vop_code(10'd895),
|
||||
.dac02_vop_code(10'd895),
|
||||
.dac00_update_vop(1'b0),
|
||||
.dac02_update_vop(1'b0),
|
||||
.dac00_vop_done(),
|
||||
.dac02_vop_done(),
|
||||
.dac0_vop_busy(),
|
||||
|
||||
.dac10_vop_code(10'd895),
|
||||
.dac12_vop_code(10'd895),
|
||||
.dac10_update_vop(1'b0),
|
||||
.dac12_update_vop(1'b0),
|
||||
.dac10_vop_done(),
|
||||
.dac12_vop_done(),
|
||||
.dac1_vop_busy(),
|
||||
|
||||
.dac20_vop_code(10'd895),
|
||||
.dac22_vop_code(10'd895),
|
||||
.dac20_update_vop(1'b0),
|
||||
.dac22_update_vop(1'b0),
|
||||
.dac20_vop_done(),
|
||||
.dac22_vop_done(),
|
||||
.dac2_vop_busy(),
|
||||
|
||||
.dac30_vop_code(10'd895),
|
||||
.dac32_vop_code(10'd895),
|
||||
.dac30_update_vop(1'b0),
|
||||
.dac32_update_vop(1'b0),
|
||||
.dac30_vop_done(),
|
||||
.dac32_vop_done(),
|
||||
.dac3_vop_busy()
|
||||
);
|
||||
|
||||
fpga_core #(
|
||||
.SIM(SIM),
|
||||
.VENDOR(VENDOR),
|
||||
.FAMILY(FAMILY),
|
||||
.PORT_CNT(PORT_CNT),
|
||||
.GTY_QUAD_CNT(GTY_QUAD_CNT),
|
||||
.GTY_CNT(GTY_CNT),
|
||||
.GTY_CLK_CNT(GTY_CLK_CNT),
|
||||
.ADC_CNT(ADC_CNT),
|
||||
.DAC_CNT(DAC_CNT)
|
||||
)
|
||||
core_inst (
|
||||
/*
|
||||
* Clock: 125MHz
|
||||
* Synchronous reset
|
||||
*/
|
||||
.clk_125mhz(clk_125mhz_int),
|
||||
.rst_125mhz(rst_125mhz_int),
|
||||
.fpga_refclk(fpga_refclk_int),
|
||||
.fpga_sysref(fpga_sysref_int),
|
||||
|
||||
/*
|
||||
* GPIO
|
||||
*/
|
||||
.sw(sw_int),
|
||||
.led(led),
|
||||
.gpio(gpio),
|
||||
|
||||
/*
|
||||
* I2C for board management
|
||||
*/
|
||||
.i2c_scl_i(i2c_int_scl_i),
|
||||
.i2c_scl_o(i2c_int_scl_o),
|
||||
.i2c_sda_i(i2c_int_sda_i),
|
||||
.i2c_sda_o(i2c_int_sda_o),
|
||||
|
||||
/*
|
||||
* UART: 921600 bps, 8N1
|
||||
*/
|
||||
.uart_rxd(uart_rxd),
|
||||
.uart_txd(uart_txd_int),
|
||||
.uart_rts(uart_rts_int),
|
||||
.uart_cts(uart_cts),
|
||||
.uart_rst_n(uart_rst_n),
|
||||
.uart_suspend_n(uart_suspend_n),
|
||||
|
||||
/*
|
||||
* Ethernet: QSFP28
|
||||
*/
|
||||
.eth_gty_tx_p(fmc_dp_c2m_p),
|
||||
.eth_gty_tx_n(fmc_dp_c2m_n),
|
||||
.eth_gty_rx_p(fmc_dp_m2c_p),
|
||||
.eth_gty_rx_n(fmc_dp_m2c_n),
|
||||
.eth_gty_mgt_refclk_p({fmc_mgt_refclk_1_0_p, fmc_mgt_refclk_0_0_p}),
|
||||
.eth_gty_mgt_refclk_n({fmc_mgt_refclk_1_0_n, fmc_mgt_refclk_0_0_n}),
|
||||
.eth_gty_mgt_refclk_out(),
|
||||
|
||||
.eth_port_resetl(),
|
||||
.eth_port_modprsl('0),
|
||||
.eth_port_intl('1),
|
||||
|
||||
/*
|
||||
* RFDC
|
||||
*/
|
||||
.axil_rfdc_clk(axil_rfdc_clk),
|
||||
.axil_rfdc_rst(axil_rfdc_rst),
|
||||
.m_axil_rfdc_wr(axil_rfdc),
|
||||
.m_axil_rfdc_rd(axil_rfdc),
|
||||
|
||||
.axis_rfdc_clk(axis_rfdc_clk),
|
||||
.axis_rfdc_rst(axis_rfdc_rst),
|
||||
.s_axis_adc(axis_adc),
|
||||
.m_axis_dac(axis_dac)
|
||||
);
|
||||
|
||||
endmodule
|
||||
|
||||
`resetall
|
||||
923
src/eth/example/HTG_ZRF8/fpga/rtl/fpga_r2.sv
Normal file
923
src/eth/example/HTG_ZRF8/fpga/rtl/fpga_r2.sv
Normal file
@@ -0,0 +1,923 @@
|
||||
// SPDX-License-Identifier: MIT
|
||||
/*
|
||||
|
||||
Copyright (c) 2021-2025 FPGA Ninja, LLC
|
||||
|
||||
Authors:
|
||||
- Alex Forencich
|
||||
|
||||
*/
|
||||
|
||||
`resetall
|
||||
`timescale 1ns / 1ps
|
||||
`default_nettype none
|
||||
|
||||
/*
|
||||
* FPGA top-level module for HTG-ZRF8-R2
|
||||
*/
|
||||
module fpga #
|
||||
(
|
||||
parameter logic SIM = 1'b0,
|
||||
parameter string VENDOR = "XILINX",
|
||||
parameter string FAMILY = "zynquplusRFSOC"
|
||||
)
|
||||
(
|
||||
/*
|
||||
* Clock: 200 MHz LVDS
|
||||
*/
|
||||
input wire logic clk_pl_user1_p,
|
||||
input wire logic clk_pl_user1_n,
|
||||
input wire logic fpga_refclk_p,
|
||||
input wire logic fpga_refclk_n,
|
||||
input wire logic fpga_sysref_p,
|
||||
input wire logic fpga_sysref_n,
|
||||
|
||||
/*
|
||||
* GPIO
|
||||
*/
|
||||
input wire logic btn,
|
||||
input wire logic [3:0] sw,
|
||||
output wire logic [3:0] led,
|
||||
|
||||
/*
|
||||
* I2C for board management
|
||||
*/
|
||||
inout wire logic i2c_scl,
|
||||
inout wire logic i2c_sda,
|
||||
output wire logic i2c_rst_n,
|
||||
|
||||
/*
|
||||
* PLL
|
||||
*/
|
||||
output wire logic clk_fdec,
|
||||
output wire logic clk_finc,
|
||||
input wire logic clk_intr_n,
|
||||
input wire logic clk_lol_n,
|
||||
output wire logic clk_sync_n,
|
||||
output wire logic clk_rst_n,
|
||||
output wire logic lmk_rst,
|
||||
output wire logic [1:0] lmk_clkin_s,
|
||||
|
||||
/*
|
||||
* UART: 921600 bps, 8N1
|
||||
*/
|
||||
output wire logic uart_rxd,
|
||||
input wire logic uart_txd,
|
||||
input wire logic uart_rts,
|
||||
output wire logic uart_cts,
|
||||
output wire logic uart_rst_n,
|
||||
input wire logic uart_suspend_n,
|
||||
|
||||
/*
|
||||
* FMC+
|
||||
*/
|
||||
// output wire logic [33:0] fmc_la_p,
|
||||
// output wire logic [33:0] fmc_la_n,
|
||||
output wire logic fmc_qsfp_modsell,
|
||||
output wire logic fmc_qsfp_resetl,
|
||||
output wire logic fmc_qsfp_lpmode,
|
||||
|
||||
output wire logic [7:0] fmc_dp_c2m_p,
|
||||
output wire logic [7:0] fmc_dp_c2m_n,
|
||||
input wire logic [7:0] fmc_dp_m2c_p,
|
||||
input wire logic [7:0] fmc_dp_m2c_n,
|
||||
input wire logic fmc_mgt_refclk_0_0_p,
|
||||
input wire logic fmc_mgt_refclk_0_0_n,
|
||||
input wire logic fmc_mgt_refclk_1_0_p,
|
||||
input wire logic fmc_mgt_refclk_1_0_n,
|
||||
|
||||
/*
|
||||
* RFDC
|
||||
*/
|
||||
input wire logic [7:0] adc_vin_p,
|
||||
input wire logic [7:0] adc_vin_n,
|
||||
|
||||
input wire logic adc_refclk_0_p,
|
||||
input wire logic adc_refclk_0_n,
|
||||
input wire logic adc_refclk_1_p,
|
||||
input wire logic adc_refclk_1_n,
|
||||
input wire logic adc_refclk_2_p,
|
||||
input wire logic adc_refclk_2_n,
|
||||
input wire logic adc_refclk_3_p,
|
||||
input wire logic adc_refclk_3_n,
|
||||
|
||||
output wire logic [7:0] dac_vout_p,
|
||||
output wire logic [7:0] dac_vout_n,
|
||||
|
||||
// input wire logic dac_refclk_0_p,
|
||||
// input wire logic dac_refclk_0_n,
|
||||
input wire logic dac_refclk_1_p,
|
||||
input wire logic dac_refclk_1_n,
|
||||
|
||||
input wire logic rfdc_sysref_p,
|
||||
input wire logic rfdc_sysref_n
|
||||
);
|
||||
|
||||
// PLL
|
||||
assign clk_fdec = 1'b0;
|
||||
assign clk_finc = 1'b0;
|
||||
assign clk_sync_n = 1'b1;
|
||||
assign clk_rst_n = 1'b1;
|
||||
|
||||
assign lmk_rst = 1'b0;
|
||||
assign lmk_clkin_s = 2'b00;
|
||||
|
||||
wire pll_i2c_busy;
|
||||
|
||||
// Clock and reset
|
||||
|
||||
wire clk_pl_user1_ibufg;
|
||||
wire clk_pl_user1_bufg;
|
||||
|
||||
// Internal 125 MHz clock
|
||||
wire clk_125mhz_mmcm_out;
|
||||
wire clk_125mhz_int;
|
||||
wire rst_125mhz_int;
|
||||
|
||||
wire mmcm_rst = pll_i2c_busy || !clk_lol_n;
|
||||
wire mmcm_locked;
|
||||
wire mmcm_clkfb;
|
||||
|
||||
IBUFGDS #(
|
||||
.DIFF_TERM("FALSE"),
|
||||
.IBUF_LOW_PWR("FALSE")
|
||||
)
|
||||
clk_pl_user1_ibufg_inst (
|
||||
.I (clk_pl_user1_p),
|
||||
.IB(clk_pl_user1_n),
|
||||
.O (clk_pl_user1_ibufg)
|
||||
);
|
||||
|
||||
BUFG
|
||||
clk_pl_user1_bufg_inst (
|
||||
.I(clk_pl_user1_ibufg),
|
||||
.O(clk_pl_user1_bufg)
|
||||
);
|
||||
|
||||
// MMCM instance
|
||||
MMCME4_BASE #(
|
||||
// 200 MHz input
|
||||
.CLKIN1_PERIOD(5.0),
|
||||
.REF_JITTER1(0.010),
|
||||
// 200 MHz input / 1 = 200 MHz PFD (range 10 MHz to 500 MHz)
|
||||
.DIVCLK_DIVIDE(1),
|
||||
// 200 MHz PFD * 5 = 1000 MHz VCO (range 800 MHz to 1600 MHz)
|
||||
.CLKFBOUT_MULT_F(5),
|
||||
.CLKFBOUT_PHASE(0),
|
||||
// 1000 MHz / 8 = 125 MHz, 0 degrees
|
||||
.CLKOUT0_DIVIDE_F(8),
|
||||
.CLKOUT0_DUTY_CYCLE(0.5),
|
||||
.CLKOUT0_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT1_DIVIDE(1),
|
||||
.CLKOUT1_DUTY_CYCLE(0.5),
|
||||
.CLKOUT1_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT2_DIVIDE(1),
|
||||
.CLKOUT2_DUTY_CYCLE(0.5),
|
||||
.CLKOUT2_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT3_DIVIDE(1),
|
||||
.CLKOUT3_DUTY_CYCLE(0.5),
|
||||
.CLKOUT3_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT4_DIVIDE(1),
|
||||
.CLKOUT4_DUTY_CYCLE(0.5),
|
||||
.CLKOUT4_PHASE(0),
|
||||
.CLKOUT4_CASCADE("FALSE"),
|
||||
// Not used
|
||||
.CLKOUT5_DIVIDE(1),
|
||||
.CLKOUT5_DUTY_CYCLE(0.5),
|
||||
.CLKOUT5_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT6_DIVIDE(1),
|
||||
.CLKOUT6_DUTY_CYCLE(0.5),
|
||||
.CLKOUT6_PHASE(0),
|
||||
|
||||
// optimized bandwidth
|
||||
.BANDWIDTH("OPTIMIZED"),
|
||||
// don't wait for lock during startup
|
||||
.STARTUP_WAIT("FALSE")
|
||||
)
|
||||
clk_mmcm_inst (
|
||||
// 200 MHz input
|
||||
.CLKIN1(clk_pl_user1_bufg),
|
||||
// direct clkfb feeback
|
||||
.CLKFBIN(mmcm_clkfb),
|
||||
.CLKFBOUT(mmcm_clkfb),
|
||||
.CLKFBOUTB(),
|
||||
// 125 MHz, 0 degrees
|
||||
.CLKOUT0(clk_125mhz_mmcm_out),
|
||||
.CLKOUT0B(),
|
||||
// Not used
|
||||
.CLKOUT1(),
|
||||
.CLKOUT1B(),
|
||||
// Not used
|
||||
.CLKOUT2(),
|
||||
.CLKOUT2B(),
|
||||
// Not used
|
||||
.CLKOUT3(),
|
||||
.CLKOUT3B(),
|
||||
// Not used
|
||||
.CLKOUT4(),
|
||||
// Not used
|
||||
.CLKOUT5(),
|
||||
// Not used
|
||||
.CLKOUT6(),
|
||||
// reset input
|
||||
.RST(mmcm_rst),
|
||||
// don't power down
|
||||
.PWRDWN(1'b0),
|
||||
// locked output
|
||||
.LOCKED(mmcm_locked)
|
||||
);
|
||||
|
||||
BUFG
|
||||
clk_125mhz_bufg_inst (
|
||||
.I(clk_125mhz_mmcm_out),
|
||||
.O(clk_125mhz_int)
|
||||
);
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
sync_reset_125mhz_inst (
|
||||
.clk(clk_125mhz_int),
|
||||
.rst(~mmcm_locked),
|
||||
.out(rst_125mhz_int)
|
||||
);
|
||||
|
||||
wire fpga_refclk_ibufg;
|
||||
wire fpga_refclk_int;
|
||||
wire fpga_sysref_ibufg;
|
||||
wire fpga_sysref_int;
|
||||
|
||||
IBUFGDS #(
|
||||
.DIFF_TERM("FALSE"),
|
||||
.IBUF_LOW_PWR("FALSE")
|
||||
)
|
||||
fpga_refclk_ibufg_inst (
|
||||
.O (fpga_refclk_ibufg),
|
||||
.I (fpga_refclk_p),
|
||||
.IB (fpga_refclk_n)
|
||||
);
|
||||
|
||||
BUFG
|
||||
fpga_refclk_bufg_inst (
|
||||
.I(fpga_refclk_ibufg),
|
||||
.O(fpga_refclk_int)
|
||||
);
|
||||
|
||||
IBUFGDS #(
|
||||
.DIFF_TERM("FALSE"),
|
||||
.IBUF_LOW_PWR("FALSE")
|
||||
)
|
||||
fpga_sysref_ibufg_inst (
|
||||
.O (fpga_sysref_ibufg),
|
||||
.I (fpga_sysref_p),
|
||||
.IB (fpga_sysref_n)
|
||||
);
|
||||
|
||||
BUFG
|
||||
fpga_sysref_bufg_inst (
|
||||
.I(fpga_sysref_ibufg),
|
||||
.O(fpga_sysref_int)
|
||||
);
|
||||
|
||||
// STARTUP instance for cfgmclk
|
||||
wire cfgmclk;
|
||||
|
||||
STARTUPE3
|
||||
startupe3_inst (
|
||||
.CFGCLK(),
|
||||
.CFGMCLK(cfgmclk),
|
||||
.DI(),
|
||||
.DO(4'd0),
|
||||
.DTS(1'b1),
|
||||
.EOS(),
|
||||
.FCSBO(1'b1),
|
||||
.FCSBTS(1'b1),
|
||||
.GSR(1'b0),
|
||||
.GTS(1'b0),
|
||||
.KEYCLEARB(1'b1),
|
||||
.PACK(1'b0),
|
||||
.PREQ(),
|
||||
.USRCCLKO(1'b0),
|
||||
.USRCCLKTS(1'b1),
|
||||
.USRDONEO(1'b0),
|
||||
.USRDONETS(1'b1)
|
||||
);
|
||||
|
||||
wire cfgmclk_int;
|
||||
|
||||
BUFG
|
||||
cfgmclk_bufg_inst (
|
||||
.I(cfgmclk),
|
||||
.O(cfgmclk_int)
|
||||
);
|
||||
|
||||
wire cfgmclk_rst_int;
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
sync_reset_cfgmclk_inst (
|
||||
.clk(cfgmclk_int),
|
||||
.rst(~btn),
|
||||
.out(cfgmclk_rst_int)
|
||||
);
|
||||
|
||||
// GPIO
|
||||
wire [3:0] sw_int;
|
||||
|
||||
taxi_debounce_switch #(
|
||||
.WIDTH(4),
|
||||
.N(4),
|
||||
.RATE(125000)
|
||||
)
|
||||
debounce_switch_inst (
|
||||
.clk(clk_125mhz_int),
|
||||
.rst(rst_125mhz_int),
|
||||
.in({sw}),
|
||||
.out({sw_int})
|
||||
);
|
||||
|
||||
wire uart_txd_int;
|
||||
wire uart_rts_int;
|
||||
|
||||
taxi_sync_signal #(
|
||||
.WIDTH(2),
|
||||
.N(2)
|
||||
)
|
||||
sync_signal_inst (
|
||||
.clk(clk_125mhz_int),
|
||||
.in({uart_txd, uart_rts}),
|
||||
.out({uart_txd_int, uart_rts_int})
|
||||
);
|
||||
|
||||
wire i2c_scl_i;
|
||||
wire i2c_scl_o;
|
||||
wire i2c_sda_i;
|
||||
wire i2c_sda_o;
|
||||
|
||||
assign i2c_scl_i = i2c_scl;
|
||||
assign i2c_scl = i2c_scl_o ? 1'bz : 1'b0;
|
||||
assign i2c_sda_i = i2c_sda;
|
||||
assign i2c_sda = i2c_sda_o ? 1'bz : 1'b0;
|
||||
assign i2c_rst_n = 1'b1;
|
||||
|
||||
wire i2c_init_scl_i = i2c_scl_i;
|
||||
wire i2c_init_scl_o;
|
||||
wire i2c_init_sda_i = i2c_sda_i;
|
||||
wire i2c_init_sda_o;
|
||||
|
||||
wire i2c_int_scl_i = i2c_scl_i;
|
||||
wire i2c_int_scl_o;
|
||||
wire i2c_int_sda_i = i2c_sda_i;
|
||||
wire i2c_int_sda_o;
|
||||
|
||||
assign i2c_scl_o = i2c_init_scl_o & i2c_int_scl_o;
|
||||
assign i2c_sda_o = i2c_init_sda_o & i2c_int_sda_o;
|
||||
|
||||
// PLL init
|
||||
taxi_axis_if #(.DATA_W(12)) pll_i2c_cmd();
|
||||
taxi_axis_if #(.DATA_W(8)) pll_i2c_tx();
|
||||
taxi_axis_if #(.DATA_W(8)) pll_i2c_rx();
|
||||
|
||||
assign pll_i2c_rx.tready = 1'b1;
|
||||
|
||||
taxi_i2c_master
|
||||
pll_i2c_master_inst (
|
||||
.clk(cfgmclk_int),
|
||||
.rst(cfgmclk_rst_int),
|
||||
|
||||
/*
|
||||
* Host interface
|
||||
*/
|
||||
.s_axis_cmd(pll_i2c_cmd),
|
||||
.s_axis_tx(pll_i2c_tx),
|
||||
.m_axis_rx(pll_i2c_rx),
|
||||
|
||||
/*
|
||||
* I2C interface
|
||||
*/
|
||||
.scl_i(i2c_init_scl_i),
|
||||
.scl_o(i2c_init_scl_o),
|
||||
.sda_i(i2c_init_sda_i),
|
||||
.sda_o(i2c_init_sda_o),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.busy(),
|
||||
.bus_control(),
|
||||
.bus_active(),
|
||||
.missed_ack(),
|
||||
|
||||
/*
|
||||
* Configuration
|
||||
*/
|
||||
.prescale(SIM ? 15 : 150),
|
||||
.stop_on_idle(1)
|
||||
);
|
||||
|
||||
pll_i2c_init_r2 #(
|
||||
.SIM_SPEEDUP(SIM)
|
||||
)
|
||||
pll_i2c_init_inst (
|
||||
.clk(cfgmclk_int),
|
||||
.rst(cfgmclk_rst_int),
|
||||
|
||||
/*
|
||||
* I2C master interface
|
||||
*/
|
||||
.m_axis_cmd(pll_i2c_cmd),
|
||||
.m_axis_tx(pll_i2c_tx),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.busy(pll_i2c_busy),
|
||||
|
||||
/*
|
||||
* Configuration
|
||||
*/
|
||||
.start(1'b1)
|
||||
);
|
||||
|
||||
localparam PORT_CNT = 2;
|
||||
localparam GTY_QUAD_CNT = PORT_CNT;
|
||||
localparam GTY_CNT = GTY_QUAD_CNT*4;
|
||||
localparam GTY_CLK_CNT = GTY_QUAD_CNT;
|
||||
|
||||
assign fmc_qsfp_modsell = 1'b0;
|
||||
assign fmc_qsfp_resetl = 1'b1;
|
||||
assign fmc_qsfp_lpmode = 1'b0;
|
||||
|
||||
// RF data converters
|
||||
localparam ADC_CNT = 8;
|
||||
localparam ADC_SAMPLE_W = 16;
|
||||
localparam ADC_SAMPLE_CNT = 4;
|
||||
localparam ADC_DATA_W = ADC_SAMPLE_W*ADC_SAMPLE_CNT;
|
||||
|
||||
localparam DAC_CNT = ADC_CNT;
|
||||
localparam DAC_SAMPLE_W = ADC_SAMPLE_W;
|
||||
localparam DAC_SAMPLE_CNT = ADC_SAMPLE_CNT;
|
||||
localparam DAC_DATA_W = DAC_SAMPLE_W*DAC_SAMPLE_CNT;
|
||||
|
||||
wire axil_rfdc_clk = clk_125mhz_int;
|
||||
wire axil_rfdc_rst = rst_125mhz_int;
|
||||
|
||||
taxi_axil_if #(
|
||||
.DATA_W(32),
|
||||
.ADDR_W(18)
|
||||
) axil_rfdc();
|
||||
|
||||
wire axis_rfdc_clk;
|
||||
wire axis_rfdc_rst;
|
||||
|
||||
wire [3:0] adc_clk_out;
|
||||
wire [3:0] dac_clk_out;
|
||||
|
||||
taxi_axis_if #(
|
||||
.DATA_W(ADC_DATA_W),
|
||||
.KEEP_EN(1),
|
||||
.KEEP_W(ADC_SAMPLE_CNT),
|
||||
.LAST_EN(0),
|
||||
.USER_EN(0),
|
||||
.ID_EN(0),
|
||||
.DEST_EN(0)
|
||||
) axis_adc[ADC_CNT]();
|
||||
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_0 = axis_adc[0].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_1 = axis_adc[1].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_2 = axis_adc[2].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_3 = axis_adc[3].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_4 = axis_adc[4].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_5 = axis_adc[5].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_6 = axis_adc[6].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [ADC_DATA_W-1:0] adc_data_7 = axis_adc[7].tdata;
|
||||
|
||||
taxi_axis_if #(
|
||||
.DATA_W(DAC_DATA_W),
|
||||
.KEEP_EN(1),
|
||||
.KEEP_W(DAC_SAMPLE_CNT),
|
||||
.LAST_EN(0),
|
||||
.USER_EN(0),
|
||||
.ID_EN(0),
|
||||
.DEST_EN(0)
|
||||
) axis_dac[DAC_CNT]();
|
||||
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_0 = axis_dac[0].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_1 = axis_dac[1].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_2 = axis_dac[2].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_3 = axis_dac[3].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_4 = axis_dac[4].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_5 = axis_dac[5].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_6 = axis_dac[6].tdata;
|
||||
(* MARK_DEBUG = "TRUE" *)
|
||||
wire [DAC_DATA_W-1:0] dac_data_7 = axis_dac[7].tdata;
|
||||
|
||||
wire rfdc_mmcm_in = dac_clk_out[0];
|
||||
wire rfdc_mmcm_rst = rst_125mhz_int;
|
||||
wire rfdc_mmcm_clkfb;
|
||||
wire rfdc_mmcm_locked;
|
||||
wire rfdc_mmcm_out;
|
||||
|
||||
// MMCM instance
|
||||
MMCME4_BASE #(
|
||||
// 62.5 MHz input
|
||||
.CLKIN1_PERIOD(16.0),
|
||||
.REF_JITTER1(0.010),
|
||||
// 62.5 MHz input / 1 = 62.5 MHz PFD (range 10 MHz to 500 MHz)
|
||||
.DIVCLK_DIVIDE(1),
|
||||
// 62.5 MHz PFD * 20 = 1250 MHz VCO (range 800 MHz to 1600 MHz)
|
||||
.CLKFBOUT_MULT_F(20),
|
||||
.CLKFBOUT_PHASE(0),
|
||||
// 1250 MHz / 5 = 250 MHz, 0 degrees
|
||||
.CLKOUT0_DIVIDE_F(5),
|
||||
.CLKOUT0_DUTY_CYCLE(0.5),
|
||||
.CLKOUT0_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT1_DIVIDE(1),
|
||||
.CLKOUT1_DUTY_CYCLE(0.5),
|
||||
.CLKOUT1_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT2_DIVIDE(1),
|
||||
.CLKOUT2_DUTY_CYCLE(0.5),
|
||||
.CLKOUT2_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT3_DIVIDE(1),
|
||||
.CLKOUT3_DUTY_CYCLE(0.5),
|
||||
.CLKOUT3_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT4_DIVIDE(1),
|
||||
.CLKOUT4_DUTY_CYCLE(0.5),
|
||||
.CLKOUT4_PHASE(0),
|
||||
.CLKOUT4_CASCADE("FALSE"),
|
||||
// Not used
|
||||
.CLKOUT5_DIVIDE(1),
|
||||
.CLKOUT5_DUTY_CYCLE(0.5),
|
||||
.CLKOUT5_PHASE(0),
|
||||
// Not used
|
||||
.CLKOUT6_DIVIDE(1),
|
||||
.CLKOUT6_DUTY_CYCLE(0.5),
|
||||
.CLKOUT6_PHASE(0),
|
||||
|
||||
// optimized bandwidth
|
||||
.BANDWIDTH("OPTIMIZED"),
|
||||
// don't wait for lock during startup
|
||||
.STARTUP_WAIT("FALSE")
|
||||
)
|
||||
rfdc_mmcm_inst (
|
||||
// 62.5 MHz input
|
||||
.CLKIN1(rfdc_mmcm_in),
|
||||
// direct clkfb feeback
|
||||
.CLKFBIN(rfdc_mmcm_clkfb),
|
||||
.CLKFBOUT(rfdc_mmcm_clkfb),
|
||||
.CLKFBOUTB(),
|
||||
// 250 MHz, 0 degrees
|
||||
.CLKOUT0(rfdc_mmcm_out),
|
||||
.CLKOUT0B(),
|
||||
// Not used
|
||||
.CLKOUT1(),
|
||||
.CLKOUT1B(),
|
||||
// Not used
|
||||
.CLKOUT2(),
|
||||
.CLKOUT2B(),
|
||||
// Not used
|
||||
.CLKOUT3(),
|
||||
.CLKOUT3B(),
|
||||
// Not used
|
||||
.CLKOUT4(),
|
||||
// Not used
|
||||
.CLKOUT5(),
|
||||
// Not used
|
||||
.CLKOUT6(),
|
||||
// reset input
|
||||
.RST(rfdc_mmcm_rst),
|
||||
// don't power down
|
||||
.PWRDWN(1'b0),
|
||||
// locked output
|
||||
.LOCKED(rfdc_mmcm_locked)
|
||||
);
|
||||
|
||||
BUFG
|
||||
axis_rfdc_bufg_inst (
|
||||
.I(rfdc_mmcm_out),
|
||||
.O(axis_rfdc_clk)
|
||||
);
|
||||
|
||||
taxi_sync_reset #(
|
||||
.N(4)
|
||||
)
|
||||
axis_rfdc_sync_reset_inst (
|
||||
.clk(axis_rfdc_clk),
|
||||
.rst(!rfdc_mmcm_locked || rfdc_mmcm_rst),
|
||||
.out(axis_rfdc_rst)
|
||||
);
|
||||
|
||||
usp_rfdc_0 rfdc_inst (
|
||||
// Common
|
||||
.sysref_in_p(rfdc_sysref_p),
|
||||
.sysref_in_n(rfdc_sysref_n),
|
||||
|
||||
.s_axi_aclk(axil_rfdc_clk),
|
||||
.s_axi_aresetn(!axil_rfdc_rst),
|
||||
.s_axi_awaddr(axil_rfdc.awaddr),
|
||||
.s_axi_awvalid(axil_rfdc.awvalid),
|
||||
.s_axi_awready(axil_rfdc.awready),
|
||||
.s_axi_wdata(axil_rfdc.wdata),
|
||||
.s_axi_wstrb(axil_rfdc.wstrb),
|
||||
.s_axi_wvalid(axil_rfdc.wvalid),
|
||||
.s_axi_wready(axil_rfdc.wready),
|
||||
.s_axi_bresp(axil_rfdc.bresp),
|
||||
.s_axi_bvalid(axil_rfdc.bvalid),
|
||||
.s_axi_bready(axil_rfdc.bready),
|
||||
.s_axi_araddr(axil_rfdc.araddr),
|
||||
.s_axi_arvalid(axil_rfdc.arvalid),
|
||||
.s_axi_arready(axil_rfdc.arready),
|
||||
.s_axi_rdata(axil_rfdc.rdata),
|
||||
.s_axi_rresp(axil_rfdc.rresp),
|
||||
.s_axi_rvalid(axil_rfdc.rvalid),
|
||||
.s_axi_rready(axil_rfdc.rready),
|
||||
|
||||
.irq(),
|
||||
|
||||
// ADC
|
||||
.adc0_clk_p(adc_refclk_0_p),
|
||||
.adc0_clk_n(adc_refclk_0_n),
|
||||
.clk_adc0(adc_clk_out[0]),
|
||||
|
||||
.adc1_clk_p(adc_refclk_1_p),
|
||||
.adc1_clk_n(adc_refclk_1_n),
|
||||
.clk_adc1(adc_clk_out[1]),
|
||||
|
||||
.adc2_clk_p(adc_refclk_2_p),
|
||||
.adc2_clk_n(adc_refclk_2_n),
|
||||
.clk_adc2(adc_clk_out[2]),
|
||||
|
||||
.adc3_clk_p(adc_refclk_3_p),
|
||||
.adc3_clk_n(adc_refclk_3_n),
|
||||
.clk_adc3(adc_clk_out[3]),
|
||||
|
||||
.vin0_01_p(adc_vin_p[7]),
|
||||
.vin0_01_n(adc_vin_n[7]),
|
||||
.vin0_23_p(adc_vin_p[6]),
|
||||
.vin0_23_n(adc_vin_n[6]),
|
||||
|
||||
.vin1_01_p(adc_vin_p[5]),
|
||||
.vin1_01_n(adc_vin_n[5]),
|
||||
.vin1_23_p(adc_vin_p[4]),
|
||||
.vin1_23_n(adc_vin_n[4]),
|
||||
|
||||
.vin2_01_p(adc_vin_p[3]),
|
||||
.vin2_01_n(adc_vin_n[3]),
|
||||
.vin2_23_p(adc_vin_p[2]),
|
||||
.vin2_23_n(adc_vin_n[2]),
|
||||
|
||||
.vin3_01_p(adc_vin_p[1]),
|
||||
.vin3_01_n(adc_vin_n[1]),
|
||||
.vin3_23_p(adc_vin_p[0]),
|
||||
.vin3_23_n(adc_vin_n[0]),
|
||||
|
||||
.m0_axis_aresetn(!axis_rfdc_rst),
|
||||
.m0_axis_aclk(axis_rfdc_clk),
|
||||
.m00_axis_tdata(axis_adc[7].tdata),
|
||||
.m00_axis_tvalid(axis_adc[7].tvalid),
|
||||
.m00_axis_tready(axis_adc[7].tready),
|
||||
.m02_axis_tdata(axis_adc[6].tdata),
|
||||
.m02_axis_tvalid(axis_adc[6].tvalid),
|
||||
.m02_axis_tready(axis_adc[6].tready),
|
||||
|
||||
.m1_axis_aresetn(!axis_rfdc_rst),
|
||||
.m1_axis_aclk(axis_rfdc_clk),
|
||||
.m10_axis_tdata(axis_adc[5].tdata),
|
||||
.m10_axis_tvalid(axis_adc[5].tvalid),
|
||||
.m10_axis_tready(axis_adc[5].tready),
|
||||
.m12_axis_tdata(axis_adc[4].tdata),
|
||||
.m12_axis_tvalid(axis_adc[4].tvalid),
|
||||
.m12_axis_tready(axis_adc[4].tready),
|
||||
|
||||
.m2_axis_aresetn(!axis_rfdc_rst),
|
||||
.m2_axis_aclk(axis_rfdc_clk),
|
||||
.m20_axis_tdata(axis_adc[3].tdata),
|
||||
.m20_axis_tvalid(axis_adc[3].tvalid),
|
||||
.m20_axis_tready(axis_adc[3].tready),
|
||||
.m22_axis_tdata(axis_adc[2].tdata),
|
||||
.m22_axis_tvalid(axis_adc[2].tvalid),
|
||||
.m22_axis_tready(axis_adc[2].tready),
|
||||
|
||||
.m3_axis_aresetn(!axis_rfdc_rst),
|
||||
.m3_axis_aclk(axis_rfdc_clk),
|
||||
.m30_axis_tdata(axis_adc[1].tdata),
|
||||
.m30_axis_tvalid(axis_adc[1].tvalid),
|
||||
.m30_axis_tready(axis_adc[1].tready),
|
||||
.m32_axis_tdata(axis_adc[0].tdata),
|
||||
.m32_axis_tvalid(axis_adc[0].tvalid),
|
||||
.m32_axis_tready(axis_adc[0].tready),
|
||||
|
||||
.adc0_01_dsa_code(5'd27),
|
||||
.adc0_23_dsa_code(5'd27),
|
||||
.adc0_dsa_update(1'b0),
|
||||
.adc1_01_dsa_code(5'd27),
|
||||
.adc1_23_dsa_code(5'd27),
|
||||
.adc1_dsa_update(1'b0),
|
||||
.adc2_01_dsa_code(5'd27),
|
||||
.adc2_23_dsa_code(5'd27),
|
||||
.adc2_dsa_update(1'b0),
|
||||
.adc3_01_dsa_code(5'd27),
|
||||
.adc3_23_dsa_code(5'd27),
|
||||
.adc3_dsa_update(1'b0),
|
||||
|
||||
// DAC
|
||||
.dac2_clk_p(dac_refclk_1_p),
|
||||
.dac2_clk_n(dac_refclk_1_n),
|
||||
|
||||
.clk_dac0(dac_clk_out[0]),
|
||||
.clk_dac1(dac_clk_out[1]),
|
||||
.clk_dac2(dac_clk_out[2]),
|
||||
.clk_dac3(dac_clk_out[3]),
|
||||
|
||||
.vout00_p(dac_vout_p[7]),
|
||||
.vout00_n(dac_vout_n[7]),
|
||||
.vout02_p(dac_vout_p[6]),
|
||||
.vout02_n(dac_vout_n[6]),
|
||||
|
||||
.vout10_p(dac_vout_p[5]),
|
||||
.vout10_n(dac_vout_n[5]),
|
||||
.vout12_p(dac_vout_p[4]),
|
||||
.vout12_n(dac_vout_n[4]),
|
||||
|
||||
.vout20_p(dac_vout_p[3]),
|
||||
.vout20_n(dac_vout_n[3]),
|
||||
.vout22_p(dac_vout_p[2]),
|
||||
.vout22_n(dac_vout_n[2]),
|
||||
|
||||
.vout30_p(dac_vout_p[1]),
|
||||
.vout30_n(dac_vout_n[1]),
|
||||
.vout32_p(dac_vout_p[0]),
|
||||
.vout32_n(dac_vout_n[0]),
|
||||
|
||||
.s0_axis_aresetn(!axis_rfdc_rst),
|
||||
.s0_axis_aclk(axis_rfdc_clk),
|
||||
.s00_axis_tdata(axis_dac[7].tdata),
|
||||
.s00_axis_tvalid(axis_dac[7].tvalid),
|
||||
.s00_axis_tready(axis_dac[7].tready),
|
||||
.s02_axis_tdata(axis_dac[6].tdata),
|
||||
.s02_axis_tvalid(axis_dac[6].tvalid),
|
||||
.s02_axis_tready(axis_dac[6].tready),
|
||||
|
||||
.s1_axis_aresetn(!axis_rfdc_rst),
|
||||
.s1_axis_aclk(axis_rfdc_clk),
|
||||
.s10_axis_tdata(axis_dac[5].tdata),
|
||||
.s10_axis_tvalid(axis_dac[5].tvalid),
|
||||
.s10_axis_tready(axis_dac[5].tready),
|
||||
.s12_axis_tdata(axis_dac[4].tdata),
|
||||
.s12_axis_tvalid(axis_dac[4].tvalid),
|
||||
.s12_axis_tready(axis_dac[4].tready),
|
||||
|
||||
.s2_axis_aresetn(!axis_rfdc_rst),
|
||||
.s2_axis_aclk(axis_rfdc_clk),
|
||||
.s20_axis_tdata(axis_dac[3].tdata),
|
||||
.s20_axis_tvalid(axis_dac[3].tvalid),
|
||||
.s20_axis_tready(axis_dac[3].tready),
|
||||
.s22_axis_tdata(axis_dac[2].tdata),
|
||||
.s22_axis_tvalid(axis_dac[2].tvalid),
|
||||
.s22_axis_tready(axis_dac[2].tready),
|
||||
|
||||
.s3_axis_aresetn(!axis_rfdc_rst),
|
||||
.s3_axis_aclk(axis_rfdc_clk),
|
||||
.s30_axis_tdata(axis_dac[1].tdata),
|
||||
.s30_axis_tvalid(axis_dac[1].tvalid),
|
||||
.s30_axis_tready(axis_dac[1].tready),
|
||||
.s32_axis_tdata(axis_dac[0].tdata),
|
||||
.s32_axis_tvalid(axis_dac[0].tvalid),
|
||||
.s32_axis_tready(axis_dac[0].tready),
|
||||
|
||||
.dac00_vop_code(10'd895),
|
||||
.dac02_vop_code(10'd895),
|
||||
.dac00_update_vop(1'b0),
|
||||
.dac02_update_vop(1'b0),
|
||||
.dac00_vop_done(),
|
||||
.dac02_vop_done(),
|
||||
.dac0_vop_busy(),
|
||||
|
||||
.dac10_vop_code(10'd895),
|
||||
.dac12_vop_code(10'd895),
|
||||
.dac10_update_vop(1'b0),
|
||||
.dac12_update_vop(1'b0),
|
||||
.dac10_vop_done(),
|
||||
.dac12_vop_done(),
|
||||
.dac1_vop_busy(),
|
||||
|
||||
.dac20_vop_code(10'd895),
|
||||
.dac22_vop_code(10'd895),
|
||||
.dac20_update_vop(1'b0),
|
||||
.dac22_update_vop(1'b0),
|
||||
.dac20_vop_done(),
|
||||
.dac22_vop_done(),
|
||||
.dac2_vop_busy(),
|
||||
|
||||
.dac30_vop_code(10'd895),
|
||||
.dac32_vop_code(10'd895),
|
||||
.dac30_update_vop(1'b0),
|
||||
.dac32_update_vop(1'b0),
|
||||
.dac30_vop_done(),
|
||||
.dac32_vop_done(),
|
||||
.dac3_vop_busy()
|
||||
);
|
||||
|
||||
fpga_core #(
|
||||
.SIM(SIM),
|
||||
.VENDOR(VENDOR),
|
||||
.FAMILY(FAMILY),
|
||||
.PORT_CNT(PORT_CNT),
|
||||
.GTY_QUAD_CNT(GTY_QUAD_CNT),
|
||||
.GTY_CNT(GTY_CNT),
|
||||
.GTY_CLK_CNT(GTY_CLK_CNT),
|
||||
.ADC_CNT(ADC_CNT),
|
||||
.DAC_CNT(DAC_CNT)
|
||||
)
|
||||
core_inst (
|
||||
/*
|
||||
* Clock: 125MHz
|
||||
* Synchronous reset
|
||||
*/
|
||||
.clk_125mhz(clk_125mhz_int),
|
||||
.rst_125mhz(rst_125mhz_int),
|
||||
.fpga_refclk(fpga_refclk_int),
|
||||
.fpga_sysref(fpga_sysref_int),
|
||||
|
||||
/*
|
||||
* GPIO
|
||||
*/
|
||||
.sw(sw_int),
|
||||
.led(led),
|
||||
.gpio(),
|
||||
|
||||
/*
|
||||
* I2C for board management
|
||||
*/
|
||||
.i2c_scl_i(i2c_int_scl_i),
|
||||
.i2c_scl_o(i2c_int_scl_o),
|
||||
.i2c_sda_i(i2c_int_sda_i),
|
||||
.i2c_sda_o(i2c_int_sda_o),
|
||||
|
||||
/*
|
||||
* UART: 921600 bps, 8N1
|
||||
*/
|
||||
.uart_rxd(uart_rxd),
|
||||
.uart_txd(uart_txd_int),
|
||||
.uart_rts(uart_rts_int),
|
||||
.uart_cts(uart_cts),
|
||||
.uart_rst_n(uart_rst_n),
|
||||
.uart_suspend_n(uart_suspend_n),
|
||||
|
||||
/*
|
||||
* Ethernet: QSFP28
|
||||
*/
|
||||
.eth_gty_tx_p(fmc_dp_c2m_p),
|
||||
.eth_gty_tx_n(fmc_dp_c2m_n),
|
||||
.eth_gty_rx_p(fmc_dp_m2c_p),
|
||||
.eth_gty_rx_n(fmc_dp_m2c_n),
|
||||
.eth_gty_mgt_refclk_p({fmc_mgt_refclk_1_0_p, fmc_mgt_refclk_0_0_p}),
|
||||
.eth_gty_mgt_refclk_n({fmc_mgt_refclk_1_0_n, fmc_mgt_refclk_0_0_n}),
|
||||
.eth_gty_mgt_refclk_out(),
|
||||
|
||||
.eth_port_resetl(),
|
||||
.eth_port_modprsl('0),
|
||||
.eth_port_intl('1),
|
||||
|
||||
/*
|
||||
* RFDC
|
||||
*/
|
||||
.axil_rfdc_clk(axil_rfdc_clk),
|
||||
.axil_rfdc_rst(axil_rfdc_rst),
|
||||
.m_axil_rfdc_wr(axil_rfdc),
|
||||
.m_axil_rfdc_rd(axil_rfdc),
|
||||
|
||||
.axis_rfdc_clk(axis_rfdc_clk),
|
||||
.axis_rfdc_rst(axis_rfdc_rst),
|
||||
.s_axis_adc(axis_adc),
|
||||
.m_axis_dac(axis_dac)
|
||||
);
|
||||
|
||||
endmodule
|
||||
|
||||
`resetall
|
||||
Reference in New Issue
Block a user