Project Full coverage report
Current view: Cores-VeeR-EL2—Cores-VeeR-EL2—design—el2_veer.sv Coverage Hit Total
Test Date: 02-01-2025 Toggle 85.9% 476 554
Test: all Branch 100.0% 59 59

            Line data    Source code
       1              : // SPDX-License-Identifier: Apache-2.0
       2              : // Copyright 2020 Western Digital Corporation or its affiliates.
       3              : //
       4              : // Licensed under the Apache License, Version 2.0 (the "License");
       5              : // you may not use this file except in compliance with the License.
       6              : // You may obtain a copy of the License at
       7              : //
       8              : // http://www.apache.org/licenses/LICENSE-2.0
       9              : //
      10              : // Unless required by applicable law or agreed to in writing, software
      11              : // distributed under the License is distributed on an "AS IS" BASIS,
      12              : // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
      13              : // See the License for the specific language governing permissions and
      14              : // limitations under the License.
      15              : 
      16              : //********************************************************************************
      17              : // $Id$
      18              : //
      19              : // Function: Top level VeeR core file
      20              : // Comments:
      21              : //
      22              : //********************************************************************************
      23              : module el2_veer
      24              : import el2_pkg::*;
      25              : #(
      26              : `include "el2_param.vh"
      27              :  )
      28              :   (
      29     62074601 :    input logic                  clk,
      30          299 :    input logic                  rst_l,
      31          297 :    input logic                  dbg_rst_l,
      32              :    // rst_vec is supposed to be connected to a constant in the top level
      33              :    /*pragma coverage off*/
      34              :    input logic [31:1]           rst_vec,
      35              :    /*pragma coverage on*/
      36            4 :    input logic                  nmi_int,
      37              :    // nmi_vec is supposed to be connected to a constant in the top level
      38              :    /*pragma coverage off*/
      39              :    input logic [31:1]           nmi_vec,
      40              :    /*pragma coverage on*/
      41          299 :    output logic                 core_rst_l,   // This is "rst_l | dbg_rst_l"
      42              : 
      43     62074601 :    output logic                 active_l2clk,
      44     62074601 :    output logic                 free_l2clk,
      45              : 
      46      3084646 :    output logic [31:0] trace_rv_i_insn_ip,
      47      4567190 :    output logic [31:0] trace_rv_i_address_ip,
      48      5861200 :    output logic   trace_rv_i_valid_ip,
      49         3444 :    output logic   trace_rv_i_exception_ip,
      50         3368 :    output logic [4:0]  trace_rv_i_ecause_ip,
      51            8 :    output logic   trace_rv_i_interrupt_ip,
      52          697 :    output logic [31:0] trace_rv_i_tval_ip,
      53              : 
      54              : 
      55            2 :    output logic                 dccm_clk_override,
      56            2 :    output logic                 icm_clk_override,
      57            8 :    output logic                 dec_tlu_core_ecc_disable,
      58              : 
      59              :    // external halt/run interface
      60          114 :    input logic  i_cpu_halt_req,    // Asynchronous Halt request to CPU
      61          114 :    input logic  i_cpu_run_req,     // Asynchronous Restart request to CPU
      62          114 :    output logic o_cpu_halt_ack,    // Core Acknowledge to Halt request
      63          114 :    output logic o_cpu_halt_status, // 1'b1 indicates processor is halted
      64          114 :    output logic o_cpu_run_ack,     // Core Acknowledge to run request
      65          124 :    output logic o_debug_mode_status, // Core to the PMU that core is in debug mode. When core is in debug mode, the PMU should refrain from sendng a halt or run request
      66              : 
      67              :    /*pragma coverage off*/
      68              :    input logic [31:4] core_id, // CORE ID
      69              :    /*pragma coverage on*/
      70              : 
      71              :    // external MPC halt/run interface
      72          114 :    input logic mpc_debug_halt_req, // Async halt request
      73          114 :    input logic mpc_debug_run_req, // Async run request
      74          297 :    input logic mpc_reset_run_req, // Run/halt after reset
      75          114 :    output logic mpc_debug_halt_ack, // Halt ack
      76          114 :    output logic mpc_debug_run_ack, // Run ack
      77            2 :    output logic debug_brkpt_status, // debug breakpoint
      78              : 
      79       341326 :    output logic dec_tlu_perfcnt0, // toggles when slot0 perf counter 0 has an event inc
      80       514626 :    output logic dec_tlu_perfcnt1,
      81       312914 :    output logic dec_tlu_perfcnt2,
      82        48468 :    output logic dec_tlu_perfcnt3,
      83              : 
      84              :    // DCCM ports
      85       263176 :    output logic                          dccm_wren,
      86       561928 :    output logic                          dccm_rden,
      87       169412 :    output logic [pt.DCCM_BITS-1:0]          dccm_wr_addr_lo,
      88       169412 :    output logic [pt.DCCM_BITS-1:0]          dccm_wr_addr_hi,
      89      1692916 :    output logic [pt.DCCM_BITS-1:0]          dccm_rd_addr_lo,
      90      1835850 :    output logic [pt.DCCM_BITS-1:0]          dccm_rd_addr_hi,
      91       168802 :    output logic [pt.DCCM_FDATA_WIDTH-1:0]   dccm_wr_data_lo,
      92       168802 :    output logic [pt.DCCM_FDATA_WIDTH-1:0]   dccm_wr_data_hi,
      93              : 
      94       394224 :    input logic [pt.DCCM_FDATA_WIDTH-1:0]    dccm_rd_data_lo,
      95       394224 :    input logic [pt.DCCM_FDATA_WIDTH-1:0]    dccm_rd_data_hi,
      96              : 
      97              :    // ICCM ports
      98      4860102 :    output logic [pt.ICCM_BITS-1:1]           iccm_rw_addr,
      99          124 :    output logic                  iccm_wren,
     100       133220 :    output logic                  iccm_rden,
     101          108 :    output logic [2:0]            iccm_wr_size,
     102           62 :    output logic [77:0]           iccm_wr_data,
     103           16 :    output logic                  iccm_buf_correct_ecc,
     104           16 :    output logic                  iccm_correction_state,
     105              : 
     106       314413 :    input  logic [63:0]          iccm_rd_data,
     107       324968 :    input  logic [77:0]           iccm_rd_data_ecc,
     108              : 
     109              :    // ICache , ITAG  ports
     110      4859912 :    output logic [31:1]           ic_rw_addr,
     111       679406 :    output logic [pt.ICACHE_NUM_WAYS-1:0]            ic_tag_valid,
     112        15224 :    output logic [pt.ICACHE_NUM_WAYS-1:0]            ic_wr_en,
     113       684407 :    output logic                  ic_rd_en,
     114              : 
     115      1665404 :    output logic [pt.ICACHE_BANKS_WAY-1:0][70:0]               ic_wr_data,         // Data to fill to the Icache. With ECC
     116      6431731 :    input  logic [63:0]               ic_rd_data ,        // Data read from Icache. 2x64bits + parity bits. F2 stage. With ECC
     117       898526 :    input  logic [70:0]               ic_debug_rd_data ,        // Data read from Icache. 2x64bits + parity bits. F2 stage. With ECC
     118            0 :    input  logic [25:0]               ictag_debug_rd_data,// Debug icache tag.
     119            8 :    output logic [70:0]               ic_debug_wr_data,   // Debug wr cache.
     120              : 
     121            0 :    input  logic [pt.ICACHE_BANKS_WAY-1:0] ic_eccerr,
     122            0 :    input  logic [pt.ICACHE_BANKS_WAY-1:0] ic_parerr,
     123      5148803 :    output logic [63:0]               ic_premux_data,     // Premux data to be muxed with each way of the Icache.
     124      5305140 :    output logic                      ic_sel_premux_data, // Select premux data
     125              : 
     126              : 
     127           40 :    output logic [pt.ICACHE_INDEX_HI:3]               ic_debug_addr,      // Read/Write addresss to the Icache.
     128           16 :    output logic                      ic_debug_rd_en,     // Icache debug rd
     129           80 :    output logic                      ic_debug_wr_en,     // Icache debug wr
     130            6 :    output logic                      ic_debug_tag_array, // Debug tag array
     131          300 :    output logic [pt.ICACHE_NUM_WAYS-1:0]                ic_debug_way,       // Debug way. Rd or Wr.
     132              : 
     133              : 
     134              : 
     135       610724 :    input  logic [pt.ICACHE_NUM_WAYS-1:0]            ic_rd_hit,
     136            4 :    input  logic                  ic_tag_perr,        // Icache Tag parity error
     137              : 
     138              :    //-------------------------- LSU AXI signals--------------------------
     139              :    // AXI Write Channels
     140       785428 :    output logic                            lsu_axi_awvalid,
     141       589678 :    input  logic                            lsu_axi_awready,
     142       373697 :    output logic [pt.LSU_BUS_TAG-1:0]       lsu_axi_awid,
     143       382262 :    output logic [31:0]                     lsu_axi_awaddr,
     144        96335 :    output logic [3:0]                      lsu_axi_awregion,
     145              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     146              :    /*pragma coverage off*/
     147              :    output logic [7:0]                      lsu_axi_awlen,
     148              :    /*pragma coverage on*/
     149         7283 :    output logic [2:0]                      lsu_axi_awsize,
     150              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     151              :    /*pragma coverage off*/
     152              :    output logic [1:0]                      lsu_axi_awburst,
     153              :    output logic                            lsu_axi_awlock,
     154              :    /*pragma coverage on*/
     155         2999 :    output logic [3:0]                      lsu_axi_awcache,
     156              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     157              :    /*pragma coverage off*/
     158              :    output logic [2:0]                      lsu_axi_awprot,
     159              :    output logic [3:0]                      lsu_axi_awqos,
     160              :    /*pragma coverage on*/
     161              : 
     162       785428 :    output logic                            lsu_axi_wvalid,
     163       589678 :    input  logic                            lsu_axi_wready,
     164       191224 :    output logic [63:0]                     lsu_axi_wdata,
     165       331408 :    output logic [7:0]                      lsu_axi_wstrb,
     166          298 :    output logic                            lsu_axi_wlast,
     167              : 
     168       589464 :    input  logic                            lsu_axi_bvalid,
     169              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     170              :    /*pragma coverage off*/
     171              :    output logic                            lsu_axi_bready,
     172              :    /*pragma coverage on*/
     173            2 :    input  logic [1:0]                      lsu_axi_bresp,
     174       158268 :    input  logic [pt.LSU_BUS_TAG-1:0]       lsu_axi_bid,
     175              : 
     176              :    // AXI Read Channels
     177       792058 :    output logic                            lsu_axi_arvalid,
     178       598554 :    input  logic                            lsu_axi_arready,
     179       373697 :    output logic [pt.LSU_BUS_TAG-1:0]       lsu_axi_arid,
     180       382262 :    output logic [31:0]                     lsu_axi_araddr,
     181        96335 :    output logic [3:0]                      lsu_axi_arregion,
     182              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     183              :    /*pragma coverage off*/
     184              :    output logic [7:0]                      lsu_axi_arlen,
     185              :    /*pragma coverage on*/
     186         7283 :    output logic [2:0]                      lsu_axi_arsize,
     187              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     188              :    /*pragma coverage off*/
     189              :    output logic [1:0]                      lsu_axi_arburst,
     190              :    output logic                            lsu_axi_arlock,
     191              :    /*pragma coverage on*/
     192         2999 :    output logic [3:0]                      lsu_axi_arcache,
     193              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     194              :    /*pragma coverage off*/
     195              :    output logic [2:0]                      lsu_axi_arprot,
     196              :    output logic [3:0]                      lsu_axi_arqos,
     197              :    /*pragma coverage on*/
     198              : 
     199       598280 :    input  logic                            lsu_axi_rvalid,
     200              :    /* exclude signals that are tied to constant value in el2_lsu_bus_buffer.sv */
     201              :    /*pragma coverage off*/
     202              :    output logic                            lsu_axi_rready,
     203              :    /*pragma coverage on*/
     204        78283 :    input  logic [pt.LSU_BUS_TAG-1:0]       lsu_axi_rid,
     205        82759 :    input  logic [63:0]                     lsu_axi_rdata,
     206            2 :    input  logic [1:0]                      lsu_axi_rresp,
     207       599132 :    input  logic                            lsu_axi_rlast,
     208              : 
     209              :    //-------------------------- IFU AXI signals--------------------------
     210              :    // AXI Write Channels
     211              :    /* exclude signals that are tied to constant value in el2_ifu_mem_ctl.sv
     212              :       IFU does not use AXI write channel */
     213              :    /*pragma coverage off*/
     214              :    output logic                            ifu_axi_awvalid,
     215              :    input  logic                            ifu_axi_awready,
     216              :    output logic [pt.IFU_BUS_TAG-1:0]       ifu_axi_awid,
     217              :    output logic [31:0]                     ifu_axi_awaddr,
     218              :    output logic [3:0]                      ifu_axi_awregion,
     219              :    output logic [7:0]                      ifu_axi_awlen,
     220              :    output logic [2:0]                      ifu_axi_awsize,
     221              :    output logic [1:0]                      ifu_axi_awburst,
     222              :    output logic                            ifu_axi_awlock,
     223              :    output logic [3:0]                      ifu_axi_awcache,
     224              :    output logic [2:0]                      ifu_axi_awprot,
     225              :    output logic [3:0]                      ifu_axi_awqos,
     226              : 
     227              :    output logic                            ifu_axi_wvalid,
     228              :    input  logic                            ifu_axi_wready,
     229              :    output logic [63:0]                     ifu_axi_wdata,
     230              :    output logic [7:0]                      ifu_axi_wstrb,
     231              :    output logic                            ifu_axi_wlast,
     232              : 
     233              :    input  logic                            ifu_axi_bvalid,
     234              :    output logic                            ifu_axi_bready,
     235              :    input  logic [1:0]                      ifu_axi_bresp,
     236              :    input  logic [pt.IFU_BUS_TAG-1:0]       ifu_axi_bid,
     237              :    /*pragma coverage on*/
     238              : 
     239              :    // AXI Read Channels
     240      5568354 :    output logic                            ifu_axi_arvalid,
     241      8272171 :    input  logic                            ifu_axi_arready,
     242      5587659 :    output logic [pt.IFU_BUS_TAG-1:0]       ifu_axi_arid,
     243      5587659 :    output logic [31:0]                     ifu_axi_araddr,
     244          621 :    output logic [3:0]                      ifu_axi_arregion,
     245              :    /* exclude signals that are tied to constant value in el2_ifu_mem_ctl.sv */
     246              :    /*pragma coverage off*/
     247              :    output logic [7:0]                      ifu_axi_arlen,
     248              :    output logic [2:0]                      ifu_axi_arsize,
     249              :    output logic [1:0]                      ifu_axi_arburst,
     250              :    output logic                            ifu_axi_arlock,
     251              :    output logic [3:0]                      ifu_axi_arcache,
     252              :    output logic [2:0]                      ifu_axi_arprot,
     253              :    output logic [3:0]                      ifu_axi_arqos,
     254              :    /*pragma coverage on*/
     255              : 
     256      8271895 :    input  logic                            ifu_axi_rvalid,
     257              :    /* exclude signals that are tied to constant value in el2_ifu_mem_ctl.sv */
     258              :    /*pragma coverage off*/
     259              :    output logic                            ifu_axi_rready,
     260              :    /*pragma coverage on*/
     261      3094450 :    input  logic [pt.IFU_BUS_TAG-1:0]       ifu_axi_rid,
     262      1745262 :    input  logic [63:0]                     ifu_axi_rdata,
     263           20 :    input  logic [1:0]                      ifu_axi_rresp,
     264      8271895 :    input  logic                            ifu_axi_rlast,
     265              : 
     266              :    //-------------------------- SB AXI signals--------------------------
     267              :    // AXI Write Channels
     268          248 :    output logic                            sb_axi_awvalid,
     269          124 :    input  logic                            sb_axi_awready,
     270              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     271              :    /*pragma coverage off*/
     272              :    output logic [pt.SB_BUS_TAG-1:0]        sb_axi_awid,
     273              :    /*pragma coverage on*/
     274          756 :    output logic [31:0]                     sb_axi_awaddr,
     275          202 :    output logic [3:0]                      sb_axi_awregion,
     276              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     277              :    /*pragma coverage off*/
     278              :    output logic [7:0]                      sb_axi_awlen,
     279              :    /*pragma coverage on*/
     280         1696 :    output logic [2:0]                      sb_axi_awsize,
     281              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     282              :    /*pragma coverage off*/
     283              :    output logic [1:0]                      sb_axi_awburst,
     284              :    output logic                            sb_axi_awlock,
     285              :    output logic [3:0]                      sb_axi_awcache,
     286              :    output logic [2:0]                      sb_axi_awprot,
     287              :    output logic [3:0]                      sb_axi_awqos,
     288              :    /*pragma coverage on*/
     289              : 
     290          248 :    output logic                            sb_axi_wvalid,
     291          124 :    input  logic                            sb_axi_wready,
     292          182 :    output logic [63:0]                     sb_axi_wdata,
     293         1524 :    output logic [7:0]                      sb_axi_wstrb,
     294          298 :    output logic                            sb_axi_wlast,
     295              : 
     296          124 :    input  logic                            sb_axi_bvalid,
     297          298 :    output logic                            sb_axi_bready,
     298            0 :    input  logic [1:0]                      sb_axi_bresp,
     299            0 :    input  logic [pt.SB_BUS_TAG-1:0]        sb_axi_bid,
     300              : 
     301              :    // AXI Read Channels
     302         1704 :    output logic                            sb_axi_arvalid,
     303          852 :    input  logic                            sb_axi_arready,
     304              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     305              :    /*pragma coverage off*/
     306              :    output logic [pt.SB_BUS_TAG-1:0]        sb_axi_arid,
     307              :    /*pragma coverage on*/
     308          756 :    output logic [31:0]                     sb_axi_araddr,
     309          202 :    output logic [3:0]                      sb_axi_arregion,
     310              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     311              :    /*pragma coverage off*/
     312              :    output logic [7:0]                      sb_axi_arlen,
     313              :    /*pragma coverage on*/
     314         1696 :    output logic [2:0]                      sb_axi_arsize,
     315              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     316              :    /*pragma coverage off*/
     317              :    output logic [1:0]                      sb_axi_arburst,
     318              :    output logic                            sb_axi_arlock,
     319              :    output logic [3:0]                      sb_axi_arcache,
     320              :    output logic [2:0]                      sb_axi_arprot,
     321              :    output logic [3:0]                      sb_axi_arqos,
     322              :    /*pragma coverage on*/
     323              : 
     324          852 :    input  logic                            sb_axi_rvalid,
     325              :    /* exclude signals that are tied to constant value in dbg/el2_dbg.sv */
     326              :    /*pragma coverage off*/
     327              :    output logic                            sb_axi_rready,
     328              :    /*pragma coverage on*/
     329            0 :    input  logic [pt.SB_BUS_TAG-1:0]        sb_axi_rid,
     330          146 :    input  logic [63:0]                     sb_axi_rdata,
     331            0 :    input  logic [1:0]                      sb_axi_rresp,
     332          852 :    input  logic                            sb_axi_rlast,
     333              : 
     334              :    //-------------------------- DMA AXI signals--------------------------
     335              :    // AXI Write Channels
     336           68 :    input  logic                         dma_axi_awvalid,
     337          298 :    output logic                         dma_axi_awready,
     338            0 :    input  logic [pt.DMA_BUS_TAG-1:0]    dma_axi_awid,
     339       276908 :    input  logic [31:0]                  dma_axi_awaddr,
     340         4137 :    input  logic [2:0]                   dma_axi_awsize,
     341          276 :    input  logic [2:0]                   dma_axi_awprot,
     342            0 :    input  logic [7:0]                   dma_axi_awlen,
     343          276 :    input  logic [1:0]                   dma_axi_awburst,
     344              : 
     345              : 
     346           68 :    input  logic                         dma_axi_wvalid,
     347          298 :    output logic                         dma_axi_wready,
     348       120087 :    input  logic [63:0]                  dma_axi_wdata,
     349       229722 :    input  logic [7:0]                   dma_axi_wstrb,
     350          276 :    input  logic                         dma_axi_wlast,
     351              : 
     352          108 :    output logic                         dma_axi_bvalid,
     353           68 :    input  logic                         dma_axi_bready,
     354            0 :    output logic [1:0]                   dma_axi_bresp,
     355            0 :    output logic [pt.DMA_BUS_TAG-1:0]    dma_axi_bid,
     356              : 
     357              :    // AXI Read Channels
     358            0 :    input  logic                         dma_axi_arvalid,
     359          298 :    output logic                         dma_axi_arready,
     360            0 :    input  logic [pt.DMA_BUS_TAG-1:0]    dma_axi_arid,
     361       276908 :    input  logic [31:0]                  dma_axi_araddr,
     362         4137 :    input  logic [2:0]                   dma_axi_arsize,
     363          276 :    input  logic [2:0]                   dma_axi_arprot,
     364            0 :    input  logic [7:0]                   dma_axi_arlen,
     365          276 :    input  logic [1:0]                   dma_axi_arburst,
     366              : 
     367            0 :    output logic                         dma_axi_rvalid,
     368            0 :    input  logic                         dma_axi_rready,
     369            0 :    output logic [pt.DMA_BUS_TAG-1:0]    dma_axi_rid,
     370           48 :    output logic [63:0]                  dma_axi_rdata,
     371            0 :    output logic [1:0]                   dma_axi_rresp,
     372          298 :    output logic                         dma_axi_rlast,
     373              : 
     374              : 
     375              :  //// AHB LITE BUS
     376      1084802 :    output logic [31:0]           haddr,
     377              :    /* exclude signals that are tied to constant value in axi4_to_ahb.sv */
     378              :    /*pragma coverage off*/
     379              :    output logic [2:0]            hburst,
     380              :    output logic                  hmastlock,
     381              :    /*pragma coverage on*/
     382           21 :    output logic [3:0]            hprot,
     383           21 :    output logic [2:0]            hsize,
     384      1442201 :    output logic [1:0]            htrans,
     385            0 :    output logic                  hwrite,
     386              : 
     387       708366 :    input  logic [63:0]           hrdata,
     388           21 :    input  logic                  hready,
     389            0 :    input  logic                  hresp,
     390              : 
     391              :    // LSU AHB Master
     392       105502 :    output logic [31:0]          lsu_haddr,
     393              :    /* exclude signals that are tied to constant value in axi4_to_ahb.sv */
     394              :    /*pragma coverage off*/
     395              :    output logic [2:0]           lsu_hburst,
     396              :    output logic                 lsu_hmastlock,
     397              :    /*pragma coverage on*/
     398           21 :    output logic [3:0]           lsu_hprot,
     399        88149 :    output logic [2:0]           lsu_hsize,
     400       437806 :    output logic [1:0]           lsu_htrans,
     401        88201 :    output logic                 lsu_hwrite,
     402       108899 :    output logic [63:0]          lsu_hwdata,
     403              : 
     404        48648 :    input  logic [63:0]          lsu_hrdata,
     405       252187 :    input  logic                 lsu_hready,
     406            0 :    input  logic                 lsu_hresp,
     407              : 
     408              :    //System Bus Debug Master
     409          368 :    output logic [31:0]          sb_haddr,
     410              :    /* exclude signals that are tied to constant value in axi4_to_ahb.sv */
     411              :    /*pragma coverage off*/
     412              :    output logic [2:0]           sb_hburst,
     413              :    output logic                 sb_hmastlock,
     414              :    /*pragma coverage on*/
     415           21 :    output logic [3:0]           sb_hprot,
     416          118 :    output logic [2:0]           sb_hsize,
     417          976 :    output logic [1:0]           sb_htrans,
     418          120 :    output logic                 sb_hwrite,
     419          154 :    output logic [63:0]          sb_hwdata,
     420              : 
     421          950 :    input  logic [63:0]          sb_hrdata,
     422          854 :    input  logic                 sb_hready,
     423            0 :    input  logic                 sb_hresp,
     424              : 
     425              :    // DMA Slave
     426           21 :    input logic                   dma_hsel,
     427           16 :    input logic [31:0]            dma_haddr,
     428            0 :    input logic [2:0]             dma_hburst,
     429            0 :    input logic                   dma_hmastlock,
     430           21 :    input logic [3:0]             dma_hprot,
     431            1 :    input logic [2:0]             dma_hsize,
     432           40 :    input logic [1:0]             dma_htrans,
     433            1 :    input logic                   dma_hwrite,
     434           16 :    input logic [63:0]            dma_hwdata,
     435           21 :    input logic                   dma_hreadyin,
     436              : 
     437            0 :    output  logic [63:0]          dma_hrdata,
     438           21 :    output  logic                 dma_hreadyout,
     439            0 :    output  logic                 dma_hresp,
     440              : 
     441          327 :    input   logic                 lsu_bus_clk_en,
     442          297 :    input   logic                 ifu_bus_clk_en,
     443          297 :    input   logic                 dbg_bus_clk_en,
     444          297 :    input   logic                 dma_bus_clk_en,
     445              : 
     446        19020 :    input logic                  dmi_reg_en,                // read or write
     447         5206 :    input logic [6:0]            dmi_reg_addr,              // address of DM register
     448         7408 :    input logic                  dmi_reg_wr_en,             // write instruction
     449         3820 :    input logic [31:0]           dmi_reg_wdata,             // write data
     450         6380 :    output logic [31:0]          dmi_reg_rdata,
     451              : 
     452              :    // ICCM/DCCM ECC status
     453           16 :    output logic                 iccm_ecc_single_error,
     454            8 :    output logic                 iccm_ecc_double_error,
     455            4 :    output logic                 dccm_ecc_single_error,
     456            4 :    output logic                 dccm_ecc_double_error,
     457              : 
     458           20 :    input logic [pt.PIC_TOTAL_INT:1]           extintsrc_req,
     459            3 :    input logic                   timer_int,
     460            5 :    input logic                   soft_int,
     461              :    // Excluding scan_mode from coverage as its usage is determined by the integrator of the VeeR core.
     462              :    /*pragma coverage off*/
     463              :    input logic                   scan_mode
     464              :    /*pragma coverage on*/
     465              : );
     466              : 
     467              : 
     468              : 
     469              : 
     470      1041644 :    logic [63:0]                  hwdata_nc;
     471              :    //----------------------------------------------------------------------
     472              :    //
     473              :    //----------------------------------------------------------------------
     474              : 
     475      5886902 :    logic                         ifu_pmu_instr_aligned;
     476            4 :    logic                         ifu_ic_error_start;
     477            0 :    logic                         ifu_iccm_dma_rd_ecc_single_err;
     478           16 :    logic                         ifu_iccm_rd_ecc_single_err;
     479            8 :    logic                         ifu_iccm_rd_ecc_double_err;
     480            4 :    logic                         lsu_dccm_rd_ecc_single_err;
     481            4 :    logic                         lsu_dccm_rd_ecc_double_err;
     482              : 
     483       460457 :    logic                         lsu_axi_awready_ahb;
     484       460457 :    logic                         lsu_axi_wready_ahb;
     485       207350 :    logic                         lsu_axi_bvalid_ahb;
     486            0 :    logic                         lsu_axi_bready_ahb;
     487            0 :    logic [1:0]                   lsu_axi_bresp_ahb;
     488        85448 :    logic [pt.LSU_BUS_TAG-1:0]    lsu_axi_bid_ahb;
     489       455823 :    logic                         lsu_axi_arready_ahb;
     490       252166 :    logic                         lsu_axi_rvalid_ahb;
     491        85448 :    logic [pt.LSU_BUS_TAG-1:0]    lsu_axi_rid_ahb;
     492        48648 :    logic [63:0]                  lsu_axi_rdata_ahb;
     493            0 :    logic [1:0]                   lsu_axi_rresp_ahb;
     494           21 :    logic                         lsu_axi_rlast_ahb;
     495              : 
     496      1050135 :    logic                         lsu_axi_awready_int;
     497      1050135 :    logic                         lsu_axi_wready_int;
     498       796814 :    logic                         lsu_axi_bvalid_int;
     499          277 :    logic                         lsu_axi_bready_int;
     500            2 :    logic [1:0]                   lsu_axi_bresp_int;
     501       243716 :    logic [pt.LSU_BUS_TAG-1:0]    lsu_axi_bid_int;
     502      1054377 :    logic                         lsu_axi_arready_int;
     503       850446 :    logic                         lsu_axi_rvalid_int;
     504       163731 :    logic [pt.LSU_BUS_TAG-1:0]    lsu_axi_rid_int;
     505       131407 :    logic [63:0]                  lsu_axi_rdata_int;
     506            2 :    logic [1:0]                   lsu_axi_rresp_int;
     507       599153 :    logic                         lsu_axi_rlast_int;
     508              : 
     509      1442215 :    logic                         ifu_axi_awready_ahb;
     510      1442215 :    logic                         ifu_axi_wready_ahb;
     511            0 :    logic                         ifu_axi_bvalid_ahb;
     512            0 :    logic                         ifu_axi_bready_ahb;
     513            0 :    logic [1:0]                   ifu_axi_bresp_ahb;
     514      1084799 :    logic [pt.IFU_BUS_TAG-1:0]    ifu_axi_bid_ahb;
     515      1442215 :    logic                         ifu_axi_arready_ahb;
     516      2884392 :    logic                         ifu_axi_rvalid_ahb;
     517      1084799 :    logic [pt.IFU_BUS_TAG-1:0]    ifu_axi_rid_ahb;
     518       708365 :    logic [63:0]                  ifu_axi_rdata_ahb;
     519            0 :    logic [1:0]                   ifu_axi_rresp_ahb;
     520           21 :    logic                         ifu_axi_rlast_ahb;
     521              : 
     522      1442215 :    logic                         ifu_axi_awready_int;
     523      1442215 :    logic                         ifu_axi_wready_int;
     524            0 :    logic                         ifu_axi_bvalid_int;
     525            0 :    logic                         ifu_axi_bready_int;
     526            0 :    logic [1:0]                   ifu_axi_bresp_int;
     527      1084799 :    logic [pt.IFU_BUS_TAG-1:0]    ifu_axi_bid_int;
     528      9714386 :    logic                         ifu_axi_arready_int;
     529     11156287 :    logic                         ifu_axi_rvalid_int;
     530      4179249 :    logic [pt.IFU_BUS_TAG-1:0]    ifu_axi_rid_int;
     531      2453627 :    logic [63:0]                  ifu_axi_rdata_int;
     532           20 :    logic [1:0]                   ifu_axi_rresp_int;
     533      8271916 :    logic                         ifu_axi_rlast_int;
     534              : 
     535          997 :    logic                         sb_axi_awready_ahb;
     536          997 :    logic                         sb_axi_wready_ahb;
     537          124 :    logic                         sb_axi_bvalid_ahb;
     538            0 :    logic                         sb_axi_bready_ahb;
     539            0 :    logic [1:0]                   sb_axi_bresp_ahb;
     540            0 :    logic [pt.SB_BUS_TAG-1:0]     sb_axi_bid_ahb;
     541          997 :    logic                         sb_axi_arready_ahb;
     542          852 :    logic                         sb_axi_rvalid_ahb;
     543            0 :    logic [pt.SB_BUS_TAG-1:0]     sb_axi_rid_ahb;
     544          950 :    logic [63:0]                  sb_axi_rdata_ahb;
     545            0 :    logic [1:0]                   sb_axi_rresp_ahb;
     546           21 :    logic                         sb_axi_rlast_ahb;
     547              : 
     548         1121 :    logic                         sb_axi_awready_int;
     549         1121 :    logic                         sb_axi_wready_int;
     550          248 :    logic                         sb_axi_bvalid_int;
     551          277 :    logic                         sb_axi_bready_int;
     552            0 :    logic [1:0]                   sb_axi_bresp_int;
     553            0 :    logic [pt.SB_BUS_TAG-1:0]     sb_axi_bid_int;
     554         1849 :    logic                         sb_axi_arready_int;
     555         1704 :    logic                         sb_axi_rvalid_int;
     556            0 :    logic [pt.SB_BUS_TAG-1:0]     sb_axi_rid_int;
     557         1096 :    logic [63:0]                  sb_axi_rdata_int;
     558            0 :    logic [1:0]                   sb_axi_rresp_int;
     559          873 :    logic                         sb_axi_rlast_int;
     560              : 
     561           40 :    logic                         dma_axi_awvalid_ahb;
     562              :    /* exclude signals that are tied to constant value in ahb_to_axi4.sv */
     563              :    /*pragma coverage off*/
     564              :    logic [pt.DMA_BUS_TAG-1:0]    dma_axi_awid_ahb;
     565              :    /*pragma coverage on*/
     566           16 :    logic [31:0]                  dma_axi_awaddr_ahb;
     567            1 :    logic [2:0]                   dma_axi_awsize_ahb;
     568              :    /* exclude signals that are tied to constant value in ahb_to_axi4.sv */
     569              :    /*pragma coverage off*/
     570              :    logic [2:0]                   dma_axi_awprot_ahb;
     571              :    logic [7:0]                   dma_axi_awlen_ahb;
     572              :    logic [1:0]                   dma_axi_awburst_ahb;
     573              :    /*pragma coverage on*/
     574           40 :    logic                         dma_axi_wvalid_ahb;
     575           16 :    logic [63:0]                  dma_axi_wdata_ahb;
     576           17 :    logic [7:0]                   dma_axi_wstrb_ahb;
     577              :    /* exclude signals that are tied to constant value in ahb_to_axi4.sv */
     578              :    /*pragma coverage off*/
     579              :    logic                         dma_axi_wlast_ahb;
     580              :    logic                         dma_axi_bready_ahb;
     581              :    /*pragma coverage on*/
     582            0 :    logic                         dma_axi_arvalid_ahb;
     583              :    /* exclude signals that are tied to constant value in ahb_to_axi4.sv */
     584              :    /*pragma coverage off*/
     585              :    logic [pt.DMA_BUS_TAG-1:0]    dma_axi_arid_ahb;
     586              :    /*pragma coverage on*/
     587           16 :    logic [31:0]                  dma_axi_araddr_ahb;
     588            1 :    logic [2:0]                   dma_axi_arsize_ahb;
     589              :    /* exclude signals that are tied to constant value in ahb_to_axi4.sv */
     590              :    /*pragma coverage off*/
     591              :    logic [2:0]                   dma_axi_arprot_ahb;
     592              :    logic [7:0]                   dma_axi_arlen_ahb;
     593              :    logic [1:0]                   dma_axi_arburst_ahb;
     594              :    logic                         dma_axi_rready_ahb;
     595              :    /*pragma coverage on*/
     596              : 
     597          108 :    logic                         dma_axi_awvalid_int;
     598            0 :    logic [pt.DMA_BUS_TAG-1:0]    dma_axi_awid_int;
     599       276924 :    logic [31:0]                  dma_axi_awaddr_int;
     600         4138 :    logic [2:0]                   dma_axi_awsize_int;
     601          276 :    logic [2:0]                   dma_axi_awprot_int;
     602            0 :    logic [7:0]                   dma_axi_awlen_int;
     603          297 :    logic [1:0]                   dma_axi_awburst_int;
     604          108 :    logic                         dma_axi_wvalid_int;
     605       120103 :    logic [63:0]                  dma_axi_wdata_int;
     606       229739 :    logic [7:0]                   dma_axi_wstrb_int;
     607          297 :    logic                         dma_axi_wlast_int;
     608           89 :    logic                         dma_axi_bready_int;
     609            0 :    logic                         dma_axi_arvalid_int;
     610            0 :    logic [pt.DMA_BUS_TAG-1:0]    dma_axi_arid_int;
     611       276924 :    logic [31:0]                  dma_axi_araddr_int;
     612         4138 :    logic [2:0]                   dma_axi_arsize_int;
     613          276 :    logic [2:0]                   dma_axi_arprot_int;
     614            0 :    logic [7:0]                   dma_axi_arlen_int;
     615          297 :    logic [1:0]                   dma_axi_arburst_int;
     616           21 :    logic                         dma_axi_rready_int;
     617              : 
     618              : 
     619              : // Icache debug
     620            2 :    logic [70:0] ifu_ic_debug_rd_data; // diagnostic icache read data
     621           16 :    logic ifu_ic_debug_rd_data_valid; // diagnostic icache read data valid
     622           80 :    el2_cache_debug_pkt_t dec_tlu_ic_diag_pkt; // packet of DICAWICS, DICAD0/1, DICAGO info for icache diagnostics
     623              : 
     624              : 
     625      4845979 :    logic         dec_i0_rs1_en_d;
     626      3420250 :    logic         dec_i0_rs2_en_d;
     627      3472151 :    logic  [31:0] gpr_i0_rs1_d;
     628      2722450 :    logic  [31:0] gpr_i0_rs2_d;
     629              : 
     630      1675744 :    logic [31:0] dec_i0_result_r;
     631      1935409 :    logic [31:0] exu_i0_result_x;
     632      4567257 :    logic [31:1] exu_i0_pc_x;
     633      4652556 :    logic [31:1] exu_npc_r;
     634              : 
     635      2836960 :    el2_alu_pkt_t  i0_ap;
     636              : 
     637              :    // Trigger signals
     638            5 :    el2_trigger_pkt_t [3:0]     trigger_pkt_any;
     639            2 :    logic [3:0]             lsu_trigger_match_m;
     640              : 
     641              : 
     642      1600211 :    logic [31:0] dec_i0_immed_d;
     643      4241879 :    logic [12:1] dec_i0_br_immed_d;
     644       519496 :    logic         dec_i0_select_pc_d;
     645              : 
     646      5248363 :    logic [31:1] dec_i0_pc_d;
     647       607204 :    logic [3:0]  dec_i0_rs1_bypass_en_d;
     648       279108 :    logic [3:0]  dec_i0_rs2_bypass_en_d;
     649              : 
     650      5247453 :    logic         dec_i0_alu_decode_d;
     651      2387600 :    logic         dec_i0_branch_d;
     652              : 
     653      5567533 :    logic         ifu_miss_state_idle;
     654          242 :    logic         dec_tlu_flush_noredir_r;
     655            0 :    logic         dec_tlu_flush_leak_one_r;
     656           20 :    logic         dec_tlu_flush_err_r;
     657      5680567 :    logic         ifu_i0_valid;
     658      7049369 :    logic [31:0]  ifu_i0_instr;
     659      5248363 :    logic [31:1]  ifu_i0_pc;
     660              : 
     661       611287 :    logic        exu_flush_final;
     662              : 
     663       610821 :    logic [31:1] exu_flush_path_final;
     664              : 
     665      2123010 :    logic [31:0] exu_lsu_rs1_d;
     666       516041 :    logic [31:0] exu_lsu_rs2_d;
     667              : 
     668              : 
     669      5901003 :    el2_lsu_pkt_t    lsu_p;
     670      5308621 :    logic             dec_qual_lsu_d;
     671              : 
     672      2134142 :    logic        dec_lsu_valid_raw_d;
     673       881453 :    logic [11:0] dec_lsu_offset_d;
     674              : 
     675       451636 :    logic [31:0]  lsu_result_m;
     676       444974 :    logic [31:0]  lsu_result_corr_r;     // This is the ECC corrected data going to RF
     677            4 :    logic         lsu_single_ecc_error_incr;     // Increment the ecc counter
     678           85 :    el2_lsu_error_pkt_t lsu_error_pkt_r;
     679            2 :    logic         lsu_imprecise_error_load_any;
     680            2 :    logic         lsu_imprecise_error_store_any;
     681       417871 :    logic [31:0]  lsu_imprecise_error_addr_any;
     682        58443 :    logic         lsu_load_stall_any;       // This is for blocking loads
     683        68809 :    logic         lsu_store_stall_any;      // This is for blocking stores
     684      1268863 :    logic         lsu_idle_any;             // doesn't include DMA
     685      1268565 :    logic         lsu_active;               // lsu is active. used for clock
     686              : 
     687              : 
     688       188420 :    logic [31:1]  lsu_fir_addr;        // fast interrupt address
     689            0 :    logic [1:0]   lsu_fir_error;       // Error during fast interrupt lookup
     690              : 
     691              :    // Non-blocking loads
     692       812334 :    logic                                 lsu_nonblock_load_valid_m;
     693      1259013 :    logic [pt.LSU_NUM_NBLOAD_WIDTH-1:0]   lsu_nonblock_load_tag_m;
     694            0 :    logic                                 lsu_nonblock_load_inv_r;
     695      1259001 :    logic [pt.LSU_NUM_NBLOAD_WIDTH-1:0]   lsu_nonblock_load_inv_tag_r;
     696       843806 :    logic                                 lsu_nonblock_load_data_valid;
     697       172540 :    logic [pt.LSU_NUM_NBLOAD_WIDTH-1:0]   lsu_nonblock_load_data_tag;
     698       376406 :    logic [31:0]                          lsu_nonblock_load_data;
     699              : 
     700        96214 :    logic        dec_csr_ren_d;
     701     15300275 :    logic [31:0] dec_csr_rddata_d;
     702              : 
     703        12560 :    logic [31:0] exu_csr_rs1_x;
     704              : 
     705      5860515 :    logic        dec_tlu_i0_commit_cmt;
     706        49554 :    logic        dec_tlu_flush_lower_r;
     707        49554 :    logic        dec_tlu_flush_lower_wb;
     708        25008 :    logic        dec_tlu_i0_kill_writeb_r;     // I0 is flushed, don't writeback any results to arch state
     709        17362 :    logic        dec_tlu_fence_i_r;            // flush is a fence_i rfnpc, flush icache
     710              : 
     711        49276 :    logic [31:1] dec_tlu_flush_path_r;
     712           39 :    logic [31:0] dec_tlu_mrac_ff;        // CSR for memory region control
     713              : 
     714      4244954 :    logic        ifu_i0_pc4;
     715              : 
     716       241502 :    el2_mul_pkt_t  mul_p;
     717              : 
     718       870234 :    el2_div_pkt_t  div_p;
     719         2466 :    logic           dec_div_cancel;
     720              : 
     721        44358 :    logic [31:0] exu_div_result;
     722       147796 :    logic exu_div_wren;
     723              : 
     724      5886902 :    logic dec_i0_decode_d;
     725              : 
     726              : 
     727      3365786 :    logic [31:1] pred_correct_npc_x;
     728              : 
     729      2753369 :    el2_br_tlu_pkt_t dec_tlu_br0_r_pkt;
     730              : 
     731       541688 :    el2_predict_pkt_t  exu_mp_pkt;
     732       416326 :    logic [pt.BHT_GHR_SIZE-1:0]  exu_mp_eghr;
     733       368565 :    logic [pt.BHT_GHR_SIZE-1:0]  exu_mp_fghr;
     734       356954 :    logic [pt.BTB_ADDR_HI:pt.BTB_ADDR_LO] exu_mp_index;
     735       392326 :    logic [pt.BTB_BTAG_SIZE-1:0]          exu_mp_btag;
     736              : 
     737       375307 :    logic [pt.BHT_GHR_SIZE-1:0]  exu_i0_br_fghr_r;
     738      1432088 :    logic [1:0]  exu_i0_br_hist_r;
     739        22632 :    logic        exu_i0_br_error_r;
     740         6862 :    logic        exu_i0_br_start_error_r;
     741      1575440 :    logic        exu_i0_br_valid_r;
     742       388588 :    logic        exu_i0_br_mp_r;
     743      2316549 :    logic        exu_i0_br_middle_r;
     744              : 
     745      2061562 :    logic        exu_i0_br_way_r;
     746              : 
     747       677846 :    logic [pt.BTB_ADDR_HI:pt.BTB_ADDR_LO] exu_i0_br_index_r;
     748              : 
     749            0 :    logic        dma_dccm_req;
     750          108 :    logic        dma_iccm_req;
     751           45 :    logic [2:0]  dma_mem_tag;
     752           48 :    logic [31:0] dma_mem_addr;
     753           29 :    logic [2:0]  dma_mem_sz;
     754           29 :    logic        dma_mem_write;
     755           48 :    logic [63:0] dma_mem_wdata;
     756              : 
     757            0 :    logic        dccm_dma_rvalid;
     758            4 :    logic        dccm_dma_ecc_error;
     759           45 :    logic [2:0]  dccm_dma_rtag;
     760       452470 :    logic [63:0] dccm_dma_rdata;
     761            0 :    logic        iccm_dma_rvalid;
     762            8 :    logic        iccm_dma_ecc_error;
     763           45 :    logic [2:0]  iccm_dma_rtag;
     764            0 :    logic [63:0] iccm_dma_rdata;
     765              : 
     766            0 :    logic        dma_dccm_stall_any;       // Stall the ld/st in decode if asserted
     767           28 :    logic        dma_iccm_stall_any;       // Stall the fetch
     768      2083268 :    logic        dccm_ready;
     769       575468 :    logic        iccm_ready;
     770              : 
     771            0 :    logic        dma_pmu_dccm_read;
     772            0 :    logic        dma_pmu_dccm_write;
     773            0 :    logic        dma_pmu_any_read;
     774          108 :    logic        dma_pmu_any_write;
     775              : 
     776          124 :    logic        ifu_i0_icaf;
     777          180 :    logic [1:0]  ifu_i0_icaf_type;
     778              : 
     779              : 
     780           42 :    logic        ifu_i0_icaf_second;
     781            4 :    logic        ifu_i0_dbecc;
     782            0 :    logic        iccm_dma_sb_error;
     783              : 
     784      4932409 :    el2_br_pkt_t i0_brp;
     785      5697496 :    logic [pt.BTB_ADDR_HI:pt.BTB_ADDR_LO] ifu_i0_bp_index;
     786       750554 :    logic [pt.BHT_GHR_SIZE-1:0] ifu_i0_bp_fghr;
     787       548504 :    logic [pt.BTB_BTAG_SIZE-1:0] ifu_i0_bp_btag;
     788              : 
     789            0 :    logic [$clog2(pt.BTB_SIZE)-1:0] ifu_i0_fa_index;
     790            0 :    logic [$clog2(pt.BTB_SIZE)-1:0] dec_fa_error_index; // Fully associative btb error index
     791              : 
     792              : 
     793      5238476 :    el2_predict_pkt_t dec_i0_predict_p_d;
     794              : 
     795       750554 :    logic [pt.BHT_GHR_SIZE-1:0] i0_predict_fghr_d;                // DEC predict fghr
     796      5697496 :    logic [pt.BTB_ADDR_HI:pt.BTB_ADDR_LO] i0_predict_index_d;     // DEC predict index
     797       548504 :    logic [pt.BTB_BTAG_SIZE-1:0] i0_predict_btag_d;               // DEC predict branch tag
     798              : 
     799              :    // PIC ports
     800            8 :    logic                  picm_wren;
     801            2 :    logic                  picm_rden;
     802           10 :    logic                  picm_mken;
     803      1691289 :    logic [31:0]           picm_rdaddr;
     804      1691256 :    logic [31:0]           picm_wraddr;
     805       706310 :    logic [31:0]           picm_wr_data;
     806            6 :    logic [31:0]           picm_rd_data;
     807              : 
     808              :    // feature disable from mfdc
     809            0 :    logic  dec_tlu_external_ldfwd_disable; // disable external load forwarding
     810            0 :    logic  dec_tlu_bpred_disable;
     811            9 :    logic  dec_tlu_wb_coalescing_disable;
     812          283 :    logic  dec_tlu_sideeffect_posted_disable;
     813          307 :    logic [2:0] dec_tlu_dma_qos_prty;         // DMA QoS priority coming from MFDC [18:16]
     814              : 
     815              :    // clock gating overrides from mcgc
     816            2 :    logic  dec_tlu_misc_clk_override;
     817            2 :    logic  dec_tlu_ifu_clk_override;
     818            2 :    logic  dec_tlu_lsu_clk_override;
     819            2 :    logic  dec_tlu_bus_clk_override;
     820            2 :    logic  dec_tlu_pic_clk_override;
     821            2 :    logic  dec_tlu_dccm_clk_override;
     822            2 :    logic  dec_tlu_icm_clk_override;
     823              : 
     824          300 :    logic  dec_tlu_picio_clk_override;
     825              : 
     826              :    assign        dccm_clk_override = dec_tlu_dccm_clk_override;   // dccm memory
     827              :    assign        icm_clk_override = dec_tlu_icm_clk_override;    // icache/iccm memory
     828              : 
     829              :   // PMP Signals
     830          106 :   el2_pmp_cfg_pkt_t       pmp_pmpcfg  [pt.PMP_ENTRIES];
     831              :   logic [31:0]            pmp_pmpaddr [pt.PMP_ENTRIES];
     832      4875801 :   logic [31:0]            pmp_chan_addr [3];
     833      1501995 :   el2_pmp_type_pkt_t      pmp_chan_type [3];
     834       156473 :   logic                   pmp_chan_err  [3];
     835              : 
     836      4860092 :   logic [31:1] ifu_pmp_addr;
     837           62 :   logic        ifu_pmp_error;
     838      2127949 :   logic [31:0] lsu_pmp_addr_start;
     839       156473 :   logic        lsu_pmp_error_start;
     840      2127949 :   logic [31:0] lsu_pmp_addr_end;
     841       156473 :   logic        lsu_pmp_error_end;
     842       996185 :   logic        lsu_pmp_we;
     843      1355496 :   logic        lsu_pmp_re;
     844              : 
     845              :    // -----------------------DEBUG  START -------------------------------
     846              : 
     847         1706 :    logic [31:0]            dbg_cmd_addr;              // the address of the debug command to used by the core
     848         1848 :    logic [31:0]            dbg_cmd_wrdata;            // If the debug command is a write command, this has the data to be written to the CSR/GPR
     849         2972 :    logic                   dbg_cmd_valid;             // commad is being driven by the dbg module. One pulse. Only dirven when core_halted has been seen
     850          296 :    logic                   dbg_cmd_write;             // 1: write command; 0: read_command
     851         1998 :    logic [1:0]             dbg_cmd_type;              // 0:gpr 1:csr 2: memory
     852         1398 :    logic [1:0]             dbg_cmd_size;              // size of the abstract mem access debug command
     853            8 :    logic                   dbg_halt_req;              // Sticky signal indicating that the debug module wants to start the entering of debug mode ( start the halting sequence )
     854            8 :    logic                   dbg_resume_req;            // Sticky signal indicating that the debug module wants to resume from debug mode
     855          298 :    logic                   dbg_core_rst_l;            // Core reset from DM
     856              : 
     857         2972 :    logic                   core_dbg_cmd_done;         // Final muxed cmd done to debug
     858            0 :    logic                   core_dbg_cmd_fail;         // Final muxed cmd done to debug
     859      1675744 :    logic [31:0]            core_dbg_rddata;           // Final muxed cmd done to debug
     860              : 
     861            0 :    logic                   dma_dbg_cmd_done;          // Abstarct memory command sent to dma is done
     862            0 :    logic                   dma_dbg_cmd_fail;          // Abstarct memory command sent to dma failed
     863           19 :    logic [31:0]            dma_dbg_rddata;            // Read data for abstract memory access
     864              : 
     865         2972 :    logic                   dbg_dma_bubble;            // Debug needs a bubble to send a valid
     866         2972 :    logic                   dma_dbg_ready;             // DMA is ready to accept debug request
     867              : 
     868      1675744 :    logic [31:0]            dec_dbg_rddata;            // The core drives this data ( intercepts the pipe and sends it here )
     869         2972 :    logic                   dec_dbg_cmd_done;          // This will be treated like a valid signal
     870            0 :    logic                   dec_dbg_cmd_fail;          // Abstract command failed
     871          114 :    logic                   dec_tlu_mpc_halted_only;   // Only halted due to MPC
     872          124 :    logic                   dec_tlu_dbg_halted;        // The core has finished the queiscing sequence. Sticks this signal high
     873            8 :    logic                   dec_tlu_resume_ack;
     874          124 :    logic                   dec_tlu_debug_mode;        // Core is in debug mode
     875          432 :    logic                   dec_debug_wdata_rs1_d;
     876            0 :    logic                   dec_tlu_force_halt;        // halt has been forced
     877              : 
     878      5886900 :    logic [1:0]             dec_data_en;
     879      5694849 :    logic [1:0]             dec_ctl_en;
     880              : 
     881              :    // PMU Signals
     882       388588 :    logic                   exu_pmu_i0_br_misp;
     883      1460784 :    logic                   exu_pmu_i0_br_ataken;
     884      1988110 :    logic                   exu_pmu_i0_pc4;
     885              : 
     886       822278 :    logic                   lsu_pmu_load_external_m;
     887       736647 :    logic                   lsu_pmu_store_external_m;
     888        34502 :    logic                   lsu_pmu_misaligned_m;
     889      1524194 :    logic                   lsu_pmu_bus_trxn;
     890        25932 :    logic                   lsu_pmu_bus_misaligned;
     891            4 :    logic                   lsu_pmu_bus_error;
     892        90020 :    logic                   lsu_pmu_bus_busy;
     893              : 
     894       586864 :    logic                   ifu_pmu_fetch_stall;
     895      5568529 :    logic                   ifu_pmu_ic_miss;
     896       737150 :    logic                   ifu_pmu_ic_hit;
     897           18 :    logic                   ifu_pmu_bus_error;
     898      4145587 :    logic                   ifu_pmu_bus_busy;
     899      9714093 :    logic                   ifu_pmu_bus_trxn;
     900              : 
     901          414 :    logic                   active_state;
     902     62074601 :    logic                   free_clk;
     903     62074601 :    logic                   active_clk;
     904            2 :    logic                   dec_pause_state_cg;
     905              : 
     906            2 :    logic                   lsu_nonblock_load_data_error;
     907              : 
     908      5655042 :    logic [15:0]            ifu_i0_cinst;
     909              : 
     910              : // fast interrupt
     911            1 :    logic [31:2]            dec_tlu_meihap;
     912            0 :    logic                   dec_extint_stall;
     913              : 
     914      7555018 :    el2_trace_pkt_t  trace_rv_trace_pkt;
     915              : 
     916              : 
     917            4 :    logic                   lsu_fastint_stall_any;
     918              : 
     919            0 :    logic [7:0]  pic_claimid;
     920            0 :    logic [3:0]  pic_pl, dec_tlu_meicurpl, dec_tlu_meipt;
     921            0 :    logic        mexintpend;
     922            0 :    logic        mhwakeup;
     923              : 
     924          108 :    logic        dma_active;
     925              : 
     926              : 
     927            2 :    logic        pause_state;
     928          114 :    logic        halt_state;
     929              : 
     930      1993560 :    logic        dec_tlu_core_empty;
     931              : 
     932              :    assign pause_state = dec_pause_state_cg & ~(dma_active | lsu_active) & dec_tlu_core_empty;
     933              : 
     934              :    assign halt_state = o_cpu_halt_status & ~(dma_active | lsu_active);
     935              : 
     936              : 
     937              :    assign active_state = (~(halt_state | pause_state) | dec_tlu_flush_lower_r | dec_tlu_flush_lower_wb)  | dec_tlu_misc_clk_override;
     938              : 
     939              :    rvoclkhdr free_cg2   ( .clk(clk), .en(1'b1),         .l1clk(free_l2clk), .* );
     940              :    rvoclkhdr active_cg2 ( .clk(clk), .en(active_state), .l1clk(active_l2clk), .* );
     941              : 
     942              : // all other clock headers are 1st level
     943              :    rvoclkhdr free_cg1   ( .clk(free_l2clk),     .en(1'b1), .l1clk(free_clk), .* );
     944              :    rvoclkhdr active_cg1 ( .clk(active_l2clk),   .en(1'b1), .l1clk(active_clk), .* );
     945              : 
     946              : 
     947              :    assign core_dbg_cmd_done = dma_dbg_cmd_done | dec_dbg_cmd_done;
     948              :    assign core_dbg_cmd_fail = dma_dbg_cmd_fail | dec_dbg_cmd_fail;
     949     24585099 :    assign core_dbg_rddata[31:0] = dma_dbg_cmd_done ? dma_dbg_rddata[31:0] : dec_dbg_rddata[31:0];
     950              : 
     951              :    el2_dbg #(.pt(pt)) dbg (
     952              :       .rst_l(core_rst_l),
     953              :       .clk(free_l2clk),
     954              :       .clk_override(dec_tlu_misc_clk_override),
     955              : 
     956              :       // AXI signals
     957              :       .sb_axi_awready(sb_axi_awready_int),
     958              :       .sb_axi_wready(sb_axi_wready_int),
     959              :       .sb_axi_bvalid(sb_axi_bvalid_int),
     960              :       .sb_axi_bresp(sb_axi_bresp_int[1:0]),
     961              : 
     962              :       .sb_axi_arready(sb_axi_arready_int),
     963              :       .sb_axi_rvalid(sb_axi_rvalid_int),
     964              :       .sb_axi_rdata(sb_axi_rdata_int[63:0]),
     965              :       .sb_axi_rresp(sb_axi_rresp_int[1:0]),
     966              :       .*
     967              :    );
     968              : 
     969              : `ifdef RV_ASSERT_ON
     970              :       assert_fetch_indbghalt: assert #0 (~(ifu.ifc_fetch_req_f & dec.tlu.dbg_tlu_halted_f & ~dec.tlu.dcsr_single_step_running)) else $display("ERROR: Fetching in dBG halt!");
     971              : `endif
     972              : 
     973              :    // -----------------   DEBUG END -----------------------------
     974              : 
     975              :    assign core_rst_l = rst_l & (dbg_core_rst_l | scan_mode);
     976              : 
     977              : `ifdef RV_USER_MODE
     978              : 
     979              :    // Operating privilege mode, 0 - machine, 1 - user
     980          807 :    logic priv_mode;
     981              :    // Effective privilege mode, 0 - machine, 1 - user (driven in el2_dec_tlu_ctl.sv)
     982          903 :    logic priv_mode_eff;
     983              :    // Next privilege mode
     984          807 :    logic priv_mode_ns;
     985              : 
     986            8 :    el2_mseccfg_pkt_t mseccfg; // mseccfg CSR for PMP
     987              : 
     988              : `endif
     989              : 
     990              :    // fetch
     991              :    el2_ifu #(.pt(pt)) ifu (
     992              :                             .clk(active_l2clk),
     993              :                             .rst_l(core_rst_l),
     994              :                             .dec_tlu_flush_err_wb       (dec_tlu_flush_err_r      ),
     995              :                             .dec_tlu_flush_noredir_wb   (dec_tlu_flush_noredir_r  ),
     996              :                             .dec_tlu_fence_i_wb         (dec_tlu_fence_i_r        ),
     997              :                             .dec_tlu_flush_leak_one_wb  (dec_tlu_flush_leak_one_r ),
     998              :                             .dec_tlu_flush_lower_wb     (dec_tlu_flush_lower_r    ),
     999              : 
    1000              :                             // AXI signals
    1001              :                             .ifu_axi_arready(ifu_axi_arready_int),
    1002              :                             .ifu_axi_rvalid(ifu_axi_rvalid_int),
    1003              :                             .ifu_axi_rid(ifu_axi_rid_int[pt.IFU_BUS_TAG-1:0]),
    1004              :                             .ifu_axi_rdata(ifu_axi_rdata_int[63:0]),
    1005              :                             .ifu_axi_rresp(ifu_axi_rresp_int[1:0]),
    1006              : 
    1007              :                             .*
    1008              :                             );
    1009              : 
    1010              : 
    1011              :    assign iccm_ecc_single_error = ifu_iccm_rd_ecc_single_err || ifu_iccm_dma_rd_ecc_single_err;
    1012              :    assign iccm_ecc_double_error = ifu_iccm_rd_ecc_double_err;
    1013              : 
    1014              :    el2_dec #(.pt(pt)) dec (
    1015              :                             .clk(active_l2clk),
    1016              :                             .dbg_cmd_wrdata(dbg_cmd_wrdata[1:0]),
    1017              :                             .rst_l(core_rst_l),
    1018              :                             .*
    1019              :                             );
    1020              : 
    1021              :    el2_exu #(.pt(pt)) exu (
    1022              :                             .clk(active_l2clk),
    1023              :                             .rst_l(core_rst_l),
    1024              :                             .*
    1025              :                             );
    1026              : 
    1027              :    el2_lsu #(.pt(pt)) lsu (
    1028              :                             .clk(active_l2clk),
    1029              :                             .rst_l(core_rst_l),
    1030              :                             .clk_override(dec_tlu_lsu_clk_override),
    1031              :                             .dec_tlu_i0_kill_writeb_r(dec_tlu_i0_kill_writeb_r),
    1032              : 
    1033              :                             // AXI signals
    1034              :                             .lsu_axi_awready(lsu_axi_awready_int),
    1035              :                             .lsu_axi_wready(lsu_axi_wready_int),
    1036              :                             .lsu_axi_bvalid(lsu_axi_bvalid_int),
    1037              :                             .lsu_axi_bid(lsu_axi_bid_int[pt.LSU_BUS_TAG-1:0]),
    1038              :                             .lsu_axi_bresp(lsu_axi_bresp_int[1:0]),
    1039              : 
    1040              :                             .lsu_axi_arready(lsu_axi_arready_int),
    1041              :                             .lsu_axi_rvalid(lsu_axi_rvalid_int),
    1042              :                             .lsu_axi_rid(lsu_axi_rid_int[pt.LSU_BUS_TAG-1:0]),
    1043              :                             .lsu_axi_rdata(lsu_axi_rdata_int[63:0]),
    1044              :                             .lsu_axi_rresp(lsu_axi_rresp_int[1:0]),
    1045              :                             .lsu_axi_rlast(lsu_axi_rlast_int),
    1046              : 
    1047              :                             .*
    1048              : 
    1049              :                             );
    1050              : 
    1051              :    assign dccm_ecc_single_error = lsu_dccm_rd_ecc_single_err;
    1052              :    assign dccm_ecc_double_error = lsu_dccm_rd_ecc_double_err;
    1053              : 
    1054              :    el2_pic_ctrl  #(.pt(pt)) pic_ctrl_inst (
    1055              :                                             .clk(free_l2clk),
    1056              :                                             .clk_override(dec_tlu_pic_clk_override),
    1057              :                                             .io_clk_override(dec_tlu_picio_clk_override),
    1058              :                                             .picm_mken (picm_mken),
    1059              :                                             .extintsrc_req({extintsrc_req[pt.PIC_TOTAL_INT:1],1'b0}),
    1060              :                                             .pl(pic_pl[3:0]),
    1061              :                                             .claimid(pic_claimid[7:0]),
    1062              :                                             .meicurpl(dec_tlu_meicurpl[3:0]),
    1063              :                                             .meipt(dec_tlu_meipt[3:0]),
    1064              :                                             .rst_l(core_rst_l),
    1065              :                                             .*);
    1066              : 
    1067              :    el2_dma_ctrl #(.pt(pt)) dma_ctrl (
    1068              :                                       .clk(free_l2clk),
    1069              :                                       .rst_l(core_rst_l),
    1070              :                                       .clk_override(dec_tlu_misc_clk_override),
    1071              : 
    1072              :                                       // AXI signals
    1073              :                                       .dma_axi_awvalid(dma_axi_awvalid_int),
    1074              :                                       .dma_axi_awid(dma_axi_awid_int[pt.DMA_BUS_TAG-1:0]),
    1075              :                                       .dma_axi_awaddr(dma_axi_awaddr_int[31:0]),
    1076              :                                       .dma_axi_awsize(dma_axi_awsize_int[2:0]),
    1077              :                                       .dma_axi_wvalid(dma_axi_wvalid_int),
    1078              :                                       .dma_axi_wdata(dma_axi_wdata_int[63:0]),
    1079              :                                       .dma_axi_wstrb(dma_axi_wstrb_int[7:0]),
    1080              :                                       .dma_axi_bready(dma_axi_bready_int),
    1081              : 
    1082              :                                       .dma_axi_arvalid(dma_axi_arvalid_int),
    1083              :                                       .dma_axi_arid(dma_axi_arid_int[pt.DMA_BUS_TAG-1:0]),
    1084              :                                       .dma_axi_araddr(dma_axi_araddr_int[31:0]),
    1085              :                                       .dma_axi_arsize(dma_axi_arsize_int[2:0]),
    1086              :                                       .dma_axi_rready(dma_axi_rready_int),
    1087              : 
    1088              :                                       .*
    1089              :                                       );
    1090              : 
    1091              :   assign pmp_chan_addr[0] = {ifu_pmp_addr, 1'b0};
    1092              :   assign pmp_chan_type[0] = EXEC;
    1093              :   assign ifu_pmp_error    = pmp_chan_err[0];
    1094              :   assign pmp_chan_addr[1] = lsu_pmp_addr_start;
    1095     98883666 :   assign pmp_chan_type[1] = lsu_pmp_we ? WRITE : (lsu_pmp_re ? READ : NONE);
    1096              :   assign lsu_pmp_error_start = pmp_chan_err[1];
    1097              :   assign pmp_chan_addr[2] = lsu_pmp_addr_end;
    1098     98883666 :   assign pmp_chan_type[2] = lsu_pmp_we ? WRITE : (lsu_pmp_re ? READ : NONE);
    1099              :   assign lsu_pmp_error_end = pmp_chan_err[2];
    1100              : 
    1101              :   el2_pmp #(
    1102              :       .PMP_CHANNELS(3),
    1103              :       .pt(pt)
    1104              :   ) pmp (
    1105              :       .clk  (active_l2clk),
    1106              :       .rst_l(core_rst_l),
    1107              :       .*
    1108              :   );
    1109              : 
    1110              :    if (pt.BUILD_AHB_LITE == 1) begin: Gen_AXI_To_AHB
    1111              : 
    1112              :       // AXI4 -> AHB Gasket for LSU
    1113              :       axi4_to_ahb #(.pt(pt),
    1114              :                     .TAG(pt.LSU_BUS_TAG)) lsu_axi4_to_ahb (
    1115              : 
    1116              :          .clk(free_l2clk),
    1117              :          .free_clk(free_clk),
    1118              :          .rst_l(core_rst_l),
    1119              :          .clk_override(dec_tlu_bus_clk_override),
    1120              :          .bus_clk_en(lsu_bus_clk_en),
    1121              :          .dec_tlu_force_halt(dec_tlu_force_halt),
    1122              : 
    1123              :          // AXI Write Channels
    1124              :          .axi_awvalid(lsu_axi_awvalid),
    1125              :          .axi_awready(lsu_axi_awready_ahb),
    1126              :          .axi_awid(lsu_axi_awid[pt.LSU_BUS_TAG-1:0]),
    1127              :          .axi_awaddr(lsu_axi_awaddr[31:0]),
    1128              :          .axi_awsize(lsu_axi_awsize[2:0]),
    1129              :          .axi_awprot(lsu_axi_awprot[2:0]),
    1130              : 
    1131              :          .axi_wvalid(lsu_axi_wvalid),
    1132              :          .axi_wready(lsu_axi_wready_ahb),
    1133              :          .axi_wdata(lsu_axi_wdata[63:0]),
    1134              :          .axi_wstrb(lsu_axi_wstrb[7:0]),
    1135              :          .axi_wlast(lsu_axi_wlast),
    1136              : 
    1137              :          .axi_bvalid(lsu_axi_bvalid_ahb),
    1138              :          .axi_bready(lsu_axi_bready),
    1139              :          .axi_bresp(lsu_axi_bresp_ahb[1:0]),
    1140              :          .axi_bid(lsu_axi_bid_ahb[pt.LSU_BUS_TAG-1:0]),
    1141              : 
    1142              :          // AXI Read Channels
    1143              :          .axi_arvalid(lsu_axi_arvalid),
    1144              :          .axi_arready(lsu_axi_arready_ahb),
    1145              :          .axi_arid(lsu_axi_arid[pt.LSU_BUS_TAG-1:0]),
    1146              :          .axi_araddr(lsu_axi_araddr[31:0]),
    1147              :          .axi_arsize(lsu_axi_arsize[2:0]),
    1148              :          .axi_arprot(lsu_axi_arprot[2:0]),
    1149              : 
    1150              :          .axi_rvalid(lsu_axi_rvalid_ahb),
    1151              :          .axi_rready(lsu_axi_rready),
    1152              :          .axi_rid(lsu_axi_rid_ahb[pt.LSU_BUS_TAG-1:0]),
    1153              :          .axi_rdata(lsu_axi_rdata_ahb[63:0]),
    1154              :          .axi_rresp(lsu_axi_rresp_ahb[1:0]),
    1155              :          .axi_rlast(lsu_axi_rlast_ahb),
    1156              : 
    1157              :          // AHB-LITE signals
    1158              :          .ahb_haddr(lsu_haddr[31:0]),
    1159              :          .ahb_hburst(lsu_hburst),
    1160              :          .ahb_hmastlock(lsu_hmastlock),
    1161              :          .ahb_hprot(lsu_hprot[3:0]),
    1162              :          .ahb_hsize(lsu_hsize[2:0]),
    1163              :          .ahb_htrans(lsu_htrans[1:0]),
    1164              :          .ahb_hwrite(lsu_hwrite),
    1165              :          .ahb_hwdata(lsu_hwdata[63:0]),
    1166              : 
    1167              :          .ahb_hrdata(lsu_hrdata[63:0]),
    1168              :          .ahb_hready(lsu_hready),
    1169              :          .ahb_hresp(lsu_hresp),
    1170              : 
    1171              :          .*
    1172              :       );
    1173              : 
    1174              :       axi4_to_ahb #(.pt(pt),
    1175              :                     .TAG(pt.IFU_BUS_TAG)) ifu_axi4_to_ahb (
    1176              :          .clk(free_l2clk),
    1177              :          .free_clk(free_clk),
    1178              :          .rst_l(core_rst_l),
    1179              :          .clk_override(dec_tlu_bus_clk_override),
    1180              :          .bus_clk_en(ifu_bus_clk_en),
    1181              :          .dec_tlu_force_halt(dec_tlu_force_halt),
    1182              : 
    1183              :           // AHB-Lite signals
    1184              :          .ahb_haddr(haddr[31:0]),
    1185              :          .ahb_hburst(hburst),
    1186              :          .ahb_hmastlock(hmastlock),
    1187              :          .ahb_hprot(hprot[3:0]),
    1188              :          .ahb_hsize(hsize[2:0]),
    1189              :          .ahb_htrans(htrans[1:0]),
    1190              :          .ahb_hwrite(hwrite),
    1191              :          .ahb_hwdata(hwdata_nc[63:0]),
    1192              : 
    1193              :          .ahb_hrdata(hrdata[63:0]),
    1194              :          .ahb_hready(hready),
    1195              :          .ahb_hresp(hresp),
    1196              : 
    1197              :          // AXI Write Channels
    1198              :          .axi_awvalid(ifu_axi_awvalid),
    1199              :          .axi_awready(ifu_axi_awready_ahb),
    1200              :          .axi_awid(ifu_axi_awid[pt.IFU_BUS_TAG-1:0]),
    1201              :          .axi_awaddr(ifu_axi_awaddr[31:0]),
    1202              :          .axi_awsize(ifu_axi_awsize[2:0]),
    1203              :          .axi_awprot(ifu_axi_awprot[2:0]),
    1204              : 
    1205              :          .axi_wvalid(ifu_axi_wvalid),
    1206              :          .axi_wready(ifu_axi_wready_ahb),
    1207              :          .axi_wdata(ifu_axi_wdata[63:0]),
    1208              :          .axi_wstrb(ifu_axi_wstrb[7:0]),
    1209              :          .axi_wlast(ifu_axi_wlast),
    1210              : 
    1211              :          .axi_bvalid(ifu_axi_bvalid_ahb),
    1212              :          .axi_bready(1'b1),
    1213              :          .axi_bresp(ifu_axi_bresp_ahb[1:0]),
    1214              :          .axi_bid(ifu_axi_bid_ahb[pt.IFU_BUS_TAG-1:0]),
    1215              : 
    1216              :          // AXI Read Channels
    1217              :          .axi_arvalid(ifu_axi_arvalid),
    1218              :          .axi_arready(ifu_axi_arready_ahb),
    1219              :          .axi_arid(ifu_axi_arid[pt.IFU_BUS_TAG-1:0]),
    1220              :          .axi_araddr(ifu_axi_araddr[31:0]),
    1221              :          .axi_arsize(ifu_axi_arsize[2:0]),
    1222              :          .axi_arprot(ifu_axi_arprot[2:0]),
    1223              : 
    1224              :          .axi_rvalid(ifu_axi_rvalid_ahb),
    1225              :          .axi_rready(ifu_axi_rready),
    1226              :          .axi_rid(ifu_axi_rid_ahb[pt.IFU_BUS_TAG-1:0]),
    1227              :          .axi_rdata(ifu_axi_rdata_ahb[63:0]),
    1228              :          .axi_rresp(ifu_axi_rresp_ahb[1:0]),
    1229              :          .axi_rlast(ifu_axi_rlast_ahb),
    1230              :          .*
    1231              :       );
    1232              : 
    1233              :       // AXI4 -> AHB Gasket for System Bus
    1234              :       axi4_to_ahb #(.pt(pt),
    1235              :                     .TAG(pt.SB_BUS_TAG)) sb_axi4_to_ahb (
    1236              :          .clk(free_l2clk),
    1237              :          .free_clk(free_clk),
    1238              :          .rst_l(dbg_rst_l),
    1239              :          .clk_override(dec_tlu_bus_clk_override),
    1240              :          .bus_clk_en(dbg_bus_clk_en),
    1241              :          .dec_tlu_force_halt(1'b0),
    1242              : 
    1243              :          // AXI Write Channels
    1244              :          .axi_awvalid(sb_axi_awvalid),
    1245              :          .axi_awready(sb_axi_awready_ahb),
    1246              :          .axi_awid(sb_axi_awid[pt.SB_BUS_TAG-1:0]),
    1247              :          .axi_awaddr(sb_axi_awaddr[31:0]),
    1248              :          .axi_awsize(sb_axi_awsize[2:0]),
    1249              :          .axi_awprot(sb_axi_awprot[2:0]),
    1250              : 
    1251              :          .axi_wvalid(sb_axi_wvalid),
    1252              :          .axi_wready(sb_axi_wready_ahb),
    1253              :          .axi_wdata(sb_axi_wdata[63:0]),
    1254              :          .axi_wstrb(sb_axi_wstrb[7:0]),
    1255              :          .axi_wlast(sb_axi_wlast),
    1256              : 
    1257              :          .axi_bvalid(sb_axi_bvalid_ahb),
    1258              :          .axi_bready(sb_axi_bready),
    1259              :          .axi_bresp(sb_axi_bresp_ahb[1:0]),
    1260              :          .axi_bid(sb_axi_bid_ahb[pt.SB_BUS_TAG-1:0]),
    1261              : 
    1262              :          // AXI Read Channels
    1263              :          .axi_arvalid(sb_axi_arvalid),
    1264              :          .axi_arready(sb_axi_arready_ahb),
    1265              :          .axi_arid(sb_axi_arid[pt.SB_BUS_TAG-1:0]),
    1266              :          .axi_araddr(sb_axi_araddr[31:0]),
    1267              :          .axi_arsize(sb_axi_arsize[2:0]),
    1268              :          .axi_arprot(sb_axi_arprot[2:0]),
    1269              : 
    1270              :          .axi_rvalid(sb_axi_rvalid_ahb),
    1271              :          .axi_rready(sb_axi_rready),
    1272              :          .axi_rid(sb_axi_rid_ahb[pt.SB_BUS_TAG-1:0]),
    1273              :          .axi_rdata(sb_axi_rdata_ahb[63:0]),
    1274              :          .axi_rresp(sb_axi_rresp_ahb[1:0]),
    1275              :          .axi_rlast(sb_axi_rlast_ahb),
    1276              :          // AHB-LITE signals
    1277              :          .ahb_haddr(sb_haddr[31:0]),
    1278              :          .ahb_hburst(sb_hburst),
    1279              :          .ahb_hmastlock(sb_hmastlock),
    1280              :          .ahb_hprot(sb_hprot[3:0]),
    1281              :          .ahb_hsize(sb_hsize[2:0]),
    1282              :          .ahb_htrans(sb_htrans[1:0]),
    1283              :          .ahb_hwrite(sb_hwrite),
    1284              :          .ahb_hwdata(sb_hwdata[63:0]),
    1285              : 
    1286              :          .ahb_hrdata(sb_hrdata[63:0]),
    1287              :          .ahb_hready(sb_hready),
    1288              :          .ahb_hresp(sb_hresp),
    1289              : 
    1290              :          .*
    1291              :       );
    1292              : 
    1293              :       //AHB -> AXI4 Gasket for DMA
    1294              :       ahb_to_axi4 #(.pt(pt),
    1295              :                     .TAG(pt.DMA_BUS_TAG)) dma_ahb_to_axi4 (
    1296              :          .clk(free_l2clk),
    1297              :          .rst_l(core_rst_l),
    1298              :          .clk_override(dec_tlu_bus_clk_override),
    1299              :          .bus_clk_en(dma_bus_clk_en),
    1300              : 
    1301              :          // AXI Write Channels
    1302              :          .axi_awvalid(dma_axi_awvalid_ahb),
    1303              :          .axi_awready(dma_axi_awready),
    1304              :          .axi_awid(dma_axi_awid_ahb[pt.DMA_BUS_TAG-1:0]),
    1305              :          .axi_awaddr(dma_axi_awaddr_ahb[31:0]),
    1306              :          .axi_awsize(dma_axi_awsize_ahb[2:0]),
    1307              :          .axi_awprot(dma_axi_awprot_ahb[2:0]),
    1308              :          .axi_awlen(dma_axi_awlen_ahb[7:0]),
    1309              :          .axi_awburst(dma_axi_awburst_ahb[1:0]),
    1310              : 
    1311              :          .axi_wvalid(dma_axi_wvalid_ahb),
    1312              :          .axi_wready(dma_axi_wready),
    1313              :          .axi_wdata(dma_axi_wdata_ahb[63:0]),
    1314              :          .axi_wstrb(dma_axi_wstrb_ahb[7:0]),
    1315              :          .axi_wlast(dma_axi_wlast_ahb),
    1316              : 
    1317              :          .axi_bvalid(dma_axi_bvalid),
    1318              :          .axi_bready(dma_axi_bready_ahb),
    1319              :          .axi_bresp(dma_axi_bresp[1:0]),
    1320              :          .axi_bid(dma_axi_bid[pt.DMA_BUS_TAG-1:0]),
    1321              : 
    1322              :          // AXI Read Channels
    1323              :          .axi_arvalid(dma_axi_arvalid_ahb),
    1324              :          .axi_arready(dma_axi_arready),
    1325              :          .axi_arid(dma_axi_arid_ahb[pt.DMA_BUS_TAG-1:0]),
    1326              :          .axi_araddr(dma_axi_araddr_ahb[31:0]),
    1327              :          .axi_arsize(dma_axi_arsize_ahb[2:0]),
    1328              :          .axi_arprot(dma_axi_arprot_ahb[2:0]),
    1329              :          .axi_arlen(dma_axi_arlen_ahb[7:0]),
    1330              :          .axi_arburst(dma_axi_arburst_ahb[1:0]),
    1331              : 
    1332              :          .axi_rvalid(dma_axi_rvalid),
    1333              :          .axi_rready(dma_axi_rready_ahb),
    1334              :          .axi_rid(dma_axi_rid[pt.DMA_BUS_TAG-1:0]),
    1335              :          .axi_rdata(dma_axi_rdata[63:0]),
    1336              :          .axi_rresp(dma_axi_rresp[1:0]),
    1337              : 
    1338              :           // AHB signals
    1339              :          .ahb_haddr(dma_haddr[31:0]),
    1340              :          .ahb_hburst(dma_hburst),
    1341              :          .ahb_hmastlock(dma_hmastlock),
    1342              :          .ahb_hprot(dma_hprot[3:0]),
    1343              :          .ahb_hsize(dma_hsize[2:0]),
    1344              :          .ahb_htrans(dma_htrans[1:0]),
    1345              :          .ahb_hwrite(dma_hwrite),
    1346              :          .ahb_hwdata(dma_hwdata[63:0]),
    1347              : 
    1348              :          .ahb_hrdata(dma_hrdata[63:0]),
    1349              :          .ahb_hreadyout(dma_hreadyout),
    1350              :          .ahb_hresp(dma_hresp),
    1351              :          .ahb_hreadyin(dma_hreadyin),
    1352              :          .ahb_hsel(dma_hsel),
    1353              :          .*
    1354              :       );
    1355              : 
    1356              :    end
    1357              : 
    1358              :    // Drive the final AXI inputs
    1359          298 :    assign lsu_axi_awready_int                 = pt.BUILD_AHB_LITE ? lsu_axi_awready_ahb : lsu_axi_awready;
    1360          298 :    assign lsu_axi_wready_int                  = pt.BUILD_AHB_LITE ? lsu_axi_wready_ahb : lsu_axi_wready;
    1361          298 :    assign lsu_axi_bvalid_int                  = pt.BUILD_AHB_LITE ? lsu_axi_bvalid_ahb : lsu_axi_bvalid;
    1362          298 :    assign lsu_axi_bready_int                  = pt.BUILD_AHB_LITE ? lsu_axi_bready_ahb : lsu_axi_bready;
    1363          298 :    assign lsu_axi_bresp_int[1:0]              = pt.BUILD_AHB_LITE ? lsu_axi_bresp_ahb[1:0] : lsu_axi_bresp[1:0];
    1364          298 :    assign lsu_axi_bid_int[pt.LSU_BUS_TAG-1:0] = pt.BUILD_AHB_LITE ? lsu_axi_bid_ahb[pt.LSU_BUS_TAG-1:0] : lsu_axi_bid[pt.LSU_BUS_TAG-1:0];
    1365          298 :    assign lsu_axi_arready_int                 = pt.BUILD_AHB_LITE ? lsu_axi_arready_ahb : lsu_axi_arready;
    1366          298 :    assign lsu_axi_rvalid_int                  = pt.BUILD_AHB_LITE ? lsu_axi_rvalid_ahb : lsu_axi_rvalid;
    1367          298 :    assign lsu_axi_rid_int[pt.LSU_BUS_TAG-1:0] = pt.BUILD_AHB_LITE ? lsu_axi_rid_ahb[pt.LSU_BUS_TAG-1:0] : lsu_axi_rid[pt.LSU_BUS_TAG-1:0];
    1368          298 :    assign lsu_axi_rdata_int[63:0]             = pt.BUILD_AHB_LITE ? lsu_axi_rdata_ahb[63:0] : lsu_axi_rdata[63:0];
    1369          298 :    assign lsu_axi_rresp_int[1:0]              = pt.BUILD_AHB_LITE ? lsu_axi_rresp_ahb[1:0] : lsu_axi_rresp[1:0];
    1370          298 :    assign lsu_axi_rlast_int                   = pt.BUILD_AHB_LITE ? lsu_axi_rlast_ahb : lsu_axi_rlast;
    1371              : 
    1372          298 :    assign ifu_axi_awready_int                 = pt.BUILD_AHB_LITE ? ifu_axi_awready_ahb : ifu_axi_awready;
    1373          298 :    assign ifu_axi_wready_int                  = pt.BUILD_AHB_LITE ? ifu_axi_wready_ahb : ifu_axi_wready;
    1374          298 :    assign ifu_axi_bvalid_int                  = pt.BUILD_AHB_LITE ? ifu_axi_bvalid_ahb : ifu_axi_bvalid;
    1375          298 :    assign ifu_axi_bready_int                  = pt.BUILD_AHB_LITE ? ifu_axi_bready_ahb : ifu_axi_bready;
    1376          298 :    assign ifu_axi_bresp_int[1:0]              = pt.BUILD_AHB_LITE ? ifu_axi_bresp_ahb[1:0] : ifu_axi_bresp[1:0];
    1377          298 :    assign ifu_axi_bid_int[pt.IFU_BUS_TAG-1:0] = pt.BUILD_AHB_LITE ? ifu_axi_bid_ahb[pt.IFU_BUS_TAG-1:0] : ifu_axi_bid[pt.IFU_BUS_TAG-1:0];
    1378          298 :    assign ifu_axi_arready_int                 = pt.BUILD_AHB_LITE ? ifu_axi_arready_ahb : ifu_axi_arready;
    1379          298 :    assign ifu_axi_rvalid_int                  = pt.BUILD_AHB_LITE ? ifu_axi_rvalid_ahb : ifu_axi_rvalid;
    1380          298 :    assign ifu_axi_rid_int[pt.IFU_BUS_TAG-1:0] = pt.BUILD_AHB_LITE ? ifu_axi_rid_ahb[pt.IFU_BUS_TAG-1:0] : ifu_axi_rid[pt.IFU_BUS_TAG-1:0];
    1381          298 :    assign ifu_axi_rdata_int[63:0]             = pt.BUILD_AHB_LITE ? ifu_axi_rdata_ahb[63:0] : ifu_axi_rdata[63:0];
    1382          298 :    assign ifu_axi_rresp_int[1:0]              = pt.BUILD_AHB_LITE ? ifu_axi_rresp_ahb[1:0] : ifu_axi_rresp[1:0];
    1383          298 :    assign ifu_axi_rlast_int                   = pt.BUILD_AHB_LITE ? ifu_axi_rlast_ahb : ifu_axi_rlast;
    1384              : 
    1385          298 :    assign sb_axi_awready_int                  = pt.BUILD_AHB_LITE ? sb_axi_awready_ahb : sb_axi_awready;
    1386          298 :    assign sb_axi_wready_int                   = pt.BUILD_AHB_LITE ? sb_axi_wready_ahb : sb_axi_wready;
    1387          298 :    assign sb_axi_bvalid_int                   = pt.BUILD_AHB_LITE ? sb_axi_bvalid_ahb : sb_axi_bvalid;
    1388          298 :    assign sb_axi_bready_int                   = pt.BUILD_AHB_LITE ? sb_axi_bready_ahb : sb_axi_bready;
    1389          298 :    assign sb_axi_bresp_int[1:0]               = pt.BUILD_AHB_LITE ? sb_axi_bresp_ahb[1:0] : sb_axi_bresp[1:0];
    1390          298 :    assign sb_axi_bid_int[pt.SB_BUS_TAG-1:0]   = pt.BUILD_AHB_LITE ? sb_axi_bid_ahb[pt.SB_BUS_TAG-1:0] : sb_axi_bid[pt.SB_BUS_TAG-1:0];
    1391          298 :    assign sb_axi_arready_int                  = pt.BUILD_AHB_LITE ? sb_axi_arready_ahb : sb_axi_arready;
    1392          298 :    assign sb_axi_rvalid_int                   = pt.BUILD_AHB_LITE ? sb_axi_rvalid_ahb : sb_axi_rvalid;
    1393          298 :    assign sb_axi_rid_int[pt.SB_BUS_TAG-1:0]   = pt.BUILD_AHB_LITE ? sb_axi_rid_ahb[pt.SB_BUS_TAG-1:0] : sb_axi_rid[pt.SB_BUS_TAG-1:0];
    1394          298 :    assign sb_axi_rdata_int[63:0]              = pt.BUILD_AHB_LITE ? sb_axi_rdata_ahb[63:0] : sb_axi_rdata[63:0];
    1395          298 :    assign sb_axi_rresp_int[1:0]               = pt.BUILD_AHB_LITE ? sb_axi_rresp_ahb[1:0] : sb_axi_rresp[1:0];
    1396          298 :    assign sb_axi_rlast_int                    = pt.BUILD_AHB_LITE ? sb_axi_rlast_ahb : sb_axi_rlast;
    1397              : 
    1398          298 :    assign dma_axi_awvalid_int                  = pt.BUILD_AHB_LITE ? dma_axi_awvalid_ahb : dma_axi_awvalid;
    1399          298 :    assign dma_axi_awid_int[pt.DMA_BUS_TAG-1:0] = pt.BUILD_AHB_LITE ? dma_axi_awid_ahb[pt.DMA_BUS_TAG-1:0] : dma_axi_awid[pt.DMA_BUS_TAG-1:0];
    1400          298 :    assign dma_axi_awaddr_int[31:0]             = pt.BUILD_AHB_LITE ? dma_axi_awaddr_ahb[31:0] : dma_axi_awaddr[31:0];
    1401          298 :    assign dma_axi_awsize_int[2:0]              = pt.BUILD_AHB_LITE ? dma_axi_awsize_ahb[2:0] : dma_axi_awsize[2:0];
    1402          298 :    assign dma_axi_awprot_int[2:0]              = pt.BUILD_AHB_LITE ? dma_axi_awprot_ahb[2:0] : dma_axi_awprot[2:0];
    1403          298 :    assign dma_axi_awlen_int[7:0]               = pt.BUILD_AHB_LITE ? dma_axi_awlen_ahb[7:0] : dma_axi_awlen[7:0];
    1404          298 :    assign dma_axi_awburst_int[1:0]             = pt.BUILD_AHB_LITE ? dma_axi_awburst_ahb[1:0] : dma_axi_awburst[1:0];
    1405          298 :    assign dma_axi_wvalid_int                   = pt.BUILD_AHB_LITE ? dma_axi_wvalid_ahb : dma_axi_wvalid;
    1406          298 :    assign dma_axi_wdata_int[63:0]              = pt.BUILD_AHB_LITE ? dma_axi_wdata_ahb[63:0] : dma_axi_wdata;
    1407          298 :    assign dma_axi_wstrb_int[7:0]               = pt.BUILD_AHB_LITE ? dma_axi_wstrb_ahb[7:0] : dma_axi_wstrb[7:0];
    1408          298 :    assign dma_axi_wlast_int                    = pt.BUILD_AHB_LITE ? dma_axi_wlast_ahb : dma_axi_wlast;
    1409          298 :    assign dma_axi_bready_int                   = pt.BUILD_AHB_LITE ? dma_axi_bready_ahb : dma_axi_bready;
    1410          298 :    assign dma_axi_arvalid_int                  = pt.BUILD_AHB_LITE ? dma_axi_arvalid_ahb : dma_axi_arvalid;
    1411          298 :    assign dma_axi_arid_int[pt.DMA_BUS_TAG-1:0] = pt.BUILD_AHB_LITE ? dma_axi_arid_ahb[pt.DMA_BUS_TAG-1:0] : dma_axi_arid[pt.DMA_BUS_TAG-1:0];
    1412          298 :    assign dma_axi_araddr_int[31:0]             = pt.BUILD_AHB_LITE ? dma_axi_araddr_ahb[31:0] : dma_axi_araddr[31:0];
    1413          298 :    assign dma_axi_arsize_int[2:0]              = pt.BUILD_AHB_LITE ? dma_axi_arsize_ahb[2:0] : dma_axi_arsize[2:0];
    1414          298 :    assign dma_axi_arprot_int[2:0]              = pt.BUILD_AHB_LITE ? dma_axi_arprot_ahb[2:0] : dma_axi_arprot[2:0];
    1415          298 :    assign dma_axi_arlen_int[7:0]               = pt.BUILD_AHB_LITE ? dma_axi_arlen_ahb[7:0] : dma_axi_arlen[7:0];
    1416          298 :    assign dma_axi_arburst_int[1:0]             = pt.BUILD_AHB_LITE ? dma_axi_arburst_ahb[1:0] : dma_axi_arburst[1:0];
    1417          298 :    assign dma_axi_rready_int                   = pt.BUILD_AHB_LITE ? dma_axi_rready_ahb : dma_axi_rready;
    1418              : 
    1419              : 
    1420              : if  (pt.BUILD_AHB_LITE == 1) begin
    1421              : `ifdef RV_ASSERT_ON
    1422              :    property ahb_trxn_aligned;
    1423              :      @(posedge clk) disable iff(~rst_l) (lsu_htrans[1:0] != 2'b0)  |-> ((lsu_hsize[2:0] == 3'h0)                              |
    1424              :                                                                         ((lsu_hsize[2:0] == 3'h1) & (lsu_haddr[0] == 1'b0))   |
    1425              :                                                                         ((lsu_hsize[2:0] == 3'h2) & (lsu_haddr[1:0] == 2'b0)) |
    1426              :                                                                         ((lsu_hsize[2:0] == 3'h3) & (lsu_haddr[2:0] == 3'b0)));
    1427              :    endproperty
    1428              :    assert_ahb_trxn_aligned: assert property (ahb_trxn_aligned) else
    1429              :      $display("Assertion ahb_trxn_aligned failed: lsu_htrans=2'h%h, lsu_hsize=3'h%h, lsu_haddr=32'h%h",lsu_htrans[1:0], lsu_hsize[2:0], lsu_haddr[31:0]);
    1430              : 
    1431              :    property dma_trxn_aligned;
    1432              :      @(posedge clk) disable iff(~rst_l) (dma_htrans[1:0] != 2'b0)  |-> ((dma_hsize[2:0] == 3'h0)                              |
    1433              :                                                                         ((dma_hsize[2:0] == 3'h1) & (dma_haddr[0] == 1'b0))   |
    1434              :                                                                         ((dma_hsize[2:0] == 3'h2) & (dma_haddr[1:0] == 2'b0)) |
    1435              :                                                                         ((dma_hsize[2:0] == 3'h3) & (dma_haddr[2:0] == 3'b0)));
    1436              :    endproperty
    1437              : 
    1438              : 
    1439              : `endif
    1440              :    end // if (pt.BUILD_AHB_LITE == 1)
    1441              : 
    1442              : 
    1443              :       // unpack packet
    1444              :       // also need retires_p==3
    1445              : 
    1446              :       assign trace_rv_i_insn_ip[31:0]     = trace_rv_trace_pkt.trace_rv_i_insn_ip[31:0];
    1447              : 
    1448              :       assign trace_rv_i_address_ip[31:0]  = trace_rv_trace_pkt.trace_rv_i_address_ip[31:0];
    1449              : 
    1450              :       assign trace_rv_i_valid_ip     = trace_rv_trace_pkt.trace_rv_i_valid_ip;
    1451              : 
    1452              :       assign trace_rv_i_exception_ip = trace_rv_trace_pkt.trace_rv_i_exception_ip;
    1453              : 
    1454              :       assign trace_rv_i_ecause_ip[4:0]    = trace_rv_trace_pkt.trace_rv_i_ecause_ip[4:0];
    1455              : 
    1456              :       assign trace_rv_i_interrupt_ip = trace_rv_trace_pkt.trace_rv_i_interrupt_ip;
    1457              : 
    1458              :       assign trace_rv_i_tval_ip[31:0]     = trace_rv_trace_pkt.trace_rv_i_tval_ip[31:0];
    1459              : 
    1460              : 
    1461              : 
    1462              : endmodule // el2_veer
    1463              :