From 5ada57114771f2e56f7578ed12c5182892608d22 Mon Sep 17 00:00:00 2001
From: Erik Kooistra <kooistra@astron.nl>
Date: Fri, 5 Dec 2014 14:25:40 +0000
Subject: [PATCH] SVN copied serializer.vhd, deserializer.vhd and sim_gx.vhd to
 technology/transceiver/ in RadioHDL/ and renamed them with prefix
 'sim_transceiver_'.

---
 libraries/io/tr_nonbonded/hdllib.cfg          |   3 -
 .../io/tr_nonbonded/src/vhdl/tr_nonbonded.vhd |   2 +-
 libraries/technology/transceiver/hdllib.cfg   |   4 +
 .../sim_transceiver_deserializer.vhd          | 113 ++++++++++++
 .../transceiver/sim_transceiver_gx.vhd        | 162 ++++++++++++++++++
 .../sim_transceiver_serializer.vhd            | 142 +++++++++++++++
 6 files changed, 422 insertions(+), 4 deletions(-)
 create mode 100644 libraries/technology/transceiver/sim_transceiver_deserializer.vhd
 create mode 100644 libraries/technology/transceiver/sim_transceiver_gx.vhd
 create mode 100644 libraries/technology/transceiver/sim_transceiver_serializer.vhd

diff --git a/libraries/io/tr_nonbonded/hdllib.cfg b/libraries/io/tr_nonbonded/hdllib.cfg
index 4da4c2ff2b..10b7137074 100644
--- a/libraries/io/tr_nonbonded/hdllib.cfg
+++ b/libraries/io/tr_nonbonded/hdllib.cfg
@@ -7,9 +7,6 @@ build_dir_sim = $HDL_BUILD_DIR
 build_dir_synth = $HDL_BUILD_DIR
 
 synth_files =
-    $UNB/Firmware/modules/tr_nonbonded/tb/vhdl/serializer.vhd
-    $UNB/Firmware/modules/tr_nonbonded/tb/vhdl/deserializer.vhd
-    $UNB/Firmware/modules/tr_nonbonded/tb/vhdl/sim_gx.vhd
     src/vhdl/tr_nonbonded.vhd
     $UNB/Firmware/modules/tr_nonbonded/src/vhdl/tr_nonbonded_reg.vhd
     $UNB/Firmware/modules/tr_nonbonded/src/vhdl/mms_tr_nonbonded.vhd
diff --git a/libraries/io/tr_nonbonded/src/vhdl/tr_nonbonded.vhd b/libraries/io/tr_nonbonded/src/vhdl/tr_nonbonded.vhd
index 20d3f8f0dc..2245c27063 100644
--- a/libraries/io/tr_nonbonded/src/vhdl/tr_nonbonded.vhd
+++ b/libraries/io/tr_nonbonded/src/vhdl/tr_nonbonded.vhd
@@ -165,7 +165,7 @@ BEGIN
 
   gen_sim: IF g_sim = TRUE AND g_sim_level = 1 GENERATE
     -- Behavioural serdes model (fast)
-    u_sim_gx: ENTITY WORK.sim_gx 
+    u_sim_gx: ENTITY tech_transceiver_lib.sim_transceiver_gx 
     GENERIC MAP (
       g_data_w        => g_data_w,
       g_nof_gx        => g_nof_gx,
diff --git a/libraries/technology/transceiver/hdllib.cfg b/libraries/technology/transceiver/hdllib.cfg
index 3c38c06a88..58e0237f13 100644
--- a/libraries/technology/transceiver/hdllib.cfg
+++ b/libraries/technology/transceiver/hdllib.cfg
@@ -7,6 +7,10 @@ build_dir_sim = $HDL_BUILD_DIR
 build_dir_synth = $HDL_BUILD_DIR
 
 synth_files =
+    sim_transceiver_serializer.vhd
+    sim_transceiver_deserializer.vhd
+    sim_transceiver_gx.vhd
+    
     tech_transceiver_component_pkg.vhd
     tech_transceiver_rx_order.vhd
     tech_transceiver_rx_align.vhd
diff --git a/libraries/technology/transceiver/sim_transceiver_deserializer.vhd b/libraries/technology/transceiver/sim_transceiver_deserializer.vhd
new file mode 100644
index 0000000000..b8daf73387
--- /dev/null
+++ b/libraries/technology/transceiver/sim_transceiver_deserializer.vhd
@@ -0,0 +1,113 @@
+--------------------------------------------------------------------------------
+--
+-- Copyright (C) 2012
+-- ASTRON (Netherlands Institute for Radio Astronomy) <http://www.astron.nl/>
+-- JIVE (Joint Institute for VLBI in Europe) <http://www.jive.nl/>
+-- P.O.Box 2, 7990 AA Dwingeloo, The Netherlands
+--
+-- This program is free software: you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation, either version 3 of the License, or
+-- (at your option) any later version.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+-- GNU General Public License for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with this program.  If not, see <http://www.gnu.org/licenses/>.
+--
+--------------------------------------------------------------------------------
+
+-- Purpose:
+--   Basic deserializer model for fast transceiver simulation
+-- Description:
+--   See sim_transceiver_serializer.vhd 
+-- Remarks:
+
+
+LIBRARY IEEE, common_lib;
+USE IEEE.STD_LOGIC_1164.ALL;
+USE IEEE.STD_LOGIC_UNSIGNED.ALL;
+USE common_lib.common_pkg.ALL;
+
+ENTITY sim_transceiver_deserializer IS 
+  GENERIC(
+    g_data_w     : NATURAL := 32;
+    g_line_rate  : NATURAL := 6250 -- In Mbps. This yields rx_clk = ((8/10)*line_rate)/g_data_w
+  );      
+  PORT(
+    tb_end       : IN  STD_LOGIC := '0';  -- in simulation stop internal clocks when tb_end='1' to support 'run -all'
+    
+    tr_clk       : IN  STD_LOGIC;
+    tr_rst       : IN  STD_LOGIC;
+
+    rx_clk       : OUT STD_LOGIC;
+    rx_rst       : OUT STD_LOGIC;
+
+    rx_out_data  : OUT STD_LOGIC_VECTOR(g_data_w-1 DOWNTO 0);
+    rx_out_ctrl  : OUT STD_LOGIC_VECTOR(g_data_w/c_byte_w-1 DOWNTO 0);
+
+    rx_in        : IN  STD_LOGIC
+  );
+
+END sim_transceiver_deserializer;
+
+
+ARCHITECTURE beh OF sim_transceiver_deserializer IS
+
+  CONSTANT c_line_clk_per     : TIME := 1000000 ps /g_line_rate; --e.g. 160 ps line clk period for 6250 Mbps
+  CONSTANT c_usr_nof_bytes    : NATURAL := g_data_w / c_byte_w;
+
+  CONSTANT c_rx_clk_per       : TIME := c_line_clk_per * ( (g_data_w*10)/8 );
+
+  SIGNAL i_rx_clk             : STD_LOGIC := '1';
+  SIGNAL i_rx_rst             : STD_LOGIC := '1';
+
+BEGIN
+
+  rx_clk   <= i_rx_clk;
+  rx_rst   <= i_rx_rst;
+  i_rx_clk <= NOT i_rx_clk OR tb_end AFTER c_rx_clk_per/2;
+  i_rx_rst <= '0' AFTER c_rx_clk_per*170;
+
+  p_deserialize: PROCESS
+    VARIABLE bit_index     : NATURAL;
+    VARIABLE v_rx_out_data : STD_LOGIC_VECTOR(g_data_w-1 DOWNTO 0);
+    VARIABLE v_rx_out_ctrl : STD_LOGIC_VECTOR(c_usr_nof_bytes-1 DOWNTO 0);
+  BEGIN
+    WAIT UNTIL tr_rst = '0';
+    WAIT UNTIL i_rx_rst = '0' ;
+
+    -- Give TX time to serialize the first word.  
+    WAIT FOR c_rx_clk_per;
+
+    -- Wait for half of a serial clk period so data is stable when sampling
+    WAIT FOR c_line_clk_per/2;
+
+    WHILE tb_end='0' LOOP
+      -- Start deserializing. Deserialization will be completed on the next rising edge of rx_clk.
+      FOR byte IN 0 TO c_usr_nof_bytes-1 LOOP
+        -- Deserialize one byte
+        FOR bit IN 0 TO c_byte_w-1 LOOP
+          WAIT FOR c_line_clk_per; 
+          -- Read one bit and assemble the parallel data word
+          bit_index := byte*c_byte_w+bit;
+          v_rx_out_data(bit_index) := rx_in;
+        END LOOP;
+        -- Read the control bit from the line
+        WAIT FOR c_line_clk_per;
+        v_rx_out_ctrl(byte) := rx_in;
+        -- Ignore the unised tenth bit
+        WAIT FOR c_line_clk_per;
+      END LOOP;
+      
+      -- End of this deserialization cycle: the rx data word has been assembled.
+      rx_out_data <= v_rx_out_data;
+      rx_out_ctrl <= v_rx_out_ctrl;
+    END LOOP;
+
+  END PROCESS;
+
+END beh;
diff --git a/libraries/technology/transceiver/sim_transceiver_gx.vhd b/libraries/technology/transceiver/sim_transceiver_gx.vhd
new file mode 100644
index 0000000000..a7bc43c3b2
--- /dev/null
+++ b/libraries/technology/transceiver/sim_transceiver_gx.vhd
@@ -0,0 +1,162 @@
+--------------------------------------------------------------------------------
+--
+-- Copyright (C) 2012
+-- ASTRON (Netherlands Institute for Radio Astronomy) <http://www.astron.nl/>
+-- JIVE (Joint Institute for VLBI in Europe) <http://www.jive.nl/>
+-- P.O.Box 2, 7990 AA Dwingeloo, The Netherlands
+--
+-- This program is free software: you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation, either version 3 of the License, or
+-- (at your option) any later version.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+-- GNU General Public License for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with this program.  If not, see <http://www.gnu.org/licenses/>.
+--
+--------------------------------------------------------------------------------
+
+-- Purpose:
+--   Drop-in simulation model for tech_transceiver_gx.vhd.
+-- Description:
+--   A fast serdes for simulation within tr_nonbonded.
+-- Remarks:
+--   None
+
+LIBRARY IEEE, common_lib, dp_lib;
+USE IEEE.STD_LOGIC_1164.ALL;
+USE IEEE.STD_LOGIC_UNSIGNED.ALL;
+USE common_lib.common_pkg.ALL;
+USE dp_lib.dp_stream_pkg.ALL;
+
+ENTITY sim_transceiver_gx IS 
+  GENERIC(
+    g_data_w     : NATURAL;
+    g_nof_gx     : NATURAL;
+    g_mbps       : NATURAL;
+    g_tx         : BOOLEAN;
+    g_rx         : BOOLEAN
+  );      
+  PORT(
+    tb_end       : IN  STD_LOGIC := '0';  -- in simulation stop internal clocks when tb_end='1' to support 'run -all'
+    
+    tr_clk       : IN  STD_LOGIC;
+
+    rx_clk       : OUT STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0);
+    rx_rst       : OUT STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0);
+    rx_sosi_arr  : OUT t_dp_sosi_arr(g_nof_gx-1 DOWNTO 0);
+    rx_siso_arr  : IN  t_dp_siso_arr(g_nof_gx-1 DOWNTO 0);
+
+    tx_clk       : OUT STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0);
+    tx_rst       : OUT STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0);
+    tx_sosi_arr  : IN  t_dp_sosi_arr(g_nof_gx-1 DOWNTO 0);
+    tx_siso_arr  : OUT t_dp_siso_arr(g_nof_gx-1 DOWNTO 0);
+   
+    --Serial I/O
+    rx_datain    : IN  STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0);
+    tx_dataout   : OUT STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0)
+  );
+
+END sim_transceiver_gx;
+
+ARCHITECTURE str OF sim_transceiver_gx IS
+
+  TYPE t_ctrl_2arr IS ARRAY(g_nof_gx-1 DOWNTO 0) OF STD_LOGIC_VECTOR(g_data_w/c_byte_w-1 DOWNTO 0);
+  
+  SIGNAL tr_rst      : STD_LOGIC;
+
+  SIGNAL i_tx_clk    : STD_LOGIC_VECTOR(g_nof_gx-1 DOWNTO 0);
+  SIGNAL tx_ready    : STD_LOGIC;
+
+  SIGNAL tx_in_ctrl  : t_ctrl_2arr;
+  SIGNAL rx_out_ctrl : t_ctrl_2arr;
+
+BEGIN
+
+  tx_clk <= i_tx_clk;
+
+  p_tx_rdy : PROCESS
+    VARIABLE v_tx_clk_cnt : NATURAL := 0;
+  BEGIN
+    tx_ready <= '0';
+    WAIT FOR 1084.8 ns;              -- Time until tx_rst (in tr_clk domain) is deasserted: tx init done
+    WHILE v_tx_clk_cnt < 1000 LOOP   -- 1000 tx clk cycles until alignment is completed
+      WAIT UNTIL rising_edge(i_tx_clk(0));
+      v_tx_clk_cnt := v_tx_clk_cnt + 1;
+      tx_ready <= '1';
+    END LOOP;
+    WAIT;
+  END PROCESS;
+
+  gen_sim: FOR i IN 0 to g_nof_gx-1 GENERATE
+    gen_tx : IF g_tx = TRUE GENERATE
+      tx_siso_arr(i).ready <= tx_ready;
+      tx_siso_arr(i).xon   <= tx_ready;
+
+      gen_fanout: FOR j IN g_data_w/c_byte_w-1 DOWNTO 0 GENERATE
+        tx_in_ctrl(i)(j) <= tx_sosi_arr(i).valid;
+      END GENERATE;
+
+      u_ser: ENTITY work.sim_transceiver_serializer
+      GENERIC MAP (
+        g_data_w     => g_data_w,
+        g_line_rate  => g_mbps
+      )
+      PORT MAP (
+        tb_end       => tb_end,
+        
+        tr_clk       => tr_clk,  
+        tr_rst       => tr_rst,
+         
+        tx_clk       => i_tx_clk(i),   
+        tx_rst       => tx_rst(i),    
+    
+        tx_in_data   => tx_sosi_arr(i).data(g_data_w-1 DOWNTO 0),
+        tx_in_ctrl   => tx_in_ctrl(i),
+    
+        tx_out       => tx_dataout(i)
+      );
+    END GENERATE;
+
+    gen_rx : IF g_rx = TRUE GENERATE   
+      u_des: ENTITY work.sim_transceiver_deserializer 
+      GENERIC MAP (
+        g_data_w     => g_data_w,
+        g_line_rate  => g_mbps
+      )
+      PORT MAP (
+        tb_end       => tb_end,
+        
+        tr_clk       => tr_clk,  
+        tr_rst       => tr_rst,
+         
+        rx_clk       => rx_clk(i),   
+        rx_rst       => rx_rst(i),    
+    
+        rx_out_data  => rx_sosi_arr(i).data(g_data_w-1 DOWNTO 0),
+        rx_out_ctrl  => rx_out_ctrl(i),
+    
+        rx_in        => rx_datain(i)
+      );
+    END GENERATE;
+
+    rx_sosi_arr(i).valid <= andv(rx_out_ctrl(i));
+
+  END GENERATE;
+
+  u_areset_tr_rst : ENTITY common_lib.common_areset
+  GENERIC MAP(
+    g_rst_level => '1'
+  )
+  PORT MAP(
+    clk     => tr_clk,
+    in_rst  => '0',
+    out_rst => tr_rst
+  );  
+
+END str;
+
diff --git a/libraries/technology/transceiver/sim_transceiver_serializer.vhd b/libraries/technology/transceiver/sim_transceiver_serializer.vhd
new file mode 100644
index 0000000000..e15c40e553
--- /dev/null
+++ b/libraries/technology/transceiver/sim_transceiver_serializer.vhd
@@ -0,0 +1,142 @@
+--------------------------------------------------------------------------------
+--
+-- Copyright (C) 2012
+-- ASTRON (Netherlands Institute for Radio Astronomy) <http://www.astron.nl/>
+-- JIVE (Joint Institute for VLBI in Europe) <http://www.jive.nl/>
+-- P.O.Box 2, 7990 AA Dwingeloo, The Netherlands
+--
+-- This program is free software: you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation, either version 3 of the License, or
+-- (at your option) any later version.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+-- GNU General Public License for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with this program.  If not, see <http://www.gnu.org/licenses/>.
+--
+--------------------------------------------------------------------------------
+
+-- Purpose:
+--   Basic serializer model for fast transceiver simulation
+-- Description:
+--   This model can be connected to the transmitter entity serial 
+--   transmitter output in simulation. As all serializers in the simualation are
+--   simultaneously released from reset and share the same transceiver
+--   reference clock, we don't need to worry about synchronization and can
+--   simply assign one or more bits per serial group as validity indicator. The most 
+--   straightforward is to mimic 10/8 encoding for as far as data rates and clock 
+--   ratios are concerned (not the encoding itself):
+--   * User data rate = (8/10)*line data rate
+--   * User clock frequency = User data rate / user data width
+--   * Serial data block size = 10 bits [9..0] LSb sent first
+--     *  [9] = Unused, '0'., indiced by 'x'.
+--     *  [8] = Control bit.
+--     *  [7..0] = Data
+--   * Word/byte alignment is not required because reference clk and rst are global in
+--     simulation: what gets transmitted first is received first.
+--   
+--  The following diagram shows the serialization of the 32-bit word 0x2. The grid of dots
+--  indicates the bit resolution. Note the 1 serial cycle of delay before the first bit
+--  is put on the line.
+--
+--         . _______________________________________ . . . . . . . . . . . . . . . . . . . . .
+-- tx_clk  _|. . . . . . . . . . . . . . . . . . . .|_________________________________________
+--         _ . . _ . . . . . . _ . . . . . . . . . _ . . . . . . . . . _ . . . . . . . . . _ .        
+-- tx_out  .|___|.|___________|.|_________________|.|_________________|.|_________________|.|_
+-- 
+--         c x 0 1 2 3 4 5 6 7 c x 0 1 2 3 4 5 6 7 c x 0 1 2 3 4 5 6 7 c x 0 1 2 3 4 5 6 7 c x
+--            |<----- Byte 0 ---->|<----- Byte 1 ---->|<----- Byte 2 ---->|<----- Byte 3 ---->|
+--
+-- Remarks:
+--   . Requirements:
+--     . All serializers in the simualation should be simultaneously released from 
+--       reset and have to share the same transceiver reference clock.
+--   . This serializer is used in the tr_nonbonded module as a behavioural model 
+--     inside phy_gx.vhd.
+
+
+LIBRARY IEEE, common_lib;
+USE IEEE.STD_LOGIC_1164.ALL;
+USE IEEE.STD_LOGIC_UNSIGNED.ALL;
+USE common_lib.common_pkg.ALL;
+
+ENTITY sim_transceiver_serializer IS 
+  GENERIC(
+    g_data_w     : NATURAL := 32;
+    g_line_rate  : NATURAL := 6250 -- In Mbps. This yields tx_clk period = ((8/10)*line_rate)/g_data_w
+  );      
+  PORT(
+    tb_end       : IN  STD_LOGIC := '0';  -- in simulation stop internal clocks when tb_end='1' to support 'run -all'
+    
+    tr_clk       : IN  STD_LOGIC;
+    tr_rst       : IN  STD_LOGIC;
+
+    tx_clk       : OUT STD_LOGIC;
+    tx_rst       : OUT STD_LOGIC;
+
+    tx_in_data   : IN  STD_LOGIC_VECTOR(g_data_w-1 DOWNTO 0);
+    tx_in_ctrl   : IN  STD_LOGIC_VECTOR(g_data_w/c_byte_w-1 DOWNTO 0);
+
+    tx_out       : OUT STD_LOGIC
+  );
+
+END sim_transceiver_serializer;
+
+
+ARCHITECTURE beh OF sim_transceiver_serializer IS
+
+  CONSTANT c_line_clk_per     : TIME    := 1000000 ps /g_line_rate; --e.g. 160 ps line clk period for 6250 Mbps
+  CONSTANT c_usr_nof_bytes    : NATURAL := g_data_w / c_byte_w;
+  CONSTANT c_tx_clk_per       : TIME    := c_line_clk_per * ( (g_data_w*10)/8 );
+
+  SIGNAL i_tx_clk             : STD_LOGIC := '1';
+  SIGNAL i_tx_rst             : STD_LOGIC := '1';
+
+BEGIN
+ 
+  tx_clk   <= i_tx_clk;
+  tx_rst   <= i_tx_rst;
+  i_tx_clk <= NOT i_tx_clk OR tb_end AFTER c_tx_clk_per/2;
+  i_tx_rst <= '0' AFTER c_tx_clk_per*170;
+
+  p_serialize: PROCESS
+    VARIABLE bit_index : NATURAL;
+  BEGIN
+    tx_out <= '0';
+    WAIT UNTIL tr_rst = '0';
+    WAIT UNTIL i_tx_rst = '0' ;
+
+    -- Deserializer waits for c_line_clk_per/2 
+    WAIT FOR c_line_clk_per;
+
+    WHILE tb_end='0' LOOP
+      -- New serialization cycle
+      FOR byte IN 0 TO c_usr_nof_bytes-1 LOOP
+        -- Put a data byte on the line
+        FOR bit IN 0 TO c_byte_w-1 LOOP
+          -- Put a data bit on the line
+          tx_out <= tx_in_data(byte*c_byte_w+bit);
+          -- Wait for one line clk period. The sum of all of these line clock cycles automatically 
+          -- creates the correct tx_clk period - for example if g_data_w = 32 and g_line_rate = 5000,
+          -- 40 (32 bits incl. 10/8 overhead) bits have to be serialized, one bit per 200 ps period.
+          -- These settings would yield a tx_clk period of 40*200 ps = 8 ns (125 MHz).
+          WAIT FOR c_line_clk_per;
+        END LOOP;
+        -- Put the control bit on the line for each byte
+        tx_out <= tx_in_ctrl(byte);
+        -- Wait for one line clk period
+        WAIT FOR c_line_clk_per;
+        -- Put the unused tenth bit = '0' on the line
+        tx_out <= '0';
+        -- Wait for one line clk period
+        WAIT FOR c_line_clk_per;
+      END LOOP;
+    END LOOP;
+
+  END PROCESS;
+
+END beh;
-- 
GitLab