diff --git a/libraries/base/dp/src/vhdl/dp_block_gen_valid_arr.vhd b/libraries/base/dp/src/vhdl/dp_block_gen_valid_arr.vhd
index a8ae4ed7218200ae0ee7c6b16fe29567a8aa75f2..530ab7dff4e4ac3f1a841fbe065ac10db0d4fa01 100644
--- a/libraries/base/dp/src/vhdl/dp_block_gen_valid_arr.vhd
+++ b/libraries/base/dp/src/vhdl/dp_block_gen_valid_arr.vhd
@@ -136,9 +136,8 @@
 -- . Using g_check_input_sync=True is similar to using a dp_sync_checker in
 --   front of this dp_block_gen_valid_arr. However the advantage of
 --   dp_sync_checker is that it provides monitoring and control via MM.
--- . If snk_in.sync is always '0', sync out is generated at g_nof_blk_per_sync.
---   Otherwise, the output sync is also derived from snk_in.sync to allow for
---   a fractional amount of blocks per sync period.
+-- . If g_check_input_sync = True, te output sync is derived from snk_in.sync to 
+--   allow for a fractional amount of blocks per sync period.
 
 LIBRARY IEEE, common_lib;
 USE IEEE.STD_LOGIC_1164.ALL;
@@ -274,14 +273,14 @@ BEGIN
             -- maintain blk_cnt for output sync interval, the blk_cnt is the local bsn that wraps at every sync
             IF r.blk_cnt>=g_nof_blk_per_sync-1 THEN
               nxt_r.blk_cnt <= 0;
-            ELSIF snk_in.sync = '1' THEN 
+            ELSIF g_check_input_sync AND snk_in.sync = '1' THEN 
               nxt_r.blk_cnt <= 1;
             ELSE
               nxt_r.blk_cnt <= r.blk_cnt+1;
             END IF;
 
             -- create local sync and pass on input bsn at local sync
-            IF r.blk_cnt=0 OR snk_in.sync = '1' THEN    -- output sync starts at first input valid
+            IF r.blk_cnt=0 OR (g_check_input_sync AND snk_in.sync = '1') THEN    -- output sync starts at first input valid
               nxt_r.reg_sosi.sync <= '1';               -- output sync for this block
               nxt_r.reg_sosi.bsn  <= in_sosi.bsn;       -- output input bsn at sync
             ELSE