diff --git a/applications/lofar2/designs/lofar2_unb2b_sdp_station/revisions/lofar2_unb2b_sdp_station_bf/tb_lofar2_unb2b_sdp_station_bf.vhd b/applications/lofar2/designs/lofar2_unb2b_sdp_station/revisions/lofar2_unb2b_sdp_station_bf/tb_lofar2_unb2b_sdp_station_bf.vhd index c8614845fb78c196b93ba64c9d0654c6e5567946..fc88e90a4a3bb1d561ce39a0571146b0799a99ec 100644 --- a/applications/lofar2/designs/lofar2_unb2b_sdp_station/revisions/lofar2_unb2b_sdp_station_bf/tb_lofar2_unb2b_sdp_station_bf.vhd +++ b/applications/lofar2/designs/lofar2_unb2b_sdp_station/revisions/lofar2_unb2b_sdp_station_bf/tb_lofar2_unb2b_sdp_station_bf.vhd @@ -141,6 +141,7 @@ architecture tb of tb_lofar2_unb2b_sdp_station_bf is constant c_exp_beamlet_scale : natural := natural(g_beamlet_scale * real(c_sdp_unit_beamlet_scale)); -- c_sdp_unit_beamlet_scale = 2**15; constant c_exp_beamlet_index : natural := 0; -- depends on beamset bset * c_sdp_S_sub_bf + constant c_beamlet_index_mod : boolean := true; constant c_exp_sdp_info : t_sdp_info := ( TO_UVEC(3, 6), -- antenna_field_index @@ -1094,7 +1095,9 @@ begin -- Therefore accept any beamlet_index MOD c_sdp_S_sub_bf = 0 as correct -- in func_sdp_verify_cep_header(). if rx_beamlet_sosi.eop = '1' then - v_bool := func_sdp_verify_cep_header(rx_sdp_cep_header, exp_sdp_cep_header); + v_bool := func_sdp_verify_cep_header(rx_sdp_cep_header, + exp_sdp_cep_header, + c_beamlet_index_mod); end if; end process; diff --git a/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf/tb_lofar2_unb2c_sdp_station_bf.vhd b/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf/tb_lofar2_unb2c_sdp_station_bf.vhd index 0e6167477ddb76d0a8d3921ad585908e4aa30fce..6d12a8748c603307877e1ff8b00d90efd6c72014 100644 --- a/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf/tb_lofar2_unb2c_sdp_station_bf.vhd +++ b/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf/tb_lofar2_unb2c_sdp_station_bf.vhd @@ -233,6 +233,7 @@ architecture tb of tb_lofar2_unb2c_sdp_station_bf is constant c_exp_beamlet_scale : natural := natural(g_beamlet_scale * real(c_sdp_unit_beamlet_scale)); -- c_sdp_unit_beamlet_scale = 2**15; constant c_exp_beamlet_index : natural := 0; -- depends on beamset bset * c_sdp_S_sub_bf + constant c_beamlet_index_mod : boolean := true; constant c_exp_sdp_info : t_sdp_info := ( TO_UVEC(3, 6), -- antenna_field_index @@ -1352,7 +1353,9 @@ begin -- Therefore accept any beamlet_index MOD c_sdp_S_sub_bf = 0 as correct -- in func_sdp_verify_cep_header(). if rx_beamlet_sosi.eop = '1' then - v_bool := func_sdp_verify_cep_header(rx_sdp_cep_header, exp_sdp_cep_header); + v_bool := func_sdp_verify_cep_header(rx_sdp_cep_header, + exp_sdp_cep_header, + c_beamlet_index_mod); end if; end process; diff --git a/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf_ring/tb_lofar2_unb2c_sdp_station_bf_ring.vhd b/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf_ring/tb_lofar2_unb2c_sdp_station_bf_ring.vhd index f4ada61682a5443c7be855ec9c9ad6a42fd86828..18702afb27646b839fa7bcb523075e7799bd1366 100644 --- a/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf_ring/tb_lofar2_unb2c_sdp_station_bf_ring.vhd +++ b/applications/lofar2/designs/lofar2_unb2c_sdp_station/revisions/lofar2_unb2c_sdp_station_bf_ring/tb_lofar2_unb2c_sdp_station_bf_ring.vhd @@ -245,6 +245,7 @@ architecture tb of tb_lofar2_unb2c_sdp_station_bf_ring is constant c_exp_beamlet_scale : natural := natural(g_beamlet_scale * real(c_sdp_unit_beamlet_scale)); -- c_sdp_unit_beamlet_scale = 2**15; constant c_exp_beamlet_index : natural := 0; -- depends on beamset bset * c_sdp_S_sub_bf + constant c_beamlet_index_mod : boolean := true; constant c_exp_sdp_info : t_sdp_info := ( TO_UVEC(3, 6), -- antenna_field_index @@ -1443,7 +1444,9 @@ begin -- Therefore accept any beamlet_index MOD c_sdp_S_sub_bf = 0 as correct -- in func_sdp_verify_cep_header(). if rx_beamlet_sosi.eop = '1' then - v_bool := func_sdp_verify_cep_header(rx_sdp_cep_header, exp_sdp_cep_header); + v_bool := func_sdp_verify_cep_header(rx_sdp_cep_header, + exp_sdp_cep_header, + c_beamlet_index_mod); end if; end process; diff --git a/applications/lofar2/libraries/sdp/tb/vhdl/tb_sdp_pkg.vhd b/applications/lofar2/libraries/sdp/tb/vhdl/tb_sdp_pkg.vhd index 512e44428bfef575e28ad1f8289af9f5250cb426..a6f9b19d3f5f044bee8c7b314f833dac4efd3275 100644 --- a/applications/lofar2/libraries/sdp/tb/vhdl/tb_sdp_pkg.vhd +++ b/applications/lofar2/libraries/sdp/tb/vhdl/tb_sdp_pkg.vhd @@ -100,7 +100,11 @@ package tb_sdp_pkg is beamlet_index : natural; dp_bsn : natural) return t_sdp_cep_header; - function func_sdp_verify_cep_header(in_hdr, exp_hdr : t_sdp_cep_header) return boolean; + function func_sdp_verify_cep_header(in_hdr : t_sdp_cep_header; + exp_hdr : t_sdp_cep_header; + beamlet_index_mod : boolean) return boolean; + function func_sdp_verify_cep_header(in_hdr : t_sdp_cep_header; + exp_hdr : t_sdp_cep_header) return boolean; ----------------------------------------------------------------------------- -- Subband equalizer (ESub) @@ -478,7 +482,9 @@ package body tb_sdp_pkg is dp_bsn); end func_sdp_compose_cep_header; - function func_sdp_verify_cep_header(in_hdr, exp_hdr : t_sdp_cep_header) return boolean is + function func_sdp_verify_cep_header(in_hdr : t_sdp_cep_header; + exp_hdr : t_sdp_cep_header; + beamlet_index_mod : boolean) return boolean is variable v_beamlet_index : natural; begin -- eth header @@ -524,8 +530,11 @@ package body tb_sdp_pkg is assert in_hdr.app.sdp_reserved = exp_hdr.app.sdp_reserved report "Wrong beamlet app.sdp_reserved" severity ERROR; assert in_hdr.app.sdp_beamlet_scale = exp_hdr.app.sdp_beamlet_scale report "Wrong beamlet app.sdp_beamlet_scale" severity ERROR; - -- Treat beamlet_index modulo c_sdp_S_sub_bf, because the beamlet packets from different beamsets may arrive in arbitrary order - v_beamlet_index := TO_UINT(in_hdr.app.sdp_beamlet_index) mod c_sdp_S_sub_bf; + v_beamlet_index := TO_UINT(in_hdr.app.sdp_beamlet_index); + if beamlet_index_mod then + -- Treat beamlet_index modulo c_sdp_S_sub_bf, because the beamlet packets from different beamsets may arrive in arbitrary order + v_beamlet_index := v_beamlet_index mod c_sdp_S_sub_bf; + end if; assert v_beamlet_index = TO_UINT(exp_hdr.app.sdp_beamlet_index) report "Wrong beamlet app.sdp_beamlet_index" severity ERROR; assert in_hdr.app.sdp_nof_blocks_per_packet = exp_hdr.app.sdp_nof_blocks_per_packet report "Wrong beamlet app.sdp_nof_blocks_per_packet" severity ERROR; assert in_hdr.app.sdp_nof_beamlets_per_block = exp_hdr.app.sdp_nof_beamlets_per_block report "Wrong beamlet app.sdp_nof_beamlets_per_block" severity ERROR; @@ -535,6 +544,12 @@ package body tb_sdp_pkg is return true; end func_sdp_verify_cep_header; + function func_sdp_verify_cep_header(in_hdr : t_sdp_cep_header; + exp_hdr : t_sdp_cep_header) return boolean is + begin + return func_sdp_verify_cep_header(in_hdr, exp_hdr, false); + end func_sdp_verify_cep_header; + function func_sdp_subband_equalizer(sp_subband_ampl, sp_subband_phase, sp_esub_gain, sp_esub_phase, cross_subband_ampl, cross_subband_phase, cross_esub_gain, cross_esub_phase : real) return t_real_arr is -- 0:3 = ampl, phase, re, im