// © IBM Corp. 2022
// Licensed under the Apache License, Version 2.0 (the "License"), as modified by
// the terms below; you may not use the files in this repository except in
// compliance with the License as modified.
// You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
//
// Modified Terms:
//
//    1) For the purpose of the patent license granted to you in Section 3 of the
//    License, the "Work" hereby includes implementations of the work of authorship
//    in physical form.
//
//    2) Notwithstanding any terms to the contrary in the License, any licenses
//    necessary for implementation of the Work that are available from OpenPOWER
//    via the Power ISA End User License Agreement (EULA) are explicitly excluded
//    hereunder, and may be obtained from OpenPOWER under the terms and conditions
//    of the EULA.
//
// Unless required by applicable law or agreed to in writing, the reference design
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License
// for the specific language governing permissions and limitations under the License.
//
// Additional rights, including the ability to physically implement a softcore that
// is compliant with the required sections of the Power ISA Specification, are
// available at no cost under the terms of the OpenPOWER Power ISA EULA, which can be
// obtained (along with the Power ISA) here: https://openpowerfoundation.org.

//  Description:  XU LSU Store Data Rotator Wrapper
//
//*****************************************************************************

// ##########################################################################################
// VHDL Contents
// 1) Load Queue
// 2) Store Queue
// 3) Load/Store Queue Control
// ##########################################################################################

`timescale 1 ns / 1 ns

`include "tri_a2o.vh"

module lq_arb(
   imq_arb_iuq_ld_req_avail,
   imq_arb_iuq_tid,
   imq_arb_iuq_usr_def,
   imq_arb_iuq_wimge,
   imq_arb_iuq_p_addr,
   imq_arb_iuq_ttype,
   imq_arb_iuq_opSize,
   imq_arb_iuq_cTag,
   imq_arb_mmq_ld_req_avail,
   imq_arb_mmq_st_req_avail,
   imq_arb_mmq_tid,
   imq_arb_mmq_usr_def,
   imq_arb_mmq_wimge,
   imq_arb_mmq_p_addr,
   imq_arb_mmq_ttype,
   imq_arb_mmq_opSize,
   imq_arb_mmq_cTag,
   imq_arb_mmq_st_data,
   ldq_arb_ld_req_pwrToken,
   ldq_arb_ld_req_avail,
   ldq_arb_tid,
   ldq_arb_usr_def,
   ldq_arb_wimge,
   ldq_arb_p_addr,
   ldq_arb_ttype,
   ldq_arb_opSize,
   ldq_arb_cTag,
   stq_arb_stq1_stg_act,
   stq_arb_st_req_avail,
   stq_arb_stq3_cmmt_val,
   stq_arb_stq3_cmmt_reject,
   stq_arb_stq3_req_val,
   stq_arb_stq3_tid,
   stq_arb_stq3_usrDef,
   stq_arb_stq3_wimge,
   stq_arb_stq3_p_addr,
   stq_arb_stq3_ttype,
   stq_arb_stq3_opSize,
   stq_arb_stq3_byteEn,
   stq_arb_stq3_cTag,
   dat_lsq_stq4_128data,
   ldq_arb_rel1_stg_act,
   ldq_arb_rel1_data_sel,
   ldq_arb_rel1_data,
   ldq_arb_rel1_blk_store,
   ldq_arb_rel1_axu_val,
   ldq_arb_rel1_op_size,
   ldq_arb_rel1_addr,
   ldq_arb_rel1_ci,
   ldq_arb_rel1_byte_swap,
   ldq_arb_rel1_thrd_id,
   ldq_arb_rel2_rdat_sel,
   stq_arb_stq1_axu_val,
   stq_arb_stq1_epid_val,
   stq_arb_stq1_opSize,
   stq_arb_stq1_p_addr,
   stq_arb_stq1_wimge_i,
   stq_arb_stq1_store_data,
   stq_arb_stq1_byte_swap,
   stq_arb_stq1_thrd_id,
   stq_arb_release_itag_vld,
   stq_arb_release_itag,
   stq_arb_release_tid,
   l2_lsq_req_ld_pop,
   l2_lsq_req_st_pop,
   l2_lsq_req_st_gather,
   ctl_lsq_stq3_icswx_data,
   ldq_arb_rel2_rd_data,
   arb_ldq_rel2_wrt_data,
   arb_stq_cred_avail,
   arb_ldq_ldq_unit_sel,
   arb_imq_iuq_unit_sel,
   arb_imq_mmq_unit_sel,
   lsq_ctl_stq1_axu_val,
   lsq_ctl_stq1_epid_val,
   lsq_dat_stq1_le_mode,
   lsq_dat_stq1_op_size,
   lsq_dat_stq1_addr,
   lsq_dat_stq2_store_data,
   lsq_ctl_stq1_addr,
   lsq_ctl_stq1_ci,
   lsq_ctl_stq1_thrd_id,
   lsq_ctl_stq_release_itag_vld,
   lsq_ctl_stq_release_itag,
   lsq_ctl_stq_release_tid,
   lsq_l2_pwrToken,
   lsq_l2_valid,
   lsq_l2_tid,
   lsq_l2_p_addr,
   lsq_l2_wimge,
   lsq_l2_usrDef,
   lsq_l2_byteEn,
   lsq_l2_ttype,
   lsq_l2_opSize,
   lsq_l2_coreTag,
   lsq_l2_dataToken,
   lsq_l2_st_data,
   ctl_lsq_spr_lsucr0_b2b,
   xu_lq_spr_xucr0_cred,
   xu_lq_spr_xucr0_cls,
   lq_pc_err_l2credit_overrun,
   vdd,
   gnd,
   clk,
   rst,
   sg_0,
   func_sl_thold_0_b,
   func_sl_force,
   func_slp_sl_thold_0_b,
   func_slp_sl_force,
   d_mode_dc,
   delay_lclkr_dc,
   mpw1_dc_b,
   mpw2_dc_b,
   scan_in,
   scan_out
);

   // IUQ Request to the L2
   input                                  imq_arb_iuq_ld_req_avail;
   input [0:1]                            imq_arb_iuq_tid;
   input [0:3]                            imq_arb_iuq_usr_def;
   input [0:4]                            imq_arb_iuq_wimge;
   input [64-`REAL_IFAR_WIDTH:63]         imq_arb_iuq_p_addr;
   input [0:5]                            imq_arb_iuq_ttype;
   input [0:2]                            imq_arb_iuq_opSize;
   input [0:4]                            imq_arb_iuq_cTag;

   // MMQ Request to the L2
   input                                  imq_arb_mmq_ld_req_avail;
   input                                  imq_arb_mmq_st_req_avail;
   input [0:1]                            imq_arb_mmq_tid;
   input [0:3]                            imq_arb_mmq_usr_def;
   input [0:4]                            imq_arb_mmq_wimge;
   input [64-`REAL_IFAR_WIDTH:63]         imq_arb_mmq_p_addr;
   input [0:5]                            imq_arb_mmq_ttype;
   input [0:2]                            imq_arb_mmq_opSize;
   input [0:4]                            imq_arb_mmq_cTag;
   input [0:15]                           imq_arb_mmq_st_data;

   // LDQ Request to the L2
   input                                  ldq_arb_ld_req_pwrToken;
   input                                  ldq_arb_ld_req_avail;
   input [0:1]                            ldq_arb_tid;
   input [0:3]                            ldq_arb_usr_def;
   input [0:4]                            ldq_arb_wimge;
   input [64-`REAL_IFAR_WIDTH:63]         ldq_arb_p_addr;
   input [0:5]                            ldq_arb_ttype;
   input [0:2]                            ldq_arb_opSize;
   input [0:4]                            ldq_arb_cTag;

   // Store Type Request to L2
   input                                  stq_arb_stq1_stg_act;
   input                                  stq_arb_st_req_avail;
   input                                  stq_arb_stq3_cmmt_val;
   input                                  stq_arb_stq3_cmmt_reject;
   input                                  stq_arb_stq3_req_val;
   input [0:1]                            stq_arb_stq3_tid;
   input [0:3]                            stq_arb_stq3_usrDef;
   input [0:4]                            stq_arb_stq3_wimge;
   input [64-`REAL_IFAR_WIDTH:63]         stq_arb_stq3_p_addr;
   input [0:5]                            stq_arb_stq3_ttype;
   input [0:2]                            stq_arb_stq3_opSize;
   input [0:15]                           stq_arb_stq3_byteEn;
   input [0:4]                            stq_arb_stq3_cTag;
   input [0:127]                          dat_lsq_stq4_128data;

   // Common Between LDQ and STQ
   input                                  ldq_arb_rel1_stg_act;
   input                                  ldq_arb_rel1_data_sel;
   input [0:127]                          ldq_arb_rel1_data;
   input                                  ldq_arb_rel1_blk_store;
   input                                  ldq_arb_rel1_axu_val;
   input [0:2]                            ldq_arb_rel1_op_size;
   input [64-`REAL_IFAR_WIDTH:63]         ldq_arb_rel1_addr;
   input                                  ldq_arb_rel1_ci;
   input                                  ldq_arb_rel1_byte_swap;
   input [0:`THREADS-1]                   ldq_arb_rel1_thrd_id;
   input                                  ldq_arb_rel2_rdat_sel;
   input                                  stq_arb_stq1_axu_val;
   input                                  stq_arb_stq1_epid_val;
   input [0:2]                            stq_arb_stq1_opSize;
   input [64-`REAL_IFAR_WIDTH:63]         stq_arb_stq1_p_addr;
   input                                  stq_arb_stq1_wimge_i;
   input [(128-`STQ_DATA_SIZE):127]       stq_arb_stq1_store_data;
   input                                  stq_arb_stq1_byte_swap;
   input [0:`THREADS-1]                   stq_arb_stq1_thrd_id;
   input                                  stq_arb_release_itag_vld;
   input [0:`ITAG_SIZE_ENC-1]             stq_arb_release_itag;
   input [0:`THREADS-1]                   stq_arb_release_tid;

   // L2 Credit Control
   input                                  l2_lsq_req_ld_pop;
   input                                  l2_lsq_req_st_pop;
   input                                  l2_lsq_req_st_gather;

   // ICSWX Data to be sent to the L2
   input [0:26]                           ctl_lsq_stq3_icswx_data;

   // Interface with Reload Data Queue
   input [0:143]                          ldq_arb_rel2_rd_data;
   output [0:143]                         arb_ldq_rel2_wrt_data;

   // L2 Credits Available
   output                                 arb_stq_cred_avail;

   // Unit Selected to Send Request to the L2
   output                                 arb_ldq_ldq_unit_sel;
   output                                 arb_imq_iuq_unit_sel;
   output                                 arb_imq_mmq_unit_sel;

   // Common Between LDQ and STQ
   output                                 lsq_ctl_stq1_axu_val;
   output                                 lsq_ctl_stq1_epid_val;
   output                                 lsq_dat_stq1_le_mode;
   output [0:2]                           lsq_dat_stq1_op_size;
   output [52:63]                         lsq_dat_stq1_addr;
   output [0:143]                         lsq_dat_stq2_store_data;
   output [64-`REAL_IFAR_WIDTH:63-`CL_SIZE] lsq_ctl_stq1_addr;
   output                                 lsq_ctl_stq1_ci;
   output [0:`THREADS-1]                  lsq_ctl_stq1_thrd_id;

   // STCX/ICSWX Itag Complete
   output                                 lsq_ctl_stq_release_itag_vld;
   output [0:`ITAG_SIZE_ENC-1]            lsq_ctl_stq_release_itag;
   output [0:`THREADS-1]                  lsq_ctl_stq_release_tid;

   // L2 Request Signals
   output                                 lsq_l2_pwrToken;
   output                                 lsq_l2_valid;
   output [0:1]                           lsq_l2_tid;
   output [64-`REAL_IFAR_WIDTH:63]        lsq_l2_p_addr;
   output [0:4]                           lsq_l2_wimge;
   output [0:3]                           lsq_l2_usrDef;
   output [0:15]                          lsq_l2_byteEn;
   output [0:5]                           lsq_l2_ttype;
   output [0:2]                           lsq_l2_opSize;
   output [0:4]                           lsq_l2_coreTag;
   output                                 lsq_l2_dataToken;
   output [0:127]                         lsq_l2_st_data;

   // SPR Bits
   input                                  ctl_lsq_spr_lsucr0_b2b;		// LSUCR0[B2B] Mode enabled
   input                                  xu_lq_spr_xucr0_cred;         // XUCR0[CRED] Mode enabled
   input                                  xu_lq_spr_xucr0_cls;          // XUCR0[CLS] Mode enabled

   // Pervasive Error Report
   output                                 lq_pc_err_l2credit_overrun;

   // Pervasive


   inout                                  vdd;
   inout                                  gnd;

   input                                  clk;
   input                                  rst;
   input                                  sg_0;
   input                                  func_sl_thold_0_b;
   input                                  func_sl_force;
   input                                  func_slp_sl_thold_0_b;
   input                                  func_slp_sl_force;
   input                                  d_mode_dc;
   input                                  delay_lclkr_dc;
   input                                  mpw1_dc_b;
   input                                  mpw2_dc_b;

   (* pin_data="PIN_FUNCTION=/SCAN_IN/" *)

   input                                  scan_in;

   (* pin_data="PIN_FUNCTION=/SCAN_OUT/" *)

   output                                 scan_out;

   //--------------------------
   // signals
   //--------------------------

   wire [0:2]                             lsq_dat_stq1_op_size_int;
   wire [52:63]                           ldq_dat_stq1_addr_int;
   wire [0:`THREADS-1]                    ldq_stq1_thrd_id;
   wire [64-`REAL_IFAR_WIDTH:63]          ldq_stq_stq1_addr;
   wire                                   ldq_stq_stq1_le_mode;
   wire                                   req_l2_val_d;
   wire                                   req_l2_val_q;
   wire                                   req_l2_ld_sent_d;
   wire                                   req_l2_ld_sent_q;
   wire [0:3]                             req_sel_usrDef_d;
   wire [0:3]                             req_sel_usrDef_q;
   wire [0:15]                            req_sel_byteEn_d;
   wire [0:15]                            req_sel_byteEn_q;
   wire [0:4]                             req_sel_wimge_d;
   wire [0:4]                             req_sel_wimge_q;
   wire [64-`REAL_IFAR_WIDTH:63]          req_sel_p_addr_d;
   wire [64-`REAL_IFAR_WIDTH:63]          req_sel_p_addr_q;
   wire [0:5]                             req_sel_ttype_d;
   wire [0:5]                             req_sel_ttype_q;
   wire [0:1]                             req_sel_tid_d;
   wire [0:1]                             req_sel_tid_q;
   wire [0:2]                             req_sel_opSize_d;
   wire [0:2]                             req_sel_opSize_q;
   wire [0:4]                             req_sel_cTag_d;
   wire [0:4]                             req_sel_cTag_q;
   wire [0:3]                             unit_req_sel_usrDef;
   wire [0:4]                             unit_req_sel_wimge;
   wire [64-`REAL_IFAR_WIDTH:63]          unit_req_sel_p_addr;
   wire [0:5]                             unit_req_sel_ttype;
   wire [0:1]                             unit_req_sel_tid;
   wire [0:2]                             unit_req_sel_opSize;
   wire [0:4]                             unit_req_sel_cTag;
   wire [0:3]                             unit_req_val;
   wire [0:3]                             unit_last_sel_d;
   wire [0:3]                             unit_last_sel_q;
   wire [0:3]                             queue_unit_sel;
   wire                                   req_l2_sent;
   wire                                   req_l2_ld_pwrToken;
   wire                                   req_l2_ld_val;
   wire                                   req_l2_st_val;
   wire                                   req_l2_act;
   wire                                   ld_type_credAvail;
   wire                                   st_type_credAvail;
   wire                                   st_req_noCreds;
   wire                                   st_req_2inpipe;
   wire                                   st_req_1inpipe;
   wire                                   st_req_0Creds;
   wire                                   st2_req_val;
   wire                                   st3_req_val;
   wire                                   mmq1_req_val;
   wire                                   mmq2_req_val_d;
   wire                                   mmq2_req_val_q;
   wire                                   mmq3_req_val_d;
   wire                                   mmq3_req_val_q;
   wire                                   stq4_data_override_d;
   wire                                   stq4_data_override_q;
   wire                                   stq2_req_val_d;
   wire                                   stq2_req_val_q;
   wire                                   stq3_icswx_val;
   wire [64-`REAL_IFAR_WIDTH:63]          req_l2_st_p_addr;
   wire [0:4]                             req_l2_st_wimge;
   wire [0:3]                             req_l2_st_usrDef;
   wire [0:5]                             req_l2_st_ttype;
   wire [0:1]                             req_l2_st_tid;
   wire [0:2]                             req_l2_st_opSize;
   wire                                   ld_st_noCred_flp_d;
   wire                                   ld_st_noCred_flp_q;
   wire                                   stq3_store_type_cmmt;
   wire                                   stq3_store_type_rej;
   wire                                   st_rej_hold_cred_d;
   wire                                   st_rej_hold_cred_q;
   wire                                   ld_noCred_hold_d;
   wire                                   ld_noCred_hold_q;
   wire                                   ld_noCred_release;
   wire                                   ld_pop_rcvd_d;
   wire                                   ld_pop_rcvd_q;
   wire                                   ld_cred_blk_rst;
   wire                                   ld_cred_blk_run;
   wire                                   ld_cred_blk_zero;
   wire [0:3]                             ld_cred_blk_decr;
   wire [0:3]                             ld_cred_blk_init;
   wire [0:3]                             ld_cred_blk_cnt_d;
   wire [0:3]                             ld_cred_blk_cnt_q;
   wire                                   load_req_sent;
   wire [0:4]                             load_cred_incr;
   wire [0:4]                             load_cred_decr;
   wire [0:1]                             load_cred_sel;
   wire [0:4]                             load_cred_cnt_d;
   wire [0:4]                             load_cred_cnt_q;
   wire                                   ld_cred_err_d;
   wire                                   ld_cred_err_q;
   wire                                   ld_req_0Creds;
   wire                                   ld_req_noCreds;
   wire                                   store_req_sent;
   wire [0:5]                             store_cred_incr;
   wire [0:5]                             store_cred_incr2;
   wire [0:5]                             store_cred_decr;
   wire [0:2]                             store_cred_sel;
   wire [0:5]                             store_cred_cnt_d;
   wire [0:5]                             store_cred_cnt_q;
   wire                                   st_cred_err_d;
   wire                                   st_cred_err_q;
   wire [0:26]                            stq4_req_st_data_d;
   wire [0:26]                            stq4_req_st_data_q;
   wire [0:127]                           req_l2_st_data;
   wire [0:143]                           stq2_store_data;
   wire [0:127]                           stq2_store_data_d;
   wire [0:127]                           stq2_store_data_q;
   wire [0:15]                            stq2_store_parity;
   wire [0:143]                           rel2_wrt_data;
   wire                                   spr_lsucr0_b2b_d;
   wire                                   spr_lsucr0_b2b_q;
   wire                                   spr_xucr0_cred_d;
   wire                                   spr_xucr0_cred_q;
   wire                                   spr_xucr0_cls_d;
   wire                                   spr_xucr0_cls_q;
   wire                                   st_b2b_st_dis;
   wire                                   ld_b2b_ld_dis;
   wire                                   stq1_stg_act;
   wire                                   lsq_l2credit_overrun;
   wire [0:4]                             ld_cred_max;
   wire [0:5]                             st_cred_max;

   //--------------------------
   // constants
   //--------------------------

   parameter                              req_l2_val_offset = 0;
   parameter                              req_l2_ld_sent_offset = req_l2_val_offset + 1;
   parameter                              req_sel_usrDef_offset = req_l2_ld_sent_offset + 1;
   parameter                              req_sel_byteEn_offset = req_sel_usrDef_offset + 4;
   parameter                              req_sel_wimge_offset = req_sel_byteEn_offset + 16;
   parameter                              req_sel_p_addr_offset = req_sel_wimge_offset + 5;
   parameter                              req_sel_ttype_offset = req_sel_p_addr_offset + `REAL_IFAR_WIDTH;
   parameter                              req_sel_tid_offset = req_sel_ttype_offset + 6;
   parameter                              req_sel_opSize_offset = req_sel_tid_offset + 2;
   parameter                              req_sel_cTag_offset = req_sel_opSize_offset + 3;
   parameter                              unit_last_sel_offset = req_sel_cTag_offset + 5;
   parameter                              load_cred_cnt_offset = unit_last_sel_offset + 4;
   parameter                              ld_cred_err_offset = load_cred_cnt_offset + 5;
   parameter                              ld_st_noCred_flp_offset = ld_cred_err_offset + 1;
   parameter                              st_rej_hold_cred_offset = ld_st_noCred_flp_offset + 1;
   parameter                              ld_noCred_hold_offset = st_rej_hold_cred_offset + 1;
   parameter                              ld_pop_rcvd_offset = ld_noCred_hold_offset + 1;
   parameter                              ld_cred_blk_cnt_offset = ld_pop_rcvd_offset + 1;
   parameter                              store_cred_cnt_offset = ld_cred_blk_cnt_offset + 4;
   parameter                              st_cred_err_offset = store_cred_cnt_offset + 6;
   parameter                              spr_lsucr0_b2b_offset = st_cred_err_offset + 1;
   parameter                              spr_xucr0_cred_offset = spr_lsucr0_b2b_offset + 1;
   parameter                              spr_xucr0_cls_offset = spr_xucr0_cred_offset + 1;
   parameter                              stq2_req_val_offset = spr_xucr0_cls_offset + 1;
   parameter                              mmq2_req_val_offset = stq2_req_val_offset + 1;
   parameter                              mmq3_req_val_offset = mmq2_req_val_offset + 1;
   parameter                              stq4_data_override_offset = mmq3_req_val_offset + 1;
   parameter                              stq4_req_st_data_offset = stq4_data_override_offset + 1;
   parameter                              stq2_store_data_offset = stq4_req_st_data_offset + 27;
   parameter                              scan_right = stq2_store_data_offset + 128 - 1;

   wire                                   tiup;
   wire [0:scan_right]                    siv;
   wire [0:scan_right]                    sov;

   assign tiup = 1'b1;

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // LSU Config Bits
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   // LSUCR0[B2B] Back-2-Back allowed for same type of L2 request
   // 1 => Back-2-Back allowed
   // 0 => Back-2-Back not allowed, LSI Mode
   assign spr_lsucr0_b2b_d = ctl_lsq_spr_lsucr0_b2b;

   // XUCR0[CRED] L2 Credit Control
   // 1 => Can only send one load or store when there is 1 store credit and 1 load credit
   // 0 => No restrictions when there is 1 store credit and 1 load credit
   assign spr_xucr0_cred_d = xu_lq_spr_xucr0_cred;

   // XUCR0[CLS] 128 Byte Cacheline Enabled
   // 1 => 128 Byte Cacheline
   // 0 => 64 Byte Cacheline
   assign spr_xucr0_cls_d = xu_lq_spr_xucr0_cls;

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // Select Between LDQ and STQ Common
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // Reloads have higher priority than Commit Pipe

   assign lsq_ctl_stq1_axu_val = (ldq_arb_rel1_blk_store == 1'b1) ? ldq_arb_rel1_axu_val :
                                                                    stq_arb_stq1_axu_val;

   assign lsq_ctl_stq1_epid_val = stq_arb_stq1_epid_val & (~ldq_arb_rel1_blk_store);

   assign lsq_dat_stq1_op_size_int = (ldq_arb_rel1_blk_store == 1'b1) ? ldq_arb_rel1_op_size :
                                                                        stq_arb_stq1_opSize;

   assign ldq_stq_stq1_addr = (ldq_arb_rel1_blk_store == 1'b1) ? ldq_arb_rel1_addr :
                                                                 stq_arb_stq1_p_addr;

   assign lsq_ctl_stq1_ci = (ldq_arb_rel1_blk_store == 1'b1) ? ldq_arb_rel1_ci :
                                                               stq_arb_stq1_wimge_i;

   assign ldq_stq_stq1_le_mode = (ldq_arb_rel1_blk_store == 1'b1) ? ldq_arb_rel1_byte_swap :
                                                                    stq_arb_stq1_byte_swap;

   assign ldq_stq1_thrd_id = (ldq_arb_rel1_blk_store == 1'b1) ? ldq_arb_rel1_thrd_id :
                                                                stq_arb_stq1_thrd_id;

   assign ldq_dat_stq1_addr_int = ldq_stq_stq1_addr[52:63];

   assign lsq_dat_stq1_op_size = lsq_dat_stq1_op_size_int;
   assign lsq_dat_stq1_addr    = ldq_dat_stq1_addr_int[52:63];
   assign lsq_ctl_stq1_thrd_id = ldq_stq1_thrd_id;
   assign lsq_ctl_stq1_addr    = ldq_stq_stq1_addr[64 - `REAL_IFAR_WIDTH:63 - `CL_SIZE];
   assign lsq_dat_stq1_le_mode = ldq_stq_stq1_le_mode;
   assign stq1_stg_act         = ldq_arb_rel1_stg_act | stq_arb_stq1_stg_act;

   assign lsq_ctl_stq_release_itag_vld = stq_arb_release_itag_vld;
   assign lsq_ctl_stq_release_itag     = stq_arb_release_itag;
   assign lsq_ctl_stq_release_tid      = stq_arb_release_tid;

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // Store Data Muxing
   // Data that needs to be rotated or written to the cache
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   generate
      if (`STQ_DATA_SIZE == 128) begin : stqDat128
         // Select between L2 reload Data and Store Data
         assign stq2_store_data_d = (ldq_arb_rel1_data_sel == 1'b1) ? ldq_arb_rel1_data :
                                                                      stq_arb_stq1_store_data;
      end
   endgenerate

   generate
      if (`STQ_DATA_SIZE == 64) begin : stqDat64
         assign stq2_store_data_d[0:63] = ldq_arb_rel1_data[0:63];

         // Select between L2 reload Data and Store Data
         assign stq2_store_data_d[64:127] = (ldq_arb_rel1_data_sel == 1'b1) ? ldq_arb_rel1_data[64:127] :
                                                                              stq_arb_stq1_store_data[64:127];
      end
   endgenerate

   generate begin : parGen
         genvar t;
         for (t = 0; t <= 15; t = t + 1) begin : parGen
            assign stq2_store_parity[t] = ^(stq2_store_data_q[t * 8:(t * 8) + 7]);
         end
      end
   endgenerate

   assign rel2_wrt_data = {stq2_store_data_q, stq2_store_parity};

   // Select betweeen L2/Store and Reload Queue Data
   assign stq2_store_data = (ldq_arb_rel2_rdat_sel == 1'b1) ? ldq_arb_rel2_rd_data :
                                                              rel2_wrt_data;

   assign lsq_dat_stq2_store_data = stq2_store_data;
   assign arb_ldq_rel2_wrt_data  = rel2_wrt_data;

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // L2 Credit Control
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   // Need to flip the no credit available to ldq and stq when running in XUCR0[CRED] mode and there are no load credits or store credits
   // Cant send both load and store requests out, need to pick one, so will ping pong between load and store
   // Want to hold flp to point to load if the store was rejected and didnt commit to the L1/L2
   // 1 => Load Queue has no Credit
   // 0 => Store Queue has no Credit
   assign ld_st_noCred_flp_d   = spr_xucr0_cred_q & (~ld_st_noCred_flp_q | ld_noCred_hold_q);
   assign stq3_store_type_cmmt = stq_arb_stq3_cmmt_val | mmq3_req_val_q;
   assign stq3_store_type_rej  = stq_arb_stq3_cmmt_reject & ~mmq3_req_val_q;
   assign st_rej_hold_cred_d   = spr_xucr0_cred_q & (stq3_store_type_rej | (st_rej_hold_cred_q & ~stq_arb_stq3_cmmt_val));
   assign ld_noCred_hold_d     = spr_xucr0_cred_q & (load_req_sent | (ld_noCred_hold_q & ~ld_noCred_release));
   assign ld_noCred_release    = ld_pop_rcvd_q & ~|(ld_cred_blk_cnt_q) & ~st_rej_hold_cred_q;
   assign ld_pop_rcvd_d        = l2_lsq_req_ld_pop | (ld_pop_rcvd_q & ~load_req_sent);

   assign ld_cred_blk_rst      = spr_xucr0_cred_q & l2_lsq_req_ld_pop;
   assign ld_cred_blk_run      = |(ld_cred_blk_cnt_q);
   assign ld_cred_blk_zero     = stq3_store_type_cmmt | stq3_store_type_rej;
   assign ld_cred_blk_decr     = ld_cred_blk_cnt_q - 4'b0001;
   assign ld_cred_blk_init     = {1'b1, spr_xucr0_cls_q, 2'b00};
   assign ld_cred_blk_cnt_d    = ld_cred_blk_rst  ? ld_cred_blk_init :
                                 ld_cred_blk_zero ? 4'b0000 :
                                 ld_cred_blk_run  ? ld_cred_blk_decr :
                                 ld_cred_blk_cnt_q;

   // Load Credit Control
   assign load_req_sent  = |(unit_req_val);
   assign load_cred_incr = load_cred_cnt_q + 5'b00001;
   assign load_cred_decr = load_cred_cnt_q - 5'b00001;
   assign load_cred_sel  = {l2_lsq_req_ld_pop, load_req_sent};

   assign load_cred_cnt_d = (load_cred_sel == 2'b10) ? load_cred_incr :
                            (load_cred_sel == 2'b01) ? load_cred_decr :
                                                       load_cred_cnt_q;

   assign ld_req_0Creds     = (load_cred_cnt_q == 5'b00000);
   assign ld_req_noCreds    = ld_req_0Creds | (spr_xucr0_cred_q & (st_req_0Creds | st_req_1inpipe | st_req_2inpipe | ld_st_noCred_flp_q));
   assign ld_type_credAvail = ~(ld_req_noCreds | ld_b2b_ld_dis);
   assign ld_cred_max       = 5'd`LOAD_CREDITS;
   assign ld_cred_err_d     = (load_cred_cnt_q > ld_cred_max);
   assign ld_b2b_ld_dis     = req_l2_ld_sent_q & (~spr_lsucr0_b2b_q);

   // Store Credit Control
   assign store_req_sent   = stq_arb_stq3_req_val | mmq3_req_val_q;
   assign store_cred_incr  = store_cred_cnt_q + 6'b00001;
   assign store_cred_incr2 = store_cred_cnt_q + 6'b00010;
   assign store_cred_decr  = store_cred_cnt_q - 6'b00001;
   assign store_cred_sel   = {l2_lsq_req_st_pop, l2_lsq_req_st_gather, store_req_sent};

   //000 store_cred_cnt_q
   //001 store_cred_decr
   //010 store_cred_incr
   //011 store_cred_cnt_q
   //100 store_cred_incr
   //101 store_cred_cnt_q
   //110 store_cred_incr2
   //111 store_cred_incr

   assign store_cred_cnt_d = (store_cred_sel == 3'b001) ? store_cred_decr :
                             (store_cred_sel == 3'b110) ? store_cred_incr2 :
                             (store_cred_sel == 3'b000) ? store_cred_cnt_q :
                             (store_cred_sel == 3'b011) ? store_cred_cnt_q :
                             (store_cred_sel == 3'b101) ? store_cred_cnt_q :
                                                          store_cred_incr;

   assign st_cred_max       = 6'd`STORE_CREDITS;
   assign st_cred_err_d     = (store_cred_cnt_q > st_cred_max);
   assign st_req_2inpipe    = (store_cred_cnt_q == 6'b000010) & st2_req_val & st3_req_val;
   assign st_req_1inpipe    = (store_cred_cnt_q == 6'b000001) & (st2_req_val ^ st3_req_val);
   assign st_req_0Creds     = (store_cred_cnt_q == 6'b000000);
   assign st_req_noCreds    = st_req_0Creds | st_req_1inpipe | st_req_2inpipe | (spr_xucr0_cred_q & (ld_req_0Creds | ~ld_st_noCred_flp_q));
   assign st_type_credAvail = ~(st_req_noCreds | st_b2b_st_dis);
   assign st2_req_val       = mmq2_req_val_q | stq2_req_val_q;
   assign st3_req_val       = (mmq3_req_val_q | stq_arb_stq3_req_val);
   assign stq2_req_val_d    = stq_arb_st_req_avail & (~mmq1_req_val);
   assign stq3_icswx_val    = (stq_arb_stq3_ttype[0:4] == 5'b10011);
   assign st_b2b_st_dis     = st2_req_val & (~spr_lsucr0_b2b_q);

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // L2 Request Arbiter
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   // Need to block off request when store request is about to be sent to L2
   assign unit_req_val[0] = ldq_arb_ld_req_avail & ld_type_credAvail & (~req_l2_st_val);
   assign unit_req_val[1] = imq_arb_iuq_ld_req_avail & ld_type_credAvail & (~req_l2_st_val);
   assign unit_req_val[2] = imq_arb_mmq_ld_req_avail & ld_type_credAvail & (~req_l2_st_val);
   assign unit_req_val[3] = 1'b0;

   assign queue_unit_sel[0] = (unit_last_sel_q[0] & (~(|(unit_req_val[1:3]))) & unit_req_val[0]) |
                              (unit_last_sel_q[1] & (~(|(unit_req_val[2:3]))) & unit_req_val[0]) |
                              (unit_last_sel_q[2] & (~unit_req_val[3])        & unit_req_val[0]) |
                              (unit_last_sel_q[3] & unit_req_val[0]);

   assign queue_unit_sel[1] = (unit_last_sel_q[0]                                                  & unit_req_val[1]) |
                              (unit_last_sel_q[1] & (~(|(({unit_req_val[0], unit_req_val[2:3]})))) & unit_req_val[1]) |
                              (unit_last_sel_q[2] & (~(|(({unit_req_val[0], unit_req_val[3]}))))   & unit_req_val[1]) |
                              (unit_last_sel_q[3] & (~unit_req_val[0])                             & unit_req_val[1]);

   assign queue_unit_sel[2] = (unit_last_sel_q[0] & (~unit_req_val[1])                             & unit_req_val[2]) |
                              (unit_last_sel_q[1]                                                  & unit_req_val[2]) |
                              (unit_last_sel_q[2] & (~(|(({unit_req_val[0:1], unit_req_val[3]})))) & unit_req_val[2]) |
                              (unit_last_sel_q[3] & (~(|(unit_req_val[0:1])))                      & unit_req_val[2]);

   assign queue_unit_sel[3] = (unit_last_sel_q[0] & (~(|(unit_req_val[1:2]))) & unit_req_val[3]) |
                              (unit_last_sel_q[1] & (~unit_req_val[2])        & unit_req_val[3]) |
                              (unit_last_sel_q[2]                             & unit_req_val[3]) |
                              (unit_last_sel_q[3] & (~(|(unit_req_val[0:2]))) & unit_req_val[3]);

   assign unit_last_sel_d = (req_l2_sent == 1'b1) ? queue_unit_sel :
                                                    unit_last_sel_q;

   // Unit Select
   assign unit_req_sel_usrDef = (ldq_arb_usr_def     & {4{queue_unit_sel[0]}}) |
                                (imq_arb_iuq_usr_def & {4{queue_unit_sel[1]}}) |
                                (imq_arb_mmq_usr_def & {4{queue_unit_sel[2]}});

   assign unit_req_sel_wimge = (ldq_arb_wimge     & {5{queue_unit_sel[0]}}) |
                               (imq_arb_iuq_wimge & {5{queue_unit_sel[1]}}) |
                               (imq_arb_mmq_wimge & {5{queue_unit_sel[2]}});

   assign unit_req_sel_p_addr = (ldq_arb_p_addr     & {`REAL_IFAR_WIDTH{queue_unit_sel[0]}}) |
                                (imq_arb_iuq_p_addr & {`REAL_IFAR_WIDTH{queue_unit_sel[1]}}) |
                                (imq_arb_mmq_p_addr & {`REAL_IFAR_WIDTH{queue_unit_sel[2]}});

   assign unit_req_sel_ttype = (ldq_arb_ttype     & {6{queue_unit_sel[0]}}) |
                               (imq_arb_iuq_ttype & {6{queue_unit_sel[1]}}) |
                               (imq_arb_mmq_ttype & {6{queue_unit_sel[2]}});

   assign unit_req_sel_tid = (ldq_arb_tid     & {2{queue_unit_sel[0]}}) |
                             (imq_arb_iuq_tid & {2{queue_unit_sel[1]}}) |
                             (imq_arb_mmq_tid & {2{queue_unit_sel[2]}});

   assign unit_req_sel_opSize = (ldq_arb_opSize     & {3{queue_unit_sel[0]}}) |
                                (imq_arb_iuq_opSize & {3{queue_unit_sel[1]}}) |
                                (imq_arb_mmq_opSize & {3{queue_unit_sel[2]}});

   assign unit_req_sel_cTag = (ldq_arb_cTag     & {5{queue_unit_sel[0]}}) |
                              (imq_arb_iuq_cTag & {5{queue_unit_sel[1]}}) |
                              (imq_arb_mmq_cTag & {5{queue_unit_sel[2]}});

   assign req_l2_sent = |(queue_unit_sel);
   assign req_l2_ld_pwrToken = (ldq_arb_ld_req_pwrToken | imq_arb_iuq_ld_req_avail | imq_arb_mmq_ld_req_avail) & ld_type_credAvail;
   assign req_l2_ld_val = (ldq_arb_ld_req_avail | imq_arb_iuq_ld_req_avail | imq_arb_mmq_ld_req_avail) & ld_type_credAvail;
   assign req_l2_ld_sent_d = req_l2_ld_val;
   assign req_l2_st_val = (stq_arb_stq3_req_val | mmq3_req_val_q);
   assign req_l2_val_d = req_l2_ld_val | stq_arb_stq3_req_val | mmq3_req_val_q;
   assign req_l2_act = ldq_arb_ld_req_pwrToken | imq_arb_iuq_ld_req_avail | imq_arb_mmq_ld_req_avail | stq_arb_stq3_req_val | mmq3_req_val_q;
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // MMQ Store Type Request Delay
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   assign mmq1_req_val         = imq_arb_mmq_st_req_avail & st_type_credAvail & (~(mmq2_req_val_q | mmq3_req_val_q));
   assign mmq2_req_val_d       = mmq1_req_val;
   assign mmq3_req_val_d       = mmq2_req_val_q;
   assign stq4_data_override_d = mmq3_req_val_q | stq3_icswx_val;

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // Mux Between Store and other requests
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   assign req_l2_st_p_addr = (mmq3_req_val_q == 1'b0) ? stq_arb_stq3_p_addr :
                                                        imq_arb_mmq_p_addr;

   assign req_l2_st_wimge = (mmq3_req_val_q == 1'b0) ? stq_arb_stq3_wimge :
                                                       imq_arb_mmq_wimge;

   assign req_l2_st_usrDef = (mmq3_req_val_q == 1'b0) ? stq_arb_stq3_usrDef :
                                                        imq_arb_mmq_usr_def;

   assign req_sel_byteEn_d = stq_arb_stq3_byteEn & {16{(~mmq3_req_val_q)}};

   assign req_l2_st_ttype = (mmq3_req_val_q == 1'b0) ? stq_arb_stq3_ttype :
                                                       imq_arb_mmq_ttype;

   assign req_l2_st_tid = (mmq3_req_val_q == 1'b0) ? stq_arb_stq3_tid :
                                                     imq_arb_mmq_tid;

   assign req_l2_st_opSize = stq_arb_stq3_opSize & {3{(~mmq3_req_val_q)}};

   assign req_sel_p_addr_d = (req_l2_st_val == 1'b1) ? req_l2_st_p_addr :
                                                       unit_req_sel_p_addr;

   assign req_sel_wimge_d = (req_l2_st_val == 1'b1) ? req_l2_st_wimge :
                                                      unit_req_sel_wimge;

   assign req_sel_usrDef_d = (req_l2_st_val == 1'b1) ? req_l2_st_usrDef :
                                                       unit_req_sel_usrDef;

   assign req_sel_ttype_d = (req_l2_st_val == 1'b1) ? req_l2_st_ttype :
                                                      unit_req_sel_ttype;

   assign req_sel_tid_d = (req_l2_st_val == 1'b1) ? req_l2_st_tid :
                                                    unit_req_sel_tid;

   assign req_sel_opSize_d = (req_l2_st_val == 1'b1) ? req_l2_st_opSize :
                                                       unit_req_sel_opSize;

   assign req_sel_cTag_d = (req_l2_st_val == 1'b1) ? stq_arb_stq3_cTag :
                                                     unit_req_sel_cTag;

   // Select between icswx and mmu request
   // ICSWX Store Data Format
   // (0:2)        => ~GS,PR,DS
   // (3:9)        => "0000000"
   // (10:31)      => RS(10:31)
   // (32:39)      => LPID
   // (40:41)      => "00"
   // (42:55)      => PID
   // TLBIVAX Store Data Format
   // (0:31)       => unusedBits
   // (32:39)      => LPAR_ID
   // (40:44)      => Reserved
   // (45:47)      => IND,GS,L
   // (48:55)      => unusedBits
   assign stq4_req_st_data_d[3:18] = (mmq3_req_val_q == 1'b1) ? imq_arb_mmq_st_data[0:15] :
                                                                ctl_lsq_stq3_icswx_data[3:18];

   assign stq4_req_st_data_d[0:2]   = ctl_lsq_stq3_icswx_data[0:2];
   assign stq4_req_st_data_d[19:26] = ctl_lsq_stq3_icswx_data[19:26];

   assign req_l2_st_data[32:55] = (stq4_data_override_q == 1'b0) ? dat_lsq_stq4_128data[32:55] :
                                                                   stq4_req_st_data_q[3:26];

   assign req_l2_st_data[0:2] = (stq4_data_override_q == 1'b0) ? dat_lsq_stq4_128data[0:2] :
                                                                 stq4_req_st_data_q[0:2];

   assign req_l2_st_data[3:9]    = dat_lsq_stq4_128data[3:9] & {7{(~stq4_data_override_q)}};
   assign req_l2_st_data[10:31]  = dat_lsq_stq4_128data[10:31];
   assign req_l2_st_data[56:127] = dat_lsq_stq4_128data[56:127];

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // Outputs
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   assign lsq_l2credit_overrun = ld_cred_err_q | st_cred_err_q;

   tri_direct_err_rpt #(.WIDTH(1)) err_rpt(
      .vd(vdd),
      .gd(gnd),
      .err_in(lsq_l2credit_overrun),
      .err_out(lq_pc_err_l2credit_overrun)
   );

   // Credits Available
   assign arb_stq_cred_avail = st_type_credAvail & (~imq_arb_mmq_st_req_avail);

   // Unit Selected to Send request to L2
   assign arb_ldq_ldq_unit_sel = queue_unit_sel[0];
   assign arb_imq_iuq_unit_sel = queue_unit_sel[1];
   assign arb_imq_mmq_unit_sel = queue_unit_sel[2] | mmq3_req_val_q;

   // L2 Request
   assign lsq_l2_pwrToken  = req_l2_ld_pwrToken | stq_arb_stq3_req_val | mmq3_req_val_q;
   assign lsq_l2_valid     = req_l2_val_q;
   assign lsq_l2_tid       = req_sel_tid_q;
   assign lsq_l2_p_addr    = req_sel_p_addr_q;
   assign lsq_l2_wimge     = req_sel_wimge_q;
   assign lsq_l2_usrDef    = req_sel_usrDef_q;
   assign lsq_l2_byteEn    = req_sel_byteEn_q;
   assign lsq_l2_ttype     = req_sel_ttype_q;
   assign lsq_l2_opSize    = req_sel_opSize_q;
   assign lsq_l2_coreTag   = req_sel_cTag_q;
   assign lsq_l2_dataToken = stq_arb_stq3_req_val | mmq3_req_val_q;
   assign lsq_l2_st_data   = req_l2_st_data;

   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
   // REGISTERS
   // XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) req_l2_val_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_l2_val_offset]),
      .scout(sov[req_l2_val_offset]),
      .din(req_l2_val_d),
      .dout(req_l2_val_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) req_l2_ld_sent_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_l2_ld_sent_offset]),
      .scout(sov[req_l2_ld_sent_offset]),
      .din(req_l2_ld_sent_d),
      .dout(req_l2_ld_sent_q)
   );


   tri_rlmreg_p #(.WIDTH(4), .INIT(0), .NEEDS_SRESET(1)) req_sel_usrDef_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_usrDef_offset:req_sel_usrDef_offset + 4 - 1]),
      .scout(sov[req_sel_usrDef_offset:req_sel_usrDef_offset + 4 - 1]),
      .din(req_sel_usrDef_d),
      .dout(req_sel_usrDef_q)
   );


   tri_rlmreg_p #(.WIDTH(16), .INIT(0), .NEEDS_SRESET(1)) req_sel_byteEn_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_byteEn_offset:req_sel_byteEn_offset + 16 - 1]),
      .scout(sov[req_sel_byteEn_offset:req_sel_byteEn_offset + 16 - 1]),
      .din(req_sel_byteEn_d),
      .dout(req_sel_byteEn_q)
   );


   tri_rlmreg_p #(.WIDTH(5), .INIT(0), .NEEDS_SRESET(1)) req_sel_wimge_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_wimge_offset:req_sel_wimge_offset + 5 - 1]),
      .scout(sov[req_sel_wimge_offset:req_sel_wimge_offset + 5 - 1]),
      .din(req_sel_wimge_d),
      .dout(req_sel_wimge_q)
   );


   tri_rlmreg_p #(.WIDTH(`REAL_IFAR_WIDTH), .INIT(0), .NEEDS_SRESET(1)) req_sel_p_addr_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_p_addr_offset:req_sel_p_addr_offset + `REAL_IFAR_WIDTH - 1]),
      .scout(sov[req_sel_p_addr_offset:req_sel_p_addr_offset + `REAL_IFAR_WIDTH - 1]),
      .din(req_sel_p_addr_d),
      .dout(req_sel_p_addr_q)
   );


   tri_rlmreg_p #(.WIDTH(6), .INIT(0), .NEEDS_SRESET(1)) req_sel_ttype_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_ttype_offset:req_sel_ttype_offset + 6 - 1]),
      .scout(sov[req_sel_ttype_offset:req_sel_ttype_offset + 6 - 1]),
      .din(req_sel_ttype_d),
      .dout(req_sel_ttype_q)
   );


   tri_rlmreg_p #(.WIDTH(2), .INIT(0), .NEEDS_SRESET(1)) req_sel_tid_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_tid_offset:req_sel_tid_offset + 2 - 1]),
      .scout(sov[req_sel_tid_offset:req_sel_tid_offset + 2 - 1]),
      .din(req_sel_tid_d),
      .dout(req_sel_tid_q)
   );


   tri_rlmreg_p #(.WIDTH(3), .INIT(0), .NEEDS_SRESET(1)) req_sel_opSize_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_opSize_offset:req_sel_opSize_offset + 3 - 1]),
      .scout(sov[req_sel_opSize_offset:req_sel_opSize_offset + 3 - 1]),
      .din(req_sel_opSize_d),
      .dout(req_sel_opSize_q)
   );


   tri_rlmreg_p #(.WIDTH(5), .INIT(0), .NEEDS_SRESET(1)) req_sel_cTag_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[req_sel_cTag_offset:req_sel_cTag_offset + 5 - 1]),
      .scout(sov[req_sel_cTag_offset:req_sel_cTag_offset + 5 - 1]),
      .din(req_sel_cTag_d),
      .dout(req_sel_cTag_q)
   );


   tri_rlmreg_p #(.WIDTH(4), .INIT(1), .NEEDS_SRESET(1)) unit_last_sel_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[unit_last_sel_offset:unit_last_sel_offset + 4 - 1]),
      .scout(sov[unit_last_sel_offset:unit_last_sel_offset + 4 - 1]),
      .din(unit_last_sel_d),
      .dout(unit_last_sel_q)
   );


   tri_rlmreg_p #(.WIDTH(5), .INIT(`LOAD_CREDITS), .NEEDS_SRESET(1)) load_cred_cnt_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[load_cred_cnt_offset:load_cred_cnt_offset + 5 - 1]),
      .scout(sov[load_cred_cnt_offset:load_cred_cnt_offset + 5 - 1]),
      .din(load_cred_cnt_d),
      .dout(load_cred_cnt_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) ld_cred_err_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[ld_cred_err_offset]),
      .scout(sov[ld_cred_err_offset]),
      .din(ld_cred_err_d),
      .dout(ld_cred_err_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) ld_st_noCred_flp_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[ld_st_noCred_flp_offset]),
      .scout(sov[ld_st_noCred_flp_offset]),
      .din(ld_st_noCred_flp_d),
      .dout(ld_st_noCred_flp_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) st_rej_hold_cred_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[st_rej_hold_cred_offset]),
      .scout(sov[st_rej_hold_cred_offset]),
      .din(st_rej_hold_cred_d),
      .dout(st_rej_hold_cred_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) ld_noCred_hold_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[ld_noCred_hold_offset]),
      .scout(sov[ld_noCred_hold_offset]),
      .din(ld_noCred_hold_d),
      .dout(ld_noCred_hold_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) ld_pop_rcvd_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[ld_pop_rcvd_offset]),
      .scout(sov[ld_pop_rcvd_offset]),
      .din(ld_pop_rcvd_d),
      .dout(ld_pop_rcvd_q)
   );

   tri_rlmreg_p #(.WIDTH(4), .INIT(0), .NEEDS_SRESET(1)) ld_cred_blk_cnt_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[ld_cred_blk_cnt_offset:ld_cred_blk_cnt_offset + 4 - 1]),
      .scout(sov[ld_cred_blk_cnt_offset:ld_cred_blk_cnt_offset + 4 - 1]),
      .din(ld_cred_blk_cnt_d),
      .dout(ld_cred_blk_cnt_q)
   );

   tri_rlmreg_p #(.WIDTH(6), .INIT(`STORE_CREDITS), .NEEDS_SRESET(1)) store_cred_cnt_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[store_cred_cnt_offset:store_cred_cnt_offset + 6 - 1]),
      .scout(sov[store_cred_cnt_offset:store_cred_cnt_offset + 6 - 1]),
      .din(store_cred_cnt_d),
      .dout(store_cred_cnt_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) st_cred_err_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[st_cred_err_offset]),
      .scout(sov[st_cred_err_offset]),
      .din(st_cred_err_d),
      .dout(st_cred_err_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) spr_lsucr0_b2b_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[spr_lsucr0_b2b_offset]),
      .scout(sov[spr_lsucr0_b2b_offset]),
      .din(spr_lsucr0_b2b_d),
      .dout(spr_lsucr0_b2b_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) spr_xucr0_cred_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[spr_xucr0_cred_offset]),
      .scout(sov[spr_xucr0_cred_offset]),
      .din(spr_xucr0_cred_d),
      .dout(spr_xucr0_cred_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) spr_xucr0_cls_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[spr_xucr0_cls_offset]),
      .scout(sov[spr_xucr0_cls_offset]),
      .din(spr_xucr0_cls_d),
      .dout(spr_xucr0_cls_q)
   );

   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) stq2_req_val_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[stq2_req_val_offset]),
      .scout(sov[stq2_req_val_offset]),
      .din(stq2_req_val_d),
      .dout(stq2_req_val_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) mmq2_req_val_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[mmq2_req_val_offset]),
      .scout(sov[mmq2_req_val_offset]),
      .din(mmq2_req_val_d),
      .dout(mmq2_req_val_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) mmq3_req_val_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[mmq3_req_val_offset]),
      .scout(sov[mmq3_req_val_offset]),
      .din(mmq3_req_val_d),
      .dout(mmq3_req_val_q)
   );


   tri_rlmlatch_p #(.INIT(0), .NEEDS_SRESET(1)) stq4_data_override_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(tiup),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[stq4_data_override_offset]),
      .scout(sov[stq4_data_override_offset]),
      .din(stq4_data_override_d),
      .dout(stq4_data_override_q)
   );


   tri_rlmreg_p #(.WIDTH(27), .INIT(0), .NEEDS_SRESET(1)) stq4_req_st_data_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(req_l2_act),
      .force_t(func_slp_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_slp_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[stq4_req_st_data_offset:stq4_req_st_data_offset + 27 - 1]),
      .scout(sov[stq4_req_st_data_offset:stq4_req_st_data_offset + 27 - 1]),
      .din(stq4_req_st_data_d),
      .dout(stq4_req_st_data_q)
   );


   tri_rlmreg_p #(.WIDTH(128), .INIT(0), .NEEDS_SRESET(1)) stq2_store_data_reg(
      .vd(vdd),
      .gd(gnd),
      .clk(clk),
	.rst(rst),
      .act(stq1_stg_act),
      .force_t(func_sl_force),
      .d_mode(d_mode_dc),
      .delay_lclkr(delay_lclkr_dc),
      .mpw1_b(mpw1_dc_b),
      .mpw2_b(mpw2_dc_b),
      .thold_b(func_sl_thold_0_b),
      .sg(sg_0),
      .scin(siv[stq2_store_data_offset:stq2_store_data_offset + 128 - 1]),
      .scout(sov[stq2_store_data_offset:stq2_store_data_offset + 128 - 1]),
      .din(stq2_store_data_d),
      .dout(stq2_store_data_q)
   );

   assign siv[0:scan_right] = {sov[1:scan_right], scan_in};
   assign scan_out = sov[0];

endmodule