Line Coverage for Module :
rv_dm
| Line No. | Total | Covered | Percent |
TOTAL | | 33 | 33 | 100.00 |
CONT_ASSIGN | 122 | 1 | 1 | 100.00 |
CONT_ASSIGN | 123 | 1 | 1 | 100.00 |
CONT_ASSIGN | 128 | 1 | 1 | 100.00 |
CONT_ASSIGN | 131 | 1 | 1 | 100.00 |
CONT_ASSIGN | 154 | 1 | 1 | 100.00 |
CONT_ASSIGN | 236 | 1 | 1 | 100.00 |
CONT_ASSIGN | 237 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 278 | 1 | 1 | 100.00 |
CONT_ASSIGN | 288 | 1 | 1 | 100.00 |
CONT_ASSIGN | 289 | 1 | 1 | 100.00 |
ALWAYS | 320 | 11 | 11 | 100.00 |
CONT_ASSIGN | 345 | 1 | 1 | 100.00 |
CONT_ASSIGN | 432 | 1 | 1 | 100.00 |
CONT_ASSIGN | 438 | 1 | 1 | 100.00 |
CONT_ASSIGN | 440 | 1 | 1 | 100.00 |
CONT_ASSIGN | 446 | 1 | 1 | 100.00 |
CONT_ASSIGN | 447 | 1 | 1 | 100.00 |
CONT_ASSIGN | 523 | 1 | 1 | 100.00 |
CONT_ASSIGN | 551 | 1 | 1 | 100.00 |
WARNING: The source file '/workspace/default/sim-vcs/../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv' or '../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv' was not found, so annotated line coverage report could not be generated.
Line No. | Covered | Statements | |
122 |
1 |
1 |
123 |
1 |
1 |
128 |
1 |
1 |
131 |
1 |
1 |
154 |
1 |
1 |
236 |
1 |
1 |
237 |
1 |
1 |
239 |
4 |
4 |
278 |
1 |
1 |
288 |
1 |
1 |
289 |
1 |
1 |
320 |
1 |
1 |
321 |
1 |
1 |
322 |
1 |
1 |
325 |
1 |
1 |
326 |
1 |
1 |
327 |
1 |
1 |
328 |
1 |
1 |
|
|
|
MISSING_ELSE |
331 |
1 |
1 |
332 |
1 |
1 |
333 |
1 |
1 |
334 |
1 |
1 |
|
|
|
MISSING_ELSE |
345 |
1 |
1 |
432 |
1 |
1 |
438 |
1 |
1 |
440 |
1 |
1 |
446 |
1 |
1 |
447 |
1 |
1 |
523 |
1 |
1 |
551 |
1 |
1 |
Cond Coverage for Module :
rv_dm
| Total | Covered | Percent |
Conditions | 47 | 36 | 76.60 |
Logical | 47 | 36 | 76.60 |
Non-Logical | 0 | 0 | |
Event | 0 | 0 | |
LINE 128
EXPRESSION (regs_intg_error | rom_intg_error | sba_gate_intg_error | rom_gate_intg_error)
-------1------- -------2------ ---------3--------- ---------4---------
-1- | -2- | -3- | -4- | Status | Tests |
0 | 0 | 0 | 0 | Covered | T7,T1,T2 |
0 | 0 | 0 | 1 | Not Covered | |
0 | 0 | 1 | 0 | Not Covered | |
0 | 1 | 0 | 0 | Not Covered | |
1 | 0 | 0 | 0 | Covered | T40,T41,T42 |
LINE 131
SUB-EXPRESSION (regs_reg2hw.alert_test.q & regs_reg2hw.alert_test.qe)
------------1----------- ------------2------------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T27,T28,T39 |
1 | 0 | Covered | T3,T27,T4 |
1 | 1 | Covered | T27,T28,T39 |
LINE 289
EXPRESSION (ndmreset_req_qual & reset_req_en)
--------1-------- ------2-----
-1- | -2- | Status | Tests |
0 | 1 | Covered | T1,T2,T3 |
1 | 0 | Covered | T4,T8,T25 |
1 | 1 | Covered | T4,T8,T25 |
LINE 325
EXPRESSION (ndmreset_req && ((!ndmreset_pending_q)))
------1----- -----------2-----------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Covered | T4,T8,T25 |
1 | 1 | Covered | T4,T8,T25 |
LINE 327
EXPRESSION (ndmreset_ack && ndmreset_pending_q)
------1----- ---------2--------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T4,T8,T25 |
1 | 0 | Not Covered | |
1 | 1 | Covered | T4,T8,T25 |
LINE 331
EXPRESSION (ndmreset_pending_q && lc_rst_asserted)
---------1-------- -------2-------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T27,T4,T28 |
1 | 0 | Covered | T4,T8,T25 |
1 | 1 | Covered | T4,T8,T25 |
LINE 333
EXPRESSION (ndmreset_ack && lc_rst_pending_q)
------1----- --------2-------
-1- | -2- | Status | Tests |
0 | 1 | Not Covered | |
1 | 0 | Not Covered | |
1 | 1 | Covered | T4,T8,T25 |
LINE 345
EXPRESSION (ndmreset_pending_q && lc_rst_pending_q && ((!ndmreset_req)) && ((!lc_rst_asserted)) && reset_req_en)
---------1-------- --------2------- --------3-------- ----------4--------- ------5-----
-1- | -2- | -3- | -4- | -5- | Status | Tests |
0 | 1 | 1 | 1 | 1 | Not Covered | |
1 | 0 | 1 | 1 | 1 | Covered | T4,T5,T6 |
1 | 1 | 0 | 1 | 1 | Not Covered | |
1 | 1 | 1 | 0 | 1 | Covered | T4,T8,T25 |
1 | 1 | 1 | 1 | 0 | Not Covered | |
1 | 1 | 1 | 1 | 1 | Covered | T4,T8,T25 |
LINE 440
EXPRESSION (debug_req & debug_req_en)
----1---- ------2-----
-1- | -2- | Status | Tests |
0 | 1 | Covered | T1,T2,T3 |
1 | 0 | Covered | T4,T5,T12 |
1 | 1 | Covered | T4,T5,T6 |
LINE 476
EXPRESSION (dmi_req_ready & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Covered | T4,T21,T5 |
1 | 1 | Covered | T7,T1,T2 |
LINE 476
EXPRESSION (dmi_rsp_valid & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Not Covered | |
1 | 1 | Covered | T7,T1,T2 |
LINE 551
EXPRESSION (device_we || device_re)
----1---- ----2----
-1- | -2- | Status | Tests |
0 | 0 | Covered | T7,T1,T2 |
0 | 1 | Covered | T4,T8,T25 |
1 | 0 | Covered | T4,T8,T25 |
LINE 567
EXPRESSION (dmi_req_valid & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Not Covered | |
1 | 1 | Covered | T7,T1,T2 |
LINE 567
EXPRESSION (dmi_rsp_ready & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Covered | T4,T21,T5 |
1 | 1 | Covered | T7,T1,T2 |
Toggle Coverage for Module :
rv_dm
| Total | Covered | Percent |
Totals |
98 |
80 |
81.63 |
Total Bits |
1140 |
1056 |
92.63 |
Total Bits 0->1 |
570 |
528 |
92.63 |
Total Bits 1->0 |
570 |
528 |
92.63 |
| | | |
Ports |
98 |
80 |
81.63 |
Port Bits |
1140 |
1056 |
92.63 |
Port Bits 0->1 |
570 |
528 |
92.63 |
Port Bits 1->0 |
570 |
528 |
92.63 |
Port Details
Name | Toggle | Toggle 1->0 | Tests | Toggle 0->1 | Tests | Direction |
clk_i |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
clk_lc_i |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
rst_ni |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
INPUT |
rst_lc_ni |
Yes |
Yes |
T4,T8,T25 |
Yes |
T7,T1,T2 |
INPUT |
next_dm_addr_i[31:0] |
Unreachable |
Unreachable |
|
Unreachable |
|
INPUT |
lc_hw_debug_en_i[3:0] |
Yes |
Yes |
T4,T25,T5 |
Yes |
T4,T25,T5 |
INPUT |
lc_dft_en_i[3:0] |
No |
No |
|
No |
|
INPUT |
pinmux_hw_debug_en_i[3:0] |
Yes |
Yes |
T24,T18,T9 |
Yes |
T24,T18,T9 |
INPUT |
otp_dis_rv_dm_late_debug_i[7:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
scanmode_i[3:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
scan_rst_ni |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
INPUT |
ndmreset_req_o |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T8,T25 |
OUTPUT |
dmactive_o |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
OUTPUT |
debug_req_o |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
OUTPUT |
unavailable_i |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T5,T6 |
INPUT |
regs_tl_d_i.d_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
regs_tl_d_i.a_user.data_intg[6:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
regs_tl_d_i.a_user.cmd_intg[6:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
regs_tl_d_i.a_user.instr_type[3:0] |
Yes |
Yes |
T27,T4,T39 |
Yes |
T27,T4,T39 |
INPUT |
regs_tl_d_i.a_user.rsvd[4:0] |
Yes |
Yes |
T27,T39,T5 |
Yes |
T27,T39,T5 |
INPUT |
regs_tl_d_i.a_data[31:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
regs_tl_d_i.a_mask[3:0] |
Yes |
Yes |
T27,T4,T39 |
Yes |
T27,T4,T39 |
INPUT |
regs_tl_d_i.a_address[31:0] |
Yes |
Yes |
T27,T4,T39 |
Yes |
T27,T4,T39 |
INPUT |
regs_tl_d_i.a_source[7:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
regs_tl_d_i.a_size[1:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
regs_tl_d_i.a_param[2:0] |
Yes |
Yes |
T27,T39,T5 |
Yes |
T27,T39,T5 |
INPUT |
regs_tl_d_i.a_opcode[2:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
regs_tl_d_i.a_valid |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
regs_tl_d_o.a_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
regs_tl_d_o.d_error |
Yes |
Yes |
T4,T5,T12 |
Yes |
T4,T5,T12 |
OUTPUT |
regs_tl_d_o.d_user.data_intg[6:0] |
Yes |
Yes |
T4,T5,T12 |
Yes |
T4,T5,T12 |
OUTPUT |
regs_tl_d_o.d_user.rsp_intg[5:0] |
Yes |
Yes |
*T27,T4,*T28 |
Yes |
T7,T1,T2 |
OUTPUT |
regs_tl_d_o.d_user.rsp_intg[6] |
No |
No |
|
No |
|
OUTPUT |
regs_tl_d_o.d_data[31:0] |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
OUTPUT |
regs_tl_d_o.d_sink |
No |
No |
|
No |
|
OUTPUT |
regs_tl_d_o.d_source[7:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T7,T1,T2 |
OUTPUT |
regs_tl_d_o.d_size[1:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
OUTPUT |
regs_tl_d_o.d_param[2:0] |
No |
No |
|
No |
|
OUTPUT |
regs_tl_d_o.d_opcode[0] |
Yes |
Yes |
*T4,*T5,*T12 |
Yes |
T4,T5,T12 |
OUTPUT |
regs_tl_d_o.d_opcode[2:1] |
No |
No |
|
No |
|
OUTPUT |
regs_tl_d_o.d_valid |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
mem_tl_d_i.d_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
mem_tl_d_i.a_user.data_intg[6:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T2,T4,T8 |
INPUT |
mem_tl_d_i.a_user.cmd_intg[6:0] |
Yes |
Yes |
T4,T8,T5 |
Yes |
T2,T4,T5 |
INPUT |
mem_tl_d_i.a_user.instr_type[3:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T2,T4,T5 |
INPUT |
mem_tl_d_i.a_user.rsvd[4:0] |
Yes |
Yes |
T5,T6,T24 |
Yes |
T5,T6,T59 |
INPUT |
mem_tl_d_i.a_data[31:0] |
Yes |
Yes |
T2,T4,T8 |
Yes |
T4,T5,T6 |
INPUT |
mem_tl_d_i.a_mask[3:0] |
Yes |
Yes |
T4,T25,T5 |
Yes |
T4,T5,T6 |
INPUT |
mem_tl_d_i.a_address[31:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
mem_tl_d_i.a_source[7:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
mem_tl_d_i.a_size[1:0] |
Yes |
Yes |
T2,T4,T5 |
Yes |
T4,T25,T5 |
INPUT |
mem_tl_d_i.a_param[2:0] |
Yes |
Yes |
T5,T6,T24 |
Yes |
T5,T6,T60 |
INPUT |
mem_tl_d_i.a_opcode[2:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T2,T4,T5 |
INPUT |
mem_tl_d_i.a_valid |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T8,T25 |
INPUT |
mem_tl_d_o.a_ready |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
mem_tl_d_o.d_error |
Yes |
Yes |
T1,T2,T3 |
Yes |
T4,T8,T25 |
OUTPUT |
mem_tl_d_o.d_user.data_intg[6:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
OUTPUT |
mem_tl_d_o.d_user.rsp_intg[5:0] |
Yes |
Yes |
T4,*T8,T25 |
Yes |
T4,T8,T25 |
OUTPUT |
mem_tl_d_o.d_user.rsp_intg[6] |
No |
No |
|
No |
|
OUTPUT |
mem_tl_d_o.d_data[31:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T4,T8,T25 |
OUTPUT |
mem_tl_d_o.d_sink |
No |
No |
|
No |
|
OUTPUT |
mem_tl_d_o.d_source[7:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
OUTPUT |
mem_tl_d_o.d_size[1:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T25,T5 |
OUTPUT |
mem_tl_d_o.d_param[2:0] |
No |
No |
|
No |
|
OUTPUT |
mem_tl_d_o.d_opcode[0] |
Yes |
Yes |
*T1,*T2,*T3 |
Yes |
T4,T8,T25 |
OUTPUT |
mem_tl_d_o.d_opcode[2:1] |
No |
No |
|
No |
|
OUTPUT |
mem_tl_d_o.d_valid |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T8,T25 |
OUTPUT |
sba_tl_h_o.d_ready |
Yes |
Yes |
T4,T8,T25 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_user.data_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_user.cmd_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_user.instr_type[0] |
Yes |
Yes |
*T4,*T8,*T25 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_user.instr_type[2:1] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_user.instr_type[3] |
Yes |
Yes |
T4,T8,T25 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_user.rsvd[4:0] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_data[31:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_mask[3:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_address[1:0] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_address[31:2] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_source[7:0] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_size[0] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_size[1] |
Yes |
Yes |
T4,T8,T25 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_param[2:0] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_opcode[0] |
Yes |
Yes |
*T1,*T2,*T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_opcode[1] |
No |
No |
|
No |
|
OUTPUT |
sba_tl_h_o.a_opcode[2] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_o.a_valid |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
sba_tl_h_i.a_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
sba_tl_h_i.d_error |
Yes |
Yes |
T7,T21,T47 |
Yes |
T21,T52,T51 |
INPUT |
sba_tl_h_i.d_user.data_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
sba_tl_h_i.d_user.rsp_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T7,T1,T2 |
INPUT |
sba_tl_h_i.d_data[31:0] |
Yes |
Yes |
T7,T1,T2 |
Yes |
T1,T2,T3 |
INPUT |
sba_tl_h_i.d_sink |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
sba_tl_h_i.d_source[7:0] |
Yes |
Yes |
T21,T51,T61 |
Yes |
T21,T52,T51 |
INPUT |
sba_tl_h_i.d_size[1:0] |
Yes |
Yes |
T21,T51,T61 |
Yes |
T21,T39,T51 |
INPUT |
sba_tl_h_i.d_param[2:0] |
Yes |
Yes |
T7,T21,T51 |
Yes |
T21,T52,T51 |
INPUT |
sba_tl_h_i.d_opcode[2:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
sba_tl_h_i.d_valid |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
alert_rx_i[0].ack_n |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
alert_rx_i[0].ack_p |
Yes |
Yes |
T27,T28,T39 |
Yes |
T27,T28,T39 |
INPUT |
alert_rx_i[0].ping_n |
No |
No |
|
No |
|
INPUT |
alert_rx_i[0].ping_p |
No |
No |
|
No |
|
INPUT |
alert_tx_o[0].alert_n |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
alert_tx_o[0].alert_p |
Yes |
Yes |
T27,T28,T39 |
Yes |
T27,T28,T39 |
OUTPUT |
jtag_i.tdi |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
jtag_i.trst_n |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
INPUT |
jtag_i.tms |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
jtag_i.tck |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
jtag_o.tdo_oe |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
jtag_o.tdo |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
*Tests covering at least one bit in the range
Branch Coverage for Module :
rv_dm
| Line No. | Total | Covered | Percent |
Branches |
|
7 |
7 |
100.00 |
IF |
320 |
7 |
7 |
100.00 |
WARNING: The source file /workspace/default/sim-vcs/../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv' or '../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv was not found/opened, so annotated branch coverage report could not be generated.
LineNo. Expression
-1-: 320 if ((!rst_ni))
-2-: 325 if ((ndmreset_req && (!ndmreset_pending_q)))
-3-: 327 if ((ndmreset_ack && ndmreset_pending_q))
-4-: 331 if ((ndmreset_pending_q && lc_rst_asserted))
-5-: 333 if ((ndmreset_ack && lc_rst_pending_q))
Branches:
-1- | -2- | -3- | -4- | -5- | Status | Tests |
1 |
- |
- |
- |
- |
Covered |
T7,T1,T2 |
0 |
1 |
- |
- |
- |
Covered |
T4,T8,T25 |
0 |
0 |
1 |
- |
- |
Covered |
T4,T8,T25 |
0 |
0 |
0 |
- |
- |
Covered |
T7,T1,T2 |
0 |
- |
- |
1 |
- |
Covered |
T4,T8,T25 |
0 |
- |
- |
0 |
1 |
Covered |
T4,T8,T25 |
0 |
- |
- |
0 |
0 |
Covered |
T7,T1,T2 |
Assert Coverage for Module :
rv_dm
Assertion Details
DebugReqOKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
DmactiveOKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
FpvSecCmRegWeOnehotCheck_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
80 |
0 |
0 |
T14 |
4711 |
0 |
0 |
0 |
T40 |
61148 |
20 |
0 |
0 |
T41 |
0 |
10 |
0 |
0 |
T42 |
0 |
20 |
0 |
0 |
T62 |
0 |
20 |
0 |
0 |
T63 |
0 |
10 |
0 |
0 |
T64 |
69666 |
0 |
0 |
0 |
T65 |
2996 |
0 |
0 |
0 |
T66 |
3975 |
0 |
0 |
0 |
T67 |
18720 |
0 |
0 |
0 |
T68 |
4190 |
0 |
0 |
0 |
T69 |
5187 |
0 |
0 |
0 |
T70 |
381547 |
0 |
0 |
0 |
T71 |
95277 |
0 |
0 |
0 |
FpvSecCmRomTlLcGateFsm_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
0 |
0 |
0 |
FpvSecCmSbaTlLcGateFsm_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
0 |
0 |
0 |
JtagRspOTdoKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
4931407 |
4931264 |
0 |
0 |
T1 |
14185 |
14185 |
0 |
0 |
T2 |
15474 |
15474 |
0 |
0 |
T3 |
16003 |
16003 |
0 |
0 |
T4 |
148516 |
148514 |
0 |
0 |
T7 |
5918 |
5918 |
0 |
0 |
T8 |
1003 |
1003 |
0 |
0 |
T21 |
25578 |
25578 |
0 |
0 |
T25 |
1034 |
1034 |
0 |
0 |
T27 |
185 |
185 |
0 |
0 |
T28 |
385 |
385 |
0 |
0 |
JtagRspOTdoOeKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
4931407 |
4931264 |
0 |
0 |
T1 |
14185 |
14185 |
0 |
0 |
T2 |
15474 |
15474 |
0 |
0 |
T3 |
16003 |
16003 |
0 |
0 |
T4 |
148516 |
148514 |
0 |
0 |
T7 |
5918 |
5918 |
0 |
0 |
T8 |
1003 |
1003 |
0 |
0 |
T21 |
25578 |
25578 |
0 |
0 |
T25 |
1034 |
1034 |
0 |
0 |
T27 |
185 |
185 |
0 |
0 |
T28 |
385 |
385 |
0 |
0 |
NdmresetOKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
RvDmLcEnDebugVal_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlMemAReadyKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlMemDValidKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlRegsAReadyKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlRegsDValidKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlSbaAValidKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlSbaDReadyKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
paramCheckNrHarts
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
245 |
245 |
0 |
0 |
T1 |
1 |
1 |
0 |
0 |
T2 |
1 |
1 |
0 |
0 |
T3 |
1 |
1 |
0 |
0 |
T4 |
1 |
1 |
0 |
0 |
T7 |
1 |
1 |
0 |
0 |
T8 |
1 |
1 |
0 |
0 |
T21 |
1 |
1 |
0 |
0 |
T25 |
1 |
1 |
0 |
0 |
T27 |
1 |
1 |
0 |
0 |
T28 |
1 |
1 |
0 |
0 |
Line Coverage for Instance : tb.dut
| Line No. | Total | Covered | Percent |
TOTAL | | 33 | 33 | 100.00 |
CONT_ASSIGN | 122 | 1 | 1 | 100.00 |
CONT_ASSIGN | 123 | 1 | 1 | 100.00 |
CONT_ASSIGN | 128 | 1 | 1 | 100.00 |
CONT_ASSIGN | 131 | 1 | 1 | 100.00 |
CONT_ASSIGN | 154 | 1 | 1 | 100.00 |
CONT_ASSIGN | 236 | 1 | 1 | 100.00 |
CONT_ASSIGN | 237 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 239 | 1 | 1 | 100.00 |
CONT_ASSIGN | 278 | 1 | 1 | 100.00 |
CONT_ASSIGN | 288 | 1 | 1 | 100.00 |
CONT_ASSIGN | 289 | 1 | 1 | 100.00 |
ALWAYS | 320 | 11 | 11 | 100.00 |
CONT_ASSIGN | 345 | 1 | 1 | 100.00 |
CONT_ASSIGN | 432 | 1 | 1 | 100.00 |
CONT_ASSIGN | 438 | 1 | 1 | 100.00 |
CONT_ASSIGN | 440 | 1 | 1 | 100.00 |
CONT_ASSIGN | 446 | 1 | 1 | 100.00 |
CONT_ASSIGN | 447 | 1 | 1 | 100.00 |
CONT_ASSIGN | 523 | 1 | 1 | 100.00 |
CONT_ASSIGN | 551 | 1 | 1 | 100.00 |
WARNING: The source file '/workspace/default/sim-vcs/../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv' or '../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv' was not found, so annotated line coverage report could not be generated.
Line No. | Covered | Statements | |
122 |
1 |
1 |
123 |
1 |
1 |
128 |
1 |
1 |
131 |
1 |
1 |
154 |
1 |
1 |
236 |
1 |
1 |
237 |
1 |
1 |
239 |
4 |
4 |
278 |
1 |
1 |
288 |
1 |
1 |
289 |
1 |
1 |
320 |
1 |
1 |
321 |
1 |
1 |
322 |
1 |
1 |
325 |
1 |
1 |
326 |
1 |
1 |
327 |
1 |
1 |
328 |
1 |
1 |
|
|
|
MISSING_ELSE |
331 |
1 |
1 |
332 |
1 |
1 |
333 |
1 |
1 |
334 |
1 |
1 |
|
|
|
MISSING_ELSE |
345 |
1 |
1 |
432 |
1 |
1 |
438 |
1 |
1 |
440 |
1 |
1 |
446 |
1 |
1 |
447 |
1 |
1 |
523 |
1 |
1 |
551 |
1 |
1 |
Cond Coverage for Instance : tb.dut
| Total | Covered | Percent |
Conditions | 42 | 36 | 85.71 |
Logical | 42 | 36 | 85.71 |
Non-Logical | 0 | 0 | |
Event | 0 | 0 | |
LINE 128
EXPRESSION (regs_intg_error | rom_intg_error | sba_gate_intg_error | rom_gate_intg_error)
-------1------- -------2------ ---------3--------- ---------4---------
-1- | -2- | -3- | -4- | Status | Tests | Exclude Annotation |
0 | 0 | 0 | 0 | Covered | T7,T1,T2 |
0 | 0 | 0 | 1 | Excluded | |
VC_COV_UNR |
0 | 0 | 1 | 0 | Excluded | |
VC_COV_UNR |
0 | 1 | 0 | 0 | Not Covered | |
1 | 0 | 0 | 0 | Covered | T40,T41,T42 |
LINE 131
SUB-EXPRESSION (regs_reg2hw.alert_test.q & regs_reg2hw.alert_test.qe)
------------1----------- ------------2------------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T27,T28,T39 |
1 | 0 | Covered | T3,T27,T4 |
1 | 1 | Covered | T27,T28,T39 |
LINE 289
EXPRESSION (ndmreset_req_qual & reset_req_en)
--------1-------- ------2-----
-1- | -2- | Status | Tests |
0 | 1 | Covered | T1,T2,T3 |
1 | 0 | Covered | T4,T8,T25 |
1 | 1 | Covered | T4,T8,T25 |
LINE 325
EXPRESSION (ndmreset_req && ((!ndmreset_pending_q)))
------1----- -----------2-----------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Covered | T4,T8,T25 |
1 | 1 | Covered | T4,T8,T25 |
LINE 327
EXPRESSION (ndmreset_ack && ndmreset_pending_q)
------1----- ---------2--------
-1- | -2- | Status | Tests | Exclude Annotation |
0 | 1 | Covered | T4,T8,T25 |
1 | 0 | Excluded | |
VC_COV_UNR |
1 | 1 | Covered | T4,T8,T25 |
LINE 331
EXPRESSION (ndmreset_pending_q && lc_rst_asserted)
---------1-------- -------2-------
-1- | -2- | Status | Tests |
0 | 1 | Covered | T27,T4,T28 |
1 | 0 | Covered | T4,T8,T25 |
1 | 1 | Covered | T4,T8,T25 |
LINE 333
EXPRESSION (ndmreset_ack && lc_rst_pending_q)
------1----- --------2-------
-1- | -2- | Status | Tests | Exclude Annotation |
0 | 1 | Not Covered | |
1 | 0 | Excluded | |
VC_COV_UNR |
1 | 1 | Covered | T4,T8,T25 |
LINE 345
EXPRESSION (ndmreset_pending_q && lc_rst_pending_q && ((!ndmreset_req)) && ((!lc_rst_asserted)) && reset_req_en)
---------1-------- --------2------- --------3-------- ----------4--------- ------5-----
-1- | -2- | -3- | -4- | -5- | Status | Tests | Exclude Annotation |
0 | 1 | 1 | 1 | 1 | Excluded | |
VC_COV_UNR |
1 | 0 | 1 | 1 | 1 | Covered | T4,T5,T6 |
1 | 1 | 0 | 1 | 1 | Not Covered | |
1 | 1 | 1 | 0 | 1 | Covered | T4,T8,T25 |
1 | 1 | 1 | 1 | 0 | Not Covered | |
1 | 1 | 1 | 1 | 1 | Covered | T4,T8,T25 |
LINE 440
EXPRESSION (debug_req & debug_req_en)
----1---- ------2-----
-1- | -2- | Status | Tests |
0 | 1 | Covered | T1,T2,T3 |
1 | 0 | Covered | T4,T5,T12 |
1 | 1 | Covered | T4,T5,T6 |
LINE 476
EXPRESSION (dmi_req_ready & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Covered | T4,T21,T5 |
1 | 1 | Covered | T7,T1,T2 |
LINE 476
EXPRESSION (dmi_rsp_valid & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Not Covered | |
1 | 1 | Covered | T7,T1,T2 |
LINE 551
EXPRESSION (device_we || device_re)
----1---- ----2----
-1- | -2- | Status | Tests |
0 | 0 | Covered | T7,T1,T2 |
0 | 1 | Covered | T4,T8,T25 |
1 | 0 | Covered | T4,T8,T25 |
LINE 567
EXPRESSION (dmi_req_valid & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Not Covered | |
1 | 1 | Covered | T7,T1,T2 |
LINE 567
EXPRESSION (dmi_rsp_ready & dmi_en)
------1------ ---2--
-1- | -2- | Status | Tests |
0 | 1 | Covered | T7,T1,T2 |
1 | 0 | Covered | T4,T21,T5 |
1 | 1 | Covered | T7,T1,T2 |
Toggle Coverage for Instance : tb.dut
| Total | Covered | Percent |
Totals |
91 |
84 |
92.31 |
Total Bits |
1082 |
1056 |
97.60 |
Total Bits 0->1 |
541 |
528 |
97.60 |
Total Bits 1->0 |
541 |
528 |
97.60 |
| | | |
Ports |
91 |
84 |
92.31 |
Port Bits |
1082 |
1056 |
97.60 |
Port Bits 0->1 |
541 |
528 |
97.60 |
Port Bits 1->0 |
541 |
528 |
97.60 |
Port Details
Name | Toggle | Toggle 1->0 | Tests | Toggle 0->1 | Tests | Direction | Exclude Annotation |
clk_i |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
clk_lc_i |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
rst_ni |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
INPUT |
|
rst_lc_ni |
Yes |
Yes |
T4,T8,T25 |
Yes |
T7,T1,T2 |
INPUT |
|
next_dm_addr_i[31:0] |
Unreachable |
Unreachable |
|
Unreachable |
|
INPUT |
|
lc_hw_debug_en_i[3:0] |
Yes |
Yes |
T4,T25,T5 |
Yes |
T4,T25,T5 |
INPUT |
|
lc_dft_en_i[3:0] |
No |
No |
|
No |
|
INPUT |
|
pinmux_hw_debug_en_i[3:0] |
Yes |
Yes |
T24,T18,T9 |
Yes |
T24,T18,T9 |
INPUT |
|
otp_dis_rv_dm_late_debug_i[7:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
|
scanmode_i[3:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
|
scan_rst_ni |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
INPUT |
|
ndmreset_req_o |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T8,T25 |
OUTPUT |
|
dmactive_o |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
OUTPUT |
|
debug_req_o |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
OUTPUT |
|
unavailable_i |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T5,T6 |
INPUT |
|
regs_tl_d_i.d_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
regs_tl_d_i.a_user.data_intg[6:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
|
regs_tl_d_i.a_user.cmd_intg[6:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
|
regs_tl_d_i.a_user.instr_type[3:0] |
Yes |
Yes |
T27,T4,T39 |
Yes |
T27,T4,T39 |
INPUT |
|
regs_tl_d_i.a_user.rsvd[4:0] |
Yes |
Yes |
T27,T39,T5 |
Yes |
T27,T39,T5 |
INPUT |
|
regs_tl_d_i.a_data[31:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
|
regs_tl_d_i.a_mask[3:0] |
Yes |
Yes |
T27,T4,T39 |
Yes |
T27,T4,T39 |
INPUT |
|
regs_tl_d_i.a_address[31:0] |
Yes |
Yes |
T27,T4,T39 |
Yes |
T27,T4,T39 |
INPUT |
|
regs_tl_d_i.a_source[7:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
|
regs_tl_d_i.a_size[1:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
|
regs_tl_d_i.a_param[2:0] |
Yes |
Yes |
T27,T39,T5 |
Yes |
T27,T39,T5 |
INPUT |
|
regs_tl_d_i.a_opcode[2:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
INPUT |
|
regs_tl_d_i.a_valid |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
regs_tl_d_o.a_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
|
regs_tl_d_o.d_error |
Yes |
Yes |
T4,T5,T12 |
Yes |
T4,T5,T12 |
OUTPUT |
|
regs_tl_d_o.d_user.data_intg[6:0] |
Yes |
Yes |
T4,T5,T12 |
Yes |
T4,T5,T12 |
OUTPUT |
|
regs_tl_d_o.d_user.rsp_intg[5:0] |
Yes |
Yes |
*T27,T4,*T28 |
Yes |
T7,T1,T2 |
OUTPUT |
|
regs_tl_d_o.d_user.rsp_intg[6] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
regs_tl_d_o.d_data[31:0] |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
OUTPUT |
|
regs_tl_d_o.d_sink |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
regs_tl_d_o.d_source[7:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T7,T1,T2 |
OUTPUT |
|
regs_tl_d_o.d_size[1:0] |
Yes |
Yes |
T27,T4,T28 |
Yes |
T27,T4,T28 |
OUTPUT |
|
regs_tl_d_o.d_param[2:0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
regs_tl_d_o.d_opcode[0] |
Yes |
Yes |
*T4,*T5,*T12 |
Yes |
T4,T5,T12 |
OUTPUT |
|
regs_tl_d_o.d_opcode[2:1] |
No |
No |
|
No |
|
OUTPUT |
|
regs_tl_d_o.d_valid |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
|
mem_tl_d_i.d_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
mem_tl_d_i.a_user.data_intg[6:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T2,T4,T8 |
INPUT |
|
mem_tl_d_i.a_user.cmd_intg[6:0] |
Yes |
Yes |
T4,T8,T5 |
Yes |
T2,T4,T5 |
INPUT |
|
mem_tl_d_i.a_user.instr_type[3:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T2,T4,T5 |
INPUT |
|
mem_tl_d_i.a_user.rsvd[4:0] |
Yes |
Yes |
T5,T6,T24 |
Yes |
T5,T6,T59 |
INPUT |
|
mem_tl_d_i.a_data[31:0] |
Yes |
Yes |
T2,T4,T8 |
Yes |
T4,T5,T6 |
INPUT |
|
mem_tl_d_i.a_mask[3:0] |
Yes |
Yes |
T4,T25,T5 |
Yes |
T4,T5,T6 |
INPUT |
|
mem_tl_d_i.a_address[31:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
|
mem_tl_d_i.a_source[7:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
INPUT |
|
mem_tl_d_i.a_size[1:0] |
Yes |
Yes |
T2,T4,T5 |
Yes |
T4,T25,T5 |
INPUT |
|
mem_tl_d_i.a_param[2:0] |
Yes |
Yes |
T5,T6,T24 |
Yes |
T5,T6,T60 |
INPUT |
|
mem_tl_d_i.a_opcode[2:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T2,T4,T5 |
INPUT |
|
mem_tl_d_i.a_valid |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T8,T25 |
INPUT |
|
mem_tl_d_o.a_ready |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
mem_tl_d_o.d_error |
Yes |
Yes |
T1,T2,T3 |
Yes |
T4,T8,T25 |
OUTPUT |
|
mem_tl_d_o.d_user.data_intg[6:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
OUTPUT |
|
mem_tl_d_o.d_user.rsp_intg[5:0] |
Yes |
Yes |
T4,*T8,T25 |
Yes |
T4,T8,T25 |
OUTPUT |
|
mem_tl_d_o.d_user.rsp_intg[6] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
mem_tl_d_o.d_data[31:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T4,T8,T25 |
OUTPUT |
|
mem_tl_d_o.d_sink |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
mem_tl_d_o.d_source[7:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T5,T6 |
OUTPUT |
|
mem_tl_d_o.d_size[1:0] |
Yes |
Yes |
T4,T5,T6 |
Yes |
T4,T25,T5 |
OUTPUT |
|
mem_tl_d_o.d_param[2:0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
mem_tl_d_o.d_opcode[0] |
Yes |
Yes |
*T1,*T2,*T3 |
Yes |
T4,T8,T25 |
OUTPUT |
|
mem_tl_d_o.d_opcode[2:1] |
No |
No |
|
No |
|
OUTPUT |
|
mem_tl_d_o.d_valid |
Yes |
Yes |
T4,T8,T25 |
Yes |
T4,T8,T25 |
OUTPUT |
|
sba_tl_h_o.d_ready |
Yes |
Yes |
T4,T8,T25 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_user.data_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_user.cmd_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_user.instr_type[0] |
Yes |
Yes |
*T4,*T8,*T25 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_user.instr_type[2:1] |
No |
No |
|
No |
|
OUTPUT |
|
sba_tl_h_o.a_user.instr_type[3] |
Yes |
Yes |
T4,T8,T25 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_user.rsvd[4:0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
sba_tl_h_o.a_data[31:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_mask[3:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_address[1:0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
sba_tl_h_o.a_address[31:2] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_source[7:0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
sba_tl_h_o.a_size[0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
sba_tl_h_o.a_size[1] |
Yes |
Yes |
T4,T8,T25 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_param[2:0] |
Excluded |
Excluded |
|
Excluded |
|
OUTPUT |
0->1:VC_COV_UNR / 1->0:VC_COV_UNR |
sba_tl_h_o.a_opcode[0] |
Yes |
Yes |
*T1,*T2,*T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_opcode[1] |
No |
No |
|
No |
|
OUTPUT |
|
sba_tl_h_o.a_opcode[2] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_o.a_valid |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
OUTPUT |
|
sba_tl_h_i.a_ready |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
sba_tl_h_i.d_error |
Yes |
Yes |
T7,T21,T47 |
Yes |
T21,T52,T51 |
INPUT |
|
sba_tl_h_i.d_user.data_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
|
sba_tl_h_i.d_user.rsp_intg[6:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T7,T1,T2 |
INPUT |
|
sba_tl_h_i.d_data[31:0] |
Yes |
Yes |
T7,T1,T2 |
Yes |
T1,T2,T3 |
INPUT |
|
sba_tl_h_i.d_sink |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
|
sba_tl_h_i.d_source[7:0] |
Yes |
Yes |
T21,T51,T61 |
Yes |
T21,T52,T51 |
INPUT |
|
sba_tl_h_i.d_size[1:0] |
Yes |
Yes |
T21,T51,T61 |
Yes |
T21,T39,T51 |
INPUT |
|
sba_tl_h_i.d_param[2:0] |
Yes |
Yes |
T7,T21,T51 |
Yes |
T21,T52,T51 |
INPUT |
|
sba_tl_h_i.d_opcode[2:0] |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
|
sba_tl_h_i.d_valid |
Yes |
Yes |
T1,T2,T3 |
Yes |
T1,T2,T3 |
INPUT |
|
alert_rx_i[0].ack_n |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
alert_rx_i[0].ack_p |
Yes |
Yes |
T27,T28,T39 |
Yes |
T27,T28,T39 |
INPUT |
|
alert_rx_i[0].ping_n |
No |
No |
|
No |
|
INPUT |
|
alert_rx_i[0].ping_p |
No |
No |
|
No |
|
INPUT |
|
alert_tx_o[0].alert_n |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
|
alert_tx_o[0].alert_p |
Yes |
Yes |
T27,T28,T39 |
Yes |
T27,T28,T39 |
OUTPUT |
|
jtag_i.tdi |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
jtag_i.trst_n |
Yes |
Yes |
T4,T21,T5 |
Yes |
T7,T1,T2 |
INPUT |
|
jtag_i.tms |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
jtag_i.tck |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
INPUT |
|
jtag_o.tdo_oe |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
|
jtag_o.tdo |
Yes |
Yes |
T7,T1,T2 |
Yes |
T7,T1,T2 |
OUTPUT |
|
*Tests covering at least one bit in the range
Branch Coverage for Instance : tb.dut
| Line No. | Total | Covered | Percent |
Branches |
|
7 |
7 |
100.00 |
IF |
320 |
7 |
7 |
100.00 |
WARNING: The source file /workspace/default/sim-vcs/../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv' or '../src/lowrisc_ip_rv_dm_0.1/rtl/rv_dm.sv was not found/opened, so annotated branch coverage report could not be generated.
LineNo. Expression
-1-: 320 if ((!rst_ni))
-2-: 325 if ((ndmreset_req && (!ndmreset_pending_q)))
-3-: 327 if ((ndmreset_ack && ndmreset_pending_q))
-4-: 331 if ((ndmreset_pending_q && lc_rst_asserted))
-5-: 333 if ((ndmreset_ack && lc_rst_pending_q))
Branches:
-1- | -2- | -3- | -4- | -5- | Status | Tests |
1 |
- |
- |
- |
- |
Covered |
T7,T1,T2 |
0 |
1 |
- |
- |
- |
Covered |
T4,T8,T25 |
0 |
0 |
1 |
- |
- |
Covered |
T4,T8,T25 |
0 |
0 |
0 |
- |
- |
Covered |
T7,T1,T2 |
0 |
- |
- |
1 |
- |
Covered |
T4,T8,T25 |
0 |
- |
- |
0 |
1 |
Covered |
T4,T8,T25 |
0 |
- |
- |
0 |
0 |
Covered |
T7,T1,T2 |
Assert Coverage for Instance : tb.dut
Assertion Details
DebugReqOKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
DmactiveOKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
FpvSecCmRegWeOnehotCheck_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
80 |
0 |
0 |
T14 |
4711 |
0 |
0 |
0 |
T40 |
61148 |
20 |
0 |
0 |
T41 |
0 |
10 |
0 |
0 |
T42 |
0 |
20 |
0 |
0 |
T62 |
0 |
20 |
0 |
0 |
T63 |
0 |
10 |
0 |
0 |
T64 |
69666 |
0 |
0 |
0 |
T65 |
2996 |
0 |
0 |
0 |
T66 |
3975 |
0 |
0 |
0 |
T67 |
18720 |
0 |
0 |
0 |
T68 |
4190 |
0 |
0 |
0 |
T69 |
5187 |
0 |
0 |
0 |
T70 |
381547 |
0 |
0 |
0 |
T71 |
95277 |
0 |
0 |
0 |
FpvSecCmRomTlLcGateFsm_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
0 |
0 |
0 |
FpvSecCmSbaTlLcGateFsm_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
0 |
0 |
0 |
JtagRspOTdoKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
4931407 |
4931264 |
0 |
0 |
T1 |
14185 |
14185 |
0 |
0 |
T2 |
15474 |
15474 |
0 |
0 |
T3 |
16003 |
16003 |
0 |
0 |
T4 |
148516 |
148514 |
0 |
0 |
T7 |
5918 |
5918 |
0 |
0 |
T8 |
1003 |
1003 |
0 |
0 |
T21 |
25578 |
25578 |
0 |
0 |
T25 |
1034 |
1034 |
0 |
0 |
T27 |
185 |
185 |
0 |
0 |
T28 |
385 |
385 |
0 |
0 |
JtagRspOTdoOeKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
4931407 |
4931264 |
0 |
0 |
T1 |
14185 |
14185 |
0 |
0 |
T2 |
15474 |
15474 |
0 |
0 |
T3 |
16003 |
16003 |
0 |
0 |
T4 |
148516 |
148514 |
0 |
0 |
T7 |
5918 |
5918 |
0 |
0 |
T8 |
1003 |
1003 |
0 |
0 |
T21 |
25578 |
25578 |
0 |
0 |
T25 |
1034 |
1034 |
0 |
0 |
T27 |
185 |
185 |
0 |
0 |
T28 |
385 |
385 |
0 |
0 |
NdmresetOKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
RvDmLcEnDebugVal_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlMemAReadyKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlMemDValidKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlRegsAReadyKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlRegsDValidKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlSbaAValidKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
TlSbaDReadyKnown_A
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
91971020 |
91915034 |
0 |
0 |
T1 |
68990 |
68933 |
0 |
0 |
T2 |
117709 |
117613 |
0 |
0 |
T3 |
140340 |
140290 |
0 |
0 |
T4 |
383403 |
383239 |
0 |
0 |
T7 |
53581 |
53504 |
0 |
0 |
T8 |
4529 |
4469 |
0 |
0 |
T21 |
67896 |
67464 |
0 |
0 |
T25 |
3770 |
3698 |
0 |
0 |
T27 |
8885 |
8832 |
0 |
0 |
T28 |
2076 |
2014 |
0 |
0 |
paramCheckNrHarts
Name | Attempts | Real Successes | Failures | Incomplete |
Total |
245 |
245 |
0 |
0 |
T1 |
1 |
1 |
0 |
0 |
T2 |
1 |
1 |
0 |
0 |
T3 |
1 |
1 |
0 |
0 |
T4 |
1 |
1 |
0 |
0 |
T7 |
1 |
1 |
0 |
0 |
T8 |
1 |
1 |
0 |
0 |
T21 |
1 |
1 |
0 |
0 |
T25 |
1 |
1 |
0 |
0 |
T27 |
1 |
1 |
0 |
0 |
T28 |
1 |
1 |
0 |
0 |