Module Definition
dashboard | hierarchy | modlist | groups | tests | asserts



Module Instance : tb.dut.u_clk_main_aes_trans

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
98.65 100.00 93.24 100.00 100.00 100.00 dut


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
u_cg 100.00 100.00 100.00 100.00
u_en_sync 100.00 100.00 100.00
u_err_sync 100.00 100.00 100.00
u_hint_sync 100.00 100.00 100.00
u_idle_cnt 100.00 100.00
u_idle_sync 100.00 100.00 100.00 100.00 100.00
u_prim_buf_en 100.00 100.00
u_prim_mubi4_sender 100.00 100.00 100.00 100.00
u_scanmode_sync 100.00 100.00 100.00



Module Instance : tb.dut.u_clk_main_hmac_trans

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
98.65 100.00 93.24 100.00 100.00 100.00 dut


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
u_cg 100.00 100.00 100.00 100.00
u_en_sync 100.00 100.00 100.00
u_err_sync 100.00 100.00 100.00
u_hint_sync 100.00 100.00 100.00
u_idle_cnt 100.00 100.00
u_idle_sync 100.00 100.00 100.00 100.00 100.00
u_prim_buf_en 100.00 100.00
u_prim_mubi4_sender 100.00 100.00 100.00 100.00
u_scanmode_sync 100.00 100.00 100.00



Module Instance : tb.dut.u_clk_main_kmac_trans

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
98.65 100.00 93.24 100.00 100.00 100.00 dut


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
u_cg 100.00 100.00 100.00 100.00
u_en_sync 100.00 100.00 100.00
u_err_sync 100.00 100.00 100.00
u_hint_sync 100.00 100.00 100.00
u_idle_cnt 100.00 100.00
u_idle_sync 100.00 100.00 100.00 100.00 100.00
u_prim_buf_en 100.00 100.00
u_prim_mubi4_sender 100.00 100.00 100.00 100.00
u_scanmode_sync 100.00 100.00 100.00



Module Instance : tb.dut.u_clk_main_otbn_trans

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
98.65 100.00 93.24 100.00 100.00 100.00 dut


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
u_cg 100.00 100.00 100.00 100.00
u_en_sync 100.00 100.00 100.00
u_err_sync 100.00 100.00 100.00
u_hint_sync 100.00 100.00 100.00
u_idle_cnt 100.00 100.00
u_idle_sync 100.00 100.00 100.00 100.00 100.00
u_prim_buf_en 100.00 100.00
u_prim_mubi4_sender 100.00 100.00 100.00 100.00
u_scanmode_sync 100.00 100.00 100.00

Line Coverage for Module : clkmgr_trans
Line No.TotalCoveredPercent
TOTAL99100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4611100.00
ALWAYS14044100.00
ALWAYS15833100.00

44 logic local_en; 45 1/1 assign idle_valid = (idle_cnt == IdleCntWidth'(TransIdleCnt)); Tests: T4 T5 T6  46 1/1 assign local_en = sw_hint_synced | ~idle_valid; Tests: T4 T5 T6  47 48 prim_flop_2sync #( 49 .Width(1) 50 ) u_hint_sync ( 51 .clk_i(clk_i), 52 .rst_ni(rst_ni), 53 .d_i(sw_hint_i), 54 .q_o(sw_hint_synced) 55 ); 56 57 // Idle sync: Idle signal comes from IP module. The reset of the Idle signal 58 // may differ from the reset here. Adding mubi sync to synchronize. 59 prim_mubi_pkg::mubi4_t [0:0] idle; 60 prim_mubi4_sync #( 61 .NumCopies ( 1 ), 62 .AsyncOn ( 1'b 1 ), 63 .StabilityCheck ( 1'b 1 ) 64 ) u_idle_sync ( 65 .clk_i, 66 .rst_ni, 67 .mubi_i (idle_i), 68 .mubi_o (idle) 69 ); 70 71 // SEC_CM: IDLE.CTR.REDUN 72 logic cnt_err; 73 prim_count #( 74 .Width(IdleCntWidth) 75 ) u_idle_cnt ( 76 .clk_i(clk_i), 77 .rst_ni(rst_ni), 78 // the default condition is to keep the clock enabled 79 .clr_i(mubi4_test_false_loose(idle[0])), 80 .set_i('0), 81 .set_cnt_i('0), 82 .incr_en_i(mubi4_test_true_strict(idle[0]) & ~idle_valid), 83 .decr_en_i(1'b0), 84 .step_i(IdleCntWidth'(1'b1)), 85 .commit_i(1'b1), 86 .cnt_o(idle_cnt), 87 .cnt_after_commit_o(), 88 .err_o(cnt_err) 89 ); 90 91 // Declared as size 1 packed array to avoid FPV warning. 92 prim_mubi_pkg::mubi4_t [0:0] scanmode; 93 prim_mubi4_sync #( 94 .NumCopies(1), 95 .AsyncOn(0) 96 ) u_scanmode_sync ( 97 .clk_i, 98 .rst_ni, 99 .mubi_i(scanmode_i), 100 .mubi_o(scanmode) 101 ); 102 103 // Add a prim buf here to make sure the CG and the lc sender inputs 104 // are derived from the same physical signal. 105 logic combined_en_d, combined_en_q; 106 prim_buf u_prim_buf_en ( 107 .in_i(local_en & en_i), 108 .out_o(combined_en_d) 109 ); 110 111 // clk_gated_i is already controlled by en_i, so there is no need 112 // to use it in the below gating function 113 prim_clock_gating #( 114 .FpgaBufGlobal(FpgaBufGlobal) 115 ) u_cg ( 116 .clk_i(clk_gated_i), 117 .en_i(local_en), 118 .test_en_i(mubi4_test_true_strict(scanmode[0])), 119 .clk_o(clk_o) 120 ); 121 122 // clock gated indication for alert handler 123 prim_mubi4_sender #( 124 .ResetValue(MuBi4True) 125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), 129 .mubi_o(alert_cg_en_o) 130 ); 131 132 // we hold the error because there is no guarantee on 133 // what the timing of cnt_err looks like, it may be a 134 // pulse or it may be level. If it's for former, 135 // prim_sync_reqack may miss it, if it's the latter, 136 // prim_pulse_sync may miss it. As a result, just 137 // latch forever and sync it over. 138 logic hold_err; 139 always_ff @(posedge clk_i or negedge rst_ni) begin 140 1/1 if (!rst_ni) begin Tests: T4 T5 T6  141 1/1 hold_err <= '0; Tests: T4 T5 T6  142 1/1 end else if (cnt_err) begin Tests: T4 T5 T6  143 1/1 hold_err <= 1'b1; Tests: T98 T16 T99  144 end MISSING_ELSE 145 end 146 147 // register facing domain 148 prim_flop_2sync #( 149 .Width(1) 150 ) u_err_sync ( 151 .clk_i(clk_reg_i), 152 .rst_ni(rst_reg_ni), 153 .d_i(hold_err), 154 .q_o(reg_cnt_err_o) 155 ); 156 157 always_ff @(posedge clk_i or negedge rst_ni) begin 158 1/1 if (!rst_ni) begin Tests: T4 T5 T6  159 1/1 combined_en_q <= '0; Tests: T4 T5 T6  160 end else begin 161 1/1 combined_en_q <= combined_en_d; Tests: T4 T5 T6 

Cond Coverage for Module : clkmgr_trans
TotalCoveredPercent
Conditions1010100.00
Logical1010100.00
Non-Logical00
Event00

 LINE       45
 EXPRESSION (idle_cnt == 4'(TransIdleCnt))
            ---------------1--------------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

 LINE       46
 EXPRESSION (sw_hint_synced | ((~idle_valid)))
             -------1------   -------2-------
-1--2-StatusTests
00CoveredT6,T27,T28
01CoveredT4,T5,T6
10CoveredT4,T5,T6

 LINE       106
 EXPRESSION (local_en & en_i)
             ----1---   --2-
-1--2-StatusTests
01CoveredT6,T27,T28
10CoveredT4,T5,T6
11CoveredT4,T5,T6

 LINE       125
 EXPRESSION (combined_en_d ? MuBi4False : MuBi4True)
             ------1------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

Branch Coverage for Module : clkmgr_trans
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 125 2 2 100.00
IF 140 3 3 100.00
IF 158 2 2 100.00


125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6


140 if (!rst_ni) begin -1- 141 hold_err <= '0; ==> 142 end else if (cnt_err) begin -2- 143 hold_err <= 1'b1; ==> 144 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T4,T5,T6
0 1 Covered T98,T16,T99
0 0 Covered T4,T5,T6


158 if (!rst_ni) begin -1- 159 combined_en_q <= '0; ==> 160 end else begin 161 combined_en_q <= combined_en_d; ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6

Line Coverage for Instance : tb.dut.u_clk_main_aes_trans
Line No.TotalCoveredPercent
TOTAL99100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4611100.00
ALWAYS14044100.00
ALWAYS15833100.00

44 logic local_en; 45 1/1 assign idle_valid = (idle_cnt == IdleCntWidth'(TransIdleCnt)); Tests: T4 T5 T6  46 1/1 assign local_en = sw_hint_synced | ~idle_valid; Tests: T4 T5 T6  47 48 prim_flop_2sync #( 49 .Width(1) 50 ) u_hint_sync ( 51 .clk_i(clk_i), 52 .rst_ni(rst_ni), 53 .d_i(sw_hint_i), 54 .q_o(sw_hint_synced) 55 ); 56 57 // Idle sync: Idle signal comes from IP module. The reset of the Idle signal 58 // may differ from the reset here. Adding mubi sync to synchronize. 59 prim_mubi_pkg::mubi4_t [0:0] idle; 60 prim_mubi4_sync #( 61 .NumCopies ( 1 ), 62 .AsyncOn ( 1'b 1 ), 63 .StabilityCheck ( 1'b 1 ) 64 ) u_idle_sync ( 65 .clk_i, 66 .rst_ni, 67 .mubi_i (idle_i), 68 .mubi_o (idle) 69 ); 70 71 // SEC_CM: IDLE.CTR.REDUN 72 logic cnt_err; 73 prim_count #( 74 .Width(IdleCntWidth) 75 ) u_idle_cnt ( 76 .clk_i(clk_i), 77 .rst_ni(rst_ni), 78 // the default condition is to keep the clock enabled 79 .clr_i(mubi4_test_false_loose(idle[0])), 80 .set_i('0), 81 .set_cnt_i('0), 82 .incr_en_i(mubi4_test_true_strict(idle[0]) & ~idle_valid), 83 .decr_en_i(1'b0), 84 .step_i(IdleCntWidth'(1'b1)), 85 .commit_i(1'b1), 86 .cnt_o(idle_cnt), 87 .cnt_after_commit_o(), 88 .err_o(cnt_err) 89 ); 90 91 // Declared as size 1 packed array to avoid FPV warning. 92 prim_mubi_pkg::mubi4_t [0:0] scanmode; 93 prim_mubi4_sync #( 94 .NumCopies(1), 95 .AsyncOn(0) 96 ) u_scanmode_sync ( 97 .clk_i, 98 .rst_ni, 99 .mubi_i(scanmode_i), 100 .mubi_o(scanmode) 101 ); 102 103 // Add a prim buf here to make sure the CG and the lc sender inputs 104 // are derived from the same physical signal. 105 logic combined_en_d, combined_en_q; 106 prim_buf u_prim_buf_en ( 107 .in_i(local_en & en_i), 108 .out_o(combined_en_d) 109 ); 110 111 // clk_gated_i is already controlled by en_i, so there is no need 112 // to use it in the below gating function 113 prim_clock_gating #( 114 .FpgaBufGlobal(FpgaBufGlobal) 115 ) u_cg ( 116 .clk_i(clk_gated_i), 117 .en_i(local_en), 118 .test_en_i(mubi4_test_true_strict(scanmode[0])), 119 .clk_o(clk_o) 120 ); 121 122 // clock gated indication for alert handler 123 prim_mubi4_sender #( 124 .ResetValue(MuBi4True) 125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), 129 .mubi_o(alert_cg_en_o) 130 ); 131 132 // we hold the error because there is no guarantee on 133 // what the timing of cnt_err looks like, it may be a 134 // pulse or it may be level. If it's for former, 135 // prim_sync_reqack may miss it, if it's the latter, 136 // prim_pulse_sync may miss it. As a result, just 137 // latch forever and sync it over. 138 logic hold_err; 139 always_ff @(posedge clk_i or negedge rst_ni) begin 140 1/1 if (!rst_ni) begin Tests: T4 T5 T6  141 1/1 hold_err <= '0; Tests: T4 T5 T6  142 1/1 end else if (cnt_err) begin Tests: T4 T5 T6  143 1/1 hold_err <= 1'b1; Tests: T98 T16 T99  144 end MISSING_ELSE 145 end 146 147 // register facing domain 148 prim_flop_2sync #( 149 .Width(1) 150 ) u_err_sync ( 151 .clk_i(clk_reg_i), 152 .rst_ni(rst_reg_ni), 153 .d_i(hold_err), 154 .q_o(reg_cnt_err_o) 155 ); 156 157 always_ff @(posedge clk_i or negedge rst_ni) begin 158 1/1 if (!rst_ni) begin Tests: T4 T5 T6  159 1/1 combined_en_q <= '0; Tests: T4 T5 T6  160 end else begin 161 1/1 combined_en_q <= combined_en_d; Tests: T4 T5 T6 

Cond Coverage for Instance : tb.dut.u_clk_main_aes_trans
TotalCoveredPercent
Conditions1010100.00
Logical1010100.00
Non-Logical00
Event00

 LINE       45
 EXPRESSION (idle_cnt == 4'(TransIdleCnt))
            ---------------1--------------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

 LINE       46
 EXPRESSION (sw_hint_synced | ((~idle_valid)))
             -------1------   -------2-------
-1--2-StatusTests
00CoveredT6,T27,T28
01CoveredT4,T5,T6
10CoveredT4,T5,T6

 LINE       106
 EXPRESSION (local_en & en_i)
             ----1---   --2-
-1--2-StatusTests
01CoveredT6,T27,T28
10CoveredT4,T5,T6
11CoveredT4,T5,T6

 LINE       125
 EXPRESSION (combined_en_d ? MuBi4False : MuBi4True)
             ------1------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

Branch Coverage for Instance : tb.dut.u_clk_main_aes_trans
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 125 2 2 100.00
IF 140 3 3 100.00
IF 158 2 2 100.00


125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6


140 if (!rst_ni) begin -1- 141 hold_err <= '0; ==> 142 end else if (cnt_err) begin -2- 143 hold_err <= 1'b1; ==> 144 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T4,T5,T6
0 1 Covered T98,T16,T99
0 0 Covered T4,T5,T6


158 if (!rst_ni) begin -1- 159 combined_en_q <= '0; ==> 160 end else begin 161 combined_en_q <= combined_en_d; ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6

Line Coverage for Instance : tb.dut.u_clk_main_hmac_trans
Line No.TotalCoveredPercent
TOTAL99100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4611100.00
ALWAYS14044100.00
ALWAYS15833100.00

44 logic local_en; 45 1/1 assign idle_valid = (idle_cnt == IdleCntWidth'(TransIdleCnt)); Tests: T4 T5 T6  46 1/1 assign local_en = sw_hint_synced | ~idle_valid; Tests: T4 T5 T6  47 48 prim_flop_2sync #( 49 .Width(1) 50 ) u_hint_sync ( 51 .clk_i(clk_i), 52 .rst_ni(rst_ni), 53 .d_i(sw_hint_i), 54 .q_o(sw_hint_synced) 55 ); 56 57 // Idle sync: Idle signal comes from IP module. The reset of the Idle signal 58 // may differ from the reset here. Adding mubi sync to synchronize. 59 prim_mubi_pkg::mubi4_t [0:0] idle; 60 prim_mubi4_sync #( 61 .NumCopies ( 1 ), 62 .AsyncOn ( 1'b 1 ), 63 .StabilityCheck ( 1'b 1 ) 64 ) u_idle_sync ( 65 .clk_i, 66 .rst_ni, 67 .mubi_i (idle_i), 68 .mubi_o (idle) 69 ); 70 71 // SEC_CM: IDLE.CTR.REDUN 72 logic cnt_err; 73 prim_count #( 74 .Width(IdleCntWidth) 75 ) u_idle_cnt ( 76 .clk_i(clk_i), 77 .rst_ni(rst_ni), 78 // the default condition is to keep the clock enabled 79 .clr_i(mubi4_test_false_loose(idle[0])), 80 .set_i('0), 81 .set_cnt_i('0), 82 .incr_en_i(mubi4_test_true_strict(idle[0]) & ~idle_valid), 83 .decr_en_i(1'b0), 84 .step_i(IdleCntWidth'(1'b1)), 85 .commit_i(1'b1), 86 .cnt_o(idle_cnt), 87 .cnt_after_commit_o(), 88 .err_o(cnt_err) 89 ); 90 91 // Declared as size 1 packed array to avoid FPV warning. 92 prim_mubi_pkg::mubi4_t [0:0] scanmode; 93 prim_mubi4_sync #( 94 .NumCopies(1), 95 .AsyncOn(0) 96 ) u_scanmode_sync ( 97 .clk_i, 98 .rst_ni, 99 .mubi_i(scanmode_i), 100 .mubi_o(scanmode) 101 ); 102 103 // Add a prim buf here to make sure the CG and the lc sender inputs 104 // are derived from the same physical signal. 105 logic combined_en_d, combined_en_q; 106 prim_buf u_prim_buf_en ( 107 .in_i(local_en & en_i), 108 .out_o(combined_en_d) 109 ); 110 111 // clk_gated_i is already controlled by en_i, so there is no need 112 // to use it in the below gating function 113 prim_clock_gating #( 114 .FpgaBufGlobal(FpgaBufGlobal) 115 ) u_cg ( 116 .clk_i(clk_gated_i), 117 .en_i(local_en), 118 .test_en_i(mubi4_test_true_strict(scanmode[0])), 119 .clk_o(clk_o) 120 ); 121 122 // clock gated indication for alert handler 123 prim_mubi4_sender #( 124 .ResetValue(MuBi4True) 125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), 129 .mubi_o(alert_cg_en_o) 130 ); 131 132 // we hold the error because there is no guarantee on 133 // what the timing of cnt_err looks like, it may be a 134 // pulse or it may be level. If it's for former, 135 // prim_sync_reqack may miss it, if it's the latter, 136 // prim_pulse_sync may miss it. As a result, just 137 // latch forever and sync it over. 138 logic hold_err; 139 always_ff @(posedge clk_i or negedge rst_ni) begin 140 1/1 if (!rst_ni) begin Tests: T4 T5 T6  141 1/1 hold_err <= '0; Tests: T4 T5 T6  142 1/1 end else if (cnt_err) begin Tests: T4 T5 T6  143 1/1 hold_err <= 1'b1; Tests: T98 T16 T99  144 end MISSING_ELSE 145 end 146 147 // register facing domain 148 prim_flop_2sync #( 149 .Width(1) 150 ) u_err_sync ( 151 .clk_i(clk_reg_i), 152 .rst_ni(rst_reg_ni), 153 .d_i(hold_err), 154 .q_o(reg_cnt_err_o) 155 ); 156 157 always_ff @(posedge clk_i or negedge rst_ni) begin 158 1/1 if (!rst_ni) begin Tests: T4 T5 T6  159 1/1 combined_en_q <= '0; Tests: T4 T5 T6  160 end else begin 161 1/1 combined_en_q <= combined_en_d; Tests: T4 T5 T6 

Cond Coverage for Instance : tb.dut.u_clk_main_hmac_trans
TotalCoveredPercent
Conditions1010100.00
Logical1010100.00
Non-Logical00
Event00

 LINE       45
 EXPRESSION (idle_cnt == 4'(TransIdleCnt))
            ---------------1--------------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

 LINE       46
 EXPRESSION (sw_hint_synced | ((~idle_valid)))
             -------1------   -------2-------
-1--2-StatusTests
00CoveredT6,T27,T28
01CoveredT4,T5,T6
10CoveredT4,T5,T6

 LINE       106
 EXPRESSION (local_en & en_i)
             ----1---   --2-
-1--2-StatusTests
01CoveredT6,T27,T28
10CoveredT4,T5,T6
11CoveredT4,T5,T6

 LINE       125
 EXPRESSION (combined_en_d ? MuBi4False : MuBi4True)
             ------1------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

Branch Coverage for Instance : tb.dut.u_clk_main_hmac_trans
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 125 2 2 100.00
IF 140 3 3 100.00
IF 158 2 2 100.00


125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6


140 if (!rst_ni) begin -1- 141 hold_err <= '0; ==> 142 end else if (cnt_err) begin -2- 143 hold_err <= 1'b1; ==> 144 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T4,T5,T6
0 1 Covered T98,T16,T99
0 0 Covered T4,T5,T6


158 if (!rst_ni) begin -1- 159 combined_en_q <= '0; ==> 160 end else begin 161 combined_en_q <= combined_en_d; ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6

Line Coverage for Instance : tb.dut.u_clk_main_kmac_trans
Line No.TotalCoveredPercent
TOTAL99100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4611100.00
ALWAYS14044100.00
ALWAYS15833100.00

44 logic local_en; 45 1/1 assign idle_valid = (idle_cnt == IdleCntWidth'(TransIdleCnt)); Tests: T4 T5 T6  46 1/1 assign local_en = sw_hint_synced | ~idle_valid; Tests: T4 T5 T6  47 48 prim_flop_2sync #( 49 .Width(1) 50 ) u_hint_sync ( 51 .clk_i(clk_i), 52 .rst_ni(rst_ni), 53 .d_i(sw_hint_i), 54 .q_o(sw_hint_synced) 55 ); 56 57 // Idle sync: Idle signal comes from IP module. The reset of the Idle signal 58 // may differ from the reset here. Adding mubi sync to synchronize. 59 prim_mubi_pkg::mubi4_t [0:0] idle; 60 prim_mubi4_sync #( 61 .NumCopies ( 1 ), 62 .AsyncOn ( 1'b 1 ), 63 .StabilityCheck ( 1'b 1 ) 64 ) u_idle_sync ( 65 .clk_i, 66 .rst_ni, 67 .mubi_i (idle_i), 68 .mubi_o (idle) 69 ); 70 71 // SEC_CM: IDLE.CTR.REDUN 72 logic cnt_err; 73 prim_count #( 74 .Width(IdleCntWidth) 75 ) u_idle_cnt ( 76 .clk_i(clk_i), 77 .rst_ni(rst_ni), 78 // the default condition is to keep the clock enabled 79 .clr_i(mubi4_test_false_loose(idle[0])), 80 .set_i('0), 81 .set_cnt_i('0), 82 .incr_en_i(mubi4_test_true_strict(idle[0]) & ~idle_valid), 83 .decr_en_i(1'b0), 84 .step_i(IdleCntWidth'(1'b1)), 85 .commit_i(1'b1), 86 .cnt_o(idle_cnt), 87 .cnt_after_commit_o(), 88 .err_o(cnt_err) 89 ); 90 91 // Declared as size 1 packed array to avoid FPV warning. 92 prim_mubi_pkg::mubi4_t [0:0] scanmode; 93 prim_mubi4_sync #( 94 .NumCopies(1), 95 .AsyncOn(0) 96 ) u_scanmode_sync ( 97 .clk_i, 98 .rst_ni, 99 .mubi_i(scanmode_i), 100 .mubi_o(scanmode) 101 ); 102 103 // Add a prim buf here to make sure the CG and the lc sender inputs 104 // are derived from the same physical signal. 105 logic combined_en_d, combined_en_q; 106 prim_buf u_prim_buf_en ( 107 .in_i(local_en & en_i), 108 .out_o(combined_en_d) 109 ); 110 111 // clk_gated_i is already controlled by en_i, so there is no need 112 // to use it in the below gating function 113 prim_clock_gating #( 114 .FpgaBufGlobal(FpgaBufGlobal) 115 ) u_cg ( 116 .clk_i(clk_gated_i), 117 .en_i(local_en), 118 .test_en_i(mubi4_test_true_strict(scanmode[0])), 119 .clk_o(clk_o) 120 ); 121 122 // clock gated indication for alert handler 123 prim_mubi4_sender #( 124 .ResetValue(MuBi4True) 125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), 129 .mubi_o(alert_cg_en_o) 130 ); 131 132 // we hold the error because there is no guarantee on 133 // what the timing of cnt_err looks like, it may be a 134 // pulse or it may be level. If it's for former, 135 // prim_sync_reqack may miss it, if it's the latter, 136 // prim_pulse_sync may miss it. As a result, just 137 // latch forever and sync it over. 138 logic hold_err; 139 always_ff @(posedge clk_i or negedge rst_ni) begin 140 1/1 if (!rst_ni) begin Tests: T4 T5 T6  141 1/1 hold_err <= '0; Tests: T4 T5 T6  142 1/1 end else if (cnt_err) begin Tests: T4 T5 T6  143 1/1 hold_err <= 1'b1; Tests: T98 T16 T99  144 end MISSING_ELSE 145 end 146 147 // register facing domain 148 prim_flop_2sync #( 149 .Width(1) 150 ) u_err_sync ( 151 .clk_i(clk_reg_i), 152 .rst_ni(rst_reg_ni), 153 .d_i(hold_err), 154 .q_o(reg_cnt_err_o) 155 ); 156 157 always_ff @(posedge clk_i or negedge rst_ni) begin 158 1/1 if (!rst_ni) begin Tests: T4 T5 T6  159 1/1 combined_en_q <= '0; Tests: T4 T5 T6  160 end else begin 161 1/1 combined_en_q <= combined_en_d; Tests: T4 T5 T6 

Cond Coverage for Instance : tb.dut.u_clk_main_kmac_trans
TotalCoveredPercent
Conditions1010100.00
Logical1010100.00
Non-Logical00
Event00

 LINE       45
 EXPRESSION (idle_cnt == 4'(TransIdleCnt))
            ---------------1--------------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

 LINE       46
 EXPRESSION (sw_hint_synced | ((~idle_valid)))
             -------1------   -------2-------
-1--2-StatusTests
00CoveredT6,T27,T28
01CoveredT4,T5,T6
10CoveredT4,T5,T6

 LINE       106
 EXPRESSION (local_en & en_i)
             ----1---   --2-
-1--2-StatusTests
01CoveredT6,T27,T28
10CoveredT4,T5,T6
11CoveredT4,T5,T6

 LINE       125
 EXPRESSION (combined_en_d ? MuBi4False : MuBi4True)
             ------1------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

Branch Coverage for Instance : tb.dut.u_clk_main_kmac_trans
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 125 2 2 100.00
IF 140 3 3 100.00
IF 158 2 2 100.00


125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6


140 if (!rst_ni) begin -1- 141 hold_err <= '0; ==> 142 end else if (cnt_err) begin -2- 143 hold_err <= 1'b1; ==> 144 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T4,T5,T6
0 1 Covered T98,T16,T99
0 0 Covered T4,T5,T6


158 if (!rst_ni) begin -1- 159 combined_en_q <= '0; ==> 160 end else begin 161 combined_en_q <= combined_en_d; ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6

Line Coverage for Instance : tb.dut.u_clk_main_otbn_trans
Line No.TotalCoveredPercent
TOTAL99100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4611100.00
ALWAYS14044100.00
ALWAYS15833100.00

44 logic local_en; 45 1/1 assign idle_valid = (idle_cnt == IdleCntWidth'(TransIdleCnt)); Tests: T4 T5 T6  46 1/1 assign local_en = sw_hint_synced | ~idle_valid; Tests: T4 T5 T6  47 48 prim_flop_2sync #( 49 .Width(1) 50 ) u_hint_sync ( 51 .clk_i(clk_i), 52 .rst_ni(rst_ni), 53 .d_i(sw_hint_i), 54 .q_o(sw_hint_synced) 55 ); 56 57 // Idle sync: Idle signal comes from IP module. The reset of the Idle signal 58 // may differ from the reset here. Adding mubi sync to synchronize. 59 prim_mubi_pkg::mubi4_t [0:0] idle; 60 prim_mubi4_sync #( 61 .NumCopies ( 1 ), 62 .AsyncOn ( 1'b 1 ), 63 .StabilityCheck ( 1'b 1 ) 64 ) u_idle_sync ( 65 .clk_i, 66 .rst_ni, 67 .mubi_i (idle_i), 68 .mubi_o (idle) 69 ); 70 71 // SEC_CM: IDLE.CTR.REDUN 72 logic cnt_err; 73 prim_count #( 74 .Width(IdleCntWidth) 75 ) u_idle_cnt ( 76 .clk_i(clk_i), 77 .rst_ni(rst_ni), 78 // the default condition is to keep the clock enabled 79 .clr_i(mubi4_test_false_loose(idle[0])), 80 .set_i('0), 81 .set_cnt_i('0), 82 .incr_en_i(mubi4_test_true_strict(idle[0]) & ~idle_valid), 83 .decr_en_i(1'b0), 84 .step_i(IdleCntWidth'(1'b1)), 85 .commit_i(1'b1), 86 .cnt_o(idle_cnt), 87 .cnt_after_commit_o(), 88 .err_o(cnt_err) 89 ); 90 91 // Declared as size 1 packed array to avoid FPV warning. 92 prim_mubi_pkg::mubi4_t [0:0] scanmode; 93 prim_mubi4_sync #( 94 .NumCopies(1), 95 .AsyncOn(0) 96 ) u_scanmode_sync ( 97 .clk_i, 98 .rst_ni, 99 .mubi_i(scanmode_i), 100 .mubi_o(scanmode) 101 ); 102 103 // Add a prim buf here to make sure the CG and the lc sender inputs 104 // are derived from the same physical signal. 105 logic combined_en_d, combined_en_q; 106 prim_buf u_prim_buf_en ( 107 .in_i(local_en & en_i), 108 .out_o(combined_en_d) 109 ); 110 111 // clk_gated_i is already controlled by en_i, so there is no need 112 // to use it in the below gating function 113 prim_clock_gating #( 114 .FpgaBufGlobal(FpgaBufGlobal) 115 ) u_cg ( 116 .clk_i(clk_gated_i), 117 .en_i(local_en), 118 .test_en_i(mubi4_test_true_strict(scanmode[0])), 119 .clk_o(clk_o) 120 ); 121 122 // clock gated indication for alert handler 123 prim_mubi4_sender #( 124 .ResetValue(MuBi4True) 125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), 129 .mubi_o(alert_cg_en_o) 130 ); 131 132 // we hold the error because there is no guarantee on 133 // what the timing of cnt_err looks like, it may be a 134 // pulse or it may be level. If it's for former, 135 // prim_sync_reqack may miss it, if it's the latter, 136 // prim_pulse_sync may miss it. As a result, just 137 // latch forever and sync it over. 138 logic hold_err; 139 always_ff @(posedge clk_i or negedge rst_ni) begin 140 1/1 if (!rst_ni) begin Tests: T4 T5 T6  141 1/1 hold_err <= '0; Tests: T4 T5 T6  142 1/1 end else if (cnt_err) begin Tests: T4 T5 T6  143 1/1 hold_err <= 1'b1; Tests: T98 T16 T99  144 end MISSING_ELSE 145 end 146 147 // register facing domain 148 prim_flop_2sync #( 149 .Width(1) 150 ) u_err_sync ( 151 .clk_i(clk_reg_i), 152 .rst_ni(rst_reg_ni), 153 .d_i(hold_err), 154 .q_o(reg_cnt_err_o) 155 ); 156 157 always_ff @(posedge clk_i or negedge rst_ni) begin 158 1/1 if (!rst_ni) begin Tests: T4 T5 T6  159 1/1 combined_en_q <= '0; Tests: T4 T5 T6  160 end else begin 161 1/1 combined_en_q <= combined_en_d; Tests: T4 T5 T6 

Cond Coverage for Instance : tb.dut.u_clk_main_otbn_trans
TotalCoveredPercent
Conditions1010100.00
Logical1010100.00
Non-Logical00
Event00

 LINE       45
 EXPRESSION (idle_cnt == 4'(TransIdleCnt))
            ---------------1--------------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

 LINE       46
 EXPRESSION (sw_hint_synced | ((~idle_valid)))
             -------1------   -------2-------
-1--2-StatusTests
00CoveredT6,T27,T28
01CoveredT4,T5,T6
10CoveredT4,T5,T6

 LINE       106
 EXPRESSION (local_en & en_i)
             ----1---   --2-
-1--2-StatusTests
01CoveredT6,T27,T28
10CoveredT4,T5,T6
11CoveredT4,T5,T6

 LINE       125
 EXPRESSION (combined_en_d ? MuBi4False : MuBi4True)
             ------1------
-1-StatusTests
0CoveredT4,T5,T6
1CoveredT4,T5,T6

Branch Coverage for Instance : tb.dut.u_clk_main_otbn_trans
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 125 2 2 100.00
IF 140 3 3 100.00
IF 158 2 2 100.00


125 ) u_prim_mubi4_sender ( 126 .clk_i(clk_i), 127 .rst_ni(rst_ni), 128 .mubi_i(combined_en_d ? MuBi4False : MuBi4True), -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6


140 if (!rst_ni) begin -1- 141 hold_err <= '0; ==> 142 end else if (cnt_err) begin -2- 143 hold_err <= 1'b1; ==> 144 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T4,T5,T6
0 1 Covered T98,T16,T99
0 0 Covered T4,T5,T6


158 if (!rst_ni) begin -1- 159 combined_en_q <= '0; ==> 160 end else begin 161 combined_en_q <= combined_en_d; ==>

Branches:
-1-StatusTests
1 Covered T4,T5,T6
0 Covered T4,T5,T6

0% 10% 20% 30% 40% 50% 60% 70% 80% 90% 100%