diff options
Diffstat (limited to 'fpga/usrp3/top/x300/x300.v')
-rw-r--r-- | fpga/usrp3/top/x300/x300.v | 1918 |
1 files changed, 1918 insertions, 0 deletions
diff --git a/fpga/usrp3/top/x300/x300.v b/fpga/usrp3/top/x300/x300.v new file mode 100644 index 000000000..aa77d1bc7 --- /dev/null +++ b/fpga/usrp3/top/x300/x300.v @@ -0,0 +1,1918 @@ +/////////////////////////////////// +// +// NOTE: A set of precompiler directives configure the features in an FPGA build +// and are listed here. These should be set exclusively using the Makefile mechanism provided. +// +// ETH10G_PORT0 - Ethernet Port0 is configured for 10G (default is 1G) +// ETH10G_PORT1 - Ethernet Port1 is configured for 10G (default is 1G) +// NO_DRAM_FIFOS - All DRAM I/F logic, supporting AXI4 and VFIFOs' replaced by internal SRAM FIFOs. +// DELETE_DSP0 - Deletes DUC and DDC from Radio0 +// DELETE_DSP1 - Deletes DUC and DDC from Radio1 +// DEBUG_UART - Adds 115kbaud UART to GPIO pins 10 & 11 for firmware debug +// +/////////////////////////////////// + +//Defines `LVFPGA_IFACE constants +`include "../../lib/io_port2/LvFpga_Chinch_Interface.vh" + +module x300 + + ( + /////////////////////////////////// + // + // Clock sources for main FPGA clocks + // + /////////////////////////////////// + input FPGA_CLK_p, input FPGA_CLK_n, + input FPGA_125MHz_CLK, + + /////////////////////////////////// + // + // High Speed SPF+ signals and clocking + // + /////////////////////////////////// + +`ifdef BUILD_1G + input ETH_CLK_p, input ETH_CLK_n, +`endif + +`ifdef BUILD_10G + input XG_CLK_p, input XG_CLK_n, +`endif + + input SFP0_RX_p, input SFP0_RX_n, + output SFP0_TX_p, output SFP0_TX_n, + input SFP1_RX_p, input SFP1_RX_n, + output SFP1_TX_p, output SFP1_TX_n, + + /////////////////////////////////// + // + // DRAM Interface + // + /////////////////////////////////// +`ifndef NO_DRAM_FIFOS + inout [31:0] ddr3_dq, // Data pins. Input for Reads, Output for Writes. + inout [3:0] ddr3_dqs_n, // Data Strobes. Input for Reads, Output for Writes. + inout [3:0] ddr3_dqs_p, + // + output [14:0] ddr3_addr, // Address + output [2:0] ddr3_ba, // Bank Address + output ddr3_ras_n, // Row Address Strobe. + output ddr3_cas_n, // Column address select + output ddr3_we_n, // Write Enable + output ddr3_reset_n, // SDRAM reset pin. + output [0:0] ddr3_ck_p, // Differential clock + output [0:0] ddr3_ck_n, + output [0:0] ddr3_cke, // Clock Enable + output [0:0] ddr3_cs_n, // Chip Select + output [3:0] ddr3_dm, // Data Mask [3] = UDM.U26, [2] = LDM.U26, ... + output [0:0] ddr3_odt, // On-Die termination enable. + // + input sys_clk_i, // 100MHz clock source to generate DDR3 clocking. +`endif + /////////////////////////////////// + // + // IOPORT2 + // + /////////////////////////////////// + + //-- The IO_Port2 asynchronous handshaking pins + input aIoResetIn_n, + output aIoReadyOut, + input aIoReadyIn, + output aIoPort2Restart, + input aStc3Gpio7, + + //-- The IO_Port2 high speed receiver pins + input IoRxClock, + input IoRxClock_n, + input [15:0] irIoRxData, + input [15:0] irIoRxData_n, + input irIoRxHeader, + input irIoRxHeader_n, + + //-- The IO_Port2 high speed transmitter interface pins + output IoTxClock, + output IoTxClock_n, + output [15:0] itIoTxData, + output [15:0] itIoTxData_n, + output itIoTxHeader, + output itIoTxHeader_n, + + output aIrq, + + /////////////////////////////////// + // + // ADC and DAC interfaces + // + /////////////////////////////////// + + input DB0_ADC_DCLK_P, input DB0_ADC_DCLK_N, + input DB0_ADC_DA0_P, input DB0_ADC_DA0_N, input DB0_ADC_DB0_P, input DB0_ADC_DB0_N, + input DB0_ADC_DA1_P, input DB0_ADC_DA1_N, input DB0_ADC_DB1_P, input DB0_ADC_DB1_N, + input DB0_ADC_DA2_P, input DB0_ADC_DA2_N, input DB0_ADC_DB2_P, input DB0_ADC_DB2_N, + input DB0_ADC_DA3_P, input DB0_ADC_DA3_N, input DB0_ADC_DB3_P, input DB0_ADC_DB3_N, + input DB0_ADC_DA4_P, input DB0_ADC_DA4_N, input DB0_ADC_DB4_P, input DB0_ADC_DB4_N, + input DB0_ADC_DA5_P, input DB0_ADC_DA5_N, input DB0_ADC_DB5_P, input DB0_ADC_DB5_N, + input DB0_ADC_DA6_P, input DB0_ADC_DA6_N, input DB0_ADC_DB6_P, input DB0_ADC_DB6_N, + + input DB1_ADC_DCLK_P, input DB1_ADC_DCLK_N, + input DB1_ADC_DA0_P, input DB1_ADC_DA0_N, input DB1_ADC_DB0_P, input DB1_ADC_DB0_N, + input DB1_ADC_DA1_P, input DB1_ADC_DA1_N, input DB1_ADC_DB1_P, input DB1_ADC_DB1_N, + input DB1_ADC_DA2_P, input DB1_ADC_DA2_N, input DB1_ADC_DB2_P, input DB1_ADC_DB2_N, + input DB1_ADC_DA3_P, input DB1_ADC_DA3_N, input DB1_ADC_DB3_P, input DB1_ADC_DB3_N, + input DB1_ADC_DA4_P, input DB1_ADC_DA4_N, input DB1_ADC_DB4_P, input DB1_ADC_DB4_N, + input DB1_ADC_DA5_P, input DB1_ADC_DA5_N, input DB1_ADC_DB5_P, input DB1_ADC_DB5_N, + input DB1_ADC_DA6_P, input DB1_ADC_DA6_N, input DB1_ADC_DB6_P, input DB1_ADC_DB6_N, + + output DB0_DAC_DCI_P, output DB0_DAC_DCI_N, + output DB0_DAC_FRAME_P, output DB0_DAC_FRAME_N, + output DB0_DAC_D0_P, output DB0_DAC_D0_N, output DB0_DAC_D1_P, output DB0_DAC_D1_N, + output DB0_DAC_D2_P, output DB0_DAC_D2_N, output DB0_DAC_D3_P, output DB0_DAC_D3_N, + output DB0_DAC_D4_P, output DB0_DAC_D4_N, output DB0_DAC_D5_P, output DB0_DAC_D5_N, + output DB0_DAC_D6_P, output DB0_DAC_D6_N, output DB0_DAC_D7_P, output DB0_DAC_D7_N, + output DB0_DAC_ENABLE, + + output DB1_DAC_DCI_P, output DB1_DAC_DCI_N, + output DB1_DAC_FRAME_P, output DB1_DAC_FRAME_N, + output DB1_DAC_D0_P, output DB1_DAC_D0_N, output DB1_DAC_D1_P, output DB1_DAC_D1_N, + output DB1_DAC_D2_P, output DB1_DAC_D2_N, output DB1_DAC_D3_P, output DB1_DAC_D3_N, + output DB1_DAC_D4_P, output DB1_DAC_D4_N, output DB1_DAC_D5_P, output DB1_DAC_D5_N, + output DB1_DAC_D6_P, output DB1_DAC_D6_N, output DB1_DAC_D7_P, output DB1_DAC_D7_N, + output DB1_DAC_ENABLE, + + output DB0_SCLK, output DB0_MOSI, + output DB0_ADC_SEN, output DB0_DAC_SEN, output DB0_TX_SEN, output DB0_RX_SEN, + output DB0_RX_LSADC_SEN, output DB0_RX_LSDAC_SEN, output DB0_TX_LSADC_SEN, output DB0_TX_LSDAC_SEN, + input DB0_RX_LSADC_MISO, input DB0_RX_MISO, input DB0_TX_LSADC_MISO, input DB0_TX_MISO, + + output DB1_SCLK, output DB1_MOSI, + output DB1_ADC_SEN, output DB1_DAC_SEN, output DB1_TX_SEN, output DB1_RX_SEN, + output DB1_RX_LSADC_SEN, output DB1_RX_LSDAC_SEN, output DB1_TX_LSADC_SEN, output DB1_TX_LSDAC_SEN, + input DB1_RX_LSADC_MISO, input DB1_RX_MISO, input DB1_TX_LSADC_MISO, input DB1_TX_MISO, + output DB_DAC_SCLK, inout DB_DAC_MOSI, + + output DB_ADC_RESET, output DB_DAC_RESET, + + inout DB_SCL, inout DB_SDA, + + /////////////////////////////////// + // + // GPIO/LEDS/Etc + // + /////////////////////////////////// + + inout [11:0] FrontPanelGpio, + + output LED_ACT1, output LED_ACT2, + output LED_LINK1, output LED_LINK2, + + output LED_PPS, output LED_REFLOCK, output LED_GPSLOCK, + output LED_LINKSTAT, output LED_LINKACT, + output LED_RX1_RX, output LED_RX2_RX, + output LED_TXRX1_RX, output LED_TXRX1_TX, + output LED_TXRX2_RX, output LED_TXRX2_TX, + inout [15:0] DB0_TX_IO, + inout [15:0] DB0_RX_IO, + inout [15:0] DB1_TX_IO, + inout [15:0] DB1_RX_IO, + + /////////////////////////////////// + // + // LMK CLock chip + // + /////////////////////////////////// + + input [1:0] LMK_Status, + input LMK_Holdover, + input LMK_Lock, + input LMK_Sync, //not used, we do soft sync + output LMK_SEN, output LMK_MOSI, output LMK_SCLK, + + /////////////////////////////////// + // + // GPSDO and Clock Refs + // + /////////////////////////////////// + + output [1:0] ClockRefSelect, + output GPS_SER_IN, input GPS_SER_OUT, + input GPS_PPS_OUT, input EXT_PPS_IN, + output EXT_PPS_OUT, input GPS_LOCK_OK, + output GPSDO_PWR_ENA, output TCXO_ENA, + + output CPRI_CLK_OUT_P, output CPRI_CLK_OUT_N, + + input FPGA_REFCLK_10MHz_p, input FPGA_REFCLK_10MHz_n, + + /////////////////////////////////// + // + // Supporting I/O for SPF+ interfaces + // (non high speed stuff) + // + /////////////////////////////////// + + inout SFPP0_SCL, inout SFPP0_SDA, + input SFPP0_ModAbs, + input SFPP0_RxLOS, // High if module asserts Loss of Signal + input SFPP0_TxFault, // Current 10G PMA/PCS apparently ignores this signal. + output SFPP0_RS0, // These are actually open drain outputs + output SFPP0_RS1, // CAUTION! Take great care, this signal shorted to VeeR on SFP module. + output SFPP0_TxDisable, // These are actually open drain outputs + + inout SFPP1_SCL, inout SFPP1_SDA, + input SFPP1_ModAbs, + input SFPP1_RxLOS, // High if module asserts Loss of Signal + input SFPP1_TxFault, // Current 10G PMA/PCS apparently ignores this signal. + output SFPP1_RS0, // These are actually open drain outputs + output SFPP1_RS1, // CAUTION! Take great care, this signal shorted to VeeR on SFP module. + output SFPP1_TxDisable // These are actually open drain outputs + + ); + + // + // LOG2 function. + // + function integer clogb2 (input integer size); + begin + size = size - 1; + for (clogb2=1; size>1; clogb2=clogb2+1) + size = size >> 1; + end + endfunction // clogb2 + + + wire radio_clk, radio_clk_2x; + wire global_rst, radio_rst, bus_rst; + + wire [3:0] sw_rst; + + + wire [63:0] vita_time; + wire [2:0] led0, led1; + + wire [31:0] debug0, debug1; + + ///////////////////////////////////////////////////////////////////// + // + // Debug logic on front panel GPIO pins + // + ////////////////////////////////////////////////////////////////////// + wire debug_txd, debug_rxd; + + `ifdef DEBUG_UART + assign FrontPanelGpio[11] = debug_txd; + + assign debug_rxd = FrontPanelGpio[10]; + + + `endif + + //////////////////////////////////////////////////////////////////// + // + // Generate Bus Clock and PCIe Clocks. + // Source clock comes from U19 which is fixed freq + // and bufferd to be used by STC3 also (Page17 schematics). + // + //////////////////////////////////////////////////////////////////// + + wire fpga_clk125, bus_clk, ioport2_clk, rio40_clk, ioport2_idelay_ref_clk; + wire bus_clk_locked, rio40_clk_locked, rio40_clk_reset; + + IBUFG fpga_125MHz_clk_buf ( + .I(FPGA_125MHz_CLK), + .O(fpga_clk125)); + + bus_clk_gen bus_clk_gen ( + .CLK_IN1(fpga_clk125), //Input Clock: 125MHz Clock from STC3 + .CLK_OUT1(bus_clk), //Output Clock 1: 175MHz + .CLK_OUT2(ioport2_clk), //Output Clock 2: 125MHz + .RESET(1'b0), + .LOCKED(bus_clk_locked)); + + //rio40_clk and ioport2_idelay_ref_clk cannot share a PLL/MMCM reset with ioport2_clk + //so they have to come from a different clocking primitive instance + pcie_clk_gen pcie_clk_gen ( + .CLK_IN1(fpga_clk125), //Input Clock: 125MHz Clock from STC3 + .CLK_OUT1(rio40_clk), //Output Clock 1: 40MHz + .CLK_OUT2(ioport2_idelay_ref_clk), //Output Clock 2: 200MHz + .RESET(rio40_clk_reset), + .LOCKED(rio40_clk_locked)); + + ///////////////////////////////////////////////////////////////////// + // + // 10MHz Reference clock + // + ////////////////////////////////////////////////////////////////////// + wire ref_clk_10mhz; + IBUFDS IBUFDS_10_MHz ( + .O(ref_clk_10mhz), + .I(FPGA_REFCLK_10MHz_p), + .IB(FPGA_REFCLK_10MHz_n) + ); + + ////////////////////////////////////////////////////////////////////// + // CPRI Clock output -- this is the dirty recovered clock from the MGT + // This goes to the LMK04816 which locks to it and cleans it up + // We get the clean versions back as CPRI_CLK (for the CPRI MGT) + // and FPGA_CLK (for our main rfclk) + ////////////////////////////////////////////////////////////////////// + + wire cpri_clk_out = 1'b0; // FIXME - connect to CPRI clock recovery when implemented + OBUFDS OBUFDS_cpri (.I(cpri_clk_out), .O(CPRI_CLK_OUT_P), .OB(CPRI_CLK_OUT_N)); + + ///////////////////////////////////////////////////////////////////// + // + // power-on-reset logic. + // + ////////////////////////////////////////////////////////////////////// + por_gen por_gen(.clk(bus_clk), .reset_out(global_rst)); + + ////////////////////////////////////////////////////////////////////// + wire sync_dacs_radio0, sync_dacs_radio1; + wire [31:0] rx0, rx1; + wire [31:0] tx0, tx1; + wire sclk0, mosi0, miso0, sclk1, mosi1, miso1; + wire [7:0] sen0, sen1; + + wire set_stb; + wire [7:0] set_addr; + wire [31:0] set_data; + + //////////////////////////////////////////////////////////////////// + // + // Generate Radio Clocks from LMK04816 + // Radio clock is normally 200MHz, radio_clk_2x 400MHz. + // In CPRI or LTE mode, radio clock is 184.32 MHz. + // radio_clk_2x is only to be used for clocking out TX samples to DAC + // + //////////////////////////////////////////////////////////////////// + wire radio_clk_locked; + + radio_clk_gen radio_clk_gen + (.CLK_IN1_P(FPGA_CLK_p), .CLK_IN1_N(FPGA_CLK_n), .CLK_OUT1(radio_clk), .CLK_OUT2(radio_clk_2x), + .RESET(sw_rst[2]), .LOCKED(radio_clk_locked)); + defparam radio_clk_gen.clkin1_buf.DIFF_TERM = "TRUE"; + + //////////////////////////////////////////////////////////////////// + // + // IJB. Radio PLL doesn't seem to lock at power up. + // Probably needs AD9610 to be programmed to 120 or 200MHz to get + // an input clock thats in the ball park for PLL configuration. + // Currently use busclk PLL lock signal to control this reset, + // but we should find a better solution, perhaps a S/W controllable + // reset like the ETH PHY uses so that we can reset this clock domain + // after programming the AD9610. + // + //////////////////////////////////////////////////////////////////// + + reset_sync radio_reset_sync + ( + .clk(radio_clk), + .reset_in(global_rst || !bus_clk_locked || sw_rst[1]), + .reset_out(radio_rst) + ); + + reset_sync int_reset_sync + ( + .clk(bus_clk), + .reset_in(global_rst || !bus_clk_locked), + .reset_out(bus_rst) + ); + + //////////////////////////////////////////////////////////////////// + + assign LED_PPS = ~(GPS_PPS_OUT | EXT_PPS_IN); + assign LED_GPSLOCK = ~GPS_LOCK_OK; + assign LED_REFLOCK = ~LMK_Lock; + assign {LED_RX1_RX,LED_TXRX1_TX,LED_TXRX1_RX} = ~led0; // active low LED driver + assign {LED_RX2_RX,LED_TXRX2_TX,LED_TXRX2_RX} = ~led1; // active low LED driver + // Allocate SPI chip selects to various slaves. + assign {DB1_DAC_SEN, DB1_ADC_SEN, DB1_RX_LSADC_SEN, DB1_RX_LSDAC_SEN, DB1_TX_LSADC_SEN, DB1_TX_LSDAC_SEN, DB1_RX_SEN, DB1_TX_SEN} = sen1; + assign {DB0_DAC_SEN, DB0_ADC_SEN, DB0_RX_LSADC_SEN, DB0_RX_LSDAC_SEN, DB0_TX_LSADC_SEN, DB0_TX_LSDAC_SEN, DB0_RX_SEN, DB0_TX_SEN} = sen0; + + wire db_dac_mosi_int, db_dac_miso; + wire drive_dac_pin; + reg drop_dac_pin; + reg [5:0] bitcount; + reg sclk_d1; + + // Register copy of outgoing DAC clock to do synchronous edge detect. + always @(posedge radio_clk) sclk_d1 <= DB_DAC_SCLK; + + always @(posedge radio_clk) + // If neither DAC is selected keep counter reset + if(DB0_DAC_SEN & DB1_DAC_SEN) + begin + bitcount <= 6'd0; + drop_dac_pin <= 1'b0; + end + else if(~DB_DAC_SCLK & sclk_d1) + // Falling edge of SCLK detected. + begin + bitcount <= bitcount + 6'd1; + end + else if(bitcount == 0 & DB_DAC_SCLK & ~sclk_d1) + // On first rising edge store R/W bit to determine if we tristate after 8bits for a Read. + drop_dac_pin <= db_dac_mosi_int; + + assign drive_dac_pin = (bitcount < 8) | ~drop_dac_pin; + + // Both DAC's use a single SPI bus on PCB. Select appriate Radio to drive the SPi bus by looking at chip selects. + assign { DB_DAC_SCLK, db_dac_mosi_int } = ~DB0_DAC_SEN ? {sclk0, mosi0} : ~DB1_DAC_SEN ? {sclk1,mosi1} : 2'b0; + // Data to/from DAC's is bi-dir so tristate driver when reading. + assign DB_DAC_MOSI = drive_dac_pin ? db_dac_mosi_int : 1'bz; + // I/O Input buffer + assign db_dac_miso = DB_DAC_MOSI; + + // If any SPI Slave is selected (except DAC) then drive SPI clk and MOSI out onto duaghterboard. + assign { DB0_SCLK, DB0_MOSI } = (~&sen0[6:0]) ? {sclk0,mosi0} : 2'b0; + assign { DB1_SCLK, DB1_MOSI } = (~&sen1[6:0]) ? {sclk1,mosi1} : 2'b0; + + // Wired OR Mux together the possible sources of read data from SPI devices. + assign miso0 = (~DB0_RX_LSADC_SEN & DB0_RX_LSADC_MISO) | + (~DB0_RX_SEN & DB0_RX_MISO) | + (~DB0_TX_LSADC_SEN & DB0_TX_LSADC_MISO) | + (~DB0_TX_SEN & DB0_TX_MISO) | + (~DB0_DAC_SEN & db_dac_miso); + + assign miso1 = (~DB1_RX_LSADC_SEN & DB1_RX_LSADC_MISO) | + (~DB1_RX_SEN & DB1_RX_MISO) | + (~DB1_TX_LSADC_SEN & DB1_TX_LSADC_MISO) | + (~DB1_TX_SEN & DB1_TX_MISO) | + (~DB1_DAC_SEN & db_dac_miso); + + ///////////////////////////////////////////////////////////////////// + // + // ADC Interface for ADS62P48 + // + ///////////////////////////////////////////////////////////////////// + wire [13:0] rx0_q_inv, rx1_q_inv, rx0_i, rx1_i; + // Analog diff pairs on I side of ADC are inverted for layout reasons, but data diff pairs are all swapped as well + // so I gets a double negative, and is unchanged. Q must be inverted. + + capture_ddrlvds #(.WIDTH(14),.B250(1)) cap_db0 + (.clk(radio_clk), .reset(radio_rst), .ssclk_p(DB0_ADC_DCLK_P), .ssclk_n(DB0_ADC_DCLK_N), + .in_p({{DB0_ADC_DA6_P, DB0_ADC_DA5_P, DB0_ADC_DA4_P, DB0_ADC_DA3_P, DB0_ADC_DA2_P, DB0_ADC_DA1_P, DB0_ADC_DA0_P}, + {DB0_ADC_DB6_P, DB0_ADC_DB5_P, DB0_ADC_DB4_P, DB0_ADC_DB3_P, DB0_ADC_DB2_P, DB0_ADC_DB1_P, DB0_ADC_DB0_P}}), + + .in_n({{DB0_ADC_DA6_N, DB0_ADC_DA5_N, DB0_ADC_DA4_N, DB0_ADC_DA3_N, DB0_ADC_DA2_N, DB0_ADC_DA1_N, DB0_ADC_DA0_N}, + {DB0_ADC_DB6_N, DB0_ADC_DB5_N, DB0_ADC_DB4_N, DB0_ADC_DB3_N, DB0_ADC_DB2_N, DB0_ADC_DB1_N, DB0_ADC_DB0_N}}), + .out({rx0_i,rx0_q_inv})); + assign rx0[31:0] = { rx0_i, 2'b00, ~rx0_q_inv, 2'b00 }; + + capture_ddrlvds #(.WIDTH(14),.B250(1)) cap_db1 + (.clk(radio_clk), .reset(radio_rst), .ssclk_p(DB1_ADC_DCLK_P), .ssclk_n(DB1_ADC_DCLK_N), + .in_p({{DB1_ADC_DA6_P, DB1_ADC_DA5_P, DB1_ADC_DA4_P, DB1_ADC_DA3_P, DB1_ADC_DA2_P, DB1_ADC_DA1_P, DB1_ADC_DA0_P}, + {DB1_ADC_DB6_P, DB1_ADC_DB5_P, DB1_ADC_DB4_P, DB1_ADC_DB3_P, DB1_ADC_DB2_P, DB1_ADC_DB1_P, DB1_ADC_DB0_P}}), + + .in_n({{DB1_ADC_DA6_N, DB1_ADC_DA5_N, DB1_ADC_DA4_N, DB1_ADC_DA3_N, DB1_ADC_DA2_N, DB1_ADC_DA1_N, DB1_ADC_DA0_N}, + {DB1_ADC_DB6_N, DB1_ADC_DB5_N, DB1_ADC_DB4_N, DB1_ADC_DB3_N, DB1_ADC_DB2_N, DB1_ADC_DB1_N, DB1_ADC_DB0_N}}), + .out({rx1_i,rx1_q_inv})); + assign rx1[31:0] = { rx1_i, 2'b00, ~rx1_q_inv, 2'b00 }; + + ///////////////////////////////////////////////////////////////////// + // + // DAC Interface for AD9146 + // + ///////////////////////////////////////////////////////////////////// + gen_ddrlvds gen_db0 + ( + .reset(radio_rst), + .tx_clk_2x_p(DB0_DAC_DCI_P), .tx_clk_2x_n(DB0_DAC_DCI_N), + .tx_frame_p(DB0_DAC_FRAME_P), .tx_frame_n(DB0_DAC_FRAME_N), + .tx_d_p({DB0_DAC_D7_P,DB0_DAC_D6_P,DB0_DAC_D5_P,DB0_DAC_D4_P,DB0_DAC_D3_P,DB0_DAC_D2_P,DB0_DAC_D1_P,DB0_DAC_D0_P}), + .tx_d_n({DB0_DAC_D7_N,DB0_DAC_D6_N,DB0_DAC_D5_N,DB0_DAC_D4_N,DB0_DAC_D3_N,DB0_DAC_D2_N,DB0_DAC_D1_N,DB0_DAC_D0_N}), + .tx_clk_2x(radio_clk_2x), .tx_clk_1x(radio_clk), + .i(~tx0[31:16]), .q(~tx0[15:0]), // invert b/c Analog diff pairs are swapped for layout + .sync_dacs(sync_dacs_radio0|sync_dacs_radio1) + ); + + + gen_ddrlvds gen_db1 + ( + .reset(radio_rst), + .tx_clk_2x_p(DB1_DAC_DCI_P), .tx_clk_2x_n(DB1_DAC_DCI_N), + .tx_frame_p(DB1_DAC_FRAME_P), .tx_frame_n(DB1_DAC_FRAME_N), + .tx_d_p({DB1_DAC_D7_P,DB1_DAC_D6_P,DB1_DAC_D5_P,DB1_DAC_D4_P,DB1_DAC_D3_P,DB1_DAC_D2_P,DB1_DAC_D1_P,DB1_DAC_D0_P}), + .tx_d_n({DB1_DAC_D7_N,DB1_DAC_D6_N,DB1_DAC_D5_N,DB1_DAC_D4_N,DB1_DAC_D3_N,DB1_DAC_D2_N,DB1_DAC_D1_N,DB1_DAC_D0_N}), + .tx_clk_2x(radio_clk_2x), .tx_clk_1x(radio_clk), + .i(~tx1[31:16]), .q(~tx1[15:0]), // invert b/c Analog diff pairs are swapped for layout + .sync_dacs(sync_dacs_radio0|sync_dacs_radio1) + ); + + + wire [7:0] leds; + assign { LED_ACT1, LED_ACT2, + LED_LINK1, LED_LINK2, + LED_LINKSTAT, LED_LINKACT } = ~leds; + + wire [31:0] debug; + + ////////////////////////////////////////////////////////////////////// + // + // PCIe Stuff + // + ////////////////////////////////////////////////////////////////////// + + localparam IOP2_MSG_WIDTH = 64; + localparam DMA_STREAM_WIDTH = `LVFPGA_IFACE_DMA_CHAN_WIDTH; + localparam DMA_COUNT_WIDTH = `LVFPGA_IFACE_DMA_SIZE_WIDTH; + localparam NUM_TX_STREAMS = `LVFPGA_IFACE_NUM_TX_DMA_CNT; + localparam NUM_RX_STREAMS = `LVFPGA_IFACE_NUM_RX_DMA_CNT; + localparam TX_STREAM_START_IDX = `LVFPGA_IFACE_TX_DMA_INDEX; + localparam RX_STREAM_START_IDX = `LVFPGA_IFACE_RX_DMA_INDEX; + + wire [DMA_STREAM_WIDTH-1:0] dmatx_tdata, dmarx_tdata; + wire dmatx_tvalid, dmarx_tvalid; + wire dmatx_tlast, dmarx_tlast; + wire dmatx_tready, dmarx_tready; + + wire [IOP2_MSG_WIDTH-1:0] o_iop2_msg_tdata, i_iop2_msg_tdata; + wire o_iop2_msg_tvalid, o_iop2_msg_tlast, o_iop2_msg_tready; + wire i_iop2_msg_tvalid, i_iop2_msg_tlast, i_iop2_msg_tready; + + wire pcie_usr_reg_wr, pcie_usr_reg_rd, pcie_usr_reg_rc, pcie_usr_reg_rdy; + wire [1:0] pcie_usr_reg_len; + wire [19:0] pcie_usr_reg_addr; + wire [31:0] pcie_usr_reg_data_in, pcie_usr_reg_data_out; + + wire chinch_reg_wr, chinch_reg_rd, chinch_reg_rc, chinch_reg_rdy; + wire [1:0] chinch_reg_len; + wire [19:0] chinch_reg_addr; + wire [31:0] chinch_reg_data_out; + wire [63:0] chinch_reg_data_in; + + wire [(NUM_TX_STREAMS*DMA_STREAM_WIDTH)-1:0] dmatx_tdata_iop2; + wire [NUM_TX_STREAMS-1:0] dmatx_tvalid_iop2, dmatx_tready_iop2; + + wire [(NUM_RX_STREAMS*DMA_STREAM_WIDTH)-1:0] dmarx_tdata_iop2; + wire [NUM_RX_STREAMS-1:0] dmarx_tvalid_iop2, dmarx_tready_iop2; + + //PCIe Express "Physical" DMA and Register logic + LvFpga_Chinch_Interface lvfpga_chinch_inst + ( + .aIoResetIn_n(aIoResetIn_n), + .bBusReset(), //Output + + // Clocks + .BusClk(ioport2_clk), + .Rio40Clk(rio40_clk), + .IDelayRefClk(ioport2_idelay_ref_clk), + .aRioClkPllLocked(rio40_clk_locked), + .aRioClkPllReset(rio40_clk_reset), + + // The IO_Port2 asynchronous handshaking pins + .aIoReadyOut(aIoReadyOut), + .aIoReadyIn(aIoReadyIn), + .aIoPort2Restart(aIoPort2Restart), + + // The IO_Port2 high speed receiver pins + .IoRxClock(IoRxClock), + .IoRxClock_n(IoRxClock_n), + .irIoRxData(irIoRxData), + .irIoRxData_n(irIoRxData_n), + .irIoRxHeader(irIoRxHeader), + .irIoRxHeader_n(irIoRxHeader_n), + + // The IO_Port2 high speed transmitter interface pins + .IoTxClock(IoTxClock), + .IoTxClock_n(IoTxClock_n), + .itIoTxData(itIoTxData), + .itIoTxData_n(itIoTxData_n), + .itIoTxHeader(itIoTxHeader), + .itIoTxHeader_n(itIoTxHeader_n), + + // DMA TX Fifos + .bDmaTxData(dmatx_tdata_iop2), + .bDmaTxValid(dmatx_tvalid_iop2), + .bDmaTxReady(dmatx_tready_iop2), + .bDmaTxEnabled(), + .bDmaTxFifoFullCnt(), + + // DMA RX Fifos + .bDmaRxData(dmarx_tdata_iop2), + .bDmaRxValid(dmarx_tvalid_iop2), + .bDmaRxReady(dmarx_tready_iop2), + .bDmaRxEnabled(), + .bDmaRxFifoFreeCnt(), + + // User Register Port In + .bUserRegPortInWt(pcie_usr_reg_wr), + .bUserRegPortInRd(pcie_usr_reg_rd), + .bUserRegPortInAddr(pcie_usr_reg_addr), + .bUserRegPortInData(pcie_usr_reg_data_in), + .bUserRegPortInSize(pcie_usr_reg_len), + + // User Register Port Out + .bUserRegPortOutData(pcie_usr_reg_data_out), + .bUserRegPortOutDataValid(pcie_usr_reg_rc), + .bUserRegPortOutReady(pcie_usr_reg_rdy), + + // Chinch Register Port Out + .bChinchRegPortOutWt(chinch_reg_wr), + .bChinchRegPortOutRd(chinch_reg_rd), + .bChinchRegPortOutAddr({12'h0, chinch_reg_addr}), + .bChinchRegPortOutData({32'h0, chinch_reg_data_out}), + .bChinchRegPortOutSize(chinch_reg_len), + + // User Register Port In + .bChinchRegPortInData(chinch_reg_data_in), + .bChinchRegPortInDataValid(chinch_reg_rc), + .bChinchRegPortInReady(chinch_reg_rdy), + + // Level interrupt + .aIrq(aIrq) + ); + + //PCIe Express adapter logic to link to the AXI crossbar and the WB bus + x300_pcie_int #( + .DMA_STREAM_WIDTH(DMA_STREAM_WIDTH), + .NUM_TX_STREAMS(NUM_TX_STREAMS), + .NUM_RX_STREAMS(NUM_RX_STREAMS), + .REGPORT_ADDR_WIDTH(20), + .REGPORT_DATA_WIDTH(32), + .IOP2_MSG_WIDTH(IOP2_MSG_WIDTH) + ) x300_pcie_int ( + .ioport2_clk(ioport2_clk), + .bus_clk(bus_clk), + .bus_rst(bus_rst), + + //DMA TX FIFOs (IoPort2 Clock Domain) + .dmatx_tdata_iop2(dmatx_tdata_iop2), + .dmatx_tvalid_iop2(dmatx_tvalid_iop2), + .dmatx_tready_iop2(dmatx_tready_iop2), + + //DMA TX FIFOs (IoPort2 Clock Domain) + .dmarx_tdata_iop2(dmarx_tdata_iop2), + .dmarx_tvalid_iop2(dmarx_tvalid_iop2), + .dmarx_tready_iop2(dmarx_tready_iop2), + + //PCIe User Regport + .pcie_usr_reg_wr(pcie_usr_reg_wr), + .pcie_usr_reg_rd(pcie_usr_reg_rd), + .pcie_usr_reg_addr(pcie_usr_reg_addr), + .pcie_usr_reg_data_in(pcie_usr_reg_data_in), + .pcie_usr_reg_len(pcie_usr_reg_len), + .pcie_usr_reg_data_out(pcie_usr_reg_data_out), + .pcie_usr_reg_rc(pcie_usr_reg_rc), + .pcie_usr_reg_rdy(pcie_usr_reg_rdy), + + //Chinch Regport + .chinch_reg_wr(chinch_reg_wr), + .chinch_reg_rd(chinch_reg_rd), + .chinch_reg_addr(chinch_reg_addr), + .chinch_reg_data_out(chinch_reg_data_out), + .chinch_reg_len(chinch_reg_len), + .chinch_reg_data_in(chinch_reg_data_in[31:0]), + .chinch_reg_rc(chinch_reg_rc), + .chinch_reg_rdy(chinch_reg_rdy), + + //DMA TX FIFO (Bus Clock Domain) + .dmatx_tdata(dmatx_tdata), + .dmatx_tlast(dmatx_tlast), + .dmatx_tvalid(dmatx_tvalid), + .dmatx_tready(dmatx_tready), + + //DMA RX FIFO (Bus Clock Domain) + .dmarx_tdata(dmarx_tdata), + .dmarx_tlast(dmarx_tlast), + .dmarx_tvalid(dmarx_tvalid), + .dmarx_tready(dmarx_tready), + + //Message FIFO Out (Bus Clock Domain) + .rego_tdata(o_iop2_msg_tdata), + .rego_tvalid(o_iop2_msg_tvalid), + .rego_tlast(o_iop2_msg_tlast), + .rego_tready(o_iop2_msg_tready), + + //Message FIFO In (Bus Clock Domain) + .regi_tdata(i_iop2_msg_tdata), + .regi_tvalid(i_iop2_msg_tvalid), + .regi_tlast(i_iop2_msg_tlast), + .regi_tready(i_iop2_msg_tready), + + //Misc + .misc_status({31'h0, aStc3Gpio7}), + .debug() + ); + + ////////////////////////////////////////////////////////////////////// + // + // Configure Ethernet PHY clocking + // + ////////////////////////////////////////////////////////////////////// +`ifdef BUILD_1G + wire gige_sfp_clk; + + IBUFDS_GTE2 gige_clk_sfp_pin (.O(gige_sfp_clk),.I(ETH_CLK_p),.IB(ETH_CLK_n), .CEB(1'b0)); +`endif +`ifdef BUILD_10G + wire xgige_sfp_clk; + wire xgige_sfp_clk_bufg; + + IBUFDS_GTE2 clk_sfp_pin (.O(xgige_sfp_clk),.I(XG_CLK_p),.IB(XG_CLK_n), .CEB(1'b0)); + + BUFG xgige_bufg_inst + ( + .I (xgige_sfp_clk), + .O (xgige_sfp_clk_bufg) + ); +`endif + + ////////////////////////////////////////////////////////////////////// + // + // Configure Ethernet PHY implemented for PORT0 + // + ////////////////////////////////////////////////////////////////////// + wire mdc0, mdio_in0, mdio_out0, mdio_tri0; + wire [4:0] prtad0 = 5'b00100; // MDIO address is 4 + +`ifdef ETH10G_PORT0 + ////////////////////////////////////////////////////////////////////// + // + // 10GBaseR PHY with XGMII interface to MAC + // + ////////////////////////////////////////////////////////////////////// + wire xgmii_clk0; // 156.25MHz + wire [63:0] xgmii_txd0; + wire [7:0] xgmii_txc0; + wire [63:0] xgmii_rxd0; + wire [7:0] xgmii_rxc0; + + wire [7:0] core_status0; + wire xge_phy_resetdone0; + + ten_gig_eth_pcs_pma_x300_top ten_gig_eth_pcs_pma_x300_top_port0 + ( + .refclk156(xgige_sfp_clk), + .refclk156_buf(xgige_sfp_clk_bufg), + .clk156(xgmii_clk0), + .reset(global_rst | sw_rst[0]), + .xgmii_txd(xgmii_txd0), + .xgmii_txc(xgmii_txc0), + .xgmii_rxd(xgmii_rxd0), + .xgmii_rxc(xgmii_rxc0), + .txp(SFP0_TX_p), + .txn(SFP0_TX_n), + .rxp(SFP0_RX_p), + .rxn(SFP0_RX_n), + .mdc(mdc0), + .mdio_in(mdio_in0), + .mdio_out(mdio_out0), + .mdio_tri(mdio_tri0), + .prtad(prtad0), + .core_status(core_status0), // Ignore for now. IJB + .resetdone(xge_phy_resetdone0), + .signal_detect(~SFPP0_RxLOS), // Undocumented, but it seems Xilinx expect this to be inverted. + .tx_fault(SFPP0_TxFault), + .tx_disable(SFPP0_TxDisable) + ); + +`else + + ////////////////////////////////////////////////////////////////////// + // + // 1000Base-X PHY with GMII interface to MAC + // + ////////////////////////////////////////////////////////////////////// + wire [31:0] gige_phy_misc_dbg0; + wire [15:0] gige_phy_int_data0; + wire [7:0] gmii_txd0, gmii_rxd0; + wire gmii_tx_en0, gmii_tx_er0, gmii_rx_dv0, gmii_rx_er0; + wire gmii_clk0; + wire [15:0] gmii_status0; + + assign SFPP0_TxDisable = 1'b0; // Always on. + + gige_phy_mdio gige_phy_port0 + ( + .reset(global_rst | sw_rst[0]), + .independent_clock(bus_clk), + .sfp_clk(gige_sfp_clk), + .SFP_TX_p(SFP0_TX_p), + .SFP_TX_n(SFP0_TX_n), + .SFP_RX_p(SFP0_RX_p), + .SFP_RX_n(SFP0_RX_n), + .gmii_clk(gmii_clk0), + .gmii_txd(gmii_txd0), + .gmii_tx_en(gmii_tx_en0), + .gmii_tx_er(gmii_tx_er0), + .gmii_rxd(gmii_rxd0), + .gmii_rx_dv(gmii_rx_dv0), + .gmii_rx_er(gmii_rx_er0), + .misc_debug(gige_phy_misc_dbg0), + .int_data(gige_phy_int_data0), + .status_vector(gmii_status0), + // MDIO signals + .prtad(prtad0), + .mdc(mdc0), + .mdio_i(mdio_in0), + .mdio_o(mdio_out0), + .mdio_t(mdio_tri0) + ); + + wire [35:0] CONTROL0; + + +/* -----\/----- EXCLUDED -----\/----- + + chipscope_ila chipscope_ila_i0 + ( + .CONTROL(CONTROL0), // INOUT BUS [35:0] + .CLK(mdc0), // IN + .TRIG0( + { + gmii_status0, //31:16 + 3'b0, prtad0, //15:8 + 4'b0, 1'b0, mdio_in0, mdio_out0, mdio_tri0 //7:0 + } + ) // IN BUS [191:0] + ); + + chipscope_icon chipscope_icon_i0 + ( + .CONTROL0(CONTROL0) // INOUT BUS [35:0] + ); + + -----/\----- EXCLUDED -----/\----- */ + +`endif // !`ifdef + + ////////////////////////////////////////////////////////////////////// + // + // Configure Ethernet PHY implemented for PORT1 + // + ////////////////////////////////////////////////////////////////////// + wire mdc1, mdio_in1, mdio_out1, mdio_tri1; + wire [4:0] prtad1 = 5'b00100; // MDIO address is 4 + +`ifdef ETH10G_PORT1 + ////////////////////////////////////////////////////////////////////// + // + // 10GBaseR PHY with XGMII interface to MAC + // + ////////////////////////////////////////////////////////////////////// + wire xgmii_clk1; // 156.25MHz + wire [63:0] xgmii_txd1; + wire [7:0] xgmii_txc1; + wire [63:0] xgmii_rxd1; + wire [7:0] xgmii_rxc1; + + wire [7:0] core_status1; + wire xge_phy_resetdone1; + + ten_gig_eth_pcs_pma_x300_top ten_gig_eth_pcs_pma_x300_top_port1 + ( + .refclk156(xgige_sfp_clk), + .refclk156_buf(xgige_sfp_clk_bufg), + .clk156(xgmii_clk1), + .reset(global_rst | sw_rst[0]), + .xgmii_txd(xgmii_txd1), + .xgmii_txc(xgmii_txc1), + .xgmii_rxd(xgmii_rxd1), + .xgmii_rxc(xgmii_rxc1), + .txp(SFP1_TX_p), + .txn(SFP1_TX_n), + .rxp(SFP1_RX_p), + .rxn(SFP1_RX_n), + .mdc(mdc1), + .mdio_in(mdio_in1), + .mdio_out(mdio_out1), + .mdio_tri(mdio_tri1), + .prtad(prtad0), + .core_status(core_status1), // Ignore for now. IJB + .resetdone(xge_phy_resetdone1), + .signal_detect(~SFPP1_RxLOS), // Undocumented, but it seems Xilinx expect this to be inverted. + .tx_fault(SFPP1_TxFault), + .tx_disable(SFPP1_TxDisable) + ); + +`else + + ////////////////////////////////////////////////////////////////////// + // + // 1000Base-X PHY with GMII interface to MAC + // + ////////////////////////////////////////////////////////////////////// + wire [31:0] gige_phy_misc_dbg1; + wire [15:0] gige_phy_int_data1; + wire [7:0] gmii_txd1, gmii_rxd1; + wire gmii_tx_en1, gmii_tx_er1, gmii_rx_dv1, gmii_rx_er1; + wire gmii_clk1; + wire [15:0] gmii_status1; + + assign SFPP1_TxDisable = 1'b0; // Always on. + + gige_phy_mdio gige_phy_port1 + ( + .reset(global_rst | sw_rst[0]), + .independent_clock(bus_clk), + .sfp_clk(gige_sfp_clk), + .SFP_TX_p(SFP1_TX_p), + .SFP_TX_n(SFP1_TX_n), + .SFP_RX_p(SFP1_RX_p), + .SFP_RX_n(SFP1_RX_n), + .gmii_clk(gmii_clk1), + .gmii_txd(gmii_txd1), + .gmii_tx_en(gmii_tx_en1), + .gmii_tx_er(gmii_tx_er1), + .gmii_rxd(gmii_rxd1), + .gmii_rx_dv(gmii_rx_dv1), + .gmii_rx_er(gmii_rx_er1), + .misc_debug(gige_phy_misc_dbg1), + .int_data(gige_phy_int_data1), + .status_vector(gmii_status1), + // MDIO signals + .prtad(prtad0), + .mdc(mdc1), + .mdio_i(mdio_in1), + .mdio_o(mdio_out1), + .mdio_t(mdio_tri1) + ); +`endif // !`ifdef + + /////////////////////////////////////////////////////////////////////////////////// + // + // Debug bus for logic analyzer use. + // + /////////////////////////////////////////////////////////////////////////////////// + +// assign {DB0_TX_IO,DB0_RX_IO} = debug0; + +// assign {DB1_TX_IO,DB1_RX_IO} = debug1; + +/* + assign debug = { + 2'b0, SFPP1_ModAbs, SFPP1_RxLOS, SFPP1_TxFault, SFPP1_RS0, SFPP1_RS1, SFPP1_TxDisable, //8 + 4'b0, gmii_tx_en, gmii_tx_er, gmii_rx_dv, gmii_rx_er, //8 + gmii_txd, gmii_rxd //16 + }; +*/ + + +`ifndef NO_DRAM_FIFOS + + /////////////////////////////////////////////////////////////////////////////////// + // + // Xilinx DDR3 Controller and PHY. + // + /////////////////////////////////////////////////////////////////////////////////// + + + wire ddr3_axi_clk; // 1/4 DDR external clock rate (250MHz) + wire ddr3_axi_rst; // Synchronized to ddr_sys_clk + wire ddr3_running; // DRAM calibration complete. + + // Slave Interface Write Address Ports + wire [3:0] s_axi_awid; + wire [31:0] s_axi_awaddr; + wire [7:0] s_axi_awlen; + wire [2:0] s_axi_awsize; + wire [1:0] s_axi_awburst; + wire [0:0] s_axi_awlock; + wire [3:0] s_axi_awcache; + wire [2:0] s_axi_awprot; + wire [3:0] s_axi_awqos; + wire s_axi_awvalid; + wire s_axi_awready; + // Slave Interface Write Data Ports + wire [127:0] s_axi_wdata; + wire [15:0] s_axi_wstrb; + wire s_axi_wlast; + wire s_axi_wvalid; + wire s_axi_wready; + // Slave Interface Write Response Ports + wire s_axi_bready; + wire [3:0] s_axi_bid; + wire [1:0] s_axi_bresp; + wire s_axi_bvalid; + // Slave Interface Read Address Ports + wire [3:0] s_axi_arid; + wire [31:0] s_axi_araddr; + wire [7:0] s_axi_arlen; + wire [2:0] s_axi_arsize; + wire [1:0] s_axi_arburst; + wire [0:0] s_axi_arlock; + wire [3:0] s_axi_arcache; + wire [2:0] s_axi_arprot; + wire [3:0] s_axi_arqos; + wire s_axi_arvalid; + wire s_axi_arready; + // Slave Interface Read Data Ports + wire s_axi_rready; + wire [3:0] s_axi_rid; + wire [127:0] s_axi_rdata; + wire [1:0] s_axi_rresp; + wire s_axi_rlast; + wire s_axi_rvalid; + + reg ddr3_axi_rst_reg_n; + + // Copied this reset circuit from example design. + always @(posedge ddr3_axi_clk) + ddr3_axi_rst_reg_n <= ~ddr3_axi_rst; + + +/* -----\/----- EXCLUDED -----\/----- + //-*************************************************************************** + // Traffic Gen related localparams + //-*************************************************************************** + localparam BL_WIDTH = 10; + localparam PORT_MODE = "BI_MODE"; + localparam DATA_MODE = 4'b0010; + localparam ADDR_MODE = 4'b0011; + localparam TST_MEM_INSTR_MODE = "R_W_INSTR_MODE"; + localparam EYE_TEST = "FALSE"; + // set EYE_TEST = "TRUE" to probe memory + // signals. Traffic Generator will only + // write to one single location and no + // read transactions will be generated. + localparam DATA_PATTERN = "DGEN_ALL"; + // For small devices, choose one only. + // For large device, choose "DGEN_ALL" + // "DGEN_HAMMER", "DGEN_WALKING1", + // "DGEN_WALKING0","DGEN_ADDR"," + // "DGEN_NEIGHBOR","DGEN_PRBS","DGEN_ALL" + localparam CMD_PATTERN = "CGEN_ALL"; + // "CGEN_PRBS","CGEN_FIXED","CGEN_BRAM", + // "CGEN_SEQUENTIAL", "CGEN_ALL" + localparam BEGIN_ADDRESS = 32'h00000000; + localparam END_ADDRESS = 32'h00ffffff; + localparam PRBS_EADDR_MASK_POS = 32'hff000000; + localparam CMD_WDT = 'h3FF; + localparam WR_WDT = 'h1FFF; + localparam RD_WDT = 'h3FF; + localparam SEL_VICTIM_LINE = 0; + localparam ENFORCE_RD_WR = 0; + localparam ENFORCE_RD_WR_CMD = 8'h11; + localparam ENFORCE_RD_WR_PATTERN = 3'b000; + localparam C_EN_WRAP_TRANS = 0; + localparam C_AXI_NBURST_TEST = 0; + + //-*************************************************************************** + // The following localparams refer to width of various ports + //-*************************************************************************** + localparam BANK_WIDTH = 3; + // # of memory Bank Address bits. + localparam CK_WIDTH = 1; + // # of CK/CK# outputs to memory. + localparam COL_WIDTH = 10; + // # of memory Column Address bits. + localparam CS_WIDTH = 1; + // # of unique CS outputs to memory. + localparam nCS_PER_RANK = 1; + // # of unique CS outputs per rank for phy + localparam CKE_WIDTH = 1; + // # of CKE outputs to memory. + localparam DATA_BUF_ADDR_WIDTH = 5; + localparam DQ_CNT_WIDTH = 5; + // = ceil(log2(DQ_WIDTH)) + localparam DQ_PER_DM = 8; + localparam DM_WIDTH = 4; + // # of DM (data mask) + localparam DQ_WIDTH = 32; + // # of DQ (data) + localparam DQS_WIDTH = 4; + localparam DQS_CNT_WIDTH = 2; + // = ceil(log2(DQS_WIDTH)) + localparam DRAM_WIDTH = 8; + // # of DQ per DQS + localparam ECC = "OFF"; + localparam nBANK_MACHS = 4; + localparam RANKS = 1; + // # of Ranks. + localparam ODT_WIDTH = 1; + // # of ODT outputs to memory. + localparam ROW_WIDTH = 15; + // # of memory Row Address bits. + localparam ADDR_WIDTH = 29; + // # = RANK_WIDTH + BANK_WIDTH + // + ROW_WIDTH + COL_WIDTH; + // Chip Select is always tied to low for + // single rank devices + localparam USE_CS_PORT = 1; + // # = 1, When Chip Select (CS#) output is enabled + // = 0, When Chip Select (CS#) output is disabled + // If CS_N disabled, user must connect + // DRAM CS_N input(s) to ground + localparam USE_DM_PORT = 1; + // # = 1, When Data Mask option is enabled + // = 0, When Data Mask option is disbaled + // When Data Mask option is disabled in + // MIG Controller Options page, the logic + // related to Data Mask should not get + // synthesized + localparam USE_ODT_PORT = 1; + // # = 1, When ODT output is enabled + // = 0, When ODT output is disabled + localparam PHY_CONTROL_MASTER_BANK = 1; + // The bank index where master PHY_CONTROL resides; + // equal to the PLL residing bank + localparam MEM_DENSITY = "4Gb"; + // Indicates the density of the Memory part + // Added for the sake of Vivado simulations + localparam MEM_SPEEDGRADE = "125"; + // Indicates the Speed grade of Memory Part + // Added for the sake of Vivado simulations + localparam MEM_DEVICE_WIDTH = 16; + // Indicates the device width of the Memory Part + // Added for the sake of Vivado simulations + + //-*************************************************************************** + // The following localparams are mode register settings + //-*************************************************************************** + localparam AL = "0"; + // DDR3 SDRAM: + // Additive Latency (Mode Register 1). + // # = "0", "CL-1", "CL-2". + // DDR2 SDRAM: + // Additive Latency (Extended Mode Register). + localparam nAL = 0; + // # Additive Latency in number of clock + // cycles. + localparam BURST_MODE = "8"; + // DDR3 SDRAM: + // Burst Length (Mode Register 0). + // # = "8", "4", "OTF". + // DDR2 SDRAM: + // Burst Length (Mode Register). + // # = "8", "4". + localparam BURST_TYPE = "SEQ"; + // DDR3 SDRAM: Burst Type (Mode Register 0). + // DDR2 SDRAM: Burst Type (Mode Register). + // # = "SEQ" - (Sequential), + // = "INT" - (Interleaved). + localparam CL = 7; + // in number of clock cycles + // DDR3 SDRAM: CAS Latency (Mode Register 0). + // DDR2 SDRAM: CAS Latency (Mode Register). + localparam CWL = 6; + // in number of clock cycles + // DDR3 SDRAM: CAS Write Latency (Mode Register 2). + // DDR2 SDRAM: Can be ignored + localparam OUTPUT_DRV = "HIGH"; + // Output Driver Impedance Control (Mode Register 1). + // # = "HIGH" - RZQ/7, + // = "LOW" - RZQ/6. + localparam RTT_NOM = "60"; + // RTT_NOM (ODT) (Mode Register 1). + // = "120" - RZQ/2, + // = "60" - RZQ/4, + // = "40" - RZQ/6. + localparam RTT_WR = "OFF"; + // RTT_WR (ODT) (Mode Register 2). + // # = "OFF" - Dynamic ODT off, + // = "120" - RZQ/2, + // = "60" - RZQ/4, + localparam ADDR_CMD_MODE = "1T" ; + // # = "1T", "2T". + localparam REG_CTRL = "OFF"; + // # = "ON" - RDIMMs, + // = "OFF" - Components, SODIMMs, UDIMMs. + localparam CA_MIRROR = "OFF"; + // C/A mirror opt for DDR3 dual rank + + //-*************************************************************************** + // The following localparams are multiplier and divisor factors for PLLE2. + // Based on the selected design frequency these localparams vary. + //-*************************************************************************** + localparam CLKIN_PERIOD = 10000; + // Input Clock Period + localparam CLKFBOUT_MULT = 10; + // write PLL VCO multiplier + localparam DIVCLK_DIVIDE = 1; + // write PLL VCO divisor + localparam CLKOUT0_PHASE = 337.5; + // Phase for PLL output clock (CLKOUT0) + localparam CLKOUT0_DIVIDE = 2; + // VCO output divisor for PLL output clock (CLKOUT0) + localparam CLKOUT1_DIVIDE = 2; + // VCO output divisor for PLL output clock (CLKOUT1) + localparam CLKOUT2_DIVIDE = 32; + // VCO output divisor for PLL output clock (CLKOUT2) + localparam CLKOUT3_DIVIDE = 8; + // VCO output divisor for PLL output clock (CLKOUT3) + + //-*************************************************************************** + // Memory Timing Localparams. These localparams varies based on the selected + // memory part. + //-*************************************************************************** + localparam tCKE = 5000; + // memory tCKE paramter in pS + localparam tFAW = 30000; + // memory tRAW paramter in pS. + localparam tRAS = 35000; + // memory tRAS paramter in pS. + localparam tRCD = 13750; + // memory tRCD paramter in pS. + localparam tREFI = 7800000; + // memory tREFI paramter in pS. + localparam tRFC = 300000; + // memory tRFC paramter in pS. + localparam tRP = 13750; + // memory tRP paramter in pS. + localparam tRRD = 6000; + // memory tRRD paramter in pS. + localparam tRTP = 7500; + // memory tRTP paramter in pS. + localparam tWTR = 7500; + // memory tWTR paramter in pS. + localparam tZQI = 128_000_000; + // memory tZQI paramter in nS. + localparam tZQCS = 64; + // memory tZQCS paramter in clock cycles. + + //-*************************************************************************** + // Simulation localparams + //-*************************************************************************** + localparam SIM_BYPASS_INIT_CAL = "OFF"; + // # = "OFF" - Complete memory init & + // calibration sequence + // # = "SKIP" - Not supported + // # = "FAST" - Complete memory init & use + // abbreviated calib sequence + + localparam SIMULATION = "FALSE"; + // Should be TRUE during design simulations and + // FALSE during implementations + + //-*************************************************************************** + // The following localparams varies based on the pin out entered in MIG GUI. + // Do not change any of these localparams directly by editing the RTL. + // Any changes required should be done through GUI and the design regenerated. + //-*************************************************************************** + localparam BYTE_LANES_B0 = 4'b1111; + // Byte lanes used in an IO column. + localparam BYTE_LANES_B1 = 4'b1110; + // Byte lanes used in an IO column. + localparam BYTE_LANES_B2 = 4'b0000; + // Byte lanes used in an IO column. + localparam BYTE_LANES_B3 = 4'b0000; + // Byte lanes used in an IO column. + localparam BYTE_LANES_B4 = 4'b0000; + // Byte lanes used in an IO column. + localparam DATA_CTL_B0 = 4'b1111; + // Indicates Byte lane is data byte lane + // or control Byte lane. '1' in a bit + // position indicates a data byte lane and + // a '0' indicates a control byte lane + localparam DATA_CTL_B1 = 4'b0000; + // Indicates Byte lane is data byte lane + // or control Byte lane. '1' in a bit + // position indicates a data byte lane and + // a '0' indicates a control byte lane + localparam DATA_CTL_B2 = 4'b0000; + // Indicates Byte lane is data byte lane + // or control Byte lane. '1' in a bit + // position indicates a data byte lane and + // a '0' indicates a control byte lane + localparam DATA_CTL_B3 = 4'b0000; + // Indicates Byte lane is data byte lane + // or control Byte lane. '1' in a bit + // position indicates a data byte lane and + // a '0' indicates a control byte lane + localparam DATA_CTL_B4 = 4'b0000; + // Indicates Byte lane is data byte lane + // or control Byte lane. '1' in a bit + // position indicates a data byte lane and + // a '0' indicates a control byte lane + localparam PHY_0_BITLANES = 48'h3FE_3FE_3FE_2FF; + localparam PHY_1_BITLANES = 48'h3FF_FFF_C00_000; + localparam PHY_2_BITLANES = 48'h000_000_000_000; + + // control/address/data pin mapping localparams + localparam CK_BYTE_MAP + = 144'h00_00_00_00_00_00_00_00_00_00_00_00_00_00_00_00_00_13; + localparam ADDR_MAP + = 192'h000_139_138_137_136_135_134_133_132_131_130_129_128_127_126_12B; + localparam BANK_MAP = 36'h12A_125_124; + localparam CAS_MAP = 12'h122; + localparam CKE_ODT_BYTE_MAP = 8'h00; + localparam CKE_MAP = 96'h000_000_000_000_000_000_000_11B; + localparam ODT_MAP = 96'h000_000_000_000_000_000_000_11A; + localparam CS_MAP = 120'h000_000_000_000_000_000_000_000_000_120; + localparam PARITY_MAP = 12'h000; + localparam RAS_MAP = 12'h123; + localparam WE_MAP = 12'h121; + localparam DQS_BYTE_MAP + = 144'h00_00_00_00_00_00_00_00_00_00_00_00_00_00_00_01_02_03; + localparam DATA0_MAP = 96'h031_032_033_034_035_036_037_038; + localparam DATA1_MAP = 96'h021_022_023_024_025_026_027_028; + localparam DATA2_MAP = 96'h011_012_013_014_015_016_017_018; + localparam DATA3_MAP = 96'h000_001_002_003_004_005_006_007; + localparam DATA4_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA5_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA6_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA7_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA8_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA9_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA10_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA11_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA12_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA13_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA14_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA15_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA16_MAP = 96'h000_000_000_000_000_000_000_000; + localparam DATA17_MAP = 96'h000_000_000_000_000_000_000_000; + localparam MASK0_MAP = 108'h000_000_000_000_000_009_019_029_039; + localparam MASK1_MAP = 108'h000_000_000_000_000_000_000_000_000; + + localparam SLOT_0_CONFIG = 8'b0000_0001; + // Mapping of Ranks. + localparam SLOT_1_CONFIG = 8'b0000_0000; + // Mapping of Ranks. + localparam MEM_ADDR_ORDER + = "BANK_ROW_COLUMN"; + + //-*************************************************************************** + // IODELAY and PHY related localparams + //-*************************************************************************** + localparam IODELAY_HP_MODE = "ON"; + // to phy_top + localparam IBUF_LPWR_MODE = "OFF"; + // to phy_top + localparam DATA_IO_IDLE_PWRDWN = "ON"; + // # = "ON", "OFF" + localparam BANK_TYPE = "HP_IO"; + // # = "HP_IO", "HPL_IO", "HR_IO", "HRL_IO" + localparam DATA_IO_PRIM_TYPE = "HP_LP"; + // # = "HP_LP", "HR_LP", "DEFAULT" + localparam CKE_ODT_AUX = "FALSE"; + localparam USER_REFRESH = "OFF"; + localparam WRLVL = "ON"; + // # = "ON" - DDR3 SDRAM + // = "OFF" - DDR2 SDRAM. + localparam ORDERING = "NORM"; + // # = "NORM", "STRICT", "RELAXED". + localparam CALIB_ROW_ADD = 16'h0000; + // Calibration row address will be used for + // calibration read and write operations + localparam CALIB_COL_ADD = 12'h000; + // Calibration column address will be used for + // calibration read and write operations + localparam CALIB_BA_ADD = 3'h0; + // Calibration bank address will be used for + // calibration read and write operations + localparam TCQ = 100; + localparam IODELAY_GRP = "IODELAY_MIG"; + // It is associated to a set of IODELAYs with + // an IDELAYCTRL that have same IODELAY CONTROLLER + // clock frequency. + localparam SYSCLK_TYPE = "SINGLE_ENDED"; + // System clock type DIFFERENTIAL, SINGLE_ENDED, + // NO_BUFFER + localparam REFCLK_TYPE = "NO_BUFFER"; + // Reference clock type DIFFERENTIAL, SINGLE_ENDED, + // NO_BUFFER, USE_SYSTEM_CLOCK + + localparam DRAM_TYPE = "DDR3"; + localparam CAL_WIDTH = "HALF"; + localparam STARVE_LIMIT = 2; + // # = 2,3,4. + + //-*************************************************************************** + // Referece clock frequency localparams + //-*************************************************************************** + localparam REFCLK_FREQ = 200.0; + // IODELAYCTRL reference clock frequency + localparam DIFF_TERM_REFCLK = "TRUE"; + // Differential Termination for idelay + // reference clock input pins + //-*************************************************************************** + // System clock frequency localparams + //-*************************************************************************** + localparam tCK = 2000; + // memory tCK paramter. + // # = Clock Period in pS. + localparam nCK_PER_CLK = 4; + // # of memory CKs per fabric CLK + localparam DIFF_TERM_SYSCLK = "TRUE"; + // Differential Termination for System + // clock input pins + + + //-*************************************************************************** + // AXI4 Shim localparams + //-*************************************************************************** + localparam C_S_AXI_ID_WIDTH = 4; + // Width of all master and slave ID signals. + // # = >= 1. + localparam C_S_AXI_MEM_SIZE = "2147483648"; + // Address Space required for this component + localparam C_S_AXI_ADDR_WIDTH = 32; + // Width of S_AXI_AWADDR; S_AXI_ARADDR, M_AXI_AWADDR and + // M_AXI_ARADDR for all SI/MI slots. + // # = 32. + localparam C_S_AXI_DATA_WIDTH = 128; + // Width of WDATA and RDATA on SI slot. + // Must be <= APP_DATA_WIDTH. + // # = 32, 64, 128, 256. + localparam C_MC_nCK_PER_CLK = 4; + // Indicates whether to instatiate upsizer + // Range: 0, 1 + localparam C_S_AXI_SUPPORTS_NARROW_BURST = 1; + // Indicates whether to instatiate upsizer + // Range: 0, 1 + localparam C_RD_WR_ARB_ALGORITHM = "ROUND_ROBIN"; + // Indicates the Arbitration + // Allowed values - "TDM", "ROUND_ROBIN", + // "RD_PRI_REG", "RD_PRI_REG_STARVE_LIMIT" + // "WRITE_PRIORITY", "WRITE_PRIORITY_REG" + localparam C_S_AXI_REG_EN0 = 20'h00000; + // C_S_AXI_REG_EN0[00] = Reserved + // C_S_AXI_REG_EN0[04] = AW CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN0[05] = W CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN0[06] = B CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN0[07] = R CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN0[08] = AW CHANNEL UPSIZER REGISTER SLICE + // C_S_AXI_REG_EN0[09] = W CHANNEL UPSIZER REGISTER SLICE + // C_S_AXI_REG_EN0[10] = AR CHANNEL UPSIZER REGISTER SLICE + // C_S_AXI_REG_EN0[11] = R CHANNEL UPSIZER REGISTER SLICE + localparam C_S_AXI_REG_EN1 = 20'h00000; + // Instatiates register slices after the upsizer. + // The type of register is specified for each channel + // in a vector. 4 bits per channel are used. + // C_S_AXI_REG_EN1[03:00] = AW CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN1[07:04] = W CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN1[11:08] = B CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN1[15:12] = AR CHANNEL REGISTER SLICE + // C_S_AXI_REG_EN1[20:16] = R CHANNEL REGISTER SLICE + // Possible values for each channel are: + // + // 0 => BYPASS = The channel is just wired through the + // module. + // 1 => FWD = The master VALID and payload signals + // are registrated. + // 2 => REV = The slave ready signal is registrated + // 3 => FWD_REV = Both FWD and REV + // 4 => SLAVE_FWD = All slave side signals and master + // VALID and payload are registrated. + // 5 => SLAVE_RDY = All slave side signals and master + // READY are registrated. + // 6 => INPUTS = Slave and Master side inputs are + // registrated. + // 7 => ADDRESS = Optimized for address channel + localparam C_S_AXI_CTRL_ADDR_WIDTH = 32; + // Width of AXI-4-Lite address bus + localparam C_S_AXI_CTRL_DATA_WIDTH = 32; + // Width of AXI-4-Lite data buses + localparam C_S_AXI_BASEADDR = 32'h0000_0000; + // Base address of AXI4 Memory Mapped bus. + localparam C_ECC_ONOFF_RESET_VALUE = 1; + // Controls ECC on/off value at startup/reset + localparam C_ECC_CE_COUNTER_WIDTH = 8; + // The external memory to controller clock ratio. + + //-*************************************************************************** + // Debug localparams + //-*************************************************************************** + localparam DEBUG_PORT = "OFF"; + // # = "ON" Enable debug signals/controls. + // = "OFF" Disable debug signals/controls. + + //-*************************************************************************** + // Temparature monitor localparam + //-*************************************************************************** + localparam TEMP_MON_CONTROL = "INTERNAL"; + // # = "INTERNAL", "EXTERNAL" + + localparam RST_ACT_LOW = 1; + // =1 for active low reset, + // =0 for active high. + //-******************* + + localparam CMD_PIPE_PLUS1 = "ON"; + // add pipeline stage between MC and PHY + localparam DATA_WIDTH = 32; + localparam ECC_WIDTH = (ECC == "OFF")? + 0 : (DATA_WIDTH <= 4)? + 4 : (DATA_WIDTH <= 10)? + 5 : (DATA_WIDTH <= 26)? + 6 : (DATA_WIDTH <= 57)? + 7 : (DATA_WIDTH <= 120)? + 8 : (DATA_WIDTH <= 247)? + 9 : 10; + localparam ECC_TEST = "OFF"; + localparam RANK_WIDTH = clogb2(RANKS); + localparam DATA_BUF_OFFSET_WIDTH = 1; + localparam MC_ERR_ADDR_WIDTH = ((CS_WIDTH == 1) ? 0 : RANK_WIDTH) + + BANK_WIDTH + ROW_WIDTH + COL_WIDTH + + DATA_BUF_OFFSET_WIDTH; + localparam tPRDI = 1_000_000; + // memory tPRDI paramter in pS. + localparam PAYLOAD_WIDTH = (ECC_TEST == "OFF") ? DATA_WIDTH : DQ_WIDTH; + //localparam BURST_LENGTH = STR_TO_INT(BURST_MODE); + localparam APP_DATA_WIDTH = 2 * nCK_PER_CLK * PAYLOAD_WIDTH; + localparam APP_MASK_WIDTH = APP_DATA_WIDTH / 8; + -----/\----- EXCLUDED -----/\----- */ + + + ddr3_32bit + /* -----\/----- EXCLUDED -----\/----- + #( + .TCQ (TCQ), + .ADDR_CMD_MODE (ADDR_CMD_MODE), + .AL (AL), + .PAYLOAD_WIDTH (PAYLOAD_WIDTH), + .BANK_WIDTH (BANK_WIDTH), + .BURST_MODE (BURST_MODE), + .BURST_TYPE (BURST_TYPE), + .CA_MIRROR (CA_MIRROR), + .CK_WIDTH (CK_WIDTH), + .COL_WIDTH (COL_WIDTH), + .CMD_PIPE_PLUS1 (CMD_PIPE_PLUS1), + .CS_WIDTH (CS_WIDTH), + .nCS_PER_RANK (nCS_PER_RANK), + .CKE_WIDTH (CKE_WIDTH), + .DATA_WIDTH (DATA_WIDTH), + .DATA_BUF_ADDR_WIDTH (DATA_BUF_ADDR_WIDTH), + .DQ_CNT_WIDTH (DQ_CNT_WIDTH), + .DQ_PER_DM (DQ_PER_DM), + .DQ_WIDTH (DQ_WIDTH), + .DQS_CNT_WIDTH (DQS_CNT_WIDTH), + .DQS_WIDTH (DQS_WIDTH), + .DRAM_WIDTH (DRAM_WIDTH), + .ECC (ECC), + .ECC_WIDTH (ECC_WIDTH), + .ECC_TEST (ECC_TEST), + .MC_ERR_ADDR_WIDTH (MC_ERR_ADDR_WIDTH), + .nAL (nAL), + .nBANK_MACHS (nBANK_MACHS), + .CKE_ODT_AUX (CKE_ODT_AUX), + .ORDERING (ORDERING), + .OUTPUT_DRV (OUTPUT_DRV), + .IBUF_LPWR_MODE (IBUF_LPWR_MODE), + .IODELAY_HP_MODE (IODELAY_HP_MODE), + .DATA_IO_IDLE_PWRDWN (DATA_IO_IDLE_PWRDWN), + .BANK_TYPE (BANK_TYPE), + .DATA_IO_PRIM_TYPE (DATA_IO_PRIM_TYPE), + .REG_CTRL (REG_CTRL), + .RTT_NOM (RTT_NOM), + .RTT_WR (RTT_WR), + .CL (CL), + .CWL (CWL), + .tCKE (tCKE), + .tFAW (tFAW), + .tPRDI (tPRDI), + .tRAS (tRAS), + .tRCD (tRCD), + .tREFI (tREFI), + .tRFC (tRFC), + .tRP (tRP), + .tRRD (tRRD), + .tRTP (tRTP), + .tWTR (tWTR), + .tZQI (tZQI), + .tZQCS (tZQCS), + .USER_REFRESH (USER_REFRESH), + .WRLVL (WRLVL), + .DEBUG_PORT (DEBUG_PORT), + .RANKS (RANKS), + .ODT_WIDTH (ODT_WIDTH), + .ROW_WIDTH (ROW_WIDTH), + .ADDR_WIDTH (ADDR_WIDTH), + .SIM_BYPASS_INIT_CAL (SIM_BYPASS_INIT_CAL), + .SIMULATION (SIMULATION), + .BYTE_LANES_B0 (BYTE_LANES_B0), + .BYTE_LANES_B1 (BYTE_LANES_B1), + .BYTE_LANES_B2 (BYTE_LANES_B2), + .BYTE_LANES_B3 (BYTE_LANES_B3), + .BYTE_LANES_B4 (BYTE_LANES_B4), + .DATA_CTL_B0 (DATA_CTL_B0), + .DATA_CTL_B1 (DATA_CTL_B1), + .DATA_CTL_B2 (DATA_CTL_B2), + .DATA_CTL_B3 (DATA_CTL_B3), + .DATA_CTL_B4 (DATA_CTL_B4), + .PHY_0_BITLANES (PHY_0_BITLANES), + .PHY_1_BITLANES (PHY_1_BITLANES), + .PHY_2_BITLANES (PHY_2_BITLANES), + .CK_BYTE_MAP (CK_BYTE_MAP), + .ADDR_MAP (ADDR_MAP), + .BANK_MAP (BANK_MAP), + .CAS_MAP (CAS_MAP), + .CKE_ODT_BYTE_MAP (CKE_ODT_BYTE_MAP), + .CKE_MAP (CKE_MAP), + .ODT_MAP (ODT_MAP), + .CS_MAP (CS_MAP), + .PARITY_MAP (PARITY_MAP), + .RAS_MAP (RAS_MAP), + .WE_MAP (WE_MAP), + .DQS_BYTE_MAP (DQS_BYTE_MAP), + .DATA0_MAP (DATA0_MAP), + .DATA1_MAP (DATA1_MAP), + .DATA2_MAP (DATA2_MAP), + .DATA3_MAP (DATA3_MAP), + .DATA4_MAP (DATA4_MAP), + .DATA5_MAP (DATA5_MAP), + .DATA6_MAP (DATA6_MAP), + .DATA7_MAP (DATA7_MAP), + .DATA8_MAP (DATA8_MAP), + .DATA9_MAP (DATA9_MAP), + .DATA10_MAP (DATA10_MAP), + .DATA11_MAP (DATA11_MAP), + .DATA12_MAP (DATA12_MAP), + .DATA13_MAP (DATA13_MAP), + .DATA14_MAP (DATA14_MAP), + .DATA15_MAP (DATA15_MAP), + .DATA16_MAP (DATA16_MAP), + .DATA17_MAP (DATA17_MAP), + .MASK0_MAP (MASK0_MAP), + .MASK1_MAP (MASK1_MAP), + .CALIB_ROW_ADD (CALIB_ROW_ADD), + .CALIB_COL_ADD (CALIB_COL_ADD), + .CALIB_BA_ADD (CALIB_BA_ADD), + .SLOT_0_CONFIG (SLOT_0_CONFIG), + .SLOT_1_CONFIG (SLOT_1_CONFIG), + .MEM_ADDR_ORDER (MEM_ADDR_ORDER), + .USE_CS_PORT (USE_CS_PORT), + .USE_DM_PORT (USE_DM_PORT), + .USE_ODT_PORT (USE_ODT_PORT), + .PHY_CONTROL_MASTER_BANK (PHY_CONTROL_MASTER_BANK), + .TEMP_MON_CONTROL (TEMP_MON_CONTROL), + + + .DM_WIDTH (DM_WIDTH), + + .nCK_PER_CLK (nCK_PER_CLK), + .tCK (tCK), + .DIFF_TERM_SYSCLK (DIFF_TERM_SYSCLK), + .CLKIN_PERIOD (CLKIN_PERIOD), + .CLKFBOUT_MULT (CLKFBOUT_MULT), + .DIVCLK_DIVIDE (DIVCLK_DIVIDE), + .CLKOUT0_PHASE (CLKOUT0_PHASE), + .CLKOUT0_DIVIDE (CLKOUT0_DIVIDE), + .CLKOUT1_DIVIDE (CLKOUT1_DIVIDE), + .CLKOUT2_DIVIDE (CLKOUT2_DIVIDE), + .CLKOUT3_DIVIDE (CLKOUT3_DIVIDE), + .C_S_AXI_ID_WIDTH (C_S_AXI_ID_WIDTH), + .C_S_AXI_ADDR_WIDTH (C_S_AXI_ADDR_WIDTH), + .C_S_AXI_DATA_WIDTH (C_S_AXI_DATA_WIDTH), + .C_MC_nCK_PER_CLK (C_MC_nCK_PER_CLK), + .C_S_AXI_SUPPORTS_NARROW_BURST (C_S_AXI_SUPPORTS_NARROW_BURST), + .C_RD_WR_ARB_ALGORITHM (C_RD_WR_ARB_ALGORITHM), + .C_S_AXI_REG_EN0 (C_S_AXI_REG_EN0), + .C_S_AXI_REG_EN1 (C_S_AXI_REG_EN1), + .C_S_AXI_CTRL_ADDR_WIDTH (C_S_AXI_CTRL_ADDR_WIDTH), + .C_S_AXI_CTRL_DATA_WIDTH (C_S_AXI_CTRL_DATA_WIDTH), + .C_S_AXI_BASEADDR (C_S_AXI_BASEADDR), + .C_ECC_ONOFF_RESET_VALUE (C_ECC_ONOFF_RESET_VALUE), + .C_ECC_CE_COUNTER_WIDTH (C_ECC_CE_COUNTER_WIDTH), + + + .SYSCLK_TYPE (SYSCLK_TYPE), + .REFCLK_TYPE (REFCLK_TYPE), + .REFCLK_FREQ (REFCLK_FREQ), + .DIFF_TERM_REFCLK (DIFF_TERM_REFCLK), + .IODELAY_GRP (IODELAY_GRP), + + .CAL_WIDTH (CAL_WIDTH), + .STARVE_LIMIT (STARVE_LIMIT), + .DRAM_TYPE (DRAM_TYPE), + + + .RST_ACT_LOW (RST_ACT_LOW) + ) + -----/\----- EXCLUDED -----/\----- */ + u_ddr3_32bit + ( + // Memory interface ports + .ddr3_addr (ddr3_addr), + .ddr3_ba (ddr3_ba), + .ddr3_cas_n (ddr3_cas_n), + .ddr3_ck_n (ddr3_ck_n), + .ddr3_ck_p (ddr3_ck_p), + .ddr3_cke (ddr3_cke), + .ddr3_ras_n (ddr3_ras_n), + .ddr3_reset_n (ddr3_reset_n), + .ddr3_we_n (ddr3_we_n), + .ddr3_dq (ddr3_dq), + .ddr3_dqs_n (ddr3_dqs_n), + .ddr3_dqs_p (ddr3_dqs_p), + .init_calib_complete (ddr3_running), + + .ddr3_cs_n (ddr3_cs_n), + .ddr3_dm (ddr3_dm), + .ddr3_odt (ddr3_odt), + // Application interface ports + .ui_clk (ddr3_axi_clk), // 250MHz clock out + .ui_clk_sync_rst (ddr3_axi_rst), // Active high Reset signal synchronised to 250MHz + .aresetn (ddr3_axi_rst_reg_n), + .app_sr_req (1'b0), + .app_sr_active (app_sr_active), + .app_ref_req (1'b0), + .app_ref_ack (app_ref_ack), + .app_zq_req (1'b0), + .app_zq_ack (app_zq_ack), + + // Slave Interface Write Address Ports + .s_axi_awid (s_axi_awid), + .s_axi_awaddr (s_axi_awaddr), + .s_axi_awlen (s_axi_awlen), + .s_axi_awsize (s_axi_awsize), + .s_axi_awburst (s_axi_awburst), + .s_axi_awlock (s_axi_awlock), + .s_axi_awcache (s_axi_awcache), + .s_axi_awprot (s_axi_awprot), + .s_axi_awqos (s_axi_awqos), + .s_axi_awvalid (s_axi_awvalid), + .s_axi_awready (s_axi_awready), + // Slave Interface Write Data Ports + .s_axi_wdata (s_axi_wdata), + .s_axi_wstrb (s_axi_wstrb), + .s_axi_wlast (s_axi_wlast), + .s_axi_wvalid (s_axi_wvalid), + .s_axi_wready (s_axi_wready), + // Slave Interface Write Response Ports + .s_axi_bid (s_axi_bid), + .s_axi_bresp (s_axi_bresp), + .s_axi_bvalid (s_axi_bvalid), + .s_axi_bready (s_axi_bready), + // Slave Interface Read Address Ports + .s_axi_arid (s_axi_arid), + .s_axi_araddr (s_axi_araddr), + .s_axi_arlen (s_axi_arlen), + .s_axi_arsize (s_axi_arsize), + .s_axi_arburst (s_axi_arburst), + .s_axi_arlock (s_axi_arlock), + .s_axi_arcache (s_axi_arcache), + .s_axi_arprot (s_axi_arprot), + .s_axi_arqos (s_axi_arqos), + .s_axi_arvalid (s_axi_arvalid), + .s_axi_arready (s_axi_arready), + // Slave Interface Read Data Ports + .s_axi_rid (s_axi_rid), + .s_axi_rdata (s_axi_rdata), + .s_axi_rresp (s_axi_rresp), + .s_axi_rlast (s_axi_rlast), + .s_axi_rvalid (s_axi_rvalid), + .s_axi_rready (s_axi_rready), + // System Clock Ports + .sys_clk_i (sys_clk_i), // From external 100MHz source. + .sys_rst (~global_rst) // IJB. Poorly named active low. Should change RST_ACT_LOW. + ); + +`endif // `ifndef NO_DRAM_FIFOS + + /////////////////////////////////////////////////////////////////////////////////// + // + // B250 Core + // + /////////////////////////////////////////////////////////////////////////////////// + x300_core x300_core + ( + .radio_clk(radio_clk), .radio_rst(radio_rst), + .bus_clk(bus_clk), .bus_rst(bus_rst), .sw_rst(sw_rst), +`ifdef DEBUG_UART + .fp_gpio(FrontPanelGpio[9:0]), // Discard upper unsued bits. +`else + .fp_gpio(FrontPanelGpio[11:0]), // Discard upper unsued bits. + `endif + // Radio0 signals + .rx0(rx0), .tx0(tx0), .db_gpio0({DB0_TX_IO,DB0_RX_IO}), + .sen0(sen0), .sclk0(sclk0), .mosi0(mosi0), .miso0(miso0), + .radio_led0(led0), .radio_misc0({DB_ADC_RESET, DB_DAC_RESET,DB0_DAC_ENABLE}), + .sync_dacs_radio0(sync_dacs_radio0), + // Radio1 signals + .rx1(rx1), .tx1(tx1), .db_gpio1({DB1_TX_IO,DB1_RX_IO}), + .sen1(sen1), .sclk1(sclk1), .mosi1(mosi1), .miso1(miso1), + .radio_led1(led1), .radio_misc1({DB1_DAC_ENABLE}), + .sync_dacs_radio1(sync_dacs_radio1), + // I2C bus + .db_scl(DB_SCL), .db_sda(DB_SDA), + // External clock gen + .ext_ref_clk(ref_clk_10mhz), + .clock_ref_sel(ClockRefSelect), + .clock_misc_opt({GPSDO_PWR_ENA, TCXO_ENA}), + .LMK_Status(LMK_Status[1:0]), .LMK_Holdover(LMK_Holdover), .LMK_Lock(LMK_Lock), .LMK_Sync(LMK_Sync), + .LMK_SEN(LMK_SEN), .LMK_SCLK(LMK_SCLK), .LMK_MOSI(LMK_MOSI), + // SFP+ 0 flags + .SFPP0_SCL(SFPP0_SCL), + .SFPP0_SDA(SFPP0_SDA), + .SFPP0_ModAbs(SFPP0_ModAbs), + .SFPP0_TxFault(SFPP0_TxFault), + .SFPP0_RxLOS(SFPP0_RxLOS), + .SFPP0_RS1(SFPP0_RS1), + .SFPP0_RS0(SFPP0_RS0), + // SFP+ 1 flags + .SFPP1_SCL(SFPP1_SCL), + .SFPP1_SDA(SFPP1_SDA), + .SFPP1_ModAbs(SFPP1_ModAbs), + .SFPP1_TxFault(SFPP1_TxFault), + .SFPP1_RxLOS(SFPP1_RxLOS), + .SFPP1_RS1(SFPP1_RS1), + .SFPP1_RS0(SFPP1_RS0), + // MDIO bus to SFP0 + .mdc0(mdc0), + .mdio_in0(mdio_in0), + .mdio_out0(mdio_out0), + // SFP+ 0 packet interface +`ifdef ETH10G_PORT0 + .xgmii_clk0(xgmii_clk0), + .xgmii_txd0(xgmii_txd0), + .xgmii_txc0(xgmii_txc0), + .xgmii_rxd0(xgmii_rxd0), + .xgmii_rxc0(xgmii_rxc0), + .xge_phy_resetdone0(xge_phy_resetdone0), +`else + .gmii_clk0(gmii_clk0), + .gmii_txd0(gmii_txd0), .gmii_tx_en0(gmii_tx_en0), .gmii_tx_er0(gmii_tx_er0), + .gmii_rxd0(gmii_rxd0), .gmii_rx_dv0(gmii_rx_dv0), .gmii_rx_er0(gmii_rx_er0), +`endif // !`ifdef + // MDIO bus to SFP1 + .mdc1(mdc1), + .mdio_in1(mdio_in1), + .mdio_out1(mdio_out1), + // SFP+ 1 packet interface +`ifdef ETH10G_PORT1 + .xgmii_clk1(xgmii_clk1), + .xgmii_txd1(xgmii_txd1), + .xgmii_txc1(xgmii_txc1), + .xgmii_rxd1(xgmii_rxd1), + .xgmii_rxc1(xgmii_rxc1), + .xge_phy_resetdone1(xge_phy_resetdone1), +`else + .gmii_clk1(gmii_clk1), + .gmii_txd1(gmii_txd1), .gmii_tx_en1(gmii_tx_en1), .gmii_tx_er1(gmii_tx_er1), + .gmii_rxd1(gmii_rxd1), .gmii_rx_dv1(gmii_rx_dv1), .gmii_rx_er1(gmii_rx_er1), +`endif // !`ifdef + // GPS Signals + .gps_pps(GPS_PPS_OUT), .ext_pps(EXT_PPS_IN), + .gps_txd(GPS_SER_IN), .gps_rxd(GPS_SER_OUT), + .pps_out(EXT_PPS_OUT), + // Debug UART + .debug_rxd(debug_rxd), .debug_txd(debug_txd), + // Misc. + .led_misc(leds), + .debug0(), .debug1(), .debug2(), +`ifndef NO_DRAM_FIFOS + // DRAM signals. + .ddr3_axi_clk (ddr3_axi_clk), + .ddr3_axi_rst (ddr3_axi_rst), + .ddr3_running (ddr3_running), + // Slave Interface Write Address Ports + .ddr3_axi_awid (s_axi_awid), + .ddr3_axi_awaddr (s_axi_awaddr), + .ddr3_axi_awlen (s_axi_awlen), + .ddr3_axi_awsize (s_axi_awsize), + .ddr3_axi_awburst (s_axi_awburst), + .ddr3_axi_awlock (s_axi_awlock), + .ddr3_axi_awcache (s_axi_awcache), + .ddr3_axi_awprot (s_axi_awprot), + .ddr3_axi_awqos (s_axi_awqos), + .ddr3_axi_awvalid (s_axi_awvalid), + .ddr3_axi_awready (s_axi_awready), + // Slave Interface Write Data Ports + .ddr3_axi_wdata (s_axi_wdata), + .ddr3_axi_wstrb (s_axi_wstrb), + .ddr3_axi_wlast (s_axi_wlast), + .ddr3_axi_wvalid (s_axi_wvalid), + .ddr3_axi_wready (s_axi_wready), + // Slave Interface Write Response Ports + .ddr3_axi_bid (s_axi_bid), + .ddr3_axi_bresp (s_axi_bresp), + .ddr3_axi_bvalid (s_axi_bvalid), + .ddr3_axi_bready (s_axi_bready), + // Slave Interface Read Address Ports + .ddr3_axi_arid (s_axi_arid), + .ddr3_axi_araddr (s_axi_araddr), + .ddr3_axi_arlen (s_axi_arlen), + .ddr3_axi_arsize (s_axi_arsize), + .ddr3_axi_arburst (s_axi_arburst), + .ddr3_axi_arlock (s_axi_arlock), + .ddr3_axi_arcache (s_axi_arcache), + .ddr3_axi_arprot (s_axi_arprot), + .ddr3_axi_arqos (s_axi_arqos), + .ddr3_axi_arvalid (s_axi_arvalid), + .ddr3_axi_arready (s_axi_arready), + // Slave Interface Read Data Ports + .ddr3_axi_rid (s_axi_rid), + .ddr3_axi_rdata (s_axi_rdata), + .ddr3_axi_rresp (s_axi_rresp), + .ddr3_axi_rlast (s_axi_rlast), + .ddr3_axi_rvalid (s_axi_rvalid), + .ddr3_axi_rready (s_axi_rready), +`endif // `ifndef NO_DRAM_FIFOS + + // IoPort2 Message FIFOs + .o_iop2_msg_tdata (o_iop2_msg_tdata), + .o_iop2_msg_tvalid (o_iop2_msg_tvalid), + .o_iop2_msg_tlast (o_iop2_msg_tlast), + .o_iop2_msg_tready (o_iop2_msg_tready), + .i_iop2_msg_tdata (i_iop2_msg_tdata), + .i_iop2_msg_tvalid (i_iop2_msg_tvalid), + .i_iop2_msg_tlast (i_iop2_msg_tlast), + .i_iop2_msg_tready (i_iop2_msg_tready), + // PCIe DMA Data + .pcio_tdata (dmarx_tdata), + .pcio_tlast (dmarx_tlast), + .pcio_tvalid (dmarx_tvalid), + .pcio_tready (dmarx_tready), + .pcii_tdata (dmatx_tdata), + .pcii_tlast (dmatx_tlast), + .pcii_tvalid (dmatx_tvalid), + .pcii_tready (dmatx_tready) + ); + + +endmodule // x300 |