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



Module Instance : tb.dut.u_reg

Instance :
SCORELINECONDTOGGLEFSMBRANCHASSERT
100.00 100.00 100.00 100.00 100.00


Instance's subtree :
SCORELINECONDTOGGLEFSMBRANCHASSERT
97.23 96.01 97.63 100.00 92.53 100.00


Parent :
SCORELINECONDTOGGLEFSMBRANCHASSERTNAME
96.70 100.00 83.87 99.60 100.00 100.00 dut


Subtrees :
NAMESCORELINECONDTOGGLEFSMBRANCHASSERT
u_alert_test 100.00 100.00
u_cfg_cdc_sync 100.00 100.00 100.00 100.00
u_cfg_cdc_sync0_qe 100.00 100.00 100.00
u_chk 100.00 100.00 100.00 100.00
u_control_core_clk_en 100.00 100.00 100.00 100.00
u_control_io_clk_en 100.00 100.00 100.00 100.00
u_control_low_power_hint 100.00 100.00 100.00 100.00
u_control_main_pd_n 100.00 100.00 100.00 100.00
u_control_usb_clk_en_active 100.00 100.00 100.00 100.00
u_control_usb_clk_en_lp 100.00 100.00 100.00 100.00
u_ctrl_cfg_regwen 100.00 100.00
u_escalate_reset_status 62.59 77.78 50.00 60.00
u_fault_status_esc_timeout 96.30 88.89 100.00 100.00
u_fault_status_main_pd_glitch 100.00 100.00 100.00 100.00
u_fault_status_reg_intg_err 96.30 88.89 100.00 100.00
u_intr_enable 100.00 100.00 100.00 100.00
u_intr_state 100.00 100.00 100.00 100.00
u_intr_test 100.00 100.00
u_prim_reg_we_check 100.00 100.00 100.00
u_reg_if 98.67 97.14 97.53 100.00 100.00
u_reset_en_en_0 100.00 100.00 100.00 100.00
u_reset_en_en_1 100.00 100.00 100.00 100.00
u_reset_en_regwen 100.00 100.00 100.00 100.00
u_reset_status_val_0 62.59 77.78 50.00 60.00
u_reset_status_val_1 62.59 77.78 50.00 60.00
u_rsp_intg_gen 100.00 100.00 100.00
u_wake_info_abort 100.00 100.00
u_wake_info_capture_dis 100.00 100.00 100.00 100.00
u_wake_info_fall_through 100.00 100.00
u_wake_info_reasons 100.00 100.00
u_wake_status_val_0 62.59 77.78 50.00 60.00
u_wake_status_val_1 62.59 77.78 50.00 60.00
u_wake_status_val_2 62.59 77.78 50.00 60.00
u_wake_status_val_3 62.59 77.78 50.00 60.00
u_wake_status_val_4 62.59 77.78 50.00 60.00
u_wake_status_val_5 62.59 77.78 50.00 60.00
u_wakeup_en_en_0 100.00 100.00 100.00 100.00
u_wakeup_en_en_1 100.00 100.00 100.00 100.00
u_wakeup_en_en_2 100.00 100.00 100.00 100.00
u_wakeup_en_en_3 100.00 100.00 100.00 100.00
u_wakeup_en_en_4 100.00 100.00 100.00 100.00
u_wakeup_en_en_5 100.00 100.00 100.00 100.00
u_wakeup_en_regwen 100.00 100.00 100.00 100.00


Since this is the module's only instance, the coverage report is the same as for the module.
Line Coverage for Module : pwrmgr_reg_top
Line No.TotalCoveredPercent
TOTAL140140100.00
ALWAYS7044100.00
CONT_ASSIGN7911100.00
CONT_ASSIGN9111100.00
CONT_ASSIGN9211100.00
CONT_ASSIGN12011100.00
CONT_ASSIGN12111100.00
CONT_ASSIGN26411100.00
CONT_ASSIGN27811100.00
CONT_ASSIGN28411100.00
CONT_ASSIGN29811100.00
CONT_ASSIGN32011100.00
CONT_ASSIGN52111100.00
CONT_ASSIGN55611100.00
CONT_ASSIGN91711100.00
CONT_ASSIGN108911100.00
CONT_ASSIGN110411100.00
CONT_ASSIGN112011100.00
CONT_ASSIGN113611100.00
ALWAYS12281818100.00
CONT_ASSIGN124811100.00
ALWAYS125211100.00
CONT_ASSIGN127311100.00
CONT_ASSIGN127511100.00
CONT_ASSIGN127611100.00
CONT_ASSIGN127811100.00
CONT_ASSIGN127911100.00
CONT_ASSIGN128111100.00
CONT_ASSIGN128211100.00
CONT_ASSIGN128411100.00
CONT_ASSIGN128511100.00
CONT_ASSIGN128611100.00
CONT_ASSIGN128811100.00
CONT_ASSIGN129011100.00
CONT_ASSIGN129211100.00
CONT_ASSIGN129411100.00
CONT_ASSIGN129611100.00
CONT_ASSIGN129811100.00
CONT_ASSIGN129911100.00
CONT_ASSIGN130111100.00
CONT_ASSIGN130211100.00
CONT_ASSIGN130411100.00
CONT_ASSIGN130511100.00
CONT_ASSIGN130711100.00
CONT_ASSIGN130911100.00
CONT_ASSIGN131111100.00
CONT_ASSIGN131311100.00
CONT_ASSIGN131511100.00
CONT_ASSIGN131711100.00
CONT_ASSIGN131811100.00
CONT_ASSIGN132011100.00
CONT_ASSIGN132111100.00
CONT_ASSIGN132311100.00
CONT_ASSIGN132511100.00
CONT_ASSIGN132611100.00
CONT_ASSIGN132811100.00
CONT_ASSIGN132911100.00
CONT_ASSIGN133011100.00
CONT_ASSIGN133211100.00
CONT_ASSIGN133411100.00
CONT_ASSIGN133611100.00
ALWAYS13401818100.00
ALWAYS13624040100.00
CONT_ASSIGN146400
CONT_ASSIGN147211100.00
CONT_ASSIGN147311100.00

69 always_ff @(posedge clk_lc_i or negedge rst_lc_ni) begin 70 1/1 if (!rst_lc_ni) begin Tests: T1 T2 T3  71 1/1 err_q <= '0; Tests: T1 T2 T3  72 1/1 end else if (intg_err || reg_we_err) begin Tests: T1 T2 T3  73 1/1 err_q <= 1'b1; Tests: T20 T21 T22  74 end MISSING_ELSE 75 end 76 77 // integrity error output is permanent and should be used for alert generation 78 // register errors are transactional 79 1/1 assign intg_err_o = err_q | intg_err | reg_we_err; Tests: T1 T2 T3  80 81 // outgoing integrity generation 82 tlul_pkg::tl_d2h_t tl_o_pre; 83 tlul_rsp_intg_gen #( 84 .EnableRspIntgGen(1), 85 .EnableDataIntgGen(1) 86 ) u_rsp_intg_gen ( 87 .tl_i(tl_o_pre), 88 .tl_o(tl_o) 89 ); 90 91 1/1 assign tl_reg_h2d = tl_i; Tests: T1 T2 T3  92 1/1 assign tl_o_pre = tl_reg_d2h; Tests: T1 T2 T3  93 94 tlul_adapter_reg #( 95 .RegAw(AW), 96 .RegDw(DW), 97 .EnableDataIntgGen(0) 98 ) u_reg_if ( 99 .clk_i (clk_i), 100 .rst_ni (rst_ni), 101 102 .tl_i (tl_reg_h2d), 103 .tl_o (tl_reg_d2h), 104 105 .en_ifetch_i(prim_mubi_pkg::MuBi4False), 106 .intg_error_o(), 107 108 .we_o (reg_we), 109 .re_o (reg_re), 110 .addr_o (reg_addr), 111 .wdata_o (reg_wdata), 112 .be_o (reg_be), 113 .busy_i (reg_busy), 114 .rdata_i (reg_rdata), 115 .error_i (reg_error) 116 ); 117 118 // cdc oversampling signals 119 120 1/1 assign reg_rdata = reg_rdata_next ; Tests: T1 T2 T3  121 1/1 assign reg_error = addrmiss | wr_err | intg_err; Tests: T50 T47 T48  122 123 // Define SW related signals 124 // Format: <reg>_<field>_{wd|we|qs} 125 // or <reg>_{wd|we|qs} if field == 1 or 0 126 logic intr_state_we; 127 logic intr_state_qs; 128 logic intr_state_wd; 129 logic intr_enable_we; 130 logic intr_enable_qs; 131 logic intr_enable_wd; 132 logic intr_test_we; 133 logic intr_test_wd; 134 logic alert_test_we; 135 logic alert_test_wd; 136 logic ctrl_cfg_regwen_re; 137 logic ctrl_cfg_regwen_qs; 138 logic control_we; 139 logic control_low_power_hint_qs; 140 logic control_low_power_hint_wd; 141 logic control_core_clk_en_qs; 142 logic control_core_clk_en_wd; 143 logic control_io_clk_en_qs; 144 logic control_io_clk_en_wd; 145 logic control_usb_clk_en_lp_qs; 146 logic control_usb_clk_en_lp_wd; 147 logic control_usb_clk_en_active_qs; 148 logic control_usb_clk_en_active_wd; 149 logic control_main_pd_n_qs; 150 logic control_main_pd_n_wd; 151 logic cfg_cdc_sync_we; 152 logic cfg_cdc_sync_qs; 153 logic cfg_cdc_sync_wd; 154 logic wakeup_en_regwen_we; 155 logic wakeup_en_regwen_qs; 156 logic wakeup_en_regwen_wd; 157 logic wakeup_en_we; 158 logic wakeup_en_en_0_qs; 159 logic wakeup_en_en_0_wd; 160 logic wakeup_en_en_1_qs; 161 logic wakeup_en_en_1_wd; 162 logic wakeup_en_en_2_qs; 163 logic wakeup_en_en_2_wd; 164 logic wakeup_en_en_3_qs; 165 logic wakeup_en_en_3_wd; 166 logic wakeup_en_en_4_qs; 167 logic wakeup_en_en_4_wd; 168 logic wakeup_en_en_5_qs; 169 logic wakeup_en_en_5_wd; 170 logic wake_status_val_0_qs; 171 logic wake_status_val_1_qs; 172 logic wake_status_val_2_qs; 173 logic wake_status_val_3_qs; 174 logic wake_status_val_4_qs; 175 logic wake_status_val_5_qs; 176 logic reset_en_regwen_we; 177 logic reset_en_regwen_qs; 178 logic reset_en_regwen_wd; 179 logic reset_en_we; 180 logic reset_en_en_0_qs; 181 logic reset_en_en_0_wd; 182 logic reset_en_en_1_qs; 183 logic reset_en_en_1_wd; 184 logic reset_status_val_0_qs; 185 logic reset_status_val_1_qs; 186 logic escalate_reset_status_qs; 187 logic wake_info_capture_dis_we; 188 logic wake_info_capture_dis_qs; 189 logic wake_info_capture_dis_wd; 190 logic wake_info_re; 191 logic wake_info_we; 192 logic [5:0] wake_info_reasons_qs; 193 logic [5:0] wake_info_reasons_wd; 194 logic wake_info_fall_through_qs; 195 logic wake_info_fall_through_wd; 196 logic wake_info_abort_qs; 197 logic wake_info_abort_wd; 198 logic fault_status_reg_intg_err_qs; 199 logic fault_status_esc_timeout_qs; 200 logic fault_status_main_pd_glitch_qs; 201 // Define register CDC handling. 202 // CDC handling is done on a per-reg instead of per-field boundary. 203 204 // Register instances 205 // R[intr_state]: V(False) 206 prim_subreg #( 207 .DW (1), 208 .SwAccess(prim_subreg_pkg::SwAccessW1C), 209 .RESVAL (1'h0), 210 .Mubi (1'b0) 211 ) u_intr_state ( 212 .clk_i (clk_i), 213 .rst_ni (rst_ni), 214 215 // from register interface 216 .we (intr_state_we), 217 .wd (intr_state_wd), 218 219 // from internal hardware 220 .de (hw2reg.intr_state.de), 221 .d (hw2reg.intr_state.d), 222 223 // to internal hardware 224 .qe (), 225 .q (reg2hw.intr_state.q), 226 .ds (), 227 228 // to register interface (read) 229 .qs (intr_state_qs) 230 ); 231 232 233 // R[intr_enable]: V(False) 234 prim_subreg #( 235 .DW (1), 236 .SwAccess(prim_subreg_pkg::SwAccessRW), 237 .RESVAL (1'h0), 238 .Mubi (1'b0) 239 ) u_intr_enable ( 240 .clk_i (clk_i), 241 .rst_ni (rst_ni), 242 243 // from register interface 244 .we (intr_enable_we), 245 .wd (intr_enable_wd), 246 247 // from internal hardware 248 .de (1'b0), 249 .d ('0), 250 251 // to internal hardware 252 .qe (), 253 .q (reg2hw.intr_enable.q), 254 .ds (), 255 256 // to register interface (read) 257 .qs (intr_enable_qs) 258 ); 259 260 261 // R[intr_test]: V(True) 262 logic intr_test_qe; 263 logic [0:0] intr_test_flds_we; 264 1/1 assign intr_test_qe = &intr_test_flds_we; Tests: T47 T54 T55  265 prim_subreg_ext #( 266 .DW (1) 267 ) u_intr_test ( 268 .re (1'b0), 269 .we (intr_test_we), 270 .wd (intr_test_wd), 271 .d ('0), 272 .qre (), 273 .qe (intr_test_flds_we[0]), 274 .q (reg2hw.intr_test.q), 275 .ds (), 276 .qs () 277 ); 278 1/1 assign reg2hw.intr_test.qe = intr_test_qe; Tests: T47 T54 T55  279 280 281 // R[alert_test]: V(True) 282 logic alert_test_qe; 283 logic [0:0] alert_test_flds_we; 284 1/1 assign alert_test_qe = &alert_test_flds_we; Tests: T48 T56 T57  285 prim_subreg_ext #( 286 .DW (1) 287 ) u_alert_test ( 288 .re (1'b0), 289 .we (alert_test_we), 290 .wd (alert_test_wd), 291 .d ('0), 292 .qre (), 293 .qe (alert_test_flds_we[0]), 294 .q (reg2hw.alert_test.q), 295 .ds (), 296 .qs () 297 ); 298 1/1 assign reg2hw.alert_test.qe = alert_test_qe; Tests: T48 T56 T57  299 300 301 // R[ctrl_cfg_regwen]: V(True) 302 prim_subreg_ext #( 303 .DW (1) 304 ) u_ctrl_cfg_regwen ( 305 .re (ctrl_cfg_regwen_re), 306 .we (1'b0), 307 .wd ('0), 308 .d (hw2reg.ctrl_cfg_regwen.d), 309 .qre (), 310 .qe (), 311 .q (), 312 .ds (), 313 .qs (ctrl_cfg_regwen_qs) 314 ); 315 316 317 // R[control]: V(False) 318 // Create REGWEN-gated WE signal 319 logic control_gated_we; 320 1/1 assign control_gated_we = control_we & ctrl_cfg_regwen_qs; Tests: T1 T2 T3  321 // F[low_power_hint]: 0:0 322 prim_subreg #( 323 .DW (1), 324 .SwAccess(prim_subreg_pkg::SwAccessRW), 325 .RESVAL (1'h0), 326 .Mubi (1'b0) 327 ) u_control_low_power_hint ( 328 .clk_i (clk_i), 329 .rst_ni (rst_ni), 330 331 // from register interface 332 .we (control_gated_we), 333 .wd (control_low_power_hint_wd), 334 335 // from internal hardware 336 .de (hw2reg.control.low_power_hint.de), 337 .d (hw2reg.control.low_power_hint.d), 338 339 // to internal hardware 340 .qe (), 341 .q (reg2hw.control.low_power_hint.q), 342 .ds (), 343 344 // to register interface (read) 345 .qs (control_low_power_hint_qs) 346 ); 347 348 // F[core_clk_en]: 4:4 349 prim_subreg #( 350 .DW (1), 351 .SwAccess(prim_subreg_pkg::SwAccessRW), 352 .RESVAL (1'h0), 353 .Mubi (1'b0) 354 ) u_control_core_clk_en ( 355 .clk_i (clk_i), 356 .rst_ni (rst_ni), 357 358 // from register interface 359 .we (control_gated_we), 360 .wd (control_core_clk_en_wd), 361 362 // from internal hardware 363 .de (1'b0), 364 .d ('0), 365 366 // to internal hardware 367 .qe (), 368 .q (reg2hw.control.core_clk_en.q), 369 .ds (), 370 371 // to register interface (read) 372 .qs (control_core_clk_en_qs) 373 ); 374 375 // F[io_clk_en]: 5:5 376 prim_subreg #( 377 .DW (1), 378 .SwAccess(prim_subreg_pkg::SwAccessRW), 379 .RESVAL (1'h0), 380 .Mubi (1'b0) 381 ) u_control_io_clk_en ( 382 .clk_i (clk_i), 383 .rst_ni (rst_ni), 384 385 // from register interface 386 .we (control_gated_we), 387 .wd (control_io_clk_en_wd), 388 389 // from internal hardware 390 .de (1'b0), 391 .d ('0), 392 393 // to internal hardware 394 .qe (), 395 .q (reg2hw.control.io_clk_en.q), 396 .ds (), 397 398 // to register interface (read) 399 .qs (control_io_clk_en_qs) 400 ); 401 402 // F[usb_clk_en_lp]: 6:6 403 prim_subreg #( 404 .DW (1), 405 .SwAccess(prim_subreg_pkg::SwAccessRW), 406 .RESVAL (1'h0), 407 .Mubi (1'b0) 408 ) u_control_usb_clk_en_lp ( 409 .clk_i (clk_i), 410 .rst_ni (rst_ni), 411 412 // from register interface 413 .we (control_gated_we), 414 .wd (control_usb_clk_en_lp_wd), 415 416 // from internal hardware 417 .de (1'b0), 418 .d ('0), 419 420 // to internal hardware 421 .qe (), 422 .q (reg2hw.control.usb_clk_en_lp.q), 423 .ds (), 424 425 // to register interface (read) 426 .qs (control_usb_clk_en_lp_qs) 427 ); 428 429 // F[usb_clk_en_active]: 7:7 430 prim_subreg #( 431 .DW (1), 432 .SwAccess(prim_subreg_pkg::SwAccessRW), 433 .RESVAL (1'h1), 434 .Mubi (1'b0) 435 ) u_control_usb_clk_en_active ( 436 .clk_i (clk_i), 437 .rst_ni (rst_ni), 438 439 // from register interface 440 .we (control_gated_we), 441 .wd (control_usb_clk_en_active_wd), 442 443 // from internal hardware 444 .de (1'b0), 445 .d ('0), 446 447 // to internal hardware 448 .qe (), 449 .q (reg2hw.control.usb_clk_en_active.q), 450 .ds (), 451 452 // to register interface (read) 453 .qs (control_usb_clk_en_active_qs) 454 ); 455 456 // F[main_pd_n]: 8:8 457 prim_subreg #( 458 .DW (1), 459 .SwAccess(prim_subreg_pkg::SwAccessRW), 460 .RESVAL (1'h1), 461 .Mubi (1'b0) 462 ) u_control_main_pd_n ( 463 .clk_i (clk_i), 464 .rst_ni (rst_ni), 465 466 // from register interface 467 .we (control_gated_we), 468 .wd (control_main_pd_n_wd), 469 470 // from internal hardware 471 .de (1'b0), 472 .d ('0), 473 474 // to internal hardware 475 .qe (), 476 .q (reg2hw.control.main_pd_n.q), 477 .ds (), 478 479 // to register interface (read) 480 .qs (control_main_pd_n_qs) 481 ); 482 483 484 // R[cfg_cdc_sync]: V(False) 485 logic cfg_cdc_sync_qe; 486 logic [0:0] cfg_cdc_sync_flds_we; 487 prim_flop #( 488 .Width(1), 489 .ResetValue(0) 490 ) u_cfg_cdc_sync0_qe ( 491 .clk_i(clk_i), 492 .rst_ni(rst_ni), 493 .d_i(&cfg_cdc_sync_flds_we), 494 .q_o(cfg_cdc_sync_qe) 495 ); 496 prim_subreg #( 497 .DW (1), 498 .SwAccess(prim_subreg_pkg::SwAccessRW), 499 .RESVAL (1'h0), 500 .Mubi (1'b0) 501 ) u_cfg_cdc_sync ( 502 .clk_i (clk_i), 503 .rst_ni (rst_ni), 504 505 // from register interface 506 .we (cfg_cdc_sync_we), 507 .wd (cfg_cdc_sync_wd), 508 509 // from internal hardware 510 .de (hw2reg.cfg_cdc_sync.de), 511 .d (hw2reg.cfg_cdc_sync.d), 512 513 // to internal hardware 514 .qe (cfg_cdc_sync_flds_we[0]), 515 .q (reg2hw.cfg_cdc_sync.q), 516 .ds (), 517 518 // to register interface (read) 519 .qs (cfg_cdc_sync_qs) 520 ); 521 1/1 assign reg2hw.cfg_cdc_sync.qe = cfg_cdc_sync_qe; Tests: T1 T2 T3  522 523 524 // R[wakeup_en_regwen]: V(False) 525 prim_subreg #( 526 .DW (1), 527 .SwAccess(prim_subreg_pkg::SwAccessW0C), 528 .RESVAL (1'h1), 529 .Mubi (1'b0) 530 ) u_wakeup_en_regwen ( 531 .clk_i (clk_i), 532 .rst_ni (rst_ni), 533 534 // from register interface 535 .we (wakeup_en_regwen_we), 536 .wd (wakeup_en_regwen_wd), 537 538 // from internal hardware 539 .de (1'b0), 540 .d ('0), 541 542 // to internal hardware 543 .qe (), 544 .q (), 545 .ds (), 546 547 // to register interface (read) 548 .qs (wakeup_en_regwen_qs) 549 ); 550 551 552 // Subregister 0 of Multireg wakeup_en 553 // R[wakeup_en]: V(False) 554 // Create REGWEN-gated WE signal 555 logic wakeup_en_gated_we; 556 1/1 assign wakeup_en_gated_we = wakeup_en_we & wakeup_en_regwen_qs; Tests: T1 T2 T3  557 // F[en_0]: 0:0 558 prim_subreg #( 559 .DW (1), 560 .SwAccess(prim_subreg_pkg::SwAccessRW), 561 .RESVAL (1'h0), 562 .Mubi (1'b0) 563 ) u_wakeup_en_en_0 ( 564 .clk_i (clk_i), 565 .rst_ni (rst_ni), 566 567 // from register interface 568 .we (wakeup_en_gated_we), 569 .wd (wakeup_en_en_0_wd), 570 571 // from internal hardware 572 .de (1'b0), 573 .d ('0), 574 575 // to internal hardware 576 .qe (), 577 .q (reg2hw.wakeup_en[0].q), 578 .ds (), 579 580 // to register interface (read) 581 .qs (wakeup_en_en_0_qs) 582 ); 583 584 // F[en_1]: 1:1 585 prim_subreg #( 586 .DW (1), 587 .SwAccess(prim_subreg_pkg::SwAccessRW), 588 .RESVAL (1'h0), 589 .Mubi (1'b0) 590 ) u_wakeup_en_en_1 ( 591 .clk_i (clk_i), 592 .rst_ni (rst_ni), 593 594 // from register interface 595 .we (wakeup_en_gated_we), 596 .wd (wakeup_en_en_1_wd), 597 598 // from internal hardware 599 .de (1'b0), 600 .d ('0), 601 602 // to internal hardware 603 .qe (), 604 .q (reg2hw.wakeup_en[1].q), 605 .ds (), 606 607 // to register interface (read) 608 .qs (wakeup_en_en_1_qs) 609 ); 610 611 // F[en_2]: 2:2 612 prim_subreg #( 613 .DW (1), 614 .SwAccess(prim_subreg_pkg::SwAccessRW), 615 .RESVAL (1'h0), 616 .Mubi (1'b0) 617 ) u_wakeup_en_en_2 ( 618 .clk_i (clk_i), 619 .rst_ni (rst_ni), 620 621 // from register interface 622 .we (wakeup_en_gated_we), 623 .wd (wakeup_en_en_2_wd), 624 625 // from internal hardware 626 .de (1'b0), 627 .d ('0), 628 629 // to internal hardware 630 .qe (), 631 .q (reg2hw.wakeup_en[2].q), 632 .ds (), 633 634 // to register interface (read) 635 .qs (wakeup_en_en_2_qs) 636 ); 637 638 // F[en_3]: 3:3 639 prim_subreg #( 640 .DW (1), 641 .SwAccess(prim_subreg_pkg::SwAccessRW), 642 .RESVAL (1'h0), 643 .Mubi (1'b0) 644 ) u_wakeup_en_en_3 ( 645 .clk_i (clk_i), 646 .rst_ni (rst_ni), 647 648 // from register interface 649 .we (wakeup_en_gated_we), 650 .wd (wakeup_en_en_3_wd), 651 652 // from internal hardware 653 .de (1'b0), 654 .d ('0), 655 656 // to internal hardware 657 .qe (), 658 .q (reg2hw.wakeup_en[3].q), 659 .ds (), 660 661 // to register interface (read) 662 .qs (wakeup_en_en_3_qs) 663 ); 664 665 // F[en_4]: 4:4 666 prim_subreg #( 667 .DW (1), 668 .SwAccess(prim_subreg_pkg::SwAccessRW), 669 .RESVAL (1'h0), 670 .Mubi (1'b0) 671 ) u_wakeup_en_en_4 ( 672 .clk_i (clk_i), 673 .rst_ni (rst_ni), 674 675 // from register interface 676 .we (wakeup_en_gated_we), 677 .wd (wakeup_en_en_4_wd), 678 679 // from internal hardware 680 .de (1'b0), 681 .d ('0), 682 683 // to internal hardware 684 .qe (), 685 .q (reg2hw.wakeup_en[4].q), 686 .ds (), 687 688 // to register interface (read) 689 .qs (wakeup_en_en_4_qs) 690 ); 691 692 // F[en_5]: 5:5 693 prim_subreg #( 694 .DW (1), 695 .SwAccess(prim_subreg_pkg::SwAccessRW), 696 .RESVAL (1'h0), 697 .Mubi (1'b0) 698 ) u_wakeup_en_en_5 ( 699 .clk_i (clk_i), 700 .rst_ni (rst_ni), 701 702 // from register interface 703 .we (wakeup_en_gated_we), 704 .wd (wakeup_en_en_5_wd), 705 706 // from internal hardware 707 .de (1'b0), 708 .d ('0), 709 710 // to internal hardware 711 .qe (), 712 .q (reg2hw.wakeup_en[5].q), 713 .ds (), 714 715 // to register interface (read) 716 .qs (wakeup_en_en_5_qs) 717 ); 718 719 720 // Subregister 0 of Multireg wake_status 721 // R[wake_status]: V(False) 722 // F[val_0]: 0:0 723 prim_subreg #( 724 .DW (1), 725 .SwAccess(prim_subreg_pkg::SwAccessRO), 726 .RESVAL (1'h0), 727 .Mubi (1'b0) 728 ) u_wake_status_val_0 ( 729 .clk_i (clk_i), 730 .rst_ni (rst_ni), 731 732 // from register interface 733 .we (1'b0), 734 .wd ('0), 735 736 // from internal hardware 737 .de (hw2reg.wake_status[0].de), 738 .d (hw2reg.wake_status[0].d), 739 740 // to internal hardware 741 .qe (), 742 .q (), 743 .ds (), 744 745 // to register interface (read) 746 .qs (wake_status_val_0_qs) 747 ); 748 749 // F[val_1]: 1:1 750 prim_subreg #( 751 .DW (1), 752 .SwAccess(prim_subreg_pkg::SwAccessRO), 753 .RESVAL (1'h0), 754 .Mubi (1'b0) 755 ) u_wake_status_val_1 ( 756 .clk_i (clk_i), 757 .rst_ni (rst_ni), 758 759 // from register interface 760 .we (1'b0), 761 .wd ('0), 762 763 // from internal hardware 764 .de (hw2reg.wake_status[1].de), 765 .d (hw2reg.wake_status[1].d), 766 767 // to internal hardware 768 .qe (), 769 .q (), 770 .ds (), 771 772 // to register interface (read) 773 .qs (wake_status_val_1_qs) 774 ); 775 776 // F[val_2]: 2:2 777 prim_subreg #( 778 .DW (1), 779 .SwAccess(prim_subreg_pkg::SwAccessRO), 780 .RESVAL (1'h0), 781 .Mubi (1'b0) 782 ) u_wake_status_val_2 ( 783 .clk_i (clk_i), 784 .rst_ni (rst_ni), 785 786 // from register interface 787 .we (1'b0), 788 .wd ('0), 789 790 // from internal hardware 791 .de (hw2reg.wake_status[2].de), 792 .d (hw2reg.wake_status[2].d), 793 794 // to internal hardware 795 .qe (), 796 .q (), 797 .ds (), 798 799 // to register interface (read) 800 .qs (wake_status_val_2_qs) 801 ); 802 803 // F[val_3]: 3:3 804 prim_subreg #( 805 .DW (1), 806 .SwAccess(prim_subreg_pkg::SwAccessRO), 807 .RESVAL (1'h0), 808 .Mubi (1'b0) 809 ) u_wake_status_val_3 ( 810 .clk_i (clk_i), 811 .rst_ni (rst_ni), 812 813 // from register interface 814 .we (1'b0), 815 .wd ('0), 816 817 // from internal hardware 818 .de (hw2reg.wake_status[3].de), 819 .d (hw2reg.wake_status[3].d), 820 821 // to internal hardware 822 .qe (), 823 .q (), 824 .ds (), 825 826 // to register interface (read) 827 .qs (wake_status_val_3_qs) 828 ); 829 830 // F[val_4]: 4:4 831 prim_subreg #( 832 .DW (1), 833 .SwAccess(prim_subreg_pkg::SwAccessRO), 834 .RESVAL (1'h0), 835 .Mubi (1'b0) 836 ) u_wake_status_val_4 ( 837 .clk_i (clk_i), 838 .rst_ni (rst_ni), 839 840 // from register interface 841 .we (1'b0), 842 .wd ('0), 843 844 // from internal hardware 845 .de (hw2reg.wake_status[4].de), 846 .d (hw2reg.wake_status[4].d), 847 848 // to internal hardware 849 .qe (), 850 .q (), 851 .ds (), 852 853 // to register interface (read) 854 .qs (wake_status_val_4_qs) 855 ); 856 857 // F[val_5]: 5:5 858 prim_subreg #( 859 .DW (1), 860 .SwAccess(prim_subreg_pkg::SwAccessRO), 861 .RESVAL (1'h0), 862 .Mubi (1'b0) 863 ) u_wake_status_val_5 ( 864 .clk_i (clk_i), 865 .rst_ni (rst_ni), 866 867 // from register interface 868 .we (1'b0), 869 .wd ('0), 870 871 // from internal hardware 872 .de (hw2reg.wake_status[5].de), 873 .d (hw2reg.wake_status[5].d), 874 875 // to internal hardware 876 .qe (), 877 .q (), 878 .ds (), 879 880 // to register interface (read) 881 .qs (wake_status_val_5_qs) 882 ); 883 884 885 // R[reset_en_regwen]: V(False) 886 prim_subreg #( 887 .DW (1), 888 .SwAccess(prim_subreg_pkg::SwAccessW0C), 889 .RESVAL (1'h1), 890 .Mubi (1'b0) 891 ) u_reset_en_regwen ( 892 .clk_i (clk_i), 893 .rst_ni (rst_ni), 894 895 // from register interface 896 .we (reset_en_regwen_we), 897 .wd (reset_en_regwen_wd), 898 899 // from internal hardware 900 .de (1'b0), 901 .d ('0), 902 903 // to internal hardware 904 .qe (), 905 .q (), 906 .ds (), 907 908 // to register interface (read) 909 .qs (reset_en_regwen_qs) 910 ); 911 912 913 // Subregister 0 of Multireg reset_en 914 // R[reset_en]: V(False) 915 // Create REGWEN-gated WE signal 916 logic reset_en_gated_we; 917 1/1 assign reset_en_gated_we = reset_en_we & reset_en_regwen_qs; Tests: T1 T2 T3  918 // F[en_0]: 0:0 919 prim_subreg #( 920 .DW (1), 921 .SwAccess(prim_subreg_pkg::SwAccessRW), 922 .RESVAL (1'h0), 923 .Mubi (1'b0) 924 ) u_reset_en_en_0 ( 925 .clk_i (clk_i), 926 .rst_ni (rst_ni), 927 928 // from register interface 929 .we (reset_en_gated_we), 930 .wd (reset_en_en_0_wd), 931 932 // from internal hardware 933 .de (1'b0), 934 .d ('0), 935 936 // to internal hardware 937 .qe (), 938 .q (reg2hw.reset_en[0].q), 939 .ds (), 940 941 // to register interface (read) 942 .qs (reset_en_en_0_qs) 943 ); 944 945 // F[en_1]: 1:1 946 prim_subreg #( 947 .DW (1), 948 .SwAccess(prim_subreg_pkg::SwAccessRW), 949 .RESVAL (1'h0), 950 .Mubi (1'b0) 951 ) u_reset_en_en_1 ( 952 .clk_i (clk_i), 953 .rst_ni (rst_ni), 954 955 // from register interface 956 .we (reset_en_gated_we), 957 .wd (reset_en_en_1_wd), 958 959 // from internal hardware 960 .de (1'b0), 961 .d ('0), 962 963 // to internal hardware 964 .qe (), 965 .q (reg2hw.reset_en[1].q), 966 .ds (), 967 968 // to register interface (read) 969 .qs (reset_en_en_1_qs) 970 ); 971 972 973 // Subregister 0 of Multireg reset_status 974 // R[reset_status]: V(False) 975 // F[val_0]: 0:0 976 prim_subreg #( 977 .DW (1), 978 .SwAccess(prim_subreg_pkg::SwAccessRO), 979 .RESVAL (1'h0), 980 .Mubi (1'b0) 981 ) u_reset_status_val_0 ( 982 .clk_i (clk_i), 983 .rst_ni (rst_ni), 984 985 // from register interface 986 .we (1'b0), 987 .wd ('0), 988 989 // from internal hardware 990 .de (hw2reg.reset_status[0].de), 991 .d (hw2reg.reset_status[0].d), 992 993 // to internal hardware 994 .qe (), 995 .q (), 996 .ds (), 997 998 // to register interface (read) 999 .qs (reset_status_val_0_qs) 1000 ); 1001 1002 // F[val_1]: 1:1 1003 prim_subreg #( 1004 .DW (1), 1005 .SwAccess(prim_subreg_pkg::SwAccessRO), 1006 .RESVAL (1'h0), 1007 .Mubi (1'b0) 1008 ) u_reset_status_val_1 ( 1009 .clk_i (clk_i), 1010 .rst_ni (rst_ni), 1011 1012 // from register interface 1013 .we (1'b0), 1014 .wd ('0), 1015 1016 // from internal hardware 1017 .de (hw2reg.reset_status[1].de), 1018 .d (hw2reg.reset_status[1].d), 1019 1020 // to internal hardware 1021 .qe (), 1022 .q (), 1023 .ds (), 1024 1025 // to register interface (read) 1026 .qs (reset_status_val_1_qs) 1027 ); 1028 1029 1030 // R[escalate_reset_status]: V(False) 1031 prim_subreg #( 1032 .DW (1), 1033 .SwAccess(prim_subreg_pkg::SwAccessRO), 1034 .RESVAL (1'h0), 1035 .Mubi (1'b0) 1036 ) u_escalate_reset_status ( 1037 .clk_i (clk_i), 1038 .rst_ni (rst_ni), 1039 1040 // from register interface 1041 .we (1'b0), 1042 .wd ('0), 1043 1044 // from internal hardware 1045 .de (hw2reg.escalate_reset_status.de), 1046 .d (hw2reg.escalate_reset_status.d), 1047 1048 // to internal hardware 1049 .qe (), 1050 .q (), 1051 .ds (), 1052 1053 // to register interface (read) 1054 .qs (escalate_reset_status_qs) 1055 ); 1056 1057 1058 // R[wake_info_capture_dis]: V(False) 1059 prim_subreg #( 1060 .DW (1), 1061 .SwAccess(prim_subreg_pkg::SwAccessRW), 1062 .RESVAL (1'h0), 1063 .Mubi (1'b0) 1064 ) u_wake_info_capture_dis ( 1065 .clk_i (clk_i), 1066 .rst_ni (rst_ni), 1067 1068 // from register interface 1069 .we (wake_info_capture_dis_we), 1070 .wd (wake_info_capture_dis_wd), 1071 1072 // from internal hardware 1073 .de (1'b0), 1074 .d ('0), 1075 1076 // to internal hardware 1077 .qe (), 1078 .q (reg2hw.wake_info_capture_dis.q), 1079 .ds (), 1080 1081 // to register interface (read) 1082 .qs (wake_info_capture_dis_qs) 1083 ); 1084 1085 1086 // R[wake_info]: V(True) 1087 logic wake_info_qe; 1088 logic [2:0] wake_info_flds_we; 1089 1/1 assign wake_info_qe = &wake_info_flds_we; Tests: T1 T2 T3  1090 // F[reasons]: 5:0 1091 prim_subreg_ext #( 1092 .DW (6) 1093 ) u_wake_info_reasons ( 1094 .re (wake_info_re), 1095 .we (wake_info_we), 1096 .wd (wake_info_reasons_wd), 1097 .d (hw2reg.wake_info.reasons.d), 1098 .qre (), 1099 .qe (wake_info_flds_we[0]), 1100 .q (reg2hw.wake_info.reasons.q), 1101 .ds (), 1102 .qs (wake_info_reasons_qs) 1103 ); 1104 1/1 assign reg2hw.wake_info.reasons.qe = wake_info_qe; Tests: T1 T2 T3  1105 1106 // F[fall_through]: 6:6 1107 prim_subreg_ext #( 1108 .DW (1) 1109 ) u_wake_info_fall_through ( 1110 .re (wake_info_re), 1111 .we (wake_info_we), 1112 .wd (wake_info_fall_through_wd), 1113 .d (hw2reg.wake_info.fall_through.d), 1114 .qre (), 1115 .qe (wake_info_flds_we[1]), 1116 .q (reg2hw.wake_info.fall_through.q), 1117 .ds (), 1118 .qs (wake_info_fall_through_qs) 1119 ); 1120 1/1 assign reg2hw.wake_info.fall_through.qe = wake_info_qe; Tests: T1 T2 T3  1121 1122 // F[abort]: 7:7 1123 prim_subreg_ext #( 1124 .DW (1) 1125 ) u_wake_info_abort ( 1126 .re (wake_info_re), 1127 .we (wake_info_we), 1128 .wd (wake_info_abort_wd), 1129 .d (hw2reg.wake_info.abort.d), 1130 .qre (), 1131 .qe (wake_info_flds_we[2]), 1132 .q (reg2hw.wake_info.abort.q), 1133 .ds (), 1134 .qs (wake_info_abort_qs) 1135 ); 1136 1/1 assign reg2hw.wake_info.abort.qe = wake_info_qe; Tests: T1 T2 T3  1137 1138 1139 // R[fault_status]: V(False) 1140 // F[reg_intg_err]: 0:0 1141 prim_subreg #( 1142 .DW (1), 1143 .SwAccess(prim_subreg_pkg::SwAccessRO), 1144 .RESVAL (1'h0), 1145 .Mubi (1'b0) 1146 ) u_fault_status_reg_intg_err ( 1147 // sync clock and reset required for this register 1148 .clk_i (clk_lc_i), 1149 .rst_ni (rst_lc_ni), 1150 1151 // from register interface 1152 .we (1'b0), 1153 .wd ('0), 1154 1155 // from internal hardware 1156 .de (hw2reg.fault_status.reg_intg_err.de), 1157 .d (hw2reg.fault_status.reg_intg_err.d), 1158 1159 // to internal hardware 1160 .qe (), 1161 .q (reg2hw.fault_status.reg_intg_err.q), 1162 .ds (), 1163 1164 // to register interface (read) 1165 .qs (fault_status_reg_intg_err_qs) 1166 ); 1167 1168 // F[esc_timeout]: 1:1 1169 prim_subreg #( 1170 .DW (1), 1171 .SwAccess(prim_subreg_pkg::SwAccessRO), 1172 .RESVAL (1'h0), 1173 .Mubi (1'b0) 1174 ) u_fault_status_esc_timeout ( 1175 // sync clock and reset required for this register 1176 .clk_i (clk_lc_i), 1177 .rst_ni (rst_lc_ni), 1178 1179 // from register interface 1180 .we (1'b0), 1181 .wd ('0), 1182 1183 // from internal hardware 1184 .de (hw2reg.fault_status.esc_timeout.de), 1185 .d (hw2reg.fault_status.esc_timeout.d), 1186 1187 // to internal hardware 1188 .qe (), 1189 .q (reg2hw.fault_status.esc_timeout.q), 1190 .ds (), 1191 1192 // to register interface (read) 1193 .qs (fault_status_esc_timeout_qs) 1194 ); 1195 1196 // F[main_pd_glitch]: 2:2 1197 prim_subreg #( 1198 .DW (1), 1199 .SwAccess(prim_subreg_pkg::SwAccessRO), 1200 .RESVAL (1'h0), 1201 .Mubi (1'b0) 1202 ) u_fault_status_main_pd_glitch ( 1203 // sync clock and reset required for this register 1204 .clk_i (clk_lc_i), 1205 .rst_ni (rst_lc_ni), 1206 1207 // from register interface 1208 .we (1'b0), 1209 .wd ('0), 1210 1211 // from internal hardware 1212 .de (hw2reg.fault_status.main_pd_glitch.de), 1213 .d (hw2reg.fault_status.main_pd_glitch.d), 1214 1215 // to internal hardware 1216 .qe (), 1217 .q (reg2hw.fault_status.main_pd_glitch.q), 1218 .ds (), 1219 1220 // to register interface (read) 1221 .qs (fault_status_main_pd_glitch_qs) 1222 ); 1223 1224 1225 1226 logic [16:0] addr_hit; 1227 always_comb begin 1228 1/1 addr_hit = '0; Tests: T1 T2 T3  1229 1/1 addr_hit[ 0] = (reg_addr == PWRMGR_INTR_STATE_OFFSET); Tests: T1 T2 T3  1230 1/1 addr_hit[ 1] = (reg_addr == PWRMGR_INTR_ENABLE_OFFSET); Tests: T1 T2 T3  1231 1/1 addr_hit[ 2] = (reg_addr == PWRMGR_INTR_TEST_OFFSET); Tests: T1 T2 T3  1232 1/1 addr_hit[ 3] = (reg_addr == PWRMGR_ALERT_TEST_OFFSET); Tests: T1 T2 T3  1233 1/1 addr_hit[ 4] = (reg_addr == PWRMGR_CTRL_CFG_REGWEN_OFFSET); Tests: T1 T2 T3  1234 1/1 addr_hit[ 5] = (reg_addr == PWRMGR_CONTROL_OFFSET); Tests: T1 T2 T3  1235 1/1 addr_hit[ 6] = (reg_addr == PWRMGR_CFG_CDC_SYNC_OFFSET); Tests: T1 T2 T3  1236 1/1 addr_hit[ 7] = (reg_addr == PWRMGR_WAKEUP_EN_REGWEN_OFFSET); Tests: T1 T2 T3  1237 1/1 addr_hit[ 8] = (reg_addr == PWRMGR_WAKEUP_EN_OFFSET); Tests: T1 T2 T3  1238 1/1 addr_hit[ 9] = (reg_addr == PWRMGR_WAKE_STATUS_OFFSET); Tests: T1 T2 T3  1239 1/1 addr_hit[10] = (reg_addr == PWRMGR_RESET_EN_REGWEN_OFFSET); Tests: T1 T2 T3  1240 1/1 addr_hit[11] = (reg_addr == PWRMGR_RESET_EN_OFFSET); Tests: T1 T2 T3  1241 1/1 addr_hit[12] = (reg_addr == PWRMGR_RESET_STATUS_OFFSET); Tests: T1 T2 T3  1242 1/1 addr_hit[13] = (reg_addr == PWRMGR_ESCALATE_RESET_STATUS_OFFSET); Tests: T1 T2 T3  1243 1/1 addr_hit[14] = (reg_addr == PWRMGR_WAKE_INFO_CAPTURE_DIS_OFFSET); Tests: T1 T2 T3  1244 1/1 addr_hit[15] = (reg_addr == PWRMGR_WAKE_INFO_OFFSET); Tests: T1 T2 T3  1245 1/1 addr_hit[16] = (reg_addr == PWRMGR_FAULT_STATUS_OFFSET); Tests: T1 T2 T3  1246 end 1247 1248 1/1 assign addrmiss = (reg_re || reg_we) ? ~|addr_hit : 1'b0 ; Tests: T1 T2 T3  1249 1250 // Check sub-word write is permitted 1251 always_comb begin 1252 1/1 wr_err = (reg_we & Tests: T1 T2 T3  1253 ((addr_hit[ 0] & (|(PWRMGR_PERMIT[ 0] & ~reg_be))) | 1254 (addr_hit[ 1] & (|(PWRMGR_PERMIT[ 1] & ~reg_be))) | 1255 (addr_hit[ 2] & (|(PWRMGR_PERMIT[ 2] & ~reg_be))) | 1256 (addr_hit[ 3] & (|(PWRMGR_PERMIT[ 3] & ~reg_be))) | 1257 (addr_hit[ 4] & (|(PWRMGR_PERMIT[ 4] & ~reg_be))) | 1258 (addr_hit[ 5] & (|(PWRMGR_PERMIT[ 5] & ~reg_be))) | 1259 (addr_hit[ 6] & (|(PWRMGR_PERMIT[ 6] & ~reg_be))) | 1260 (addr_hit[ 7] & (|(PWRMGR_PERMIT[ 7] & ~reg_be))) | 1261 (addr_hit[ 8] & (|(PWRMGR_PERMIT[ 8] & ~reg_be))) | 1262 (addr_hit[ 9] & (|(PWRMGR_PERMIT[ 9] & ~reg_be))) | 1263 (addr_hit[10] & (|(PWRMGR_PERMIT[10] & ~reg_be))) | 1264 (addr_hit[11] & (|(PWRMGR_PERMIT[11] & ~reg_be))) | 1265 (addr_hit[12] & (|(PWRMGR_PERMIT[12] & ~reg_be))) | 1266 (addr_hit[13] & (|(PWRMGR_PERMIT[13] & ~reg_be))) | 1267 (addr_hit[14] & (|(PWRMGR_PERMIT[14] & ~reg_be))) | 1268 (addr_hit[15] & (|(PWRMGR_PERMIT[15] & ~reg_be))) | 1269 (addr_hit[16] & (|(PWRMGR_PERMIT[16] & ~reg_be))))); 1270 end 1271 1272 // Generate write-enables 1273 1/1 assign intr_state_we = addr_hit[0] & reg_we & !reg_error; Tests: T1 T2 T3  1274 1275 1/1 assign intr_state_wd = reg_wdata[0]; Tests: T1 T2 T3  1276 1/1 assign intr_enable_we = addr_hit[1] & reg_we & !reg_error; Tests: T1 T2 T3  1277 1278 1/1 assign intr_enable_wd = reg_wdata[0]; Tests: T1 T2 T3  1279 1/1 assign intr_test_we = addr_hit[2] & reg_we & !reg_error; Tests: T1 T2 T3  1280 1281 1/1 assign intr_test_wd = reg_wdata[0]; Tests: T1 T2 T3  1282 1/1 assign alert_test_we = addr_hit[3] & reg_we & !reg_error; Tests: T1 T2 T3  1283 1284 1/1 assign alert_test_wd = reg_wdata[0]; Tests: T1 T2 T3  1285 1/1 assign ctrl_cfg_regwen_re = addr_hit[4] & reg_re & !reg_error; Tests: T1 T2 T3  1286 1/1 assign control_we = addr_hit[5] & reg_we & !reg_error; Tests: T1 T2 T3  1287 1288 1/1 assign control_low_power_hint_wd = reg_wdata[0]; Tests: T1 T2 T3  1289 1290 1/1 assign control_core_clk_en_wd = reg_wdata[4]; Tests: T1 T2 T3  1291 1292 1/1 assign control_io_clk_en_wd = reg_wdata[5]; Tests: T1 T2 T3  1293 1294 1/1 assign control_usb_clk_en_lp_wd = reg_wdata[6]; Tests: T1 T2 T3  1295 1296 1/1 assign control_usb_clk_en_active_wd = reg_wdata[7]; Tests: T1 T2 T3  1297 1298 1/1 assign control_main_pd_n_wd = reg_wdata[8]; Tests: T1 T2 T3  1299 1/1 assign cfg_cdc_sync_we = addr_hit[6] & reg_we & !reg_error; Tests: T1 T2 T3  1300 1301 1/1 assign cfg_cdc_sync_wd = reg_wdata[0]; Tests: T1 T2 T3  1302 1/1 assign wakeup_en_regwen_we = addr_hit[7] & reg_we & !reg_error; Tests: T1 T2 T3  1303 1304 1/1 assign wakeup_en_regwen_wd = reg_wdata[0]; Tests: T1 T2 T3  1305 1/1 assign wakeup_en_we = addr_hit[8] & reg_we & !reg_error; Tests: T1 T2 T3  1306 1307 1/1 assign wakeup_en_en_0_wd = reg_wdata[0]; Tests: T1 T2 T3  1308 1309 1/1 assign wakeup_en_en_1_wd = reg_wdata[1]; Tests: T1 T2 T3  1310 1311 1/1 assign wakeup_en_en_2_wd = reg_wdata[2]; Tests: T1 T2 T3  1312 1313 1/1 assign wakeup_en_en_3_wd = reg_wdata[3]; Tests: T1 T2 T3  1314 1315 1/1 assign wakeup_en_en_4_wd = reg_wdata[4]; Tests: T1 T2 T3  1316 1317 1/1 assign wakeup_en_en_5_wd = reg_wdata[5]; Tests: T1 T2 T3  1318 1/1 assign reset_en_regwen_we = addr_hit[10] & reg_we & !reg_error; Tests: T1 T2 T3  1319 1320 1/1 assign reset_en_regwen_wd = reg_wdata[0]; Tests: T1 T2 T3  1321 1/1 assign reset_en_we = addr_hit[11] & reg_we & !reg_error; Tests: T1 T2 T3  1322 1323 1/1 assign reset_en_en_0_wd = reg_wdata[0]; Tests: T1 T2 T3  1324 1325 1/1 assign reset_en_en_1_wd = reg_wdata[1]; Tests: T1 T2 T3  1326 1/1 assign wake_info_capture_dis_we = addr_hit[14] & reg_we & !reg_error; Tests: T1 T2 T3  1327 1328 1/1 assign wake_info_capture_dis_wd = reg_wdata[0]; Tests: T1 T2 T3  1329 1/1 assign wake_info_re = addr_hit[15] & reg_re & !reg_error; Tests: T1 T2 T3  1330 1/1 assign wake_info_we = addr_hit[15] & reg_we & !reg_error; Tests: T1 T2 T3  1331 1332 1/1 assign wake_info_reasons_wd = reg_wdata[5:0]; Tests: T1 T2 T3  1333 1334 1/1 assign wake_info_fall_through_wd = reg_wdata[6]; Tests: T1 T2 T3  1335 1336 1/1 assign wake_info_abort_wd = reg_wdata[7]; Tests: T1 T2 T3  1337 1338 // Assign write-enables to checker logic vector. 1339 always_comb begin 1340 1/1 reg_we_check = '0; Tests: T1 T2 T3  1341 1/1 reg_we_check[0] = intr_state_we; Tests: T1 T2 T3  1342 1/1 reg_we_check[1] = intr_enable_we; Tests: T1 T2 T3  1343 1/1 reg_we_check[2] = intr_test_we; Tests: T1 T2 T3  1344 1/1 reg_we_check[3] = alert_test_we; Tests: T1 T2 T3  1345 1/1 reg_we_check[4] = 1'b0; Tests: T1 T2 T3  1346 1/1 reg_we_check[5] = control_gated_we; Tests: T1 T2 T3  1347 1/1 reg_we_check[6] = cfg_cdc_sync_we; Tests: T1 T2 T3  1348 1/1 reg_we_check[7] = wakeup_en_regwen_we; Tests: T1 T2 T3  1349 1/1 reg_we_check[8] = wakeup_en_gated_we; Tests: T1 T2 T3  1350 1/1 reg_we_check[9] = 1'b0; Tests: T1 T2 T3  1351 1/1 reg_we_check[10] = reset_en_regwen_we; Tests: T1 T2 T3  1352 1/1 reg_we_check[11] = reset_en_gated_we; Tests: T1 T2 T3  1353 1/1 reg_we_check[12] = 1'b0; Tests: T1 T2 T3  1354 1/1 reg_we_check[13] = 1'b0; Tests: T1 T2 T3  1355 1/1 reg_we_check[14] = wake_info_capture_dis_we; Tests: T1 T2 T3  1356 1/1 reg_we_check[15] = wake_info_we; Tests: T1 T2 T3  1357 1/1 reg_we_check[16] = 1'b0; Tests: T1 T2 T3  1358 end 1359 1360 // Read data return 1361 always_comb begin 1362 1/1 reg_rdata_next = '0; Tests: T1 T2 T3  1363 1/1 unique case (1'b1) Tests: T1 T2 T3  1364 addr_hit[0]: begin 1365 1/1 reg_rdata_next[0] = intr_state_qs; Tests: T1 T2 T3  1366 end 1367 1368 addr_hit[1]: begin 1369 1/1 reg_rdata_next[0] = intr_enable_qs; Tests: T1 T2 T3  1370 end 1371 1372 addr_hit[2]: begin 1373 1/1 reg_rdata_next[0] = '0; Tests: T1 T2 T3  1374 end 1375 1376 addr_hit[3]: begin 1377 1/1 reg_rdata_next[0] = '0; Tests: T1 T2 T3  1378 end 1379 1380 addr_hit[4]: begin 1381 1/1 reg_rdata_next[0] = ctrl_cfg_regwen_qs; Tests: T1 T2 T3  1382 end 1383 1384 addr_hit[5]: begin 1385 1/1 reg_rdata_next[0] = control_low_power_hint_qs; Tests: T1 T2 T3  1386 1/1 reg_rdata_next[4] = control_core_clk_en_qs; Tests: T1 T2 T3  1387 1/1 reg_rdata_next[5] = control_io_clk_en_qs; Tests: T1 T2 T3  1388 1/1 reg_rdata_next[6] = control_usb_clk_en_lp_qs; Tests: T1 T2 T3  1389 1/1 reg_rdata_next[7] = control_usb_clk_en_active_qs; Tests: T1 T2 T3  1390 1/1 reg_rdata_next[8] = control_main_pd_n_qs; Tests: T1 T2 T3  1391 end 1392 1393 addr_hit[6]: begin 1394 1/1 reg_rdata_next[0] = cfg_cdc_sync_qs; Tests: T1 T2 T3  1395 end 1396 1397 addr_hit[7]: begin 1398 1/1 reg_rdata_next[0] = wakeup_en_regwen_qs; Tests: T1 T2 T3  1399 end 1400 1401 addr_hit[8]: begin 1402 1/1 reg_rdata_next[0] = wakeup_en_en_0_qs; Tests: T1 T2 T3  1403 1/1 reg_rdata_next[1] = wakeup_en_en_1_qs; Tests: T1 T2 T3  1404 1/1 reg_rdata_next[2] = wakeup_en_en_2_qs; Tests: T1 T2 T3  1405 1/1 reg_rdata_next[3] = wakeup_en_en_3_qs; Tests: T1 T2 T3  1406 1/1 reg_rdata_next[4] = wakeup_en_en_4_qs; Tests: T1 T2 T3  1407 1/1 reg_rdata_next[5] = wakeup_en_en_5_qs; Tests: T1 T2 T3  1408 end 1409 1410 addr_hit[9]: begin 1411 1/1 reg_rdata_next[0] = wake_status_val_0_qs; Tests: T1 T2 T3  1412 1/1 reg_rdata_next[1] = wake_status_val_1_qs; Tests: T1 T2 T3  1413 1/1 reg_rdata_next[2] = wake_status_val_2_qs; Tests: T1 T2 T3  1414 1/1 reg_rdata_next[3] = wake_status_val_3_qs; Tests: T1 T2 T3  1415 1/1 reg_rdata_next[4] = wake_status_val_4_qs; Tests: T1 T2 T3  1416 1/1 reg_rdata_next[5] = wake_status_val_5_qs; Tests: T1 T2 T3  1417 end 1418 1419 addr_hit[10]: begin 1420 1/1 reg_rdata_next[0] = reset_en_regwen_qs; Tests: T1 T2 T3  1421 end 1422 1423 addr_hit[11]: begin 1424 1/1 reg_rdata_next[0] = reset_en_en_0_qs; Tests: T1 T2 T3  1425 1/1 reg_rdata_next[1] = reset_en_en_1_qs; Tests: T1 T2 T3  1426 end 1427 1428 addr_hit[12]: begin 1429 1/1 reg_rdata_next[0] = reset_status_val_0_qs; Tests: T1 T2 T3  1430 1/1 reg_rdata_next[1] = reset_status_val_1_qs; Tests: T1 T2 T3  1431 end 1432 1433 addr_hit[13]: begin 1434 1/1 reg_rdata_next[0] = escalate_reset_status_qs; Tests: T1 T2 T3  1435 end 1436 1437 addr_hit[14]: begin 1438 1/1 reg_rdata_next[0] = wake_info_capture_dis_qs; Tests: T1 T2 T3  1439 end 1440 1441 addr_hit[15]: begin 1442 1/1 reg_rdata_next[5:0] = wake_info_reasons_qs; Tests: T1 T2 T3  1443 1/1 reg_rdata_next[6] = wake_info_fall_through_qs; Tests: T1 T2 T3  1444 1/1 reg_rdata_next[7] = wake_info_abort_qs; Tests: T1 T2 T3  1445 end 1446 1447 addr_hit[16]: begin 1448 1/1 reg_rdata_next[0] = fault_status_reg_intg_err_qs; Tests: T1 T2 T3  1449 1/1 reg_rdata_next[1] = fault_status_esc_timeout_qs; Tests: T1 T2 T3  1450 1/1 reg_rdata_next[2] = fault_status_main_pd_glitch_qs; Tests: T1 T2 T3  1451 end 1452 1453 default: begin 1454 reg_rdata_next = '1; 1455 end 1456 endcase 1457 end 1458 1459 // shadow busy 1460 logic shadow_busy; 1461 assign shadow_busy = 1'b0; 1462 1463 // register busy 1464 unreachable assign reg_busy = shadow_busy; 1465 1466 // Unused signal tieoff 1467 1468 // wdata / byte enable are not always fully used 1469 // add a blanket unused statement to handle lint waivers 1470 logic unused_wdata; 1471 logic unused_be; 1472 1/1 assign unused_wdata = ^reg_wdata; Tests: T1 T2 T3  1473 1/1 assign unused_be = ^reg_be; Tests: T1 T2 T3 

Cond Coverage for Module : pwrmgr_reg_top
TotalCoveredPercent
Conditions190190100.00
Logical190190100.00
Non-Logical00
Event00

 LINE       60
 EXPRESSION (reg_we && ((!addrmiss)))
             ---1--    ------2------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT50,T47,T58
11CoveredT1,T2,T3

 LINE       72
 EXPRESSION (intg_err || reg_we_err)
             ----1---    -----2----
-1--2-StatusTests
00CoveredT1,T2,T3
01CoveredT20,T21,T22
10CoveredT53,T59,T60

 LINE       79
 EXPRESSION (err_q | intg_err | reg_we_err)
             --1--   ----2---   -----3----
-1--2--3-StatusTests
000CoveredT1,T2,T3
001CoveredT20,T21,T22
010CoveredT53,T59,T60
100CoveredT20,T21,T22

 LINE       121
 EXPRESSION (addrmiss | wr_err | intg_err)
             ----1---   ---2--   ----3---
-1--2--3-StatusTests
000CoveredT1,T2,T3
001CoveredT53,T59,T60
010CoveredT50,T47,T48
100CoveredT50,T47,T48

 LINE       320
 EXPRESSION (control_we & ctrl_cfg_regwen_qs)
             -----1----   ---------2--------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT61,T62,T63
11CoveredT1,T3,T4

 LINE       556
 EXPRESSION (wakeup_en_we & wakeup_en_regwen_qs)
             ------1-----   ---------2---------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT64,T53,T59
11CoveredT1,T3,T4

 LINE       917
 EXPRESSION (reset_en_we & reset_en_regwen_qs)
             -----1-----   ---------2--------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT57,T64,T65
11CoveredT1,T2,T5

 LINE       1229
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_INTR_STATE_OFFSET)
            ---------------------------1--------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       1230
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_INTR_ENABLE_OFFSET)
            ---------------------------1---------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       1231
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_INTR_TEST_OFFSET)
            --------------------------1--------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT5,T6,T23

 LINE       1232
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_ALERT_TEST_OFFSET)
            ---------------------------1--------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT5,T6,T23

 LINE       1233
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_CTRL_CFG_REGWEN_OFFSET)
            -----------------------------1-----------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT6,T23,T30

 LINE       1234
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_CONTROL_OFFSET)
            -------------------------1-------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T3,T4

 LINE       1235
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_CFG_CDC_SYNC_OFFSET)
            ----------------------------1---------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       1236
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_WAKEUP_EN_REGWEN_OFFSET)
            ------------------------------1-----------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT5,T6,T23

 LINE       1237
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_WAKEUP_EN_OFFSET)
            --------------------------1--------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T3,T4

 LINE       1238
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_WAKE_STATUS_OFFSET)
            ---------------------------1---------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T3,T4

 LINE       1239
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_RESET_EN_REGWEN_OFFSET)
            -----------------------------1-----------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT6,T23,T16

 LINE       1240
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_RESET_EN_OFFSET)
            --------------------------1-------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T5

 LINE       1241
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_RESET_STATUS_OFFSET)
            ----------------------------1---------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T5

 LINE       1242
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_ESCALATE_RESET_STATUS_OFFSET)
            --------------------------------1--------------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT5,T6,T23

 LINE       1243
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_WAKE_INFO_CAPTURE_DIS_OFFSET)
            --------------------------------1--------------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       1244
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_WAKE_INFO_OFFSET)
            --------------------------1--------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       1245
 EXPRESSION (reg_addr == pwrmgr_reg_pkg::PWRMGR_FAULT_STATUS_OFFSET)
            ----------------------------1---------------------------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT6,T23,T20

 LINE       1248
 EXPRESSION ((reg_re || reg_we) ? ((~|addr_hit)) : 1'b0)
             ---------1--------
-1-StatusTests
0CoveredT1,T2,T3
1CoveredT1,T2,T3

 LINE       1248
 SUB-EXPRESSION (reg_re || reg_we)
                 ---1--    ---2--
-1--2-StatusTests
00CoveredT1,T2,T3
01CoveredT1,T2,T3
10CoveredT1,T2,T3

 LINE       1252
 EXPRESSION 
 Number  Term
      1  reg_we & 
      2  ((addr_hit[0] & ((|(4'b1 & (~reg_be))))) | (addr_hit[1] & ((|(4'b1 & (~reg_be))))) | (addr_hit[2] & ((|(4'b1 & (~reg_be))))) | (addr_hit[3] & ((|(4'b1 & (~reg_be))))) | (addr_hit[4] & ((|(4'b1 & (~reg_be))))) | (addr_hit[5] & ((|(4'b0011 & (~reg_be))))) | (addr_hit[6] & ((|(4'b1 & (~reg_be))))) | (addr_hit[7] & ((|(4'b1 & (~reg_be))))) | (addr_hit[8] & ((|(4'b1 & (~reg_be))))) | (addr_hit[9] & ((|(4'b1 & (~reg_be))))) | (addr_hit[10] & ((|(4'b1 & (~reg_be))))) | (addr_hit[11] & ((|(4'b1 & (~reg_be))))) | (addr_hit[12] & ((|(4'b1 & (~reg_be))))) | (addr_hit[13] & ((|(4'b1 & (~reg_be))))) | (addr_hit[14] & ((|(4'b1 & (~reg_be))))) | (addr_hit[15] & ((|(4'b1 & (~reg_be))))) | (addr_hit[16] & ((|(4'b1 & (~reg_be)))))))
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T3
11CoveredT50,T47,T48

 LINE       1252
 SUB-EXPRESSION 
 Number  Term
      1  (addr_hit[0] & ((|(4'b1 & (~reg_be))))) | 
      2  (addr_hit[1] & ((|(4'b1 & (~reg_be))))) | 
      3  (addr_hit[2] & ((|(4'b1 & (~reg_be))))) | 
      4  (addr_hit[3] & ((|(4'b1 & (~reg_be))))) | 
      5  (addr_hit[4] & ((|(4'b1 & (~reg_be))))) | 
      6  (addr_hit[5] & ((|(4'b0011 & (~reg_be))))) | 
      7  (addr_hit[6] & ((|(4'b1 & (~reg_be))))) | 
      8  (addr_hit[7] & ((|(4'b1 & (~reg_be))))) | 
      9  (addr_hit[8] & ((|(4'b1 & (~reg_be))))) | 
     10  (addr_hit[9] & ((|(4'b1 & (~reg_be))))) | 
     11  (addr_hit[10] & ((|(4'b1 & (~reg_be))))) | 
     12  (addr_hit[11] & ((|(4'b1 & (~reg_be))))) | 
     13  (addr_hit[12] & ((|(4'b1 & (~reg_be))))) | 
     14  (addr_hit[13] & ((|(4'b1 & (~reg_be))))) | 
     15  (addr_hit[14] & ((|(4'b1 & (~reg_be))))) | 
     16  (addr_hit[15] & ((|(4'b1 & (~reg_be))))) | 
     17  (addr_hit[16] & ((|(4'b1 & (~reg_be))))))
-1--2--3--4--5--6--7--8--9--10--11--12--13--14--15--16--17-StatusTests
00000000000000000CoveredT1,T2,T3
00000000000000001CoveredT6,T16,T27
00000000000000010CoveredT6,T30,T16
00000000000000100CoveredT5,T6,T23
00000000000001000CoveredT5,T6,T23
00000000000010000CoveredT1,T2,T5
00000000000100000CoveredT6,T23,T30
00000000001000000CoveredT23,T16,T27
00000000010000000CoveredT1,T3,T4
00000000100000000CoveredT6,T16,T27
00000001000000000CoveredT5,T23,T16
00000010000000000CoveredT1,T3,T4
00000100000000000CoveredT5,T6,T16
00001000000000000CoveredT6,T23,T16
00010000000000000CoveredT6,T23,T30
00100000000000000CoveredT6,T23,T27
01000000000000000CoveredT5,T6,T30
10000000000000000CoveredT2,T6,T9

 LINE       1252
 SUB-EXPRESSION (addr_hit[0] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T3
11CoveredT2,T6,T9

 LINE       1252
 SUB-EXPRESSION (addr_hit[1] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T3
11CoveredT5,T6,T30

 LINE       1252
 SUB-EXPRESSION (addr_hit[2] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT5,T6,T30
11CoveredT6,T23,T27

 LINE       1252
 SUB-EXPRESSION (addr_hit[3] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT5,T6,T23
11CoveredT6,T23,T30

 LINE       1252
 SUB-EXPRESSION (addr_hit[4] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT6,T23,T30
11CoveredT6,T23,T16

 LINE       1252
 SUB-EXPRESSION (addr_hit[5] & ((|(4'b0011 & (~reg_be)))))
                 -----1-----   -------------2------------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T3,T4
11CoveredT5,T6,T16

 LINE       1252
 SUB-EXPRESSION (addr_hit[6] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T3
11CoveredT1,T3,T4

 LINE       1252
 SUB-EXPRESSION (addr_hit[7] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT6,T30,T16
11CoveredT5,T23,T16

 LINE       1252
 SUB-EXPRESSION (addr_hit[8] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T3,T4
11CoveredT6,T16,T27

 LINE       1252
 SUB-EXPRESSION (addr_hit[9] & ((|(4'b1 & (~reg_be)))))
                 -----1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T3,T4
11CoveredT1,T3,T4

 LINE       1252
 SUB-EXPRESSION (addr_hit[10] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT6,T23,T16
11CoveredT23,T16,T27

 LINE       1252
 SUB-EXPRESSION (addr_hit[11] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T5
11CoveredT6,T23,T30

 LINE       1252
 SUB-EXPRESSION (addr_hit[12] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T5
11CoveredT1,T2,T5

 LINE       1252
 SUB-EXPRESSION (addr_hit[13] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT5,T6,T23
11CoveredT5,T6,T23

 LINE       1252
 SUB-EXPRESSION (addr_hit[14] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T3
11CoveredT5,T6,T23

 LINE       1252
 SUB-EXPRESSION (addr_hit[15] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT1,T2,T3
11CoveredT6,T30,T16

 LINE       1252
 SUB-EXPRESSION (addr_hit[16] & ((|(4'b1 & (~reg_be)))))
                 ------1-----   -----------2-----------
-1--2-StatusTests
01CoveredT1,T2,T3
10CoveredT6,T23,T20
11CoveredT6,T16,T27

 LINE       1273
 EXPRESSION (addr_hit[0] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T3
110CoveredT52,T66,T67
111CoveredT1,T2,T3

 LINE       1276
 EXPRESSION (addr_hit[1] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T3
110CoveredT48,T68,T52
111CoveredT1,T2,T3

 LINE       1279
 EXPRESSION (addr_hit[2] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT5,T6,T23
110CoveredT47,T54,T55
111CoveredT69,T70,T71

 LINE       1282
 EXPRESSION (addr_hit[3] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT5,T6,T23
110CoveredT48,T56,T66
111CoveredT57,T64,T65

 LINE       1285
 EXPRESSION (addr_hit[4] & reg_re & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT6,T23,T30
110CoveredT53,T72,T73
111CoveredT24,T25,T26

 LINE       1286
 EXPRESSION (addr_hit[5] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T3,T4
110CoveredT48,T52,T66
111CoveredT1,T3,T4

 LINE       1299
 EXPRESSION (addr_hit[6] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T3
110CoveredT52,T67,T74
111CoveredT1,T2,T3

 LINE       1302
 EXPRESSION (addr_hit[7] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT5,T6,T23
110CoveredT50,T49,T59
111CoveredT57,T64,T65

 LINE       1305
 EXPRESSION (addr_hit[8] & reg_we & ((!reg_error)))
             -----1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T3,T4
110CoveredT50,T49,T68
111CoveredT1,T3,T4

 LINE       1318
 EXPRESSION (addr_hit[10] & reg_we & ((!reg_error)))
             ------1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT6,T23,T16
110CoveredT49,T56,T55
111CoveredT57,T64,T65

 LINE       1321
 EXPRESSION (addr_hit[11] & reg_we & ((!reg_error)))
             ------1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T5
110CoveredT47,T67,T74
111CoveredT1,T2,T5

 LINE       1326
 EXPRESSION (addr_hit[14] & reg_we & ((!reg_error)))
             ------1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T3
110CoveredT52,T67,T74
111CoveredT1,T2,T3

 LINE       1329
 EXPRESSION (addr_hit[15] & reg_re & ((!reg_error)))
             ------1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T3
110CoveredT75
111CoveredT2,T3,T4

 LINE       1330
 EXPRESSION (addr_hit[15] & reg_we & ((!reg_error)))
             ------1-----   ---2--   -------3------
-1--2--3-StatusTests
011CoveredT1,T2,T3
101CoveredT1,T2,T3
110CoveredT47,T67,T74
111CoveredT1,T2,T3

Branch Coverage for Module : pwrmgr_reg_top
Line No.TotalCoveredPercent
Branches 23 23 100.00
TERNARY 1248 2 2 100.00
IF 70 3 3 100.00
CASE 1363 18 18 100.00


1248 assign addrmiss = (reg_re || reg_we) ? ~|addr_hit : 1'b0 ; -1- ==> ==>

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


70 if (!rst_lc_ni) begin -1- 71 err_q <= '0; ==> 72 end else if (intg_err || reg_we_err) begin -2- 73 err_q <= 1'b1; ==> 74 end MISSING_ELSE ==>

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


1363 unique case (1'b1) -1- 1364 addr_hit[0]: begin 1365 reg_rdata_next[0] = intr_state_qs; ==> 1366 end 1367 1368 addr_hit[1]: begin 1369 reg_rdata_next[0] = intr_enable_qs; ==> 1370 end 1371 1372 addr_hit[2]: begin 1373 reg_rdata_next[0] = '0; ==> 1374 end 1375 1376 addr_hit[3]: begin 1377 reg_rdata_next[0] = '0; ==> 1378 end 1379 1380 addr_hit[4]: begin 1381 reg_rdata_next[0] = ctrl_cfg_regwen_qs; ==> 1382 end 1383 1384 addr_hit[5]: begin 1385 reg_rdata_next[0] = control_low_power_hint_qs; ==> 1386 reg_rdata_next[4] = control_core_clk_en_qs; 1387 reg_rdata_next[5] = control_io_clk_en_qs; 1388 reg_rdata_next[6] = control_usb_clk_en_lp_qs; 1389 reg_rdata_next[7] = control_usb_clk_en_active_qs; 1390 reg_rdata_next[8] = control_main_pd_n_qs; 1391 end 1392 1393 addr_hit[6]: begin 1394 reg_rdata_next[0] = cfg_cdc_sync_qs; ==> 1395 end 1396 1397 addr_hit[7]: begin 1398 reg_rdata_next[0] = wakeup_en_regwen_qs; ==> 1399 end 1400 1401 addr_hit[8]: begin 1402 reg_rdata_next[0] = wakeup_en_en_0_qs; ==> 1403 reg_rdata_next[1] = wakeup_en_en_1_qs; 1404 reg_rdata_next[2] = wakeup_en_en_2_qs; 1405 reg_rdata_next[3] = wakeup_en_en_3_qs; 1406 reg_rdata_next[4] = wakeup_en_en_4_qs; 1407 reg_rdata_next[5] = wakeup_en_en_5_qs; 1408 end 1409 1410 addr_hit[9]: begin 1411 reg_rdata_next[0] = wake_status_val_0_qs; ==> 1412 reg_rdata_next[1] = wake_status_val_1_qs; 1413 reg_rdata_next[2] = wake_status_val_2_qs; 1414 reg_rdata_next[3] = wake_status_val_3_qs; 1415 reg_rdata_next[4] = wake_status_val_4_qs; 1416 reg_rdata_next[5] = wake_status_val_5_qs; 1417 end 1418 1419 addr_hit[10]: begin 1420 reg_rdata_next[0] = reset_en_regwen_qs; ==> 1421 end 1422 1423 addr_hit[11]: begin 1424 reg_rdata_next[0] = reset_en_en_0_qs; ==> 1425 reg_rdata_next[1] = reset_en_en_1_qs; 1426 end 1427 1428 addr_hit[12]: begin 1429 reg_rdata_next[0] = reset_status_val_0_qs; ==> 1430 reg_rdata_next[1] = reset_status_val_1_qs; 1431 end 1432 1433 addr_hit[13]: begin 1434 reg_rdata_next[0] = escalate_reset_status_qs; ==> 1435 end 1436 1437 addr_hit[14]: begin 1438 reg_rdata_next[0] = wake_info_capture_dis_qs; ==> 1439 end 1440 1441 addr_hit[15]: begin 1442 reg_rdata_next[5:0] = wake_info_reasons_qs; ==> 1443 reg_rdata_next[6] = wake_info_fall_through_qs; 1444 reg_rdata_next[7] = wake_info_abort_qs; 1445 end 1446 1447 addr_hit[16]: begin 1448 reg_rdata_next[0] = fault_status_reg_intg_err_qs; ==> 1449 reg_rdata_next[1] = fault_status_esc_timeout_qs; 1450 reg_rdata_next[2] = fault_status_main_pd_glitch_qs; 1451 end 1452 1453 default: begin 1454 reg_rdata_next = '1; ==>

Branches:
-1-StatusTests
addr_hit[0] Covered T1,T2,T3
addr_hit[1] Covered T1,T2,T3
addr_hit[2] Covered T1,T2,T3
addr_hit[3] Covered T1,T2,T3
addr_hit[4] Covered T1,T2,T3
addr_hit[5] Covered T1,T2,T3
addr_hit[6] Covered T1,T2,T3
addr_hit[7] Covered T1,T2,T3
addr_hit[8] Covered T1,T2,T3
addr_hit[9] Covered T1,T2,T3
addr_hit[10] Covered T1,T2,T3
addr_hit[11] Covered T1,T2,T3
addr_hit[12] Covered T1,T2,T3
addr_hit[13] Covered T1,T2,T3
addr_hit[14] Covered T1,T2,T3
addr_hit[15] Covered T1,T2,T3
addr_hit[16] Covered T1,T2,T3
default Covered T1,T2,T3


Assert Coverage for Module : pwrmgr_reg_top
TotalAttemptedPercentSucceeded/MatchedPercent
Assertions 4 4 100.00 4 100.00
Cover properties 0 0 0
Cover sequences 0 0 0
Total 4 4 100.00 4 100.00




Assertion Details

NameAttemptsReal SuccessesFailuresIncomplete
en2addrHit 17707464 510988 0 0
reAfterRv 17707464 510988 0 0
rePulse 17707464 271529 0 0
wePulse 17707464 239459 0 0


en2addrHit
NameAttemptsReal SuccessesFailuresIncomplete
Total 17707464 510988 0 0
T1 1469 52 0 0
T2 6613 169 0 0
T3 16153 232 0 0
T4 2143 111 0 0
T5 1326 23 0 0
T6 1552 163 0 0
T7 20478 856 0 0
T8 4160 244 0 0
T9 22338 858 0 0
T10 523 1 0 0

reAfterRv
NameAttemptsReal SuccessesFailuresIncomplete
Total 17707464 510988 0 0
T1 1469 52 0 0
T2 6613 169 0 0
T3 16153 232 0 0
T4 2143 111 0 0
T5 1326 23 0 0
T6 1552 163 0 0
T7 20478 856 0 0
T8 4160 244 0 0
T9 22338 858 0 0
T10 523 1 0 0

rePulse
NameAttemptsReal SuccessesFailuresIncomplete
Total 17707464 271529 0 0
T1 1469 42 0 0
T2 6613 103 0 0
T3 16153 102 0 0
T4 2143 63 0 0
T5 1326 12 0 0
T6 1552 99 0 0
T7 20478 404 0 0
T8 4160 182 0 0
T9 22338 406 0 0
T10 523 1 0 0

wePulse
NameAttemptsReal SuccessesFailuresIncomplete
Total 17707464 239459 0 0
T1 1469 10 0 0
T2 6613 66 0 0
T3 16153 130 0 0
T4 2143 48 0 0
T5 1326 11 0 0
T6 1552 64 0 0
T7 20478 452 0 0
T8 4160 62 0 0
T9 22338 452 0 0
T10 523 0 0 0
T38 0 10 0 0

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