Line Coverage for Module : 
prim_fifo_sync
|  | Line No. | Total | Covered | Percent | 
|---|
| TOTAL |  | 14 | 14 | 100.00 | 
| ALWAYS | 69 | 4 | 4 | 100.00 | 
| CONT_ASSIGN | 81 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 82 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 100 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 101 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 120 | 1 | 1 | 100.00 | 
| ALWAYS | 123 | 2 | 2 | 100.00 | 
| CONT_ASSIGN | 133 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 134 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 140 | 1 | 1 | 100.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:       T4 T9 T6 
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:       T4 T9 T6 
134        1/1                assign empty = fifo_empty;
           Tests:       T1 T2 T3 
135                         end
136                     
137                         if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero
138                           assign rdata_o = empty ? Width'(0) : rdata_int;
139                         end else begin : gen_no_output_zero
140        1/1                assign rdata_o = rdata_int;
           Tests:       T4 T9 T6 
Cond Coverage for Module : 
prim_fifo_sync
|  | Total | Covered | Percent | 
|---|
| Conditions | 14 | 11 | 78.57 | 
| Logical | 14 | 11 | 78.57 | 
| Non-Logical | 0 | 0 |  | 
| Event | 0 | 0 |  | 
 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
| -1- | -2- | Status | Tests | 
|---|
| 0 | 1 | Covered | T9,T6,T10 | 
| 1 | 0 | Covered | T1,T2,T3 | 
| 1 | 1 | Covered | T1,T2,T3 | 
 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
| -1- | -2- | Status | Tests | 
|---|
| 0 | 1 | Covered | T1,T2,T3 | 
| 1 | 0 | Not Covered |  | 
| 1 | 1 | Covered | T4,T9,T6 | 
 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
| -1- | -2- | -3- | Status | Tests | 
|---|
| 0 | 1 | 1 | Covered | T1,T2,T3 | 
| 1 | 0 | 1 | Covered | T30,T31,T32 | 
| 1 | 1 | 0 | Not Covered |  | 
| 1 | 1 | 1 | Covered | T4,T9,T6 | 
 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
| -1- | -2- | -3- | Status | Tests | 
|---|
| 0 | 1 | 1 | Covered | T3,T28,T29 | 
| 1 | 0 | 1 | Covered | T4,T9,T6 | 
| 1 | 1 | 0 | Not Covered |  | 
| 1 | 1 | 1 | Covered | T9,T10,T14 | 
Branch Coverage for Module : 
prim_fifo_sync
|  | Line No. | Total | Covered | Percent | 
| Branches |  | 5 | 5 | 100.00 | 
| IF | 69 | 3 | 3 | 100.00 | 
| IF | 123 | 2 | 2 | 100.00 | 
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- | Status | Tests | 
| 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- | Status | Tests | 
| 1 | Covered | T4,T9,T6 | 
| 0 | Covered | T1,T2,T3 | 
Assert Coverage for Module : 
prim_fifo_sync
Assertion Details
DataKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 24780270 | 1525459 | 0 | 0 | 
| T6 | 274 | 63 | 0 | 0 | 
| T7 | 0 | 395 | 0 | 0 | 
| T8 | 0 | 277 | 0 | 0 | 
| T9 | 7494 | 4490 | 0 | 0 | 
| T10 | 6906 | 4378 | 0 | 0 | 
| T14 | 0 | 3179 | 0 | 0 | 
| T18 | 0 | 5255 | 0 | 0 | 
| T24 | 2786 | 0 | 0 | 0 | 
| T26 | 3968 | 0 | 0 | 0 | 
| T27 | 0 | 97 | 0 | 0 | 
| T28 | 860 | 0 | 0 | 0 | 
| T36 | 5906 | 0 | 0 | 0 | 
| T37 | 1860 | 0 | 0 | 0 | 
| T39 | 28918 | 0 | 0 | 0 | 
| T42 | 0 | 6661 | 0 | 0 | 
| T61 | 1964 | 0 | 0 | 0 | 
| T64 | 0 | 2008 | 0 | 0 | 
DataKnown_AKnownEnable
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 25496134 | 25144158 | 0 | 0 | 
| T1 | 2022 | 1898 | 0 | 0 | 
| T2 | 2236 | 2102 | 0 | 0 | 
| T3 | 1676 | 1340 | 0 | 0 | 
| T4 | 2250 | 1894 | 0 | 0 | 
| T5 | 21804 | 21546 | 0 | 0 | 
| T19 | 1524 | 1406 | 0 | 0 | 
| T20 | 3284 | 3172 | 0 | 0 | 
| T21 | 4776 | 4674 | 0 | 0 | 
| T22 | 1810 | 1654 | 0 | 0 | 
| T23 | 3264 | 3112 | 0 | 0 | 
DepthKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 25496134 | 25144158 | 0 | 0 | 
| T1 | 2022 | 1898 | 0 | 0 | 
| T2 | 2236 | 2102 | 0 | 0 | 
| T3 | 1676 | 1340 | 0 | 0 | 
| T4 | 2250 | 1894 | 0 | 0 | 
| T5 | 21804 | 21546 | 0 | 0 | 
| T19 | 1524 | 1406 | 0 | 0 | 
| T20 | 3284 | 3172 | 0 | 0 | 
| T21 | 4776 | 4674 | 0 | 0 | 
| T22 | 1810 | 1654 | 0 | 0 | 
| T23 | 3264 | 3112 | 0 | 0 | 
RvalidKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 25496134 | 25144158 | 0 | 0 | 
| T1 | 2022 | 1898 | 0 | 0 | 
| T2 | 2236 | 2102 | 0 | 0 | 
| T3 | 1676 | 1340 | 0 | 0 | 
| T4 | 2250 | 1894 | 0 | 0 | 
| T5 | 21804 | 21546 | 0 | 0 | 
| T19 | 1524 | 1406 | 0 | 0 | 
| T20 | 3284 | 3172 | 0 | 0 | 
| T21 | 4776 | 4674 | 0 | 0 | 
| T22 | 1810 | 1654 | 0 | 0 | 
| T23 | 3264 | 3112 | 0 | 0 | 
WreadyKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 25496134 | 25144158 | 0 | 0 | 
| T1 | 2022 | 1898 | 0 | 0 | 
| T2 | 2236 | 2102 | 0 | 0 | 
| T3 | 1676 | 1340 | 0 | 0 | 
| T4 | 2250 | 1894 | 0 | 0 | 
| T5 | 21804 | 21546 | 0 | 0 | 
| T19 | 1524 | 1406 | 0 | 0 | 
| T20 | 3284 | 3172 | 0 | 0 | 
| T21 | 4776 | 4674 | 0 | 0 | 
| T22 | 1810 | 1654 | 0 | 0 | 
| T23 | 3264 | 3112 | 0 | 0 | 
gen_normal_fifo.depthShallNotExceedParamDepth
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 25129038 | 1618162 | 0 | 0 | 
| T4 | 2250 | 292 | 0 | 0 | 
| T5 | 21804 | 0 | 0 | 0 | 
| T6 | 0 | 1056 | 0 | 0 | 
| T7 | 0 | 1208 | 0 | 0 | 
| T9 | 7494 | 4490 | 0 | 0 | 
| T10 | 0 | 4378 | 0 | 0 | 
| T14 | 0 | 3179 | 0 | 0 | 
| T18 | 0 | 5255 | 0 | 0 | 
| T20 | 3284 | 0 | 0 | 0 | 
| T21 | 4776 | 0 | 0 | 0 | 
| T22 | 1810 | 0 | 0 | 0 | 
| T23 | 3264 | 0 | 0 | 0 | 
| T24 | 2786 | 0 | 0 | 0 | 
| T27 | 0 | 97 | 0 | 0 | 
| T28 | 3746 | 0 | 0 | 0 | 
| T36 | 5906 | 0 | 0 | 0 | 
| T42 | 0 | 6661 | 0 | 0 | 
| T64 | 0 | 2008 | 0 | 0 | 
 
Line Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_rescmd
|  | Line No. | Total | Covered | Percent | 
|---|
| TOTAL |  | 14 | 14 | 100.00 | 
| ALWAYS | 69 | 4 | 4 | 100.00 | 
| CONT_ASSIGN | 81 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 82 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 100 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 101 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 120 | 1 | 1 | 100.00 | 
| ALWAYS | 123 | 2 | 2 | 100.00 | 
| CONT_ASSIGN | 133 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 134 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 140 | 1 | 1 | 100.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:       T4 T9 T6 
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:       T4 T9 T6 
134        1/1                assign empty = fifo_empty;
           Tests:       T1 T2 T3 
135                         end
136                     
137                         if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero
138                           assign rdata_o = empty ? Width'(0) : rdata_int;
139                         end else begin : gen_no_output_zero
140        1/1                assign rdata_o = rdata_int;
           Tests:       T4 T9 T6 
Cond Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_rescmd
|  | Total | Covered | Percent | 
|---|
| Conditions | 14 | 11 | 78.57 | 
| Logical | 14 | 11 | 78.57 | 
| Non-Logical | 0 | 0 |  | 
| Event | 0 | 0 |  | 
 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
| -1- | -2- | Status | Tests | 
|---|
| 0 | 1 | Covered | T9,T14,T108 | 
| 1 | 0 | Covered | T1,T2,T3 | 
| 1 | 1 | Covered | T1,T2,T3 | 
 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
| -1- | -2- | Status | Tests | 
|---|
| 0 | 1 | Covered | T1,T2,T3 | 
| 1 | 0 | Not Covered |  | 
| 1 | 1 | Covered | T4,T9,T6 | 
 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
| -1- | -2- | -3- | Status | Tests | 
|---|
| 0 | 1 | 1 | Covered | T1,T2,T3 | 
| 1 | 0 | 1 | Covered | T30,T109 | 
| 1 | 1 | 0 | Not Covered |  | 
| 1 | 1 | 1 | Covered | T4,T9,T6 | 
 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
| -1- | -2- | -3- | Status | Tests | 
|---|
| 0 | 1 | 1 | Covered | T28,T29,T110 | 
| 1 | 0 | 1 | Covered | T4,T9,T6 | 
| 1 | 1 | 0 | Not Covered |  | 
| 1 | 1 | 1 | Covered | T9,T10,T14 | 
Branch Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_rescmd
|  | Line No. | Total | Covered | Percent | 
| Branches |  | 5 | 5 | 100.00 | 
| IF | 69 | 3 | 3 | 100.00 | 
| IF | 123 | 2 | 2 | 100.00 | 
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- | Status | Tests | 
| 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- | Status | Tests | 
| 1 | Covered | T4,T9,T6 | 
| 0 | Covered | T1,T2,T3 | 
Assert Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_rescmd
Assertion Details
DataKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12390135 | 756334 | 0 | 0 | 
| T6 | 137 | 19 | 0 | 0 | 
| T7 | 0 | 144 | 0 | 0 | 
| T8 | 0 | 119 | 0 | 0 | 
| T9 | 3747 | 2180 | 0 | 0 | 
| T10 | 3453 | 2122 | 0 | 0 | 
| T14 | 0 | 1589 | 0 | 0 | 
| T18 | 0 | 2588 | 0 | 0 | 
| T24 | 1393 | 0 | 0 | 0 | 
| T26 | 1984 | 0 | 0 | 0 | 
| T27 | 0 | 47 | 0 | 0 | 
| T28 | 430 | 0 | 0 | 0 | 
| T36 | 2953 | 0 | 0 | 0 | 
| T37 | 930 | 0 | 0 | 0 | 
| T39 | 14459 | 0 | 0 | 0 | 
| T42 | 0 | 3326 | 0 | 0 | 
| T61 | 982 | 0 | 0 | 0 | 
| T64 | 0 | 989 | 0 | 0 | 
DataKnown_AKnownEnable
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
DepthKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
RvalidKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
WreadyKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
gen_normal_fifo.depthShallNotExceedParamDepth
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12564519 | 802508 | 0 | 0 | 
| T4 | 1125 | 147 | 0 | 0 | 
| T5 | 10902 | 0 | 0 | 0 | 
| T6 | 0 | 512 | 0 | 0 | 
| T7 | 0 | 536 | 0 | 0 | 
| T9 | 3747 | 2180 | 0 | 0 | 
| T10 | 0 | 2122 | 0 | 0 | 
| T14 | 0 | 1589 | 0 | 0 | 
| T18 | 0 | 2588 | 0 | 0 | 
| T20 | 1642 | 0 | 0 | 0 | 
| T21 | 2388 | 0 | 0 | 0 | 
| T22 | 905 | 0 | 0 | 0 | 
| T23 | 1632 | 0 | 0 | 0 | 
| T24 | 1393 | 0 | 0 | 0 | 
| T27 | 0 | 47 | 0 | 0 | 
| T28 | 1873 | 0 | 0 | 0 | 
| T36 | 2953 | 0 | 0 | 0 | 
| T42 | 0 | 3326 | 0 | 0 | 
| T64 | 0 | 989 | 0 | 0 | 
 
Line Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_gencmd
|  | Line No. | Total | Covered | Percent | 
|---|
| TOTAL |  | 14 | 14 | 100.00 | 
| ALWAYS | 69 | 4 | 4 | 100.00 | 
| CONT_ASSIGN | 81 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 82 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 100 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 101 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 120 | 1 | 1 | 100.00 | 
| ALWAYS | 123 | 2 | 2 | 100.00 | 
| CONT_ASSIGN | 133 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 134 | 1 | 1 | 100.00 | 
| CONT_ASSIGN | 140 | 1 | 1 | 100.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:       T4 T9 T6 
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:       T4 T9 T6 
134        1/1                assign empty = fifo_empty;
           Tests:       T1 T2 T3 
135                         end
136                     
137                         if (OutputZeroIfEmpty == 1'b1) begin : gen_output_zero
138                           assign rdata_o = empty ? Width'(0) : rdata_int;
139                         end else begin : gen_no_output_zero
140        1/1                assign rdata_o = rdata_int;
           Tests:       T4 T9 T6 
Cond Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_gencmd
|  | Total | Covered | Percent | 
|---|
| Conditions | 14 | 11 | 78.57 | 
| Logical | 14 | 11 | 78.57 | 
| Non-Logical | 0 | 0 |  | 
| Event | 0 | 0 |  | 
 LINE       81
 EXPRESSION (((~full_o)) & ((~gen_normal_fifo.under_rst)))
             -----1-----   ---------------2--------------
| -1- | -2- | Status | Tests | 
|---|
| 0 | 1 | Covered | T9,T6,T10 | 
| 1 | 0 | Covered | T1,T2,T3 | 
| 1 | 1 | Covered | T1,T2,T3 | 
 LINE       82
 EXPRESSION (((~gen_normal_fifo.empty)) & ((~gen_normal_fifo.under_rst)))
             -------------1------------   ---------------2--------------
| -1- | -2- | Status | Tests | 
|---|
| 0 | 1 | Covered | T1,T2,T3 | 
| 1 | 0 | Not Covered |  | 
| 1 | 1 | Covered | T4,T9,T6 | 
 LINE       100
 EXPRESSION (wvalid_i & wready_o & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
| -1- | -2- | -3- | Status | Tests | 
|---|
| 0 | 1 | 1 | Covered | T1,T2,T3 | 
| 1 | 0 | 1 | Covered | T31,T32,T111 | 
| 1 | 1 | 0 | Not Covered |  | 
| 1 | 1 | 1 | Covered | T4,T9,T6 | 
 LINE       101
 EXPRESSION (rvalid_o & rready_i & ((~gen_normal_fifo.under_rst)))
             ----1---   ----2---   ---------------3--------------
| -1- | -2- | -3- | Status | Tests | 
|---|
| 0 | 1 | 1 | Covered | T3,T63,T112 | 
| 1 | 0 | 1 | Covered | T4,T9,T6 | 
| 1 | 1 | 0 | Not Covered |  | 
| 1 | 1 | 1 | Covered | T9,T10,T14 | 
Branch Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_gencmd
|  | Line No. | Total | Covered | Percent | 
| Branches |  | 5 | 5 | 100.00 | 
| IF | 69 | 3 | 3 | 100.00 | 
| IF | 123 | 2 | 2 | 100.00 | 
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- | Status | Tests | 
| 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- | Status | Tests | 
| 1 | Covered | T4,T9,T6 | 
| 0 | Covered | T1,T2,T3 | 
Assert Coverage for Instance : tb.dut.u_edn_core.u_prim_fifo_sync_gencmd
Assertion Details
DataKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12390135 | 769125 | 0 | 0 | 
| T6 | 137 | 44 | 0 | 0 | 
| T7 | 0 | 251 | 0 | 0 | 
| T8 | 0 | 158 | 0 | 0 | 
| T9 | 3747 | 2310 | 0 | 0 | 
| T10 | 3453 | 2256 | 0 | 0 | 
| T14 | 0 | 1590 | 0 | 0 | 
| T18 | 0 | 2667 | 0 | 0 | 
| T24 | 1393 | 0 | 0 | 0 | 
| T26 | 1984 | 0 | 0 | 0 | 
| T27 | 0 | 50 | 0 | 0 | 
| T28 | 430 | 0 | 0 | 0 | 
| T36 | 2953 | 0 | 0 | 0 | 
| T37 | 930 | 0 | 0 | 0 | 
| T39 | 14459 | 0 | 0 | 0 | 
| T42 | 0 | 3335 | 0 | 0 | 
| T61 | 982 | 0 | 0 | 0 | 
| T64 | 0 | 1019 | 0 | 0 | 
DataKnown_AKnownEnable
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
DepthKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
RvalidKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
WreadyKnown_A
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12748067 | 12572079 | 0 | 0 | 
| T1 | 1011 | 949 | 0 | 0 | 
| T2 | 1118 | 1051 | 0 | 0 | 
| T3 | 838 | 670 | 0 | 0 | 
| T4 | 1125 | 947 | 0 | 0 | 
| T5 | 10902 | 10773 | 0 | 0 | 
| T19 | 762 | 703 | 0 | 0 | 
| T20 | 1642 | 1586 | 0 | 0 | 
| T21 | 2388 | 2337 | 0 | 0 | 
| T22 | 905 | 827 | 0 | 0 | 
| T23 | 1632 | 1556 | 0 | 0 | 
gen_normal_fifo.depthShallNotExceedParamDepth
| Name | Attempts | Real Successes | Failures | Incomplete | 
| Total | 12564519 | 815654 | 0 | 0 | 
| T4 | 1125 | 145 | 0 | 0 | 
| T5 | 10902 | 0 | 0 | 0 | 
| T6 | 0 | 544 | 0 | 0 | 
| T7 | 0 | 672 | 0 | 0 | 
| T9 | 3747 | 2310 | 0 | 0 | 
| T10 | 0 | 2256 | 0 | 0 | 
| T14 | 0 | 1590 | 0 | 0 | 
| T18 | 0 | 2667 | 0 | 0 | 
| T20 | 1642 | 0 | 0 | 0 | 
| T21 | 2388 | 0 | 0 | 0 | 
| T22 | 905 | 0 | 0 | 0 | 
| T23 | 1632 | 0 | 0 | 0 | 
| T24 | 1393 | 0 | 0 | 0 | 
| T27 | 0 | 50 | 0 | 0 | 
| T28 | 1873 | 0 | 0 | 0 | 
| T36 | 2953 | 0 | 0 | 0 | 
| T42 | 0 | 3335 | 0 | 0 | 
| T64 | 0 | 1019 | 0 | 0 |