8354 sync regcomp(3C) with upstream (fix make catalog)
[unleashed/tickless.git] / usr / src / uts / sun4u / montecarlo / sys / mct_topology.h
blob205e2e608fd64a6fc8b816102562ac91850ee442
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
7 * with the License.
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
20 * CDDL HEADER END
23 * Copyright (c) 1999, 2000 by Sun Microsystems, Inc.
24 * All rights reserved.
27 #ifndef _MONTECARLO_SYS_MCT_TOPOLOGY_H
28 #define _MONTECARLO_SYS_MCT_TOPOLOGY_H
30 #pragma ident "%Z%%M% %I% %E% SMI"
32 #ifdef __cplusplus
33 extern "C" {
34 #endif
37 * mct_topology.h
38 * MonteCarlo / Tonga topology structures and types for the scsb driver
39 * and its kstat structure "env_topology", to be available to applications
40 * like envmond and snmp agents.
43 * SCB information also defined in scsb.h, which file is not available to
44 * applications.
46 #define SCB_P10_NOK_LED_REGS 4
47 #define SCB_P10_OK_LED_REGS 4
48 #define SCB_P10_BLINK_LED_REGS 2
49 #define SCB_P10_LED_REGS 10
50 #define SCB_P15_NOK_LED_REGS 3
51 #define SCB_P15_OK_LED_REGS 3
52 #define SCB_P15_BLINK_LED_REGS 3
53 #define SCB_P15_LED_REGS 9
55 /* Save this existing definition, but use it as the MAX */
56 #define SCSB_LEDDATA_REGISTERS SCB_P10_LED_REGS
58 #define MC_MAX_SLOTS 8 /* CPU, ALRM, cPCI Slots */
59 #define MC_MAX_FAN 2
60 #define MC_MAX_PDU 2
61 #define MC_MAX_PS 2
62 #define MC_MAX_DISK 3
63 #define MC_MAX_SCB 1
64 #define MC_MAX_AC 1
65 #define MC_MAX_CFTM 1
66 #define MC_MAX_CRTM 1
67 #define MC_MAX_PRTM 1
69 #define TG_MAX_SLOTS 5 /* CPU, ALRM, cPCI Slots */
70 #define TG_MAX_FAN 2
71 #define TG_MAX_PS 1
72 #define TG_MAX_PDU 1
73 #define TG_MAX_DISK 1
74 #define TG_MAX_SCB 1
75 #define TG_MAX_AC 1
76 #define TG_MAX_CFTM 1
77 #define TG_MAX_CRTM 1
78 #define TG_MAX_PRTM 1
81 * Maximum number of FRUs in MCT systems,
82 * used for sizeof fru_id_table[] and index check
84 #define MCT_MAX_FRUS 32
87 * The I2C addresses of System I2C devices
88 * from "MonteCarlo: Programming Interface Specifications" Version 0.9
90 #define MCT_I2C_CPUPWR 0x72
91 #define MCT_I2C_FAN1 0x74
92 #define MCT_I2C_FAN2 0x76
93 #define MCT_I2C_FAN3 0x78
94 #define MCT_I2C_PS1 0x7c
95 #define MCT_I2C_PS2 0x7e
96 #define MCT_I2C_SCB 0x80
97 #define MCT_I2C_CPUTEMP 0x9e
100 * CFG1_MPID masks
102 #define SCTRL_MPID_MASK 0xf
103 #define SCTRL_MPID_HALF 0x0
104 #define SCTRL_MPID_QUARTER 0x1
105 #define SCTRL_MPID_QUARTER_NODSK 0x3
108 * Interrupt Event Codes
109 * Also used by "scsb" to locate fruid_table index,
110 * so the order is very important.
112 #define SCTRL_EVENT_NONE 0x0000
113 #define SCTRL_EVENT_SLOT1 0x00000001
114 #define SCTRL_EVENT_SLOT2 0x00000002
115 #define SCTRL_EVENT_SLOT3 0x00000004
116 #define SCTRL_EVENT_SLOT4 0x00000008
117 #define SCTRL_EVENT_SLOT5 0x00000010
118 #define SCTRL_EVENT_SLOT6 0x00000020
119 #define SCTRL_EVENT_SLOT7 0x00000040
120 #define SCTRL_EVENT_SLOT8 0x00000080
121 #define SCTRL_EVENT_SLOT9 0x00000100
122 #define SCTRL_EVENT_SLOT10 0x00000200
123 #define SCTRL_EVENT_PDU1 0x00000400
124 #define SCTRL_EVENT_PDU2 0x00000800
125 #define SCTRL_EVENT_PS1 0x00001000
126 #define SCTRL_EVENT_PS2 0x00002000
127 #define SCTRL_EVENT_DISK1 0x00004000
128 #define SCTRL_EVENT_DISK2 0x00008000
129 #define SCTRL_EVENT_DISK3 0x00010000
130 #define SCTRL_EVENT_FAN1 0x00020000
131 #define SCTRL_EVENT_FAN2 0x00040000
132 #define SCTRL_EVENT_FAN3 0x00080000
133 #define SCTRL_EVENT_ALARM 0x00100000
134 #define SCTRL_EVENT_SCB 0x00200000
135 #define SCTRL_EVENT_SSB 0x00400000
136 #define SCTRL_EVENT_CRTM 0x00800000
137 #define SCTRL_EVENT_CFTM 0x01000000
138 #define SCTRL_EVENT_PRTM 0x02000000
139 #define SCTRL_EVENT_PWRDWN 0x04000000
140 #define SCTRL_EVENT_REPLACE 0x08000000
141 #define SCTRL_EVENT_ALARM_INT 0x10000000
142 #define SCTRL_EVENT_ALARM_INSERTION 0x20000000
143 #define SCTRL_EVENT_ALARM_REMOVAL 0x40000000
144 #define SCTRL_EVENT_OTHER 0x80000000
148 typedef uchar_t topo_id_t;
149 typedef uchar_t fru_id_t;
150 typedef uint16_t fru_version_t;
151 typedef uint16_t fru_max_t;
152 typedef uint16_t scsb_unum_t;
154 typedef enum {
155 MCT_HEALTH_NA = 0,
156 MCT_HEALTH_OK = 1,
157 MCT_HEALTH_NOK = 2
158 } fru_health_t;
161 * Known MC/Tg Slot occupants, and UNKN for unknown
162 * NOTE: the CTC occupant is the CFTM FRU type on MonteCarlo
164 typedef enum {
165 OC_UNKN = 0,
166 OC_CPU = 1,
167 OC_AC = 2,
168 OC_BHS = 3,
169 OC_FHS = 4,
170 OC_HAHS = 5,
171 OC_QFE = 6,
172 OC_FRCH = 7,
173 OC_COMBO = 8,
174 OC_PMC = 9,
175 OC_ATM = 10,
176 OC_CTC = 11
177 } mct_slot_occupant_t;
179 typedef enum {
180 SLOT = 0,
181 PDU = 1,
182 PS = 2,
183 DISK = 3,
184 FAN = 4,
185 ALARM = 5,
186 SCB = 6,
187 SSB = 7,
188 CFTM = 8,
189 CRTM = 9,
190 PRTM = 10,
191 MIDPLANE = 11
192 } scsb_utype_t;
194 #define SCSB_UNIT_TYPES 11 /* w/o MIDPLANE */
196 typedef enum scsb_fru_status {
197 FRU_NOT_PRESENT,
198 FRU_PRESENT,
199 FRU_NOT_AVAILABLE
200 } scsb_fru_status_t;
202 typedef enum {
203 SWAP_NOT, SWAP_BASIC, SWAP_FULL, SWAP_HA
204 } cpci_swap_type_t;
206 typedef struct fru_options {
207 char *board_name;
208 cpci_swap_type_t swap_type;
209 struct fru_options *next;
210 } fru_options_t;
212 typedef struct fru_i2c_info {
213 uchar_t syscfg_reg;
214 uchar_t syscfg_bit;
215 uchar_t ledata_reg;
216 uchar_t ledata_bit;
217 uchar_t blink_reg;
218 uchar_t blink_bit;
219 } fru_i2c_info_t;
221 typedef struct fru_info {
222 scsb_fru_status_t fru_status; /* FRU present status */
223 scsb_unum_t fru_unit; /* FRU external unit number */
224 scsb_utype_t fru_type; /* also an index to FRU lists */
225 fru_id_t fru_id; /* I2C address, SCSIID, Slot Num */
226 fru_version_t fru_version; /* version number where possible */
227 fru_options_t *type_list; /* list of possible boards for slots */
228 fru_i2c_info_t *i2c_info; /* for I2C devices */
229 struct fru_info *next;
230 } fru_info_t;
232 struct system_info {
233 fru_info_t mid_plane; /* one always present */
234 fru_max_t max_units[SCSB_UNIT_TYPES];
235 fru_info_t *fru_info_list[SCSB_UNIT_TYPES];
239 * scsb kstat types
241 #define SCSB_KS_LEDDATA "scsb_leddata"
242 #define SCSB_KS_STATE "scsb_state"
243 #define SCSB_KS_EVC_REGISTER "scsb_evc_register"
244 #define SCSB_KS_TOPOLOGY "env_topology"
246 typedef struct ks_fru_info {
247 scsb_fru_status_t fru_status; /* FRU presence/availability status */
248 scsb_unum_t fru_unit; /* FRU external unit number */
249 scsb_utype_t fru_type; /* and occupant type for solts */
250 fru_id_t fru_id; /* I2C address, SCSIID, Slot Num */
251 fru_version_t fru_version; /* version number where possible */
252 fru_health_t fru_health; /* From NOK LED, if available */
253 } ks_fru_info_t;
255 typedef union scsb_leddata {
256 uchar_t scb_led_regs[SCSB_LEDDATA_REGISTERS];
257 union {
258 struct {
259 uchar_t nok_leds[SCB_P10_NOK_LED_REGS];
260 uchar_t ok_leds[SCB_P10_OK_LED_REGS];
261 uchar_t blink_leds[SCB_P10_BLINK_LED_REGS];
262 } p10;
263 struct {
264 uchar_t nok_leds[SCB_P15_NOK_LED_REGS];
265 uchar_t ok_leds[SCB_P15_OK_LED_REGS];
266 uchar_t blink_leds[SCB_P15_BLINK_LED_REGS];
267 } p15;
268 } leds;
269 } scsb_ks_leddata_t;
271 typedef struct {
272 uint8_t scb_present; /* SCB is present */
273 uint8_t ssb_present; /* SSB is present */
274 uint8_t scsb_frozen; /* SCB swap state */
275 uint8_t scsb_mode; /* driver access mode */
276 uint8_t unused_1;
277 uint8_t unused_2;
278 uint8_t unused_3;
279 uint8_t unused_4;
280 uint32_t event_code; /* event code bit map */
281 } scsb_ks_state_t;
283 typedef struct {
284 ks_fru_info_t mid_plane;
285 fru_max_t max_units[SCSB_UNIT_TYPES];
286 ks_fru_info_t mct_slots[MC_MAX_SLOTS];
287 ks_fru_info_t mct_pdu[MC_MAX_PDU];
288 ks_fru_info_t mct_ps[MC_MAX_PS];
289 ks_fru_info_t mct_disk[MC_MAX_DISK];
290 ks_fru_info_t mct_fan[MC_MAX_FAN];
291 ks_fru_info_t mct_scb[MC_MAX_SCB];
292 ks_fru_info_t mct_ssb[MC_MAX_SCB];
293 ks_fru_info_t mct_alarm[MC_MAX_AC];
294 ks_fru_info_t mct_cftm[MC_MAX_CFTM];
295 ks_fru_info_t mct_crtm[MC_MAX_CRTM];
296 ks_fru_info_t mct_prtm[MC_MAX_PRTM];
297 } mct_topology_t;
299 #ifdef __cplusplus
301 #endif
303 #endif /* _MONTECARLO_SYS_MCT_TOPOLOGY_H */