Commit | Line | Data |
---|---|---|
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 | ||
37 | class 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 | ||
69 | task 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 | ||
96 | task ilupeuCSR::set_ILU_default_access_methods (integer method) { | |
97 | CSR.fire_dlc_ilu_cib_csr_a_pec_int_en.set_default_access_method(method); | |
98 | CSR.fire_dlc_ilu_cib_csr_a_pec_en_err.set_default_access_method(method); | |
99 | CSR.fire_dlc_ilu_cib_csr_a_ilu_int_en.set_default_access_method(method); | |
100 | CSR.fire_dlc_ilu_cib_csr_a_ilu_log_en.set_default_access_method(method); | |
101 | CSR.fire_dlc_ilu_cib_csr_a_ilu_en_err.set_default_access_method(method); | |
102 | CSR.fire_dlc_ilu_cib_csr_a_ilu_log_err_rw1c_alias.set_default_access_method(method); | |
103 | CSR.fire_dlc_ilu_cib_csr_a_ilu_log_err_rw1s_alias.set_default_access_method(method); | |
104 | CSR.fire_dlc_ilu_cib_csr_a_ilu_diagnos.set_default_access_method(method); | |
105 | } | |
106 | ||
107 | task ilupeuCSR::set_PTL_default_access_methods (integer method) { | |
108 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ici.set_default_access_method(method); | |
109 | CSR.fire_plc_tlu_ctb_tlr_csr_a_replay_tim_thresh.set_default_access_method(method); | |
110 | CSR.fire_plc_tlu_ctb_tlr_csr_a_slt_cap.set_default_access_method(method); | |
111 | CSR.fire_plc_tlu_ctb_tlr_csr_a_link_cfg.set_default_access_method(method); | |
112 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_icr.set_default_access_method(method); | |
113 | CSR.fire_plc_tlu_ctb_tlr_csr_a_force_ltssm.set_default_access_method(method); | |
114 | CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_log.set_default_access_method(method); | |
115 | CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_int_en.set_default_access_method(method); | |
116 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_err_rw1s_alias.set_default_access_method(method); | |
117 | CSR.fire_plc_tlu_ctb_tlr_csr_a_lnk_sts.set_default_access_method(method); | |
118 | CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_log_en.set_default_access_method(method); | |
119 | CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_int_en.set_default_access_method(method); | |
120 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_err_rw1c_alias.set_default_access_method(method); | |
121 | CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_en_err.set_default_access_method(method); | |
122 | CSR.fire_plc_tlu_ctb_tlr_csr_a_symbol_num.set_default_access_method(method); | |
123 | CSR.fire_plc_tlu_ctb_tlr_csr_a_replay_timer.set_default_access_method(method); | |
124 | CSR.fire_plc_tlu_ctb_tlr_csr_a_rue_hdr1.set_default_access_method(method); | |
125 | CSR.fire_plc_tlu_ctb_tlr_csr_a_rue_hdr2.set_default_access_method(method); | |
126 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prf0.set_default_access_method(method); | |
127 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prf1.set_default_access_method(method); | |
128 | CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_err_rw1s_alias.set_default_access_method(method); | |
129 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prf2.set_default_access_method(method); | |
130 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_int_en.set_default_access_method(method); | |
131 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_en_err.set_default_access_method(method); | |
132 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_sts.set_default_access_method(method); | |
133 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tue_hdr1.set_default_access_method(method); | |
134 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tue_hdr2.set_default_access_method(method); | |
135 | CSR.fire_plc_tlu_ctb_tlr_csr_a_dev_sts.set_default_access_method(method); | |
136 | CSR.fire_plc_tlu_ctb_tlr_csr_a_trn_off.set_default_access_method(method); | |
137 | CSR.fire_plc_tlu_ctb_tlr_csr_a_oe_err_rw1c_alias.set_default_access_method(method); | |
138 | CSR.fire_plc_tlu_ctb_tlr_csr_a_roe_hdr1.set_default_access_method(method); | |
139 | CSR.fire_plc_tlu_ctb_tlr_csr_a_roe_hdr2.set_default_access_method(method); | |
140 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_prfc.set_default_access_method(method); | |
141 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_log.set_default_access_method(method); | |
142 | CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_int_sts.set_default_access_method(method); | |
143 | CSR.fire_plc_tlu_ctb_tlr_csr_a_peu_dlpl_serdes_rev.set_default_access_method(method); | |
144 | CSR.fire_plc_tlu_ctb_tlr_csr_a_toe_hdr1.set_default_access_method(method); | |
145 | CSR.fire_plc_tlu_ctb_tlr_csr_a_toe_hdr2.set_default_access_method(method); | |
146 | CSR.fire_plc_tlu_ctb_tlr_csr_a_acknak_thresh.set_default_access_method(method); | |
147 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ven_dllp_msg.set_default_access_method(method); | |
148 | CSR.fire_plc_tlu_ctb_tlr_csr_a_lane_skew.set_default_access_method(method); | |
149 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_int_en.set_default_access_method(method); | |
150 | CSR.fire_plc_tlu_ctb_tlr_csr_a_core_status.set_default_access_method(method); | |
151 | CSR.fire_plc_tlu_ctb_tlr_csr_a_lnk_cap.set_default_access_method(method); | |
152 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_en_err.set_default_access_method(method); | |
153 | CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_sts_clr_rw1s_alias.set_default_access_method(method); | |
154 | CSR.fire_plc_tlu_ctb_tlr_csr_a_lnk_ctl.set_default_access_method(method); | |
155 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_err_rw1s_alias.set_default_access_method(method); | |
156 | CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_pll.set_default_access_method(method); | |
157 | CSR.fire_plc_tlu_ctb_tlr_csr_a_acknak_timer.set_default_access_method(method); | |
158 | CSR.fire_plc_tlu_ctb_tlr_csr_a_event_err_sts_clr_rw1c_alias.set_default_access_method(method); | |
159 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_diag.set_default_access_method(method); | |
160 | CSR.fire_plc_tlu_ctb_tlr_csr_a_symbol_timer.set_default_access_method(method); | |
161 | CSR.fire_plc_tlu_ctb_tlr_csr_a_link_ctl.set_default_access_method(method); | |
162 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ce_err_rw1c_alias.set_default_access_method(method); | |
163 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_erb.set_default_access_method(method); | |
164 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ecc.set_default_access_method(method); | |
165 | CSR.fire_plc_tlu_ctb_tlr_csr_a_ue_log.set_default_access_method(method); | |
166 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ctl.set_default_access_method(method); | |
167 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ecl.set_default_access_method(method); | |
168 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_ica.set_default_access_method(method); | |
169 | CSR.fire_plc_tlu_ctb_tlr_csr_a_dev_cap.set_default_access_method(method); | |
170 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_dbg_sel_a.set_default_access_method(method); | |
171 | CSR.fire_plc_tlu_ctb_tlr_csr_a_tlu_dbg_sel_b.set_default_access_method(method); | |
172 | CSR.fire_plc_tlu_ctb_tlr_csr_a_dev_ctl.set_default_access_method(method); | |
173 | CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_xmitter_lane_ctl[offset].set_default_access_method(method); | |
174 | CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_receiver_lane_status[offset].set_default_access_method(method); | |
175 | CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_xmitter_lane_status[offset].set_default_access_method(method); | |
176 | CSR.fire_plc_tlu_ctb_tlr_csr_a_serdes_receiver_lane_ctl[offset].set_default_access_method(method); | |
177 | } | |
178 | ||
179 | task ilupeuCSR::set_LPU_default_access_methods (integer method) { | |
180 | } |