Line Coverage for Module :
keymgr_data_en_state
| Line No. | Total | Covered | Percent |
TOTAL | | 30 | 29 | 96.67 |
ALWAYS | 69 | 3 | 3 | 100.00 |
ALWAYS | 79 | 27 | 26 | 96.30 |
68 // SEC_CM: DATA.FSM.SPARSE
69 3/3 `PRIM_FLOP_SPARSE_FSM(u_state_regs, state_d, state_q, state_e, StCtrlDataIdle)
Tests: T1 T2 T3 | T1 T2 T3 | T1 T2 T3
PRIM_FLOP_SPARSE_FSM(u_state_regs, state_d, state_q, state_e, StCtrlDataIdle):
69.1 `ifdef SIMULATION
69.2 prim_sparse_fsm_flop #(
69.3 .StateEnumT(state_e),
69.4 .Width($bits(state_e)),
69.5 .ResetValue($bits(state_e)'(StCtrlDataIdle)),
69.6 .EnableAlertTriggerSVA(1),
69.7 .CustomForceName("state_q")
69.8 ) u_state_regs (
69.9 .clk_i ( clk_i ),
69.10 .rst_ni ( rst_ni ),
69.11 .state_i ( state_d ),
69.12 .state_o ( )
69.13 );
69.14 always_ff @(posedge clk_i or negedge rst_ni) begin
69.15 1/1 if (!rst_ni) begin
Tests: T1 T2 T3
69.16 1/1 state_q <= StCtrlDataIdle;
Tests: T1 T2 T3
69.17 end else begin
69.18 1/1 state_q <= state_d;
Tests: T1 T2 T3
69.19 end
69.20 end
69.21 u_state_regs_A: assert property (@(posedge clk_i) disable iff ((!rst_ni) !== '0) (state_q === u_state_regs.state_o))
69.22 else begin
69.23 `ifdef UVM
69.24 uvm_pkg::uvm_report_error("ASSERT FAILED", "u_state_regs_A", uvm_pkg::UVM_NONE,
69.25 "../src/lowrisc_ip_keymgr_0.1/rtl/keymgr_data_en_state.sv", 69, "", 1);
69.26 `else
69.27 $error("%0t: (%0s:%0d) [%m] [ASSERT FAILED] %0s", $time, `__FILE__, `__LINE__,
69.28 `PRIM_STRINGIFY(u_state_regs_A));
69.29 `endif
69.30 end
69.31 `else
69.32 prim_sparse_fsm_flop #(
69.33 .StateEnumT(state_e),
69.34 .Width($bits(state_e)),
69.35 .ResetValue($bits(state_e)'(StCtrlDataIdle)),
69.36 .EnableAlertTriggerSVA(1)
69.37 ) u_state_regs (
69.38 .clk_i ( `PRIM_FLOP_CLK ),
69.39 .rst_ni ( `PRIM_FLOP_RST ),
69.40 .state_i ( state_d ),
69.41 .state_o ( state_q )
69.42 );
69.43 `endif70
71 // The below control path is used for modulating the datapath to sideload and sw keys.
72 // This path is separate from the data_valid_o path, thus creating two separate attack points.
73 // The data is only enabled when a non-advance operation is invoked.
74 // When an advance operation is called, the data is disabled. It will stay disabled until an
75 // entire completion sequence is seen (op_done_o assert -> start_i de-assertion).
76 // When a generate operation is called, the data is enabled. However, any indication of this
77 // supposedly being an advance call will force the path to disable again.
78 always_comb begin
79 1/1 state_d = state_q;
Tests: T1 T2 T3
80 1/1 fsm_err_o = 1'b0;
Tests: T1 T2 T3
81 1/1 data_hw_en_o = 1'b0;
Tests: T1 T2 T3
82 1/1 data_sw_en_o = 1'b0;
Tests: T1 T2 T3
83 1/1 unique case (state_q)
Tests: T1 T2 T3
84
85 StCtrlDataIdle: begin
86 1/1 if (adv_en_i) begin
Tests: T1 T2 T3
87 1/1 state_d = StCtrlDataDis;
Tests: T1 T2 T3
88 1/1 end else if ((id_en_i || gen_en_i) && mubi4_test_true_strict(hw_sel_i)) begin
Tests: T1 T2 T3
89 1/1 state_d = StCtrlDataHwEn;
Tests: T2 T3 T4
90 1/1 end else if ((id_en_i || gen_en_i) && mubi4_test_false_strict(hw_sel_i)) begin
Tests: T1 T2 T3
91 1/1 state_d = StCtrlDataSwEn;
Tests: T1 T2 T5
92 1/1 end else if (id_en_i || gen_en_i) begin
Tests: T1 T2 T3
93 0/1 ==> state_d = StCtrlDataDis;
94 end
MISSING_ELSE
95 end
96
97 StCtrlDataHwEn: begin
98 1/1 data_hw_en_o = 1'b1;
Tests: T2 T3 T4
99 1/1 if (op_done_i) begin
Tests: T2 T3 T4
100 1/1 state_d = StCtrlDataWait;
Tests: T2 T3 T4
101 1/1 end else if (adv_en_i || mubi4_test_false_loose(hw_sel_i)) begin
Tests: T2 T3 T4
102 1/1 state_d = StCtrlDataDis;
Tests: T6 T7 T8
103 end
MISSING_ELSE
104 end
105
106 StCtrlDataSwEn: begin
107 1/1 data_sw_en_o = 1'b1;
Tests: T1 T2 T5
108 1/1 if (op_done_i) begin
Tests: T1 T2 T5
109 1/1 state_d = StCtrlDataWait;
Tests: T1 T2 T5
110 1/1 end else if (adv_en_i || mubi4_test_true_loose(hw_sel_i)) begin
Tests: T1 T2 T5
111 1/1 state_d = StCtrlDataDis;
Tests: T9
112 end
MISSING_ELSE
113 end
114
115 StCtrlDataDis: begin
116 1/1 if (op_done_i) begin
Tests: T1 T2 T3
117 1/1 state_d = StCtrlDataWait;
Tests: T1 T2 T3
118 end
MISSING_ELSE
119 end
120
121 StCtrlDataWait: begin
122 1/1 if (!op_start_i) begin
Tests: T1 T2 T3
123 1/1 state_d = StCtrlDataIdle;
Tests: T1 T2 T3
124 end
==> MISSING_ELSE
125 end
126
127 default: begin
128 fsm_err_o = 1'b1;
Cond Coverage for Module :
keymgr_data_en_state
| Total | Covered | Percent |
Conditions | 3 | 1 | 33.33 |
Logical | 3 | 1 | 33.33 |
Non-Logical | 0 | 0 | |
Event | 0 | 0 | |
LINE 92
EXPRESSION (id_en_i || gen_en_i)
---1--- ----2---
-1- | -2- | Status | Tests |
0 | 0 | Covered | T1,T2,T3 |
0 | 1 | Not Covered | |
1 | 0 | Not Covered | |
FSM Coverage for Module :
keymgr_data_en_state
Summary for FSM :: state_q
| Total | Covered | Percent | |
States |
5 |
5 |
100.00 |
(Not included in score) |
Transitions |
9 |
9 |
100.00 |
|
Sequences |
0 |
0 |
|
|
State, Transition and Sequence Details for FSM :: state_q
states | Line No. | Covered | Tests |
StCtrlDataDis |
87 |
Covered |
T1,T2,T3 |
StCtrlDataHwEn |
89 |
Covered |
T2,T3,T4 |
StCtrlDataIdle |
123 |
Covered |
T1,T2,T3 |
StCtrlDataSwEn |
91 |
Covered |
T1,T2,T5 |
StCtrlDataWait |
100 |
Covered |
T1,T2,T3 |
transitions | Line No. | Covered | Tests |
StCtrlDataDis->StCtrlDataWait |
117 |
Covered |
T1,T2,T3 |
StCtrlDataHwEn->StCtrlDataDis |
102 |
Covered |
T6,T7,T8 |
StCtrlDataHwEn->StCtrlDataWait |
100 |
Covered |
T2,T3,T4 |
StCtrlDataIdle->StCtrlDataDis |
87 |
Covered |
T1,T2,T3 |
StCtrlDataIdle->StCtrlDataHwEn |
89 |
Covered |
T2,T3,T4 |
StCtrlDataIdle->StCtrlDataSwEn |
91 |
Covered |
T1,T2,T5 |
StCtrlDataSwEn->StCtrlDataDis |
111 |
Covered |
T9 |
StCtrlDataSwEn->StCtrlDataWait |
109 |
Covered |
T1,T2,T5 |
StCtrlDataWait->StCtrlDataIdle |
123 |
Covered |
T1,T2,T3 |
Branch Coverage for Module :
keymgr_data_en_state
| Line No. | Total | Covered | Percent |
Branches |
|
18 |
16 |
88.89 |
IF |
69 |
2 |
2 |
100.00 |
CASE |
83 |
16 |
14 |
87.50 |
69 `PRIM_FLOP_SPARSE_FSM(u_state_regs, state_d, state_q, state_e, StCtrlDataIdle)
-1-
==>
==>
Branches:
-1- | Status | Tests |
1 |
Covered |
T1,T2,T3 |
0 |
Covered |
T1,T2,T3 |
83 unique case (state_q)
-1-
84
85 StCtrlDataIdle: begin
86 if (adv_en_i) begin
-2-
87 state_d = StCtrlDataDis;
==>
88 end else if ((id_en_i || gen_en_i) && mubi4_test_true_strict(hw_sel_i)) begin
-3-
89 state_d = StCtrlDataHwEn;
==>
90 end else if ((id_en_i || gen_en_i) && mubi4_test_false_strict(hw_sel_i)) begin
-4-
91 state_d = StCtrlDataSwEn;
==>
92 end else if (id_en_i || gen_en_i) begin
-5-
93 state_d = StCtrlDataDis;
==>
94 end
MISSING_ELSE
==>
95 end
96
97 StCtrlDataHwEn: begin
98 data_hw_en_o = 1'b1;
99 if (op_done_i) begin
-6-
100 state_d = StCtrlDataWait;
==>
101 end else if (adv_en_i || mubi4_test_false_loose(hw_sel_i)) begin
-7-
102 state_d = StCtrlDataDis;
==>
103 end
MISSING_ELSE
==>
104 end
105
106 StCtrlDataSwEn: begin
107 data_sw_en_o = 1'b1;
108 if (op_done_i) begin
-8-
109 state_d = StCtrlDataWait;
==>
110 end else if (adv_en_i || mubi4_test_true_loose(hw_sel_i)) begin
-9-
111 state_d = StCtrlDataDis;
==>
112 end
MISSING_ELSE
==>
113 end
114
115 StCtrlDataDis: begin
116 if (op_done_i) begin
-10-
117 state_d = StCtrlDataWait;
==>
118 end
MISSING_ELSE
==>
119 end
120
121 StCtrlDataWait: begin
122 if (!op_start_i) begin
-11-
123 state_d = StCtrlDataIdle;
==>
124 end
MISSING_ELSE
==>
125 end
126
127 default: begin
128 fsm_err_o = 1'b1;
==>
Branches:
-1- | -2- | -3- | -4- | -5- | -6- | -7- | -8- | -9- | -10- | -11- | Status | Tests |
StCtrlDataIdle |
1 |
- |
- |
- |
- |
- |
- |
- |
- |
- |
Covered |
T1,T2,T3 |
StCtrlDataIdle |
0 |
1 |
- |
- |
- |
- |
- |
- |
- |
- |
Covered |
T2,T3,T4 |
StCtrlDataIdle |
0 |
0 |
1 |
- |
- |
- |
- |
- |
- |
- |
Covered |
T1,T2,T5 |
StCtrlDataIdle |
0 |
0 |
0 |
1 |
- |
- |
- |
- |
- |
- |
Not Covered |
|
StCtrlDataIdle |
0 |
0 |
0 |
0 |
- |
- |
- |
- |
- |
- |
Covered |
T1,T2,T3 |
StCtrlDataHwEn |
- |
- |
- |
- |
1 |
- |
- |
- |
- |
- |
Covered |
T2,T3,T4 |
StCtrlDataHwEn |
- |
- |
- |
- |
0 |
1 |
- |
- |
- |
- |
Covered |
T6,T7,T8 |
StCtrlDataHwEn |
- |
- |
- |
- |
0 |
0 |
- |
- |
- |
- |
Covered |
T2,T3,T4 |
StCtrlDataSwEn |
- |
- |
- |
- |
- |
- |
1 |
- |
- |
- |
Covered |
T1,T2,T5 |
StCtrlDataSwEn |
- |
- |
- |
- |
- |
- |
0 |
1 |
- |
- |
Covered |
T9 |
StCtrlDataSwEn |
- |
- |
- |
- |
- |
- |
0 |
0 |
- |
- |
Covered |
T1,T2,T5 |
StCtrlDataDis |
- |
- |
- |
- |
- |
- |
- |
- |
1 |
- |
Covered |
T1,T2,T3 |
StCtrlDataDis |
- |
- |
- |
- |
- |
- |
- |
- |
0 |
- |
Covered |
T1,T2,T3 |
StCtrlDataWait |
- |
- |
- |
- |
- |
- |
- |
- |
- |
1 |
Covered |
T1,T2,T3 |
StCtrlDataWait |
- |
- |
- |
- |
- |
- |
- |
- |
- |
0 |
Not Covered |
|
default |
- |
- |
- |
- |
- |
- |
- |
- |
- |
- |
Covered |
T10,T11,T12 |
Assert Coverage for Module :
keymgr_data_en_state
Assertion Details
Name | Attempts | Real Successes | Failures | Incomplete |
u_state_regs_A |
18148070 |
17976056 |
0 |
0 |
u_state_regs_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
18148070 |
17976056 |
0 |
0 |
T1 |
2958 |
2872 |
0 |
0 |
T2 |
6298 |
6244 |
0 |
0 |
T3 |
16693 |
16627 |
0 |
0 |
T4 |
3983 |
3916 |
0 |
0 |
T5 |
14313 |
14240 |
0 |
0 |
T13 |
22924 |
22829 |
0 |
0 |
T14 |
9766 |
9669 |
0 |
0 |
T15 |
7284 |
7213 |
0 |
0 |
T16 |
10424 |
10338 |
0 |
0 |
T17 |
8989 |
8890 |
0 |
0 |