... | @@ -100,37 +100,37 @@ particular), not all ports are required. |
... | @@ -100,37 +100,37 @@ particular), not all ports are required. |
|
<td align="center">clk_board_125m_i</td>
|
|
<td align="center">clk_board_125m_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- Clock inputs from the board</td>
|
|
<td>125 MHz clock input from the VFC-HD board (OSC2 output).</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">clk_board_20m_i</td>
|
|
<td align="center">clk_board_20m_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- Clock inputs from the board</td>
|
|
<td>20 MHz clock input from the VFC-HD board (OSC3 output).</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">areset_n_i</td>
|
|
<td align="center">areset_n_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- Reset input (active low, can be async)</td>
|
|
<td>Reset input, active low. Can be asynchronous.)</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">clk_sys_62m5_o</td>
|
|
<td align="center">clk_sys_62m5_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- 62.5MHz sys clock output</td>
|
|
<td>62.5MHz system clock output.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">clk_ref_125m_o</td>
|
|
<td align="center">clk_ref_125m_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- 125MHz ref clock output</td>
|
|
<td>125MHz WR reference clock output.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">rst_sys_62m5_o</td>
|
|
<td align="center">rst_sys_62m5_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- active high reset output, synchronous to clk_sys_62m5_o</td>
|
|
<td>Active high reset output, synchronous to clk_sys_62m5_o.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center"><strong>SPI interfaces to DACs</strong></td>
|
|
<td align="center"><strong>SPI interfaces to DACs</strong></td>
|
... | @@ -139,25 +139,25 @@ particular), not all ports are required. |
... | @@ -139,25 +139,25 @@ particular), not all ports are required. |
|
<td align="center">dac_ref_sync_n_o</td>
|
|
<td align="center">dac_ref_sync_n_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>SPI CSn for main (ref) VCXO</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">dac_dmtd_sync_n_o</td>
|
|
<td align="center">dac_dmtd_sync_n_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>SPI CSn for helper (DMTD) VCXO</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">dac_din_o</td>
|
|
<td align="center">dac_din_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>SPI MOSI</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">dac_sclk_o</td>
|
|
<td align="center">dac_sclk_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>SPI CLK</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center"><strong>SFP I/O for transceiver and SFP management info from VFC-HD</strong></td>
|
|
<td align="center"><strong>SFP I/O for transceiver and SFP management info from VFC-HD</strong></td>
|
... | @@ -166,25 +166,28 @@ particular), not all ports are required. |
... | @@ -166,25 +166,28 @@ particular), not all ports are required. |
|
<td align="center">sfp_tx_o</td>
|
|
<td align="center">sfp_tx_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>SFP TX</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">sfp_rx_i</td>
|
|
<td align="center">sfp_rx_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>SFP RX</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">sfp_det_valid_i</td>
|
|
<td align="center">sfp_det_valid_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- HIGH if both of the following are true: -- 1. SFP is detected (plugged in) -- 2. The part number has been successfully read after the SFP detection</td>
|
|
<td><em>High</em> if both of the following are true:<br />
|
|
|
|
1. SFP is detected (plugged in)<br />
|
|
|
|
2. The part number has been successfully read after the SFP detection</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">sfp_data_i</td>
|
|
<td align="center">sfp_data_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic_vector (127 downto 0)</td>
|
|
<td>std_logic_vector</td>
|
|
<td>-- 16 byte vendor Part Number (PN) -- (ASCII encoded, first character byte in bits 127 downto 120)</td>
|
|
<td>The VFC-HD board implements I2C multiplexers to provide access to the numerous SFP interfaces (as well as other I2C-controlled peripherals).<br />
|
|
|
|
The <a href="https://gitlab.cern.ch/dlamprid/VFC-HD/tree/master">VFC-HD project</a> provides an additional module (in Verilog) which takes care of accessing the SFP information and making it available to the WR PTP code, in the form of a 16 byte vendor Part Number (128 bits std_logic_vector, ASCII encoded, first character byte in bits 127 downto 120).</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center"><strong>I2C EEPROM</strong></td>
|
|
<td align="center"><strong>I2C EEPROM</strong></td>
|
... | @@ -193,13 +196,13 @@ particular), not all ports are required. |
... | @@ -193,13 +196,13 @@ particular), not all ports are required. |
|
<td align="center">eeprom_sda_b</td>
|
|
<td align="center">eeprom_sda_b</td>
|
|
<td>inout</td>
|
|
<td>inout</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>Bidirectional I2C SDA line.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">eeprom_scl_o</td>
|
|
<td align="center">eeprom_scl_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td>-- VFC-HD defines SCL as output, which works because the EEPROM is the -- only device connected on this I2C bus.</td>
|
|
<td>Normally, this should also be bidirectional, but VFC-HD defines SCL as output, which works because the EEPROM is the only device connected on this I2C bus.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center"><strong>Onewire interface</strong></td>
|
|
<td align="center"><strong>Onewire interface</strong></td>
|
... | @@ -208,13 +211,13 @@ particular), not all ports are required. |
... | @@ -208,13 +211,13 @@ particular), not all ports are required. |
|
<td align="center">onewire_i</td>
|
|
<td align="center">onewire_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>Data input from the onewire interface.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">onewire_oen_o</td>
|
|
<td align="center">onewire_oen_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>Output enable to the onewire interface. When this is asserted, the instantiating module should drive the onewire data output to ground.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center"><strong>External WB interface</strong></td>
|
|
<td align="center"><strong>External WB interface</strong></td>
|
... | @@ -223,7 +226,8 @@ particular), not all ports are required. |
... | @@ -223,7 +226,8 @@ particular), not all ports are required. |
|
<td align="center">wb_adr_i</td>
|
|
<td align="center">wb_adr_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic_vector</td>
|
|
<td>std_logic_vector</td>
|
|
<td>WR fabric "sink" interface. VHDL records are not used here, to facilitate integration of the module into Verilog-based projects (such as the VFC-HD)</td>
|
|
<td>Wishbone slave interface, operating in "Pipelined" mode, with word granularity. It provides access to all the Wishbone peripherals inside the WR PTP core.<br />
|
|
|
|
VHDL records are not used here, to facilitate integration of the module into Verilog-based projects (such as the VFC-HD).</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wb_dat_i</td>
|
|
<td align="center">wb_dat_i</td>
|
... | @@ -305,46 +309,55 @@ VHDL records are not used here, to facilitate integration of the module into Ver |
... | @@ -305,46 +309,55 @@ VHDL records are not used here, to facilitate integration of the module into Ver |
|
<td align="center">wrf_src_dat_o</td>
|
|
<td align="center">wrf_src_dat_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic_vector</td>
|
|
<td>std_logic_vector</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrf_src_cyc_o</td>
|
|
<td align="center">wrf_src_cyc_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrf_src_stb_o</td>
|
|
<td align="center">wrf_src_stb_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrf_src_we_o</td>
|
|
<td align="center">wrf_src_we_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrf_src_sel_o</td>
|
|
<td align="center">wrf_src_sel_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic_vector</td>
|
|
<td>std_logic_vector</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrf_src_ack_i</td>
|
|
<td align="center">wrf_src_ack_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrf_src_stall_i</td>
|
|
<td align="center">wrf_src_stall_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrf_src_err_i</td>
|
|
<td align="center">wrf_src_err_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrf_src_rty_i</td>
|
|
<td align="center">wrf_src_rty_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
|
|
<td></td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrf_snk_adr_i</td>
|
|
<td align="center">wrf_snk_adr_i</td>
|
... | @@ -414,61 +427,61 @@ VHDL records are not used here, to facilitate integration of the module into Ver |
... | @@ -414,61 +427,61 @@ VHDL records are not used here, to facilitate integration of the module into Ver |
|
<td align="center">wrs_tx_data_i</td>
|
|
<td align="center">wrs_tx_data_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic_vector</td>
|
|
<td>std_logic_vector</td>
|
|
<td>The width of the vector is equal to g_streamer_width parameter.</td>
|
|
<td>Data word to be sent over the physical link. The width of the vector is equal to g_streamer_width parameter.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrs_tx_valid_i</td>
|
|
<td align="center">wrs_tx_valid_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>An '1' indicates that the tx_data_i contains a valid data word.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrs_tx_dreq_o</td>
|
|
<td align="center">wrs_tx_dreq_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>Synchronous data request: when '1', the user may send a data word in the following clock cycle.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrs_tx_last_i</td>
|
|
<td align="center">wrs_tx_last_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>An '1' indicates the last data word in a larger block of samples.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrs_tx_flush_i</td>
|
|
<td align="center">wrs_tx_flush_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>When asserted, the streamer will immediately send out all the data that is stored in its TX buffer.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrs_rx_first_o</td>
|
|
<td align="center">wrs_rx_first_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>An '1' indicates the first data word of the data block on wrs_rx_data_o.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrs_rx_last_o</td>
|
|
<td align="center">wrs_rx_last_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>An '1' indicates the last data word of the data block on wrs_rx_data_o.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrs_rx_data_o</td>
|
|
<td align="center">wrs_rx_data_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic_vector</td>
|
|
<td>std_logic_vector</td>
|
|
<td>The width of the vector is equal to g_streamer_width parameter.</td>
|
|
<td>Data word received from the physical link. The width of the vector is equal to g_streamer_width parameter.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center">wrs_rx_valid_o</td>
|
|
<td align="center">wrs_rx_valid_o</td>
|
|
<td>out</td>
|
|
<td>out</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>An '1' indicates that rx_data_o is outputting a valid data word.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="odd">
|
|
<tr class="odd">
|
|
<td align="center">wrs_rx_dreq_i</td>
|
|
<td align="center">wrs_rx_dreq_i</td>
|
|
<td>in</td>
|
|
<td>in</td>
|
|
<td>std_logic</td>
|
|
<td>std_logic</td>
|
|
<td></td>
|
|
<td>Synchronous data request input: when '1', the streamer may output another data word in the subsequent clock cycle.</td>
|
|
</tr>
|
|
</tr>
|
|
<tr class="even">
|
|
<tr class="even">
|
|
<td align="center"><strong>WRPC timing interface and status</strong></td>
|
|
<td align="center"><strong>WRPC timing interface and status</strong></td>
|
... | @@ -630,5 +643,5 @@ wiki](https://www.ohwr.org/project/vfc-hd/wikis). |
... | @@ -630,5 +643,5 @@ wiki](https://www.ohwr.org/project/vfc-hd/wikis). |
|
|
|
|
|
-----
|
|
-----
|
|
|
|
|
|
16 December 2016
|
|
19 December 2016
|
|
|
|
|