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

Module : spi_p2s
SCORELINECONDTOGGLEFSMBRANCHASSERT
90.20 100.00 84.62 76.19 100.00

Source File(s) :
/workspace/default/sim-vcs/../src/lowrisc_ip_spi_device_0.1/rtl/spi_p2s.sv

Module self-instances :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
tb.dut.u_p2s 90.20 100.00 84.62 76.19 100.00



Module Instance : tb.dut.u_p2s

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
90.20 100.00 84.62 76.19 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
90.20 100.00 84.62 76.19 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
95.39 96.31 94.03 97.00 93.33 96.30 dut


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
no children


Since this is the module's only instance, the coverage report is the same as for the module.
Line Coverage for Module : spi_p2s
Line No.TotalCoveredPercent
TOTAL3737100.00
ALWAYS7155100.00
CONT_ASSIGN9211100.00
ALWAYS11155100.00
ALWAYS12344100.00
CONT_ASSIGN14311100.00
ALWAYS14755100.00
CONT_ASSIGN17911100.00
ALWAYS18366100.00
CONT_ASSIGN19211100.00
ALWAYS19655100.00
ALWAYS21433100.00
WARNING: The source file '/workspace/default/sim-vcs/../src/lowrisc_ip_spi_device_0.1/rtl/spi_p2s.sv' or '../src/lowrisc_ip_spi_device_0.1/rtl/spi_p2s.sv' was not found, so annotated line coverage report could not be generated.
Line No.CoveredStatements
71 1 1
73 1 1
75 1 1
79 1 1
83 1 1
92 1 1
111 1 1
113 1 1
114 1 1
115 1 1
116 1 1
123 1 1
125 1 1
129 1 1
133 1 1
143 1 1
147 1 1
149 1 1
151 1 1
156 1 1
161 1 1
179 1 1
183 1 1
184 1 1
185 1 1
186 1 1
187 1 1
188 1 1
MISSING_ELSE
192 1 1
196 1 1
198 1 1
199 1 1
200 1 1
201 1 1
214 1 1
215 1 1
217 1 1


Cond Coverage for Module : spi_p2s
TotalCoveredPercent
Conditions524484.62
Logical524484.62
Non-Logical00
Event00

 LINE       92
 EXPRESSION (csb_i ? 4'b0 : out_enable)
             --1--
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT1,T4,T2

 LINE       114
 EXPRESSION (cnt == 3'h6)
            ------1------
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT1,T2,T3

 LINE       115
 EXPRESSION (cnt == 3'h2)
            ------1------
-1-StatusTests
0CoveredT3,T9,T10
1CoveredT3,T9,T10

 LINE       116
 EXPRESSION (cnt == 3'b0)
            ------1------
-1-StatusTests
0CoveredT3,T9,T10
1CoveredT3,T9,T10

 LINE       125
 EXPRESSION (order_i ? ({1'b0, out_shift_d[7:1]}) : ({out_shift_d[6:0], 1'b0}))
             ---1---
-1-StatusTests
0CoveredT4,T3,T13
1CoveredT1,T2,T3

 LINE       129
 EXPRESSION (order_i ? ({2'b0, out_shift_d[7:2]}) : ({out_shift_d[5:0], 2'b0}))
             ---1---
-1-StatusTests
0CoveredT3,T9,T10
1Not Covered

 LINE       133
 EXPRESSION (order_i ? ({4'b0, out_shift_d[7:4]}) : ({out_shift_d[3:0], 4'b0}))
             ---1---
-1-StatusTests
0CoveredT3,T9,T10
1Not Covered

 LINE       143
 EXPRESSION (first_beat ? data_i : out_shift)
             -----1----
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T4,T2

 LINE       151
 EXPRESSION (order_i ? (((!first_beat)) ? out_shift[0] : data_i[0]) : (((!first_beat)) ? out_shift[7] : data_i[7]))
             ---1---
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT1,T2,T3

 LINE       151
 SUB-EXPRESSION (((!first_beat)) ? out_shift[0] : data_i[0])
                 -------1-------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       151
 SUB-EXPRESSION (((!first_beat)) ? out_shift[7] : data_i[7])
                 -------1-------
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT3,T10,T11

 LINE       156
 EXPRESSION (order_i ? (((!first_beat)) ? out_shift[1:0] : data_i[1:0]) : (((!first_beat)) ? out_shift[7:6] : data_i[7:6]))
             ---1---
-1-StatusTests
0CoveredT3,T9,T10
1Not Covered

 LINE       156
 SUB-EXPRESSION (((!first_beat)) ? out_shift[1:0] : data_i[1:0])
                 -------1-------
-1-StatusTests
0Not Covered
1Not Covered

 LINE       156
 SUB-EXPRESSION (((!first_beat)) ? out_shift[7:6] : data_i[7:6])
                 -------1-------
-1-StatusTests
0CoveredT3,T9,T10
1CoveredT3,T9,T10

 LINE       161
 EXPRESSION (order_i ? (((!first_beat)) ? out_shift[3:0] : data_i[3:0]) : (((!first_beat)) ? out_shift[7:4] : data_i[7:4]))
             ---1---
-1-StatusTests
0CoveredT3,T9,T10
1Not Covered

 LINE       161
 SUB-EXPRESSION (((!first_beat)) ? out_shift[3:0] : data_i[3:0])
                 -------1-------
-1-StatusTests
0Not Covered
1Not Covered

 LINE       161
 SUB-EXPRESSION (((!first_beat)) ? out_shift[7:4] : data_i[7:4])
                 -------1-------
-1-StatusTests
0CoveredT3,T9,T10
1CoveredT3,T9,T10

 LINE       187
 EXPRESSION (data_valid_i && ((tx_state != TxIdle) || (cpha_i == 1'b0)))
             ------1-----    ---------------------2--------------------
-1--2-StatusTests
01CoveredT4,T3,T9
10CoveredT1,T3,T7
11CoveredT1,T2,T3

 LINE       187
 SUB-EXPRESSION ((tx_state != TxIdle) || (cpha_i == 1'b0))
                 ----------1---------    --------2-------
-1--2-StatusTests
00CoveredT1,T3,T7
01CoveredT4,T2,T3
10CoveredT1,T3,T7

 LINE       187
 SUB-EXPRESSION (tx_state != TxIdle)
                ----------1---------
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT1,T4,T2

 LINE       187
 SUB-EXPRESSION (cpha_i == 1'b0)
                --------1-------
-1-StatusTests
0CoveredT1,T3,T7
1CoveredT4,T2,T3

 LINE       192
 EXPRESSION (cnt == '0)
            -----1-----
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT1,T4,T2

 LINE       199
 EXPRESSION (cnt == 3'('h00000007))
            -----------1-----------
-1-StatusTests
0CoveredT1,T4,T2
1CoveredT1,T2,T3

 LINE       200
 EXPRESSION (cnt == 3'('h00000003))
            -----------1-----------
-1-StatusTests
0CoveredT3,T9,T10
1CoveredT3,T9,T10

 LINE       201
 EXPRESSION (cnt == 3'('b1))
            --------1-------
-1-StatusTests
0CoveredT3,T9,T10
1CoveredT3,T9,T10

Branch Coverage for Module : spi_p2s
Line No.TotalCoveredPercent
Branches 42 32 76.19
TERNARY 92 2 2 100.00
TERNARY 143 2 2 100.00
CASE 73 4 3 75.00
CASE 113 4 3 75.00
CASE 123 7 5 71.43
CASE 149 13 8 61.54
IF 183 4 4 100.00
CASE 198 4 3 75.00
IF 214 2 2 100.00

WARNING: The source file /workspace/default/sim-vcs/../src/lowrisc_ip_spi_device_0.1/rtl/spi_p2s.sv' or '../src/lowrisc_ip_spi_device_0.1/rtl/spi_p2s.sv was not found/opened, so annotated branch coverage report could not be generated.

LineNo. Expression -1-: 92 (csb_i) ?

Branches:
-1-StatusTests
1 Covered T1,T4,T2
0 Covered T1,T4,T2


LineNo. Expression -1-: 143 (first_beat) ?

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


LineNo. Expression -1-: 73 case (io_mode)

Branches:
-1-StatusTests
SingleIO Covered T1,T4,T2
DualIO Covered T3,T9,T10
QuadIO Covered T3,T9,T10
default Not Covered


LineNo. Expression -1-: 113 case (io_mode)

Branches:
-1-StatusTests
SingleIO Covered T1,T4,T2
DualIO Covered T3,T9,T10
QuadIO Covered T3,T9,T10
default Not Covered


LineNo. Expression -1-: 123 case (io_mode) -2-: 125 (order_i) ? -3-: 129 (order_i) ? -4-: 133 (order_i) ?

Branches:
-1--2--3--4-StatusTests
SingleIO 1 - - Covered T1,T2,T3
SingleIO 0 - - Covered T4,T3,T13
DualIO - 1 - Not Covered
DualIO - 0 - Covered T3,T9,T10
QuadIO - - 1 Not Covered
QuadIO - - 0 Covered T3,T9,T10
default - - - Covered T1,T4,T2


LineNo. Expression -1-: 149 case (io_mode) -2-: 151 (order_i) ? -3-: 151 ((!first_beat)) ? -4-: 151 ((!first_beat)) ? -5-: 156 (order_i) ? -6-: 156 ((!first_beat)) ? -7-: 156 ((!first_beat)) ? -8-: 161 (order_i) ? -9-: 161 ((!first_beat)) ? -10-: 161 ((!first_beat)) ?

Branches:
-1--2--3--4--5--6--7--8--9--10-StatusTests
SingleIO 1 1 - - - - - - - Covered T1,T2,T3
SingleIO 1 0 - - - - - - - Covered T1,T2,T3
SingleIO 0 - 1 - - - - - - Covered T3,T10,T11
SingleIO 0 - 0 - - - - - - Covered T1,T4,T2
DualIO - - - 1 1 - - - - Not Covered
DualIO - - - 1 0 - - - - Not Covered
DualIO - - - 0 - 1 - - - Covered T3,T9,T10
DualIO - - - 0 - 0 - - - Covered T3,T9,T10
QuadIO - - - - - - 1 1 - Not Covered
QuadIO - - - - - - 1 0 - Not Covered
QuadIO - - - - - - 0 - 1 Covered T3,T9,T10
QuadIO - - - - - - 0 - 0 Covered T3,T9,T10
default - - - - - - - - - Not Covered


LineNo. Expression -1-: 183 if ((!rst_ni)) -2-: 185 if (last_beat) -3-: 187 if ((data_valid_i && ((tx_state != TxIdle) || (cpha_i == 1'b0))))

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


LineNo. Expression -1-: 198 case (io_mode)

Branches:
-1-StatusTests
SingleIO Covered T1,T4,T2
DualIO Covered T3,T9,T10
QuadIO Covered T3,T9,T10
default Not Covered


LineNo. Expression -1-: 214 if ((!rst_ni))

Branches:
-1-StatusTests
1 Covered T1,T4,T2
0 Covered T1,T4,T2


Assert Coverage for Module : spi_p2s
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 2 2 100.00 2 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 2 2 100.00 2 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
IoModeChangeValid_A 377360050 8440 0 0
IoModeDefault_A 377360050 66683 0 0


IoModeChangeValid_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 377360050 8440 0 0
T1 419394 1 0 0
T2 1538 0 0 0
T3 152345 40 0 0
T4 10519 1 0 0
T5 0 9 0 0
T7 671221 0 0 0
T8 68995 0 0 0
T9 101789 20 0 0
T10 78746 24 0 0
T11 33590 9 0 0
T13 62566 0 0 0
T14 0 1 0 0
T19 0 1 0 0
T33 0 1 0 0

IoModeDefault_A
NameAttemptsReal SuccessesFailuresIncomplete
Total 377360050 66683 0 0
T1 419394 2 0 0
T2 1538 1 0 0
T3 152345 330 0 0
T4 10519 2 0 0
T7 671221 819 0 0
T8 0 2 0 0
T9 101789 2 0 0
T10 78746 3 0 0
T11 33590 2 0 0
T12 1538 1 0 0
T13 62566 0 0 0

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