// ---------------------------------------------------------------------- // "THE BEER-WARE LICENSE" (Revision 42): // wrote this file. As long as you retain this // notice you can do whatever you want with this stuff. If we meet // some day, and you think this stuff is worth it, you can buy me a // beer in return Yasunori Osana at University of the Ryukyus, // Japan. // ---------------------------------------------------------------------- // OpenFC project: an open FPGA accelerated cluster toolkit // Kyokko project: an open Multi-vendor Aurora 64B/66B-compatible link // // Modules in this file: // c10gx: Top-level module for Intel Cyclone 10 GX Dev board, // with 2x Kyokko on SFP ports // ---------------------------------------------------------------------- `default_nettype none module c10gx ( input wire RST_N, // User PB is active low input wire USRCLK, // 100MHz input wire REFCLK644P, input wire [1:0] SFP_RXP, output wire [1:0] SFP_TXP, output wire [3:0] LED ); parameter NumCh=2; wire RST = ~RST_N; wire CLK100 = USRCLK; // ------------------------------------------------------------ // Kyokko signals wire [NumCh-1:0] CH_UP, AURORA_CLK; // Data channel wire [63:0] S_AXI_TX_TDATA [NumCh-1:0], M_AXI_RX_TDATA [NumCh-1:0]; wire [NumCh-1:0] S_AXI_TX_TLAST, S_AXI_TX_TVALID, S_AXI_TX_TREADY, M_AXI_RX_TLAST, M_AXI_RX_TVALID; // UFC channel wire [NumCh-1:0] UFC_TX_REQ; wire [7:0] UFC_TX_MS [NumCh-1:0]; wire [63:0] S_AXI_UFC_TX_TDATA [NumCh-1:0], M_AXI_UFC_RX_TDATA [NumCh-1:0]; wire [NumCh-1:0] S_AXI_UFC_TX_TVALID, S_AXI_UFC_TX_TREADY, M_AXI_UFC_RX_TLAST, M_AXI_UFC_RX_TVALID; // NFC channel wire [15:0] S_AXI_NFC_TDATA [NumCh-1:0]; wire [NumCh-1:0] S_AXI_NFC_TVALID, S_AXI_NFC_TREADY; // ------------------------------------------------------------ // Signal bundles wire [NumCh*64-1:0] TX_DATA, RX_DATA, UFC_TX_DATA, UFC_RX_DATA; wire [NumCh*16-1:0] NFC_TX_DATA; wire [NumCh* 8-1:0] UFC_MS; genvar ch; for (ch=0; ch