Initial commit of OpenSPARC T2 design and verification files.
[OpenSPARC-T2-DV] / verif / env / ilu_peu / vera / csr / ilupeuCSR.vr
CommitLineData
86530b38
AT
1// ========== Copyright Header Begin ==========================================
2//
3// OpenSPARC T2 Processor File: ilupeuCSR.vr
4// Copyright (C) 1995-2007 Sun Microsystems, Inc. All Rights Reserved
5// 4150 Network Circle, Santa Clara, California 95054, U.S.A.
6//
7// * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
8//
9// This program is free software; you can redistribute it and/or modify
10// it under the terms of the GNU General Public License as published by
11// the Free Software Foundation; version 2 of the License.
12//
13// This program is distributed in the hope that it will be useful,
14// but WITHOUT ANY WARRANTY; without even the implied warranty of
15// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16// GNU General Public License for more details.
17//
18// You should have received a copy of the GNU General Public License
19// along with this program; if not, write to the Free Software
20// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21//
22// For the avoidance of doubt, and except that if any non-GPL license
23// choice is available it will apply instead, Sun elects to use only
24// the General Public License version 2 (GPLv2) at this time for any
25// software where a choice of GPL license versions is made
26// available with the language indicating that GPLv2 or any later version
27// may be used, or where a choice of which version of the GPL is applied is
28// otherwise unspecified.
29//
30// Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
31// CA 95054 USA or visit www.sun.com if you need additional information or
32// have any questions.
33//
34// ========== Copyright Header End ============================================
35#include "CCCXactor.vrh"
36
37class ilupeuCSR {
38
39 local integer offset;
40
41 protected ReportClass _report;
42
43 CSRCollection CSR;
44
45 // Declare csr transactor
46 CCCXactor CSRRingXactor;
47
48 // Declare access methods
49 StubAccessMethod StubMethod;
50 OmniAccessMethod OmniMethod;
51 DaemonAccessMethod DaemonMethod;
52 // Need 3 access methods for the 3 different "rings"
53 CCCAccessMethod PioFastMethod;
54 CCCAccessMethod PioMedMethod;
55 CCCAccessMethod PioSlowMethod;
56 CCCAccessMethod JTAGMethod;
57
58 CSRAccessMethod ilupeuMethodArray[];
59
60 task new(ReportClass a_rpt);
61
62 // Tasks for changing access methods based on fast,med,slow
63 task set_ILU_default_access_methods(integer method);
64 task set_PTL_default_access_methods(integer method);
65 task set_LPU_default_access_methods(integer method);
66
67}
68
69task ilupeuCSR::new (ReportClass a_rpt) {
70 _report = a_rpt;
71
72 // Instantiate transactor
73 CSRRingXactor = new(RingXactorDataInBind, RingXactorDataOutBind, _report, 1);
74
75 StubMethod = new;
76 OmniMethod = new(0); // index=0, not used?
77 DaemonMethod = new(0); // index=0, not used?
78 // change timeouts for the 3 methods?
79
80 PioFastMethod = new(_report, CSRRingXactor, 3, 500, 1); // bus id = 3, timeout = 50
81 PioMedMethod = new(_report, CSRRingXactor, 2, 500, 1); // bus id = 2, timeout = 50
82 PioSlowMethod = new(_report, CSRRingXactor, 1, 500, 1); // bus id = 1, timeout = 50
83 JTAGMethod = new(_report, CSRRingXactor, 0, 500, 1); // bus id = 0, timeout = 50
84
85 ilupeuMethodArray[CSRT_STUB] = StubMethod;
86 ilupeuMethodArray[CSRT_OMNI] = OmniMethod;
87 ilupeuMethodArray[CSRT_DAEMON] = DaemonMethod;
88 ilupeuMethodArray[FIRE_PIO_FAST] = PioFastMethod;
89 ilupeuMethodArray[FIRE_PIO_MED] = PioMedMethod;
90 ilupeuMethodArray[FIRE_PIO_SLOW] = PioSlowMethod;
91 ilupeuMethodArray[FIRE_JTAG] = JTAGMethod;
92
93 CSR = new(ilupeuMethodArray);
94}
95
96task ilupeuCSR::set_ILU_default_access_methods (integer method) {
97CSR.fire_dlc_ilu_cib_csr_a_pec_int_en.set_default_access_method(method);
98CSR.fire_dlc_ilu_cib_csr_a_pec_en_err.set_default_access_method(method);
99CSR.fire_dlc_ilu_cib_csr_a_ilu_int_en.set_default_access_method(method);
100CSR.fire_dlc_ilu_cib_csr_a_ilu_log_en.set_default_access_method(method);
101CSR.fire_dlc_ilu_cib_csr_a_ilu_en_err.set_default_access_method(method);
102CSR.fire_dlc_ilu_cib_csr_a_ilu_log_err_rw1c_alias.set_default_access_method(method);
103CSR.fire_dlc_ilu_cib_csr_a_ilu_log_err_rw1s_alias.set_default_access_method(method);
104CSR.fire_dlc_ilu_cib_csr_a_ilu_diagnos.set_default_access_method(method);
105}
106
107task ilupeuCSR::set_PTL_default_access_methods (integer method) {
108CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ici.set_default_access_method(method);
109CSR.fire_plc_tlu_ctb_tlr_csr_a_replay_tim_thresh.set_default_access_method(method);
110CSR.fire_plc_tlu_ctb_tlr_csr_a_slt_cap.set_default_access_method(method);
111CSR.fire_plc_tlu_ctb_tlr_csr_a_link_cfg.set_default_access_method(method);
112CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_icr.set_default_access_method(method);
113CSR.fire_plc_tlu_ctb_tlr_csr_a_force_ltssm.set_default_access_method(method);
114CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_log.set_default_access_method(method);
115CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_int_en.set_default_access_method(method);
116CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_err_rw1s_alias.set_default_access_method(method);
117CSR.fire_plc_tlu_ctb_tlr_csr_a_lnk_sts.set_default_access_method(method);
118CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_log_en.set_default_access_method(method);
119CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_int_en.set_default_access_method(method);
120CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_err_rw1c_alias.set_default_access_method(method);
121CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_en_err.set_default_access_method(method);
122CSR.fire_plc_tlu_ctb_tlr_csr_a_symbol_num.set_default_access_method(method);
123CSR.fire_plc_tlu_ctb_tlr_csr_a_replay_timer.set_default_access_method(method);
124CSR.fire_plc_tlu_ctb_tlr_csr_a_rue_hdr1.set_default_access_method(method);
125CSR.fire_plc_tlu_ctb_tlr_csr_a_rue_hdr2.set_default_access_method(method);
126CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prf0.set_default_access_method(method);
127CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prf1.set_default_access_method(method);
128CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_err_rw1s_alias.set_default_access_method(method);
129CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prf2.set_default_access_method(method);
130CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_int_en.set_default_access_method(method);
131CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_en_err.set_default_access_method(method);
132CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_sts.set_default_access_method(method);
133CSR.fire_plc_tlu_ctb_tlr_csr_a_tue_hdr1.set_default_access_method(method);
134CSR.fire_plc_tlu_ctb_tlr_csr_a_tue_hdr2.set_default_access_method(method);
135CSR.fire_plc_tlu_ctb_tlr_csr_a_dev_sts.set_default_access_method(method);
136CSR.fire_plc_tlu_ctb_tlr_csr_a_trn_off.set_default_access_method(method);
137CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_err_rw1c_alias.set_default_access_method(method);
138CSR.fire_plc_tlu_ctb_tlr_csr_a_roe_hdr1.set_default_access_method(method);
139CSR.fire_plc_tlu_ctb_tlr_csr_a_roe_hdr2.set_default_access_method(method);
140CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prfc.set_default_access_method(method);
141CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_log.set_default_access_method(method);
142CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_int_sts.set_default_access_method(method);
143CSR.fire_plc_tlu_ctb_tlr_csr_a_peu_dlpl_serdes_rev.set_default_access_method(method);
144CSR.fire_plc_tlu_ctb_tlr_csr_a_toe_hdr1.set_default_access_method(method);
145CSR.fire_plc_tlu_ctb_tlr_csr_a_toe_hdr2.set_default_access_method(method);
146CSR.fire_plc_tlu_ctb_tlr_csr_a_acknak_thresh.set_default_access_method(method);
147CSR.fire_plc_tlu_ctb_tlr_csr_a_ven_dllp_msg.set_default_access_method(method);
148CSR.fire_plc_tlu_ctb_tlr_csr_a_lane_skew.set_default_access_method(method);
149CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_int_en.set_default_access_method(method);
150CSR.fire_plc_tlu_ctb_tlr_csr_a_core_status.set_default_access_method(method);
151CSR.fire_plc_tlu_ctb_tlr_csr_a_lnk_cap.set_default_access_method(method);
152CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_en_err.set_default_access_method(method);
153CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_sts_clr_rw1s_alias.set_default_access_method(method);
154CSR.fire_plc_tlu_ctb_tlr_csr_a_lnk_ctl.set_default_access_method(method);
155CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_err_rw1s_alias.set_default_access_method(method);
156CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_pll.set_default_access_method(method);
157CSR.fire_plc_tlu_ctb_tlr_csr_a_acknak_timer.set_default_access_method(method);
158CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_sts_clr_rw1c_alias.set_default_access_method(method);
159CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_diag.set_default_access_method(method);
160CSR.fire_plc_tlu_ctb_tlr_csr_a_symbol_timer.set_default_access_method(method);
161CSR.fire_plc_tlu_ctb_tlr_csr_a_link_ctl.set_default_access_method(method);
162CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_err_rw1c_alias.set_default_access_method(method);
163CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_erb.set_default_access_method(method);
164CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ecc.set_default_access_method(method);
165CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_log.set_default_access_method(method);
166CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ctl.set_default_access_method(method);
167CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ecl.set_default_access_method(method);
168CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ica.set_default_access_method(method);
169CSR.fire_plc_tlu_ctb_tlr_csr_a_dev_cap.set_default_access_method(method);
170CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_dbg_sel_a.set_default_access_method(method);
171CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_dbg_sel_b.set_default_access_method(method);
172CSR.fire_plc_tlu_ctb_tlr_csr_a_dev_ctl.set_default_access_method(method);
173CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_xmitter_lane_ctl[offset].set_default_access_method(method);
174CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_receiver_lane_status[offset].set_default_access_method(method);
175CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_xmitter_lane_status[offset].set_default_access_method(method);
176CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_receiver_lane_ctl[offset].set_default_access_method(method);
177}
178
179task ilupeuCSR::set_LPU_default_access_methods (integer method) {
180}