dashboard | hierarchy | modlist | groups | tests | asserts

Module Instance : tb.dut.u_tlul2sram_egress.u_rspfifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
89.88 92.86 100.00 100.00 66.67


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
90.95 97.14 100.00 100.00 66.67


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
86.94 95.83 76.84 90.48 84.62 u_tlul2sram_egress


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
gen_normal_fifo.u_fifo_cnt 100.00 100.00 100.00 100.00


Module Instance : tb.dut.u_tlul2sram_ingress.u_reqfifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
91.69 95.83 79.25 91.67 100.00 u_tlul2sram_ingress


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
gen_normal_fifo.u_fifo_cnt 100.00 100.00 100.00 100.00


Module Instance : tb.dut.u_tlul2sram_ingress.u_sramreqfifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
91.69 95.83 79.25 91.67 100.00 u_tlul2sram_ingress


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
gen_normal_fifo.u_fifo_cnt 100.00 100.00 100.00 100.00


Module Instance : tb.dut.u_tlul2sram_ingress.u_rspfifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
91.69 95.83 79.25 91.67 100.00 u_tlul2sram_ingress


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
gen_normal_fifo.u_fifo_cnt 100.00 100.00 100.00 100.00


Module Instance : tb.dut.u_sys_sram_arbiter.u_req_fifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
100.00 100.00 100.00 u_sys_sram_arbiter


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
gen_normal_fifo.u_fifo_cnt 100.00 100.00 100.00 100.00


Module Instance : tb.dut.u_reg.u_socket.fifo_h.reqfifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
100.00 100.00 100.00 fifo_h


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
no children


Module Instance : tb.dut.u_reg.u_socket.fifo_h.rspfifo

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
100.00 100.00 100.00 fifo_h


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
no children

Go back
Module Instances:
tb.dut.u_tlul2sram_egress.u_rspfifo
tb.dut.u_tlul2sram_ingress.u_reqfifo
tb.dut.u_tlul2sram_ingress.u_sramreqfifo
tb.dut.u_tlul2sram_ingress.u_rspfifo
tb.dut.u_sys_sram_arbiter.u_req_fifo
tb.dut.u_reg.u_socket.fifo_h.reqfifo
tb.dut.u_reg.u_socket.fifo_h.rspfifo
Line Coverage for Instance : tb.dut.u_tlul2sram_egress.u_rspfifo
Line No.TotalCoveredPercent
TOTAL141392.86
ALWAYS6944100.00
CONT_ASSIGN8111100.00
CONT_ASSIGN8211100.00
CONT_ASSIGN10011100.00
CONT_ASSIGN10111100.00
CONT_ASSIGN108100.00
ALWAYS11111100.00
CONT_ASSIGN11611100.00
CONT_ASSIGN13011100.00
CONT_ASSIGN13111100.00
CONT_ASSIGN13811100.00

68 always_ff @(posedge clk_i or negedge rst_ni) begin 69 1/1 if (!rst_ni) begin Tests: T1 T2 T3  70 1/1 under_rst <= 1'b1; Tests: T1 T2 T3  71 1/1 end else if (under_rst) begin Tests: T1 T2 T3  72 1/1 under_rst <= ~under_rst; Tests: T1 T2 T3  73 end MISSING_ELSE 74 end 75 76 logic empty; 77 78 // full and not ready for write are two different concepts. 79 // The latter can be '0' when under reset, while the former is an indication that no more 80 // entries can be written. 81 1/1 assign wready_o = ~full_o & ~under_rst; Tests: T1 T2 T3  82 1/1 assign rvalid_o = ~empty & ~under_rst; Tests: T1 T2 T3  83 84 prim_fifo_sync_cnt #( 85 .Depth(Depth), 86 .Secure(Secure) 87 ) u_fifo_cnt ( 88 .clk_i, 89 .rst_ni, 90 .clr_i, 91 .incr_wptr_i(fifo_incr_wptr), 92 .incr_rptr_i(fifo_incr_rptr), 93 .wptr_o(fifo_wptr), 94 .rptr_o(fifo_rptr), 95 .full_o, 96 .empty_o(fifo_empty), 97 .depth_o, 98 .err_o 99 ); 100 1/1 assign fifo_incr_wptr = wvalid_i & wready_o & ~under_rst; Tests: T1 T2 T3  101 1/1 assign fifo_incr_rptr = rvalid_o & rready_i & ~under_rst; Tests: T1 T2 T3  102 103 // the generate blocks below are needed to avoid lint errors due to array indexing 104 // in the where the fifo only has one storage element 105 logic [Depth-1:0][Width-1:0] storage; 106 logic [Width-1:0] storage_rdata; 107 if (Depth == 1) begin : gen_depth_eq1 108 0/1 ==> assign storage_rdata = storage[0]; 109 110 always_ff @(posedge clk_i) 111 1/1 if (fifo_incr_wptr) begin Tests: T1 T2 T3  112 excluded storage[0] <= wdata_i; Exclude Annotation: VC_COV_UNR 113 end MISSING_ELSE 114 115 logic unused_ptrs; 116 1/1 assign unused_ptrs = ^{fifo_wptr, fifo_rptr}; Tests: T1 T2 T3  117 118 // fifo with more than one storage element 119 end else begin : gen_depth_gt1 120 assign storage_rdata = storage[fifo_rptr]; 121 122 always_ff @(posedge clk_i) 123 if (fifo_incr_wptr) begin 124 storage[fifo_wptr] <= wdata_i; 125 end 126 end 127 128 logic [Width-1:0] rdata_int; 129 if (Pass == 1'b1) begin : gen_pass 130 1/1 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; Tests: T1 T2 T3  131 1/1 assign empty = fifo_empty & ~wvalid_i; Tests: T1 T2 T3  132 end else begin : gen_nopass 133 assign rdata_int = storage_rdata; 134 assign empty = fifo_empty; 135 end 136 137 if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero 138 1/1 assign rdata_o = empty ? Width'(0) : rdata_int; Tests: T1 T2 T3 

Cond Coverage for Instance : tb.dut.u_tlul2sram_egress.u_rspfifo
TotalCoveredPercent
Conditions88100.00
Logical88100.00
Non-Logical00
Event00

 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01Excluded VC_COV_UNR
10CoveredT1,T2,T3
11CoveredT1,T2,T3

 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01CoveredT1,T2,T3
10Excluded VC_COV_UNR
11Excluded VC_COV_UNR

 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011CoveredT1,T2,T3
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111Excluded VC_COV_UNR

 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011Excluded VC_COV_UNR
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111Excluded VC_COV_UNR

 LINE       130
 EXPRESSION ((gen_normal_fifo.fifo_empty && wvalid_i) ? wdata_i : gen_normal_fifo.storage_rdata)
             --------------------1-------------------
-1-StatusTestsExclude Annotation
0CoveredT1,T2,T3
1Excluded VC_COV_UNR

 LINE       130
 SUB-EXPRESSION (gen_normal_fifo.fifo_empty && wvalid_i)
                 -------------1------------    ----2---
-1--2-StatusTestsExclude Annotation
01Excluded VC_COV_UNR
10CoveredT1,T2,T3
11Excluded VC_COV_UNR

 LINE       131
 EXPRESSION (gen_normal_fifo.fifo_empty & ((~wvalid_i)))
             -------------1------------   ------2------
-1--2-StatusTestsExclude Annotation
01Excluded VC_COV_UNR
10Excluded VC_COV_UNR
11CoveredT1,T2,T3

 LINE       138
 EXPRESSION (gen_normal_fifo.empty ? (40'(0)) : gen_normal_fifo.rdata_int)
             ----------1----------
-1-StatusTestsExclude Annotation
0Excluded VC_COV_UNR
1CoveredT1,T2,T3

Branch Coverage for Instance : tb.dut.u_tlul2sram_egress.u_rspfifo
Line No.TotalCoveredPercent
Branches 6 6 100.00
TERNARY 130 1 1 100.00
TERNARY 138 1 1 100.00
IF 69 3 3 100.00
IF 111 1 1 100.00


130 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; -1- ==> (Excluded) ==>

Branches:
-1-StatusTestsExclude Annotation
1 Excluded VC_COV_UNR
0 Covered T1,T2,T3


138 assign rdata_o = empty ? Width'(0) : rdata_int; -1- ==> ==> (Excluded)

Branches:
-1-StatusTestsExclude Annotation
1 Covered T1,T2,T3
0 Excluded VC_COV_UNR


69 if (!rst_ni) begin -1- 70 under_rst <= 1'b1; ==> 71 end else if (under_rst) begin -2- 72 under_rst <= ~under_rst; ==> 73 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T1,T2,T3
0 1 Covered T1,T2,T3
0 0 Covered T1,T2,T3


111 if (fifo_incr_wptr) begin -1- 112 storage[0] <= wdata_i; ==> (Excluded) Exclude Annotation: VC_COV_UNR 113 end MISSING_ELSE ==>

Branches:
-1-StatusTestsExclude Annotation
1 Excluded VC_COV_UNR
0 Covered T1,T2,T3


Assert Coverage for Instance : tb.dut.u_tlul2sram_egress.u_rspfifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 4 66.67
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 4 66.67




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 463294267 0 0 0
DataKnown_AKnownEnable 463294267 463204918 0 0
DepthKnown_A 463294267 463204918 0 0
RvalidKnown_A 463294267 463204918 0 0
WreadyKnown_A 463294267 463204918 0 0
gen_normal_fifo.depthShallNotExceedParamDepth 463294267 0 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 0 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_normal_fifo.depthShallNotExceedParamDepth
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 0 0 0

Line Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_reqfifo
Line No.TotalCoveredPercent
TOTAL1515100.00
ALWAYS6944100.00
CONT_ASSIGN8111100.00
CONT_ASSIGN8211100.00
CONT_ASSIGN10011100.00
CONT_ASSIGN10111100.00
CONT_ASSIGN10811100.00
ALWAYS11122100.00
CONT_ASSIGN11611100.00
CONT_ASSIGN13311100.00
CONT_ASSIGN13411100.00
CONT_ASSIGN13811100.00

68 always_ff @(posedge clk_i or negedge rst_ni) begin 69 1/1 if (!rst_ni) begin Tests: T1 T2 T3  70 1/1 under_rst <= 1'b1; Tests: T1 T2 T3  71 1/1 end else if (under_rst) begin Tests: T1 T2 T3  72 1/1 under_rst <= ~under_rst; Tests: T1 T2 T3  73 end MISSING_ELSE 74 end 75 76 logic empty; 77 78 // full and not ready for write are two different concepts. 79 // The latter can be '0' when under reset, while the former is an indication that no more 80 // entries can be written. 81 1/1 assign wready_o = ~full_o & ~under_rst; Tests: T1 T2 T3  82 1/1 assign rvalid_o = ~empty & ~under_rst; Tests: T1 T2 T3  83 84 prim_fifo_sync_cnt #( 85 .Depth(Depth), 86 .Secure(Secure) 87 ) u_fifo_cnt ( 88 .clk_i, 89 .rst_ni, 90 .clr_i, 91 .incr_wptr_i(fifo_incr_wptr), 92 .incr_rptr_i(fifo_incr_rptr), 93 .wptr_o(fifo_wptr), 94 .rptr_o(fifo_rptr), 95 .full_o, 96 .empty_o(fifo_empty), 97 .depth_o, 98 .err_o 99 ); 100 1/1 assign fifo_incr_wptr = wvalid_i & wready_o & ~under_rst; Tests: T1 T2 T3  101 1/1 assign fifo_incr_rptr = rvalid_o & rready_i & ~under_rst; Tests: T1 T2 T3  102 103 // the generate blocks below are needed to avoid lint errors due to array indexing 104 // in the where the fifo only has one storage element 105 logic [Depth-1:0][Width-1:0] storage; 106 logic [Width-1:0] storage_rdata; 107 if (Depth == 1) begin : gen_depth_eq1 108 1/1 assign storage_rdata = storage[0]; Tests: T6 T10 T25  109 110 always_ff @(posedge clk_i) 111 1/1 if (fifo_incr_wptr) begin Tests: T1 T2 T3  112 1/1 storage[0] <= wdata_i; Tests: T6 T10 T25  113 end MISSING_ELSE 114 115 logic unused_ptrs; 116 1/1 assign unused_ptrs = ^{fifo_wptr, fifo_rptr}; Tests: T1 T2 T3  117 118 // fifo with more than one storage element 119 end else begin : gen_depth_gt1 120 assign storage_rdata = storage[fifo_rptr]; 121 122 always_ff @(posedge clk_i) 123 if (fifo_incr_wptr) begin 124 storage[fifo_wptr] <= wdata_i; 125 end 126 end 127 128 logic [Width-1:0] rdata_int; 129 if (Pass == 1'b1) begin : gen_pass 130 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; 131 assign empty = fifo_empty & ~wvalid_i; 132 end else begin : gen_nopass 133 1/1 assign rdata_int = storage_rdata; Tests: T6 T10 T25  134 1/1 assign empty = fifo_empty; Tests: T1 T2 T3  135 end 136 137 if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero 138 1/1 assign rdata_o = empty ? Width'(0) : rdata_int; Tests: T1 T2 T3 

Cond Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_reqfifo
TotalCoveredPercent
Conditions1111100.00
Logical1111100.00
Non-Logical00
Event00

 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
-1--2-StatusTests
01CoveredT6,T10,T25
10CoveredT1,T2,T3
11CoveredT1,T2,T3

 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01CoveredT1,T2,T3
10Excluded VC_COV_UNR
11CoveredT6,T10,T25

 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011CoveredT1,T2,T3
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011Excluded VC_COV_UNR
101CoveredT6,T10,T25
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       138
 EXPRESSION (gen_normal_fifo.empty ? (17'(0)) : gen_normal_fifo.rdata_int)
             ----------1----------
-1-StatusTests
0CoveredT6,T10,T25
1CoveredT1,T2,T3

Branch Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_reqfifo
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 138 2 2 100.00
IF 69 3 3 100.00
IF 123 2 2 100.00


138 assign rdata_o = empty ? Width'(0) : rdata_int; -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T1,T2,T3
0 Covered T6,T10,T25


69 if (!rst_ni) begin -1- 70 under_rst <= 1'b1; ==> 71 end else if (under_rst) begin -2- 72 under_rst <= ~under_rst; ==> 73 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T1,T2,T3
0 1 Covered T1,T2,T3
0 0 Covered T1,T2,T3


123 if (fifo_incr_wptr) begin -1- 124 storage[fifo_wptr] <= wdata_i; ==> 125 end MISSING_ELSE ==>

Branches:
-1-StatusTests
1 Covered T6,T10,T25
0 Covered T1,T2,T3


Assert Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_reqfifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 6 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 6 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 463294267 435740 0 0
DataKnown_AKnownEnable 463294267 463204918 0 0
DepthKnown_A 463294267 463204918 0 0
RvalidKnown_A 463294267 463204918 0 0
WreadyKnown_A 463294267 463204918 0 0
gen_normal_fifo.depthShallNotExceedParamDepth 463294267 435740 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 435740 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 2076 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 782 0 0
T25 0 268 0 0
T27 0 12 0 0
T39 0 416 0 0
T40 0 474 0 0
T41 0 35 0 0
T42 0 959 0 0
T43 0 281 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_normal_fifo.depthShallNotExceedParamDepth
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 435740 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 2076 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 782 0 0
T25 0 268 0 0
T27 0 12 0 0
T39 0 416 0 0
T40 0 474 0 0
T41 0 35 0 0
T42 0 959 0 0
T43 0 281 0 0

Line Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_sramreqfifo
Line No.TotalCoveredPercent
TOTAL1515100.00
ALWAYS6944100.00
CONT_ASSIGN8111100.00
CONT_ASSIGN8211100.00
CONT_ASSIGN10011100.00
CONT_ASSIGN10111100.00
CONT_ASSIGN10811100.00
ALWAYS11122100.00
CONT_ASSIGN11611100.00
CONT_ASSIGN13311100.00
CONT_ASSIGN13411100.00
CONT_ASSIGN13811100.00

68 always_ff @(posedge clk_i or negedge rst_ni) begin 69 1/1 if (!rst_ni) begin Tests: T1 T2 T3  70 1/1 under_rst <= 1'b1; Tests: T1 T2 T3  71 1/1 end else if (under_rst) begin Tests: T1 T2 T3  72 1/1 under_rst <= ~under_rst; Tests: T1 T2 T3  73 end MISSING_ELSE 74 end 75 76 logic empty; 77 78 // full and not ready for write are two different concepts. 79 // The latter can be '0' when under reset, while the former is an indication that no more 80 // entries can be written. 81 1/1 assign wready_o = ~full_o & ~under_rst; Tests: T1 T2 T3  82 1/1 assign rvalid_o = ~empty & ~under_rst; Tests: T1 T2 T3  83 84 prim_fifo_sync_cnt #( 85 .Depth(Depth), 86 .Secure(Secure) 87 ) u_fifo_cnt ( 88 .clk_i, 89 .rst_ni, 90 .clr_i, 91 .incr_wptr_i(fifo_incr_wptr), 92 .incr_rptr_i(fifo_incr_rptr), 93 .wptr_o(fifo_wptr), 94 .rptr_o(fifo_rptr), 95 .full_o, 96 .empty_o(fifo_empty), 97 .depth_o, 98 .err_o 99 ); 100 1/1 assign fifo_incr_wptr = wvalid_i & wready_o & ~under_rst; Tests: T1 T2 T3  101 1/1 assign fifo_incr_rptr = rvalid_o & rready_i & ~under_rst; Tests: T1 T2 T3  102 103 // the generate blocks below are needed to avoid lint errors due to array indexing 104 // in the where the fifo only has one storage element 105 logic [Depth-1:0][Width-1:0] storage; 106 logic [Width-1:0] storage_rdata; 107 if (Depth == 1) begin : gen_depth_eq1 108 1/1 assign storage_rdata = storage[0]; Tests: T6 T10 T25  109 110 always_ff @(posedge clk_i) 111 1/1 if (fifo_incr_wptr) begin Tests: T1 T2 T3  112 1/1 storage[0] <= wdata_i; Tests: T6 T10 T25  113 end MISSING_ELSE 114 115 logic unused_ptrs; 116 1/1 assign unused_ptrs = ^{fifo_wptr, fifo_rptr}; Tests: T1 T2 T3  117 118 // fifo with more than one storage element 119 end else begin : gen_depth_gt1 120 assign storage_rdata = storage[fifo_rptr]; 121 122 always_ff @(posedge clk_i) 123 if (fifo_incr_wptr) begin 124 storage[fifo_wptr] <= wdata_i; 125 end 126 end 127 128 logic [Width-1:0] rdata_int; 129 if (Pass == 1'b1) begin : gen_pass 130 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; 131 assign empty = fifo_empty & ~wvalid_i; 132 end else begin : gen_nopass 133 1/1 assign rdata_int = storage_rdata; Tests: T6 T10 T25  134 1/1 assign empty = fifo_empty; Tests: T1 T2 T3  135 end 136 137 if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero 138 1/1 assign rdata_o = empty ? Width'(0) : rdata_int; Tests: T1 T2 T3 

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

 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
-1--2-StatusTests
01CoveredT6,T10,T25
10CoveredT1,T2,T3
11CoveredT1,T2,T3

 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01CoveredT1,T2,T3
10Excluded VC_COV_UNR
11CoveredT6,T10,T25

 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011CoveredT1,T2,T3
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011Excluded VC_COV_UNR
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       138
 EXPRESSION (gen_normal_fifo.empty ? (5'(0)) : gen_normal_fifo.rdata_int)
             ----------1----------
-1-StatusTests
0CoveredT6,T10,T25
1CoveredT1,T2,T3

Branch Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_sramreqfifo
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 138 2 2 100.00
IF 69 3 3 100.00
IF 123 2 2 100.00


138 assign rdata_o = empty ? Width'(0) : rdata_int; -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T1,T2,T3
0 Covered T6,T10,T25


69 if (!rst_ni) begin -1- 70 under_rst <= 1'b1; ==> 71 end else if (under_rst) begin -2- 72 under_rst <= ~under_rst; ==> 73 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T1,T2,T3
0 1 Covered T1,T2,T3
0 0 Covered T1,T2,T3


123 if (fifo_incr_wptr) begin -1- 124 storage[fifo_wptr] <= wdata_i; ==> 125 end MISSING_ELSE ==>

Branches:
-1-StatusTests
1 Covered T6,T10,T25
0 Covered T1,T2,T3


Assert Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_sramreqfifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 6 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 6 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 463294267 178118 0 0
DataKnown_AKnownEnable 463294267 463204918 0 0
DepthKnown_A 463294267 463204918 0 0
RvalidKnown_A 463294267 463204918 0 0
WreadyKnown_A 463294267 463204918 0 0
gen_normal_fifo.depthShallNotExceedParamDepth 463294267 178118 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 178118 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 464 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 240 0 0
T25 0 77 0 0
T27 0 12 0 0
T39 0 416 0 0
T40 0 474 0 0
T41 0 35 0 0
T42 0 192 0 0
T43 0 59 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_normal_fifo.depthShallNotExceedParamDepth
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 178118 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 464 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 240 0 0
T25 0 77 0 0
T27 0 12 0 0
T39 0 416 0 0
T40 0 474 0 0
T41 0 35 0 0
T42 0 192 0 0
T43 0 59 0 0

Line Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_rspfifo
Line No.TotalCoveredPercent
TOTAL1515100.00
ALWAYS6944100.00
CONT_ASSIGN8111100.00
CONT_ASSIGN8211100.00
CONT_ASSIGN10011100.00
CONT_ASSIGN10111100.00
CONT_ASSIGN10811100.00
ALWAYS11122100.00
CONT_ASSIGN11611100.00
CONT_ASSIGN13011100.00
CONT_ASSIGN13111100.00
CONT_ASSIGN13811100.00

68 always_ff @(posedge clk_i or negedge rst_ni) begin 69 1/1 if (!rst_ni) begin Tests: T1 T2 T3  70 1/1 under_rst <= 1'b1; Tests: T1 T2 T3  71 1/1 end else if (under_rst) begin Tests: T1 T2 T3  72 1/1 under_rst <= ~under_rst; Tests: T1 T2 T3  73 end MISSING_ELSE 74 end 75 76 logic empty; 77 78 // full and not ready for write are two different concepts. 79 // The latter can be '0' when under reset, while the former is an indication that no more 80 // entries can be written. 81 1/1 assign wready_o = ~full_o & ~under_rst; Tests: T1 T2 T3  82 1/1 assign rvalid_o = ~empty & ~under_rst; Tests: T1 T2 T3  83 84 prim_fifo_sync_cnt #( 85 .Depth(Depth), 86 .Secure(Secure) 87 ) u_fifo_cnt ( 88 .clk_i, 89 .rst_ni, 90 .clr_i, 91 .incr_wptr_i(fifo_incr_wptr), 92 .incr_rptr_i(fifo_incr_rptr), 93 .wptr_o(fifo_wptr), 94 .rptr_o(fifo_rptr), 95 .full_o, 96 .empty_o(fifo_empty), 97 .depth_o, 98 .err_o 99 ); 100 1/1 assign fifo_incr_wptr = wvalid_i & wready_o & ~under_rst; Tests: T1 T2 T3  101 1/1 assign fifo_incr_rptr = rvalid_o & rready_i & ~under_rst; Tests: T1 T2 T3  102 103 // the generate blocks below are needed to avoid lint errors due to array indexing 104 // in the where the fifo only has one storage element 105 logic [Depth-1:0][Width-1:0] storage; 106 logic [Width-1:0] storage_rdata; 107 if (Depth == 1) begin : gen_depth_eq1 108 1/1 assign storage_rdata = storage[0]; Tests: T6 T10 T25  109 110 always_ff @(posedge clk_i) 111 1/1 if (fifo_incr_wptr) begin Tests: T1 T2 T3  112 1/1 storage[0] <= wdata_i; Tests: T6 T10 T25  113 end MISSING_ELSE 114 115 logic unused_ptrs; 116 1/1 assign unused_ptrs = ^{fifo_wptr, fifo_rptr}; Tests: T1 T2 T3  117 118 // fifo with more than one storage element 119 end else begin : gen_depth_gt1 120 assign storage_rdata = storage[fifo_rptr]; 121 122 always_ff @(posedge clk_i) 123 if (fifo_incr_wptr) begin 124 storage[fifo_wptr] <= wdata_i; 125 end 126 end 127 128 logic [Width-1:0] rdata_int; 129 if (Pass == 1'b1) begin : gen_pass 130 1/1 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; Tests: T1 T2 T3  131 1/1 assign empty = fifo_empty & ~wvalid_i; Tests: T1 T2 T3  132 end else begin : gen_nopass 133 assign rdata_int = storage_rdata; 134 assign empty = fifo_empty; 135 end 136 137 if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero 138 1/1 assign rdata_o = empty ? Width'(0) : rdata_int; Tests: T1 T2 T3 

Cond Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_rspfifo
TotalCoveredPercent
Conditions1818100.00
Logical1818100.00
Non-Logical00
Event00

 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
-1--2-StatusTests
01CoveredT10,T25,T22
10CoveredT1,T2,T3
11CoveredT1,T2,T3

 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01CoveredT1,T2,T3
10Excluded VC_COV_UNR
11CoveredT6,T10,T25

 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011CoveredT1,T2,T3
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011Excluded VC_COV_UNR
101CoveredT6,T10,T25
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       130
 EXPRESSION ((gen_normal_fifo.fifo_empty && wvalid_i) ? wdata_i : gen_normal_fifo.storage_rdata)
             --------------------1-------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT6,T10,T25

 LINE       130
 SUB-EXPRESSION (gen_normal_fifo.fifo_empty && wvalid_i)
                 -------------1------------    ----2---
-1--2-StatusTestsExclude Annotation
01Excluded VC_COV_UNR
10CoveredT1,T2,T3
11CoveredT6,T10,T25

 LINE       131
 EXPRESSION (gen_normal_fifo.fifo_empty & ((~wvalid_i)))
             -------------1------------   ------2------
-1--2-StatusTests
01CoveredT10,T25,T22
10CoveredT6,T10,T25
11CoveredT1,T2,T3

 LINE       138
 EXPRESSION (gen_normal_fifo.empty ? (40'(0)) : gen_normal_fifo.rdata_int)
             ----------1----------
-1-StatusTests
0CoveredT6,T10,T25
1CoveredT1,T2,T3

Branch Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_rspfifo
Line No.TotalCoveredPercent
Branches 9 9 100.00
TERNARY 130 2 2 100.00
TERNARY 138 2 2 100.00
IF 69 3 3 100.00
IF 111 2 2 100.00


130 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T6,T10,T25
0 Covered T1,T2,T3


138 assign rdata_o = empty ? Width'(0) : rdata_int; -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T1,T2,T3
0 Covered T6,T10,T25


69 if (!rst_ni) begin -1- 70 under_rst <= 1'b1; ==> 71 end else if (under_rst) begin -2- 72 under_rst <= ~under_rst; ==> 73 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T1,T2,T3
0 1 Covered T1,T2,T3
0 0 Covered T1,T2,T3


111 if (fifo_incr_wptr) begin -1- 112 storage[0] <= wdata_i; ==> 113 end MISSING_ELSE ==>

Branches:
-1-StatusTests
1 Covered T6,T10,T25
0 Covered T1,T2,T3


Assert Coverage for Instance : tb.dut.u_tlul2sram_ingress.u_rspfifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 6 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 6 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 463294267 435740 0 0
DataKnown_AKnownEnable 463294267 463204918 0 0
DepthKnown_A 463294267 463204918 0 0
RvalidKnown_A 463294267 463204918 0 0
WreadyKnown_A 463294267 463204918 0 0
gen_normal_fifo.depthShallNotExceedParamDepth 463294267 435740 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 435740 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 2076 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 782 0 0
T25 0 268 0 0
T27 0 12 0 0
T39 0 416 0 0
T40 0 474 0 0
T41 0 35 0 0
T42 0 959 0 0
T43 0 281 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_normal_fifo.depthShallNotExceedParamDepth
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 435740 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 2076 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 782 0 0
T25 0 268 0 0
T27 0 12 0 0
T39 0 416 0 0
T40 0 474 0 0
T41 0 35 0 0
T42 0 959 0 0
T43 0 281 0 0

Line Coverage for Instance : tb.dut.u_sys_sram_arbiter.u_req_fifo
Line No.TotalCoveredPercent
TOTAL1414100.00
ALWAYS6944100.00
CONT_ASSIGN8111100.00
CONT_ASSIGN8211100.00
CONT_ASSIGN10011100.00
CONT_ASSIGN10111100.00
CONT_ASSIGN12011100.00
ALWAYS12322100.00
CONT_ASSIGN13311100.00
CONT_ASSIGN13411100.00
CONT_ASSIGN13811100.00

68 always_ff @(posedge clk_i or negedge rst_ni) begin 69 1/1 if (!rst_ni) begin Tests: T1 T2 T3  70 1/1 under_rst <= 1'b1; Tests: T1 T2 T3  71 1/1 end else if (under_rst) begin Tests: T1 T2 T3  72 1/1 under_rst <= ~under_rst; Tests: T1 T2 T3  73 end MISSING_ELSE 74 end 75 76 logic empty; 77 78 // full and not ready for write are two different concepts. 79 // The latter can be '0' when under reset, while the former is an indication that no more 80 // entries can be written. 81 1/1 assign wready_o = ~full_o & ~under_rst; Tests: T1 T2 T3  82 1/1 assign rvalid_o = ~empty & ~under_rst; Tests: T1 T2 T3  83 84 prim_fifo_sync_cnt #( 85 .Depth(Depth), 86 .Secure(Secure) 87 ) u_fifo_cnt ( 88 .clk_i, 89 .rst_ni, 90 .clr_i, 91 .incr_wptr_i(fifo_incr_wptr), 92 .incr_rptr_i(fifo_incr_rptr), 93 .wptr_o(fifo_wptr), 94 .rptr_o(fifo_rptr), 95 .full_o, 96 .empty_o(fifo_empty), 97 .depth_o, 98 .err_o 99 ); 100 1/1 assign fifo_incr_wptr = wvalid_i & wready_o & ~under_rst; Tests: T1 T2 T3  101 1/1 assign fifo_incr_rptr = rvalid_o & rready_i & ~under_rst; Tests: T1 T2 T3  102 103 // the generate blocks below are needed to avoid lint errors due to array indexing 104 // in the where the fifo only has one storage element 105 logic [Depth-1:0][Width-1:0] storage; 106 logic [Width-1:0] storage_rdata; 107 if (Depth == 1) begin : gen_depth_eq1 108 assign storage_rdata = storage[0]; 109 110 always_ff @(posedge clk_i) 111 if (fifo_incr_wptr) begin 112 storage[0] <= wdata_i; 113 end 114 115 logic unused_ptrs; 116 assign unused_ptrs = ^{fifo_wptr, fifo_rptr}; 117 118 // fifo with more than one storage element 119 end else begin : gen_depth_gt1 120 1/1 assign storage_rdata = storage[fifo_rptr]; Tests: T1 T2 T3  121 122 always_ff @(posedge clk_i) 123 1/1 if (fifo_incr_wptr) begin Tests: T1 T2 T3  124 1/1 storage[fifo_wptr] <= wdata_i; Tests: T6 T10 T25  125 end MISSING_ELSE 126 end 127 128 logic [Width-1:0] rdata_int; 129 if (Pass == 1'b1) begin : gen_pass 130 assign rdata_int = (fifo_empty && wvalid_i) ? wdata_i : storage_rdata; 131 assign empty = fifo_empty & ~wvalid_i; 132 end else begin : gen_nopass 133 1/1 assign rdata_int = storage_rdata; Tests: T6 T10 T25  134 1/1 assign empty = fifo_empty; Tests: T1 T2 T3  135 end 136 137 if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero 138 1/1 assign rdata_o = empty ? Width'(0) : rdata_int; Tests: T1 T2 T3 

Cond Coverage for Instance : tb.dut.u_sys_sram_arbiter.u_req_fifo
TotalCoveredPercent
Conditions99100.00
Logical99100.00
Non-Logical00
Event00

 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01Excluded VC_COV_UNR
10CoveredT1,T2,T3
11CoveredT1,T2,T3

 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
-1--2-StatusTestsExclude Annotation
01CoveredT1,T2,T3
10Excluded VC_COV_UNR
11CoveredT6,T10,T25

 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011CoveredT1,T2,T3
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
-1--2--3-StatusTestsExclude Annotation
011Excluded VC_COV_UNR
101Excluded VC_COV_UNR
110Excluded VC_COV_UNR
111CoveredT6,T10,T25

 LINE       138
 EXPRESSION (gen_normal_fifo.empty ? (5'(0)) : gen_normal_fifo.rdata_int)
             ----------1----------
-1-StatusTests
0CoveredT6,T10,T25
1CoveredT1,T2,T3

Branch Coverage for Instance : tb.dut.u_sys_sram_arbiter.u_req_fifo
Line No.TotalCoveredPercent
Branches 7 7 100.00
TERNARY 138 2 2 100.00
IF 69 3 3 100.00
IF 123 2 2 100.00


138 assign rdata_o = empty ? Width'(0) : rdata_int; -1- ==> ==>

Branches:
-1-StatusTests
1 Covered T1,T2,T3
0 Covered T6,T10,T25


69 if (!rst_ni) begin -1- 70 under_rst <= 1'b1; ==> 71 end else if (under_rst) begin -2- 72 under_rst <= ~under_rst; ==> 73 end MISSING_ELSE ==>

Branches:
-1--2-StatusTests
1 - Covered T1,T2,T3
0 1 Covered T1,T2,T3
0 0 Covered T1,T2,T3


123 if (fifo_incr_wptr) begin -1- 124 storage[fifo_wptr] <= wdata_i; ==> 125 end MISSING_ELSE ==>

Branches:
-1-StatusTests
1 Covered T6,T10,T25
0 Covered T1,T2,T3


Assert Coverage for Instance : tb.dut.u_sys_sram_arbiter.u_req_fifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 6 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 6 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 463294267 182252 0 0
DataKnown_AKnownEnable 463294267 463204918 0 0
DepthKnown_A 463294267 463204918 0 0
RvalidKnown_A 463294267 463204918 0 0
WreadyKnown_A 463294267 463204918 0 0
gen_normal_fifo.depthShallNotExceedParamDepth 463294267 182252 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 182252 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 464 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 244 0 0
T25 0 77 0 0
T27 0 12 0 0
T39 0 435 0 0
T40 0 474 0 0
T41 0 35 0 0
T52 0 2 0 0
T55 0 4 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 463204918 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_normal_fifo.depthShallNotExceedParamDepth
NameAttemptsReal SuccessesFailuresIncomplete
Total 463294267 182252 0 0
T6 7293 17 0 0
T7 10105 0 0 0
T8 10913 0 0 0
T9 3730 0 0 0
T10 83260 464 0 0
T11 251431 0 0 0
T12 61473 0 0 0
T13 15612 0 0 0
T14 445458 0 0 0
T15 4263 0 0 0
T22 0 244 0 0
T25 0 77 0 0
T27 0 12 0 0
T39 0 435 0 0
T40 0 474 0 0
T41 0 35 0 0
T52 0 2 0 0
T55 0 4 0 0

Line Coverage for Instance : tb.dut.u_reg.u_socket.fifo_h.reqfifo
Line No.TotalCoveredPercent
TOTAL44100.00
CONT_ASSIGN4411100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4811100.00
CONT_ASSIGN4911100.00
CONT_ASSIGN5300

43 // device facing 44 1/1 assign rvalid_o = wvalid_i; Tests: T1 T2 T3  45 1/1 assign rdata_o = wdata_i; Tests: T1 T2 T3  46 47 // host facing 48 1/1 assign wready_o = rready_i; Tests: T1 T2 T3  49 1/1 assign full_o = rready_i; Tests: T1 T2 T3  50 51 // this avoids lint warnings 52 logic unused_clr; 53 unreachable assign unused_clr = clr_i;

Assert Coverage for Instance : tb.dut.u_reg.u_socket.fifo_h.reqfifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 6 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 6 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 465548306 9334732 0 0
DataKnown_AKnownEnable 465548306 465414243 0 0
DepthKnown_A 465548306 465414243 0 0
RvalidKnown_A 465548306 465414243 0 0
WreadyKnown_A 465548306 465414243 0 0
gen_passthru_fifo.paramCheckPass 1131 1131 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 9334732 0 0
T1 1826 11 0 0
T2 1727 77 0 0
T3 1571 1 0 0
T4 4925 38 0 0
T5 2791 20 0 0
T6 7293 479 0 0
T7 10105 1719 0 0
T8 10913 920 0 0
T9 3730 1740 0 0
T10 83260 3490 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_passthru_fifo.paramCheckPass
NameAttemptsReal SuccessesFailuresIncomplete
Total 1131 1131 0 0
T1 1 1 0 0
T2 1 1 0 0
T3 1 1 0 0
T4 1 1 0 0
T5 1 1 0 0
T6 1 1 0 0
T7 1 1 0 0
T8 1 1 0 0
T9 1 1 0 0
T10 1 1 0 0

Line Coverage for Instance : tb.dut.u_reg.u_socket.fifo_h.rspfifo
Line No.TotalCoveredPercent
TOTAL44100.00
CONT_ASSIGN4411100.00
CONT_ASSIGN4511100.00
CONT_ASSIGN4811100.00
CONT_ASSIGN4911100.00
CONT_ASSIGN5300

43 // device facing 44 1/1 assign rvalid_o = wvalid_i; Tests: T1 T2 T3  45 1/1 assign rdata_o = wdata_i; Tests: T1 T2 T3  46 47 // host facing 48 1/1 assign wready_o = rready_i; Tests: T1 T2 T3  49 1/1 assign full_o = rready_i; Tests: T1 T2 T3  50 51 // this avoids lint warnings 52 logic unused_clr; 53 unreachable assign unused_clr = clr_i;

Assert Coverage for Instance : tb.dut.u_reg.u_socket.fifo_h.rspfifo
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 6 6 100.00 6 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 6 6 100.00 6 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
DataKnown_A 465548306 16422897 0 0
DataKnown_AKnownEnable 465548306 465414243 0 0
DepthKnown_A 465548306 465414243 0 0
RvalidKnown_A 465548306 465414243 0 0
WreadyKnown_A 465548306 465414243 0 0
gen_passthru_fifo.paramCheckPass 1131 1131 0 0


DataKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 16422897 0 0
T1 1826 11 0 0
T2 1727 357 0 0
T3 1571 1 0 0
T4 4925 38 0 0
T5 2791 20 0 0
T6 7293 479 0 0
T7 10105 1036 0 0
T8 10913 2915 0 0
T9 3730 976 0 0
T10 83260 14449 0 0

DataKnown_AKnownEnable
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

DepthKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

RvalidKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

WreadyKnown_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 465548306 465414243 0 0
T1 1826 1752 0 0
T2 1727 1628 0 0
T3 1571 1489 0 0
T4 4925 4870 0 0
T5 2791 2725 0 0
T6 7293 7233 0 0
T7 10105 10030 0 0
T8 10913 10815 0 0
T9 3730 3646 0 0
T10 83260 83169 0 0

gen_passthru_fifo.paramCheckPass
NameAttemptsReal SuccessesFailuresIncomplete
Total 1131 1131 0 0
T1 1 1 0 0
T2 1 1 0 0
T3 1 1 0 0
T4 1 1 0 0
T5 1 1 0 0
T6 1 1 0 0
T7 1 1 0 0
T8 1 1 0 0
T9 1 1 0 0
T10 1 1 0 0

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