You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1434 lines
56 KiB
Verilog

// © 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