Updated to the newest libraries
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@ -1,411 +1,400 @@
|
|||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
-- Paul Scherrer Institute (PSI)
|
-- Paul Scherrer Institute (PSI)
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Unit : evr320_ifc1210_wrapper.vhd
|
-- Unit : evr320_ifc1210_wrapper.vhd
|
||||||
-- Author : Patric Bucher, Benoit Stef
|
-- Author : Patric Bucher, Benoit Stef
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Copyright© PSI, Section DSV
|
-- Copyright© PSI, Section DSV
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Comment : Wraps evr320 decoder together with GTX component and TMEM registers.
|
-- Comment : Wraps evr320 decoder together with GTX component and TMEM registers.
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
library ieee;
|
library ieee;
|
||||||
use ieee.std_logic_1164.all;
|
use ieee.std_logic_1164.all;
|
||||||
use ieee.numeric_std.all;
|
use ieee.numeric_std.all;
|
||||||
use ieee.math_real.all;
|
use ieee.math_real.all;
|
||||||
|
|
||||||
library tosca2;
|
library tosca2;
|
||||||
use tosca2.tosca2_glb_pkg.all;
|
use tosca2.tosca2_glb_pkg.all;
|
||||||
|
|
||||||
use work.evr320_pkg.all;
|
use work.evr320_pkg.all;
|
||||||
use work.v6vlx_gtxe1_pkg.all;
|
use work.v6vlx_gtxe1_pkg.all;
|
||||||
|
|
||||||
entity evr320_ifc1210_wrapper is
|
entity evr320_ifc1210_wrapper is
|
||||||
generic(
|
generic(
|
||||||
g_MGT_LOCATION : string := "GTXE1_X0Y16"; -- "GTXE1_X0Y0" to "GTXE1_X0Y11" | "GTXE1_X0Y16" to "GTXE1_X0Y19"
|
g_MGT_LOCATION : string := "GTXE1_X0Y16"; -- "GTXE1_X0Y0" to "GTXE1_X0Y11" | "GTXE1_X0Y16" to "GTXE1_X0Y19"
|
||||||
g_FACILITY : string := "SFEL"; -- "HIPA" | "SFEL"
|
g_FACILITY : string := "SFEL"; -- "HIPA" | "SFEL"
|
||||||
g_EVENT_RECORDER : boolean := false; -- enable/disable Event Recorder functionality
|
g_EVENT_RECORDER : boolean := false; -- enable/disable Event Recorder functionality
|
||||||
g_XUSER_CLK_FREQ : natural := 125000000 -- Xuser Clk Frequency in Hz
|
g_XUSER_CLK_FREQ : natural := 125000000 -- Xuser Clk Frequency in Hz
|
||||||
);
|
);
|
||||||
port(
|
port(
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
-- Debug interface
|
-- Debug interface
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
debug_clk : out std_logic;
|
debug_clk : out std_logic;
|
||||||
debug : out std_logic_vector(127 downto 0);
|
debug : out std_logic_vector(127 downto 0);
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
-- TOSCA2 TMEM Interface (xuser clock domain, 100-250MHz)
|
-- TOSCA2 TMEM Interface (xuser clock domain, 100-250MHz)
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
xuser_CLK : in std_logic;
|
xuser_CLK : in std_logic;
|
||||||
xuser_RESET : in std_logic;
|
xuser_RESET : in std_logic;
|
||||||
xuser_TMEM_ENA : in std_logic;
|
xuser_TMEM_ENA : in std_logic;
|
||||||
xuser_TMEM_WE : in std_logic_vector(7 downto 0);
|
xuser_TMEM_WE : in std_logic_vector(7 downto 0);
|
||||||
xuser_TMEM_ADD : in std_logic_vector(13 downto 3);
|
xuser_TMEM_ADD : in std_logic_vector(13 downto 3);
|
||||||
xuser_TMEM_DATW : in std_logic_vector(63 downto 0);
|
xuser_TMEM_DATW : in std_logic_vector(63 downto 0);
|
||||||
xuser_TMEM_DATR : out std_logic_vector(63 downto 0);
|
xuser_TMEM_DATR : out std_logic_vector(63 downto 0);
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
-- MGT Interface
|
-- MGT Interface
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
mgt_refclk_i : in std_logic; -- MGT Reference Clock
|
mgt_refclk_i : in std_logic; -- MGT Reference Clock
|
||||||
mgt_sfp_los_i : in std_logic; -- SFP Loss of Signal (light on receiver)
|
mgt_sfp_los_i : in std_logic; -- SFP Loss of Signal (light on receiver)
|
||||||
mgt_rx_n : in std_logic; -- MGT RX N
|
mgt_rx_n : in std_logic; -- MGT RX N
|
||||||
mgt_rx_p : in std_logic; -- MGT RX P
|
mgt_rx_p : in std_logic; -- MGT RX P
|
||||||
mgt_tx_n : out std_logic; -- MGT TX N
|
mgt_tx_n : out std_logic; -- MGT TX N
|
||||||
mgt_tx_p : out std_logic; -- MGT TX P
|
mgt_tx_p : out std_logic; -- MGT TX P
|
||||||
mgt_status_o : out std_logic_vector(31 downto 0); -- MGT Status
|
mgt_status_o : out std_logic_vector(31 downto 0); -- MGT Status
|
||||||
mgt_control_i : in std_logic_vector(31 downto 0); -- MGT Control
|
mgt_control_i : in std_logic_vector(31 downto 0); -- MGT Control
|
||||||
---------------------------------------------------------------------------
|
mgt_rx_data_o : out std_logic_Vector(15 downto 0); -- for debug purpose
|
||||||
-- User interface MGT clock
|
mgt_rx_charisk_o : out std_logic_vector(1 downto 0); -- for debug purpose
|
||||||
---------------------------------------------------------------------------
|
|
||||||
clk_evr_o : out std_logic; -- Recovered parallel clock from MGT
|
---------------------------------------------------------------------------
|
||||||
rst_evr_o : out std_logic; -- reset according to RX Loss of sync
|
-- User interface MGT clock
|
||||||
usr_events_o : out std_logic_vector(3 downto 0); -- User defined event pulses with one clock cycles length & no delay
|
---------------------------------------------------------------------------
|
||||||
sos_event_o : out std_logic; -- Start-of-Sequence Event
|
clk_evr_o : out std_logic; -- Recovered parallel clock from MGT
|
||||||
usr_events_adj_o : out std_logic_vector(3 downto 0); -- User defined event pulses adjusted in delay & length
|
rst_evr_o : out std_logic; -- reset according to RX Loss of sync
|
||||||
sos_events_adj_o : out std_logic; -- Start-of-Sequence adjusted in delay & length
|
usr_events_o : out std_logic_vector(3 downto 0); -- User defined event pulses with one clock cycles length & no delay
|
||||||
--------------------------------------------------------------------------
|
sos_event_o : out std_logic; -- Start-of-Sequence Event
|
||||||
-- Decoder axi stream interface, User clock
|
usr_events_adj_o : out std_logic_vector(3 downto 0); -- User defined event pulses adjusted in delay & length
|
||||||
--------------------------------------------------------------------------
|
sos_events_adj_o : out std_logic; -- Start-of-Sequence adjusted in delay & length
|
||||||
stream_clk_i : in std_logic := '0';
|
--------------------------------------------------------------------------
|
||||||
stream_data_o : out std_logic_vector(7 downto 0);
|
-- Decoder axi stream interface, User clock
|
||||||
stream_addr_o : out std_logic_vector(10 downto 0);
|
--------------------------------------------------------------------------
|
||||||
stream_valid_o : out std_logic
|
stream_clk_i : in std_logic := '0';
|
||||||
);
|
stream_data_o : out std_logic_vector(7 downto 0);
|
||||||
end evr320_ifc1210_wrapper;
|
stream_addr_o : out std_logic_vector(10 downto 0);
|
||||||
|
stream_valid_o : out std_logic
|
||||||
architecture rtl of evr320_ifc1210_wrapper is
|
);
|
||||||
|
end evr320_ifc1210_wrapper;
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
-- Parameters
|
architecture rtl of evr320_ifc1210_wrapper is
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
constant c_TOSCA2_DATA_WIDTH : integer := 64;
|
-- --------------------------------------------------------------------------
|
||||||
constant c_EVR_REG64_COUNT : integer := 16; -- unused, only documentation
|
-- Parameters
|
||||||
constant c_EVR_MEM_SIZE : integer := 16384; -- unused, only documentation
|
-- --------------------------------------------------------------------------
|
||||||
|
constant c_TOSCA2_DATA_WIDTH : integer := 64;
|
||||||
-- --------------------------------------------------------------------------
|
constant c_EVR_REG64_COUNT : integer := 16; -- unused, only documentation
|
||||||
-- Signal definitions
|
constant c_EVR_MEM_SIZE : integer := 16384; -- unused, only documentation
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
signal clk_evr : std_logic;
|
-- --------------------------------------------------------------------------
|
||||||
--signal clk_evr_monitor : std_logic; -- for debugging
|
-- Signal definitions
|
||||||
signal rst_evr : std_logic;
|
-- --------------------------------------------------------------------------
|
||||||
signal mgt_control : std_logic_vector(31 downto 0) := (others => '0');
|
signal clk_evr : std_logic;
|
||||||
signal mgt_status : std_logic_vector(31 downto 0);
|
--signal clk_evr_monitor : std_logic; -- for debugging
|
||||||
signal mgt_rx_data : std_logic_vector(15 downto 0);
|
signal rst_evr : std_logic;
|
||||||
signal mgt_rx_charisk : std_logic_vector(1 downto 0);
|
signal mgt_control : std_logic_vector(31 downto 0) := (others => '0');
|
||||||
signal mgt_lossofsync : std_logic;
|
signal mgt_status : std_logic_vector(31 downto 0);
|
||||||
signal mgt_reset_tmem_evr : std_logic; -- for legacy reasons, ifc1210 mgt control is in tmem_psi_generic part
|
signal mgt_rx_data : std_logic_vector(15 downto 0);
|
||||||
signal mem_clk : std_logic;
|
signal mgt_rx_charisk : std_logic_vector(1 downto 0);
|
||||||
signal mem_addr_evr : std_logic_vector(11 downto 0);
|
signal mgt_lossofsync : std_logic;
|
||||||
signal mem_addr_tosca : std_logic_vector(10 downto 0);
|
signal mgt_reset_tmem_evr : std_logic; -- for legacy reasons, ifc1210 mgt control is in tmem_psi_generic part
|
||||||
signal mem_data : std_logic_vector(c_TOSCA2_DATA_WIDTH - 1 downto 0);
|
signal mem_clk : std_logic;
|
||||||
signal evr_params : typ_evr320_params;
|
signal mem_addr_evr : std_logic_vector(11 downto 0);
|
||||||
signal evr_params_sync : typ_evr320_params;
|
signal mem_addr_tosca : std_logic_vector(10 downto 0);
|
||||||
signal evr_params_xuser : typ_evr320_params;
|
signal mem_data : std_logic_vector(c_TOSCA2_DATA_WIDTH - 1 downto 0);
|
||||||
signal event_recorder_status : typ_evt_rec_status;
|
signal evr_params : typ_evr320_params;
|
||||||
signal event_recorder_control : typ_evt_rec_ctrl;
|
signal evr_params_sync : typ_evr320_params;
|
||||||
signal event_recorder_control_sync : typ_evt_rec_ctrl;
|
signal evr_params_xuser : typ_evr320_params;
|
||||||
signal event_recorder_control_xuser : typ_evt_rec_ctrl;
|
signal event_recorder_status : typ_evt_rec_status;
|
||||||
signal evr_latency_measure_stat : typ_rec_latency_measure_stat;
|
signal event_recorder_control : typ_evt_rec_ctrl;
|
||||||
signal evr_latency_measure_ctrl : typ_rec_latency_measure_ctrl;
|
signal event_recorder_control_sync : typ_evt_rec_ctrl;
|
||||||
signal evr_frequency : std_logic_vector(31 downto 0) := (others => '0');
|
signal event_recorder_control_xuser : typ_evt_rec_ctrl;
|
||||||
signal debug_data : std_logic_vector(127 downto 0);
|
signal evr_latency_measure_stat : typ_rec_latency_measure_stat;
|
||||||
signal decoder_event_valid : std_logic;
|
signal evr_latency_measure_ctrl : typ_rec_latency_measure_ctrl;
|
||||||
signal decoder_event : std_logic_vector(7 downto 0);
|
signal evr_frequency : std_logic_vector(31 downto 0) := (others => '0');
|
||||||
|
signal debug_data : std_logic_vector(127 downto 0);
|
||||||
-- --------------------------------------------------------------------------
|
signal decoder_event_valid : std_logic;
|
||||||
-- Attribute definitions
|
signal decoder_event : std_logic_vector(7 downto 0);
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
attribute keep : string;
|
-- --------------------------------------------------------------------------
|
||||||
attribute keep of clk_evr : signal is "TRUE";
|
-- Attribute definitions
|
||||||
attribute keep of debug_data : signal is "TRUE";
|
-- --------------------------------------------------------------------------
|
||||||
signal usr_events_s : std_logic_vector(3 downto 0);
|
attribute keep : string;
|
||||||
signal sos_event_s : std_logic;
|
attribute keep of clk_evr : signal is "TRUE";
|
||||||
signal evr_rst_s : std_logic;
|
attribute keep of debug_data : signal is "TRUE";
|
||||||
signal usr_event_delay_s : typ_arr_delay;
|
signal usr_events_s : std_logic_vector(3 downto 0);
|
||||||
signal usr_event_width_s : typ_arr_width;
|
signal sos_event_s : std_logic;
|
||||||
|
signal evr_rst_s : std_logic;
|
||||||
-- ----------------------------------------------------------------------------
|
signal usr_event_delay_s : typ_arr_delay;
|
||||||
-- ----------------------------------------------------------------------------
|
signal usr_event_width_s : typ_arr_width;
|
||||||
-- //////////////////// Main Body /////////////////////////
|
|
||||||
-- ----------------------------------------------------------------------------
|
-- ----------------------------------------------------------------------------
|
||||||
-- ----------------------------------------------------------------------------
|
-- ----------------------------------------------------------------------------
|
||||||
begin
|
-- //////////////////// Main Body /////////////////////////
|
||||||
|
-- ----------------------------------------------------------------------------
|
||||||
-- --------------------------------------------------------------------------
|
-- ----------------------------------------------------------------------------
|
||||||
-- static signal assignments
|
begin
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
mgt_lossofsync <= mgt_status(15);
|
-- --------------------------------------------------------------------------
|
||||||
rst_evr_o <= mgt_status(15);
|
-- static signal assignments
|
||||||
mem_addr_evr <= '0' & mem_addr_tosca;
|
-- --------------------------------------------------------------------------
|
||||||
|
mgt_lossofsync <= mgt_status(15);
|
||||||
mgt_control(c_GTXRESET) <= mgt_control_i(c_GTXRESET) or mgt_sfp_los_i or mgt_reset_tmem_evr;
|
rst_evr_o <= mgt_status(15);
|
||||||
mgt_control(4 downto 1) <= mgt_control_i(4 downto 1);
|
mem_addr_evr <= '0' & mem_addr_tosca;
|
||||||
mgt_control(c_RXCDRRESET) <= mgt_control_i(c_RXCDRRESET);
|
|
||||||
mgt_control(31 downto 6) <= mgt_control_i(31 downto 6);
|
mgt_control(c_GTXRESET) <= mgt_control_i(c_GTXRESET) or mgt_sfp_los_i or mgt_reset_tmem_evr;
|
||||||
|
mgt_control(4 downto 1) <= mgt_control_i(4 downto 1);
|
||||||
-- --------------------------------------------------------------------------
|
mgt_control(c_RXCDRRESET) <= mgt_control_i(c_RXCDRRESET);
|
||||||
-- Synchronisation to EVR Clock
|
mgt_control(31 downto 6) <= mgt_control_i(31 downto 6);
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
prc_sync_evr : process(clk_evr)
|
-- --------------------------------------------------------------------------
|
||||||
begin
|
-- Synchronisation to EVR Clock
|
||||||
if rising_edge(clk_evr) then
|
-- --------------------------------------------------------------------------
|
||||||
---
|
prc_sync_evr : process(clk_evr)
|
||||||
evr_params_sync <= evr_params_xuser;
|
begin
|
||||||
evr_params <= evr_params_sync;
|
if rising_edge(clk_evr) then
|
||||||
---
|
---
|
||||||
event_recorder_control_sync <= event_recorder_control_xuser;
|
evr_params_sync <= evr_params_xuser;
|
||||||
event_recorder_control <= event_recorder_control_sync;
|
evr_params <= evr_params_sync;
|
||||||
---
|
---
|
||||||
end if;
|
event_recorder_control_sync <= event_recorder_control_xuser;
|
||||||
end process;
|
event_recorder_control <= event_recorder_control_sync;
|
||||||
|
---
|
||||||
-- --------------------------------------------------------------------------
|
end if;
|
||||||
-- EVR320 Decoder
|
end process;
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
evr320_decoder_inst : entity work.evr320_decoder
|
-- --------------------------------------------------------------------------
|
||||||
generic map(
|
-- EVR320 Decoder
|
||||||
EVENT_RECORDER => g_EVENT_RECORDER,
|
-- --------------------------------------------------------------------------
|
||||||
MEM_DATA_WIDTH => c_TOSCA2_DATA_WIDTH)
|
evr320_decoder_inst : entity work.evr320_decoder
|
||||||
port map(
|
generic map(
|
||||||
-- Debug interface
|
FACILITY => g_FACILITY,
|
||||||
debug_clk => debug_clk,
|
EVENT_RECORDER => g_EVENT_RECORDER,
|
||||||
debug => debug_data,
|
MEM_DATA_WIDTH => c_TOSCA2_DATA_WIDTH,
|
||||||
-- GTX parallel interface
|
EXP_REC_CLK_FREQ => 50_632_820)
|
||||||
i_mgt_rst => mgt_lossofsync,
|
port map(
|
||||||
i_mgt_rx_clk => clk_evr,
|
-- Debug interface
|
||||||
i_mgt_rx_data => mgt_rx_data,
|
debug_clk => debug_clk,
|
||||||
i_mgt_rx_charisk => mgt_rx_charisk,
|
debug => debug_data,
|
||||||
-- User interface CPU clock
|
-- GTX parallel interface
|
||||||
i_usr_clk => mem_clk,
|
i_mgt_rst => mgt_lossofsync,
|
||||||
i_evr_params => evr_params,
|
i_mgt_rx_clk => clk_evr,
|
||||||
o_event_recorder_stat => event_recorder_status,
|
i_mgt_rx_data => mgt_rx_data,
|
||||||
i_event_recorder_ctrl => event_recorder_control,
|
i_mgt_rx_charisk => mgt_rx_charisk,
|
||||||
i_mem_addr => mem_addr_evr,
|
-- User interface CPU clock
|
||||||
o_mem_data => mem_data,
|
i_usr_clk => mem_clk,
|
||||||
-- user stream interface, user clock
|
i_evr_params => evr_params,
|
||||||
i_stream_clk => stream_clk_i,
|
o_event_recorder_stat => event_recorder_status,
|
||||||
o_stream_data => stream_data_o,
|
i_event_recorder_ctrl => event_recorder_control,
|
||||||
o_stream_addr => stream_addr_o,
|
i_mem_addr => mem_addr_evr,
|
||||||
o_stream_valid => stream_valid_o,
|
o_mem_data => mem_data,
|
||||||
-- User interface MGT clock
|
-- user stream interface, user clock
|
||||||
o_usr_events => usr_events_s,
|
i_stream_clk => stream_clk_i,
|
||||||
-- o_usr_events_ext => usr_events_ext_o, -- not in use anymore
|
o_stream_data => stream_data_o,
|
||||||
o_sos_event => sos_event_s,
|
o_stream_addr => stream_addr_o,
|
||||||
o_event => decoder_event,
|
o_stream_valid => stream_valid_o,
|
||||||
o_event_valid => decoder_event_valid
|
-- User interface MGT clock
|
||||||
);
|
o_usr_events => usr_events_s,
|
||||||
|
-- o_usr_events_ext => usr_events_ext_o, -- not in use anymore
|
||||||
usr_events_o <= usr_events_s;
|
o_sos_event => sos_event_s,
|
||||||
sos_event_o <= sos_event_s;
|
o_event => decoder_event,
|
||||||
|
o_event_valid => decoder_event_valid
|
||||||
-- --------------------------------------------------------------------------
|
);
|
||||||
-- MGT Wrapper for GTX Virtex-6
|
|
||||||
-- --------------------------------------------------------------------------
|
usr_events_o <= usr_events_s;
|
||||||
mgt_wrapper_inst : entity work.v6vlx_gtxe1_wrapper
|
sos_event_o <= sos_event_s;
|
||||||
generic map(
|
|
||||||
g_MGT_LOCATION => g_MGT_LOCATION,
|
-- --------------------------------------------------------------------------
|
||||||
g_FACILITY => g_FACILITY)
|
-- MGT Wrapper for GTX Virtex-6
|
||||||
port map(
|
-- --------------------------------------------------------------------------
|
||||||
-- MGT serial interface
|
mgt_wrapper_inst : entity work.v6vlx_gtxe1_wrapper
|
||||||
i_mgt_refclk => mgt_refclk_i,
|
generic map(
|
||||||
o_mgt_refclk => open,
|
g_MGT_LOCATION => g_MGT_LOCATION,
|
||||||
i_mgt_rx_p => mgt_rx_p,
|
g_FACILITY => g_FACILITY)
|
||||||
i_mgt_rx_n => mgt_rx_n,
|
port map(
|
||||||
o_mgt_tx_p => mgt_tx_p,
|
-- MGT serial interface
|
||||||
o_mgt_tx_n => mgt_tx_n,
|
i_mgt_refclk => mgt_refclk_i,
|
||||||
-- MGT parallel interface
|
o_mgt_refclk => open,
|
||||||
o_mgt_status => mgt_status,
|
i_mgt_rx_p => mgt_rx_p,
|
||||||
i_mgt_control => mgt_control,
|
i_mgt_rx_n => mgt_rx_n,
|
||||||
o_mgt_recclk => clk_evr,
|
o_mgt_tx_p => mgt_tx_p,
|
||||||
o_mgt_rx_data => mgt_rx_data,
|
o_mgt_tx_n => mgt_tx_n,
|
||||||
o_mgt_rx_charisk => mgt_rx_charisk
|
-- MGT parallel interface
|
||||||
);
|
o_mgt_status => mgt_status,
|
||||||
|
i_mgt_control => mgt_control,
|
||||||
-- --------------------------------------------------------------------------
|
o_mgt_recclk => clk_evr,
|
||||||
-- TMEM
|
o_mgt_rx_data => mgt_rx_data,
|
||||||
-- --------------------------------------------------------------------------
|
o_mgt_rx_charisk => mgt_rx_charisk
|
||||||
--formatter:off
|
);
|
||||||
evr320_tmem_inst : entity work.evr320_tmem
|
mgt_rx_charisk_o <= mgt_rx_charisk;
|
||||||
port map(
|
mgt_rx_data_o <= mgt_rx_data;
|
||||||
-- TOSCA2 TMEM Interface
|
-- --------------------------------------------------------------------------
|
||||||
xuser_CLK => xuser_CLK,
|
-- TMEM
|
||||||
xuser_RESET => xuser_RESET,
|
-- --------------------------------------------------------------------------
|
||||||
xuser_TMEM_ENA => xuser_TMEM_ENA,
|
--formatter:off
|
||||||
xuser_TMEM_WE => xuser_TMEM_WE,
|
evr320_tmem_inst : entity work.evr320_tmem
|
||||||
xuser_TMEM_ADD => xuser_TMEM_ADD,
|
port map(
|
||||||
xuser_TMEM_DATW => xuser_TMEM_DATW,
|
-- TOSCA2 TMEM Interface
|
||||||
xuser_TMEM_DATR => xuser_TMEM_DATR,
|
xuser_CLK => xuser_CLK,
|
||||||
-- EVR320 Memory/Parameter Interface
|
xuser_RESET => xuser_RESET,
|
||||||
evr_params_o => evr_params_xuser,
|
xuser_TMEM_ENA => xuser_TMEM_ENA,
|
||||||
evr_frequency_i => evr_frequency,
|
xuser_TMEM_WE => xuser_TMEM_WE,
|
||||||
evr_evt_rec_status_i => event_recorder_status,
|
xuser_TMEM_ADD => xuser_TMEM_ADD,
|
||||||
evr_evt_rec_control_o => event_recorder_control_xuser,
|
xuser_TMEM_DATW => xuser_TMEM_DATW,
|
||||||
evr_latency_measure_stat_i => evr_latency_measure_stat,
|
xuser_TMEM_DATR => xuser_TMEM_DATR,
|
||||||
evr_latency_measure_ctrl_o => evr_latency_measure_ctrl,
|
-- EVR320 Memory/Parameter Interface
|
||||||
mgt_status_i => mgt_status,
|
evr_params_o => evr_params_xuser,
|
||||||
mgt_reset_o => mgt_reset_tmem_evr,
|
evr_frequency_i => evr_frequency,
|
||||||
mem_clk_o => mem_clk,
|
evr_evt_rec_status_i => event_recorder_status,
|
||||||
mem_addr_o => mem_addr_tosca,
|
evr_evt_rec_control_o => event_recorder_control_xuser,
|
||||||
mem_data_i => mem_data,
|
evr_latency_measure_stat_i => evr_latency_measure_stat,
|
||||||
--
|
evr_latency_measure_ctrl_o => evr_latency_measure_ctrl,
|
||||||
evr_clk_i => clk_evr,
|
mgt_status_i => mgt_status,
|
||||||
evr_rst_i => evr_rst_s,
|
mgt_reset_o => mgt_reset_tmem_evr,
|
||||||
evr_pulse_delay_o => usr_event_delay_s,
|
mem_clk_o => mem_clk,
|
||||||
evr_pulse_width_o => usr_event_width_s);
|
mem_addr_o => mem_addr_tosca,
|
||||||
|
mem_data_i => mem_data,
|
||||||
-- --------------------------------------------------------------------------
|
--
|
||||||
-- Measure EVR Clock (based on xuser_CLK)
|
evr_clk_i => clk_evr,
|
||||||
-- --------------------------------------------------------------------------
|
evr_rst_i => evr_rst_s,
|
||||||
clock_meas_inst : entity work.psi_common_clk_meas
|
evr_pulse_delay_o => usr_event_delay_s,
|
||||||
generic map(
|
evr_pulse_width_o => usr_event_width_s);
|
||||||
MasterFrequency_g => g_XUSER_CLK_FREQ,
|
|
||||||
MaxMeasFrequency_g => 150000000
|
-- --------------------------------------------------------------------------
|
||||||
)
|
-- Measure EVR Clock (based on xuser_CLK)
|
||||||
port map(
|
-- --------------------------------------------------------------------------
|
||||||
ClkMaster => xuser_CLK,
|
clock_meas_inst : entity work.psi_common_clk_meas
|
||||||
Rst => xuser_RESET,
|
generic map(
|
||||||
ClkTest => clk_evr,
|
master_frequency_g => g_XUSER_CLK_FREQ,
|
||||||
FrequencyHz => evr_frequency
|
max_meas_frequency_g => 150000000
|
||||||
);
|
)
|
||||||
|
port map(
|
||||||
-- --------------------------------------------------------------------------
|
clk_master_i => xuser_CLK,
|
||||||
-- Event Latency Measurement for SW tests
|
rst_i => xuser_RESET,
|
||||||
-- --------------------------------------------------------------------------
|
clk_test_i => clk_evr,
|
||||||
lat_meas_block : block
|
frequency_hz_o => evr_frequency
|
||||||
type state_type is (armed, count);
|
);
|
||||||
signal state : state_type;
|
|
||||||
signal counter : unsigned(31 downto 0);
|
-- --------------------------------------------------------------------------
|
||||||
signal event_nr_sync, event_nr : std_logic_vector(7 downto 0);
|
-- Event Latency Measurement for SW tests
|
||||||
signal event_detected : std_logic_vector(3 downto 0);
|
-- --------------------------------------------------------------------------
|
||||||
signal event_detected_sync : std_logic_vector(1 downto 0);
|
lat_meas_block : block
|
||||||
constant MAX_COUNT : unsigned(31 downto 0) := to_unsigned(g_XUSER_CLK_FREQ / 100, 32); -- MAX 10ms
|
type state_type is (armed, count);
|
||||||
begin
|
signal state : state_type;
|
||||||
|
signal counter : unsigned(31 downto 0);
|
||||||
-- Process: filter events for matching event_nr register:
|
signal event_nr_sync, event_nr : std_logic_vector(7 downto 0);
|
||||||
---------------------------------------------------------
|
signal event_detected : std_logic_vector(3 downto 0);
|
||||||
ext_event_proc : process(clk_evr)
|
signal event_detected_sync : std_logic_vector(1 downto 0);
|
||||||
begin
|
constant MAX_COUNT : unsigned(31 downto 0) := to_unsigned(g_XUSER_CLK_FREQ / 10, 32); -- MAX 100ms ~ 10Hz
|
||||||
if (rising_edge(clk_evr)) then
|
begin
|
||||||
-- sync to MGT clock domain:
|
|
||||||
event_nr_sync <= evr_latency_measure_ctrl.event_nr;
|
-- Process: filter events for matching event_nr register:
|
||||||
event_nr <= event_nr_sync;
|
---------------------------------------------------------
|
||||||
|
ext_event_proc : process(clk_evr)
|
||||||
-- check if event has been detected and stretch pulse:
|
begin
|
||||||
event_detected <= event_detected(2 downto 0) & '0';
|
if (rising_edge(clk_evr)) then
|
||||||
if (decoder_event_valid = '1' and decoder_event = event_nr) then
|
-- sync to MGT clock domain:
|
||||||
event_detected <= (others => '1');
|
event_nr_sync <= evr_latency_measure_ctrl.event_nr;
|
||||||
end if;
|
event_nr <= event_nr_sync;
|
||||||
end if;
|
|
||||||
end process;
|
-- check if event has been detected and stretch pulse:
|
||||||
|
event_detected <= event_detected(2 downto 0) & '0';
|
||||||
-- Process: Counter when configured event has been detected:
|
if (decoder_event_valid = '1' and decoder_event = event_nr) then
|
||||||
------------------------------------------------------------
|
event_detected <= (others => '1');
|
||||||
lat_meas_proc : process(xuser_CLK, counter)
|
end if;
|
||||||
begin
|
end if;
|
||||||
if rising_edge(xuser_CLK) then
|
end process;
|
||||||
-- sync to user clock domain:
|
|
||||||
event_detected_sync <= event_detected_sync(0) & event_detected(3);
|
-- Process: Counter when configured event has been detected:
|
||||||
|
------------------------------------------------------------
|
||||||
-- counter FSM:
|
lat_meas_proc : process(xuser_CLK, counter)
|
||||||
---------------
|
begin
|
||||||
case state is
|
if rising_edge(xuser_CLK) then
|
||||||
-- counter is armed:
|
-- sync to user clock domain:
|
||||||
when armed =>
|
event_detected_sync <= event_detected_sync(0) & event_detected(3);
|
||||||
counter <= (others => '0');
|
|
||||||
-- start counting when event detected (rising edge):
|
-- counter FSM:
|
||||||
if (event_detected_sync(1) = '0' and event_detected_sync(0) = '1') then
|
---------------
|
||||||
state <= count;
|
case state is
|
||||||
end if;
|
-- counter is armed:
|
||||||
|
when armed =>
|
||||||
-- counting:
|
counter <= (others => '0');
|
||||||
when count =>
|
-- start counting when event detected (rising edge):
|
||||||
-- count only up to 10ms, and stop:
|
if (event_detected_sync(1) = '0' and event_detected_sync(0) = '1') then
|
||||||
if (counter < MAX_COUNT) then
|
state <= count;
|
||||||
counter <= counter + 1;
|
end if;
|
||||||
end if;
|
|
||||||
if (evr_latency_measure_ctrl.counter_arm = '1') then
|
-- counting:
|
||||||
state <= armed;
|
when count =>
|
||||||
end if;
|
-- count only up to 10ms, and stop:
|
||||||
end case;
|
if (counter < MAX_COUNT) then
|
||||||
end if;
|
counter <= counter + 1;
|
||||||
evr_latency_measure_stat.counter_val <= std_logic_vector(counter);
|
end if;
|
||||||
evr_latency_measure_stat.event_detected <= event_detected_sync(event_detected_sync'left);
|
if (evr_latency_measure_ctrl.counter_arm = '1') then
|
||||||
end process;
|
state <= armed;
|
||||||
|
end if;
|
||||||
end block;
|
end case;
|
||||||
|
end if;
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
-- Add delay output
|
evr_latency_measure_stat.counter_val <= std_logic_vector(counter);
|
||||||
-- --------------------------------------------------------------------------
|
end process;
|
||||||
output_delay_block : block
|
|
||||||
signal rst0_s, rst1_s : std_logic; -- double stage sync for reset
|
end block;
|
||||||
signal usr_evt_shaped_s : std_logic_vector(4 downto 0);
|
|
||||||
signal usr_events_adj_s : std_logic_vector(4 downto 0);
|
-- --------------------------------------------------------------------------
|
||||||
signal usr_events_concat_s : std_logic_vector(4 downto 0);
|
-- Add delay output
|
||||||
signal mmcm_locked : std_logic;
|
-- --------------------------------------------------------------------------
|
||||||
signal rxpll_locked : std_logic;
|
output_delay_block : block
|
||||||
signal evr_rst_in : std_logic;
|
--signal rst0_s, rst1_s : std_logic; -- double stage sync for reset
|
||||||
|
signal usr_evt_shaped_s : std_logic_vector(4 downto 0);
|
||||||
begin
|
signal usr_events_adj_s : std_logic_vector(4 downto 0);
|
||||||
|
signal usr_events_concat_s : std_logic_vector(4 downto 0);
|
||||||
rxpll_locked <= mgt_status(1);
|
|
||||||
mmcm_locked <= mgt_status(2);
|
begin
|
||||||
evr_rst_in <= xuser_RESET or (not rxpll_locked) or (not mmcm_locked);
|
|
||||||
|
evr_rst_s <= mgt_status(15); -- RXLOSSOFSYNC
|
||||||
--*** double stage sync for reset ***--
|
usr_events_concat_s <= usr_events_s & sos_event_s;
|
||||||
proc_rst : process(clk_evr)
|
|
||||||
begin
|
gene_adj_out : for i in 0 to 4 generate
|
||||||
if rising_edge(clk_evr) then
|
|
||||||
rst0_s <= evr_rst_in;
|
--*** Adjust pulse length in clk cycles EVENT 0,1,2,3 ***
|
||||||
rst1_s <= rst0_s;
|
inst_pulslength_evt0 : entity work.psi_common_pulse_shaper_cfg
|
||||||
end if;
|
generic map(HoldIn_g => false,
|
||||||
end process;
|
hold_off_ena_g => false,
|
||||||
|
max_hold_off_g => 10,
|
||||||
evr_rst_s <= rst1_s;
|
max_duration_g => MaxDuration_c,
|
||||||
|
Rst_Pol_g => '1')
|
||||||
usr_events_concat_s <= usr_events_s & sos_event_s;
|
port map(clk_i => clk_evr,
|
||||||
|
rst_i => evr_rst_s,
|
||||||
gene_adj_out : for i in 0 to 4 generate
|
width_i => usr_event_width_s(i),
|
||||||
|
hold_i => (others => '0'),
|
||||||
--*** Adjust pulse length in clk cycles EVENT 0,1,2,3 ***
|
dat_i => usr_events_concat_s(i),
|
||||||
inst_pulslength_evt0 : entity work.psi_common_pulse_shaper_cfg
|
dat_o => usr_evt_shaped_s(i));
|
||||||
generic map(HoldIn_g => false,
|
|
||||||
HoldOffEna_g => false,
|
--*** delay adjust EVENT 0,1,2,3***
|
||||||
MaxHoldOff_g => 10,
|
inst_adjdelay_evt0 : entity work.psi_common_delay_cfg
|
||||||
MaxDuration_g => MaxDuration_c,
|
generic map(width_g => 1,
|
||||||
RstPol_g => '1')
|
max_delay_g => MaxDelay_c,
|
||||||
port map(clk_i => clk_evr,
|
rst_pol_g => '1',
|
||||||
rst_i => rst1_s,
|
ram_behavior_g => "RBW",
|
||||||
width_i => usr_event_width_s(i),
|
hold_g => True)
|
||||||
hold_i => (others => '0'),
|
port map(clk_i => clk_evr,
|
||||||
dat_i => usr_events_concat_s(i),
|
rst_i => evr_rst_s,
|
||||||
dat_o => usr_evt_shaped_s(i));
|
dat_i(0) => usr_evt_shaped_s(i),
|
||||||
|
vld_i => '1',
|
||||||
--*** delay adjust EVENT 0,1,2,3***
|
del_i => usr_event_delay_s(i),
|
||||||
inst_adjdelay_evt0 : entity work.psi_common_delay_cfg
|
dat_o(0) => usr_events_adj_s(i));
|
||||||
generic map(Width_g => 1,
|
end generate;
|
||||||
MaxDelay_g => MaxDelay_c,
|
|
||||||
RStPol_g => '1',
|
usr_events_adj_o <= usr_events_adj_s(4 downto 1);
|
||||||
RamBehavior_g => "RBW",
|
sos_events_adj_o <= usr_events_adj_s(0);
|
||||||
Hold_g => True)
|
end block;
|
||||||
port map( clk_i => clk_evr,
|
-- --------------------------------------------------------------------------
|
||||||
rst_i => rst1_s,
|
-- port mapping
|
||||||
dat_i(0) => usr_evt_shaped_s(i),
|
-- --------------------------------------------------------------------------
|
||||||
str_i => '1',
|
clk_evr_o <= clk_evr;
|
||||||
del_i => usr_event_delay_s(i),
|
mgt_status_o <= mgt_status;
|
||||||
dat_o(0) => usr_events_adj_s(i));
|
debug <= debug_data;
|
||||||
end generate;
|
|
||||||
|
end rtl;
|
||||||
usr_events_adj_o <= usr_events_adj_s(4 downto 1);
|
-- ----------------------------------------------------------------------------
|
||||||
sos_events_adj_o <= usr_events_adj_s(0);
|
-- ////////////////////////////////////////////////////////////////////////////
|
||||||
end block;
|
-- ----------------------------------------------------------------------------
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
-- port mapping
|
|
||||||
-- --------------------------------------------------------------------------
|
|
||||||
clk_evr_o <= clk_evr;
|
|
||||||
mgt_status_o <= mgt_status;
|
|
||||||
debug <= debug_data;
|
|
||||||
|
|
||||||
end rtl;
|
|
||||||
-- ----------------------------------------------------------------------------
|
|
||||||
-- ////////////////////////////////////////////////////////////////////////////
|
|
||||||
-- ----------------------------------------------------------------------------
|
|
||||||
|
@ -1,382 +1,403 @@
|
|||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Paul Scherrer Institute (PSI)
|
-- Paul Scherrer Institute (PSI)
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Unit : evr320_tmem.vhd
|
-- Unit : evr320_tmem.vhd
|
||||||
-- Author : Patric Bucher, Benoit Stef
|
-- Author : Patric Bucher, Benoit Stef
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Copyright (c) PSI, Section DSV
|
-- Copyright (c) PSI, Section DSV
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Comment : TMEM address decoding for register and memory access to evr320.
|
-- Comment : TMEM address decoding for register and memory access to evr320.
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
library ieee;
|
library ieee;
|
||||||
use ieee.std_logic_1164.all;
|
use ieee.std_logic_1164.all;
|
||||||
use ieee.numeric_std.all;
|
use ieee.numeric_std.all;
|
||||||
use ieee.math_real.all;
|
use ieee.math_real.all;
|
||||||
|
|
||||||
library tosca2;
|
library tosca2;
|
||||||
use tosca2.tosca2_glb_pkg.all;
|
use tosca2.tosca2_glb_pkg.all;
|
||||||
|
|
||||||
use work.evr320_pkg.all;
|
use work.evr320_pkg.all;
|
||||||
|
|
||||||
entity evr320_tmem is
|
entity evr320_tmem is
|
||||||
port(
|
port(
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
-- TOSCA2 TMEM Interface (xuser clock domain, 100-250MHz)
|
-- TOSCA2 TMEM Interface (xuser clock domain, 100-250MHz)
|
||||||
-- ------------------------------------------------------------------------
|
-- ------------------------------------------------------------------------
|
||||||
xuser_CLK : in std_logic;
|
xuser_CLK : in std_logic;
|
||||||
xuser_RESET : in std_logic;
|
xuser_RESET : in std_logic;
|
||||||
xuser_TMEM_ENA : in std_logic;
|
xuser_TMEM_ENA : in std_logic;
|
||||||
xuser_TMEM_WE : in std_logic_vector( 7 downto 0);
|
xuser_TMEM_WE : in std_logic_vector( 7 downto 0);
|
||||||
xuser_TMEM_ADD : in std_logic_vector(13 downto 3);
|
xuser_TMEM_ADD : in std_logic_vector(13 downto 3);
|
||||||
xuser_TMEM_DATW : in std_logic_vector(63 downto 0);
|
xuser_TMEM_DATW : in std_logic_vector(63 downto 0);
|
||||||
xuser_TMEM_DATR : out std_logic_vector(63 downto 0);
|
xuser_TMEM_DATR : out std_logic_vector(63 downto 0);
|
||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
-- EVR320 Memory/Parameter Interface
|
-- EVR320 Memory/Parameter Interface
|
||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
evr_params_o : out typ_evr320_params;
|
evr_params_o : out typ_evr320_params;
|
||||||
evr_frequency_i : in std_logic_vector(31 downto 0);
|
evr_frequency_i : in std_logic_vector(31 downto 0);
|
||||||
evr_evt_rec_status_i : in typ_evt_rec_status;
|
evr_evt_rec_status_i : in typ_evt_rec_status;
|
||||||
evr_evt_rec_control_o : out typ_evt_rec_ctrl;
|
evr_evt_rec_control_o : out typ_evt_rec_ctrl;
|
||||||
evr_latency_measure_stat_i : in typ_rec_latency_measure_stat;
|
evr_latency_measure_stat_i : in typ_rec_latency_measure_stat;
|
||||||
evr_latency_measure_ctrl_o : out typ_rec_latency_measure_ctrl;
|
evr_latency_measure_ctrl_o : out typ_rec_latency_measure_ctrl;
|
||||||
mgt_status_i : in std_logic_vector(31 downto 0) := (others=>'0');
|
mgt_status_i : in std_logic_vector(31 downto 0);
|
||||||
mgt_reset_o : out std_logic;
|
mgt_reset_o : out std_logic;
|
||||||
mem_clk_o : out std_logic;
|
mem_clk_o : out std_logic;
|
||||||
mem_addr_o : out std_logic_vector(10 downto 0);
|
mem_addr_o : out std_logic_vector(10 downto 0);
|
||||||
mem_data_i : in std_logic_vector(63 downto 0);
|
mem_data_i : in std_logic_vector(63 downto 0);
|
||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
-- EVR320 pulse output paremters
|
-- EVR320 pulse output paremters
|
||||||
---------------------------------------------------------------------------
|
---------------------------------------------------------------------------
|
||||||
evr_clk_i : in std_logic;
|
evr_clk_i : in std_logic;
|
||||||
evr_rst_i : in std_logic;
|
evr_rst_i : in std_logic;
|
||||||
evr_pulse_delay_o : out typ_arr_delay;
|
evr_pulse_delay_o : out typ_arr_delay;
|
||||||
evr_pulse_width_o : out typ_arr_width
|
evr_pulse_width_o : out typ_arr_width
|
||||||
);
|
);
|
||||||
end evr320_tmem;
|
end evr320_tmem;
|
||||||
|
|
||||||
|
|
||||||
architecture rtl of evr320_tmem is
|
architecture rtl of evr320_tmem is
|
||||||
|
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
-- Constants
|
-- Constants
|
||||||
-- ---------------------------------------------------------------------------
|
-- ---------------------------------------------------------------------------
|
||||||
constant reserved : std_logic_vector(63 downto 0) := X"0000_0000_0000_0000";
|
constant reserved : std_logic_vector(63 downto 0) := X"0000_0000_0000_0000";
|
||||||
constant c_LOW : std_logic_vector(63 downto 0) := X"0000_0000_0000_0000";
|
constant c_LOW : std_logic_vector(63 downto 0) := X"0000_0000_0000_0000";
|
||||||
constant NUM_REG64 : integer := 16;
|
constant NUM_REG64 : integer := 16;
|
||||||
constant TMEM_ADDR_LSB : integer := 3; -- 64 bit
|
constant TMEM_ADDR_LSB : integer := 3; -- 64 bit
|
||||||
constant REG_ADDR_WIDTH : integer := integer(ceil(log2(real(NUM_REG64)))) + TMEM_ADDR_LSB;
|
constant REG_ADDR_WIDTH : integer := integer(ceil(log2(real(NUM_REG64)))) + TMEM_ADDR_LSB;
|
||||||
constant REG_ADDR_MSB : integer := REG_ADDR_WIDTH - 1;
|
constant REG_ADDR_MSB : integer := REG_ADDR_WIDTH - 1;
|
||||||
constant MEM_ADDR_START : std_logic_vector(7 downto 0) := X"10";
|
constant MEM_ADDR_START : std_logic_vector(7 downto 0) := X"10";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-- --------------------------------------------------------------------------
|
-- --------------------------------------------------------------------------
|
||||||
-- Signal definitions
|
-- Signal definitions
|
||||||
-- --------------------------------------------------------------------------
|
-- --------------------------------------------------------------------------
|
||||||
-- xuser tmem signals
|
-- xuser tmem signals
|
||||||
signal xuser_TMEM_WE_reg : std_logic_vector( 7 downto 0) := (others => '0');
|
signal xuser_TMEM_WE_reg : std_logic_vector( 7 downto 0) := (others => '0');
|
||||||
signal xuser_TMEM_ENA_reg : std_logic := '0';
|
signal xuser_TMEM_ENA_reg : std_logic := '0';
|
||||||
signal xuser_TMEM_ADD_reg : std_logic_vector(13 downto 3) := (others => '0');
|
signal xuser_TMEM_ADD_reg : std_logic_vector(13 downto 3) := (others => '0');
|
||||||
signal xuser_TMEM_DATW_reg : std_logic_vector(63 downto 0) := (others => '0');
|
signal xuser_TMEM_DATW_reg : std_logic_vector(63 downto 0) := (others => '0');
|
||||||
|
|
||||||
-- evr params
|
-- evr params
|
||||||
signal mgt_status_evr : std_logic_vector(15 downto 0) := (others => '0');
|
signal mgt_status_evr : std_logic_vector(15 downto 0) := (others => '0');
|
||||||
signal mgt_status_evr_sync : std_logic_vector(15 downto 0) := (others => '0');
|
signal mgt_status_evr_sync : std_logic_vector(15 downto 0) := (others => '0');
|
||||||
signal mgt_reset : std_logic := '0';
|
signal mgt_reset : std_logic := '0';
|
||||||
signal event_enable : std_logic_vector( 3 downto 0) := (others => '0');
|
signal event_enable : std_logic_vector( 3 downto 0) := (others => '0');
|
||||||
signal event_numbers : typ_arr8(3 downto 0) := (others => (others => '0'));
|
signal event_numbers : typ_arr8(3 downto 0) := (others => (others => '0'));
|
||||||
signal event_numbers_concat : std_logic_vector(31 downto 0);
|
signal event_numbers_concat : std_logic_vector(31 downto 0);
|
||||||
signal cs_min_cnt : std_logic_vector(31 downto 0) := c_CHECKSUM_MIN_EVT;
|
signal cs_min_cnt : std_logic_vector(31 downto 0) := c_CHECKSUM_MIN_EVT;
|
||||||
signal cs_min_time : std_logic_vector(31 downto 0) := c_CHECKSUM_MIN_TIME;
|
signal cs_min_time : std_logic_vector(31 downto 0) := c_CHECKSUM_MIN_TIME;
|
||||||
signal evr_frequency_sync : std_logic_vector(31 downto 0) := (others => '0');
|
signal evr_frequency_sync : std_logic_vector(31 downto 0) := (others => '0');
|
||||||
signal evr_frequency : std_logic_vector(31 downto 0) := (others => '0');
|
signal evr_frequency : std_logic_vector(31 downto 0) := (others => '0');
|
||||||
|
|
||||||
-- event recorder
|
-- event recorder
|
||||||
signal er_status : typ_evt_rec_status := c_INIT_EVT_REC_STATUS;
|
signal er_status : typ_evt_rec_status := c_INIT_EVT_REC_STATUS;
|
||||||
signal er_status_sync : typ_evt_rec_status := c_INIT_EVT_REC_STATUS;
|
signal er_status_sync : typ_evt_rec_status := c_INIT_EVT_REC_STATUS;
|
||||||
signal er_event_enable : std_logic := '0';
|
signal er_event_enable : std_logic := '0';
|
||||||
signal er_event_number : std_logic_vector( 7 downto 0) := c_SOS_EVENT_DEFAULT;
|
signal er_event_number : std_logic_vector( 7 downto 0) := c_SOS_EVENT_DEFAULT;
|
||||||
signal er_data_ack : std_logic_vector( 3 downto 0) := (others => '0');
|
signal er_data_ack : std_logic_vector( 3 downto 0) := (others => '0');
|
||||||
signal er_error_ack : std_logic_vector( 3 downto 0) := (others => '0');
|
signal er_error_ack : std_logic_vector( 3 downto 0) := (others => '0');
|
||||||
signal er_handshake_status : std_logic_vector(31 downto 0) := (others => '0');
|
signal er_handshake_status : std_logic_vector(31 downto 0) := (others => '0');
|
||||||
signal er_control_concat : std_logic_vector(31 downto 0) := (others => '0');
|
signal er_control_concat : std_logic_vector(31 downto 0) := (others => '0');
|
||||||
|
|
||||||
-- latency measurement
|
-- latency measurement
|
||||||
signal lat_counter_arm : std_logic := '0';
|
signal lat_counter_arm : std_logic := '0';
|
||||||
signal lat_event_nr : std_logic_vector(7 downto 0) := c_SOS_EVENT_DEFAULT;
|
signal lat_event_nr : std_logic_vector(7 downto 0) := x"26"; -- default SOS event
|
||||||
signal lat_counter_val : std_logic_vector(31 downto 0) := (others=>'0');
|
signal lat_counter_val : std_logic_vector(31 downto 0) := (others=>'0');
|
||||||
signal lat_event_detected : std_logic_vector(7 downto 0);
|
|
||||||
signal lat_arm : std_logic := '0';
|
-- signal evr_force : std_logic_vector(3 downto 0) := (others => '0');
|
||||||
signal lat_arm_edge : std_logic_vector(1 downto 0) := (others=>'0');
|
-- signal evr_force_rd : std_logic_vector(3 downto 0) := (others => '0'); -- readback
|
||||||
|
-- signal evr_force_pulse : typ_arr4(3 downto 0) := (others => (others => '0'));
|
||||||
-- event pulse config
|
|
||||||
signal evr_puls_width_cfg_s : typ_arr_width :=(others => UsrEventWidthDefault_c);
|
-- event pulse config
|
||||||
signal evr_puls_delay_cfg_s : typ_arr_delay :=(others => (others => '0'));
|
|
||||||
|
signal evr_puls_width_cfg_s : typ_arr_width :=((others=>(others=>'0')));
|
||||||
-- ----------------------------------------------------------------------------
|
signal evr_puls_delay_cfg_s : typ_arr_delay :=((others=>(others=>'0')));
|
||||||
-- ----------------------------------------------------------------------------
|
|
||||||
-- //////////////////// Main Body /////////////////////////
|
-- ----------------------------------------------------------------------------
|
||||||
-- ----------------------------------------------------------------------------
|
-- ----------------------------------------------------------------------------
|
||||||
-- ----------------------------------------------------------------------------
|
-- //////////////////// Main Body /////////////////////////
|
||||||
begin
|
-- ----------------------------------------------------------------------------
|
||||||
|
-- ----------------------------------------------------------------------------
|
||||||
-- --------------------------------------------------------------------------
|
begin
|
||||||
-- static signal assignments
|
|
||||||
-- --------------------------------------------------------------------------
|
-- --------------------------------------------------------------------------
|
||||||
event_numbers_concat <= event_numbers(3) & event_numbers(2) & event_numbers(1) & event_numbers(0);
|
-- static signal assignments
|
||||||
er_handshake_status <= X"0000" & bit2byte(er_status.data_error) & bit2byte(er_status.data_valid);
|
-- --------------------------------------------------------------------------
|
||||||
er_control_concat <= X"0000" & er_event_number & bit2byte(er_event_enable);
|
event_numbers_concat <= event_numbers(3) & event_numbers(2) & event_numbers(1) & event_numbers(0);
|
||||||
lat_counter_val <= evr_latency_measure_stat_i.counter_val;
|
er_handshake_status <= X"0000" & bit2byte(er_status.data_error) & bit2byte(er_status.data_valid);
|
||||||
|
er_control_concat <= X"0000" & er_event_number & bit2byte(er_event_enable);
|
||||||
process (xuser_CLK)
|
lat_counter_val <= evr_latency_measure_stat_i.counter_val;
|
||||||
begin
|
|
||||||
if rising_edge(xuser_CLK) then
|
-- --------------------------------------------------------------------------
|
||||||
-- edge detection of latency arm:
|
-- TODO: proper CDC
|
||||||
lat_arm_edge <= lat_arm_edge(0) & lat_arm;
|
-- Synchronisation to xuser_CLK
|
||||||
lat_counter_arm <= lat_arm_edge(0) and not lat_arm_edge(1);
|
-- --------------------------------------------------------------------------
|
||||||
|
prc_sync_xuser: process (xuser_CLK)
|
||||||
|
begin
|
||||||
if (evr_latency_measure_stat_i.event_detected = '1') then
|
if rising_edge(xuser_CLK) then
|
||||||
lat_event_detected <= (others=>'1');
|
---
|
||||||
end if;
|
xuser_TMEM_WE_reg <= xuser_TMEM_WE;
|
||||||
if (lat_counter_arm = '1') then
|
xuser_TMEM_ENA_reg <= xuser_TMEM_ENA;
|
||||||
lat_event_detected <= (others=>'0');
|
xuser_TMEM_DATW_reg <= xuser_TMEM_DATW;
|
||||||
end if;
|
xuser_TMEM_ADD_reg <= xuser_TMEM_ADD;
|
||||||
end if;
|
---
|
||||||
end process;
|
mgt_status_evr_sync <= "000000" & mgt_status_i(c_RXRESETDONE) & mgt_status_i(c_RXLOSSOFSYNC) & "000000" & mgt_status_i(c_RXRESETDONE) & mgt_status_i(c_RXPLLLKDET);
|
||||||
|
mgt_status_evr <= mgt_status_evr_sync;
|
||||||
-- --------------------------------------------------------------------------
|
---
|
||||||
-- Synchronisation to xuser_CLK
|
er_status_sync <= evr_evt_rec_status_i;
|
||||||
-- --------------------------------------------------------------------------
|
er_status <= er_status_sync;
|
||||||
prc_sync_xuser: process (xuser_CLK)
|
---
|
||||||
begin
|
evr_frequency_sync <= evr_frequency_i;
|
||||||
if rising_edge(xuser_CLK) then
|
evr_frequency <= evr_frequency_sync;
|
||||||
---
|
---
|
||||||
xuser_TMEM_WE_reg <= xuser_TMEM_WE;
|
end if;
|
||||||
xuser_TMEM_ENA_reg <= xuser_TMEM_ENA;
|
end process;
|
||||||
xuser_TMEM_DATW_reg <= xuser_TMEM_DATW;
|
|
||||||
xuser_TMEM_ADD_reg <= xuser_TMEM_ADD;
|
-- --------------------------------------------------------------------------
|
||||||
---
|
-- Read operation
|
||||||
mgt_status_evr_sync <= "000000" & mgt_status_i(c_RXRESETDONE) & mgt_status_i(c_RXLOSSOFSYNC) & "000000" & mgt_status_i(c_RXRESETDONE) & mgt_status_i(c_RXPLLLKDET);
|
-- --------------------------------------------------------------------------
|
||||||
mgt_status_evr <= mgt_status_evr_sync;
|
read_tmem_evr: process(xuser_CLK)
|
||||||
---
|
begin
|
||||||
er_status_sync <= evr_evt_rec_status_i;
|
if (rising_edge(xuser_CLK)) then
|
||||||
er_status <= er_status_sync;
|
lat_counter_arm <= '0';
|
||||||
---
|
if (xuser_TMEM_ENA_reg = '1') then
|
||||||
evr_frequency_sync <= evr_frequency_i;
|
if (xuser_TMEM_ADD_reg(13 downto REG_ADDR_WIDTH) = c_LOW(13 downto REG_ADDR_WIDTH)) then
|
||||||
evr_frequency <= evr_frequency_sync;
|
case xuser_TMEM_ADD_reg(REG_ADDR_MSB downto TMEM_ADDR_LSB) is
|
||||||
---
|
when X"0" => xuser_TMEM_DATR <= event_numbers_concat & X"0000" & mgt_status_evr; -- 64bit / ByteAddr 000
|
||||||
end if;
|
when X"1" => xuser_TMEM_DATR <= reserved(63 downto 32) & X"0000_00" & bit2byte(mgt_reset); -- 64bit / ByteAddr 008 --> 0x00C = not implemented in ifc1210
|
||||||
end process;
|
when X"2" => xuser_TMEM_DATR <= reserved(63 downto 32) & bit2byte(event_enable); -- 64bit / ByteAddr 010 --> 0x014 = Bit0 SW Trigger Event 0, Bit8 SW Trigger Event 1, ... evr_force
|
||||||
|
when X"3" => xuser_TMEM_DATR <= evr_frequency & reserved(31 downto 0); -- 64bit / ByteAddr 018 --> 0x018 = Implementation Options + c_EVR_Location_vec
|
||||||
-- --------------------------------------------------------------------------
|
when X"4" => xuser_TMEM_DATR <= cs_min_time & cs_min_cnt; -- 64bit / ByteAddr 020
|
||||||
-- Read operation
|
when X"5" => xuser_TMEM_DATR <= reserved(63 downto 0); -- 64bit / ByteAddr 028
|
||||||
-- --------------------------------------------------------------------------
|
when X"6" => xuser_TMEM_DATR <= lat_counter_val & X"000000" & lat_event_nr; -- 64bit / ByteAddr 030
|
||||||
blk_tmemrd : block
|
when X"7" => xuser_TMEM_DATR <= reserved(63 downto 32) & lat_counter_val; lat_counter_arm <= '1'; -- 64bit / ByteAddr 038
|
||||||
|
when X"8" => xuser_TMEM_DATR <= er_handshake_status & er_control_concat; -- 64bit / ByteAddr 040
|
||||||
begin
|
when X"9" => xuser_TMEM_DATR <= reserved(63 downto 32) & er_status.usr_events_counter; -- 64bit / ByteAddr 048
|
||||||
read_tmem_evr: process(xuser_CLK)
|
when X"A" => xuser_TMEM_DATR <= evr_puls_delay_cfg_s(4) & evr_puls_delay_cfg_s(3) & evr_puls_delay_cfg_s(2) & evr_puls_delay_cfg_s(1) ; -- 64bit / ByteAddr 050
|
||||||
begin
|
when X"B" => xuser_TMEM_DATR <= evr_puls_width_cfg_s(4) & evr_puls_width_cfg_s(3) & evr_puls_width_cfg_s(2) & evr_puls_width_cfg_s(1) ; --64 bit / ByteAddr 054
|
||||||
if (rising_edge(xuser_CLK)) then
|
when X"C" => xuser_TMEM_DATR <= reserved(63 downto 32) & evr_puls_width_cfg_s(0) & evr_puls_delay_cfg_s(0); -- 64bit / ByteAddr 058
|
||||||
if (xuser_TMEM_ENA_reg = '1') then
|
when others => xuser_TMEM_DATR <= (others => '0');
|
||||||
if (xuser_TMEM_ADD_reg(13 downto REG_ADDR_WIDTH) = c_LOW(13 downto REG_ADDR_WIDTH)) then
|
end case;
|
||||||
case xuser_TMEM_ADD_reg(REG_ADDR_MSB downto TMEM_ADDR_LSB) is
|
else --> 0x0080-0x4000
|
||||||
when X"0" => xuser_TMEM_DATR <= event_numbers_concat & X"0000" & mgt_status_evr; -- 64bit / ByteAddr 000
|
xuser_TMEM_DATR <= mem_data_i;
|
||||||
when X"1" => xuser_TMEM_DATR <= reserved(63 downto 32) & X"0000_00" & bit2byte(mgt_reset); -- 64bit / ByteAddr 008 --> 0x00C = not implemented in ifc1210
|
end if;
|
||||||
when X"2" => xuser_TMEM_DATR <= reserved(63 downto 32) & bit2byte(event_enable); -- 64bit / ByteAddr 010 --> 0x014 = Bit0 SW Trigger Event 0, Bit8 SW Trigger Event 1, ...
|
end if;
|
||||||
when X"3" => xuser_TMEM_DATR <= evr_frequency & reserved(31 downto 0); -- 64bit / ByteAddr 018 --> 0x018 = Implementation Options + c_EVR_Location_vec
|
end if;
|
||||||
when X"4" => xuser_TMEM_DATR <= cs_min_time & cs_min_cnt; -- 64bit / ByteAddr 020
|
end process;
|
||||||
when X"5" => xuser_TMEM_DATR <= reserved(63 downto 0); -- 64bit / ByteAddr 028
|
|
||||||
when X"6" => xuser_TMEM_DATR <= lat_counter_val & x"00" & lat_event_detected & X"00" & lat_event_nr; -- 64bit / ByteAddr 030
|
|
||||||
when X"7" => xuser_TMEM_DATR <= reserved(63 downto 32) & reserved(31 downto 0); -- 64bit / ByteAddr 038
|
-- --------------------------------------------------------------------------
|
||||||
when X"8" => xuser_TMEM_DATR <= er_handshake_status & er_control_concat; -- 64bit / ByteAddr 040
|
-- Write operation - Byte control
|
||||||
when X"9" => xuser_TMEM_DATR <= reserved(63 downto 32) & er_status.usr_events_counter; -- 64bit / ByteAddr 048
|
-- --------------------------------------------------------------------------
|
||||||
when X"A" => xuser_TMEM_DATR <= evr_puls_delay_cfg_s(4) & evr_puls_delay_cfg_s(3) & evr_puls_delay_cfg_s(2) & evr_puls_delay_cfg_s(1) ; -- 64bit / ByteAddr 050
|
write_tmem_evr: process(xuser_CLK)
|
||||||
when X"B" => xuser_TMEM_DATR <= evr_puls_width_cfg_s(4) & evr_puls_width_cfg_s(3) & evr_puls_width_cfg_s(2) & evr_puls_width_cfg_s(1) ; --64 bit / ByteAddr 054
|
begin
|
||||||
when X"C" => xuser_TMEM_DATR <= reserved(63 downto 32) & evr_puls_width_cfg_s(0) & evr_puls_delay_cfg_s(0); -- 64bit / ByteAddr 058
|
if rising_edge(xuser_CLK) then
|
||||||
when others => xuser_TMEM_DATR <= (others => '0');
|
|
||||||
end case;
|
-- default assignments
|
||||||
else --> 0x0080-0x4000
|
er_data_ack <= er_data_ack(2 downto 0) & '0';
|
||||||
xuser_TMEM_DATR <= mem_data_i;
|
er_error_ack <= er_error_ack(2 downto 0) & '0';
|
||||||
end if;
|
|
||||||
end if;
|
|
||||||
end if;
|
if (xuser_TMEM_ENA_reg = '1' and xuser_TMEM_ADD_reg(13 downto REG_ADDR_WIDTH) = c_LOW(13 downto REG_ADDR_WIDTH)) then
|
||||||
end process;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"0" then --ByteAddr 000
|
||||||
end block;
|
-- if xuser_TMEM_WE_reg(0) = '1' then -read only- <= xuser_TMEM_DATW_reg( 7 downto 0); end if;
|
||||||
|
-- if xuser_TMEM_WE_reg(1) = '1' then -read only- <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
||||||
-- --------------------------------------------------------------------------
|
-- if xuser_TMEM_WE_reg(2) = '1' then -read only- <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
||||||
-- Write operation - Byte control
|
-- if xuser_TMEM_WE_reg(3) = '1' then -read only- <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
||||||
-- --------------------------------------------------------------------------
|
if xuser_TMEM_WE_reg(4) = '1' then event_numbers(0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
||||||
write_tmem_evr: process(xuser_CLK)
|
if xuser_TMEM_WE_reg(5) = '1' then event_numbers(1) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
||||||
begin
|
if xuser_TMEM_WE_reg(6) = '1' then event_numbers(2) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
||||||
if rising_edge(xuser_CLK) then
|
if xuser_TMEM_WE_reg(7) = '1' then event_numbers(3) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
||||||
|
end if;
|
||||||
-- default assignments
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
er_data_ack <= er_data_ack(2 downto 0) & '0';
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"1" then --ByteAddr 008
|
||||||
er_error_ack <= er_error_ack(2 downto 0) & '0';
|
if xuser_TMEM_WE_reg(0) = '1' then mgt_reset <= xuser_TMEM_DATW_reg(0); end if;
|
||||||
lat_arm <= '0';
|
-- if xuser_TMEM_WE_reg(1) = '1' then -reserved- <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
||||||
|
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
||||||
|
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
||||||
if (xuser_TMEM_ENA_reg = '1' and xuser_TMEM_ADD_reg(13 downto REG_ADDR_WIDTH) = c_LOW(13 downto REG_ADDR_WIDTH)) then
|
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"0" then --ByteAddr 000
|
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
||||||
-- if xuser_TMEM_WE_reg(0) = '1' then -read only- <= xuser_TMEM_DATW_reg( 7 downto 0); end if;
|
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
||||||
-- if xuser_TMEM_WE_reg(1) = '1' then -read only- <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
end if;
|
||||||
-- if xuser_TMEM_WE_reg(2) = '1' then -read only- <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
-- if xuser_TMEM_WE_reg(3) = '1' then -read only- <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"2" then --ByteAddr 010
|
||||||
if xuser_TMEM_WE_reg(4) = '1' then event_numbers(0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
if xuser_TMEM_WE_reg(0) = '1' then event_enable(0) <= xuser_TMEM_DATW_reg( 0); end if;
|
||||||
if xuser_TMEM_WE_reg(5) = '1' then event_numbers(1) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
if xuser_TMEM_WE_reg(1) = '1' then event_enable(1) <= xuser_TMEM_DATW_reg( 8); end if;
|
||||||
if xuser_TMEM_WE_reg(6) = '1' then event_numbers(2) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
if xuser_TMEM_WE_reg(2) = '1' then event_enable(2) <= xuser_TMEM_DATW_reg(16); end if;
|
||||||
if xuser_TMEM_WE_reg(7) = '1' then event_numbers(3) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
if xuser_TMEM_WE_reg(3) = '1' then event_enable(3) <= xuser_TMEM_DATW_reg(24); end if;
|
||||||
end if;
|
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"1" then --ByteAddr 008
|
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
||||||
if xuser_TMEM_WE_reg(0) = '1' then mgt_reset <= xuser_TMEM_DATW_reg(0); end if;
|
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
||||||
-- if xuser_TMEM_WE_reg(1) = '1' then -reserved- <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
end if;
|
||||||
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"4" then --ByteAddr 020
|
||||||
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
if xuser_TMEM_WE_reg(0) = '1' then cs_min_cnt ( 7 downto 0) <= xuser_TMEM_DATW_reg( 7 downto 0); end if;
|
||||||
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
if xuser_TMEM_WE_reg(1) = '1' then cs_min_cnt (15 downto 8) <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
||||||
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
if xuser_TMEM_WE_reg(2) = '1' then cs_min_cnt (23 downto 16) <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
||||||
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
if xuser_TMEM_WE_reg(3) = '1' then cs_min_cnt (31 downto 24) <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
||||||
end if;
|
if xuser_TMEM_WE_reg(4) = '1' then cs_min_time( 7 downto 0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
if xuser_TMEM_WE_reg(5) = '1' then cs_min_time(15 downto 8) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"2" then --ByteAddr 010
|
if xuser_TMEM_WE_reg(6) = '1' then cs_min_time(23 downto 16) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
||||||
if xuser_TMEM_WE_reg(0) = '1' then event_enable(0) <= xuser_TMEM_DATW_reg( 0); end if;
|
if xuser_TMEM_WE_reg(7) = '1' then cs_min_time(31 downto 24) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
||||||
if xuser_TMEM_WE_reg(1) = '1' then event_enable(1) <= xuser_TMEM_DATW_reg( 8); end if;
|
end if;
|
||||||
if xuser_TMEM_WE_reg(2) = '1' then event_enable(2) <= xuser_TMEM_DATW_reg(16); end if;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
if xuser_TMEM_WE_reg(3) = '1' then event_enable(3) <= xuser_TMEM_DATW_reg(24); end if;
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"6" then --ByteAddr 030 Latency Measurement
|
||||||
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
if xuser_TMEM_WE_reg(0) = '1' then lat_event_nr ( 7 downto 0) <= xuser_TMEM_DATW_reg( 7 downto 0); end if;
|
||||||
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
-- if xuser_TMEM_WE_reg(1) = '1' then -reserved- (15 downto 8) <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
||||||
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- (23 downto 16) <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
||||||
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- (31 downto 24) <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
||||||
end if;
|
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- ( 7 downto 0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- (15 downto 8) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"4" then --ByteAddr 020
|
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- (23 downto 16) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
||||||
if xuser_TMEM_WE_reg(0) = '1' then cs_min_cnt ( 7 downto 0) <= xuser_TMEM_DATW_reg( 7 downto 0); end if;
|
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- (31 downto 24) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
||||||
if xuser_TMEM_WE_reg(1) = '1' then cs_min_cnt (15 downto 8) <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
end if;
|
||||||
if xuser_TMEM_WE_reg(2) = '1' then cs_min_cnt (23 downto 16) <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
if xuser_TMEM_WE_reg(3) = '1' then cs_min_cnt (31 downto 24) <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"8" then --ByteAddr 040
|
||||||
if xuser_TMEM_WE_reg(4) = '1' then cs_min_time( 7 downto 0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
if xuser_TMEM_WE_reg(0) = '1' then er_event_enable <= xuser_TMEM_DATW_reg(0); end if;
|
||||||
if xuser_TMEM_WE_reg(5) = '1' then cs_min_time(15 downto 8) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
if xuser_TMEM_WE_reg(1) = '1' then er_event_number <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
||||||
if xuser_TMEM_WE_reg(6) = '1' then cs_min_time(23 downto 16) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
||||||
if xuser_TMEM_WE_reg(7) = '1' then cs_min_time(31 downto 24) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
||||||
end if;
|
-- if xuser_TMEM_WE_reg(4) = '1' then -read only- <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
-- if xuser_TMEM_WE_reg(5) = '1' then -read only- <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"6" then --ByteAddr 030 Latency Measurement
|
if xuser_TMEM_WE_reg(6) = '1' and xuser_TMEM_DATW_reg(48) = '1' then er_data_ack <= (others => '1'); end if;
|
||||||
if xuser_TMEM_WE_reg(0) = '1' then lat_event_nr ( 7 downto 0) <= xuser_TMEM_DATW_reg( 7 downto 0); end if;
|
if xuser_TMEM_WE_reg(7) = '1' and xuser_TMEM_DATW_reg(56) = '1' then er_error_ack <= (others => '1'); end if;
|
||||||
-- if xuser_TMEM_WE_reg(1) = '1' then -reserved- (15 downto 8) <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
end if;
|
||||||
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- (23 downto 16) <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- (31 downto 24) <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"A" then --ByteAddr 050
|
||||||
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- ( 7 downto 0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
if xuser_TMEM_WE_reg(1 downto 0) = "11" then evr_puls_delay_cfg_s(1) <= xuser_TMEM_DATW_reg(15 downto 0); end if; -- usr evt 0 del
|
||||||
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- (15 downto 8) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
if xuser_TMEM_WE_reg(3 downto 2) = "11" then evr_puls_delay_cfg_s(2) <= xuser_TMEM_DATW_reg(31 downto 16); end if; -- usr evt 1 del
|
||||||
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- (23 downto 16) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
if xuser_TMEM_WE_reg(5 downto 4) = "11" then evr_puls_delay_cfg_s(3) <= xuser_TMEM_DATW_reg(47 downto 32); end if; -- usr evt 2 del
|
||||||
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- (31 downto 24) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
if xuser_TMEM_WE_reg(7 downto 6) = "11" then evr_puls_delay_cfg_s(4) <= xuser_TMEM_DATW_reg(63 downto 48); end if; -- usr evt 3 del
|
||||||
end if;
|
end if;
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"7" then --ByteAddr 038 Latency Measurement
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"B" then --ByteAddr 058
|
||||||
if xuser_TMEM_WE_reg(0) = '1' then lat_arm <= xuser_TMEM_DATW_reg(0); end if;
|
if xuser_TMEM_WE_reg(1 downto 0) = "11" then evr_puls_width_cfg_s(1) <= xuser_TMEM_DATW_reg(15 downto 0); end if; -- usr evt 0 width
|
||||||
-- if xuser_TMEM_WE_reg(1) = '1' then -reserved- (15 downto 8) <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
if xuser_TMEM_WE_reg(3 downto 2) = "11" then evr_puls_width_cfg_s(2) <= xuser_TMEM_DATW_reg(31 downto 16); end if; -- usr evt 1 width
|
||||||
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- (23 downto 16) <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
if xuser_TMEM_WE_reg(5 downto 4) = "11" then evr_puls_width_cfg_s(3) <= xuser_TMEM_DATW_reg(47 downto 32); end if; -- usr evt 2 width
|
||||||
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- (31 downto 24) <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
if xuser_TMEM_WE_reg(7 downto 6) = "11" then evr_puls_width_cfg_s(4) <= xuser_TMEM_DATW_reg(63 downto 48); end if; -- usr evt 3 width
|
||||||
-- if xuser_TMEM_WE_reg(4) = '1' then -reserved- ( 7 downto 0) <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
end if;
|
||||||
-- if xuser_TMEM_WE_reg(5) = '1' then -reserved- (15 downto 8) <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
-----------------------------------------------------------------------------------------------------------------
|
||||||
-- if xuser_TMEM_WE_reg(6) = '1' then -reserved- (23 downto 16) <= xuser_TMEM_DATW_reg(55 downto 48); end if;
|
if xuser_TMEM_ADD_reg(6 downto 3) = X"C" then --ByteAddr 060
|
||||||
-- if xuser_TMEM_WE_reg(7) = '1' then -reserved- (31 downto 24) <= xuser_TMEM_DATW_reg(63 downto 56); end if;
|
if xuser_TMEM_WE_reg(1 downto 0) = "11" then evr_puls_delay_cfg_s(0) <= xuser_TMEM_DATW_reg(15 downto 0); end if; -- sos evt del
|
||||||
end if;
|
if xuser_TMEM_WE_reg(3 downto 2) = "11" then evr_puls_width_cfg_s(0) <= xuser_TMEM_DATW_reg(31 downto 16); end if; -- sos evt width
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
end if;
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"8" then --ByteAddr 040
|
end if;
|
||||||
if xuser_TMEM_WE_reg(0) = '1' then er_event_enable <= xuser_TMEM_DATW_reg(0); end if;
|
end if;
|
||||||
if xuser_TMEM_WE_reg(1) = '1' then er_event_number <= xuser_TMEM_DATW_reg(15 downto 8); end if;
|
end process;
|
||||||
-- if xuser_TMEM_WE_reg(2) = '1' then -reserved- <= xuser_TMEM_DATW_reg(23 downto 16); end if;
|
|
||||||
-- if xuser_TMEM_WE_reg(3) = '1' then -reserved- <= xuser_TMEM_DATW_reg(31 downto 24); end if;
|
|
||||||
-- if xuser_TMEM_WE_reg(4) = '1' then -read only- <= xuser_TMEM_DATW_reg(39 downto 32); end if;
|
-- --------------------------------------------------------------------------
|
||||||
-- if xuser_TMEM_WE_reg(5) = '1' then -read only- <= xuser_TMEM_DATW_reg(47 downto 40); end if;
|
-- Port mapping
|
||||||
if xuser_TMEM_WE_reg(6) = '1' and xuser_TMEM_DATW_reg(48) = '1' then er_data_ack <= (others => '1'); end if;
|
-- --------------------------------------------------------------------------
|
||||||
if xuser_TMEM_WE_reg(7) = '1' and xuser_TMEM_DATW_reg(56) = '1' then er_error_ack <= (others => '1'); end if;
|
mem_clk_o <= xuser_CLK;
|
||||||
end if;
|
mem_addr_o <= std_logic_vector(unsigned(xuser_TMEM_ADD) - unsigned(MEM_ADDR_START));
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
--event recorder had to be also added to cdc
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"A" then --ByteAddr 050
|
evr_evt_rec_control_o <= (er_event_number, er_event_enable, er_data_ack(3), er_error_ack(3));
|
||||||
if xuser_TMEM_WE_reg(1 downto 0) = "11" then evr_puls_delay_cfg_s(1) <= xuser_TMEM_DATW_reg(15 downto 0); end if; -- usr evt 0 del
|
mgt_reset_o <= mgt_reset;
|
||||||
if xuser_TMEM_WE_reg(3 downto 2) = "11" then evr_puls_delay_cfg_s(2) <= xuser_TMEM_DATW_reg(31 downto 16); end if; -- usr evt 1 del
|
|
||||||
if xuser_TMEM_WE_reg(5 downto 4) = "11" then evr_puls_delay_cfg_s(3) <= xuser_TMEM_DATW_reg(47 downto 32); end if; -- usr evt 2 del
|
-- --------------------------------------------------------------------------
|
||||||
if xuser_TMEM_WE_reg(7 downto 6) = "11" then evr_puls_delay_cfg_s(4) <= xuser_TMEM_DATW_reg(63 downto 48); end if; -- usr evt 3 del
|
-- add CDC output
|
||||||
end if;
|
-- --------------------------------------------------------------------------
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
block_cdc_evr_puls_param : block
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"B" then --ByteAddr 058
|
signal input_s, output_s : std_logic_vector(10 * 16 - 1 downto 0);
|
||||||
if xuser_TMEM_WE_reg(1 downto 0) = "11" then evr_puls_width_cfg_s(1) <= xuser_TMEM_DATW_reg(15 downto 0); end if; -- usr evt 0 width
|
begin
|
||||||
if xuser_TMEM_WE_reg(3 downto 2) = "11" then evr_puls_width_cfg_s(2) <= xuser_TMEM_DATW_reg(31 downto 16); end if; -- usr evt 1 width
|
-- ------------------------------------------------------------------------
|
||||||
if xuser_TMEM_WE_reg(5 downto 4) = "11" then evr_puls_width_cfg_s(3) <= xuser_TMEM_DATW_reg(47 downto 32); end if; -- usr evt 2 width
|
-- Assemble Input
|
||||||
if xuser_TMEM_WE_reg(7 downto 6) = "11" then evr_puls_width_cfg_s(4) <= xuser_TMEM_DATW_reg(63 downto 48); end if; -- usr evt 3 width
|
-- ------------------------------------------------------------------------
|
||||||
end if;
|
--** pulse delay parameters **
|
||||||
-----------------------------------------------------------------------------------------------------------------
|
input_s(15 downto 0) <= evr_puls_delay_cfg_s(0);
|
||||||
if xuser_TMEM_ADD_reg(6 downto 3) = X"C" then --ByteAddr 060
|
input_s(31 downto 16) <= evr_puls_delay_cfg_s(1);
|
||||||
if xuser_TMEM_WE_reg(1 downto 0) = "11" then evr_puls_delay_cfg_s(0) <= xuser_TMEM_DATW_reg(15 downto 0); end if; -- sos evt del
|
input_s(47 downto 32) <= evr_puls_delay_cfg_s(2);
|
||||||
if xuser_TMEM_WE_reg(3 downto 2) = "11" then evr_puls_width_cfg_s(0) <= xuser_TMEM_DATW_reg(31 downto 16); end if; -- sos evt width
|
input_s(63 downto 48) <= evr_puls_delay_cfg_s(3);
|
||||||
end if;
|
input_s(79 downto 64) <= evr_puls_delay_cfg_s(4);
|
||||||
end if;
|
--** pulse width parameters **
|
||||||
end if;
|
input_s(95 downto 80) <= evr_puls_width_cfg_s(0);
|
||||||
end process;
|
input_s(111 downto 96) <= evr_puls_width_cfg_s(1);
|
||||||
|
input_s(127 downto 112) <= evr_puls_width_cfg_s(2);
|
||||||
|
input_s(143 downto 128) <= evr_puls_width_cfg_s(3);
|
||||||
-- --------------------------------------------------------------------------
|
input_s(159 downto 144) <= evr_puls_width_cfg_s(4);
|
||||||
-- Port mapping
|
|
||||||
-- --------------------------------------------------------------------------
|
-- Instance
|
||||||
mem_clk_o <= xuser_CLK;
|
inst_cdc_fast_stat : entity work.psi_common_status_cc
|
||||||
mem_addr_o <= std_logic_vector(unsigned(xuser_TMEM_ADD) - unsigned(MEM_ADDR_START));
|
generic map(width_g => input_s'length)
|
||||||
evr_params_o <= (event_numbers, event_enable, cs_min_cnt, cs_min_time);
|
port map(a_clk_i => xuser_CLK,
|
||||||
evr_evt_rec_control_o <= (er_event_number, er_event_enable, er_data_ack(3), er_error_ack(3));
|
a_rst_i => xuser_RESET,
|
||||||
mgt_reset_o <= mgt_reset;
|
a_dat_i => input_s,
|
||||||
evr_latency_measure_ctrl_o <= (lat_event_nr, lat_counter_arm);
|
b_clk_i => evr_clk_i,
|
||||||
|
b_rst_i => evr_rst_i,
|
||||||
-- --------------------------------------------------------------------------
|
b_dat_o => output_s);
|
||||||
-- add CDC output
|
-- ------------------------------------------------------------------------
|
||||||
-- --------------------------------------------------------------------------
|
-- Disassemble Output
|
||||||
block_cdc_evr_puls_param : block
|
-- ------------------------------------------------------------------------
|
||||||
signal input_s, output_s : std_logic_vector(10 * 16 - 1 downto 0);
|
--** pulse delay parameters **
|
||||||
begin
|
evr_pulse_delay_o(0) <= output_s(15 downto 0);
|
||||||
-- ------------------------------------------------------------------------
|
evr_pulse_delay_o(1) <= output_s(31 downto 16);
|
||||||
-- Assemble Input
|
evr_pulse_delay_o(2) <= output_s(47 downto 32);
|
||||||
-- ------------------------------------------------------------------------
|
evr_pulse_delay_o(3) <= output_s(63 downto 48);
|
||||||
--** pulse delay parameters **
|
evr_pulse_delay_o(4) <= output_s(79 downto 64);
|
||||||
input_s(15 downto 0) <= evr_puls_delay_cfg_s(0);
|
--** pulse width parameters **
|
||||||
input_s(31 downto 16) <= evr_puls_delay_cfg_s(1);
|
evr_pulse_width_o(0) <= output_s(95 downto 80);
|
||||||
input_s(47 downto 32) <= evr_puls_delay_cfg_s(2);
|
evr_pulse_width_o(1) <= output_s(111 downto 96);
|
||||||
input_s(63 downto 48) <= evr_puls_delay_cfg_s(3);
|
evr_pulse_width_o(2) <= output_s(127 downto 112);
|
||||||
input_s(79 downto 64) <= evr_puls_delay_cfg_s(4);
|
evr_pulse_width_o(3) <= output_s(143 downto 128);
|
||||||
--** pulse width parameters **
|
evr_pulse_width_o(4) <= output_s(159 downto 144);
|
||||||
input_s(95 downto 80) <= evr_puls_width_cfg_s(0);
|
end block;
|
||||||
input_s(111 downto 96) <= evr_puls_width_cfg_s(1);
|
|
||||||
input_s(127 downto 112) <= evr_puls_width_cfg_s(2);
|
block_cdc_evr_code_param : block
|
||||||
input_s(143 downto 128) <= evr_puls_width_cfg_s(3);
|
signal input_s, output_s : std_logic_vector(108 downto 0);
|
||||||
input_s(159 downto 144) <= evr_puls_width_cfg_s(4);
|
begin
|
||||||
|
-- ------------------------------------------------------------------------
|
||||||
-- Instance
|
-- Assemble Input
|
||||||
inst_cdc_fast_stat : entity work.psi_common_status_cc
|
-- ------------------------------------------------------------------------
|
||||||
generic map(DataWidth_g => input_s'length)
|
--** event numbers **
|
||||||
port map(ClkA => xuser_CLK,
|
input_s( 7 downto 0) <= event_numbers(0);
|
||||||
RstInA => xuser_RESET,
|
input_s(15 downto 8) <= event_numbers(1);
|
||||||
DataA => input_s,
|
input_s(23 downto 16) <= event_numbers(2);
|
||||||
ClkB => evr_clk_i,
|
input_s(31 downto 24) <= event_numbers(3);
|
||||||
RstInB => evr_rst_i,
|
--** event pulse enable **
|
||||||
DataB => output_s);
|
input_s(35 downto 32) <= event_enable;
|
||||||
-- ------------------------------------------------------------------------
|
--** time counter **
|
||||||
-- Disassemble Output
|
input_s(67 downto 36) <= cs_min_time;
|
||||||
-- ------------------------------------------------------------------------
|
input_s(99 downto 68) <= cs_min_cnt;
|
||||||
--** pulse delay parameters **
|
--** latency counter **
|
||||||
evr_pulse_delay_o(0) <= output_s(15 downto 0);
|
input_s(100) <= lat_counter_arm;
|
||||||
evr_pulse_delay_o(1) <= output_s(31 downto 16);
|
input_s(108 downto 101) <= lat_event_nr;
|
||||||
evr_pulse_delay_o(2) <= output_s(47 downto 32);
|
|
||||||
evr_pulse_delay_o(3) <= output_s(63 downto 48);
|
-- Instance
|
||||||
evr_pulse_delay_o(4) <= output_s(79 downto 64);
|
inst_cdc_fast_stat : entity work.psi_common_status_cc
|
||||||
--** pulse width parameters **
|
generic map(width_g => input_s'length)
|
||||||
evr_pulse_width_o(0) <= output_s(95 downto 80);
|
port map(a_clk_i => xuser_CLK,
|
||||||
evr_pulse_width_o(1) <= output_s(111 downto 96);
|
a_rst_i => xuser_RESET,
|
||||||
evr_pulse_width_o(2) <= output_s(127 downto 112);
|
a_rst_o => open,
|
||||||
evr_pulse_width_o(3) <= output_s(143 downto 128);
|
a_dat_i => input_s,
|
||||||
evr_pulse_width_o(4) <= output_s(159 downto 144);
|
b_clk_i => evr_clk_i,
|
||||||
end block;
|
b_rst_i => evr_rst_i,
|
||||||
|
b_rst_o => open,
|
||||||
end rtl;
|
b_dat_o => output_s);
|
||||||
|
-- ------------------------------------------------------------------------
|
||||||
|
-- Disassemble Output
|
||||||
|
-- ------------------------------------------------------------------------
|
||||||
|
--** event numbers **
|
||||||
|
evr_params_o.event_numbers(0) <= output_s( 7 downto 0) ;
|
||||||
|
evr_params_o.event_numbers(1) <= output_s(15 downto 8) ;
|
||||||
|
evr_params_o.event_numbers(2) <= output_s(23 downto 16);
|
||||||
|
evr_params_o.event_numbers(3) <= output_s(31 downto 24);
|
||||||
|
--** event pulse enable **
|
||||||
|
evr_params_o.event_enable <= output_s(35 downto 32);
|
||||||
|
--** time counter **
|
||||||
|
evr_params_o.cs_min_time <= output_s(67 downto 36);
|
||||||
|
evr_params_o.cs_min_cnt <= output_s(99 downto 68);
|
||||||
|
--** latency counter **
|
||||||
|
evr_latency_measure_ctrl_o.counter_arm <= output_s(100) ;
|
||||||
|
evr_latency_measure_ctrl_o.event_nr <= output_s(108 downto 101) ;
|
||||||
|
end block;
|
||||||
|
|
||||||
|
end rtl;
|
||||||
|
-- ----------------------------------------------------------------------------
|
||||||
|
-- ////////////////////////////////////////////////////////////////////////////
|
||||||
|
-- ----------------------------------------------------------------------------
|
||||||
|
Reference in New Issue
Block a user